From 96b9d070280bb9c4b5155d41faf8b7823f155b3d Mon Sep 17 00:00:00 2001 From: Hyyan Abo Fakher Date: Mon, 4 Apr 2022 09:25:43 +0200 Subject: [PATCH] refactor: `GxOptions.setImmutableColumns` is deprecated BREAKING CHANGE: Grid Option 'immutableColumns' is now gone. Columns are immutable by default. --- GxOptions.bbj | 21 + client/dist/ag-grid-community.js | 79429 +++++----- client/dist/ag-grid-community.min.js | 8 +- client/dist/ag-grid-enterprise.js | 179222 +++++++++++++---------- client/dist/ag-grid-enterprise.min.js | 8 +- client/dist/bbj-grid-widget.js | 45344 +++--- client/dist/bbj-grid-widget.min.js | 512 +- client/dist/report.html | 6 +- client/package-lock.json | 12703 ++ client/package.json | 4 +- client/yarn.lock | 18 +- demo/ColumnsUpdate.bbj | 19 - 12 files changed, 185910 insertions(+), 131384 deletions(-) create mode 100644 client/package-lock.json diff --git a/GxOptions.bbj b/GxOptions.bbj index c2876e60..37a4a227 100644 --- a/GxOptions.bbj +++ b/GxOptions.bbj @@ -1133,6 +1133,27 @@ class public GxOptions rem * rem * @param BBjNumber enabled! true to enable , false to disable rem * + rem * @deprecated Columns are immutable by default. + rem */ + method public void setImmutableColumns(BBjNumber enabled!) + GxLogger.warn("since version 1.7.0, BBjGridExWidget.setImmutableColumns(BBjNumber enabled!) is deprecated. Columns are immutable by default.") + #ImmutableColumns! = 1 + methodend + rem /** + rem * Get DeltaColumn Mode value + rem * + rem * @return BBjNumber true when enabled , false otherwise + rem * + rem * @deprecated Columns are immutable by default. + rem */ + method public BBjNumber getDeltaColumnMode() + methodret 1 + methodend + rem /** + rem * Enable/disable DeltaColumn Mode + rem * + rem * @param BBjNumber enabled! true to enable , false to disable + rem * rem * @deprecated use `GxOptions.setImmutableColumns` instead rem */ method public void setDeltaColumnMode(BBjNumber enabled!) diff --git a/client/dist/ag-grid-community.js b/client/dist/ag-grid-community.js index 3e0793e7..627e0872 100644 --- a/client/dist/ag-grid-community.js +++ b/client/dist/ag-grid-community.js @@ -1,10 +1,10 @@ /** - * @ag-grid-community/all-modules - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/all-modules - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -// @ag-grid-community/all-modules v23.2.0 +// @ag-grid-community/all-modules v27.1.0 (function webpackUniversalModuleDefinition(root, factory) { if(typeof exports === 'object' && typeof module === 'object') module.exports = factory(); @@ -111,29 +111,29 @@ return /******/ (function(modules) { // webpackBootstrap */ var ClientSideRowModelModule = __webpack_require__(1); var GridCoreModule = __webpack_require__(3); -var CsvExportModule = __webpack_require__(211); -var InfiniteRowModelModule = __webpack_require__(218); -var agGrid = __webpack_require__(223); +var CsvExportModule = __webpack_require__(261); +var InfiniteRowModelModule = __webpack_require__(271); +var agGrid = __webpack_require__(276); Object.keys(agGrid).forEach(function(key) { exports[key] = agGrid[key]; }); agGrid.ModuleRegistry.register(ClientSideRowModelModule.ClientSideRowModelModule); agGrid.ModuleRegistry.register(CsvExportModule.CsvExportModule); agGrid.ModuleRegistry.register(InfiniteRowModelModule.InfiniteRowModelModule); -__webpack_require__(224); -__webpack_require__(228); -__webpack_require__(230); -__webpack_require__(232); -__webpack_require__(234); -__webpack_require__(236); -__webpack_require__(238); -__webpack_require__(240); -__webpack_require__(242); -__webpack_require__(244); -__webpack_require__(246); -__webpack_require__(248); -__webpack_require__(250); -__webpack_require__(252); +__webpack_require__(277); +__webpack_require__(281); +__webpack_require__(283); +__webpack_require__(285); +__webpack_require__(287); +__webpack_require__(289); +__webpack_require__(291); +__webpack_require__(293); +__webpack_require__(295); +__webpack_require__(297); +__webpack_require__(299); +__webpack_require__(301); +__webpack_require__(303); +__webpack_require__(305); /***/ }), /* 1 */ @@ -155,13 +155,13 @@ __webpack_require__.r(__webpack_exports__); __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ClientSideRowModelModule", function() { return ClientSideRowModelModule; }); /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3); -/* harmony import */ var _clientSideRowModel_clientSideRowModel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(203); -/* harmony import */ var _clientSideRowModel_filterStage__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(205); -/* harmony import */ var _clientSideRowModel_sortStage__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(206); -/* harmony import */ var _clientSideRowModel_flattenStage__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(207); -/* harmony import */ var _clientSideRowModel_sortService__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(208); -/* harmony import */ var _clientSideRowModel_filterService__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(209); -/* harmony import */ var _clientSideRowModel_immutableService__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(210); +/* harmony import */ var _clientSideRowModel_clientSideRowModel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(253); +/* harmony import */ var _clientSideRowModel_filterStage__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(255); +/* harmony import */ var _clientSideRowModel_sortStage__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(256); +/* harmony import */ var _clientSideRowModel_flattenStage__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(257); +/* harmony import */ var _clientSideRowModel_sortService__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(258); +/* harmony import */ var _clientSideRowModel_filterService__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(259); +/* harmony import */ var _clientSideRowModel_immutableService__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(260); @@ -183,46 +183,46 @@ var ClientSideRowModelModule = { "use strict"; __webpack_require__.r(__webpack_exports__); -/* WEBPACK VAR INJECTION */(function(global) {/* harmony import */ var _columnController_columnFactory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(5); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnFactory", function() { return _columnController_columnFactory__WEBPACK_IMPORTED_MODULE_0__["ColumnFactory"]; }); +/* WEBPACK VAR INJECTION */(function(global) {/* harmony import */ var _columns_columnFactory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(5); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnFactory", function() { return _columns_columnFactory__WEBPACK_IMPORTED_MODULE_0__["ColumnFactory"]; }); -/* harmony import */ var _columnController_columnController__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(42); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnController", function() { return _columnController_columnController__WEBPACK_IMPORTED_MODULE_1__["ColumnController"]; }); +/* harmony import */ var _columns_columnModel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(22); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnModel", function() { return _columns_columnModel__WEBPACK_IMPORTED_MODULE_1__["ColumnModel"]; }); -/* harmony import */ var _columnController_columnKeyCreator__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(6); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnKeyCreator", function() { return _columnController_columnKeyCreator__WEBPACK_IMPORTED_MODULE_2__["ColumnKeyCreator"]; }); +/* harmony import */ var _columns_columnKeyCreator__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(6); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnKeyCreator", function() { return _columns_columnKeyCreator__WEBPACK_IMPORTED_MODULE_2__["ColumnKeyCreator"]; }); -/* harmony import */ var _columnController_columnUtils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(46); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnUtils", function() { return _columnController_columnUtils__WEBPACK_IMPORTED_MODULE_3__["ColumnUtils"]; }); +/* harmony import */ var _columns_columnUtils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(28); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnUtils", function() { return _columns_columnUtils__WEBPACK_IMPORTED_MODULE_3__["ColumnUtils"]; }); -/* harmony import */ var _columnController_displayedGroupCreator__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(47); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DisplayedGroupCreator", function() { return _columnController_displayedGroupCreator__WEBPACK_IMPORTED_MODULE_4__["DisplayedGroupCreator"]; }); +/* harmony import */ var _columns_displayedGroupCreator__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(29); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DisplayedGroupCreator", function() { return _columns_displayedGroupCreator__WEBPACK_IMPORTED_MODULE_4__["DisplayedGroupCreator"]; }); -/* harmony import */ var _columnController_groupInstanceIdCreator__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(45); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GroupInstanceIdCreator", function() { return _columnController_groupInstanceIdCreator__WEBPACK_IMPORTED_MODULE_5__["GroupInstanceIdCreator"]; }); +/* harmony import */ var _columns_groupInstanceIdCreator__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(25); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GroupInstanceIdCreator", function() { return _columns_groupInstanceIdCreator__WEBPACK_IMPORTED_MODULE_5__["GroupInstanceIdCreator"]; }); -/* harmony import */ var _components_componentUtil__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(48); +/* harmony import */ var _components_componentUtil__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(30); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ComponentUtil", function() { return _components_componentUtil__WEBPACK_IMPORTED_MODULE_6__["ComponentUtil"]; }); -/* harmony import */ var _components_colDefUtil__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(51); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColDefUtil", function() { return _components_colDefUtil__WEBPACK_IMPORTED_MODULE_7__["ColDefUtil"]; }); +/* harmony import */ var _components_agStackComponentsRegistry__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(32); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgStackComponentsRegistry", function() { return _components_agStackComponentsRegistry__WEBPACK_IMPORTED_MODULE_7__["AgStackComponentsRegistry"]; }); -/* harmony import */ var _components_framework_userComponentRegistry__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(53); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "UserComponentRegistry", function() { return _components_framework_userComponentRegistry__WEBPACK_IMPORTED_MODULE_8__["UserComponentRegistry"]; }); +/* harmony import */ var _components_colDefUtil__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(33); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColDefUtil", function() { return _components_colDefUtil__WEBPACK_IMPORTED_MODULE_8__["ColDefUtil"]; }); -/* harmony import */ var _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(74); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "UserComponentFactory", function() { return _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_9__["UserComponentFactory"]; }); +/* harmony import */ var _components_framework_userComponentRegistry__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(34); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "UserComponentRegistry", function() { return _components_framework_userComponentRegistry__WEBPACK_IMPORTED_MODULE_9__["UserComponentRegistry"]; }); -/* harmony import */ var _components_agGridNg1__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(94); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "initialiseAgGridWithAngular1", function() { return _components_agGridNg1__WEBPACK_IMPORTED_MODULE_10__["initialiseAgGridWithAngular1"]; }); +/* harmony import */ var _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(102); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "UserComponentFactory", function() { return _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_10__["UserComponentFactory"]; }); -/* harmony import */ var _components_agGridWebComponent__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(193); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "initialiseAgGridWithWebComponents", function() { return _components_agGridWebComponent__WEBPACK_IMPORTED_MODULE_11__["initialiseAgGridWithWebComponents"]; }); +/* harmony import */ var _components_agGridNg1__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(105); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "initialiseAgGridWithAngular1", function() { return _components_agGridNg1__WEBPACK_IMPORTED_MODULE_11__["initialiseAgGridWithAngular1"]; }); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(41); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(20); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BeanStub", function() { return _context_beanStub__WEBPACK_IMPORTED_MODULE_12__["BeanStub"]; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(37); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(12); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Context", function() { return _context_context__WEBPACK_IMPORTED_MODULE_13__["Context"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Autowired", function() { return _context_context__WEBPACK_IMPORTED_MODULE_13__["Autowired"]; }); @@ -242,363 +242,466 @@ __webpack_require__.r(__webpack_exports__); /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(57); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "QuerySelector", function() { return _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_14__["QuerySelector"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GuiListener", function() { return _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_14__["GuiListener"]; }); - /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RefSelector", function() { return _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_14__["RefSelector"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridListener", function() { return _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_14__["GridListener"]; }); +/* harmony import */ var _interfaces_iExcelCreator__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(150); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ExcelFactoryMode", function() { return _interfaces_iExcelCreator__WEBPACK_IMPORTED_MODULE_15__["ExcelFactoryMode"]; }); + +/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(97); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DragAndDropService", function() { return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_16__["DragAndDropService"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DragSourceType", function() { return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_16__["DragSourceType"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HorizontalDirection", function() { return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_16__["HorizontalDirection"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "VerticalDirection", function() { return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_16__["VerticalDirection"]; }); + +/* harmony import */ var _dragAndDrop_dragService__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(181); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DragService", function() { return _dragAndDrop_dragService__WEBPACK_IMPORTED_MODULE_17__["DragService"]; }); + +/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(10); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Column", function() { return _entities_column__WEBPACK_IMPORTED_MODULE_18__["Column"]; }); + +/* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(9); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnGroup", function() { return _entities_columnGroup__WEBPACK_IMPORTED_MODULE_19__["ColumnGroup"]; }); + +/* harmony import */ var _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(8); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ProvidedColumnGroup", function() { return _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_20__["ProvidedColumnGroup"]; }); + +/* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(94); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNode", function() { return _entities_rowNode__WEBPACK_IMPORTED_MODULE_21__["RowNode"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowHighlightPosition", function() { return _entities_rowNode__WEBPACK_IMPORTED_MODULE_21__["RowHighlightPosition"]; }); + +/* harmony import */ var _filter_filterManager__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(162); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "FilterManager", function() { return _filter_filterManager__WEBPACK_IMPORTED_MODULE_22__["FilterManager"]; }); + +/* harmony import */ var _filter_provided_providedFilter__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(62); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ProvidedFilter", function() { return _filter_provided_providedFilter__WEBPACK_IMPORTED_MODULE_23__["ProvidedFilter"]; }); + +/* harmony import */ var _filter_provided_simpleFilter__WEBPACK_IMPORTED_MODULE_24__ = __webpack_require__(60); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SimpleFilter", function() { return _filter_provided_simpleFilter__WEBPACK_IMPORTED_MODULE_24__["SimpleFilter"]; }); + +/* harmony import */ var _filter_provided_scalarFilter__WEBPACK_IMPORTED_MODULE_25__ = __webpack_require__(72); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ScalarFilter", function() { return _filter_provided_scalarFilter__WEBPACK_IMPORTED_MODULE_25__["ScalarFilter"]; }); + +/* harmony import */ var _filter_provided_number_numberFilter__WEBPACK_IMPORTED_MODULE_26__ = __webpack_require__(76); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "NumberFilter", function() { return _filter_provided_number_numberFilter__WEBPACK_IMPORTED_MODULE_26__["NumberFilter"]; }); + +/* harmony import */ var _filter_provided_text_textFilter__WEBPACK_IMPORTED_MODULE_27__ = __webpack_require__(79); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TextFilter", function() { return _filter_provided_text_textFilter__WEBPACK_IMPORTED_MODULE_27__["TextFilter"]; }); + +/* harmony import */ var _filter_provided_date_dateFilter__WEBPACK_IMPORTED_MODULE_28__ = __webpack_require__(58); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DateFilter", function() { return _filter_provided_date_dateFilter__WEBPACK_IMPORTED_MODULE_28__["DateFilter"]; }); + +/* harmony import */ var _filter_provided_text_textFloatingFilter__WEBPACK_IMPORTED_MODULE_29__ = __webpack_require__(80); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TextFloatingFilter", function() { return _filter_provided_text_textFloatingFilter__WEBPACK_IMPORTED_MODULE_29__["TextFloatingFilter"]; }); + +/* harmony import */ var _headerRendering_cells_floatingFilter_headerFilterCellComp__WEBPACK_IMPORTED_MODULE_30__ = __webpack_require__(140); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderFilterCellComp", function() { return _headerRendering_cells_floatingFilter_headerFilterCellComp__WEBPACK_IMPORTED_MODULE_30__["HeaderFilterCellComp"]; }); + +/* harmony import */ var _filter_floating_floatingFilterMapper__WEBPACK_IMPORTED_MODULE_31__ = __webpack_require__(104); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "FloatingFilterMapper", function() { return _filter_floating_floatingFilterMapper__WEBPACK_IMPORTED_MODULE_31__["FloatingFilterMapper"]; }); + +/* harmony import */ var _gridBodyComp_gridBodyComp__WEBPACK_IMPORTED_MODULE_32__ = __webpack_require__(164); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridBodyComp", function() { return _gridBodyComp_gridBodyComp__WEBPACK_IMPORTED_MODULE_32__["GridBodyComp"]; }); + +/* harmony import */ var _gridBodyComp_gridBodyCtrl__WEBPACK_IMPORTED_MODULE_33__ = __webpack_require__(166); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridBodyCtrl", function() { return _gridBodyComp_gridBodyCtrl__WEBPACK_IMPORTED_MODULE_33__["GridBodyCtrl"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowAnimationCssClasses", function() { return _gridBodyComp_gridBodyCtrl__WEBPACK_IMPORTED_MODULE_33__["RowAnimationCssClasses"]; }); + +/* harmony import */ var _gridBodyComp_scrollVisibleService__WEBPACK_IMPORTED_MODULE_34__ = __webpack_require__(188); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ScrollVisibleService", function() { return _gridBodyComp_scrollVisibleService__WEBPACK_IMPORTED_MODULE_34__["ScrollVisibleService"]; }); + +/* harmony import */ var _gridBodyComp_mouseEventService__WEBPACK_IMPORTED_MODULE_35__ = __webpack_require__(183); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MouseEventService", function() { return _gridBodyComp_mouseEventService__WEBPACK_IMPORTED_MODULE_35__["MouseEventService"]; }); + +/* harmony import */ var _gridBodyComp_navigationService__WEBPACK_IMPORTED_MODULE_36__ = __webpack_require__(202); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "NavigationService", function() { return _gridBodyComp_navigationService__WEBPACK_IMPORTED_MODULE_36__["NavigationService"]; }); + +/* harmony import */ var _gridBodyComp_rowContainer_rowContainerComp__WEBPACK_IMPORTED_MODULE_37__ = __webpack_require__(237); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowContainerComp", function() { return _gridBodyComp_rowContainer_rowContainerComp__WEBPACK_IMPORTED_MODULE_37__["RowContainerComp"]; }); + +/* harmony import */ var _gridBodyComp_rowContainer_rowContainerCtrl__WEBPACK_IMPORTED_MODULE_38__ = __webpack_require__(125); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowContainerName", function() { return _gridBodyComp_rowContainer_rowContainerCtrl__WEBPACK_IMPORTED_MODULE_38__["RowContainerName"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowContainerCtrl", function() { return _gridBodyComp_rowContainer_rowContainerCtrl__WEBPACK_IMPORTED_MODULE_38__["RowContainerCtrl"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowContainerType", function() { return _gridBodyComp_rowContainer_rowContainerCtrl__WEBPACK_IMPORTED_MODULE_38__["RowContainerType"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "getRowContainerTypeForName", function() { return _gridBodyComp_rowContainer_rowContainerCtrl__WEBPACK_IMPORTED_MODULE_38__["getRowContainerTypeForName"]; }); -/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(104); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DragAndDropService", function() { return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_15__["DragAndDropService"]; }); +/* harmony import */ var _headerRendering_columnDrag_bodyDropPivotTarget__WEBPACK_IMPORTED_MODULE_39__ = __webpack_require__(145); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BodyDropPivotTarget", function() { return _headerRendering_columnDrag_bodyDropPivotTarget__WEBPACK_IMPORTED_MODULE_39__["BodyDropPivotTarget"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DragSourceType", function() { return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_15__["DragSourceType"]; }); +/* harmony import */ var _headerRendering_columnDrag_bodyDropTarget__WEBPACK_IMPORTED_MODULE_40__ = __webpack_require__(143); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BodyDropTarget", function() { return _headerRendering_columnDrag_bodyDropTarget__WEBPACK_IMPORTED_MODULE_40__["BodyDropTarget"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HorizontalDirection", function() { return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_15__["HorizontalDirection"]; }); +/* harmony import */ var _headerRendering_cells_cssClassApplier__WEBPACK_IMPORTED_MODULE_41__ = __webpack_require__(155); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CssClassApplier", function() { return _headerRendering_cells_cssClassApplier__WEBPACK_IMPORTED_MODULE_41__["CssClassApplier"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "VerticalDirection", function() { return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_15__["VerticalDirection"]; }); +/* harmony import */ var _headerRendering_rowContainer_headerRowContainerComp__WEBPACK_IMPORTED_MODULE_42__ = __webpack_require__(141); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderRowContainerComp", function() { return _headerRendering_rowContainer_headerRowContainerComp__WEBPACK_IMPORTED_MODULE_42__["HeaderRowContainerComp"]; }); -/* harmony import */ var _dragAndDrop_dragService__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(139); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DragService", function() { return _dragAndDrop_dragService__WEBPACK_IMPORTED_MODULE_16__["DragService"]; }); +/* harmony import */ var _headerRendering_gridHeaderComp__WEBPACK_IMPORTED_MODULE_43__ = __webpack_require__(133); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridHeaderComp", function() { return _headerRendering_gridHeaderComp__WEBPACK_IMPORTED_MODULE_43__["GridHeaderComp"]; }); -/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(35); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Column", function() { return _entities_column__WEBPACK_IMPORTED_MODULE_17__["Column"]; }); +/* harmony import */ var _headerRendering_gridHeaderCtrl__WEBPACK_IMPORTED_MODULE_44__ = __webpack_require__(134); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridHeaderCtrl", function() { return _headerRendering_gridHeaderCtrl__WEBPACK_IMPORTED_MODULE_44__["GridHeaderCtrl"]; }); -/* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(34); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnGroup", function() { return _entities_columnGroup__WEBPACK_IMPORTED_MODULE_18__["ColumnGroup"]; }); +/* harmony import */ var _headerRendering_row_headerRowComp__WEBPACK_IMPORTED_MODULE_45__ = __webpack_require__(136); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderRowComp", function() { return _headerRendering_row_headerRowComp__WEBPACK_IMPORTED_MODULE_45__["HeaderRowComp"]; }); -/* harmony import */ var _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(33); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "OriginalColumnGroup", function() { return _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_19__["OriginalColumnGroup"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderRowType", function() { return _headerRendering_row_headerRowComp__WEBPACK_IMPORTED_MODULE_45__["HeaderRowType"]; }); -/* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(68); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNode", function() { return _entities_rowNode__WEBPACK_IMPORTED_MODULE_20__["RowNode"]; }); +/* harmony import */ var _headerRendering_row_headerRowCtrl__WEBPACK_IMPORTED_MODULE_46__ = __webpack_require__(146); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderRowCtrl", function() { return _headerRendering_row_headerRowCtrl__WEBPACK_IMPORTED_MODULE_46__["HeaderRowCtrl"]; }); -/* harmony import */ var _filter_filterManager__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(125); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "FilterManager", function() { return _filter_filterManager__WEBPACK_IMPORTED_MODULE_21__["FilterManager"]; }); +/* harmony import */ var _headerRendering_cells_column_headerCellCtrl__WEBPACK_IMPORTED_MODULE_47__ = __webpack_require__(154); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderCellCtrl", function() { return _headerRendering_cells_column_headerCellCtrl__WEBPACK_IMPORTED_MODULE_47__["HeaderCellCtrl"]; }); -/* harmony import */ var _filter_provided_providedFilter__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(62); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ProvidedFilter", function() { return _filter_provided_providedFilter__WEBPACK_IMPORTED_MODULE_22__["ProvidedFilter"]; }); +/* harmony import */ var _headerRendering_cells_floatingFilter_headerFilterCellCtrl__WEBPACK_IMPORTED_MODULE_48__ = __webpack_require__(147); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderFilterCellCtrl", function() { return _headerRendering_cells_floatingFilter_headerFilterCellCtrl__WEBPACK_IMPORTED_MODULE_48__["HeaderFilterCellCtrl"]; }); -/* harmony import */ var _filter_provided_simpleFilter__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(60); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SimpleFilter", function() { return _filter_provided_simpleFilter__WEBPACK_IMPORTED_MODULE_23__["SimpleFilter"]; }); +/* harmony import */ var _headerRendering_cells_columnGroup_headerGroupCellCtrl__WEBPACK_IMPORTED_MODULE_49__ = __webpack_require__(159); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderGroupCellCtrl", function() { return _headerRendering_cells_columnGroup_headerGroupCellCtrl__WEBPACK_IMPORTED_MODULE_49__["HeaderGroupCellCtrl"]; }); -/* harmony import */ var _filter_provided_scalarFilter__WEBPACK_IMPORTED_MODULE_24__ = __webpack_require__(63); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ScalarFilter", function() { return _filter_provided_scalarFilter__WEBPACK_IMPORTED_MODULE_24__["ScalarFilter"]; }); +/* harmony import */ var _headerRendering_cells_abstractCell_abstractHeaderCellCtrl__WEBPACK_IMPORTED_MODULE_50__ = __webpack_require__(148); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AbstractHeaderCellCtrl", function() { return _headerRendering_cells_abstractCell_abstractHeaderCellCtrl__WEBPACK_IMPORTED_MODULE_50__["AbstractHeaderCellCtrl"]; }); -/* harmony import */ var _filter_provided_number_numberFilter__WEBPACK_IMPORTED_MODULE_25__ = __webpack_require__(83); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "NumberFilter", function() { return _filter_provided_number_numberFilter__WEBPACK_IMPORTED_MODULE_25__["NumberFilter"]; }); +/* harmony import */ var _headerRendering_rowContainer_headerRowContainerCtrl__WEBPACK_IMPORTED_MODULE_51__ = __webpack_require__(142); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderRowContainerCtrl", function() { return _headerRendering_rowContainer_headerRowContainerCtrl__WEBPACK_IMPORTED_MODULE_51__["HeaderRowContainerCtrl"]; }); -/* harmony import */ var _filter_provided_text_textFilter__WEBPACK_IMPORTED_MODULE_26__ = __webpack_require__(90); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TextFilter", function() { return _filter_provided_text_textFilter__WEBPACK_IMPORTED_MODULE_26__["TextFilter"]; }); +/* harmony import */ var _headerRendering_common_horizontalResizeService__WEBPACK_IMPORTED_MODULE_52__ = __webpack_require__(176); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HorizontalResizeService", function() { return _headerRendering_common_horizontalResizeService__WEBPACK_IMPORTED_MODULE_52__["HorizontalResizeService"]; }); -/* harmony import */ var _filter_provided_date_dateFilter__WEBPACK_IMPORTED_MODULE_27__ = __webpack_require__(58); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DateFilter", function() { return _filter_provided_date_dateFilter__WEBPACK_IMPORTED_MODULE_27__["DateFilter"]; }); +/* harmony import */ var _headerRendering_columnDrag_moveColumnFeature__WEBPACK_IMPORTED_MODULE_53__ = __webpack_require__(144); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MoveColumnFeature", function() { return _headerRendering_columnDrag_moveColumnFeature__WEBPACK_IMPORTED_MODULE_53__["MoveColumnFeature"]; }); -/* harmony import */ var _gridPanel_gridPanel__WEBPACK_IMPORTED_MODULE_28__ = __webpack_require__(127); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridPanel", function() { return _gridPanel_gridPanel__WEBPACK_IMPORTED_MODULE_28__["GridPanel"]; }); +/* harmony import */ var _headerRendering_cells_column_standardMenu__WEBPACK_IMPORTED_MODULE_54__ = __webpack_require__(242); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "StandardMenuFactory", function() { return _headerRendering_cells_column_standardMenu__WEBPACK_IMPORTED_MODULE_54__["StandardMenuFactory"]; }); -/* harmony import */ var _gridPanel_scrollVisibleService__WEBPACK_IMPORTED_MODULE_29__ = __webpack_require__(148); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ScrollVisibleService", function() { return _gridPanel_scrollVisibleService__WEBPACK_IMPORTED_MODULE_29__["ScrollVisibleService"]; }); +/* harmony import */ var _layout_tabbedLayout__WEBPACK_IMPORTED_MODULE_55__ = __webpack_require__(243); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TabbedLayout", function() { return _layout_tabbedLayout__WEBPACK_IMPORTED_MODULE_55__["TabbedLayout"]; }); -/* harmony import */ var _gridPanel_mouseEventService__WEBPACK_IMPORTED_MODULE_30__ = __webpack_require__(142); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MouseEventService", function() { return _gridPanel_mouseEventService__WEBPACK_IMPORTED_MODULE_30__["MouseEventService"]; }); +/* harmony import */ var _misc_simpleHttpRequest__WEBPACK_IMPORTED_MODULE_56__ = __webpack_require__(244); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "simpleHttpRequest", function() { return _misc_simpleHttpRequest__WEBPACK_IMPORTED_MODULE_56__["simpleHttpRequest"]; }); -/* harmony import */ var _headerRendering_bodyDropPivotTarget__WEBPACK_IMPORTED_MODULE_31__ = __webpack_require__(123); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BodyDropPivotTarget", function() { return _headerRendering_bodyDropPivotTarget__WEBPACK_IMPORTED_MODULE_31__["BodyDropPivotTarget"]; }); +/* harmony import */ var _misc_resizeObserverService__WEBPACK_IMPORTED_MODULE_57__ = __webpack_require__(206); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ResizeObserverService", function() { return _misc_resizeObserverService__WEBPACK_IMPORTED_MODULE_57__["ResizeObserverService"]; }); -/* harmony import */ var _headerRendering_bodyDropTarget__WEBPACK_IMPORTED_MODULE_32__ = __webpack_require__(121); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BodyDropTarget", function() { return _headerRendering_bodyDropTarget__WEBPACK_IMPORTED_MODULE_32__["BodyDropTarget"]; }); +/* harmony import */ var _misc_animationFrameService__WEBPACK_IMPORTED_MODULE_58__ = __webpack_require__(201); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AnimationFrameService", function() { return _misc_animationFrameService__WEBPACK_IMPORTED_MODULE_58__["AnimationFrameService"]; }); -/* harmony import */ var _headerRendering_cssClassApplier__WEBPACK_IMPORTED_MODULE_33__ = __webpack_require__(112); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CssClassApplier", function() { return _headerRendering_cssClassApplier__WEBPACK_IMPORTED_MODULE_33__["CssClassApplier"]; }); +/* harmony import */ var _rendering_cellEditors_largeTextCellEditor__WEBPACK_IMPORTED_MODULE_59__ = __webpack_require__(84); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "LargeTextCellEditor", function() { return _rendering_cellEditors_largeTextCellEditor__WEBPACK_IMPORTED_MODULE_59__["LargeTextCellEditor"]; }); -/* harmony import */ var _headerRendering_headerContainer__WEBPACK_IMPORTED_MODULE_34__ = __webpack_require__(109); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderContainer", function() { return _headerRendering_headerContainer__WEBPACK_IMPORTED_MODULE_34__["HeaderContainer"]; }); +/* harmony import */ var _rendering_cellEditors_popupEditorWrapper__WEBPACK_IMPORTED_MODULE_60__ = __webpack_require__(240); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupEditorWrapper", function() { return _rendering_cellEditors_popupEditorWrapper__WEBPACK_IMPORTED_MODULE_60__["PopupEditorWrapper"]; }); -/* harmony import */ var _headerRendering_headerRootComp__WEBPACK_IMPORTED_MODULE_35__ = __webpack_require__(108); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderRootComp", function() { return _headerRendering_headerRootComp__WEBPACK_IMPORTED_MODULE_35__["HeaderRootComp"]; }); +/* harmony import */ var _rendering_cellEditors_popupSelectCellEditor__WEBPACK_IMPORTED_MODULE_61__ = __webpack_require__(86); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupSelectCellEditor", function() { return _rendering_cellEditors_popupSelectCellEditor__WEBPACK_IMPORTED_MODULE_61__["PopupSelectCellEditor"]; }); -/* harmony import */ var _headerRendering_headerRowComp__WEBPACK_IMPORTED_MODULE_36__ = __webpack_require__(110); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderRowComp", function() { return _headerRendering_headerRowComp__WEBPACK_IMPORTED_MODULE_36__["HeaderRowComp"]; }); +/* harmony import */ var _rendering_cellEditors_popupTextCellEditor__WEBPACK_IMPORTED_MODULE_62__ = __webpack_require__(88); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupTextCellEditor", function() { return _rendering_cellEditors_popupTextCellEditor__WEBPACK_IMPORTED_MODULE_62__["PopupTextCellEditor"]; }); -/* harmony import */ var _headerRendering_horizontalResizeService__WEBPACK_IMPORTED_MODULE_37__ = __webpack_require__(136); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HorizontalResizeService", function() { return _headerRendering_horizontalResizeService__WEBPACK_IMPORTED_MODULE_37__["HorizontalResizeService"]; }); +/* harmony import */ var _rendering_cellEditors_selectCellEditor__WEBPACK_IMPORTED_MODULE_63__ = __webpack_require__(87); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectCellEditor", function() { return _rendering_cellEditors_selectCellEditor__WEBPACK_IMPORTED_MODULE_63__["SelectCellEditor"]; }); -/* harmony import */ var _headerRendering_moveColumnController__WEBPACK_IMPORTED_MODULE_38__ = __webpack_require__(122); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MoveColumnController", function() { return _headerRendering_moveColumnController__WEBPACK_IMPORTED_MODULE_38__["MoveColumnController"]; }); +/* harmony import */ var _rendering_cellEditors_textCellEditor__WEBPACK_IMPORTED_MODULE_64__ = __webpack_require__(89); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TextCellEditor", function() { return _rendering_cellEditors_textCellEditor__WEBPACK_IMPORTED_MODULE_64__["TextCellEditor"]; }); -/* harmony import */ var _headerRendering_standardMenu__WEBPACK_IMPORTED_MODULE_39__ = __webpack_require__(138); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "StandardMenuFactory", function() { return _headerRendering_standardMenu__WEBPACK_IMPORTED_MODULE_39__["StandardMenuFactory"]; }); +/* harmony import */ var _rendering_beans__WEBPACK_IMPORTED_MODULE_65__ = __webpack_require__(121); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Beans", function() { return _rendering_beans__WEBPACK_IMPORTED_MODULE_65__["Beans"]; }); -/* harmony import */ var _layout_tabbedLayout__WEBPACK_IMPORTED_MODULE_40__ = __webpack_require__(194); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TabbedLayout", function() { return _layout_tabbedLayout__WEBPACK_IMPORTED_MODULE_40__["TabbedLayout"]; }); +/* harmony import */ var _rendering_cellRenderers_animateShowChangeCellRenderer__WEBPACK_IMPORTED_MODULE_66__ = __webpack_require__(90); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AnimateShowChangeCellRenderer", function() { return _rendering_cellRenderers_animateShowChangeCellRenderer__WEBPACK_IMPORTED_MODULE_66__["AnimateShowChangeCellRenderer"]; }); -/* harmony import */ var _misc_simpleHttpRequest__WEBPACK_IMPORTED_MODULE_41__ = __webpack_require__(195); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "simpleHttpRequest", function() { return _misc_simpleHttpRequest__WEBPACK_IMPORTED_MODULE_41__["simpleHttpRequest"]; }); +/* harmony import */ var _rendering_cellRenderers_animateSlideCellRenderer__WEBPACK_IMPORTED_MODULE_67__ = __webpack_require__(91); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AnimateSlideCellRenderer", function() { return _rendering_cellRenderers_animateSlideCellRenderer__WEBPACK_IMPORTED_MODULE_67__["AnimateSlideCellRenderer"]; }); -/* harmony import */ var _misc_resizeObserverService__WEBPACK_IMPORTED_MODULE_42__ = __webpack_require__(168); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ResizeObserverService", function() { return _misc_resizeObserverService__WEBPACK_IMPORTED_MODULE_42__["ResizeObserverService"]; }); +/* harmony import */ var _rendering_cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_68__ = __webpack_require__(92); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GroupCellRenderer", function() { return _rendering_cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_68__["GroupCellRenderer"]; }); -/* harmony import */ var _rendering_cellEditors_largeTextCellEditor__WEBPACK_IMPORTED_MODULE_43__ = __webpack_require__(82); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "LargeTextCellEditor", function() { return _rendering_cellEditors_largeTextCellEditor__WEBPACK_IMPORTED_MODULE_43__["LargeTextCellEditor"]; }); +/* harmony import */ var _rendering_cellRenderers_groupCellRendererCtrl__WEBPACK_IMPORTED_MODULE_69__ = __webpack_require__(93); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GroupCellRendererCtrl", function() { return _rendering_cellRenderers_groupCellRendererCtrl__WEBPACK_IMPORTED_MODULE_69__["GroupCellRendererCtrl"]; }); -/* harmony import */ var _rendering_cellEditors_popupEditorWrapper__WEBPACK_IMPORTED_MODULE_44__ = __webpack_require__(105); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupEditorWrapper", function() { return _rendering_cellEditors_popupEditorWrapper__WEBPACK_IMPORTED_MODULE_44__["PopupEditorWrapper"]; }); +/* harmony import */ var _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_70__ = __webpack_require__(152); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SetLeftFeature", function() { return _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_70__["SetLeftFeature"]; }); -/* harmony import */ var _rendering_cellEditors_popupSelectCellEditor__WEBPACK_IMPORTED_MODULE_45__ = __webpack_require__(81); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupSelectCellEditor", function() { return _rendering_cellEditors_popupSelectCellEditor__WEBPACK_IMPORTED_MODULE_45__["PopupSelectCellEditor"]; }); +/* harmony import */ var _rendering_features_positionableFeature__WEBPACK_IMPORTED_MODULE_71__ = __webpack_require__(211); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PositionableFeature", function() { return _rendering_features_positionableFeature__WEBPACK_IMPORTED_MODULE_71__["PositionableFeature"]; }); -/* harmony import */ var _rendering_cellEditors_popupTextCellEditor__WEBPACK_IMPORTED_MODULE_46__ = __webpack_require__(80); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupTextCellEditor", function() { return _rendering_cellEditors_popupTextCellEditor__WEBPACK_IMPORTED_MODULE_46__["PopupTextCellEditor"]; }); +/* harmony import */ var _rendering_autoWidthCalculator__WEBPACK_IMPORTED_MODULE_72__ = __webpack_require__(175); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AutoWidthCalculator", function() { return _rendering_autoWidthCalculator__WEBPACK_IMPORTED_MODULE_72__["AutoWidthCalculator"]; }); -/* harmony import */ var _rendering_cellEditors_selectCellEditor__WEBPACK_IMPORTED_MODULE_47__ = __webpack_require__(79); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectCellEditor", function() { return _rendering_cellEditors_selectCellEditor__WEBPACK_IMPORTED_MODULE_47__["SelectCellEditor"]; }); +/* harmony import */ var _rendering_checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_73__ = __webpack_require__(95); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CheckboxSelectionComponent", function() { return _rendering_checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_73__["CheckboxSelectionComponent"]; }); -/* harmony import */ var _rendering_cellEditors_textCellEditor__WEBPACK_IMPORTED_MODULE_48__ = __webpack_require__(54); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TextCellEditor", function() { return _rendering_cellEditors_textCellEditor__WEBPACK_IMPORTED_MODULE_48__["TextCellEditor"]; }); +/* harmony import */ var _rendering_cell_cellComp__WEBPACK_IMPORTED_MODULE_74__ = __webpack_require__(239); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellComp", function() { return _rendering_cell_cellComp__WEBPACK_IMPORTED_MODULE_74__["CellComp"]; }); -/* harmony import */ var _rendering_cellRenderers_animateShowChangeCellRenderer__WEBPACK_IMPORTED_MODULE_49__ = __webpack_require__(76); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AnimateShowChangeCellRenderer", function() { return _rendering_cellRenderers_animateShowChangeCellRenderer__WEBPACK_IMPORTED_MODULE_49__["AnimateShowChangeCellRenderer"]; }); +/* harmony import */ var _rendering_cell_cellCtrl__WEBPACK_IMPORTED_MODULE_75__ = __webpack_require__(114); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellCtrl", function() { return _rendering_cell_cellCtrl__WEBPACK_IMPORTED_MODULE_75__["CellCtrl"]; }); -/* harmony import */ var _rendering_cellRenderers_animateSlideCellRenderer__WEBPACK_IMPORTED_MODULE_50__ = __webpack_require__(77); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AnimateSlideCellRenderer", function() { return _rendering_cellRenderers_animateSlideCellRenderer__WEBPACK_IMPORTED_MODULE_50__["AnimateSlideCellRenderer"]; }); +/* harmony import */ var _rendering_row_rowCtrl__WEBPACK_IMPORTED_MODULE_76__ = __webpack_require__(113); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowCtrl", function() { return _rendering_row_rowCtrl__WEBPACK_IMPORTED_MODULE_76__["RowCtrl"]; }); -/* harmony import */ var _rendering_cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_51__ = __webpack_require__(67); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GroupCellRenderer", function() { return _rendering_cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_51__["GroupCellRenderer"]; }); +/* harmony import */ var _rendering_rowRenderer__WEBPACK_IMPORTED_MODULE_77__ = __webpack_require__(112); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowRenderer", function() { return _rendering_rowRenderer__WEBPACK_IMPORTED_MODULE_77__["RowRenderer"]; }); -/* harmony import */ var _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_52__ = __webpack_require__(114); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SetLeftFeature", function() { return _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_52__["SetLeftFeature"]; }); +/* harmony import */ var _rendering_valueFormatterService__WEBPACK_IMPORTED_MODULE_78__ = __webpack_require__(185); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ValueFormatterService", function() { return _rendering_valueFormatterService__WEBPACK_IMPORTED_MODULE_78__["ValueFormatterService"]; }); -/* harmony import */ var _rendering_autoWidthCalculator__WEBPACK_IMPORTED_MODULE_53__ = __webpack_require__(135); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AutoWidthCalculator", function() { return _rendering_autoWidthCalculator__WEBPACK_IMPORTED_MODULE_53__["AutoWidthCalculator"]; }); +/* harmony import */ var _pinnedRowModel_pinnedRowModel__WEBPACK_IMPORTED_MODULE_79__ = __webpack_require__(223); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PinnedRowModel", function() { return _pinnedRowModel_pinnedRowModel__WEBPACK_IMPORTED_MODULE_79__["PinnedRowModel"]; }); -/* harmony import */ var _rendering_cellRendererFactory__WEBPACK_IMPORTED_MODULE_54__ = __webpack_require__(144); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellRendererFactory", function() { return _rendering_cellRendererFactory__WEBPACK_IMPORTED_MODULE_54__["CellRendererFactory"]; }); +/* harmony import */ var _interfaces_serverSideTransaction__WEBPACK_IMPORTED_MODULE_80__ = __webpack_require__(245); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ServerSideTransactionResultStatus", function() { return _interfaces_serverSideTransaction__WEBPACK_IMPORTED_MODULE_80__["ServerSideTransactionResultStatus"]; }); -/* harmony import */ var _rendering_checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_55__ = __webpack_require__(69); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CheckboxSelectionComponent", function() { return _rendering_checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_55__["CheckboxSelectionComponent"]; }); +/* harmony import */ var _utils_changedPath__WEBPACK_IMPORTED_MODULE_81__ = __webpack_require__(110); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ChangedPath", function() { return _utils_changedPath__WEBPACK_IMPORTED_MODULE_81__["ChangedPath"]; }); -/* harmony import */ var _rendering_cellComp__WEBPACK_IMPORTED_MODULE_56__ = __webpack_require__(101); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellComp", function() { return _rendering_cellComp__WEBPACK_IMPORTED_MODULE_56__["CellComp"]; }); +/* harmony import */ var _rowNodeCache_rowNodeBlock__WEBPACK_IMPORTED_MODULE_82__ = __webpack_require__(230); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNodeBlock", function() { return _rowNodeCache_rowNodeBlock__WEBPACK_IMPORTED_MODULE_82__["RowNodeBlock"]; }); -/* harmony import */ var _rendering_rowComp__WEBPACK_IMPORTED_MODULE_57__ = __webpack_require__(100); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowComp", function() { return _rendering_rowComp__WEBPACK_IMPORTED_MODULE_57__["RowComp"]; }); +/* harmony import */ var _rowNodeCache_rowNodeBlockLoader__WEBPACK_IMPORTED_MODULE_83__ = __webpack_require__(229); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNodeBlockLoader", function() { return _rowNodeCache_rowNodeBlockLoader__WEBPACK_IMPORTED_MODULE_83__["RowNodeBlockLoader"]; }); -/* harmony import */ var _rendering_rowRenderer__WEBPACK_IMPORTED_MODULE_58__ = __webpack_require__(99); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowRenderer", function() { return _rendering_rowRenderer__WEBPACK_IMPORTED_MODULE_58__["RowRenderer"]; }); +/* harmony import */ var _pagination_paginationProxy__WEBPACK_IMPORTED_MODULE_84__ = __webpack_require__(193); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PaginationProxy", function() { return _pagination_paginationProxy__WEBPACK_IMPORTED_MODULE_84__["PaginationProxy"]; }); -/* harmony import */ var _rendering_valueFormatterService__WEBPACK_IMPORTED_MODULE_59__ = __webpack_require__(145); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ValueFormatterService", function() { return _rendering_valueFormatterService__WEBPACK_IMPORTED_MODULE_59__["ValueFormatterService"]; }); +/* harmony import */ var _interfaces_iClientSideRowModel__WEBPACK_IMPORTED_MODULE_85__ = __webpack_require__(151); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ClientSideRowModelSteps", function() { return _interfaces_iClientSideRowModel__WEBPACK_IMPORTED_MODULE_85__["ClientSideRowModelSteps"]; }); -/* harmony import */ var _pinnedRowModel_pinnedRowModel__WEBPACK_IMPORTED_MODULE_60__ = __webpack_require__(188); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PinnedRowModel", function() { return _pinnedRowModel_pinnedRowModel__WEBPACK_IMPORTED_MODULE_60__["PinnedRowModel"]; }); +/* harmony import */ var _styling_stylingService__WEBPACK_IMPORTED_MODULE_86__ = __webpack_require__(189); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "StylingService", function() { return _styling_stylingService__WEBPACK_IMPORTED_MODULE_86__["StylingService"]; }); -/* harmony import */ var _utils_changedPath__WEBPACK_IMPORTED_MODULE_61__ = __webpack_require__(97); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ChangedPath", function() { return _utils_changedPath__WEBPACK_IMPORTED_MODULE_61__["ChangedPath"]; }); +/* harmony import */ var _styling_layoutFeature__WEBPACK_IMPORTED_MODULE_87__ = __webpack_require__(165); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "LayoutCssClasses", function() { return _styling_layoutFeature__WEBPACK_IMPORTED_MODULE_87__["LayoutCssClasses"]; }); -/* harmony import */ var _modules_rowNodeCache_rowNodeBlock__WEBPACK_IMPORTED_MODULE_62__ = __webpack_require__(196); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNodeBlock", function() { return _modules_rowNodeCache_rowNodeBlock__WEBPACK_IMPORTED_MODULE_62__["RowNodeBlock"]; }); +/* harmony import */ var _widgets_agAbstractField__WEBPACK_IMPORTED_MODULE_88__ = __webpack_require__(67); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgAbstractField", function() { return _widgets_agAbstractField__WEBPACK_IMPORTED_MODULE_88__["AgAbstractField"]; }); -/* harmony import */ var _modules_rowNodeCache_rowNodeBlockLoader__WEBPACK_IMPORTED_MODULE_63__ = __webpack_require__(197); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNodeBlockLoader", function() { return _modules_rowNodeCache_rowNodeBlockLoader__WEBPACK_IMPORTED_MODULE_63__["RowNodeBlockLoader"]; }); +/* harmony import */ var _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_89__ = __webpack_require__(158); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgCheckbox", function() { return _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_89__["AgCheckbox"]; }); -/* harmony import */ var _modules_rowNodeCache_rowNodeCache__WEBPACK_IMPORTED_MODULE_64__ = __webpack_require__(198); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNodeCache", function() { return _modules_rowNodeCache_rowNodeCache__WEBPACK_IMPORTED_MODULE_64__["RowNodeCache"]; }); +/* harmony import */ var _widgets_agRadioButton__WEBPACK_IMPORTED_MODULE_90__ = __webpack_require__(186); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgRadioButton", function() { return _widgets_agRadioButton__WEBPACK_IMPORTED_MODULE_90__["AgRadioButton"]; }); -/* harmony import */ var _pagination_paginationProxy__WEBPACK_IMPORTED_MODULE_65__ = __webpack_require__(153); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PaginationProxy", function() { return _pagination_paginationProxy__WEBPACK_IMPORTED_MODULE_65__["PaginationProxy"]; }); +/* harmony import */ var _widgets_agToggleButton__WEBPACK_IMPORTED_MODULE_91__ = __webpack_require__(220); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgToggleButton", function() { return _widgets_agToggleButton__WEBPACK_IMPORTED_MODULE_91__["AgToggleButton"]; }); -/* harmony import */ var _styling_stylingService__WEBPACK_IMPORTED_MODULE_66__ = __webpack_require__(149); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "StylingService", function() { return _styling_stylingService__WEBPACK_IMPORTED_MODULE_66__["StylingService"]; }); +/* harmony import */ var _widgets_agInputTextField__WEBPACK_IMPORTED_MODULE_92__ = __webpack_require__(212); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgInputTextField", function() { return _widgets_agInputTextField__WEBPACK_IMPORTED_MODULE_92__["AgInputTextField"]; }); -/* harmony import */ var _widgets_agAbstractField__WEBPACK_IMPORTED_MODULE_67__ = __webpack_require__(72); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgAbstractField", function() { return _widgets_agAbstractField__WEBPACK_IMPORTED_MODULE_67__["AgAbstractField"]; }); +/* harmony import */ var _widgets_agInputTextArea__WEBPACK_IMPORTED_MODULE_93__ = __webpack_require__(213); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgInputTextArea", function() { return _widgets_agInputTextArea__WEBPACK_IMPORTED_MODULE_93__["AgInputTextArea"]; }); -/* harmony import */ var _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_68__ = __webpack_require__(70); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgCheckbox", function() { return _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_68__["AgCheckbox"]; }); +/* harmony import */ var _widgets_agInputNumberField__WEBPACK_IMPORTED_MODULE_94__ = __webpack_require__(217); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgInputNumberField", function() { return _widgets_agInputNumberField__WEBPACK_IMPORTED_MODULE_94__["AgInputNumberField"]; }); -/* harmony import */ var _widgets_agRadioButton__WEBPACK_IMPORTED_MODULE_69__ = __webpack_require__(146); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgRadioButton", function() { return _widgets_agRadioButton__WEBPACK_IMPORTED_MODULE_69__["AgRadioButton"]; }); +/* harmony import */ var _widgets_agInputRange__WEBPACK_IMPORTED_MODULE_95__ = __webpack_require__(218); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgInputRange", function() { return _widgets_agInputRange__WEBPACK_IMPORTED_MODULE_95__["AgInputRange"]; }); -/* harmony import */ var _widgets_agToggleButton__WEBPACK_IMPORTED_MODULE_70__ = __webpack_require__(184); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgToggleButton", function() { return _widgets_agToggleButton__WEBPACK_IMPORTED_MODULE_70__["AgToggleButton"]; }); +/* harmony import */ var _widgets_agSelect__WEBPACK_IMPORTED_MODULE_96__ = __webpack_require__(66); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgSelect", function() { return _widgets_agSelect__WEBPACK_IMPORTED_MODULE_96__["AgSelect"]; }); -/* harmony import */ var _widgets_agInputTextField__WEBPACK_IMPORTED_MODULE_71__ = __webpack_require__(173); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgInputTextField", function() { return _widgets_agInputTextField__WEBPACK_IMPORTED_MODULE_71__["AgInputTextField"]; }); +/* harmony import */ var _widgets_agSlider__WEBPACK_IMPORTED_MODULE_97__ = __webpack_require__(214); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgSlider", function() { return _widgets_agSlider__WEBPACK_IMPORTED_MODULE_97__["AgSlider"]; }); -/* harmony import */ var _widgets_agInputTextArea__WEBPACK_IMPORTED_MODULE_72__ = __webpack_require__(174); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgInputTextArea", function() { return _widgets_agInputTextArea__WEBPACK_IMPORTED_MODULE_72__["AgInputTextArea"]; }); +/* harmony import */ var _widgets_agAngleSelect__WEBPACK_IMPORTED_MODULE_98__ = __webpack_require__(219); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgAngleSelect", function() { return _widgets_agAngleSelect__WEBPACK_IMPORTED_MODULE_98__["AgAngleSelect"]; }); -/* harmony import */ var _widgets_agInputNumberField__WEBPACK_IMPORTED_MODULE_73__ = __webpack_require__(179); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgInputNumberField", function() { return _widgets_agInputNumberField__WEBPACK_IMPORTED_MODULE_73__["AgInputNumberField"]; }); +/* harmony import */ var _widgets_agColorPicker__WEBPACK_IMPORTED_MODULE_99__ = __webpack_require__(215); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgColorPicker", function() { return _widgets_agColorPicker__WEBPACK_IMPORTED_MODULE_99__["AgColorPicker"]; }); -/* harmony import */ var _widgets_agInputRange__WEBPACK_IMPORTED_MODULE_74__ = __webpack_require__(180); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgInputRange", function() { return _widgets_agInputRange__WEBPACK_IMPORTED_MODULE_74__["AgInputRange"]; }); +/* harmony import */ var _widgets_agGroupComponent__WEBPACK_IMPORTED_MODULE_100__ = __webpack_require__(208); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgGroupComponent", function() { return _widgets_agGroupComponent__WEBPACK_IMPORTED_MODULE_100__["AgGroupComponent"]; }); -/* harmony import */ var _widgets_agSelect__WEBPACK_IMPORTED_MODULE_75__ = __webpack_require__(181); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgSelect", function() { return _widgets_agSelect__WEBPACK_IMPORTED_MODULE_75__["AgSelect"]; }); +/* harmony import */ var _widgets_agMenuItemComponent__WEBPACK_IMPORTED_MODULE_101__ = __webpack_require__(246); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgMenuItemComponent", function() { return _widgets_agMenuItemComponent__WEBPACK_IMPORTED_MODULE_101__["AgMenuItemComponent"]; }); -/* harmony import */ var _widgets_agSlider__WEBPACK_IMPORTED_MODULE_76__ = __webpack_require__(175); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgSlider", function() { return _widgets_agSlider__WEBPACK_IMPORTED_MODULE_76__["AgSlider"]; }); +/* harmony import */ var _widgets_agMenuList__WEBPACK_IMPORTED_MODULE_102__ = __webpack_require__(247); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgMenuList", function() { return _widgets_agMenuList__WEBPACK_IMPORTED_MODULE_102__["AgMenuList"]; }); -/* harmony import */ var _widgets_agAngleSelect__WEBPACK_IMPORTED_MODULE_77__ = __webpack_require__(183); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgAngleSelect", function() { return _widgets_agAngleSelect__WEBPACK_IMPORTED_MODULE_77__["AgAngleSelect"]; }); +/* harmony import */ var _widgets_agMenuPanel__WEBPACK_IMPORTED_MODULE_103__ = __webpack_require__(248); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgMenuPanel", function() { return _widgets_agMenuPanel__WEBPACK_IMPORTED_MODULE_103__["AgMenuPanel"]; }); -/* harmony import */ var _widgets_agColorPicker__WEBPACK_IMPORTED_MODULE_78__ = __webpack_require__(176); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgColorPicker", function() { return _widgets_agColorPicker__WEBPACK_IMPORTED_MODULE_78__["AgColorPicker"]; }); +/* harmony import */ var _widgets_agDialog__WEBPACK_IMPORTED_MODULE_104__ = __webpack_require__(209); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgDialog", function() { return _widgets_agDialog__WEBPACK_IMPORTED_MODULE_104__["AgDialog"]; }); -/* harmony import */ var _widgets_agGroupComponent__WEBPACK_IMPORTED_MODULE_79__ = __webpack_require__(170); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgGroupComponent", function() { return _widgets_agGroupComponent__WEBPACK_IMPORTED_MODULE_79__["AgGroupComponent"]; }); +/* harmony import */ var _widgets_agPanel__WEBPACK_IMPORTED_MODULE_105__ = __webpack_require__(210); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgPanel", function() { return _widgets_agPanel__WEBPACK_IMPORTED_MODULE_105__["AgPanel"]; }); -/* harmony import */ var _widgets_agDialog__WEBPACK_IMPORTED_MODULE_80__ = __webpack_require__(171); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgDialog", function() { return _widgets_agDialog__WEBPACK_IMPORTED_MODULE_80__["AgDialog"]; }); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_106__ = __webpack_require__(36); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Component", function() { return _widgets_component__WEBPACK_IMPORTED_MODULE_106__["Component"]; }); -/* harmony import */ var _widgets_agPanel__WEBPACK_IMPORTED_MODULE_81__ = __webpack_require__(172); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgPanel", function() { return _widgets_agPanel__WEBPACK_IMPORTED_MODULE_81__["AgPanel"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CssClassManager", function() { return _widgets_component__WEBPACK_IMPORTED_MODULE_106__["CssClassManager"]; }); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_82__ = __webpack_require__(56); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Component", function() { return _widgets_component__WEBPACK_IMPORTED_MODULE_82__["Component"]; }); +/* harmony import */ var _widgets_managedFocusFeature__WEBPACK_IMPORTED_MODULE_107__ = __webpack_require__(64); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ManagedFocusFeature", function() { return _widgets_managedFocusFeature__WEBPACK_IMPORTED_MODULE_107__["ManagedFocusFeature"]; }); -/* harmony import */ var _widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_83__ = __webpack_require__(117); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ManagedFocusComponent", function() { return _widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_83__["ManagedFocusComponent"]; }); +/* harmony import */ var _widgets_tabGuardComp__WEBPACK_IMPORTED_MODULE_108__ = __webpack_require__(179); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TabGuardComp", function() { return _widgets_tabGuardComp__WEBPACK_IMPORTED_MODULE_108__["TabGuardComp"]; }); -/* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_84__ = __webpack_require__(55); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupComponent", function() { return _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_84__["PopupComponent"]; }); +/* harmony import */ var _widgets_tabGuardCtrl__WEBPACK_IMPORTED_MODULE_109__ = __webpack_require__(180); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TabGuardCtrl", function() { return _widgets_tabGuardCtrl__WEBPACK_IMPORTED_MODULE_109__["TabGuardCtrl"]; }); -/* harmony import */ var _widgets_popupService__WEBPACK_IMPORTED_MODULE_85__ = __webpack_require__(133); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupService", function() { return _widgets_popupService__WEBPACK_IMPORTED_MODULE_85__["PopupService"]; }); +/* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_110__ = __webpack_require__(85); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupComponent", function() { return _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_110__["PopupComponent"]; }); -/* harmony import */ var _widgets_touchListener__WEBPACK_IMPORTED_MODULE_86__ = __webpack_require__(65); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TouchListener", function() { return _widgets_touchListener__WEBPACK_IMPORTED_MODULE_86__["TouchListener"]; }); +/* harmony import */ var _widgets_popupService__WEBPACK_IMPORTED_MODULE_111__ = __webpack_require__(172); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupService", function() { return _widgets_popupService__WEBPACK_IMPORTED_MODULE_111__["PopupService"]; }); -/* harmony import */ var _widgets_virtualList__WEBPACK_IMPORTED_MODULE_87__ = __webpack_require__(199); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "VirtualList", function() { return _widgets_virtualList__WEBPACK_IMPORTED_MODULE_87__["VirtualList"]; }); +/* harmony import */ var _widgets_touchListener__WEBPACK_IMPORTED_MODULE_112__ = __webpack_require__(82); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TouchListener", function() { return _widgets_touchListener__WEBPACK_IMPORTED_MODULE_112__["TouchListener"]; }); -/* harmony import */ var _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_88__ = __webpack_require__(102); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellRangeType", function() { return _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_88__["CellRangeType"]; }); +/* harmony import */ var _widgets_virtualList__WEBPACK_IMPORTED_MODULE_113__ = __webpack_require__(249); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "VirtualList", function() { return _widgets_virtualList__WEBPACK_IMPORTED_MODULE_113__["VirtualList"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectionHandleType", function() { return _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_88__["SelectionHandleType"]; }); +/* harmony import */ var _interfaces_IRangeService__WEBPACK_IMPORTED_MODULE_114__ = __webpack_require__(116); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellRangeType", function() { return _interfaces_IRangeService__WEBPACK_IMPORTED_MODULE_114__["CellRangeType"]; }); -/* harmony import */ var _vanillaFrameworkOverrides__WEBPACK_IMPORTED_MODULE_89__ = __webpack_require__(147); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "VanillaFrameworkOverrides", function() { return _vanillaFrameworkOverrides__WEBPACK_IMPORTED_MODULE_89__["VanillaFrameworkOverrides"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectionHandleType", function() { return _interfaces_IRangeService__WEBPACK_IMPORTED_MODULE_114__["SelectionHandleType"]; }); -/* harmony import */ var _cellNavigationService__WEBPACK_IMPORTED_MODULE_90__ = __webpack_require__(143); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellNavigationService", function() { return _cellNavigationService__WEBPACK_IMPORTED_MODULE_90__["CellNavigationService"]; }); +/* harmony import */ var _autoScrollService__WEBPACK_IMPORTED_MODULE_115__ = __webpack_require__(169); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AutoScrollService", function() { return _autoScrollService__WEBPACK_IMPORTED_MODULE_115__["AutoScrollService"]; }); -/* harmony import */ var _alignedGridsService__WEBPACK_IMPORTED_MODULE_91__ = __webpack_require__(157); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AlignedGridsService", function() { return _alignedGridsService__WEBPACK_IMPORTED_MODULE_91__["AlignedGridsService"]; }); +/* harmony import */ var _vanillaFrameworkOverrides__WEBPACK_IMPORTED_MODULE_116__ = __webpack_require__(187); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "VanillaFrameworkOverrides", function() { return _vanillaFrameworkOverrides__WEBPACK_IMPORTED_MODULE_116__["VanillaFrameworkOverrides"]; }); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_92__ = __webpack_require__(25); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Constants", function() { return _constants__WEBPACK_IMPORTED_MODULE_92__["Constants"]; }); +/* harmony import */ var _cellNavigationService__WEBPACK_IMPORTED_MODULE_117__ = __webpack_require__(184); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellNavigationService", function() { return _cellNavigationService__WEBPACK_IMPORTED_MODULE_117__["CellNavigationService"]; }); -/* harmony import */ var _grid__WEBPACK_IMPORTED_MODULE_93__ = __webpack_require__(95); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Grid", function() { return _grid__WEBPACK_IMPORTED_MODULE_93__["Grid"]; }); +/* harmony import */ var _alignedGridsService__WEBPACK_IMPORTED_MODULE_118__ = __webpack_require__(197); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AlignedGridsService", function() { return _alignedGridsService__WEBPACK_IMPORTED_MODULE_118__["AlignedGridsService"]; }); -/* harmony import */ var _gridApi__WEBPACK_IMPORTED_MODULE_94__ = __webpack_require__(130); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridApi", function() { return _gridApi__WEBPACK_IMPORTED_MODULE_94__["GridApi"]; }); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_119__ = __webpack_require__(15); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Constants", function() { return _constants_constants__WEBPACK_IMPORTED_MODULE_119__["Constants"]; }); -/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_95__ = __webpack_require__(44); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Events", function() { return _eventKeys__WEBPACK_IMPORTED_MODULE_95__["Events"]; }); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_120__ = __webpack_require__(65); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "KeyCode", function() { return _constants_keyCode__WEBPACK_IMPORTED_MODULE_120__["KeyCode"]; }); -/* harmony import */ var _focusController__WEBPACK_IMPORTED_MODULE_96__ = __webpack_require__(141); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "FocusController", function() { return _focusController__WEBPACK_IMPORTED_MODULE_96__["FocusController"]; }); +/* harmony import */ var _grid__WEBPACK_IMPORTED_MODULE_121__ = __webpack_require__(106); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Grid", function() { return _grid__WEBPACK_IMPORTED_MODULE_121__["Grid"]; }); -/* harmony import */ var _functions__WEBPACK_IMPORTED_MODULE_97__ = __webpack_require__(200); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "defaultGroupComparator", function() { return _functions__WEBPACK_IMPORTED_MODULE_97__["defaultGroupComparator"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridCoreCreator", function() { return _grid__WEBPACK_IMPORTED_MODULE_121__["GridCoreCreator"]; }); -/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_98__ = __webpack_require__(50); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridOptionsWrapper", function() { return _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_98__["GridOptionsWrapper"]; }); +/* harmony import */ var _gridApi__WEBPACK_IMPORTED_MODULE_122__ = __webpack_require__(149); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridApi", function() { return _gridApi__WEBPACK_IMPORTED_MODULE_122__["GridApi"]; }); -/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_99__ = __webpack_require__(36); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "EventService", function() { return _eventService__WEBPACK_IMPORTED_MODULE_99__["EventService"]; }); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_123__ = __webpack_require__(24); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Events", function() { return _eventKeys__WEBPACK_IMPORTED_MODULE_123__["Events"]; }); -/* harmony import */ var _rowNodes_selectableService__WEBPACK_IMPORTED_MODULE_100__ = __webpack_require__(165); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectableService", function() { return _rowNodes_selectableService__WEBPACK_IMPORTED_MODULE_100__["SelectableService"]; }); +/* harmony import */ var _focusService__WEBPACK_IMPORTED_MODULE_124__ = __webpack_require__(173); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "FocusService", function() { return _focusService__WEBPACK_IMPORTED_MODULE_124__["FocusService"]; }); -/* harmony import */ var _gridCore__WEBPACK_IMPORTED_MODULE_101__ = __webpack_require__(137); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridCore", function() { return _gridCore__WEBPACK_IMPORTED_MODULE_101__["GridCore"]; }); +/* harmony import */ var _functions__WEBPACK_IMPORTED_MODULE_125__ = __webpack_require__(250); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "defaultGroupComparator", function() { return _functions__WEBPACK_IMPORTED_MODULE_125__["defaultGroupComparator"]; }); -/* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_102__ = __webpack_require__(134); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Logger", function() { return _logger__WEBPACK_IMPORTED_MODULE_102__["Logger"]; }); +/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_126__ = __webpack_require__(107); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridOptionsWrapper", function() { return _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_126__["GridOptionsWrapper"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "LoggerFactory", function() { return _logger__WEBPACK_IMPORTED_MODULE_102__["LoggerFactory"]; }); +/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_127__ = __webpack_require__(11); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "EventService", function() { return _eventService__WEBPACK_IMPORTED_MODULE_127__["EventService"]; }); -/* harmony import */ var _selectionController__WEBPACK_IMPORTED_MODULE_103__ = __webpack_require__(96); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectionController", function() { return _selectionController__WEBPACK_IMPORTED_MODULE_103__["SelectionController"]; }); +/* harmony import */ var _rowNodes_selectableService__WEBPACK_IMPORTED_MODULE_128__ = __webpack_require__(204); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectableService", function() { return _rowNodes_selectableService__WEBPACK_IMPORTED_MODULE_128__["SelectableService"]; }); -/* harmony import */ var _sortController__WEBPACK_IMPORTED_MODULE_104__ = __webpack_require__(140); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SortController", function() { return _sortController__WEBPACK_IMPORTED_MODULE_104__["SortController"]; }); +/* harmony import */ var _rowNodes_rowNodeSorter__WEBPACK_IMPORTED_MODULE_129__ = __webpack_require__(231); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNodeSorter", function() { return _rowNodes_rowNodeSorter__WEBPACK_IMPORTED_MODULE_129__["RowNodeSorter"]; }); -/* harmony import */ var _templateService__WEBPACK_IMPORTED_MODULE_105__ = __webpack_require__(132); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TemplateService", function() { return _templateService__WEBPACK_IMPORTED_MODULE_105__["TemplateService"]; }); +/* harmony import */ var _ctrlsService__WEBPACK_IMPORTED_MODULE_130__ = __webpack_require__(232); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CtrlsService", function() { return _ctrlsService__WEBPACK_IMPORTED_MODULE_130__["CtrlsService"]; }); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_106__ = __webpack_require__(7); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Color", function() { return _utils__WEBPACK_IMPORTED_MODULE_106__["Color"]; }); +/* harmony import */ var _gridComp_gridComp__WEBPACK_IMPORTED_MODULE_131__ = __webpack_require__(177); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridComp", function() { return _gridComp_gridComp__WEBPACK_IMPORTED_MODULE_131__["GridComp"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "stringToArray", function() { return _utils__WEBPACK_IMPORTED_MODULE_106__["stringToArray"]; }); +/* harmony import */ var _gridComp_gridCtrl__WEBPACK_IMPORTED_MODULE_132__ = __webpack_require__(178); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridCtrl", function() { return _gridComp_gridCtrl__WEBPACK_IMPORTED_MODULE_132__["GridCtrl"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "_", function() { return _utils__WEBPACK_IMPORTED_MODULE_106__["_"]; }); +/* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_133__ = __webpack_require__(174); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Logger", function() { return _logger__WEBPACK_IMPORTED_MODULE_133__["Logger"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "NumberSequence", function() { return _utils__WEBPACK_IMPORTED_MODULE_106__["NumberSequence"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "LoggerFactory", function() { return _logger__WEBPACK_IMPORTED_MODULE_133__["LoggerFactory"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PromiseStatus", function() { return _utils__WEBPACK_IMPORTED_MODULE_106__["PromiseStatus"]; }); +/* harmony import */ var _selectionService__WEBPACK_IMPORTED_MODULE_134__ = __webpack_require__(109); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectionService", function() { return _selectionService__WEBPACK_IMPORTED_MODULE_134__["SelectionService"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Promise", function() { return _utils__WEBPACK_IMPORTED_MODULE_106__["Promise"]; }); +/* harmony import */ var _sortController__WEBPACK_IMPORTED_MODULE_135__ = __webpack_require__(182); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SortController", function() { return _sortController__WEBPACK_IMPORTED_MODULE_135__["SortController"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Timer", function() { return _utils__WEBPACK_IMPORTED_MODULE_106__["Timer"]; }); +/* harmony import */ var _templateService__WEBPACK_IMPORTED_MODULE_136__ = __webpack_require__(171); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TemplateService", function() { return _templateService__WEBPACK_IMPORTED_MODULE_136__["TemplateService"]; }); -/* harmony import */ var _valueService_valueService__WEBPACK_IMPORTED_MODULE_107__ = __webpack_require__(126); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ValueService", function() { return _valueService_valueService__WEBPACK_IMPORTED_MODULE_107__["ValueService"]; }); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_137__ = __webpack_require__(37); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Color", function() { return _utils__WEBPACK_IMPORTED_MODULE_137__["Color"]; }); -/* harmony import */ var _valueService_valueCache__WEBPACK_IMPORTED_MODULE_108__ = __webpack_require__(155); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ValueCache", function() { return _valueService_valueCache__WEBPACK_IMPORTED_MODULE_108__["ValueCache"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "stringToArray", function() { return _utils__WEBPACK_IMPORTED_MODULE_137__["stringToArray"]; }); -/* harmony import */ var _valueService_expressionService__WEBPACK_IMPORTED_MODULE_109__ = __webpack_require__(131); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ExpressionService", function() { return _valueService_expressionService__WEBPACK_IMPORTED_MODULE_109__["ExpressionService"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "_", function() { return _utils__WEBPACK_IMPORTED_MODULE_137__["_"]; }); -/* harmony import */ var _entities_cellPosition__WEBPACK_IMPORTED_MODULE_110__ = __webpack_require__(187); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellPositionUtils", function() { return _entities_cellPosition__WEBPACK_IMPORTED_MODULE_110__["CellPositionUtils"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "NumberSequence", function() { return _utils__WEBPACK_IMPORTED_MODULE_137__["NumberSequence"]; }); -/* harmony import */ var _entities_rowPosition__WEBPACK_IMPORTED_MODULE_111__ = __webpack_require__(186); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowPositionUtils", function() { return _entities_rowPosition__WEBPACK_IMPORTED_MODULE_111__["RowPositionUtils"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgPromiseStatus", function() { return _utils__WEBPACK_IMPORTED_MODULE_137__["AgPromiseStatus"]; }); -/* harmony import */ var _headerRendering_header_headerPosition__WEBPACK_IMPORTED_MODULE_112__ = __webpack_require__(192); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderPositionUtils", function() { return _headerRendering_header_headerPosition__WEBPACK_IMPORTED_MODULE_112__["HeaderPositionUtils"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgPromise", function() { return _utils__WEBPACK_IMPORTED_MODULE_137__["AgPromise"]; }); -/* harmony import */ var _headerRendering_header_headerNavigationService__WEBPACK_IMPORTED_MODULE_113__ = __webpack_require__(124); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderNavigationService", function() { return _headerRendering_header_headerNavigationService__WEBPACK_IMPORTED_MODULE_113__["HeaderNavigationService"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Timer", function() { return _utils__WEBPACK_IMPORTED_MODULE_137__["Timer"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderNavigationDirection", function() { return _headerRendering_header_headerNavigationService__WEBPACK_IMPORTED_MODULE_113__["HeaderNavigationDirection"]; }); +/* harmony import */ var _valueService_valueService__WEBPACK_IMPORTED_MODULE_138__ = __webpack_require__(163); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ValueService", function() { return _valueService_valueService__WEBPACK_IMPORTED_MODULE_138__["ValueService"]; }); -/* harmony import */ var _propertyKeys__WEBPACK_IMPORTED_MODULE_114__ = __webpack_require__(49); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PropertyKeys", function() { return _propertyKeys__WEBPACK_IMPORTED_MODULE_114__["PropertyKeys"]; }); +/* harmony import */ var _valueService_valueCache__WEBPACK_IMPORTED_MODULE_139__ = __webpack_require__(195); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ValueCache", function() { return _valueService_valueCache__WEBPACK_IMPORTED_MODULE_139__["ValueCache"]; }); -/* harmony import */ var _columnController_columnApi__WEBPACK_IMPORTED_MODULE_115__ = __webpack_require__(98); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnApi", function() { return _columnController_columnApi__WEBPACK_IMPORTED_MODULE_115__["ColumnApi"]; }); +/* harmony import */ var _valueService_expressionService__WEBPACK_IMPORTED_MODULE_140__ = __webpack_require__(170); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ExpressionService", function() { return _valueService_expressionService__WEBPACK_IMPORTED_MODULE_140__["ExpressionService"]; }); -/* harmony import */ var _components_framework_frameworkComponentWrapper__WEBPACK_IMPORTED_MODULE_116__ = __webpack_require__(201); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BaseComponentWrapper", function() { return _components_framework_frameworkComponentWrapper__WEBPACK_IMPORTED_MODULE_116__["BaseComponentWrapper"]; }); +/* harmony import */ var _entities_cellPosition__WEBPACK_IMPORTED_MODULE_141__ = __webpack_require__(222); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellPositionUtils", function() { return _entities_cellPosition__WEBPACK_IMPORTED_MODULE_141__["CellPositionUtils"]; }); -/* harmony import */ var _environment__WEBPACK_IMPORTED_MODULE_117__ = __webpack_require__(161); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Environment", function() { return _environment__WEBPACK_IMPORTED_MODULE_117__["Environment"]; }); +/* harmony import */ var _entities_rowPosition__WEBPACK_IMPORTED_MODULE_142__ = __webpack_require__(221); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowPositionUtils", function() { return _entities_rowPosition__WEBPACK_IMPORTED_MODULE_142__["RowPositionUtils"]; }); -/* harmony import */ var _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_118__ = __webpack_require__(107); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TooltipFeature", function() { return _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_118__["TooltipFeature"]; }); +/* harmony import */ var _headerRendering_common_headerPosition__WEBPACK_IMPORTED_MODULE_143__ = __webpack_require__(226); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderPositionUtils", function() { return _headerRendering_common_headerPosition__WEBPACK_IMPORTED_MODULE_143__["HeaderPositionUtils"]; }); -/* harmony import */ var _interfaces_iChartOptions__WEBPACK_IMPORTED_MODULE_119__ = __webpack_require__(202); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ChartType", function() { return _interfaces_iChartOptions__WEBPACK_IMPORTED_MODULE_119__["ChartType"]; }); +/* harmony import */ var _headerRendering_common_headerNavigationService__WEBPACK_IMPORTED_MODULE_144__ = __webpack_require__(135); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderNavigationService", function() { return _headerRendering_common_headerNavigationService__WEBPACK_IMPORTED_MODULE_144__["HeaderNavigationService"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "LegendPosition", function() { return _interfaces_iChartOptions__WEBPACK_IMPORTED_MODULE_119__["LegendPosition"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderNavigationDirection", function() { return _headerRendering_common_headerNavigationService__WEBPACK_IMPORTED_MODULE_144__["HeaderNavigationDirection"]; }); -/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_120__ = __webpack_require__(38); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ModuleNames", function() { return _modules_moduleNames__WEBPACK_IMPORTED_MODULE_120__["ModuleNames"]; }); +/* harmony import */ var _propertyKeys__WEBPACK_IMPORTED_MODULE_145__ = __webpack_require__(31); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PropertyKeys", function() { return _propertyKeys__WEBPACK_IMPORTED_MODULE_145__["PropertyKeys"]; }); -/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_121__ = __webpack_require__(39); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ModuleRegistry", function() { return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_121__["ModuleRegistry"]; }); +/* harmony import */ var _columns_columnApi__WEBPACK_IMPORTED_MODULE_146__ = __webpack_require__(111); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnApi", function() { return _columns_columnApi__WEBPACK_IMPORTED_MODULE_146__["ColumnApi"]; }); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_122__ = __webpack_require__(43); +/* harmony import */ var _components_framework_frameworkComponentWrapper__WEBPACK_IMPORTED_MODULE_147__ = __webpack_require__(251); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BaseComponentWrapper", function() { return _components_framework_frameworkComponentWrapper__WEBPACK_IMPORTED_MODULE_147__["BaseComponentWrapper"]; }); + +/* harmony import */ var _environment__WEBPACK_IMPORTED_MODULE_148__ = __webpack_require__(200); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Environment", function() { return _environment__WEBPACK_IMPORTED_MODULE_148__["Environment"]; }); + +/* harmony import */ var _widgets_customTooltipFeature__WEBPACK_IMPORTED_MODULE_149__ = __webpack_require__(56); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CustomTooltipFeature", function() { return _widgets_customTooltipFeature__WEBPACK_IMPORTED_MODULE_149__["CustomTooltipFeature"]; }); + +/* harmony import */ var _interfaces_iSparklineCellRendererParams__WEBPACK_IMPORTED_MODULE_150__ = __webpack_require__(252); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BarColumnLabelPlacement", function() { return _interfaces_iSparklineCellRendererParams__WEBPACK_IMPORTED_MODULE_150__["BarColumnLabelPlacement"]; }); + +/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_151__ = __webpack_require__(16); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ModuleNames", function() { return _modules_moduleNames__WEBPACK_IMPORTED_MODULE_151__["ModuleNames"]; }); + +/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_152__ = __webpack_require__(17); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ModuleRegistry", function() { return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_152__["ModuleRegistry"]; }); + +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_153__ = __webpack_require__(23); /* empty/unused harmony star reexport *//** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -609,7 +712,7 @@ globalObj.HTMLSelectElement = typeof HTMLSelectElement === 'undefined' ? {} : HT globalObj.HTMLInputElement = typeof HTMLInputElement === 'undefined' ? {} : HTMLInputElement; globalObj.Node = typeof Node === 'undefined' ? {} : Node; globalObj.MouseEvent = typeof MouseEvent === 'undefined' ? {} : MouseEvent; -// columnController +// columns @@ -627,6 +730,8 @@ globalObj.MouseEvent = typeof MouseEvent === 'undefined' ? {} : MouseEvent; +// excel + // dragAndDrop @@ -635,7 +740,9 @@ globalObj.MouseEvent = typeof MouseEvent === 'undefined' ? {} : MouseEvent; -// filter + + + @@ -647,6 +754,11 @@ globalObj.MouseEvent = typeof MouseEvent === 'undefined' ? {} : MouseEvent; + + +// rowContainer + + // headerRendering @@ -657,6 +769,13 @@ globalObj.MouseEvent = typeof MouseEvent === 'undefined' ? {} : MouseEvent; + + + + + + + // layout // misc @@ -669,10 +788,15 @@ globalObj.MouseEvent = typeof MouseEvent === 'undefined' ? {} : MouseEvent; +// rendering / cellRenderers + + + // features + // rendering @@ -688,8 +812,10 @@ globalObj.MouseEvent = typeof MouseEvent === 'undefined' ? {} : MouseEvent; + //styling + // widgets @@ -706,6 +832,11 @@ globalObj.MouseEvent = typeof MouseEvent === 'undefined' ? {} : MouseEvent; + + + + + @@ -745,7 +876,12 @@ globalObj.MouseEvent = typeof MouseEvent === 'undefined' ? {} : MouseEvent; -// charts + + + + + +// sparklines @@ -788,15 +924,18 @@ module.exports = g; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnFactory", function() { return ColumnFactory; }); /* harmony import */ var _columnKeyCreator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6); -/* harmony import */ var _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(33); -/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(35); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37); -/* harmony import */ var _entities_defaultColumnTypes__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(40); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(41); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony import */ var _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(8); +/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(10); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(12); +/* harmony import */ var _entities_defaultColumnTypes__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(19); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(20); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(15); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(13); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(7); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(18); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -829,6 +968,9 @@ var __param = (undefined && undefined.__param) || function (paramIndex, decorato + + + // takes ColDefs and ColGroupDefs and turns them into Columns and OriginalGroups var ColumnFactory = /** @class */ (function (_super) { __extends(ColumnFactory, _super); @@ -838,24 +980,20 @@ var ColumnFactory = /** @class */ (function (_super) { ColumnFactory.prototype.setBeans = function (loggerFactory) { this.logger = loggerFactory.create('ColumnFactory'); }; - ColumnFactory.prototype.createColumnTree = function (defs, primaryColumns, existingColumns) { + ColumnFactory.prototype.createColumnTree = function (defs, primaryColumns, existingTree) { // column key creator dishes out unique column id's in a deterministic way, // so if we have two grids (that could be master/slave) with same column definitions, // then this ensures the two grids use identical id's. var columnKeyCreator = new _columnKeyCreator__WEBPACK_IMPORTED_MODULE_0__["ColumnKeyCreator"](); - if (existingColumns) { - var existingKeys = existingColumns.map(function (col) { return col.getId(); }); - columnKeyCreator.addExistingKeys(existingKeys); - } - // we take a copy of the columns as we are going to be removing from them - var existingColsCopy = existingColumns ? existingColumns.slice() : null; + var _a = this.extractExistingTreeData(existingTree), existingCols = _a.existingCols, existingGroups = _a.existingGroups, existingColKeys = _a.existingColKeys; + columnKeyCreator.addExistingKeys(existingColKeys); // create am unbalanced tree that maps the provided definitions - var unbalancedTree = this.recursivelyCreateColumns(defs, 0, primaryColumns, existingColsCopy, columnKeyCreator, null); + var unbalancedTree = this.recursivelyCreateColumns(defs, 0, primaryColumns, existingCols, columnKeyCreator, existingGroups); var treeDept = this.findMaxDept(unbalancedTree, 0); this.logger.log('Number of levels for grouped columns is ' + treeDept); var columnTree = this.balanceColumnTree(unbalancedTree, 0, treeDept, columnKeyCreator); var deptFirstCallback = function (child, parent) { - if (child instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"]) { + if (child instanceof _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_1__["ProvidedColumnGroup"]) { child.setupExpandable(); } // we set the original parents at the end, rather than when we go along, as balancing the tree @@ -868,6 +1006,25 @@ var ColumnFactory = /** @class */ (function (_super) { treeDept: treeDept }; }; + ColumnFactory.prototype.extractExistingTreeData = function (existingTree) { + var existingCols = []; + var existingGroups = []; + var existingColKeys = []; + if (existingTree) { + this.columnUtils.depthFirstOriginalTreeSearch(null, existingTree, function (item) { + if (item instanceof _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_1__["ProvidedColumnGroup"]) { + var group = item; + existingGroups.push(group); + } + else { + var col = item; + existingColKeys.push(col.getId()); + existingCols.push(col); + } + }); + } + return { existingCols: existingCols, existingGroups: existingGroups, existingColKeys: existingColKeys }; + }; ColumnFactory.prototype.createForAutoGroups = function (autoGroupCols, gridBalancedTree) { var _this = this; var autoColBalancedTree = []; @@ -882,7 +1039,7 @@ var ColumnFactory = /** @class */ (function (_super) { // at the end, this will be the top of the tree item. var nextChild = column; for (var i = dept - 1; i >= 0; i--) { - var autoGroup = new _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"](null, "FAKE_PATH_" + column.getId() + "}_" + i, true, i); + var autoGroup = new _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_1__["ProvidedColumnGroup"](null, "FAKE_PATH_" + column.getId() + "}_" + i, true, i); this.context.createBean(autoGroup); autoGroup.setChildren([nextChild]); nextChild.setOriginalParent(autoGroup); @@ -894,7 +1051,7 @@ var ColumnFactory = /** @class */ (function (_super) { ColumnFactory.prototype.findDepth = function (balancedColumnTree) { var dept = 0; var pointer = balancedColumnTree; - while (pointer && pointer[0] && pointer[0] instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"]) { + while (pointer && pointer[0] && pointer[0] instanceof _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_1__["ProvidedColumnGroup"]) { dept++; pointer = pointer[0].getChildren(); } @@ -906,7 +1063,7 @@ var ColumnFactory = /** @class */ (function (_super) { // for columns we need to pad for (var i = 0; i < unbalancedTree.length; i++) { var child = unbalancedTree[i]; - if (child instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"]) { + if (child instanceof _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_1__["ProvidedColumnGroup"]) { // child is a group, all we do is go to the next level of recursion var originalGroup = child; var newChildren = this.balanceColumnTree(originalGroup.getChildren(), currentDept + 1, columnDept, columnKeyCreator); @@ -921,7 +1078,7 @@ var ColumnFactory = /** @class */ (function (_super) { for (var j = columnDept - 1; j >= currentDept; j--) { var newColId = columnKeyCreator.getUniqueKey(null, null); var colGroupDefMerged = this.createMergedColGroupDef(null); - var paddedGroup = new _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"](colGroupDefMerged, newColId, true, currentDept); + var paddedGroup = new _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_1__["ProvidedColumnGroup"](colGroupDefMerged, newColId, true, currentDept); this.context.createBean(paddedGroup); if (currentPaddedGroup) { currentPaddedGroup.setChildren([paddedGroup]); @@ -932,9 +1089,9 @@ var ColumnFactory = /** @class */ (function (_super) { } } // likewise this if statement will not run if no padded groups - if (firstPaddedGroup) { + if (firstPaddedGroup && currentPaddedGroup) { result.push(firstPaddedGroup); - var hasGroups = unbalancedTree.some(function (child) { return child instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"]; }); + var hasGroups = unbalancedTree.some(function (leaf) { return leaf instanceof _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_1__["ProvidedColumnGroup"]; }); if (hasGroups) { currentPaddedGroup.setChildren([child]); continue; @@ -953,7 +1110,7 @@ var ColumnFactory = /** @class */ (function (_super) { var maxDeptThisLevel = dept; for (var i = 0; i < treeChildren.length; i++) { var abstractColumn = treeChildren[i]; - if (abstractColumn instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"]) { + if (abstractColumn instanceof _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_1__["ProvidedColumnGroup"]) { var originalGroup = abstractColumn; var newDept = this.findMaxDept(originalGroup.getChildren(), dept + 1); if (maxDeptThisLevel < newDept) { @@ -963,7 +1120,7 @@ var ColumnFactory = /** @class */ (function (_super) { } return maxDeptThisLevel; }; - ColumnFactory.prototype.recursivelyCreateColumns = function (defs, level, primaryColumns, existingColsCopy, columnKeyCreator, parent) { + ColumnFactory.prototype.recursivelyCreateColumns = function (defs, level, primaryColumns, existingColsCopy, columnKeyCreator, existingGroups) { var _this = this; var result = []; if (!defs) { @@ -972,32 +1129,36 @@ var ColumnFactory = /** @class */ (function (_super) { defs.forEach(function (def) { var newGroupOrColumn; if (_this.isColumnGroup(def)) { - newGroupOrColumn = _this.createColumnGroup(primaryColumns, def, level, existingColsCopy, columnKeyCreator, parent); + newGroupOrColumn = _this.createColumnGroup(primaryColumns, def, level, existingColsCopy, columnKeyCreator, existingGroups); } else { - newGroupOrColumn = _this.createColumn(primaryColumns, def, existingColsCopy, columnKeyCreator, parent); + newGroupOrColumn = _this.createColumn(primaryColumns, def, existingColsCopy, columnKeyCreator); } result.push(newGroupOrColumn); }); return result; }; - ColumnFactory.prototype.createColumnGroup = function (primaryColumns, colGroupDef, level, existingColumns, columnKeyCreator, parent) { + ColumnFactory.prototype.createColumnGroup = function (primaryColumns, colGroupDef, level, existingColumns, columnKeyCreator, existingGroups) { var colGroupDefMerged = this.createMergedColGroupDef(colGroupDef); - var groupId = columnKeyCreator.getUniqueKey(colGroupDefMerged.groupId, null); - var originalGroup = new _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"](colGroupDefMerged, groupId, false, level); + var groupId = columnKeyCreator.getUniqueKey(colGroupDefMerged.groupId || null, null); + var originalGroup = new _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_1__["ProvidedColumnGroup"](colGroupDefMerged, groupId, false, level); this.context.createBean(originalGroup); - var children = this.recursivelyCreateColumns(colGroupDefMerged.children, level + 1, primaryColumns, existingColumns, columnKeyCreator, originalGroup); + var existingGroup = this.findExistingGroup(colGroupDef, existingGroups); + if (existingGroup && existingGroup.isExpanded()) { + originalGroup.setExpanded(true); + } + var children = this.recursivelyCreateColumns(colGroupDefMerged.children, level + 1, primaryColumns, existingColumns, columnKeyCreator, existingGroups); originalGroup.setChildren(children); return originalGroup; }; ColumnFactory.prototype.createMergedColGroupDef = function (colGroupDef) { var colGroupDefMerged = {}; - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].assign(colGroupDefMerged, this.gridOptionsWrapper.getDefaultColGroupDef()); - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].assign(colGroupDefMerged, colGroupDef); + Object.assign(colGroupDefMerged, this.gridOptionsWrapper.getDefaultColGroupDef()); + Object.assign(colGroupDefMerged, colGroupDef); this.checkForDeprecatedItems(colGroupDefMerged); return colGroupDefMerged; }; - ColumnFactory.prototype.createColumn = function (primaryColumns, colDef, existingColsCopy, columnKeyCreator, parent) { + ColumnFactory.prototype.createColumn = function (primaryColumns, colDef, existingColsCopy, columnKeyCreator) { var colDefMerged = this.mergeColDefs(colDef); this.checkForDeprecatedItems(colDefMerged); // see if column already exists @@ -1010,70 +1171,144 @@ var ColumnFactory = /** @class */ (function (_super) { } else { column.setColDef(colDefMerged, colDef); + this.applyColumnState(column, colDefMerged); } return column; }; - ColumnFactory.prototype.findExistingColumn = function (colDef, existingColsCopy) { - var res = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].find(existingColsCopy, function (col) { - var oldColDef = col.getUserProvidedColDef(); - if (!oldColDef) { + ColumnFactory.prototype.applyColumnState = function (column, colDef) { + // flex + var flex = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_8__["attrToNumber"])(colDef.flex); + if (flex !== undefined) { + column.setFlex(flex); + } + // width - we only set width if column is not flexing + var noFlexThisCol = column.getFlex() <= 0; + if (noFlexThisCol) { + // both null and undefined means we skip, as it's not possible to 'clear' width (a column must have a width) + var width = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_8__["attrToNumber"])(colDef.width); + if (width != null) { + column.setActualWidth(width); + } + else { + // otherwise set the width again, in case min or max width has changed, + // and width needs to be adjusted. + var widthBeforeUpdate = column.getActualWidth(); + column.setActualWidth(widthBeforeUpdate); + } + } + // sort - anything but undefined will set sort, thus null or empty string will clear the sort + if (colDef.sort !== undefined) { + if (colDef.sort == _constants_constants__WEBPACK_IMPORTED_MODULE_6__["Constants"].SORT_ASC || colDef.sort == _constants_constants__WEBPACK_IMPORTED_MODULE_6__["Constants"].SORT_DESC) { + column.setSort(colDef.sort); + } + else { + column.setSort(undefined); + } + } + // sorted at - anything but undefined, thus null will clear the sortIndex + var sortIndex = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_8__["attrToNumber"])(colDef.sortIndex); + if (sortIndex !== undefined) { + column.setSortIndex(sortIndex); + } + // hide - anything but undefined, thus null will clear the hide + var hide = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_8__["attrToBoolean"])(colDef.hide); + if (hide !== undefined) { + column.setVisible(!hide); + } + // pinned - anything but undefined, thus null or empty string will remove pinned + if (colDef.pinned !== undefined) { + column.setPinned(colDef.pinned); + } + }; + ColumnFactory.prototype.findExistingColumn = function (newColDef, existingColsCopy) { + var res = (existingColsCopy || []).find(function (existingCol) { + var existingColDef = existingCol.getUserProvidedColDef(); + if (!existingColDef) { return false; } - // first check object references - if (oldColDef === colDef) { + var newHasId = newColDef.colId != null; + var newHasField = newColDef.field != null; + if (newHasId) { + return existingCol.getId() === newColDef.colId; + } + if (newHasField) { + return existingColDef.field === newColDef.field; + } + // if no id or field present, then try object equivalence. + if (existingColDef === newColDef) { return true; } - // second check id's - var oldColHadId = oldColDef.colId !== null && oldColDef.colId !== undefined; - if (oldColHadId) { - return oldColDef.colId === colDef.colId; + return false; + }); + // make sure we remove, so if user provided duplicate id, then we don't have more than + // one column instance for colDef with common id + if (existingColsCopy && res) { + Object(_utils_array__WEBPACK_IMPORTED_MODULE_9__["removeFromArray"])(existingColsCopy, res); + } + return res || null; + }; + ColumnFactory.prototype.findExistingGroup = function (newGroupDef, existingGroups) { + var res = existingGroups.find(function (existingGroup) { + var existingDef = existingGroup.getColGroupDef(); + if (!existingDef) { + return false; + } + var newHasId = newGroupDef.groupId != null; + if (newHasId) { + return existingGroup.getId() === newGroupDef.groupId; } return false; }); // make sure we remove, so if user provided duplicate id, then we don't have more than // one column instance for colDef with common id if (res) { - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].removeFromArray(existingColsCopy, res); + Object(_utils_array__WEBPACK_IMPORTED_MODULE_9__["removeFromArray"])(existingGroups, res); } - return res; + return res || null; }; ColumnFactory.prototype.mergeColDefs = function (colDef) { // start with empty merged definition var colDefMerged = {}; // merge properties from default column definitions - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].assign(colDefMerged, this.gridOptionsWrapper.getDefaultColDef()); + var defaultColDef = this.gridOptionsWrapper.getDefaultColDef(); + Object(_utils_object__WEBPACK_IMPORTED_MODULE_7__["mergeDeep"])(colDefMerged, defaultColDef, false, true); // merge properties from column type properties - if (colDef.type) { - this.assignColumnTypes(colDef, colDefMerged); + var columnType = colDef.type; + if (!columnType) { + columnType = defaultColDef && defaultColDef.type; + } + // if type of both colDef and defaultColDef, then colDef gets preference + if (columnType) { + this.assignColumnTypes(columnType, colDefMerged); } // merge properties from column definitions - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].assign(colDefMerged, colDef); + Object(_utils_object__WEBPACK_IMPORTED_MODULE_7__["mergeDeep"])(colDefMerged, colDef, false, true); return colDefMerged; }; - ColumnFactory.prototype.assignColumnTypes = function (colDef, colDefMerged) { - var typeKeys; - if (colDef.type instanceof Array) { - var invalidArray = colDef.type.some(function (a) { return typeof a !== 'string'; }); + ColumnFactory.prototype.assignColumnTypes = function (type, colDefMerged) { + var typeKeys = []; + if (type instanceof Array) { + var invalidArray = type.some(function (a) { return typeof a !== 'string'; }); if (invalidArray) { - console.warn("ag-grid: if colDef.type is supplied an array it should be of type 'string[]'"); + console.warn("AG Grid: if colDef.type is supplied an array it should be of type 'string[]'"); } else { - typeKeys = colDef.type; + typeKeys = type; } } - else if (typeof colDef.type === 'string') { - typeKeys = colDef.type.split(','); + else if (typeof type === 'string') { + typeKeys = type.split(','); } else { - console.warn("ag-grid: colDef.type should be of type 'string' | 'string[]'"); + console.warn("AG Grid: colDef.type should be of type 'string' | 'string[]'"); return; } // merge user defined with default column types - var allColumnTypes = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].assign({}, _entities_defaultColumnTypes__WEBPACK_IMPORTED_MODULE_4__["DefaultColumnTypes"]); + var allColumnTypes = Object.assign({}, _entities_defaultColumnTypes__WEBPACK_IMPORTED_MODULE_4__["DefaultColumnTypes"]); var userTypes = this.gridOptionsWrapper.getColumnTypes() || {}; - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(userTypes, function (key, value) { + Object(_utils_object__WEBPACK_IMPORTED_MODULE_7__["iterateObject"])(userTypes, function (key, value) { if (key in allColumnTypes) { - console.warn("ag-Grid: the column type '" + key + "' is a default column type and cannot be overridden."); + console.warn("AG Grid: the column type '" + key + "' is a default column type and cannot be overridden."); } else { allColumnTypes[key] = value; @@ -1082,10 +1317,10 @@ var ColumnFactory = /** @class */ (function (_super) { typeKeys.forEach(function (t) { var typeColDef = allColumnTypes[t.trim()]; if (typeColDef) { - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].assign(colDefMerged, typeColDef); + Object(_utils_object__WEBPACK_IMPORTED_MODULE_7__["mergeDeep"])(colDefMerged, typeColDef, false, true); } else { - console.warn("ag-grid: colDef.type '" + t + "' does not correspond to defined gridOptions.columnTypes"); + console.warn("AG Grid: colDef.type '" + t + "' does not correspond to defined gridOptions.columnTypes"); } }); }; @@ -1093,25 +1328,25 @@ var ColumnFactory = /** @class */ (function (_super) { if (colDef) { var colDefNoType = colDef; // take out the type, so we can access attributes not defined in the type if (colDefNoType.group !== undefined) { - console.warn('ag-grid: colDef.group is invalid, please check documentation on how to do grouping as it changed in version 3'); + console.warn('AG Grid: colDef.group is invalid, please check documentation on how to do grouping as it changed in version 3'); } if (colDefNoType.headerGroup !== undefined) { - console.warn('ag-grid: colDef.headerGroup is invalid, please check documentation on how to do grouping as it changed in version 3'); + console.warn('AG Grid: colDef.headerGroup is invalid, please check documentation on how to do grouping as it changed in version 3'); } if (colDefNoType.headerGroupShow !== undefined) { - console.warn('ag-grid: colDef.headerGroupShow is invalid, should be columnGroupShow, please check documentation on how to do grouping as it changed in version 3'); + console.warn('AG Grid: colDef.headerGroupShow is invalid, should be columnGroupShow, please check documentation on how to do grouping as it changed in version 3'); } if (colDefNoType.suppressRowGroup !== undefined) { - console.warn('ag-grid: colDef.suppressRowGroup is deprecated, please use colDef.type instead'); + console.warn('AG Grid: colDef.suppressRowGroup is deprecated, please use colDef.type instead'); } if (colDefNoType.suppressAggregation !== undefined) { - console.warn('ag-grid: colDef.suppressAggregation is deprecated, please use colDef.type instead'); + console.warn('AG Grid: colDef.suppressAggregation is deprecated, please use colDef.type instead'); } if (colDefNoType.suppressRowGroup || colDefNoType.suppressAggregation) { - console.warn('ag-grid: colDef.suppressAggregation and colDef.suppressRowGroup are deprecated, use allowRowGroup, allowPivot and allowValue instead'); + console.warn('AG Grid: colDef.suppressAggregation and colDef.suppressRowGroup are deprecated, use allowRowGroup, allowPivot and allowValue instead'); } if (colDefNoType.displayName) { - console.warn("ag-grid: Found displayName " + colDefNoType.displayName + ", please use headerName instead, displayName is deprecated."); + console.warn("AG Grid: Found displayName " + colDefNoType.displayName + ", please use headerName instead, displayName is deprecated."); colDefNoType.headerName = colDefNoType.displayName; } } @@ -1120,9 +1355,6 @@ var ColumnFactory = /** @class */ (function (_super) { ColumnFactory.prototype.isColumnGroup = function (abstractColDef) { return abstractColDef.children !== undefined; }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('gridOptionsWrapper') - ], ColumnFactory.prototype, "gridOptionsWrapper", void 0); __decorate([ Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('columnUtils') ], ColumnFactory.prototype, "columnUtils", void 0); @@ -1133,7 +1365,7 @@ var ColumnFactory = /** @class */ (function (_super) { Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Bean"])('columnFactory') ], ColumnFactory); return ColumnFactory; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_6__["BeanStub"])); +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_5__["BeanStub"])); @@ -1144,10 +1376,10 @@ var ColumnFactory = /** @class */ (function (_super) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnKeyCreator", function() { return ColumnKeyCreator; }); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -1167,7 +1399,7 @@ var ColumnKeyCreator = /** @class */ (function () { }; ColumnKeyCreator.prototype.getUniqueKey = function (colId, colField) { // in case user passed in number for colId, convert to string - colId = _utils__WEBPACK_IMPORTED_MODULE_0__["_"].toStringOrNull(colId); + colId = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_0__["toStringOrNull"])(colId); var count = 0; while (true) { var idToTry = void 0; @@ -1204,38 +1436,155 @@ var ColumnKeyCreator = /** @class */ (function () { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony import */ var _color__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(8); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Color", function() { return _color__WEBPACK_IMPORTED_MODULE_0__["Color"]; }); - -/* harmony import */ var _csv__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(9); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "stringToArray", function() { return _csv__WEBPACK_IMPORTED_MODULE_1__["stringToArray"]; }); - -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(10); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "_", function() { return _utils__WEBPACK_IMPORTED_MODULE_2__["_"]; }); - -/* harmony import */ var _numberSequence__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(30); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "NumberSequence", function() { return _numberSequence__WEBPACK_IMPORTED_MODULE_3__["NumberSequence"]; }); - -/* harmony import */ var _promise__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(31); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PromiseStatus", function() { return _promise__WEBPACK_IMPORTED_MODULE_4__["PromiseStatus"]; }); - -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Promise", function() { return _promise__WEBPACK_IMPORTED_MODULE_4__["Promise"]; }); - -/* harmony import */ var _timer__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(32); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Timer", function() { return _timer__WEBPACK_IMPORTED_MODULE_5__["Timer"]; }); - +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "makeNull", function() { return makeNull; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "exists", function() { return exists; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "missing", function() { return missing; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "missingOrEmpty", function() { return missingOrEmpty; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "toStringOrNull", function() { return toStringOrNull; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "attrToNumber", function() { return attrToNumber; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "attrToBoolean", function() { return attrToBoolean; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "attrToString", function() { return attrToString; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "referenceCompare", function() { return referenceCompare; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "jsonEquals", function() { return jsonEquals; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "defaultComparator", function() { return defaultComparator; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "values", function() { return values; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ - - - - - - +/** + * If value is undefined, null or blank, returns null, otherwise returns the value + * @param {T} value + * @returns {T | null} + */ +function makeNull(value) { + if (value == null || value === '') { + return null; + } + return value; +} +function exists(value, allowEmptyString) { + if (allowEmptyString === void 0) { allowEmptyString = false; } + return value != null && (value !== '' || allowEmptyString); +} +function missing(value) { + return !exists(value); +} +function missingOrEmpty(value) { + return value == null || value.length === 0; +} +function toStringOrNull(value) { + return value != null && typeof value.toString === 'function' ? value.toString() : null; +} +// for parsing html attributes, where we want empty strings and missing attributes to be undefined +function attrToNumber(value) { + if (value === undefined) { + // undefined or empty means ignore the value + return; + } + if (value === null || value === '') { + // null or blank means clear + return null; + } + if (typeof value === 'number') { + return isNaN(value) ? undefined : value; + } + var valueParsed = parseInt(value, 10); + return isNaN(valueParsed) ? undefined : valueParsed; +} +// for parsing html attributes, where we want empty strings and missing attributes to be undefined +function attrToBoolean(value) { + if (value === undefined) { + // undefined or empty means ignore the value + return; + } + if (value === null || value === '') { + // null means clear + return false; + } + if (typeof value === 'boolean') { + // if simple boolean, return the boolean + return value; + } + // if equal to the string 'true' (ignoring case) then return true + return (/true/i).test(value); +} +// for parsing html attributes, where we want empty strings and missing attributes to be undefined +function attrToString(value) { + if (value == null || value === '') { + return; + } + return value; +} +/** @deprecated */ +function referenceCompare(left, right) { + if (left == null && right == null) { + return true; + } + if (left == null && right != null) { + return false; + } + if (left != null && right == null) { + return false; + } + return left === right; +} +function jsonEquals(val1, val2) { + var val1Json = val1 ? JSON.stringify(val1) : null; + var val2Json = val2 ? JSON.stringify(val2) : null; + return val1Json === val2Json; +} +function defaultComparator(valueA, valueB, accentedCompare) { + if (accentedCompare === void 0) { accentedCompare = false; } + var valueAMissing = valueA == null; + var valueBMissing = valueB == null; + // this is for aggregations sum and avg, where the result can be a number that is wrapped. + // if we didn't do this, then the toString() value would be used, which would result in + // the strings getting used instead of the numbers. + if (valueA && valueA.toNumber) { + valueA = valueA.toNumber(); + } + if (valueB && valueB.toNumber) { + valueB = valueB.toNumber(); + } + if (valueAMissing && valueBMissing) { + return 0; + } + if (valueAMissing) { + return -1; + } + if (valueBMissing) { + return 1; + } + function doQuickCompare(a, b) { + return (a > b ? 1 : (a < b ? -1 : 0)); + } + if (typeof valueA !== 'string') { + return doQuickCompare(valueA, valueB); + } + if (!accentedCompare) { + return doQuickCompare(valueA, valueB); + } + try { + // using local compare also allows chinese comparisons + return valueA.localeCompare(valueB); + } + catch (e) { + // if something wrong with localeCompare, eg not supported + // by browser, then just continue with the quick one + return doQuickCompare(valueA, valueB); + } +} +function values(object) { + if (object instanceof Set || object instanceof Map) { + var arr_1 = []; + object.forEach(function (value) { return arr_1.push(value); }); + return arr_1; + } + return Object.values(object); +} /***/ }), @@ -1244,420 +1593,178 @@ __webpack_require__.r(__webpack_exports__); "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Color", function() { return Color; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ProvidedColumnGroup", function() { return ProvidedColumnGroup; }); +/* harmony import */ var _columnGroup__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(9); +/* harmony import */ var _column__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(10); +/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(11); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var Color = /** @class */ (function () { - /** - * Every color component should be in the [0, 1] range. - * Some easing functions (such as elastic easing) can overshoot the target value by some amount. - * So, when animating colors, if the source or target color components are already near - * or at the edge of the allowed [0, 1] range, it is possible for the intermediate color - * component value to end up outside of that range mid-animation. For this reason the constructor - * performs range checking/constraining. - * @param r Red component. - * @param g Green component. - * @param b Blue component. - * @param a Alpha (opacity) component. - */ - function Color(r, g, b, a) { - if (a === void 0) { a = 1; } - // NaN is treated as 0. - this.r = Math.min(1, Math.max(0, r || 0)); - this.g = Math.min(1, Math.max(0, g || 0)); - this.b = Math.min(1, Math.max(0, b || 0)); - this.a = Math.min(1, Math.max(0, a || 0)); + + + +var ProvidedColumnGroup = /** @class */ (function () { + function ProvidedColumnGroup(colGroupDef, groupId, padding, level) { + this.localEventService = new _eventService__WEBPACK_IMPORTED_MODULE_2__["EventService"](); + this.expandable = false; + this.colGroupDef = colGroupDef; + this.groupId = groupId; + this.expanded = !!colGroupDef && !!colGroupDef.openByDefault; + this.padding = padding; + this.level = level; } - /** - * The given string can be in one of the following formats: - * - #rgb - * - #rrggbb - * - rgb(r, g, b) - * - rgba(r, g, b, a) - * - CSS color name such as 'white', 'orange', 'cyan', etc. - * @param str - */ - Color.fromString = function (str) { - // hexadecimal notation - if (str.indexOf('#') >= 0) { // there can be some leading whitespace - return Color.fromHexString(str); - } - // color name - var hex = Color.nameToHex[str]; - if (hex) { - return Color.fromHexString(hex); - } - // rgb(a) notation - if (str.indexOf('rgb') >= 0) { - return Color.fromRgbaString(str); - } - throw new Error("Invalid color string: '" + str + "'"); + ProvidedColumnGroup.prototype.setOriginalParent = function (originalParent) { + this.originalParent = originalParent; }; - // Using separate RegExp for the short hex notation because strings like `#abcd` - // are matched as ['#abcd', 'ab', 'c', 'd', undefined] when the `{1,2}` quantifier is used. - Color.fromHexString = function (str) { - var values = str.match(Color.hexRe); - if (values) { - var r = parseInt(values[1], 16); - var g = parseInt(values[2], 16); - var b = parseInt(values[3], 16); - var a = values[4] !== undefined ? parseInt(values[4], 16) : 255; - return new Color(r / 255, g / 255, b / 255, a / 255); - } - values = str.match(Color.shortHexRe); - if (values) { - var r = parseInt(values[1], 16); - var g = parseInt(values[2], 16); - var b = parseInt(values[3], 16); - var a = values[4] !== undefined ? parseInt(values[4], 16) : 15; - r += r * 16; - g += g * 16; - b += b * 16; - a += a * 16; - return new Color(r / 255, g / 255, b / 255, a / 255); - } - throw new Error("Malformed hexadecimal color string: '" + str + "'"); + ProvidedColumnGroup.prototype.getOriginalParent = function () { + return this.originalParent; }; - Color.fromRgbaString = function (str) { - var values = str.match(Color.rgbRe); - if (values) { - return new Color(+values[1] / 255, +values[2] / 255, +values[3] / 255); - } - values = str.match(Color.rgbaRe); - if (values) { - return new Color(+values[1] / 255, +values[2] / 255, +values[3] / 255, +values[4]); - } - throw new Error("Malformed rgb/rgba color string: '" + str + "'"); + ProvidedColumnGroup.prototype.getLevel = function () { + return this.level; }; - Color.fromArray = function (arr) { - if (arr.length === 4) { - return new Color(arr[0], arr[1], arr[2], arr[3]); - } - if (arr.length === 3) { - return new Color(arr[0], arr[1], arr[2]); + ProvidedColumnGroup.prototype.isVisible = function () { + // return true if at least one child is visible + if (this.children) { + return this.children.some(function (child) { return child.isVisible(); }); } - throw new Error('The given array should contain 3 or 4 color components (numbers).'); + return false; }; - /** - * Creates an instance of the Color class from the given HSB(A) components. - * @param h Hue in the [0, 360) range. - * @param s Saturation in the [0, 1] range. - * @param b Brightness in the [0, 1] range. - * @param alpha Opacity in the [0, 1] range. Defaults to 1 (completely opaque). - */ - Color.fromHSB = function (h, s, b, alpha) { - if (alpha === void 0) { alpha = 1; } - var rgb = Color.HSBtoRGB(h, s, b); - return new Color(rgb[0], rgb[1], rgb[2], alpha); + ProvidedColumnGroup.prototype.isPadding = function () { + return this.padding; }; - Color.padHex = function (str) { - // Can't use `padStart(2, '0')` here because of IE. - return str.length === 1 ? '0' + str : str; + ProvidedColumnGroup.prototype.setExpanded = function (expanded) { + this.expanded = expanded === undefined ? false : expanded; + var event = { + type: ProvidedColumnGroup.EVENT_EXPANDED_CHANGED + }; + this.localEventService.dispatchEvent(event); }; - Color.prototype.toHexString = function () { - var hex = '#' - + Color.padHex(Math.round(this.r * 255).toString(16)) - + Color.padHex(Math.round(this.g * 255).toString(16)) - + Color.padHex(Math.round(this.b * 255).toString(16)); - if (this.a < 1) { - hex += Color.padHex(Math.round(this.a * 255).toString(16)); - } - return hex; + ProvidedColumnGroup.prototype.isExpandable = function () { + return this.expandable; }; - Color.prototype.toRgbaString = function (fractionDigits) { - if (fractionDigits === void 0) { fractionDigits = 3; } - var components = [ - Math.round(this.r * 255), - Math.round(this.g * 255), - Math.round(this.b * 255) - ]; - var k = Math.pow(10, fractionDigits); - if (this.a !== 1) { - components.push(Math.round(this.a * k) / k); - return "rgba(" + components.join(', ') + ")"; + ProvidedColumnGroup.prototype.isExpanded = function () { + return this.expanded; + }; + ProvidedColumnGroup.prototype.getGroupId = function () { + return this.groupId; + }; + ProvidedColumnGroup.prototype.getId = function () { + return this.getGroupId(); + }; + ProvidedColumnGroup.prototype.setChildren = function (children) { + this.children = children; + }; + ProvidedColumnGroup.prototype.getChildren = function () { + return this.children; + }; + ProvidedColumnGroup.prototype.getColGroupDef = function () { + return this.colGroupDef; + }; + ProvidedColumnGroup.prototype.getLeafColumns = function () { + var result = []; + this.addLeafColumns(result); + return result; + }; + ProvidedColumnGroup.prototype.addLeafColumns = function (leafColumns) { + if (!this.children) { + return; } - return "rgb(" + components.join(', ') + ")"; + this.children.forEach(function (child) { + if (child instanceof _column__WEBPACK_IMPORTED_MODULE_1__["Column"]) { + leafColumns.push(child); + } + else if (child instanceof ProvidedColumnGroup) { + child.addLeafColumns(leafColumns); + } + }); }; - Color.prototype.toString = function () { - if (this.a === 1) { - return this.toHexString(); + ProvidedColumnGroup.prototype.getColumnGroupShow = function () { + var colGroupDef = this.colGroupDef; + if (!colGroupDef) { + return; } - return this.toRgbaString(); + return colGroupDef.columnGroupShow; }; - Color.prototype.toHSB = function () { - return Color.RGBtoHSB(this.r, this.g, this.b); + // need to check that this group has at least one col showing when both expanded and contracted. + // if not, then we don't allow expanding and contracting on this group + ProvidedColumnGroup.prototype.setupExpandable = function () { + var _this = this; + this.setExpandable(); + // note - we should be removing this event listener + this.getLeafColumns().forEach(function (col) { return col.addEventListener(_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_VISIBLE_CHANGED, _this.onColumnVisibilityChanged.bind(_this)); }); }; - /** - * Converts the given RGB triple to an array of HSB (HSV) components. - * The hue component will be `NaN` for achromatic colors. - */ - Color.RGBtoHSB = function (r, g, b) { - var min = Math.min(r, g, b); - var max = Math.max(r, g, b); - var S = max !== 0 ? (max - min) / max : 0; - var H = NaN; - // min == max, means all components are the same - // and the color is a shade of gray with no hue (H is NaN) - if (min !== max) { - var delta = max - min; - var rc = (max - r) / delta; - var gc = (max - g) / delta; - var bc = (max - b) / delta; - if (r === max) { - H = bc - gc; + ProvidedColumnGroup.prototype.setExpandable = function () { + if (this.isPadding()) { + return; + } + // want to make sure the group doesn't disappear when it's open + var atLeastOneShowingWhenOpen = false; + // want to make sure the group doesn't disappear when it's closed + var atLeastOneShowingWhenClosed = false; + // want to make sure the group has something to show / hide + var atLeastOneChangeable = false; + var children = this.findChildrenRemovingPadding(); + for (var i = 0, j = children.length; i < j; i++) { + var abstractColumn = children[i]; + if (!abstractColumn.isVisible()) { + continue; } - else if (g === max) { - H = 2.0 + rc - bc; + // if the abstractColumn is a grid generated group, there will be no colDef + var headerGroupShow = abstractColumn.getColumnGroupShow(); + if (headerGroupShow === _columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"].HEADER_GROUP_SHOW_OPEN) { + atLeastOneShowingWhenOpen = true; + atLeastOneChangeable = true; } - else { - H = 4.0 + gc - rc; + else if (headerGroupShow === _columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"].HEADER_GROUP_SHOW_CLOSED) { + atLeastOneShowingWhenClosed = true; + atLeastOneChangeable = true; } - H /= 6.0; - if (H < 0) { - H = H + 1.0; + else { + atLeastOneShowingWhenOpen = true; + atLeastOneShowingWhenClosed = true; } } - return [H * 360, S, max]; - }; - /** - * Converts the given HSB (HSV) triple to an array of RGB components. - */ - Color.HSBtoRGB = function (H, S, B) { - if (isNaN(H)) { - H = 0; - } - H = (((H % 360) + 360) % 360) / 360; // normalize hue to [0, 360] interval, then scale to [0, 1] - var r = 0; - var g = 0; - var b = 0; - if (S === 0) { - r = g = b = B; - } - else { - var h = (H - Math.floor(H)) * 6; - var f = h - Math.floor(h); - var p = B * (1 - S); - var q = B * (1 - S * f); - var t = B * (1 - (S * (1 - f))); - switch (h >> 0) { // discard the floating point part of the number - case 0: - r = B; - g = t; - b = p; - break; - case 1: - r = q; - g = B; - b = p; - break; - case 2: - r = p; - g = B; - b = t; - break; - case 3: - r = p; - g = q; - b = B; - break; - case 4: - r = t; - g = p; - b = B; - break; - case 5: - r = B; - g = p; - b = q; - break; - } + var expandable = atLeastOneShowingWhenOpen && atLeastOneShowingWhenClosed && atLeastOneChangeable; + if (this.expandable !== expandable) { + this.expandable = expandable; + var event_1 = { + type: ProvidedColumnGroup.EVENT_EXPANDABLE_CHANGED + }; + this.localEventService.dispatchEvent(event_1); } - return [r, g, b]; }; - Color.prototype.derive = function (hueShift, saturationFactor, brightnessFactor, opacityFactor) { - var hsb = Color.RGBtoHSB(this.r, this.g, this.b); - var b = hsb[2]; - if (b == 0 && brightnessFactor > 1.0) { - b = 0.05; - } - var h = (((hsb[0] + hueShift) % 360) + 360) % 360; - var s = Math.max(Math.min(hsb[1] * saturationFactor, 1.0), 0.0); - b = Math.max(Math.min(b * brightnessFactor, 1.0), 0.0); - var a = Math.max(Math.min(this.a * opacityFactor, 1.0), 0.0); - var rgba = Color.HSBtoRGB(h, s, b); - rgba.push(a); - return Color.fromArray(rgba); + ProvidedColumnGroup.prototype.findChildrenRemovingPadding = function () { + var res = []; + var process = function (items) { + items.forEach(function (item) { + // if padding, we add this children instead of the padding + var skipBecausePadding = item instanceof ProvidedColumnGroup && item.isPadding(); + if (skipBecausePadding) { + process(item.children); + } + else { + res.push(item); + } + }); + }; + process(this.children); + return res; }; - Color.prototype.brighter = function () { - return this.derive(0, 1.0, 1.0 / 0.7, 1.0); + ProvidedColumnGroup.prototype.onColumnVisibilityChanged = function () { + this.setExpandable(); }; - Color.prototype.darker = function () { - return this.derive(0, 1.0, 0.7, 1.0); + ProvidedColumnGroup.prototype.addEventListener = function (eventType, listener) { + this.localEventService.addEventListener(eventType, listener); }; - // See https://drafts.csswg.org/css-color/#hex-notation - Color.hexRe = /\s*#([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})?\s*$/; - Color.shortHexRe = /\s*#([0-9a-fA-F])([0-9a-fA-F])([0-9a-fA-F])([0-9a-fA-F])?\s*$/; - Color.rgbRe = /\s*rgb\((\d+),\s*(\d+),\s*(\d+)\)\s*/; - Color.rgbaRe = /\s*rgba\((\d+),\s*(\d+),\s*(\d+),\s*([.\d]+)\)\s*/; - /** - * CSS Color Module Level 4: - * https://drafts.csswg.org/css-color/#named-colors - */ - Color.nameToHex = Object.freeze({ - aliceblue: '#F0F8FF', - antiquewhite: '#FAEBD7', - aqua: '#00FFFF', - aquamarine: '#7FFFD4', - azure: '#F0FFFF', - beige: '#F5F5DC', - bisque: '#FFE4C4', - black: '#000000', - blanchedalmond: '#FFEBCD', - blue: '#0000FF', - blueviolet: '#8A2BE2', - brown: '#A52A2A', - burlywood: '#DEB887', - cadetblue: '#5F9EA0', - chartreuse: '#7FFF00', - chocolate: '#D2691E', - coral: '#FF7F50', - cornflowerblue: '#6495ED', - cornsilk: '#FFF8DC', - crimson: '#DC143C', - cyan: '#00FFFF', - darkblue: '#00008B', - darkcyan: '#008B8B', - darkgoldenrod: '#B8860B', - darkgray: '#A9A9A9', - darkgreen: '#006400', - darkgrey: '#A9A9A9', - darkkhaki: '#BDB76B', - darkmagenta: '#8B008B', - darkolivegreen: '#556B2F', - darkorange: '#FF8C00', - darkorchid: '#9932CC', - darkred: '#8B0000', - darksalmon: '#E9967A', - darkseagreen: '#8FBC8F', - darkslateblue: '#483D8B', - darkslategray: '#2F4F4F', - darkslategrey: '#2F4F4F', - darkturquoise: '#00CED1', - darkviolet: '#9400D3', - deeppink: '#FF1493', - deepskyblue: '#00BFFF', - dimgray: '#696969', - dimgrey: '#696969', - dodgerblue: '#1E90FF', - firebrick: '#B22222', - floralwhite: '#FFFAF0', - forestgreen: '#228B22', - fuchsia: '#FF00FF', - gainsboro: '#DCDCDC', - ghostwhite: '#F8F8FF', - gold: '#FFD700', - goldenrod: '#DAA520', - gray: '#808080', - green: '#008000', - greenyellow: '#ADFF2F', - grey: '#808080', - honeydew: '#F0FFF0', - hotpink: '#FF69B4', - indianred: '#CD5C5C', - indigo: '#4B0082', - ivory: '#FFFFF0', - khaki: '#F0E68C', - lavender: '#E6E6FA', - lavenderblush: '#FFF0F5', - lawngreen: '#7CFC00', - lemonchiffon: '#FFFACD', - lightblue: '#ADD8E6', - lightcoral: '#F08080', - lightcyan: '#E0FFFF', - lightgoldenrodyellow: '#FAFAD2', - lightgray: '#D3D3D3', - lightgreen: '#90EE90', - lightgrey: '#D3D3D3', - lightpink: '#FFB6C1', - lightsalmon: '#FFA07A', - lightseagreen: '#20B2AA', - lightskyblue: '#87CEFA', - lightslategray: '#778899', - lightslategrey: '#778899', - lightsteelblue: '#B0C4DE', - lightyellow: '#FFFFE0', - lime: '#00FF00', - limegreen: '#32CD32', - linen: '#FAF0E6', - magenta: '#FF00FF', - maroon: '#800000', - mediumaquamarine: '#66CDAA', - mediumblue: '#0000CD', - mediumorchid: '#BA55D3', - mediumpurple: '#9370DB', - mediumseagreen: '#3CB371', - mediumslateblue: '#7B68EE', - mediumspringgreen: '#00FA9A', - mediumturquoise: '#48D1CC', - mediumvioletred: '#C71585', - midnightblue: '#191970', - mintcream: '#F5FFFA', - mistyrose: '#FFE4E1', - moccasin: '#FFE4B5', - navajowhite: '#FFDEAD', - navy: '#000080', - oldlace: '#FDF5E6', - olive: '#808000', - olivedrab: '#6B8E23', - orange: '#FFA500', - orangered: '#FF4500', - orchid: '#DA70D6', - palegoldenrod: '#EEE8AA', - palegreen: '#98FB98', - paleturquoise: '#AFEEEE', - palevioletred: '#DB7093', - papayawhip: '#FFEFD5', - peachpuff: '#FFDAB9', - peru: '#CD853F', - pink: '#FFC0CB', - plum: '#DDA0DD', - powderblue: '#B0E0E6', - purple: '#800080', - rebeccapurple: '#663399', - red: '#FF0000', - rosybrown: '#BC8F8F', - royalblue: '#4169E1', - saddlebrown: '#8B4513', - salmon: '#FA8072', - sandybrown: '#F4A460', - seagreen: '#2E8B57', - seashell: '#FFF5EE', - sienna: '#A0522D', - silver: '#C0C0C0', - skyblue: '#87CEEB', - slateblue: '#6A5ACD', - slategray: '#708090', - slategrey: '#708090', - snow: '#FFFAFA', - springgreen: '#00FF7F', - steelblue: '#4682B4', - tan: '#D2B48C', - teal: '#008080', - thistle: '#D8BFD8', - tomato: '#FF6347', - turquoise: '#40E0D0', - violet: '#EE82EE', - wheat: '#F5DEB3', - white: '#FFFFFF', - whitesmoke: '#F5F5F5', - yellow: '#FFFF00', - yellowgreen: '#9ACD32' - }); - return Color; + ProvidedColumnGroup.prototype.removeEventListener = function (eventType, listener) { + this.localEventService.removeEventListener(eventType, listener); + }; + ProvidedColumnGroup.EVENT_EXPANDED_CHANGED = 'expandedChanged'; + ProvidedColumnGroup.EVENT_EXPANDABLE_CHANGED = 'expandableChanged'; + return ProvidedColumnGroup; }()); @@ -1668,89 +1775,302 @@ var Color = /** @class */ (function () { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "stringToArray", function() { return stringToArray; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnGroup", function() { return ColumnGroup; }); +/* harmony import */ var _column__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(10); +/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(11); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(18); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -// Based on https://stackoverflow.com/a/14991797 -// This will parse a delimited string into an array of arrays. -function stringToArray(strData, delimiter) { - if (delimiter === void 0) { delimiter = ','; } - var data = []; - var isNewline = function (char) { return char === '\r' || char === '\n'; }; - var insideQuotedField = false; - var _loop_1 = function (row, column, position) { - var previousChar = strData[position - 1]; - var currentChar = strData[position]; - var nextChar = strData[position + 1]; - var ensureDataExists = function () { - if (!data[row]) { - // create row if it doesn't exist - data[row] = []; +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + +var ColumnGroup = /** @class */ (function () { + function ColumnGroup(providedColumnGroup, groupId, instanceId, pinned) { + // depends on the open/closed state of the group, only displaying columns are stored here + this.displayedChildren = []; + this.localEventService = new _eventService__WEBPACK_IMPORTED_MODULE_1__["EventService"](); + this.groupId = groupId; + this.instanceId = instanceId; + this.providedColumnGroup = providedColumnGroup; + this.pinned = pinned; + } + // this is static, a it is used outside of this class + ColumnGroup.createUniqueId = function (groupId, instanceId) { + return groupId + '_' + instanceId; + }; + // as the user is adding and removing columns, the groups are recalculated. + // this reset clears out all children, ready for children to be added again + ColumnGroup.prototype.reset = function () { + this.parent = null; + this.children = null; + this.displayedChildren = null; + }; + ColumnGroup.prototype.getParent = function () { + return this.parent; + }; + ColumnGroup.prototype.setParent = function (parent) { + this.parent = parent; + }; + ColumnGroup.prototype.getUniqueId = function () { + return ColumnGroup.createUniqueId(this.groupId, this.instanceId); + }; + ColumnGroup.prototype.isEmptyGroup = function () { + return this.displayedChildren.length === 0; + }; + ColumnGroup.prototype.isMoving = function () { + var allLeafColumns = this.getProvidedColumnGroup().getLeafColumns(); + if (!allLeafColumns || allLeafColumns.length === 0) { + return false; + } + return allLeafColumns.every(function (col) { return col.isMoving(); }); + }; + ColumnGroup.prototype.checkLeft = function () { + // first get all children to setLeft, as it impacts our decision below + this.displayedChildren.forEach(function (child) { + if (child instanceof ColumnGroup) { + child.checkLeft(); } - if (!data[row][column]) { - // create column if it doesn't exist - data[row][column] = ''; + }); + // set our left based on first displayed column + if (this.displayedChildren.length > 0) { + if (this.gridOptionsWrapper.isEnableRtl()) { + var lastChild = Object(_utils_array__WEBPACK_IMPORTED_MODULE_3__["last"])(this.displayedChildren); + var lastChildLeft = lastChild.getLeft(); + this.setLeft(lastChildLeft); } - }; - ensureDataExists(); - if (currentChar === '"') { - if (insideQuotedField) { - if (nextChar === '"') { - // unescape double quote - data[row][column] += '"'; - position++; - } - else { - // exit quoted field - insideQuotedField = false; + else { + var firstChildLeft = this.displayedChildren[0].getLeft(); + this.setLeft(firstChildLeft); + } + } + else { + // this should never happen, as if we have no displayed columns, then + // this groups should not even exist. + this.setLeft(null); + } + }; + ColumnGroup.prototype.getLeft = function () { + return this.left; + }; + ColumnGroup.prototype.getOldLeft = function () { + return this.oldLeft; + }; + ColumnGroup.prototype.setLeft = function (left) { + this.oldLeft = left; + if (this.left !== left) { + this.left = left; + this.localEventService.dispatchEvent(this.createAgEvent(ColumnGroup.EVENT_LEFT_CHANGED)); + } + }; + ColumnGroup.prototype.getPinned = function () { + return this.pinned; + }; + ColumnGroup.prototype.createAgEvent = function (type) { + return { type: type }; + }; + ColumnGroup.prototype.addEventListener = function (eventType, listener) { + this.localEventService.addEventListener(eventType, listener); + }; + ColumnGroup.prototype.removeEventListener = function (eventType, listener) { + this.localEventService.removeEventListener(eventType, listener); + }; + ColumnGroup.prototype.getGroupId = function () { + return this.groupId; + }; + ColumnGroup.prototype.getInstanceId = function () { + return this.instanceId; + }; + ColumnGroup.prototype.isChildInThisGroupDeepSearch = function (wantedChild) { + var result = false; + this.children.forEach(function (foundChild) { + if (wantedChild === foundChild) { + result = true; + } + if (foundChild instanceof ColumnGroup) { + if (foundChild.isChildInThisGroupDeepSearch(wantedChild)) { + result = true; } - return out_row_1 = row, out_column_1 = column, out_position_1 = position, "continue"; } - else if (previousChar === undefined || previousChar === delimiter || isNewline(previousChar)) { - // enter quoted field - insideQuotedField = true; - return out_row_1 = row, out_column_1 = column, out_position_1 = position, "continue"; + }); + return result; + }; + ColumnGroup.prototype.getActualWidth = function () { + var groupActualWidth = 0; + if (this.displayedChildren) { + this.displayedChildren.forEach(function (child) { + groupActualWidth += child.getActualWidth(); + }); + } + return groupActualWidth; + }; + ColumnGroup.prototype.isResizable = function () { + if (!this.displayedChildren) { + return false; + } + // if at least one child is resizable, then the group is resizable + var result = false; + this.displayedChildren.forEach(function (child) { + if (child.isResizable()) { + result = true; } + }); + return result; + }; + ColumnGroup.prototype.getMinWidth = function () { + var result = 0; + this.displayedChildren.forEach(function (groupChild) { + result += groupChild.getMinWidth() || 0; + }); + return result; + }; + ColumnGroup.prototype.addChild = function (child) { + if (!this.children) { + this.children = []; } - if (!insideQuotedField) { - if (currentChar === delimiter) { - // move to next column - column++; - ensureDataExists(); - return out_row_1 = row, out_column_1 = column, out_position_1 = position, "continue"; + this.children.push(child); + }; + ColumnGroup.prototype.getDisplayedChildren = function () { + return this.displayedChildren; + }; + ColumnGroup.prototype.getLeafColumns = function () { + var result = []; + this.addLeafColumns(result); + return result; + }; + ColumnGroup.prototype.getDisplayedLeafColumns = function () { + var result = []; + this.addDisplayedLeafColumns(result); + return result; + }; + // why two methods here doing the same thing? + ColumnGroup.prototype.getDefinition = function () { + return this.providedColumnGroup.getColGroupDef(); + }; + ColumnGroup.prototype.getColGroupDef = function () { + return this.providedColumnGroup.getColGroupDef(); + }; + ColumnGroup.prototype.isPadding = function () { + return this.providedColumnGroup.isPadding(); + }; + ColumnGroup.prototype.isExpandable = function () { + return this.providedColumnGroup.isExpandable(); + }; + ColumnGroup.prototype.isExpanded = function () { + return this.providedColumnGroup.isExpanded(); + }; + ColumnGroup.prototype.setExpanded = function (expanded) { + this.providedColumnGroup.setExpanded(expanded); + }; + ColumnGroup.prototype.addDisplayedLeafColumns = function (leafColumns) { + this.displayedChildren.forEach(function (child) { + if (child instanceof _column__WEBPACK_IMPORTED_MODULE_0__["Column"]) { + leafColumns.push(child); } - else if (isNewline(currentChar)) { - // move to next row - column = 0; - row++; - ensureDataExists(); - if (currentChar === '\r' && nextChar === '\n') { - // skip over second newline character if it exists - position++; - } - return out_row_1 = row, out_column_1 = column, out_position_1 = position, "continue"; + else if (child instanceof ColumnGroup) { + child.addDisplayedLeafColumns(leafColumns); + } + }); + }; + ColumnGroup.prototype.addLeafColumns = function (leafColumns) { + this.children.forEach(function (child) { + if (child instanceof _column__WEBPACK_IMPORTED_MODULE_0__["Column"]) { + leafColumns.push(child); + } + else if (child instanceof ColumnGroup) { + child.addLeafColumns(leafColumns); } + }); + }; + ColumnGroup.prototype.getChildren = function () { + return this.children; + }; + ColumnGroup.prototype.getColumnGroupShow = function () { + return this.providedColumnGroup.getColumnGroupShow(); + }; + ColumnGroup.prototype.getProvidedColumnGroup = function () { + return this.providedColumnGroup; + }; + /** @deprecated getOriginalColumnGroup is deprecated, use getOriginalColumnGroup. */ + ColumnGroup.prototype.getOriginalColumnGroup = function () { + console.warn('AG Grid: columnGroup.getOriginalColumnGroup() is deprecated due to a method rename, use columnGroup.getProvidedColumnGroup() instead'); + return this.getProvidedColumnGroup(); + }; + ColumnGroup.prototype.getPaddingLevel = function () { + var parent = this.getParent(); + if (!this.isPadding() || !parent || !parent.isPadding()) { + return 0; } - // add current character to current column - data[row][column] += currentChar; - out_row_1 = row; - out_column_1 = column; - out_position_1 = position; + return 1 + parent.getPaddingLevel(); }; - var out_row_1, out_column_1, out_position_1; - // iterate over each character, keep track of current row and column (of the returned array) - for (var row = 0, column = 0, position = 0; position < strData.length; position++) { - _loop_1(row, column, position); - row = out_row_1; - column = out_column_1; - position = out_position_1; - } - return data; -} + ColumnGroup.prototype.calculateDisplayedColumns = function () { + var _this = this; + // clear out last time we calculated + this.displayedChildren = []; + // find the column group that is controlling expandable. this is relevant when we have padding (empty) + // groups, where the expandable is actually the first parent that is not a padding group. + var parentWithExpansion = this; + while (parentWithExpansion != null && parentWithExpansion.isPadding()) { + parentWithExpansion = parentWithExpansion.getParent(); + } + var isExpandable = parentWithExpansion ? parentWithExpansion.providedColumnGroup.isExpandable() : false; + // it not expandable, everything is visible + if (!isExpandable) { + this.displayedChildren = this.children; + this.localEventService.dispatchEvent(this.createAgEvent(ColumnGroup.EVENT_DISPLAYED_CHILDREN_CHANGED)); + return; + } + // Add cols based on columnGroupShow + // Note - the below also adds padding groups, these are always added because they never have + // colDef.columnGroupShow set. + this.children.forEach(function (child) { + // never add empty groups + var emptyGroup = child instanceof ColumnGroup && (!child.displayedChildren || !child.displayedChildren.length); + if (emptyGroup) { + return; + } + var headerGroupShow = child.getColumnGroupShow(); + switch (headerGroupShow) { + case ColumnGroup.HEADER_GROUP_SHOW_OPEN: + // when set to open, only show col if group is open + if (parentWithExpansion.providedColumnGroup.isExpanded()) { + _this.displayedChildren.push(child); + } + break; + case ColumnGroup.HEADER_GROUP_SHOW_CLOSED: + // when set to open, only show col if group is open + if (!parentWithExpansion.providedColumnGroup.isExpanded()) { + _this.displayedChildren.push(child); + } + break; + default: + _this.displayedChildren.push(child); + break; + } + }); + this.localEventService.dispatchEvent(this.createAgEvent(ColumnGroup.EVENT_DISPLAYED_CHILDREN_CHANGED)); + }; + ColumnGroup.HEADER_GROUP_SHOW_OPEN = 'open'; + ColumnGroup.HEADER_GROUP_SHOW_CLOSED = 'closed'; + ColumnGroup.EVENT_LEFT_CHANGED = 'leftChanged'; + ColumnGroup.EVENT_DISPLAYED_CHILDREN_CHANGED = 'displayedChildrenChanged'; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper') + ], ColumnGroup.prototype, "gridOptionsWrapper", void 0); + return ColumnGroup; +}()); + /***/ }), @@ -1759,42 +2079,26 @@ function stringToArray(strData, delimiter) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "_", function() { return _; }); -/* harmony import */ var _general__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(11); -/* harmony import */ var _array__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(17); -/* harmony import */ var _browser__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(13); -/* harmony import */ var _csv__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(9); -/* harmony import */ var _date__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(18); -/* harmony import */ var _dom__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(12); -/* harmony import */ var _event__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(20); -/* harmony import */ var _function__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(21); -/* harmony import */ var _fuzzyMatch__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(22); -/* harmony import */ var _generic__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(14); -/* harmony import */ var _icon__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(23); -/* harmony import */ var _keyboard__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(24); -/* harmony import */ var _map__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(26); -/* harmony import */ var _mouse__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(27); -/* harmony import */ var _number__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(19); -/* harmony import */ var _object__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(16); -/* harmony import */ var _rowNode__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(28); -/* harmony import */ var _set__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(29); -/* harmony import */ var _string__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(15); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Column", function() { return Column; }); +/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(11); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(15); +/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(16); +/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(17); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(14); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(13); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var __assign = (undefined && undefined.__assign) || function () { - __assign = Object.assign || function(t) { - for (var s, i = 1, n = arguments.length; i < n; i++) { - s = arguments[i]; - for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) - t[p] = s[p]; - } - return t; - }; - return __assign.apply(this, arguments); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; }; @@ -1804,39 +2108,8360 @@ var __assign = (undefined && undefined.__assign) || function () { - - - - - - - - - - - -var utils = __assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign({}, _general__WEBPACK_IMPORTED_MODULE_0__), _array__WEBPACK_IMPORTED_MODULE_1__), _browser__WEBPACK_IMPORTED_MODULE_2__), _csv__WEBPACK_IMPORTED_MODULE_3__), _date__WEBPACK_IMPORTED_MODULE_4__), _dom__WEBPACK_IMPORTED_MODULE_5__), _event__WEBPACK_IMPORTED_MODULE_6__), _function__WEBPACK_IMPORTED_MODULE_7__), _fuzzyMatch__WEBPACK_IMPORTED_MODULE_8__), _generic__WEBPACK_IMPORTED_MODULE_9__), _icon__WEBPACK_IMPORTED_MODULE_10__), _keyboard__WEBPACK_IMPORTED_MODULE_11__), _map__WEBPACK_IMPORTED_MODULE_12__), _mouse__WEBPACK_IMPORTED_MODULE_13__), _number__WEBPACK_IMPORTED_MODULE_14__), _object__WEBPACK_IMPORTED_MODULE_15__), _rowNode__WEBPACK_IMPORTED_MODULE_16__), _set__WEBPACK_IMPORTED_MODULE_17__), _string__WEBPACK_IMPORTED_MODULE_18__); -var _ = utils; - - -/***/ }), -/* 11 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getNameOfClass", function() { return getNameOfClass; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "findLineByLeastSquares", function() { return findLineByLeastSquares; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssStyleObjectToMarkup", function() { return cssStyleObjectToMarkup; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "message", function() { return message; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "bindCellRendererToHtmlElement", function() { return bindCellRendererToHtmlElement; }); -/* harmony import */ var _dom__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); -/* harmony import */ var _string__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(15); -/* harmony import */ var _object__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(16); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ +var instanceIdSequence = 0; +// Wrapper around a user provide column definition. The grid treats the column definition as ready only. +// This class contains all the runtime information about a column, plus some logic (the definition has no logic). +// This class implements both interfaces ColumnGroupChild and ProvidedColumnGroupChild as the class can +// appear as a child of either the original tree or the displayed tree. However the relevant group classes +// for each type only implements one, as each group can only appear in it's associated tree (eg ProvidedColumnGroup +// can only appear in OriginalColumn tree). +var Column = /** @class */ (function () { + function Column(colDef, userProvidedColDef, colId, primary) { + // used by React (and possibly other frameworks) as key for rendering + this.instanceId = instanceIdSequence++; + this.moving = false; + this.menuVisible = false; + this.filterActive = false; + this.eventService = new _eventService__WEBPACK_IMPORTED_MODULE_0__["EventService"](); + this.rowGroupActive = false; + this.pivotActive = false; + this.aggregationActive = false; + this.colDef = colDef; + this.userProvidedColDef = userProvidedColDef; + this.colId = colId; + this.primary = primary; + this.setState(colDef); + } + Column.prototype.getInstanceId = function () { + return this.instanceId; + }; + Column.prototype.setState = function (colDef) { + // sort + if (colDef.sort !== undefined) { + if (colDef.sort === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_ASC || colDef.sort === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_DESC) { + this.sort = colDef.sort; + } + } + else { + if (colDef.initialSort === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_ASC || colDef.initialSort === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_DESC) { + this.sort = colDef.initialSort; + } + } + // sortIndex + var sortIndex = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["attrToNumber"])(colDef.sortIndex); + var initialSortIndex = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["attrToNumber"])(colDef.initialSortIndex); + if (sortIndex !== undefined) { + if (sortIndex !== null) { + this.sortIndex = sortIndex; + } + } + else { + if (initialSortIndex !== null) { + this.sortIndex = initialSortIndex; + } + } + // hide + var hide = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["attrToBoolean"])(colDef.hide); + var initialHide = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["attrToBoolean"])(colDef.initialHide); + if (hide !== undefined) { + this.visible = !hide; + } + else { + this.visible = !initialHide; + } + // pinned + if (colDef.pinned !== undefined) { + this.setPinned(colDef.pinned); + } + else { + this.setPinned(colDef.initialPinned); + } + // flex + var flex = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["attrToNumber"])(colDef.flex); + var initialFlex = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["attrToNumber"])(colDef.initialFlex); + if (flex !== undefined) { + this.flex = flex; + } + else if (initialFlex !== undefined) { + this.flex = initialFlex; + } + }; + // gets called when user provides an alternative colDef, eg + Column.prototype.setColDef = function (colDef, userProvidedColDef) { + this.colDef = colDef; + this.userProvidedColDef = userProvidedColDef; + this.initMinAndMaxWidths(); + this.initDotNotation(); + }; + /** + * Returns the column definition provided by the application. + * This may not be correct, as items can be superseded by default column options. + * However it's useful for comparison, eg to know which application column definition matches that column. + */ + Column.prototype.getUserProvidedColDef = function () { + return this.userProvidedColDef; + }; + Column.prototype.setParent = function (parent) { + this.parent = parent; + }; + /** Returns the parent column group, if column grouping is active. */ + Column.prototype.getParent = function () { + return this.parent; + }; + Column.prototype.setOriginalParent = function (originalParent) { + this.originalParent = originalParent; + }; + Column.prototype.getOriginalParent = function () { + return this.originalParent; + }; + // this is done after constructor as it uses gridOptionsWrapper + Column.prototype.initialise = function () { + this.initMinAndMaxWidths(); + this.resetActualWidth('gridInitializing'); + this.initDotNotation(); + this.validate(); + }; + Column.prototype.initDotNotation = function () { + var suppressDotNotation = this.gridOptionsWrapper.isSuppressFieldDotNotation(); + this.fieldContainsDots = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["exists"])(this.colDef.field) && this.colDef.field.indexOf('.') >= 0 && !suppressDotNotation; + this.tooltipFieldContainsDots = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["exists"])(this.colDef.tooltipField) && this.colDef.tooltipField.indexOf('.') >= 0 && !suppressDotNotation; + }; + Column.prototype.initMinAndMaxWidths = function () { + var colDef = this.colDef; + this.minWidth = this.columnUtils.calculateColMinWidth(colDef); + this.maxWidth = this.columnUtils.calculateColMaxWidth(colDef); + }; + Column.prototype.resetActualWidth = function (source) { + if (source === void 0) { source = 'api'; } + var initialWidth = this.columnUtils.calculateColInitialWidth(this.colDef); + this.setActualWidth(initialWidth, source, true); + }; + Column.prototype.isEmptyGroup = function () { + return false; + }; + Column.prototype.isRowGroupDisplayed = function (colId) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["missing"])(this.colDef) || Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["missing"])(this.colDef.showRowGroup)) { + return false; + } + var showingAllGroups = this.colDef.showRowGroup === true; + var showingThisGroup = this.colDef.showRowGroup === colId; + return showingAllGroups || showingThisGroup; + }; + /** Returns `true` if column is a primary column, `false` if secondary. Secondary columns are used for pivoting. */ + Column.prototype.isPrimary = function () { + return this.primary; + }; + /** Returns `true` if column filtering is allowed. */ + Column.prototype.isFilterAllowed = function () { + // filter defined means it's a string, class or true. + // if its false, null or undefined then it's false. + var filterDefined = !!this.colDef.filter || !!this.colDef.filterFramework; + return this.primary && filterDefined; + }; + Column.prototype.isFieldContainsDots = function () { + return this.fieldContainsDots; + }; + Column.prototype.isTooltipFieldContainsDots = function () { + return this.tooltipFieldContainsDots; + }; + Column.prototype.validate = function () { + var colDefAny = this.colDef; + function warnOnce(msg, key, obj) { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_6__["doOnce"])(function () { + if (obj) { + console.warn(msg, obj); + } + else { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_6__["doOnce"])(function () { return console.warn(msg); }, key); + } + }, key); + } + var usingCSRM = this.gridOptionsWrapper.isRowModelDefault(); + if (usingCSRM && !_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].RowGroupingModule)) { + var rowGroupingItems = ['enableRowGroup', 'rowGroup', 'rowGroupIndex', 'enablePivot', 'enableValue', 'pivot', 'pivotIndex', 'aggFunc']; + rowGroupingItems.forEach(function (item) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["exists"])(colDefAny[item])) { + if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].isPackageBased()) { + warnOnce("AG Grid: " + item + " is only valid in ag-grid-enterprise, your column definition should not have " + item, 'ColumnRowGroupingMissing' + item); + } + else { + warnOnce("AG Grid: " + item + " is only valid with AG Grid Enterprise Module " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].RowGroupingModule + " - your column definition should not have " + item, 'ColumnRowGroupingMissing' + item); + } + } + }); + } + if (!_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].RichSelectModule)) { + if (this.colDef.cellEditor === 'agRichSelect') { + if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].isPackageBased()) { + warnOnce("AG Grid: " + this.colDef.cellEditor + " can only be used with ag-grid-enterprise", 'ColumnRichSelectMissing'); + } + else { + warnOnce("AG Grid: " + this.colDef.cellEditor + " can only be used with AG Grid Enterprise Module " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].RichSelectModule, 'ColumnRichSelectMissing'); + } + } + } + if (this.gridOptionsWrapper.isTreeData()) { + var itemsNotAllowedWithTreeData = ['rowGroup', 'rowGroupIndex', 'pivot', 'pivotIndex']; + itemsNotAllowedWithTreeData.forEach(function (item) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["exists"])(colDefAny[item])) { + warnOnce("AG Grid: " + item + " is not possible when doing tree data, your column definition should not have " + item, 'TreeDataCannotRowGroup'); + } + }); + } + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["exists"])(this.colDef.width) && typeof this.colDef.width !== 'number') { + warnOnce('AG Grid: colDef.width should be a number, not ' + typeof this.colDef.width, 'ColumnCheck_asdfawef'); + } + if (colDefAny.pinnedRowCellRenderer) { + warnOnce('AG Grid: pinnedRowCellRenderer no longer exists, use cellRendererSelector if you want a different Cell Renderer for pinned rows. Check params.node.rowPinned. This was an unfortunate (but necessary) change we had to do to allow future plans we have of re-skinng the data grid in frameworks such as React, Angular and Vue. See https://www.ag-grid.com/javascript-grid/cell-rendering/#many-renderers-one-column', 'colDef.pinnedRowCellRenderer-deprecated'); + } + if (colDefAny.pinnedRowCellRendererParams) { + warnOnce('AG Grid: pinnedRowCellRenderer no longer exists, use cellRendererSelector if you want a different Cell Renderer for pinned rows. Check params.node.rowPinned. This was an unfortunate (but necessary) change we had to do to allow future plans we have of re-skinng the data grid in frameworks such as React, Angular and Vue. See https://www.ag-grid.com/javascript-grid/cell-rendering/#many-renderers-one-column', 'colDef.pinnedRowCellRenderer-deprecated'); + } + if (colDefAny.pinnedRowCellRendererFramework) { + warnOnce('AG Grid: pinnedRowCellRenderer no longer exists, use cellRendererSelector if you want a different Cell Renderer for pinned rows. Check params.node.rowPinned. This was an unfortunate (but necessary) change we had to do to allow future plans we have of re-skinng the data grid in frameworks such as React, Angular and Vue. See https://www.ag-grid.com/javascript-grid/cell-rendering/#many-renderers-one-column', 'colDef.pinnedRowCellRenderer-deprecated'); + } + if (colDefAny.pinnedRowValueGetter) { + warnOnce('AG Grid: pinnedRowCellRenderer is deprecated, use cellRendererSelector if you want a different Cell Renderer for pinned rows. Check params.node.rowPinned. This was an unfortunate (but necessary) change we had to do to allow future plans we have of re-skinng the data grid in frameworks such as React, Angular and Vue.', 'colDef.pinnedRowCellRenderer-deprecated'); + } + }; + /** Add an event listener to the column. */ + Column.prototype.addEventListener = function (eventType, listener) { + this.eventService.addEventListener(eventType, listener); + }; + /** Remove event listener from the column. */ + Column.prototype.removeEventListener = function (eventType, listener) { + this.eventService.removeEventListener(eventType, listener); + }; + Column.prototype.createColumnFunctionCallbackParams = function (rowNode) { + return { + node: rowNode, + data: rowNode.data, + column: this, + colDef: this.colDef, + context: this.gridOptionsWrapper.getContext(), + api: this.gridOptionsWrapper.getApi(), + columnApi: this.gridOptionsWrapper.getColumnApi() + }; + }; + Column.prototype.isSuppressNavigable = function (rowNode) { + // if boolean set, then just use it + if (typeof this.colDef.suppressNavigable === 'boolean') { + return this.colDef.suppressNavigable; + } + // if function, then call the function to find out + if (typeof this.colDef.suppressNavigable === 'function') { + var params = this.createColumnFunctionCallbackParams(rowNode); + var userFunc = this.colDef.suppressNavigable; + return userFunc(params); + } + return false; + }; + Column.prototype.isCellEditable = function (rowNode) { + // only allow editing of groups if the user has this option enabled + if (rowNode.group && !this.gridOptionsWrapper.isEnableGroupEdit()) { + return false; + } + return this.isColumnFunc(rowNode, this.colDef.editable); + }; + Column.prototype.isSuppressFillHandle = function () { + return !!Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["attrToBoolean"])(this.colDef.suppressFillHandle); + }; + Column.prototype.isAutoHeight = function () { + return !!Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["attrToBoolean"])(this.colDef.autoHeight); + }; + Column.prototype.isRowDrag = function (rowNode) { + return this.isColumnFunc(rowNode, this.colDef.rowDrag); + }; + Column.prototype.isDndSource = function (rowNode) { + return this.isColumnFunc(rowNode, this.colDef.dndSource); + }; + Column.prototype.isCellCheckboxSelection = function (rowNode) { + return this.isColumnFunc(rowNode, this.colDef.checkboxSelection); + }; + Column.prototype.isSuppressPaste = function (rowNode) { + return this.isColumnFunc(rowNode, this.colDef ? this.colDef.suppressPaste : null); + }; + Column.prototype.isResizable = function () { + return !!Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["attrToBoolean"])(this.colDef.resizable); + }; + Column.prototype.isColumnFunc = function (rowNode, value) { + // if boolean set, then just use it + if (typeof value === 'boolean') { + return value; + } + // if function, then call the function to find out + if (typeof value === 'function') { + var params = this.createColumnFunctionCallbackParams(rowNode); + var editableFunc = value; + return editableFunc(params); + } + return false; + }; + Column.prototype.setMoving = function (moving, source) { + if (source === void 0) { source = "api"; } + this.moving = moving; + this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_MOVING_CHANGED, source)); + }; + Column.prototype.createColumnEvent = function (type, source) { + return { + api: this.gridApi, + columnApi: this.columnApi, + type: type, + column: this, + columns: [this], + source: source + }; + }; + Column.prototype.isMoving = function () { + return this.moving; + }; + /** If sorting is active, returns the sort direction e.g. `'asc'` or `'desc'`. */ + Column.prototype.getSort = function () { + return this.sort; + }; + Column.prototype.setSort = function (sort, source) { + if (source === void 0) { source = "api"; } + if (this.sort !== sort) { + this.sort = sort; + this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_SORT_CHANGED, source)); + } + }; + Column.prototype.setMenuVisible = function (visible, source) { + if (source === void 0) { source = "api"; } + if (this.menuVisible !== visible) { + this.menuVisible = visible; + this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_MENU_VISIBLE_CHANGED, source)); + } + }; + Column.prototype.isMenuVisible = function () { + return this.menuVisible; + }; + Column.prototype.isSortAscending = function () { + return this.sort === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_ASC; + }; + Column.prototype.isSortDescending = function () { + return this.sort === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_DESC; + }; + Column.prototype.isSortNone = function () { + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["missing"])(this.sort); + }; + Column.prototype.isSorting = function () { + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["exists"])(this.sort); + }; + Column.prototype.getSortIndex = function () { + return this.sortIndex; + }; + Column.prototype.setSortIndex = function (sortOrder) { + this.sortIndex = sortOrder; + }; + Column.prototype.setAggFunc = function (aggFunc) { + this.aggFunc = aggFunc; + }; + /** If aggregation is set for the column, returns the aggregation function. */ + Column.prototype.getAggFunc = function () { + return this.aggFunc; + }; + Column.prototype.getLeft = function () { + return this.left; + }; + Column.prototype.getOldLeft = function () { + return this.oldLeft; + }; + Column.prototype.getRight = function () { + return this.left + this.actualWidth; + }; + Column.prototype.setLeft = function (left, source) { + if (source === void 0) { source = "api"; } + this.oldLeft = this.left; + if (this.left !== left) { + this.left = left; + this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_LEFT_CHANGED, source)); + } + }; + /** Returns `true` if filter is active on the column. */ + Column.prototype.isFilterActive = function () { + return this.filterActive; + }; + // additionalEventAttributes is used by provided simple floating filter, so it can add 'floatingFilter=true' to the event + Column.prototype.setFilterActive = function (active, source, additionalEventAttributes) { + if (source === void 0) { source = "api"; } + if (this.filterActive !== active) { + this.filterActive = active; + this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_FILTER_ACTIVE_CHANGED, source)); + } + var filterChangedEvent = this.createColumnEvent(Column.EVENT_FILTER_CHANGED, source); + if (additionalEventAttributes) { + Object(_utils_object__WEBPACK_IMPORTED_MODULE_7__["mergeDeep"])(filterChangedEvent, additionalEventAttributes); + } + this.eventService.dispatchEvent(filterChangedEvent); + }; + Column.prototype.setPinned = function (pinned) { + if (pinned === true || pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_LEFT) { + this.pinned = _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_LEFT; + } + else if (pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_RIGHT) { + this.pinned = _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_RIGHT; + } + else { + this.pinned = null; + } + }; + Column.prototype.setFirstRightPinned = function (firstRightPinned, source) { + if (source === void 0) { source = "api"; } + if (this.firstRightPinned !== firstRightPinned) { + this.firstRightPinned = firstRightPinned; + this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_FIRST_RIGHT_PINNED_CHANGED, source)); + } + }; + Column.prototype.setLastLeftPinned = function (lastLeftPinned, source) { + if (source === void 0) { source = "api"; } + if (this.lastLeftPinned !== lastLeftPinned) { + this.lastLeftPinned = lastLeftPinned; + this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_LAST_LEFT_PINNED_CHANGED, source)); + } + }; + Column.prototype.isFirstRightPinned = function () { + return this.firstRightPinned; + }; + Column.prototype.isLastLeftPinned = function () { + return this.lastLeftPinned; + }; + Column.prototype.isPinned = function () { + return this.pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_LEFT || this.pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_RIGHT; + }; + Column.prototype.isPinnedLeft = function () { + return this.pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_LEFT; + }; + Column.prototype.isPinnedRight = function () { + return this.pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_RIGHT; + }; + Column.prototype.getPinned = function () { + return this.pinned; + }; + Column.prototype.setVisible = function (visible, source) { + if (source === void 0) { source = "api"; } + var newValue = visible === true; + if (this.visible !== newValue) { + this.visible = newValue; + this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_VISIBLE_CHANGED, source)); + } + }; + Column.prototype.isVisible = function () { + return this.visible; + }; + /** Returns the column definition for this column. + * The column definition will be the result of merging the application provided column definition with any provided defaults + * (e.g. `defaultColDef` grid option, or column types. + * + * Equivalent: `getDefinition` */ + Column.prototype.getColDef = function () { + return this.colDef; + }; + Column.prototype.getColumnGroupShow = function () { + return this.colDef.columnGroupShow; + }; + /** + * Returns the unique ID for the column. + * + * Equivalent: `getId`, `getUniqueId` */ + Column.prototype.getColId = function () { + return this.colId; + }; + /** + * Returns the unique ID for the column. + * + * Equivalent: `getColId`, `getUniqueId` */ + Column.prototype.getId = function () { + return this.getColId(); + }; + /** + * Returns the unique ID for the column. + * + * Equivalent: `getColId`, `getId` */ + Column.prototype.getUniqueId = function () { + return this.getId(); + }; + Column.prototype.getDefinition = function () { + return this.colDef; + }; + /** Returns the current width of the column. If the column is resized, the actual width is the new size. */ + Column.prototype.getActualWidth = function () { + return this.actualWidth; + }; + Column.prototype.createBaseColDefParams = function (rowNode) { + var params = { + node: rowNode, + data: rowNode.data, + colDef: this.colDef, + column: this, + api: this.gridOptionsWrapper.getApi(), + columnApi: this.gridOptionsWrapper.getColumnApi(), + context: this.gridOptionsWrapper.getContext() + }; + return params; + }; + Column.prototype.getColSpan = function (rowNode) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["missing"])(this.colDef.colSpan)) { + return 1; + } + var params = this.createBaseColDefParams(rowNode); + var colSpan = this.colDef.colSpan(params); + // colSpan must be number equal to or greater than 1 + return Math.max(colSpan, 1); + }; + Column.prototype.getRowSpan = function (rowNode) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["missing"])(this.colDef.rowSpan)) { + return 1; + } + var params = this.createBaseColDefParams(rowNode); + var rowSpan = this.colDef.rowSpan(params); + // rowSpan must be number equal to or greater than 1 + return Math.max(rowSpan, 1); + }; + Column.prototype.setActualWidth = function (actualWidth, source, silent) { + if (source === void 0) { source = "api"; } + if (silent === void 0) { silent = false; } + if (this.minWidth != null) { + actualWidth = Math.max(actualWidth, this.minWidth); + } + if (this.maxWidth != null) { + actualWidth = Math.min(actualWidth, this.maxWidth); + } + if (this.actualWidth !== actualWidth) { + // disable flex for this column if it was manually resized. + this.actualWidth = actualWidth; + if (this.flex && source !== 'flex' && source !== 'gridInitializing') { + this.flex = null; + } + if (!silent) { + this.fireColumnWidthChangedEvent(source); + } + } + }; + Column.prototype.fireColumnWidthChangedEvent = function (source) { + this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_WIDTH_CHANGED, source)); + }; + Column.prototype.isGreaterThanMax = function (width) { + if (this.maxWidth != null) { + return width > this.maxWidth; + } + return false; + }; + Column.prototype.getMinWidth = function () { + return this.minWidth; + }; + Column.prototype.getMaxWidth = function () { + return this.maxWidth; + }; + Column.prototype.getFlex = function () { + return this.flex || 0; + }; + // this method should only be used by the columnModel to + // change flex when required by the setColumnState method. + Column.prototype.setFlex = function (flex) { + if (this.flex !== flex) { + this.flex = flex; + } + }; + Column.prototype.setMinimum = function (source) { + if (source === void 0) { source = "api"; } + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["exists"])(this.minWidth)) { + this.setActualWidth(this.minWidth, source); + } + }; + Column.prototype.setRowGroupActive = function (rowGroup, source) { + if (source === void 0) { source = "api"; } + if (this.rowGroupActive !== rowGroup) { + this.rowGroupActive = rowGroup; + this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_ROW_GROUP_CHANGED, source)); + } + }; + /** Returns `true` if row group is currently active for this column. */ + Column.prototype.isRowGroupActive = function () { + return this.rowGroupActive; + }; + Column.prototype.setPivotActive = function (pivot, source) { + if (source === void 0) { source = "api"; } + if (this.pivotActive !== pivot) { + this.pivotActive = pivot; + this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_PIVOT_CHANGED, source)); + } + }; + /** Returns `true` if pivot is currently active for this column. */ + Column.prototype.isPivotActive = function () { + return this.pivotActive; + }; + Column.prototype.isAnyFunctionActive = function () { + return this.isPivotActive() || this.isRowGroupActive() || this.isValueActive(); + }; + Column.prototype.isAnyFunctionAllowed = function () { + return this.isAllowPivot() || this.isAllowRowGroup() || this.isAllowValue(); + }; + Column.prototype.setValueActive = function (value, source) { + if (source === void 0) { source = "api"; } + if (this.aggregationActive !== value) { + this.aggregationActive = value; + this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_VALUE_CHANGED, source)); + } + }; + /** Returns `true` if value (aggregation) is currently active for this column. */ + Column.prototype.isValueActive = function () { + return this.aggregationActive; + }; + Column.prototype.isAllowPivot = function () { + return this.colDef.enablePivot === true; + }; + Column.prototype.isAllowValue = function () { + return this.colDef.enableValue === true; + }; + Column.prototype.isAllowRowGroup = function () { + return this.colDef.enableRowGroup === true; + }; + Column.prototype.getMenuTabs = function (defaultValues) { + var menuTabs = this.getColDef().menuTabs; + if (menuTabs == null) { + menuTabs = defaultValues; + } + return menuTabs; + }; + // this used to be needed, as previous version of ag-grid had lockPosition as column state, + // so couldn't depend on colDef version. + Column.prototype.isLockPosition = function () { + console.warn('AG Grid: since v21, col.isLockPosition() should not be used, please use col.getColDef().lockPosition instead.'); + return this.colDef ? !!this.colDef.lockPosition : false; + }; + // this used to be needed, as previous version of ag-grid had lockVisible as column state, + // so couldn't depend on colDef version. + Column.prototype.isLockVisible = function () { + console.warn('AG Grid: since v21, col.isLockVisible() should not be used, please use col.getColDef().lockVisible instead.'); + return this.colDef ? !!this.colDef.lockVisible : false; + }; + // this used to be needed, as previous version of ag-grid had lockPinned as column state, + // so couldn't depend on colDef version. + Column.prototype.isLockPinned = function () { + console.warn('AG Grid: since v21, col.isLockPinned() should not be used, please use col.getColDef().lockPinned instead.'); + return this.colDef ? !!this.colDef.lockPinned : false; + }; + // + renderedHeaderCell - for making header cell transparent when moving + Column.EVENT_MOVING_CHANGED = 'movingChanged'; + // + renderedCell - changing left position + Column.EVENT_LEFT_CHANGED = 'leftChanged'; + // + renderedCell - changing width + Column.EVENT_WIDTH_CHANGED = 'widthChanged'; + // + renderedCell - for changing pinned classes + Column.EVENT_LAST_LEFT_PINNED_CHANGED = 'lastLeftPinnedChanged'; + Column.EVENT_FIRST_RIGHT_PINNED_CHANGED = 'firstRightPinnedChanged'; + // + renderedColumn - for changing visibility icon + Column.EVENT_VISIBLE_CHANGED = 'visibleChanged'; + // + every time the filter changes, used in the floating filters + Column.EVENT_FILTER_CHANGED = 'filterChanged'; + // + renderedHeaderCell - marks the header with filter icon + Column.EVENT_FILTER_ACTIVE_CHANGED = 'filterActiveChanged'; + // + renderedHeaderCell - marks the header with sort icon + Column.EVENT_SORT_CHANGED = 'sortChanged'; + Column.EVENT_MENU_VISIBLE_CHANGED = 'menuVisibleChanged'; + // + toolpanel, for gui updates + Column.EVENT_ROW_GROUP_CHANGED = 'columnRowGroupChanged'; + // + toolpanel, for gui updates + Column.EVENT_PIVOT_CHANGED = 'columnPivotChanged'; + // + toolpanel, for gui updates + Column.EVENT_VALUE_CHANGED = 'columnValueChanged'; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') + ], Column.prototype, "gridOptionsWrapper", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnUtils') + ], Column.prototype, "columnUtils", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnApi') + ], Column.prototype, "columnApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridApi') + ], Column.prototype, "gridApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('context') + ], Column.prototype, "context", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], Column.prototype, "initialise", null); + return Column; +}()); + + + +/***/ }), +/* 11 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "EventService", function() { return EventService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; +var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { + return function (target, key) { decorator(target, key, paramIndex); } +}; + +var EventService = /** @class */ (function () { + function EventService() { + this.allSyncListeners = new Map(); + this.allAsyncListeners = new Map(); + this.globalSyncListeners = new Set(); + this.globalAsyncListeners = new Set(); + this.asyncFunctionsQueue = []; + this.scheduled = false; + // using an object performs better than a Set for the number of different events we have + this.firedEvents = {}; + } + // because this class is used both inside the context and outside the context, we do not + // use autowired attributes, as that would be confusing, as sometimes the attributes + // would be wired, and sometimes not. + // + // the global event servers used by AG Grid is autowired by the context once, and this + // setBeans method gets called once. + // + // the times when this class is used outside of the context (eg RowNode has an instance of this + // class) then it is not a bean, and this setBeans method is not called. + EventService.prototype.setBeans = function (loggerFactory, gridOptionsWrapper, frameworkOverrides, globalEventListener) { + if (globalEventListener === void 0) { globalEventListener = null; } + this.frameworkOverrides = frameworkOverrides; + if (globalEventListener) { + var async = gridOptionsWrapper.useAsyncEvents(); + this.addGlobalListener(globalEventListener, async); + } + }; + EventService.prototype.getListeners = function (eventType, async, autoCreateListenerCollection) { + var listenerMap = async ? this.allAsyncListeners : this.allSyncListeners; + var listeners = listenerMap.get(eventType); + // Note: 'autoCreateListenerCollection' should only be 'true' if a listener is about to be added. For instance + // getListeners() is also called during event dispatch even though no listeners are added. This measure protects + // against 'memory bloat' as empty collections will prevent the RowNode's event service from being removed after + // the RowComp is destroyed, see noRegisteredListenersExist() below. + if (!listeners && autoCreateListenerCollection) { + listeners = new Set(); + listenerMap.set(eventType, listeners); + } + return listeners; + }; + EventService.prototype.noRegisteredListenersExist = function () { + return this.allSyncListeners.size === 0 && this.allAsyncListeners.size === 0 && + this.globalSyncListeners.size === 0 && this.globalAsyncListeners.size === 0; + }; + EventService.prototype.addEventListener = function (eventType, listener, async) { + if (async === void 0) { async = false; } + this.getListeners(eventType, async, true).add(listener); + }; + EventService.prototype.removeEventListener = function (eventType, listener, async) { + if (async === void 0) { async = false; } + var listeners = this.getListeners(eventType, async, false); + if (!listeners) { + return; + } + listeners.delete(listener); + if (listeners.size === 0) { + var listenerMap = async ? this.allAsyncListeners : this.allSyncListeners; + listenerMap.delete(eventType); + } + }; + EventService.prototype.addGlobalListener = function (listener, async) { + if (async === void 0) { async = false; } + (async ? this.globalAsyncListeners : this.globalSyncListeners).add(listener); + }; + EventService.prototype.removeGlobalListener = function (listener, async) { + if (async === void 0) { async = false; } + (async ? this.globalAsyncListeners : this.globalSyncListeners).delete(listener); + }; + EventService.prototype.dispatchEvent = function (event) { + this.dispatchToListeners(event, true); + this.dispatchToListeners(event, false); + this.firedEvents[event.type] = true; + }; + EventService.prototype.dispatchEventOnce = function (event) { + if (!this.firedEvents[event.type]) { + this.dispatchEvent(event); + } + }; + EventService.prototype.dispatchToListeners = function (event, async) { + var _this = this; + var eventType = event.type; + var processEventListeners = function (listeners) { return listeners.forEach(function (listener) { + if (async) { + _this.dispatchAsync(function () { return listener(event); }); + } + else { + listener(event); + } + }); }; + var listeners = this.getListeners(eventType, async, false); + if (listeners) { + processEventListeners(listeners); + } + var globalListeners = async ? this.globalAsyncListeners : this.globalSyncListeners; + globalListeners.forEach(function (listener) { + if (async) { + _this.dispatchAsync(function () { return _this.frameworkOverrides.dispatchEvent(eventType, function () { return listener(eventType, event); }, true); }); + } + else { + _this.frameworkOverrides.dispatchEvent(eventType, function () { return listener(eventType, event); }, true); + } + }); + }; + // this gets called inside the grid's thread, for each event that it + // wants to set async. the grid then batches the events into one setTimeout() + // because setTimeout() is an expensive operation. ideally we would have + // each event in it's own setTimeout(), but we batch for performance. + EventService.prototype.dispatchAsync = function (func) { + // add to the queue for executing later in the next VM turn + this.asyncFunctionsQueue.push(func); + // check if timeout is already scheduled. the first time the grid calls + // this within it's thread turn, this should be false, so it will schedule + // the 'flush queue' method the first time it comes here. then the flag is + // set to 'true' so it will know it's already scheduled for subsequent calls. + if (!this.scheduled) { + // if not scheduled, schedule one + window.setTimeout(this.flushAsyncQueue.bind(this), 0); + // mark that it is scheduled + this.scheduled = true; + } + }; + // this happens in the next VM turn only, and empties the queue of events + EventService.prototype.flushAsyncQueue = function () { + this.scheduled = false; + // we take a copy, because the event listener could be using + // the grid, which would cause more events, which would be potentially + // added to the queue, so safe to take a copy, the new events will + // get executed in a later VM turn rather than risk updating the + // queue as we are flushing it. + var queueCopy = this.asyncFunctionsQueue.slice(); + this.asyncFunctionsQueue = []; + // execute the queue + queueCopy.forEach(function (func) { return func(); }); + }; + __decorate([ + __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('loggerFactory')), + __param(1, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('gridOptionsWrapper')), + __param(2, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('frameworkOverrides')), + __param(3, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('globalEventListener')) + ], EventService.prototype, "setBeans", null); + EventService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('eventService') + ], EventService); + return EventService; +}()); + + + +/***/ }), +/* 12 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Context", function() { return Context; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PreConstruct", function() { return PreConstruct; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PostConstruct", function() { return PostConstruct; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PreDestroy", function() { return PreDestroy; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Bean", function() { return Bean; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Autowired", function() { return Autowired; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Optional", function() { return Optional; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Qualifier", function() { return Qualifier; }); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(13); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(14); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ + + + +var Context = /** @class */ (function () { + function Context(params, logger) { + this.beanWrappers = {}; + this.destroyed = false; + if (!params || !params.beanClasses) { + return; + } + this.contextParams = params; + this.logger = logger; + this.logger.log(">> creating ag-Application Context"); + this.createBeans(); + var beanInstances = this.getBeanInstances(); + this.wireBeans(beanInstances); + this.logger.log(">> ag-Application Context ready - component is alive"); + } + Context.prototype.getBeanInstances = function () { + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_0__["values"])(this.beanWrappers).map(function (beanEntry) { return beanEntry.beanInstance; }); + }; + Context.prototype.createBean = function (bean, afterPreCreateCallback) { + if (!bean) { + throw Error("Can't wire to bean since it is null"); + } + this.wireBeans([bean], afterPreCreateCallback); + return bean; + }; + Context.prototype.wireBeans = function (beanInstances, afterPreCreateCallback) { + this.autoWireBeans(beanInstances); + this.methodWireBeans(beanInstances); + this.callLifeCycleMethods(beanInstances, 'preConstructMethods'); + // the callback sets the attributes, so the component has access to attributes + // before postConstruct methods in the component are executed + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_0__["exists"])(afterPreCreateCallback)) { + beanInstances.forEach(afterPreCreateCallback); + } + this.callLifeCycleMethods(beanInstances, 'postConstructMethods'); + }; + Context.prototype.createBeans = function () { + var _this = this; + // register all normal beans + this.contextParams.beanClasses.forEach(this.createBeanWrapper.bind(this)); + // register override beans, these will overwrite beans above of same name + // instantiate all beans - overridden beans will be left out + Object(_utils_object__WEBPACK_IMPORTED_MODULE_1__["iterateObject"])(this.beanWrappers, function (key, beanEntry) { + var constructorParamsMeta; + if (beanEntry.bean.__agBeanMetaData && beanEntry.bean.__agBeanMetaData.autowireMethods && beanEntry.bean.__agBeanMetaData.autowireMethods.agConstructor) { + constructorParamsMeta = beanEntry.bean.__agBeanMetaData.autowireMethods.agConstructor; + } + var constructorParams = _this.getBeansForParameters(constructorParamsMeta, beanEntry.bean.name); + var newInstance = applyToConstructor(beanEntry.bean, constructorParams); + beanEntry.beanInstance = newInstance; + }); + var createdBeanNames = Object.keys(this.beanWrappers).join(', '); + this.logger.log("created beans: " + createdBeanNames); + }; + // tslint:disable-next-line + Context.prototype.createBeanWrapper = function (BeanClass) { + var metaData = BeanClass.__agBeanMetaData; + if (!metaData) { + var beanName = void 0; + if (BeanClass.prototype.constructor) { + beanName = Object(_utils_function__WEBPACK_IMPORTED_MODULE_2__["getFunctionName"])(BeanClass.prototype.constructor); + } + else { + beanName = "" + BeanClass; + } + console.error("Context item " + beanName + " is not a bean"); + return; + } + var beanEntry = { + bean: BeanClass, + beanInstance: null, + beanName: metaData.beanName + }; + this.beanWrappers[metaData.beanName] = beanEntry; + }; + Context.prototype.autoWireBeans = function (beanInstances) { + var _this = this; + beanInstances.forEach(function (beanInstance) { + _this.forEachMetaDataInHierarchy(beanInstance, function (metaData, beanName) { + var attributes = metaData.agClassAttributes; + if (!attributes) { + return; + } + attributes.forEach(function (attribute) { + var otherBean = _this.lookupBeanInstance(beanName, attribute.beanName, attribute.optional); + beanInstance[attribute.attributeName] = otherBean; + }); + }); + }); + }; + Context.prototype.methodWireBeans = function (beanInstances) { + var _this = this; + beanInstances.forEach(function (beanInstance) { + _this.forEachMetaDataInHierarchy(beanInstance, function (metaData, beanName) { + Object(_utils_object__WEBPACK_IMPORTED_MODULE_1__["iterateObject"])(metaData.autowireMethods, function (methodName, wireParams) { + // skip constructor, as this is dealt with elsewhere + if (methodName === "agConstructor") { + return; + } + var initParams = _this.getBeansForParameters(wireParams, beanName); + beanInstance[methodName].apply(beanInstance, initParams); + }); + }); + }); + }; + Context.prototype.forEachMetaDataInHierarchy = function (beanInstance, callback) { + var prototype = Object.getPrototypeOf(beanInstance); + while (prototype != null) { + var constructor = prototype.constructor; + if (constructor.hasOwnProperty('__agBeanMetaData')) { + var metaData = constructor.__agBeanMetaData; + var beanName = this.getBeanName(constructor); + callback(metaData, beanName); + } + prototype = Object.getPrototypeOf(prototype); + } + }; + Context.prototype.getBeanName = function (constructor) { + if (constructor.__agBeanMetaData && constructor.__agBeanMetaData.beanName) { + return constructor.__agBeanMetaData.beanName; + } + var constructorString = constructor.toString(); + var beanName = constructorString.substring(9, constructorString.indexOf("(")); + return beanName; + }; + Context.prototype.getBeansForParameters = function (parameters, beanName) { + var _this = this; + var beansList = []; + if (parameters) { + Object(_utils_object__WEBPACK_IMPORTED_MODULE_1__["iterateObject"])(parameters, function (paramIndex, otherBeanName) { + var otherBean = _this.lookupBeanInstance(beanName, otherBeanName); + beansList[Number(paramIndex)] = otherBean; + }); + } + return beansList; + }; + Context.prototype.lookupBeanInstance = function (wiringBean, beanName, optional) { + if (optional === void 0) { optional = false; } + if (beanName === "context") { + return this; + } + if (this.contextParams.providedBeanInstances && this.contextParams.providedBeanInstances.hasOwnProperty(beanName)) { + return this.contextParams.providedBeanInstances[beanName]; + } + var beanEntry = this.beanWrappers[beanName]; + if (beanEntry) { + return beanEntry.beanInstance; + } + if (!optional) { + console.error("AG Grid: unable to find bean reference " + beanName + " while initialising " + wiringBean); + } + return null; + }; + Context.prototype.callLifeCycleMethods = function (beanInstances, lifeCycleMethod) { + var _this = this; + beanInstances.forEach(function (beanInstance) { return _this.callLifeCycleMethodsOnBean(beanInstance, lifeCycleMethod); }); + }; + Context.prototype.callLifeCycleMethodsOnBean = function (beanInstance, lifeCycleMethod, methodToIgnore) { + // putting all methods into a map removes duplicates + var allMethods = {}; + // dump methods from each level of the metadata hierarchy + this.forEachMetaDataInHierarchy(beanInstance, function (metaData) { + var methods = metaData[lifeCycleMethod]; + if (methods) { + methods.forEach(function (methodName) { + if (methodName != methodToIgnore) { + allMethods[methodName] = true; + } + }); + } + }); + var allMethodsList = Object.keys(allMethods); + allMethodsList.forEach(function (methodName) { return beanInstance[methodName](); }); + }; + Context.prototype.getBean = function (name) { + return this.lookupBeanInstance("getBean", name, true); + }; + Context.prototype.destroy = function () { + if (this.destroyed) { + return; + } + this.logger.log(">> Shutting down ag-Application Context"); + var beanInstances = this.getBeanInstances(); + this.destroyBeans(beanInstances); + this.contextParams.providedBeanInstances = null; + this.destroyed = true; + this.logger.log(">> ag-Application Context shut down - component is dead"); + }; + Context.prototype.destroyBean = function (bean) { + if (!bean) { + return; + } + this.destroyBeans([bean]); + }; + Context.prototype.destroyBeans = function (beans) { + var _this = this; + if (!beans) { + return []; + } + beans.forEach(function (bean) { + _this.callLifeCycleMethodsOnBean(bean, 'preDestroyMethods', 'destroy'); + // call destroy() explicitly if it exists + var beanAny = bean; + if (typeof beanAny.destroy === 'function') { + beanAny.destroy(); + } + }); + return []; + }; + return Context; +}()); + +// taken from: http://stackoverflow.com/questions/3362471/how-can-i-call-a-javascript-constructor-using-call-or-apply +// allows calling 'apply' on a constructor +function applyToConstructor(constructor, argArray) { + var args = [null].concat(argArray); + var factoryFunction = constructor.bind.apply(constructor, args); + return new factoryFunction(); +} +function PreConstruct(target, methodName, descriptor) { + var props = getOrCreateProps(target.constructor); + if (!props.preConstructMethods) { + props.preConstructMethods = []; + } + props.preConstructMethods.push(methodName); +} +function PostConstruct(target, methodName, descriptor) { + var props = getOrCreateProps(target.constructor); + if (!props.postConstructMethods) { + props.postConstructMethods = []; + } + props.postConstructMethods.push(methodName); +} +function PreDestroy(target, methodName, descriptor) { + var props = getOrCreateProps(target.constructor); + if (!props.preDestroyMethods) { + props.preDestroyMethods = []; + } + props.preDestroyMethods.push(methodName); +} +function Bean(beanName) { + return function (classConstructor) { + var props = getOrCreateProps(classConstructor); + props.beanName = beanName; + }; +} +function Autowired(name) { + return function (target, propertyKey, descriptor) { + autowiredFunc(target, name, false, target, propertyKey, null); + }; +} +function Optional(name) { + return function (target, propertyKey, descriptor) { + autowiredFunc(target, name, true, target, propertyKey, null); + }; +} +function autowiredFunc(target, name, optional, classPrototype, methodOrAttributeName, index) { + if (name === null) { + console.error("AG Grid: Autowired name should not be null"); + return; + } + if (typeof index === "number") { + console.error("AG Grid: Autowired should be on an attribute"); + return; + } + // it's an attribute on the class + var props = getOrCreateProps(target.constructor); + if (!props.agClassAttributes) { + props.agClassAttributes = []; + } + props.agClassAttributes.push({ + attributeName: methodOrAttributeName, + beanName: name, + optional: optional + }); +} +function Qualifier(name) { + return function (classPrototype, methodOrAttributeName, index) { + var constructor = typeof classPrototype == "function" ? classPrototype : classPrototype.constructor; + var props; + if (typeof index === "number") { + // it's a parameter on a method + var methodName = void 0; + if (methodOrAttributeName) { + props = getOrCreateProps(constructor); + methodName = methodOrAttributeName; + } + else { + props = getOrCreateProps(constructor); + methodName = "agConstructor"; + } + if (!props.autowireMethods) { + props.autowireMethods = {}; + } + if (!props.autowireMethods[methodName]) { + props.autowireMethods[methodName] = {}; + } + props.autowireMethods[methodName][index] = name; + } + }; +} +function getOrCreateProps(target) { + if (!target.hasOwnProperty("__agBeanMetaData")) { + target.__agBeanMetaData = {}; + } + return target.__agBeanMetaData; +} + + +/***/ }), +/* 13 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "iterateObject", function() { return iterateObject; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cloneObject", function() { return cloneObject; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "deepCloneObject", function() { return deepCloneObject; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "deepCloneDefinition", function() { return deepCloneDefinition; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getProperty", function() { return getProperty; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setProperty", function() { return setProperty; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "copyPropertiesIfPresent", function() { return copyPropertiesIfPresent; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "copyPropertyIfPresent", function() { return copyPropertyIfPresent; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getAllKeysInObjects", function() { return getAllKeysInObjects; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getAllValuesInObject", function() { return getAllValuesInObject; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "mergeDeep", function() { return mergeDeep; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "missingOrEmptyObject", function() { return missingOrEmptyObject; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "get", function() { return get; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "set", function() { return set; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "deepFreeze", function() { return deepFreeze; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getValueUsingField", function() { return getValueUsingField; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeAllReferences", function() { return removeAllReferences; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isNonNullObject", function() { return isNonNullObject; }); +/* harmony import */ var _generic__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ + +function iterateObject(object, callback) { + if (object == null) { + return; + } + if (Array.isArray(object)) { + object.forEach(function (value, index) { return callback("" + index, value); }); + } + else { + Object.keys(object).forEach(function (key) { return callback(key, object[key]); }); + } +} +function cloneObject(object) { + var copy = {}; + var keys = Object.keys(object); + for (var i = 0; i < keys.length; i++) { + var key = keys[i]; + var value = object[key]; + copy[key] = value; + } + return copy; +} +function deepCloneObject(object) { + return JSON.parse(JSON.stringify(object)); +} +// returns copy of an object, doing a deep clone of any objects with that object. +// this is used for eg creating copies of Column Definitions, where we want to +// deep copy all objects, but do not want to deep copy functions (eg when user provides +// a function or class for colDef.cellRenderer) +function deepCloneDefinition(object, keysToSkip) { + if (!object) { + return; + } + var obj = object; + var res = {}; + Object.keys(obj).forEach(function (key) { + if (keysToSkip && keysToSkip.indexOf(key) >= 0) { + return; + } + var value = obj[key]; + // 'simple object' means a bunch of key/value pairs, eg {filter: 'myFilter'}. it does + // NOT include the following: + // 1) arrays + // 2) functions or classes (eg ColumnAPI instance) + var sourceIsSimpleObject = isNonNullObject(value) && value.constructor === Object; + if (sourceIsSimpleObject) { + res[key] = deepCloneDefinition(value); + } + else { + res[key] = value; + } + }); + return res; +} +function getProperty(object, key) { + return object[key]; +} +function setProperty(object, key, value) { + object[key] = value; +} +/** + * Will copy the specified properties from `source` into the equivalent properties on `target`, ignoring properties with + * a value of `undefined`. + */ +function copyPropertiesIfPresent(source, target) { + var properties = []; + for (var _i = 2; _i < arguments.length; _i++) { + properties[_i - 2] = arguments[_i]; + } + properties.forEach(function (p) { return copyPropertyIfPresent(source, target, p); }); +} +/** + * Will copy the specified property from `source` into the equivalent property on `target`, unless the property has a + * value of `undefined`. If a transformation is provided, it will be applied to the value before being set on `target`. + */ +function copyPropertyIfPresent(source, target, property, transform) { + var value = getProperty(source, property); + if (value !== undefined) { + setProperty(target, property, transform ? transform(value) : value); + } +} +function getAllKeysInObjects(objects) { + var allValues = {}; + objects.filter(function (obj) { return obj != null; }).forEach(function (obj) { + Object.keys(obj).forEach(function (key) { return allValues[key] = null; }); + }); + return Object.keys(allValues); +} +function getAllValuesInObject(obj) { + if (!obj) { + return []; + } + var anyObject = Object; + if (typeof anyObject.values === 'function') { + return anyObject.values(obj); + } + var ret = []; + for (var key in obj) { + if (obj.hasOwnProperty(key) && obj.propertyIsEnumerable(key)) { + ret.push(obj[key]); + } + } + return ret; +} +function mergeDeep(dest, source, copyUndefined, makeCopyOfSimpleObjects) { + if (copyUndefined === void 0) { copyUndefined = true; } + if (makeCopyOfSimpleObjects === void 0) { makeCopyOfSimpleObjects = false; } + if (!Object(_generic__WEBPACK_IMPORTED_MODULE_0__["exists"])(source)) { + return; + } + iterateObject(source, function (key, sourceValue) { + var destValue = dest[key]; + if (destValue === sourceValue) { + return; + } + // when creating params, we don't want to just copy objects over. otherwise merging ColDefs (eg DefaultColDef + // and Column Types) would result in params getting shared between objects. + // by putting an empty value into destValue first, it means we end up copying over values from + // the source object, rather than just copying in the source object in it's entirety. + if (makeCopyOfSimpleObjects) { + var objectIsDueToBeCopied = destValue == null && sourceValue != null; + if (objectIsDueToBeCopied) { + // 'simple object' means a bunch of key/value pairs, eg {filter: 'myFilter'}, as opposed + // to a Class instance (such as ColumnAPI instance). + var sourceIsSimpleObject = typeof sourceValue === 'object' && sourceValue.constructor === Object; + var dontCopy = sourceIsSimpleObject; + if (dontCopy) { + destValue = {}; + dest[key] = destValue; + } + } + } + if (isNonNullObject(sourceValue) && isNonNullObject(destValue) && !Array.isArray(destValue)) { + mergeDeep(destValue, sourceValue, copyUndefined, makeCopyOfSimpleObjects); + } + else if (copyUndefined || sourceValue !== undefined) { + dest[key] = sourceValue; + } + }); +} +function missingOrEmptyObject(value) { + return Object(_generic__WEBPACK_IMPORTED_MODULE_0__["missing"])(value) || Object.keys(value).length === 0; +} +function get(source, expression, defaultValue) { + if (source == null) { + return defaultValue; + } + var keys = expression.split('.'); + var objectToRead = source; + while (keys.length > 1) { + objectToRead = objectToRead[keys.shift()]; + if (objectToRead == null) { + return defaultValue; + } + } + var value = objectToRead[keys[0]]; + return value != null ? value : defaultValue; +} +function set(target, expression, value) { + if (target == null) { + return; + } + var keys = expression.split('.'); + var objectToUpdate = target; + while (keys.length > 1) { + objectToUpdate = objectToUpdate[keys.shift()]; + if (objectToUpdate == null) { + return; + } + } + objectToUpdate[keys[0]] = value; +} +function deepFreeze(object) { + Object.freeze(object); + Object(_generic__WEBPACK_IMPORTED_MODULE_0__["values"])(object).forEach(function (v) { + if (isNonNullObject(v) || typeof v === 'function') { + deepFreeze(v); + } + }); + return object; +} +function getValueUsingField(data, field, fieldContainsDots) { + if (!field || !data) { + return; + } + // if no '.', then it's not a deep value + if (!fieldContainsDots) { + return data[field]; + } + // otherwise it is a deep value, so need to dig for it + var fields = field.split('.'); + var currentObject = data; + for (var i = 0; i < fields.length; i++) { + if (currentObject == null) { + return undefined; + } + currentObject = currentObject[fields[i]]; + } + return currentObject; +} +// used by ColumnAPI and GridAPI to remove all references, so keeping grid in memory resulting in a +// memory leak if user is not disposing of the GridAPI or ColumnApi references +function removeAllReferences(obj, objectName) { + Object.keys(obj).forEach(function (key) { + var value = obj[key]; + // we want to replace all the @autowired services, which are objects. any simple types (boolean, string etc) + // we don't care about + if (typeof value === 'object') { + obj[key] = undefined; + } + }); + var proto = Object.getPrototypeOf(obj); + var properties = {}; + Object.keys(proto).forEach(function (key) { + var value = proto[key]; + // leave all basic types - this is needed for GridAPI to leave the "destroyed: boolean" attribute alone + if (typeof value === 'function') { + var func = function () { + console.warn("AG Grid: " + objectName + " function " + key + "() cannot be called as the grid has been destroyed.\n Please don't call grid API functions on destroyed grids - as a matter of fact you shouldn't\n be keeping the API reference, your application has a memory leak! Remove the API reference\n when the grid is destroyed."); + }; + properties[key] = { value: func, writable: true }; + } + }); + Object.defineProperties(obj, properties); +} +function isNonNullObject(value) { + return typeof value === 'object' && value !== null; +} + + +/***/ }), +/* 14 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "doOnce", function() { return doOnce; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getFunctionName", function() { return getFunctionName; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getFunctionParameters", function() { return getFunctionParameters; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isFunction", function() { return isFunction; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "executeInAWhile", function() { return executeInAWhile; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "executeNextVMTurn", function() { return executeNextVMTurn; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "executeAfter", function() { return executeAfter; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "debounce", function() { return debounce; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "waitUntil", function() { return waitUntil; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "compose", function() { return compose; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "callIfPresent", function() { return callIfPresent; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var FUNCTION_STRIP_COMMENTS = /((\/\/.*$)|(\/\*[\s\S]*?\*\/))/mg; +var FUNCTION_ARGUMENT_NAMES = /([^\s,]+)/g; +var doOnceFlags = {}; +/** + * If the key was passed before, then doesn't execute the func + * @param {Function} func + * @param {string} key + */ +function doOnce(func, key) { + if (doOnceFlags[key]) { + return; + } + func(); + doOnceFlags[key] = true; +} +function getFunctionName(funcConstructor) { + // for every other browser in the world + if (funcConstructor.name) { + return funcConstructor.name; + } + // for the pestilence that is ie11 + var matches = /function\s+([^\(]+)/.exec(funcConstructor.toString()); + return matches && matches.length === 2 ? matches[1].trim() : null; +} +/** @deprecated */ +function getFunctionParameters(func) { + var fnStr = func.toString().replace(FUNCTION_STRIP_COMMENTS, ''); + return fnStr.slice(fnStr.indexOf('(') + 1, fnStr.indexOf(')')).match(FUNCTION_ARGUMENT_NAMES) || []; +} +function isFunction(val) { + return !!(val && val.constructor && val.call && val.apply); +} +function executeInAWhile(funcs) { + executeAfter(funcs, 400); +} +var executeNextVMTurnFuncs = []; +var executeNextVMTurnPending = false; +function executeNextVMTurn(func) { + executeNextVMTurnFuncs.push(func); + if (executeNextVMTurnPending) { + return; + } + executeNextVMTurnPending = true; + window.setTimeout(function () { + var funcsCopy = executeNextVMTurnFuncs.slice(); + executeNextVMTurnFuncs.length = 0; + executeNextVMTurnPending = false; + funcsCopy.forEach(function (func) { return func(); }); + }, 0); +} +function executeAfter(funcs, milliseconds) { + if (milliseconds === void 0) { milliseconds = 0; } + if (funcs.length > 0) { + window.setTimeout(function () { return funcs.forEach(function (func) { return func(); }); }, milliseconds); + } +} +/** + * from https://stackoverflow.com/questions/24004791/can-someone-explain-the-debounce-function-in-javascript + * @param {Function} func The function to be debounced + * @param {number} wait The time in ms to debounce + * @param {boolean} immediate If it should run immediately or wait for the initial debounce delay + * @return {Function} The debounced function + */ +function debounce(func, wait, immediate) { + if (immediate === void 0) { immediate = false; } + // 'private' variable for instance + // The returned function will be able to reference this due to closure. + // Each call to the returned function will share this common timer. + var timeout; + // Calling debounce returns a new anonymous function + return function () { + var args = []; + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + // reference the context and args for the setTimeout function + var context = this; + // Should the function be called now? If immediate is true + // and not already in a timeout then the answer is: Yes + var callNow = immediate && !timeout; + // This is the basic debounce behaviour where you can call this + // function several times, but it will only execute once + // [before or after imposing a delay]. + // Each time the returned function is called, the timer starts over. + window.clearTimeout(timeout); + // Set the new timeout + timeout = window.setTimeout(function () { + // Inside the timeout function, clear the timeout variable + // which will let the next execution run when in 'immediate' mode + timeout = null; + // Check if the function already ran with the immediate flag + if (!immediate) { + // Call the original function with apply + // apply lets you define the 'this' object as well as the arguments + // (both captured before setTimeout) + func.apply(context, args); + } + }, wait); + // Immediate mode and no wait timer? Execute the function.. + if (callNow) { + func.apply(context, args); + } + }; +} +function waitUntil(condition, callback, timeout, timeoutMessage) { + if (timeout === void 0) { timeout = 100; } + var timeStamp = new Date().getTime(); + var interval = null; + var executed = false; + var internalCallback = function () { + var reachedTimeout = ((new Date().getTime()) - timeStamp) > timeout; + if (condition() || reachedTimeout) { + callback(); + executed = true; + if (interval != null) { + window.clearInterval(interval); + interval = null; + } + if (reachedTimeout && timeoutMessage) { + console.warn(timeoutMessage); + } + } + }; + internalCallback(); + if (!executed) { + interval = window.setInterval(internalCallback, 10); + } +} +function compose() { + var fns = []; + for (var _i = 0; _i < arguments.length; _i++) { + fns[_i] = arguments[_i]; + } + return function (arg) { return fns.reduce(function (composed, f) { return f(composed); }, arg); }; +} +function callIfPresent(func) { + if (func) { + func(); + } +} + + +/***/ }), +/* 15 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Constants", function() { return Constants; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var Constants = /** @class */ (function () { + function Constants() { + } + Constants.ROW_BUFFER_SIZE = 10; + Constants.LAYOUT_INTERVAL = 500; + Constants.BATCH_WAIT_MILLIS = 50; + Constants.EXPORT_TYPE_DRAG_COPY = 'dragCopy'; + Constants.EXPORT_TYPE_CLIPBOARD = 'clipboard'; + Constants.EXPORT_TYPE_EXCEL = 'excel'; + Constants.EXPORT_TYPE_CSV = 'csv'; + Constants.ROW_MODEL_TYPE_INFINITE = 'infinite'; + Constants.ROW_MODEL_TYPE_VIEWPORT = 'viewport'; + Constants.ROW_MODEL_TYPE_CLIENT_SIDE = 'clientSide'; + Constants.ROW_MODEL_TYPE_SERVER_SIDE = 'serverSide'; + Constants.ALWAYS = 'always'; + Constants.ONLY_WHEN_GROUPING = 'onlyWhenGrouping'; + Constants.PINNED_TOP = 'top'; + Constants.PINNED_BOTTOM = 'bottom'; + Constants.DOM_LAYOUT_NORMAL = 'normal'; + Constants.DOM_LAYOUT_PRINT = 'print'; + Constants.DOM_LAYOUT_AUTO_HEIGHT = 'autoHeight'; + Constants.GROUP_AUTO_COLUMN_ID = 'ag-Grid-AutoColumn'; + Constants.SOURCE_PASTE = 'paste'; + Constants.PINNED_RIGHT = 'right'; + Constants.PINNED_LEFT = 'left'; + Constants.SORT_ASC = 'asc'; + Constants.SORT_DESC = 'desc'; + Constants.INPUT_SELECTOR = 'input, select, button, textarea'; + Constants.FOCUSABLE_SELECTOR = '[tabindex], input, select, button, textarea'; + Constants.FOCUSABLE_EXCLUDE = '.ag-hidden, .ag-hidden *, [disabled], .ag-disabled, .ag-disabled *'; + return Constants; +}()); + + + +/***/ }), +/* 16 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ModuleNames", function() { return ModuleNames; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var ModuleNames; +(function (ModuleNames) { + // when using modules, user references this + ModuleNames["CommunityCoreModule"] = "@ag-grid-community/core"; + // when not using modules, user references this + ModuleNames["CommunityAllModules"] = "@ag-grid-community/all"; + // community modules + ModuleNames["InfiniteRowModelModule"] = "@ag-grid-community/infinite-row-model"; + ModuleNames["ClientSideRowModelModule"] = "@ag-grid-community/client-side-row-model"; + ModuleNames["CsvExportModule"] = "@ag-grid-community/csv-export"; + // enterprise core - users never import on this, but other enterprise modules do + ModuleNames["EnterpriseCoreModule"] = "@ag-grid-enterprise/core"; + // when not using modules, user references this + ModuleNames["EnterpriseAllModules"] = "@ag-grid-enterprise/all"; + // enterprise modules + ModuleNames["RowGroupingModule"] = "@ag-grid-enterprise/row-grouping"; + ModuleNames["ColumnToolPanelModule"] = "@ag-grid-enterprise/column-tool-panel"; + ModuleNames["FiltersToolPanelModule"] = "@ag-grid-enterprise/filter-tool-panel"; + ModuleNames["MenuModule"] = "@ag-grid-enterprise/menu"; + ModuleNames["SetFilterModule"] = "@ag-grid-enterprise/set-filter"; + ModuleNames["MultiFilterModule"] = "@ag-grid-enterprise/multi-filter"; + ModuleNames["StatusBarModule"] = "@ag-grid-enterprise/status-bar"; + ModuleNames["SideBarModule"] = "@ag-grid-enterprise/side-bar"; + ModuleNames["RangeSelectionModule"] = "@ag-grid-enterprise/range-selection"; + ModuleNames["MasterDetailModule"] = "@ag-grid-enterprise/master-detail"; + ModuleNames["RichSelectModule"] = "@ag-grid-enterprise/rich-select"; + ModuleNames["GridChartsModule"] = "@ag-grid-enterprise/charts"; + ModuleNames["ViewportRowModelModule"] = "@ag-grid-enterprise/viewport-row-model"; + ModuleNames["ServerSideRowModelModule"] = "@ag-grid-enterprise/server-side-row-model"; + ModuleNames["ExcelExportModule"] = "@ag-grid-enterprise/excel-export"; + ModuleNames["ClipboardModule"] = "@ag-grid-enterprise/clipboard"; + ModuleNames["SparklinesModule"] = "@ag-grid-enterprise/sparklines"; + // framework wrappers currently don't provide beans, comps etc, so no need to be modules, + // however i argue they should be as in theory they 'could' provide beans etc + ModuleNames["AngularModule"] = "@ag-grid-community/angular"; + ModuleNames["ReactModule"] = "@ag-grid-community/react"; + ModuleNames["VueModule"] = "@ag-grid-community/vue"; + ModuleNames["PolymerModule"] = "@ag-grid-community/polymer"; + // and then this, which is definitely not a grid module, as it should not have any dependency + // on the grid (ie shouldn't even reference the Module interface) + // ChartsModule = "@ag-grid-community/charts-core", +})(ModuleNames || (ModuleNames = {})); + + +/***/ }), +/* 17 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ModuleRegistry", function() { return ModuleRegistry; }); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(14); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ + + +var ModuleRegistry = /** @class */ (function () { + function ModuleRegistry() { + } + ModuleRegistry.register = function (module, moduleBased) { + if (moduleBased === void 0) { moduleBased = true; } + ModuleRegistry.modulesMap[module.moduleName] = module; + if (ModuleRegistry.moduleBased === undefined) { + ModuleRegistry.moduleBased = moduleBased; + } + else { + if (ModuleRegistry.moduleBased !== moduleBased) { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_0__["doOnce"])(function () { + console.warn("AG Grid: You are mixing modules (i.e. @ag-grid-community/core) and packages (ag-grid-community) - you can only use one or the other of these mechanisms."); + console.warn('Please see https://www.ag-grid.com/javascript-grid/packages-modules/ for more information.'); + }, 'ModulePackageCheck'); + } + } + }; + // noinspection JSUnusedGlobalSymbols + ModuleRegistry.registerModules = function (modules, moduleBased) { + if (moduleBased === void 0) { moduleBased = true; } + if (!modules) { + return; + } + modules.forEach(function (module) { return ModuleRegistry.register(module, moduleBased); }); + }; + ModuleRegistry.assertRegistered = function (moduleName, reason) { + if (this.isRegistered(moduleName)) { + return true; + } + var warningKey = reason + moduleName; + var warningMessage; + if (ModuleRegistry.moduleBased) { + warningMessage = "AG Grid: unable to use " + reason + " as module " + moduleName + " is not present. Please see: https://www.ag-grid.com/javascript-grid/modules/"; + } + else { + warningMessage = "AG Grid: unable to use " + reason + " as package 'ag-grid-enterprise' is not present. Please see: https://www.ag-grid.com/javascript-grid/packages/"; + } + Object(_utils_function__WEBPACK_IMPORTED_MODULE_0__["doOnce"])(function () { + console.warn(warningMessage); + }, warningKey); + return false; + }; + ModuleRegistry.isRegistered = function (moduleName) { + return !!ModuleRegistry.modulesMap[moduleName]; + }; + ModuleRegistry.getRegisteredModules = function () { + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_1__["values"])(ModuleRegistry.modulesMap); + }; + ModuleRegistry.isPackageBased = function () { + return !ModuleRegistry.moduleBased; + }; + // having in a map a) removes duplicates and b) allows fast lookup + ModuleRegistry.modulesMap = {}; + return ModuleRegistry; +}()); + + + +/***/ }), +/* 18 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "firstExistingValue", function() { return firstExistingValue; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "existsAndNotEmpty", function() { return existsAndNotEmpty; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "last", function() { return last; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "areEqual", function() { return areEqual; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "compareArrays", function() { return compareArrays; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "shallowCompare", function() { return shallowCompare; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "sortNumerically", function() { return sortNumerically; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeRepeatsFromArray", function() { return removeRepeatsFromArray; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeFromArray", function() { return removeFromArray; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeAllFromArray", function() { return removeAllFromArray; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "insertIntoArray", function() { return insertIntoArray; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "insertArrayIntoArray", function() { return insertArrayIntoArray; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "moveInArray", function() { return moveInArray; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "includes", function() { return includes; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "flatten", function() { return flatten; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "pushAll", function() { return pushAll; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "toStrings", function() { return toStrings; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "forEachReverse", function() { return forEachReverse; }); +/* harmony import */ var _generic__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ + +function firstExistingValue() { + var values = []; + for (var _i = 0; _i < arguments.length; _i++) { + values[_i] = arguments[_i]; + } + for (var i = 0; i < values.length; i++) { + var value = values[i]; + if (Object(_generic__WEBPACK_IMPORTED_MODULE_0__["exists"])(value)) { + return value; + } + } + return null; +} +function existsAndNotEmpty(value) { + return value != null && value.length > 0; +} +function last(arr) { + if (!arr || !arr.length) { + return; + } + return arr[arr.length - 1]; +} +function areEqual(a, b, comparator) { + if (a == null && b == null) { + return true; + } + return a != null && + b != null && + a.length === b.length && + a.every(function (value, index) { return comparator ? comparator(value, b[index]) : b[index] === value; }); +} +/** @deprecated */ +function compareArrays(array1, array2) { + return areEqual(array1, array2); +} +/** @deprecated */ +function shallowCompare(arr1, arr2) { + return areEqual(arr1, arr2); +} +function sortNumerically(array) { + return array.sort(function (a, b) { return a - b; }); +} +function removeRepeatsFromArray(array, object) { + if (!array) { + return; + } + for (var index = array.length - 2; index >= 0; index--) { + var thisOneMatches = array[index] === object; + var nextOneMatches = array[index + 1] === object; + if (thisOneMatches && nextOneMatches) { + array.splice(index + 1, 1); + } + } +} +function removeFromArray(array, object) { + var index = array.indexOf(object); + if (index >= 0) { + array.splice(index, 1); + } +} +function removeAllFromArray(array, toRemove) { + toRemove.forEach(function (item) { return removeFromArray(array, item); }); +} +function insertIntoArray(array, object, toIndex) { + array.splice(toIndex, 0, object); +} +function insertArrayIntoArray(dest, src, toIndex) { + if (dest == null || src == null) { + return; + } + // put items in backwards, otherwise inserted items end up in reverse order + for (var i = src.length - 1; i >= 0; i--) { + var item = src[i]; + insertIntoArray(dest, item, toIndex); + } +} +function moveInArray(array, objectsToMove, toIndex) { + // first take out items from the array + removeAllFromArray(array, objectsToMove); + // now add the objects, in same order as provided to us, that means we start at the end + // as the objects will be pushed to the right as they are inserted + objectsToMove.slice().reverse().forEach(function (obj) { return insertIntoArray(array, obj, toIndex); }); +} +function includes(array, value) { + return array.indexOf(value) > -1; +} +function flatten(arrayOfArrays) { + return [].concat.apply([], arrayOfArrays); +} +function pushAll(target, source) { + if (source == null || target == null) { + return; + } + source.forEach(function (value) { return target.push(value); }); +} +function toStrings(array) { + return array.map(_generic__WEBPACK_IMPORTED_MODULE_0__["toStringOrNull"]); +} +function forEachReverse(list, action) { + if (list == null) { + return; + } + for (var i = list.length - 1; i >= 0; i--) { + action(list[i], i); + } +} + + +/***/ }), +/* 19 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DefaultColumnTypes", function() { return DefaultColumnTypes; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var DefaultColumnTypes = { + numericColumn: { + headerClass: 'ag-right-aligned-header', + cellClass: 'ag-right-aligned-cell' + }, + rightAligned: { + headerClass: 'ag-right-aligned-header', + cellClass: 'ag-right-aligned-cell' + } +}; + + +/***/ }), +/* 20 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BeanStub", function() { return BeanStub; }); +/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(11); +/* harmony import */ var _context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _utils_event__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(21); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + +var BeanStub = /** @class */ (function () { + function BeanStub() { + var _this = this; + this.destroyFunctions = []; + this.destroyed = false; + // for vue 3 - prevents Vue from trying to make this (and obviously any sub classes) from being reactive + // prevents vue from creating proxies for created objects and prevents identity related issues + this.__v_skip = true; + this.isAlive = function () { return !_this.destroyed; }; + } + // this was a test constructor niall built, when active, it prints after 5 seconds all beans/components that are + // not destroyed. to use, create a new grid, then api.destroy() before 5 seconds. then anything that gets printed + // points to a bean or component that was not properly disposed of. + // constructor() { + // setTimeout(()=> { + // if (this.isAlive()) { + // let prototype: any = Object.getPrototypeOf(this); + // const constructor: any = prototype.constructor; + // const constructorString = constructor.toString(); + // const beanName = constructorString.substring(9, constructorString.indexOf("(")); + // console.log('is alive ' + beanName); + // } + // }, 5000); + // } + // CellComp and GridComp and override this because they get the FrameworkOverrides from the Beans bean + BeanStub.prototype.getFrameworkOverrides = function () { + return this.frameworkOverrides; + }; + BeanStub.prototype.getContext = function () { + return this.context; + }; + BeanStub.prototype.destroy = function () { + // let prototype: any = Object.getPrototypeOf(this); + // const constructor: any = prototype.constructor; + // const constructorString = constructor.toString(); + // const beanName = constructorString.substring(9, constructorString.indexOf("(")); + this.destroyFunctions.forEach(function (func) { return func(); }); + this.destroyFunctions.length = 0; + this.destroyed = true; + this.dispatchEvent({ type: BeanStub.EVENT_DESTROYED }); + }; + BeanStub.prototype.addEventListener = function (eventType, listener) { + if (!this.localEventService) { + this.localEventService = new _eventService__WEBPACK_IMPORTED_MODULE_0__["EventService"](); + } + this.localEventService.addEventListener(eventType, listener); + }; + BeanStub.prototype.removeEventListener = function (eventType, listener) { + if (this.localEventService) { + this.localEventService.removeEventListener(eventType, listener); + } + }; + BeanStub.prototype.dispatchEventAsync = function (event) { + var _this = this; + window.setTimeout(function () { return _this.dispatchEvent(event); }, 0); + }; + BeanStub.prototype.dispatchEvent = function (event) { + if (this.localEventService) { + this.localEventService.dispatchEvent(event); + } + }; + BeanStub.prototype.addManagedListener = function (object, event, listener) { + var _this = this; + if (this.destroyed) { + return; + } + if (object instanceof HTMLElement) { + Object(_utils_event__WEBPACK_IMPORTED_MODULE_2__["addSafePassiveEventListener"])(this.getFrameworkOverrides(), object, event, listener); + } + else { + object.addEventListener(event, listener); + } + var destroyFunc = function () { + object.removeEventListener(event, listener); + _this.destroyFunctions = _this.destroyFunctions.filter(function (fn) { return fn !== destroyFunc; }); + return null; + }; + this.destroyFunctions.push(destroyFunc); + return destroyFunc; + }; + BeanStub.prototype.addDestroyFunc = function (func) { + // if we are already destroyed, we execute the func now + if (this.isAlive()) { + this.destroyFunctions.push(func); + } + else { + func(); + } + }; + BeanStub.prototype.createManagedBean = function (bean, context) { + var res = this.createBean(bean, context); + this.addDestroyFunc(this.destroyBean.bind(this, bean, context)); + return res; + }; + BeanStub.prototype.createBean = function (bean, context, afterPreCreateCallback) { + return (context || this.getContext()).createBean(bean, afterPreCreateCallback); + }; + BeanStub.prototype.destroyBean = function (bean, context) { + return (context || this.getContext()).destroyBean(bean); + }; + BeanStub.prototype.destroyBeans = function (beans, context) { + var _this = this; + if (beans) { + beans.forEach(function (bean) { return _this.destroyBean(bean, context); }); + } + return []; + }; + BeanStub.EVENT_DESTROYED = 'destroyed'; + __decorate([ + Object(_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('frameworkOverrides') + ], BeanStub.prototype, "frameworkOverrides", void 0); + __decorate([ + Object(_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('context') + ], BeanStub.prototype, "context", void 0); + __decorate([ + Object(_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('eventService') + ], BeanStub.prototype, "eventService", void 0); + __decorate([ + Object(_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') + ], BeanStub.prototype, "gridOptionsWrapper", void 0); + __decorate([ + _context__WEBPACK_IMPORTED_MODULE_1__["PreDestroy"] + ], BeanStub.prototype, "destroy", null); + return BeanStub; +}()); + + + +/***/ }), +/* 21 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "stopPropagationForAgGrid", function() { return stopPropagationForAgGrid; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isStopPropagationForAgGrid", function() { return isStopPropagationForAgGrid; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isEventSupported", function() { return isEventSupported; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getCtrlForEvent", function() { return getCtrlForEvent; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addChangeListener", function() { return addChangeListener; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isElementInEventPath", function() { return isElementInEventPath; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "createEventPath", function() { return createEventPath; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addAgGridEventPath", function() { return addAgGridEventPath; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getEventPath", function() { return getEventPath; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addSafePassiveEventListener", function() { return addSafePassiveEventListener; }); +/* harmony import */ var _array__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(18); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ + +var AG_GRID_STOP_PROPAGATION = '__ag_Grid_Stop_Propagation'; +var PASSIVE_EVENTS = ['touchstart', 'touchend', 'touchmove', 'touchcancel']; +var supports = {}; +/** + * a user once raised an issue - they said that when you opened a popup (eg context menu) + * and then clicked on a selection checkbox, the popup wasn't closed. this is because the + * popup listens for clicks on the body, however ag-grid WAS stopping propagation on the + * checkbox clicks (so the rows didn't pick them up as row selection selection clicks). + * to get around this, we have a pattern to stop propagation for the purposes of AG Grid, + * but we still let the event pass back to the body. + * @param {Event} event + */ +function stopPropagationForAgGrid(event) { + event[AG_GRID_STOP_PROPAGATION] = true; +} +function isStopPropagationForAgGrid(event) { + return event[AG_GRID_STOP_PROPAGATION] === true; +} +var isEventSupported = (function () { + var tags = { + select: 'input', + change: 'input', + submit: 'form', + reset: 'form', + error: 'img', + load: 'img', + abort: 'img' + }; + var eventChecker = function (eventName) { + if (typeof supports[eventName] === 'boolean') { + return supports[eventName]; + } + var el = document.createElement(tags[eventName] || 'div'); + eventName = 'on' + eventName; + return supports[eventName] = (eventName in el); + }; + return eventChecker; +})(); +function getCtrlForEvent(gridOptionsWrapper, event, type) { + var sourceElement = event.target; + while (sourceElement) { + var renderedComp = gridOptionsWrapper.getDomData(sourceElement, type); + if (renderedComp) { + return renderedComp; + } + sourceElement = sourceElement.parentElement; + } + return null; +} +/** + * @deprecated + * Adds all type of change listeners to an element, intended to be a text field + * @param {HTMLElement} element + * @param {EventListener} listener + */ +function addChangeListener(element, listener) { + element.addEventListener('changed', listener); + element.addEventListener('paste', listener); + element.addEventListener('input', listener); +} +function isElementInEventPath(element, event) { + if (!event || !element) { + return false; + } + return getEventPath(event).indexOf(element) >= 0; +} +function createEventPath(event) { + var res = []; + var pointer = event.target; + while (pointer) { + res.push(pointer); + pointer = pointer.parentElement; + } + return res; +} +/** + * firefox doesn't have event.path set, or any alternative to it, so we hack + * it in. this is needed as it's to late to work out the path when the item is + * removed from the dom. used by MouseEventService, where it works out if a click + * was from the current grid, or a detail grid (master / detail). + * @param {Event} event + */ +function addAgGridEventPath(event) { + event.__agGridEventPath = getEventPath(event); +} +/** + * Gets the path for an Event. + * https://stackoverflow.com/questions/39245488/event-path-undefined-with-firefox-and-vue-js + * https://developer.mozilla.org/en-US/docs/Web/API/Event + * @param {Event} event + * @returns {EventTarget[]} + */ +function getEventPath(event) { + var eventNoType = event; + if (eventNoType.path) { + // Chrome supports path + return eventNoType.path; + } + if (eventNoType.composedPath) { + // Firefox supports composePath + return eventNoType.composedPath(); + } + if (eventNoType.__agGridEventPath) { + // Firefox supports composePath + return eventNoType.__agGridEventPath; + } + // and finally, if none of the above worked, + // we create the path ourselves + return createEventPath(event); +} +function addSafePassiveEventListener(frameworkOverrides, eElement, event, listener) { + var isPassive = Object(_array__WEBPACK_IMPORTED_MODULE_0__["includes"])(PASSIVE_EVENTS, event); + var options = isPassive ? { passive: true } : undefined; + // this check is here for certain scenarios where I believe the user must be destroying + // the grid somehow but continuing for it to be used + if (frameworkOverrides && frameworkOverrides.addEventListener) { + frameworkOverrides.addEventListener(eElement, event, listener, options); + } +} + + +/***/ }), +/* 22 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnModel", function() { return ColumnModel; }); +/* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(9); +/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(10); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(23); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(20); +/* harmony import */ var _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(8); +/* harmony import */ var _groupInstanceIdCreator__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(25); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(12); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(15); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(18); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(7); +/* harmony import */ var _utils_string__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(26); +/* harmony import */ var _utils_map__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(27); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(14); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; +var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { + return function (target, key) { decorator(target, key, paramIndex); } +}; +var __values = (undefined && undefined.__values) || function(o) { + var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0; + if (m) return m.call(o); + if (o && typeof o.length === "number") return { + next: function () { + if (o && i >= o.length) o = void 0; + return { value: o && o[i++], done: !o }; + } + }; + throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined."); +}; +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; +}; +var __spread = (undefined && undefined.__spread) || function () { + for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); + return ar; +}; + + + + + + + + + + + + + +var ColumnModel = /** @class */ (function (_super) { + __extends(ColumnModel, _super); + function ColumnModel() { + var _this = _super !== null && _super.apply(this, arguments) || this; + // header row count, based on user provided columns + _this.primaryHeaderRowCount = 0; + _this.secondaryHeaderRowCount = 0; + _this.secondaryColumnsPresent = false; + // header row count, either above, or based on pivoting if we are pivoting + _this.gridHeaderRowCount = 0; + // leave level columns of the displayed trees + _this.displayedColumnsLeft = []; + _this.displayedColumnsRight = []; + _this.displayedColumnsCenter = []; + // all three lists above combined + _this.displayedColumns = []; + // for fast lookup, to see if a column or group is still displayed + _this.displayedColumnsAndGroupsMap = {}; + // all columns to be rendered + _this.viewportColumns = []; + // all columns to be rendered in the centre + _this.viewportColumnsCenter = []; + _this.autoHeightActiveAtLeastOnce = false; + _this.rowGroupColumns = []; + _this.valueColumns = []; + _this.pivotColumns = []; + _this.ready = false; + _this.autoGroupsNeedBuilding = false; + _this.forceRecreateAutoGroups = false; + _this.pivotMode = false; + _this.bodyWidth = 0; + _this.leftWidth = 0; + _this.rightWidth = 0; + _this.bodyWidthDirty = true; + _this.colDefVersion = 0; + _this.flexColsCalculatedAtLestOnce = false; + return _this; + } + ColumnModel.prototype.init = function () { + var _this = this; + this.suppressColumnVirtualisation = this.gridOptionsWrapper.isSuppressColumnVirtualisation(); + var pivotMode = this.gridOptionsWrapper.isPivotMode(); + if (this.isPivotSettingAllowed(pivotMode)) { + this.pivotMode = pivotMode; + } + this.usingTreeData = this.gridOptionsWrapper.isTreeData(); + this.addManagedListener(this.gridOptionsWrapper, 'autoGroupColumnDef', function () { return _this.onAutoGroupColumnDefChanged(); }); + this.addManagedListener(this.gridOptionsWrapper, 'defaultColDef', function () { return _this.onDefaultColDefChanged(); }); + }; + ColumnModel.prototype.onAutoGroupColumnDefChanged = function () { + this.autoGroupsNeedBuilding = true; + this.forceRecreateAutoGroups = true; + this.updateGridColumns(); + this.updateDisplayedColumns('gridOptionsChanged'); + }; + ColumnModel.prototype.onDefaultColDefChanged = function () { + // col def's should get revisited, even if specific column hasn't changed, + // as the defaultColDef impacts all columns, so each column should assume it's Col Def has changed. + this.colDefVersion++; + // likewise for autoGroupCol, the default col def impacts this + this.forceRecreateAutoGroups = true; + this.createColumnsFromColumnDefs(true); + }; + ColumnModel.prototype.getColDefVersion = function () { + return this.colDefVersion; + }; + ColumnModel.prototype.setColumnDefs = function (columnDefs, source) { + if (source === void 0) { source = 'api'; } + var colsPreviouslyExisted = !!this.columnDefs; + this.colDefVersion++; + this.columnDefs = columnDefs; + this.createColumnsFromColumnDefs(colsPreviouslyExisted, source); + }; + ColumnModel.prototype.createColumnsFromColumnDefs = function (colsPreviouslyExisted, source) { + var _this = this; + if (source === void 0) { source = 'api'; } + // only need to raise before/after events if updating columns, never if setting columns for first time + var raiseEventsFunc = colsPreviouslyExisted ? this.compareColumnStatesAndRaiseEvents(source) : undefined; + // always invalidate cache on changing columns, as the column id's for the new columns + // could overlap with the old id's, so the cache would return old values for new columns. + this.valueCache.expire(); + // NOTE ================== + // we should be destroying the existing columns and groups if they exist, for example, the original column + // group adds a listener to the columns, it should be also removing the listeners + this.autoGroupsNeedBuilding = true; + var oldPrimaryColumns = this.primaryColumns; + var oldPrimaryTree = this.primaryColumnTree; + var balancedTreeResult = this.columnFactory.createColumnTree(this.columnDefs, true, oldPrimaryTree); + this.primaryColumnTree = balancedTreeResult.columnTree; + this.primaryHeaderRowCount = balancedTreeResult.treeDept + 1; + this.primaryColumns = this.getColumnsFromTree(this.primaryColumnTree); + this.primaryColumnsMap = {}; + this.primaryColumns.forEach(function (col) { return _this.primaryColumnsMap[col.getId()] = col; }); + this.extractRowGroupColumns(source, oldPrimaryColumns); + this.extractPivotColumns(source, oldPrimaryColumns); + this.extractValueColumns(source, oldPrimaryColumns); + this.ready = true; + // if we are showing secondary columns, then no need to update grid columns + // at this point, as it's the pivot service responsibility to change these + // if we are no longer pivoting (ie and need to revert back to primary, otherwise + // we shouldn't be touching the primary). + var gridColsNotProcessed = this.gridColsArePrimary === undefined; + var processGridCols = this.gridColsArePrimary || gridColsNotProcessed; + if (processGridCols) { + this.updateGridColumns(); + if (colsPreviouslyExisted && !this.gridOptionsWrapper.isMaintainColumnOrder()) { + this.orderGridColumnsLikePrimary(); + } + this.updateDisplayedColumns(source); + this.checkViewportColumns(); + } + // this event is not used by AG Grid, but left here for backwards compatibility, + // in case applications use it + this.dispatchEverythingChanged(source); + raiseEventsFunc && raiseEventsFunc(); + this.dispatchNewColumnsLoaded(); + }; + ColumnModel.prototype.dispatchNewColumnsLoaded = function () { + var newColumnsLoadedEvent = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_NEW_COLUMNS_LOADED, + api: this.gridApi, + columnApi: this.columnApi + }; + this.eventService.dispatchEvent(newColumnsLoadedEvent); + }; + // this event is legacy, no grid code listens to it. instead the grid listens to New Columns Loaded + ColumnModel.prototype.dispatchEverythingChanged = function (source) { + if (source === void 0) { source = 'api'; } + var eventEverythingChanged = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_EVERYTHING_CHANGED, + api: this.gridApi, + columnApi: this.columnApi, + source: source + }; + this.eventService.dispatchEvent(eventEverythingChanged); + }; + ColumnModel.prototype.orderGridColumnsLikePrimary = function () { + var _this = this; + var primaryColumns = this.primaryColumns; + if (!primaryColumns) { + return; + } + this.gridColumns.sort(function (colA, colB) { + var primaryIndexA = primaryColumns.indexOf(colA); + var primaryIndexB = primaryColumns.indexOf(colB); + // if both cols are present in primary, then we just return the position, + // so position is maintained. + var indexAPresent = primaryIndexA >= 0; + var indexBPresent = primaryIndexB >= 0; + if (indexAPresent && indexBPresent) { + return primaryIndexA - primaryIndexB; + } + if (indexAPresent) { + // B is auto group column, so put B first + return 1; + } + if (indexBPresent) { + // A is auto group column, so put A first + return -1; + } + // otherwise both A and B are auto-group columns. so we just keep the order + // as they were already in. + var gridIndexA = _this.gridColumns.indexOf(colA); + var gridIndexB = _this.gridColumns.indexOf(colB); + return gridIndexA - gridIndexB; + }); + }; + ColumnModel.prototype.getAllDisplayedAutoHeightCols = function () { + return this.displayedAutoHeightCols; + }; + ColumnModel.prototype.setViewport = function () { + if (this.gridOptionsWrapper.isEnableRtl()) { + this.viewportLeft = this.bodyWidth - this.scrollPosition - this.scrollWidth; + this.viewportRight = this.bodyWidth - this.scrollPosition; + } + else { + this.viewportLeft = this.scrollPosition; + this.viewportRight = this.scrollWidth + this.scrollPosition; + } + }; + // used by clipboard service, to know what columns to paste into + ColumnModel.prototype.getDisplayedColumnsStartingAt = function (column) { + var currentColumn = column; + var columns = []; + while (currentColumn != null) { + columns.push(currentColumn); + currentColumn = this.getDisplayedColAfter(currentColumn); + } + return columns; + }; + // checks what columns are currently displayed due to column virtualisation. fires an event + // if the list of columns has changed. + // + setColumnWidth(), setViewportPosition(), setColumnDefs(), sizeColumnsToFit() + ColumnModel.prototype.checkViewportColumns = function () { + // check displayCenterColumnTree exists first, as it won't exist when grid is initialising + if (this.displayedColumnsCenter == null) { + return; + } + var hashBefore = this.viewportColumns.map(function (column) { return column.getId(); }).join('#'); + this.extractViewport(); + var hashAfter = this.viewportColumns.map(function (column) { return column.getId(); }).join('#'); + if (hashBefore !== hashAfter) { + var event_1 = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_VIRTUAL_COLUMNS_CHANGED, + api: this.gridApi, + columnApi: this.columnApi + }; + this.eventService.dispatchEvent(event_1); + } + }; + ColumnModel.prototype.setViewportPosition = function (scrollWidth, scrollPosition) { + if (scrollWidth !== this.scrollWidth || scrollPosition !== this.scrollPosition || this.bodyWidthDirty) { + this.scrollWidth = scrollWidth; + this.scrollPosition = scrollPosition; + // we need to call setVirtualViewportLeftAndRight() at least once after the body width changes, + // as the viewport can stay the same, but in RTL, if body width changes, we need to work out the + // virtual columns again + this.bodyWidthDirty = true; + this.setViewport(); + if (this.ready) { + this.checkViewportColumns(); + } + } + }; + ColumnModel.prototype.isPivotMode = function () { + return this.pivotMode; + }; + ColumnModel.prototype.isPivotSettingAllowed = function (pivot) { + if (pivot && this.gridOptionsWrapper.isTreeData()) { + console.warn("AG Grid: Pivot mode not available in conjunction Tree Data i.e. 'gridOptions.treeData: true'"); + return false; + } + return true; + }; + ColumnModel.prototype.setPivotMode = function (pivotMode, source) { + if (source === void 0) { source = 'api'; } + if (pivotMode === this.pivotMode || !this.isPivotSettingAllowed(this.pivotMode)) { + return; + } + this.pivotMode = pivotMode; + // we need to update grid columns to cover the scenario where user has groupSuppressAutoColumn=true, as + // this means we don't use auto group column UNLESS we are in pivot mode (it's mandatory in pivot mode), + // so need to updateGridColumn() to check it autoGroupCol needs to be added / removed + this.autoGroupsNeedBuilding = true; + this.updateGridColumns(); + this.updateDisplayedColumns(source); + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_MODE_CHANGED, + api: this.gridApi, + columnApi: this.columnApi + }; + this.eventService.dispatchEvent(event); + }; + ColumnModel.prototype.getSecondaryPivotColumn = function (pivotKeys, valueColKey) { + if (!this.secondaryColumnsPresent || !this.secondaryColumns) { + return null; + } + var valueColumnToFind = this.getPrimaryColumn(valueColKey); + var foundColumn = null; + this.secondaryColumns.forEach(function (column) { + var thisPivotKeys = column.getColDef().pivotKeys; + var pivotValueColumn = column.getColDef().pivotValueColumn; + var pivotKeyMatches = Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["areEqual"])(thisPivotKeys, pivotKeys); + var pivotValueMatches = pivotValueColumn === valueColumnToFind; + if (pivotKeyMatches && pivotValueMatches) { + foundColumn = column; + } + }); + return foundColumn; + }; + ColumnModel.prototype.setBeans = function (loggerFactory) { + this.logger = loggerFactory.create('columnModel'); + }; + ColumnModel.prototype.setFirstRightAndLastLeftPinned = function (source) { + var lastLeft; + var firstRight; + if (this.gridOptionsWrapper.isEnableRtl()) { + lastLeft = this.displayedColumnsLeft ? this.displayedColumnsLeft[0] : null; + firstRight = this.displayedColumnsRight ? Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["last"])(this.displayedColumnsRight) : null; + } + else { + lastLeft = this.displayedColumnsLeft ? Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["last"])(this.displayedColumnsLeft) : null; + firstRight = this.displayedColumnsRight ? this.displayedColumnsRight[0] : null; + } + this.gridColumns.forEach(function (column) { + column.setLastLeftPinned(column === lastLeft, source); + column.setFirstRightPinned(column === firstRight, source); + }); + }; + ColumnModel.prototype.autoSizeColumns = function (params) { + var _this = this; + var columns = params.columns, skipHeader = params.skipHeader, skipHeaderGroups = params.skipHeaderGroups, stopAtGroup = params.stopAtGroup, _a = params.source, source = _a === void 0 ? 'api' : _a; + // because of column virtualisation, we can only do this function on columns that are + // actually rendered, as non-rendered columns (outside the viewport and not rendered + // due to column virtualisation) are not present. this can result in all rendered columns + // getting narrowed, which in turn introduces more rendered columns on the RHS which + // did not get autosized in the original run, leaving the visible grid with columns on + // the LHS sized, but RHS no. so we keep looping through the visible columns until + // no more cols are available (rendered) to be resized + // we autosize after animation frames finish in case any cell renderers need to complete first. this can + // happen eg if client code is calling api.autoSizeAllColumns() straight after grid is initialised, but grid + // hasn't fully drawn out all the cells yet (due to cell renderers in animation frames). + this.animationFrameService.flushAllFrames(); + // keep track of which cols we have resized in here + var columnsAutosized = []; + // initialise with anything except 0 so that while loop executes at least once + var changesThisTimeAround = -1; + var shouldSkipHeader = skipHeader != null ? skipHeader : this.gridOptionsWrapper.isSkipHeaderOnAutoSize(); + var shouldSkipHeaderGroups = skipHeaderGroups != null ? skipHeaderGroups : shouldSkipHeader; + while (changesThisTimeAround !== 0) { + changesThisTimeAround = 0; + this.actionOnGridColumns(columns, function (column) { + // if already autosized, skip it + if (columnsAutosized.indexOf(column) >= 0) { + return false; + } + // get how wide this col should be + var preferredWidth = _this.autoWidthCalculator.getPreferredWidthForColumn(column, shouldSkipHeader); + // preferredWidth = -1 if this col is not on the screen + if (preferredWidth > 0) { + var newWidth = _this.normaliseColumnWidth(column, preferredWidth); + column.setActualWidth(newWidth, source); + columnsAutosized.push(column); + changesThisTimeAround++; + } + return true; + }, source); + } + if (!shouldSkipHeaderGroups) { + this.autoSizeColumnGroupsByColumns(columns, stopAtGroup); + } + this.fireColumnResizedEvent(columnsAutosized, true, 'autosizeColumns'); + }; + ColumnModel.prototype.fireColumnResizedEvent = function (columns, finished, source, flexColumns) { + if (flexColumns === void 0) { flexColumns = null; } + if (columns && columns.length) { + var event_2 = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_RESIZED, + columns: columns, + column: columns.length === 1 ? columns[0] : null, + flexColumns: flexColumns, + finished: finished, + api: this.gridApi, + columnApi: this.columnApi, + source: source + }; + this.eventService.dispatchEvent(event_2); + } + }; + ColumnModel.prototype.autoSizeColumn = function (key, skipHeader, source) { + if (source === void 0) { source = "api"; } + if (key) { + this.autoSizeColumns({ columns: [key], skipHeader: skipHeader, skipHeaderGroups: true, source: source }); + } + }; + ColumnModel.prototype.autoSizeColumnGroupsByColumns = function (keys, stopAtGroup) { + var e_1, _a, e_2, _b; + var columnGroups = new Set(); + var columns = this.getGridColumns(keys); + columns.forEach(function (col) { + var parent = col.getParent(); + while (parent && parent != stopAtGroup) { + if (!parent.isPadding()) { + columnGroups.add(parent); + } + parent = parent.getParent(); + } + }); + var headerGroupCtrl; + var resizedColumns = []; + try { + for (var columnGroups_1 = __values(columnGroups), columnGroups_1_1 = columnGroups_1.next(); !columnGroups_1_1.done; columnGroups_1_1 = columnGroups_1.next()) { + var columnGroup = columnGroups_1_1.value; + try { + for (var _c = (e_2 = void 0, __values(this.ctrlsService.getHeaderRowContainerCtrls())), _d = _c.next(); !_d.done; _d = _c.next()) { + var headerContainerCtrl = _d.value; + headerGroupCtrl = headerContainerCtrl.getHeaderCtrlForColumn(columnGroup); + if (headerGroupCtrl) { + break; + } + } + } + catch (e_2_1) { e_2 = { error: e_2_1 }; } + finally { + try { + if (_d && !_d.done && (_b = _c.return)) _b.call(_c); + } + finally { if (e_2) throw e_2.error; } + } + if (headerGroupCtrl) { + headerGroupCtrl.resizeLeafColumnsToFit(); + } + } + } + catch (e_1_1) { e_1 = { error: e_1_1 }; } + finally { + try { + if (columnGroups_1_1 && !columnGroups_1_1.done && (_a = columnGroups_1.return)) _a.call(columnGroups_1); + } + finally { if (e_1) throw e_1.error; } + } + return resizedColumns; + }; + ColumnModel.prototype.autoSizeAllColumns = function (skipHeader, source) { + if (source === void 0) { source = "api"; } + var allDisplayedColumns = this.getAllDisplayedColumns(); + this.autoSizeColumns({ columns: allDisplayedColumns, skipHeader: skipHeader, source: source }); + }; + ColumnModel.prototype.getColumnsFromTree = function (rootColumns) { + var result = []; + var recursiveFindColumns = function (childColumns) { + for (var i = 0; i < childColumns.length; i++) { + var child = childColumns[i]; + if (child instanceof _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"]) { + result.push(child); + } + else if (child instanceof _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_4__["ProvidedColumnGroup"]) { + recursiveFindColumns(child.getChildren()); + } + } + }; + recursiveFindColumns(rootColumns); + return result; + }; + ColumnModel.prototype.getAllDisplayedTrees = function () { + if (this.displayedTreeLeft && this.displayedTreeRight && this.displayedTreeCentre) { + return this.displayedTreeLeft + .concat(this.displayedTreeCentre) + .concat(this.displayedTreeRight); + } + return null; + }; + // + columnSelectPanel + ColumnModel.prototype.getPrimaryColumnTree = function () { + return this.primaryColumnTree; + }; + // + gridPanel -> for resizing the body and setting top margin + ColumnModel.prototype.getHeaderRowCount = function () { + return this.gridHeaderRowCount; + }; + // + headerRenderer -> setting pinned body width + ColumnModel.prototype.getDisplayedTreeLeft = function () { + return this.displayedTreeLeft; + }; + // + headerRenderer -> setting pinned body width + ColumnModel.prototype.getDisplayedTreeRight = function () { + return this.displayedTreeRight; + }; + // + headerRenderer -> setting pinned body width + ColumnModel.prototype.getDisplayedTreeCentre = function () { + return this.displayedTreeCentre; + }; + // gridPanel -> ensureColumnVisible + ColumnModel.prototype.isColumnDisplayed = function (column) { + return this.getAllDisplayedColumns().indexOf(column) >= 0; + }; + // + csvCreator + ColumnModel.prototype.getAllDisplayedColumns = function () { + return this.displayedColumns; + }; + ColumnModel.prototype.getViewportColumns = function () { + return this.viewportColumns; + }; + ColumnModel.prototype.getDisplayedLeftColumnsForRow = function (rowNode) { + if (!this.colSpanActive) { + return this.displayedColumnsLeft; + } + return this.getDisplayedColumnsForRow(rowNode, this.displayedColumnsLeft); + }; + ColumnModel.prototype.getDisplayedRightColumnsForRow = function (rowNode) { + if (!this.colSpanActive) { + return this.displayedColumnsRight; + } + return this.getDisplayedColumnsForRow(rowNode, this.displayedColumnsRight); + }; + ColumnModel.prototype.getDisplayedColumnsForRow = function (rowNode, displayedColumns, filterCallback, emptySpaceBeforeColumn) { + var result = []; + var lastConsideredCol = null; + var _loop_1 = function (i) { + var col = displayedColumns[i]; + var maxAllowedColSpan = displayedColumns.length - i; + var colSpan = Math.min(col.getColSpan(rowNode), maxAllowedColSpan); + var columnsToCheckFilter = [col]; + if (colSpan > 1) { + var colsToRemove = colSpan - 1; + for (var j = 1; j <= colsToRemove; j++) { + columnsToCheckFilter.push(displayedColumns[i + j]); + } + i += colsToRemove; + } + // see which cols we should take out for column virtualisation + var filterPasses; + if (filterCallback) { + // if user provided a callback, means some columns may not be in the viewport. + // the user will NOT provide a callback if we are talking about pinned areas, + // as pinned areas have no horizontal scroll and do not virtualise the columns. + // if lots of columns, that means column spanning, and we set filterPasses = true + // if one or more of the columns spanned pass the filter. + filterPasses = false; + columnsToCheckFilter.forEach(function (colForFilter) { + if (filterCallback(colForFilter)) { + filterPasses = true; + } + }); + } + else { + filterPasses = true; + } + if (filterPasses) { + if (result.length === 0 && lastConsideredCol) { + var gapBeforeColumn = emptySpaceBeforeColumn ? emptySpaceBeforeColumn(col) : false; + if (gapBeforeColumn) { + result.push(lastConsideredCol); + } + } + result.push(col); + } + lastConsideredCol = col; + out_i_1 = i; + }; + var out_i_1; + for (var i = 0; i < displayedColumns.length; i++) { + _loop_1(i); + i = out_i_1; + } + return result; + }; + // + rowRenderer + // if we are not column spanning, this just returns back the virtual centre columns, + // however if we are column spanning, then different rows can have different virtual + // columns, so we have to work out the list for each individual row. + ColumnModel.prototype.getViewportCenterColumnsForRow = function (rowNode) { + var _this = this; + if (!this.colSpanActive) { + return this.viewportColumnsCenter; + } + var emptySpaceBeforeColumn = function (col) { + var left = col.getLeft(); + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(left) && left > _this.viewportLeft; + }; + // if doing column virtualisation, then we filter based on the viewport. + var filterCallback = this.suppressColumnVirtualisation ? null : this.isColumnInViewport.bind(this); + return this.getDisplayedColumnsForRow(rowNode, this.displayedColumnsCenter, filterCallback, emptySpaceBeforeColumn); + }; + ColumnModel.prototype.getAriaColumnIndex = function (col) { + return this.getAllGridColumns().indexOf(col) + 1; + }; + ColumnModel.prototype.isColumnInViewport = function (col) { + // we never filter out autoHeight columns, as we need them in the DOM for calculating Auto Height + if (col.isAutoHeight()) { + return true; + } + var columnLeft = col.getLeft() || 0; + var columnRight = columnLeft + col.getActualWidth(); + // adding 200 for buffer size, so some cols off viewport are rendered. + // this helps horizontal scrolling so user rarely sees white space (unless + // they scroll horizontally fast). however we are conservative, as the more + // buffer the slower the vertical redraw speed + var leftBounds = this.viewportLeft - 200; + var rightBounds = this.viewportRight + 200; + var columnToMuchLeft = columnLeft < leftBounds && columnRight < leftBounds; + var columnToMuchRight = columnLeft > rightBounds && columnRight > rightBounds; + return !columnToMuchLeft && !columnToMuchRight; + }; + // used by: + // + angularGrid -> setting pinned body width + // note: this should be cached + ColumnModel.prototype.getDisplayedColumnsLeftWidth = function () { + return this.getWidthOfColsInList(this.displayedColumnsLeft); + }; + // note: this should be cached + ColumnModel.prototype.getDisplayedColumnsRightWidth = function () { + return this.getWidthOfColsInList(this.displayedColumnsRight); + }; + ColumnModel.prototype.updatePrimaryColumnList = function (keys, masterList, actionIsAdd, columnCallback, eventType, source) { + var _this = this; + if (source === void 0) { source = "api"; } + if (!keys || Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missingOrEmpty"])(keys)) { + return; + } + var atLeastOne = false; + keys.forEach(function (key) { + var columnToAdd = _this.getPrimaryColumn(key); + if (!columnToAdd) { + return; + } + if (actionIsAdd) { + if (masterList.indexOf(columnToAdd) >= 0) { + return; + } + masterList.push(columnToAdd); + } + else { + if (masterList.indexOf(columnToAdd) < 0) { + return; + } + Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["removeFromArray"])(masterList, columnToAdd); + } + columnCallback(columnToAdd); + atLeastOne = true; + }); + if (!atLeastOne) { + return; + } + if (this.autoGroupsNeedBuilding) { + this.updateGridColumns(); + } + this.updateDisplayedColumns(source); + var event = { + type: eventType, + columns: masterList, + column: masterList.length === 1 ? masterList[0] : null, + api: this.gridApi, + columnApi: this.columnApi, + source: source + }; + this.eventService.dispatchEvent(event); + }; + ColumnModel.prototype.setRowGroupColumns = function (colKeys, source) { + if (source === void 0) { source = "api"; } + this.autoGroupsNeedBuilding = true; + this.setPrimaryColumnList(colKeys, this.rowGroupColumns, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, this.setRowGroupActive.bind(this), source); + }; + ColumnModel.prototype.setRowGroupActive = function (active, column, source) { + if (active === column.isRowGroupActive()) { + return; + } + column.setRowGroupActive(active, source); + if (!active && !this.gridOptionsWrapper.isSuppressMakeColumnVisibleAfterUnGroup()) { + column.setVisible(true, source); + } + }; + ColumnModel.prototype.addRowGroupColumn = function (key, source) { + if (source === void 0) { source = "api"; } + if (key) { + this.addRowGroupColumns([key], source); + } + }; + ColumnModel.prototype.addRowGroupColumns = function (keys, source) { + if (source === void 0) { source = "api"; } + this.autoGroupsNeedBuilding = true; + this.updatePrimaryColumnList(keys, this.rowGroupColumns, true, this.setRowGroupActive.bind(this, true), _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, source); + }; + ColumnModel.prototype.removeRowGroupColumns = function (keys, source) { + if (source === void 0) { source = "api"; } + this.autoGroupsNeedBuilding = true; + this.updatePrimaryColumnList(keys, this.rowGroupColumns, false, this.setRowGroupActive.bind(this, false), _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, source); + }; + ColumnModel.prototype.removeRowGroupColumn = function (key, source) { + if (source === void 0) { source = "api"; } + if (key) { + this.removeRowGroupColumns([key], source); + } + }; + ColumnModel.prototype.addPivotColumns = function (keys, source) { + if (source === void 0) { source = "api"; } + this.updatePrimaryColumnList(keys, this.pivotColumns, true, function (column) { return column.setPivotActive(true, source); }, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_CHANGED, source); + }; + ColumnModel.prototype.setPivotColumns = function (colKeys, source) { + if (source === void 0) { source = "api"; } + this.setPrimaryColumnList(colKeys, this.pivotColumns, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_CHANGED, function (added, column) { + column.setPivotActive(added, source); + }, source); + }; + ColumnModel.prototype.addPivotColumn = function (key, source) { + if (source === void 0) { source = "api"; } + this.addPivotColumns([key], source); + }; + ColumnModel.prototype.removePivotColumns = function (keys, source) { + if (source === void 0) { source = "api"; } + this.updatePrimaryColumnList(keys, this.pivotColumns, false, function (column) { return column.setPivotActive(false, source); }, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_CHANGED, source); + }; + ColumnModel.prototype.removePivotColumn = function (key, source) { + if (source === void 0) { source = "api"; } + this.removePivotColumns([key], source); + }; + ColumnModel.prototype.setPrimaryColumnList = function (colKeys, masterList, eventName, columnCallback, source) { + var _this = this; + masterList.length = 0; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(colKeys)) { + colKeys.forEach(function (key) { + var column = _this.getPrimaryColumn(key); + if (column) { + masterList.push(column); + } + }); + } + (this.primaryColumns || []).forEach(function (column) { + var added = masterList.indexOf(column) >= 0; + columnCallback(added, column); + }); + if (this.autoGroupsNeedBuilding) { + this.updateGridColumns(); + } + this.updateDisplayedColumns(source); + this.fireColumnEvent(eventName, masterList, source); + }; + ColumnModel.prototype.setValueColumns = function (colKeys, source) { + if (source === void 0) { source = "api"; } + this.setPrimaryColumnList(colKeys, this.valueColumns, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VALUE_CHANGED, this.setValueActive.bind(this), source); + }; + ColumnModel.prototype.setValueActive = function (active, column, source) { + if (active === column.isValueActive()) { + return; + } + column.setValueActive(active, source); + if (active && !column.getAggFunc()) { + var initialAggFunc = this.aggFuncService.getDefaultAggFunc(column); + column.setAggFunc(initialAggFunc); + } + }; + ColumnModel.prototype.addValueColumns = function (keys, source) { + if (source === void 0) { source = "api"; } + this.updatePrimaryColumnList(keys, this.valueColumns, true, this.setValueActive.bind(this, true), _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VALUE_CHANGED, source); + }; + ColumnModel.prototype.addValueColumn = function (colKey, source) { + if (source === void 0) { source = "api"; } + if (colKey) { + this.addValueColumns([colKey], source); + } + }; + ColumnModel.prototype.removeValueColumn = function (colKey, source) { + if (source === void 0) { source = "api"; } + this.removeValueColumns([colKey], source); + }; + ColumnModel.prototype.removeValueColumns = function (keys, source) { + if (source === void 0) { source = "api"; } + this.updatePrimaryColumnList(keys, this.valueColumns, false, this.setValueActive.bind(this, false), _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VALUE_CHANGED, source); + }; + // returns the width we can set to this col, taking into consideration min and max widths + ColumnModel.prototype.normaliseColumnWidth = function (column, newWidth) { + var minWidth = column.getMinWidth(); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(minWidth) && newWidth < minWidth) { + newWidth = minWidth; + } + var maxWidth = column.getMaxWidth(); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(maxWidth) && column.isGreaterThanMax(newWidth)) { + newWidth = maxWidth; + } + return newWidth; + }; + ColumnModel.prototype.getPrimaryOrGridColumn = function (key) { + var column = this.getPrimaryColumn(key); + return column || this.getGridColumn(key); + }; + ColumnModel.prototype.setColumnWidths = function (columnWidths, shiftKey, // @takeFromAdjacent - if user has 'shift' pressed, then pixels are taken from adjacent column + finished, // @finished - ends up in the event, tells the user if more events are to come + source) { + var _this = this; + if (source === void 0) { source = "api"; } + var sets = []; + columnWidths.forEach(function (columnWidth) { + var col = _this.getPrimaryOrGridColumn(columnWidth.key); + if (!col) { + return; + } + sets.push({ + width: columnWidth.newWidth, + ratios: [1], + columns: [col] + }); + // if user wants to do shift resize by default, then we invert the shift operation + var defaultIsShift = _this.gridOptionsWrapper.getColResizeDefault() === 'shift'; + if (defaultIsShift) { + shiftKey = !shiftKey; + } + if (shiftKey) { + var otherCol = _this.getDisplayedColAfter(col); + if (!otherCol) { + return; + } + var widthDiff = col.getActualWidth() - columnWidth.newWidth; + var otherColWidth = otherCol.getActualWidth() + widthDiff; + sets.push({ + width: otherColWidth, + ratios: [1], + columns: [otherCol] + }); + } + }); + if (sets.length === 0) { + return; + } + this.resizeColumnSets({ + resizeSets: sets, + finished: finished, + source: source + }); + }; + ColumnModel.prototype.checkMinAndMaxWidthsForSet = function (columnResizeSet) { + var columns = columnResizeSet.columns, width = columnResizeSet.width; + // every col has a min width, so sum them all up and see if we have enough room + // for all the min widths + var minWidthAccumulated = 0; + var maxWidthAccumulated = 0; + var maxWidthActive = true; + columns.forEach(function (col) { + var minWidth = col.getMinWidth(); + minWidthAccumulated += minWidth || 0; + var maxWidth = col.getMaxWidth(); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(maxWidth) && maxWidth > 0) { + maxWidthAccumulated += maxWidth; + } + else { + // if at least one columns has no max width, it means the group of columns + // then has no max width, as at least one column can take as much width as possible + maxWidthActive = false; + } + }); + var minWidthPasses = width >= minWidthAccumulated; + var maxWidthPasses = !maxWidthActive || (width <= maxWidthAccumulated); + return minWidthPasses && maxWidthPasses; + }; + // method takes sets of columns and resizes them. either all sets will be resized, or nothing + // be resized. this is used for example when user tries to resize a group and holds shift key, + // then both the current group (grows), and the adjacent group (shrinks), will get resized, + // so that's two sets for this method. + ColumnModel.prototype.resizeColumnSets = function (params) { + var _this = this; + var resizeSets = params.resizeSets, finished = params.finished, source = params.source; + var passMinMaxCheck = !resizeSets || resizeSets.every(function (columnResizeSet) { return _this.checkMinAndMaxWidthsForSet(columnResizeSet); }); + if (!passMinMaxCheck) { + // even though we are not going to resize beyond min/max size, we still need to raise event when finished + if (finished) { + var columns = resizeSets && resizeSets.length > 0 ? resizeSets[0].columns : null; + this.fireColumnResizedEvent(columns, finished, source); + } + return; // don't resize! + } + var changedCols = []; + var allResizedCols = []; + resizeSets.forEach(function (set) { + var width = set.width, columns = set.columns, ratios = set.ratios; + // keep track of pixels used, and last column gets the remaining, + // to cater for rounding errors, and min width adjustments + var newWidths = {}; + var finishedCols = {}; + columns.forEach(function (col) { return allResizedCols.push(col); }); + // the loop below goes through each col. if a col exceeds it's min/max width, + // it then gets set to its min/max width and the column is removed marked as 'finished' + // and the calculation is done again leaving this column out. take for example columns + // {A, width: 50, maxWidth: 100} + // {B, width: 50} + // {C, width: 50} + // and then the set is set to width 600 - on the first pass the grid tries to set each column + // to 200. it checks A and sees 200 > 100 and so sets the width to 100. col A is then marked + // as 'finished' and the calculation is done again with the remaining cols B and C, which end up + // splitting the remaining 500 pixels. + var finishedColsGrew = true; + var loopCount = 0; + var _loop_2 = function () { + loopCount++; + if (loopCount > 1000) { + // this should never happen, but in the future, someone might introduce a bug here, + // so we stop the browser from hanging and report bug properly + console.error('AG Grid: infinite loop in resizeColumnSets'); + return "break"; + } + finishedColsGrew = false; + var subsetCols = []; + var subsetRatioTotal = 0; + var pixelsToDistribute = width; + columns.forEach(function (col, index) { + var thisColFinished = finishedCols[col.getId()]; + if (thisColFinished) { + pixelsToDistribute -= newWidths[col.getId()]; + } + else { + subsetCols.push(col); + var ratioThisCol = ratios[index]; + subsetRatioTotal += ratioThisCol; + } + }); + // because we are not using all of the ratios (cols can be missing), + // we scale the ratio. if all columns are included, then subsetRatioTotal=1, + // and so the ratioScale will be 1. + var ratioScale = 1 / subsetRatioTotal; + subsetCols.forEach(function (col, index) { + var lastCol = index === (subsetCols.length - 1); + var colNewWidth; + if (lastCol) { + colNewWidth = pixelsToDistribute; + } + else { + colNewWidth = Math.round(ratios[index] * width * ratioScale); + pixelsToDistribute -= colNewWidth; + } + var minWidth = col.getMinWidth(); + var maxWidth = col.getMaxWidth(); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(minWidth) && colNewWidth < minWidth) { + colNewWidth = minWidth; + finishedCols[col.getId()] = true; + finishedColsGrew = true; + } + else if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(maxWidth) && maxWidth > 0 && colNewWidth > maxWidth) { + colNewWidth = maxWidth; + finishedCols[col.getId()] = true; + finishedColsGrew = true; + } + newWidths[col.getId()] = colNewWidth; + }); + }; + while (finishedColsGrew) { + var state_1 = _loop_2(); + if (state_1 === "break") + break; + } + columns.forEach(function (col) { + var newWidth = newWidths[col.getId()]; + var actualWidth = col.getActualWidth(); + if (actualWidth !== newWidth) { + col.setActualWidth(newWidth, source); + changedCols.push(col); + } + }); + }); + // if no cols changed, then no need to update more or send event. + var atLeastOneColChanged = changedCols.length > 0; + var flexedCols = this.refreshFlexedColumns({ resizingCols: allResizedCols, skipSetLeft: true }); + if (atLeastOneColChanged) { + this.setLeftValues(source); + this.updateBodyWidths(); + this.checkViewportColumns(); + } + // check for change first, to avoid unnecessary firing of events + // however we always fire 'finished' events. this is important + // when groups are resized, as if the group is changing slowly, + // eg 1 pixel at a time, then each change will fire change events + // in all the columns in the group, but only one with get the pixel. + var colsForEvent = allResizedCols.concat(flexedCols); + if (atLeastOneColChanged || finished) { + this.fireColumnResizedEvent(colsForEvent, finished, source, flexedCols); + } + }; + ColumnModel.prototype.setColumnAggFunc = function (key, aggFunc, source) { + if (source === void 0) { source = "api"; } + if (!key) { + return; + } + var column = this.getPrimaryColumn(key); + if (!column) { + return; + } + column.setAggFunc(aggFunc); + this.fireColumnEvent(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VALUE_CHANGED, [column], source); + }; + ColumnModel.prototype.fireColumnEvent = function (type, columns, source) { + var event = { + type: type, + columns: columns, + column: (columns && columns.length == 1) ? columns[0] : null, + api: this.gridApi, + columnApi: this.columnApi, + source: source + }; + this.eventService.dispatchEvent(event); + }; + ColumnModel.prototype.moveRowGroupColumn = function (fromIndex, toIndex, source) { + if (source === void 0) { source = "api"; } + var column = this.rowGroupColumns[fromIndex]; + this.rowGroupColumns.splice(fromIndex, 1); + this.rowGroupColumns.splice(toIndex, 0, column); + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, + columns: this.rowGroupColumns, + column: this.rowGroupColumns.length === 1 ? this.rowGroupColumns[0] : null, + api: this.gridApi, + columnApi: this.columnApi, + source: source + }; + this.eventService.dispatchEvent(event); + }; + ColumnModel.prototype.moveColumns = function (columnsToMoveKeys, toIndex, source) { + if (source === void 0) { source = "api"; } + this.columnAnimationService.start(); + if (toIndex > this.gridColumns.length - columnsToMoveKeys.length) { + console.warn('AG Grid: tried to insert columns in invalid location, toIndex = ' + toIndex); + console.warn('AG Grid: remember that you should not count the moving columns when calculating the new index'); + return; + } + // we want to pull all the columns out first and put them into an ordered list + var columnsToMove = this.getGridColumns(columnsToMoveKeys); + var failedRules = !this.doesMovePassRules(columnsToMove, toIndex); + if (failedRules) { + return; + } + Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["moveInArray"])(this.gridColumns, columnsToMove, toIndex); + this.updateDisplayedColumns(source); + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_MOVED, + columns: columnsToMove, + column: columnsToMove.length === 1 ? columnsToMove[0] : null, + toIndex: toIndex, + api: this.gridApi, + columnApi: this.columnApi, + source: source + }; + this.eventService.dispatchEvent(event); + this.columnAnimationService.finish(); + }; + ColumnModel.prototype.doesMovePassRules = function (columnsToMove, toIndex) { + // make a copy of what the grid columns would look like after the move + var proposedColumnOrder = this.gridColumns.slice(); + Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["moveInArray"])(proposedColumnOrder, columnsToMove, toIndex); + // then check that the new proposed order of the columns passes all rules + if (!this.doesMovePassMarryChildren(proposedColumnOrder)) { + return false; + } + if (!this.doesMovePassLockedPositions(proposedColumnOrder)) { + return false; + } + return true; + }; + // returns the provided cols sorted in same order as they appear in grid columns. eg if grid columns + // contains [a,b,c,d,e] and col passed is [e,a] then the passed cols are sorted into [a,e] + ColumnModel.prototype.sortColumnsLikeGridColumns = function (cols) { + var _this = this; + if (!cols || cols.length <= 1) { + return; + } + var notAllColsInGridColumns = cols.filter(function (c) { return _this.gridColumns.indexOf(c) < 0; }).length > 0; + if (notAllColsInGridColumns) { + return; + } + cols.sort(function (a, b) { + var indexA = _this.gridColumns.indexOf(a); + var indexB = _this.gridColumns.indexOf(b); + return indexA - indexB; + }); + }; + ColumnModel.prototype.doesMovePassLockedPositions = function (proposedColumnOrder) { + var foundNonLocked = false; + var rulePassed = true; + // go though the cols, see if any non-locked appear before any locked + proposedColumnOrder.forEach(function (col) { + if (col.getColDef().lockPosition) { + if (foundNonLocked) { + rulePassed = false; + } + } + else { + foundNonLocked = true; + } + }); + return rulePassed; + }; + ColumnModel.prototype.doesMovePassMarryChildren = function (allColumnsCopy) { + var rulePassed = true; + this.columnUtils.depthFirstOriginalTreeSearch(null, this.gridBalancedTree, function (child) { + if (!(child instanceof _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_4__["ProvidedColumnGroup"])) { + return; + } + var columnGroup = child; + var colGroupDef = columnGroup.getColGroupDef(); + var marryChildren = colGroupDef && colGroupDef.marryChildren; + if (!marryChildren) { + return; + } + var newIndexes = []; + columnGroup.getLeafColumns().forEach(function (col) { + var newColIndex = allColumnsCopy.indexOf(col); + newIndexes.push(newColIndex); + }); + var maxIndex = Math.max.apply(Math, newIndexes); + var minIndex = Math.min.apply(Math, newIndexes); + // spread is how far the first column in this group is away from the last column + var spread = maxIndex - minIndex; + var maxSpread = columnGroup.getLeafColumns().length - 1; + // if the columns + if (spread > maxSpread) { + rulePassed = false; + } + // console.log(`maxIndex = ${maxIndex}, minIndex = ${minIndex}, spread = ${spread}, maxSpread = ${maxSpread}, fail = ${spread > (count-1)}`) + // console.log(allColumnsCopy.map( col => col.getColDef().field).join(',')); + }); + return rulePassed; + }; + ColumnModel.prototype.moveColumn = function (key, toIndex, source) { + if (source === void 0) { source = "api"; } + this.moveColumns([key], toIndex, source); + }; + ColumnModel.prototype.moveColumnByIndex = function (fromIndex, toIndex, source) { + if (source === void 0) { source = "api"; } + var column = this.gridColumns[fromIndex]; + this.moveColumn(column, toIndex, source); + }; + ColumnModel.prototype.getColumnDefs = function () { + var _this = this; + if (!this.primaryColumns) { + return; + } + var cols = this.primaryColumns.slice(); + if (this.gridColsArePrimary) { + cols.sort(function (a, b) { return _this.gridColumns.indexOf(a) - _this.gridColumns.indexOf(b); }); + } + else if (this.lastPrimaryOrder) { + cols.sort(function (a, b) { return _this.lastPrimaryOrder.indexOf(a) - _this.lastPrimaryOrder.indexOf(b); }); + } + return this.columnDefFactory.buildColumnDefs(cols, this.rowGroupColumns, this.pivotColumns); + }; + // used by: + // + angularGrid -> for setting body width + // + rowController -> setting main row widths (when inserting and resizing) + // need to cache this + ColumnModel.prototype.getBodyContainerWidth = function () { + return this.bodyWidth; + }; + ColumnModel.prototype.getContainerWidth = function (pinned) { + switch (pinned) { + case _constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT: + return this.leftWidth; + case _constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT: + return this.rightWidth; + default: + return this.bodyWidth; + } + }; + // after setColumnWidth or updateGroupsAndDisplayedColumns + ColumnModel.prototype.updateBodyWidths = function () { + var newBodyWidth = this.getWidthOfColsInList(this.displayedColumnsCenter); + var newLeftWidth = this.getWidthOfColsInList(this.displayedColumnsLeft); + var newRightWidth = this.getWidthOfColsInList(this.displayedColumnsRight); + // this is used by virtual col calculation, for RTL only, as a change to body width can impact displayed + // columns, due to RTL inverting the y coordinates + this.bodyWidthDirty = this.bodyWidth !== newBodyWidth; + var atLeastOneChanged = this.bodyWidth !== newBodyWidth || this.leftWidth !== newLeftWidth || this.rightWidth !== newRightWidth; + if (atLeastOneChanged) { + this.bodyWidth = newBodyWidth; + this.leftWidth = newLeftWidth; + this.rightWidth = newRightWidth; + // when this fires, it is picked up by the gridPanel, which ends up in + // gridPanel calling setWidthAndScrollPosition(), which in turn calls setViewportPosition() + var event_3 = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, + api: this.gridApi, + columnApi: this.columnApi + }; + this.eventService.dispatchEvent(event_3); + } + }; + // + rowController + ColumnModel.prototype.getValueColumns = function () { + return this.valueColumns ? this.valueColumns : []; + }; + // + rowController + ColumnModel.prototype.getPivotColumns = function () { + return this.pivotColumns ? this.pivotColumns : []; + }; + // + clientSideRowModel + ColumnModel.prototype.isPivotActive = function () { + return this.pivotColumns && this.pivotColumns.length > 0 && this.pivotMode; + }; + // + toolPanel + ColumnModel.prototype.getRowGroupColumns = function () { + return this.rowGroupColumns ? this.rowGroupColumns : []; + }; + // + rowController -> while inserting rows + ColumnModel.prototype.getDisplayedCenterColumns = function () { + return this.displayedColumnsCenter; + }; + // + rowController -> while inserting rows + ColumnModel.prototype.getDisplayedLeftColumns = function () { + return this.displayedColumnsLeft; + }; + ColumnModel.prototype.getDisplayedRightColumns = function () { + return this.displayedColumnsRight; + }; + ColumnModel.prototype.getDisplayedColumns = function (type) { + switch (type) { + case _constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT: + return this.getDisplayedLeftColumns(); + case _constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT: + return this.getDisplayedRightColumns(); + default: + return this.getDisplayedCenterColumns(); + } + }; + // used by: + // + clientSideRowController -> sorting, building quick filter text + // + headerRenderer -> sorting (clearing icon) + ColumnModel.prototype.getAllPrimaryColumns = function () { + return this.primaryColumns ? this.primaryColumns.slice() : null; + }; + ColumnModel.prototype.getSecondaryColumns = function () { + return this.secondaryColumns ? this.secondaryColumns.slice() : null; + }; + ColumnModel.prototype.getAllColumnsForQuickFilter = function () { + return this.columnsForQuickFilter; + }; + // + moveColumnController + ColumnModel.prototype.getAllGridColumns = function () { + return this.gridColumns; + }; + ColumnModel.prototype.isEmpty = function () { + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missingOrEmpty"])(this.gridColumns); + }; + ColumnModel.prototype.isRowGroupEmpty = function () { + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missingOrEmpty"])(this.rowGroupColumns); + }; + ColumnModel.prototype.setColumnVisible = function (key, visible, source) { + if (source === void 0) { source = "api"; } + this.setColumnsVisible([key], visible, source); + }; + ColumnModel.prototype.setColumnsVisible = function (keys, visible, source) { + var _this = this; + if (visible === void 0) { visible = false; } + if (source === void 0) { source = "api"; } + this.columnAnimationService.start(); + this.actionOnGridColumns(keys, function (column) { + if (column.isVisible() !== visible) { + column.setVisible(visible, source); + return true; + } + return false; + }, source, function () { + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VISIBLE, + visible: visible, + column: null, + columns: null, + api: _this.gridApi, + columnApi: _this.columnApi, + source: source + }; + return event; + }); + this.columnAnimationService.finish(); + }; + ColumnModel.prototype.setColumnPinned = function (key, pinned, source) { + if (source === void 0) { source = "api"; } + if (key) { + this.setColumnsPinned([key], pinned, source); + } + }; + ColumnModel.prototype.setColumnsPinned = function (keys, pinned, source) { + var _this = this; + if (source === void 0) { source = "api"; } + if (this.gridOptionsWrapper.getDomLayout() === 'print') { + console.warn("Changing the column pinning status is not allowed with domLayout='print'"); + return; + } + this.columnAnimationService.start(); + var actualPinned; + if (pinned === true || pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT) { + actualPinned = _constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT; + } + else if (pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT) { + actualPinned = _constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT; + } + else { + actualPinned = null; + } + this.actionOnGridColumns(keys, function (col) { + if (col.getPinned() !== actualPinned) { + col.setPinned(actualPinned); + return true; + } + return false; + }, source, function () { + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PINNED, + pinned: actualPinned, + column: null, + columns: null, + api: _this.gridApi, + columnApi: _this.columnApi, + source: source + }; + return event; + }); + this.columnAnimationService.finish(); + }; + // does an action on a set of columns. provides common functionality for looking up the + // columns based on key, getting a list of effected columns, and then updated the event + // with either one column (if it was just one col) or a list of columns + // used by: autoResize, setVisible, setPinned + ColumnModel.prototype.actionOnGridColumns = function (// the column keys this action will be on + keys, + // the action to do - if this returns false, the column was skipped + // and won't be included in the event + action, + // should return back a column event of the right type + source, createEvent) { + var _this = this; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missingOrEmpty"])(keys)) { + return; + } + var updatedColumns = []; + keys.forEach(function (key) { + var column = _this.getGridColumn(key); + if (!column) { + return; + } + // need to check for false with type (ie !== instead of !=) + // as not returning anything (undefined) would also be false + var resultOfAction = action(column); + if (resultOfAction !== false) { + updatedColumns.push(column); + } + }); + if (!updatedColumns.length) { + return; + } + this.updateDisplayedColumns(source); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(createEvent) && createEvent) { + var event_4 = createEvent(); + event_4.columns = updatedColumns; + event_4.column = updatedColumns.length === 1 ? updatedColumns[0] : null; + this.eventService.dispatchEvent(event_4); + } + }; + ColumnModel.prototype.getDisplayedColBefore = function (col) { + var allDisplayedColumns = this.getAllDisplayedColumns(); + var oldIndex = allDisplayedColumns.indexOf(col); + if (oldIndex > 0) { + return allDisplayedColumns[oldIndex - 1]; + } + return null; + }; + // used by: + // + rowRenderer -> for navigation + ColumnModel.prototype.getDisplayedColAfter = function (col) { + var allDisplayedColumns = this.getAllDisplayedColumns(); + var oldIndex = allDisplayedColumns.indexOf(col); + if (oldIndex < (allDisplayedColumns.length - 1)) { + return allDisplayedColumns[oldIndex + 1]; + } + return null; + }; + ColumnModel.prototype.getDisplayedGroupAfter = function (columnGroup) { + return this.getDisplayedGroupAtDirection(columnGroup, 'After'); + }; + ColumnModel.prototype.getDisplayedGroupBefore = function (columnGroup) { + return this.getDisplayedGroupAtDirection(columnGroup, 'Before'); + }; + ColumnModel.prototype.getDisplayedGroupAtDirection = function (columnGroup, direction) { + // pick the last displayed column in this group + var requiredLevel = columnGroup.getProvidedColumnGroup().getLevel() + columnGroup.getPaddingLevel(); + var colGroupLeafColumns = columnGroup.getDisplayedLeafColumns(); + var col = direction === 'After' ? Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["last"])(colGroupLeafColumns) : colGroupLeafColumns[0]; + var getDisplayColMethod = "getDisplayedCol" + direction; + while (true) { + // keep moving to the next col, until we get to another group + var column = this[getDisplayColMethod](col); + if (!column) { + return null; + } + var groupPointer = this.getColumnGroupAtLevel(column, requiredLevel); + if (groupPointer !== columnGroup) { + return groupPointer; + } + } + }; + ColumnModel.prototype.getColumnGroupAtLevel = function (column, level) { + // get group at same level as the one we are looking for + var groupPointer = column.getParent(); + var originalGroupLevel; + var groupPointerLevel; + while (true) { + var groupPointerProvidedColumnGroup = groupPointer.getProvidedColumnGroup(); + originalGroupLevel = groupPointerProvidedColumnGroup.getLevel(); + groupPointerLevel = groupPointer.getPaddingLevel(); + if (originalGroupLevel + groupPointerLevel <= level) { + break; + } + groupPointer = groupPointer.getParent(); + } + return groupPointer; + }; + ColumnModel.prototype.isPinningLeft = function () { + return this.displayedColumnsLeft.length > 0; + }; + ColumnModel.prototype.isPinningRight = function () { + return this.displayedColumnsRight.length > 0; + }; + ColumnModel.prototype.getPrimaryAndSecondaryAndAutoColumns = function () { + var result = this.primaryColumns ? this.primaryColumns.slice(0) : []; + if (this.groupAutoColumns && Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(this.groupAutoColumns)) { + this.groupAutoColumns.forEach(function (col) { return result.push(col); }); + } + if (this.secondaryColumnsPresent && this.secondaryColumns) { + this.secondaryColumns.forEach(function (column) { return result.push(column); }); + } + return result; + }; + ColumnModel.prototype.createStateItemFromColumn = function (column) { + var rowGroupIndex = column.isRowGroupActive() ? this.rowGroupColumns.indexOf(column) : null; + var pivotIndex = column.isPivotActive() ? this.pivotColumns.indexOf(column) : null; + var aggFunc = column.isValueActive() ? column.getAggFunc() : null; + var sort = column.getSort() != null ? column.getSort() : null; + var sortIndex = column.getSortIndex() != null ? column.getSortIndex() : null; + var flex = column.getFlex() != null && column.getFlex() > 0 ? column.getFlex() : null; + var res = { + colId: column.getColId(), + width: column.getActualWidth(), + hide: !column.isVisible(), + pinned: column.getPinned(), + sort: sort, + sortIndex: sortIndex, + aggFunc: aggFunc, + rowGroup: column.isRowGroupActive(), + rowGroupIndex: rowGroupIndex, + pivot: column.isPivotActive(), + pivotIndex: pivotIndex, + flex: flex + }; + return res; + }; + ColumnModel.prototype.getColumnState = function () { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(this.primaryColumns) || !this.isAlive()) { + return []; + } + var colsForState = this.getPrimaryAndSecondaryAndAutoColumns(); + var res = colsForState.map(this.createStateItemFromColumn.bind(this)); + if (!this.pivotMode) { + this.orderColumnStateList(res); + } + return res; + }; + ColumnModel.prototype.getPrimaryAndAutoGroupCols = function () { + if (!this.groupAutoColumns) { + return this.primaryColumns; + } + return __spread((this.primaryColumns || []), this.groupAutoColumns); + }; + ColumnModel.prototype.orderColumnStateList = function (columnStateList) { + // for fast looking, store the index of each column + var gridColumnIdMap = Object(_utils_map__WEBPACK_IMPORTED_MODULE_11__["convertToMap"])(this.gridColumns.map(function (col, index) { return [col.getColId(), index]; })); + columnStateList.sort(function (itemA, itemB) { + var posA = gridColumnIdMap.has(itemA.colId) ? gridColumnIdMap.get(itemA.colId) : -1; + var posB = gridColumnIdMap.has(itemB.colId) ? gridColumnIdMap.get(itemB.colId) : -1; + return posA - posB; + }); + }; + ColumnModel.prototype.resetColumnState = function (source) { + // NOTE = there is one bug here that no customer has noticed - if a column has colDef.lockPosition, + // this is ignored below when ordering the cols. to work, we should always put lockPosition cols first. + // As a work around, developers should just put lockPosition columns first in their colDef list. + if (source === void 0) { source = "api"; } + // we can't use 'allColumns' as the order might of messed up, so get the primary ordered list + var primaryColumns = this.getColumnsFromTree(this.primaryColumnTree); + var columnStates = []; + // we start at 1000, so if user has mix of rowGroup and group specified, it will work with both. + // eg IF user has ColA.rowGroupIndex=0, ColB.rowGroupIndex=1, ColC.rowGroup=true, + // THEN result will be ColA.rowGroupIndex=0, ColB.rowGroupIndex=1, ColC.rowGroup=1000 + var letRowGroupIndex = 1000; + var letPivotIndex = 1000; + var colsToProcess = []; + if (this.groupAutoColumns) { + colsToProcess = colsToProcess.concat(this.groupAutoColumns); + } + if (primaryColumns) { + colsToProcess = colsToProcess.concat(primaryColumns); + } + colsToProcess.forEach(function (column) { + var getValueOrNull = function (a, b) { return a != null ? a : b != null ? b : null; }; + var colDef = column.getColDef(); + var sort = getValueOrNull(colDef.sort, colDef.initialSort); + var sortIndex = getValueOrNull(colDef.sortIndex, colDef.initialSortIndex); + var hide = getValueOrNull(colDef.hide, colDef.initialHide); + var pinned = getValueOrNull(colDef.pinned, colDef.initialPinned); + var width = getValueOrNull(colDef.width, colDef.initialWidth); + var flex = getValueOrNull(colDef.flex, colDef.initialFlex); + var rowGroupIndex = getValueOrNull(colDef.rowGroupIndex, colDef.initialRowGroupIndex); + var rowGroup = getValueOrNull(colDef.rowGroup, colDef.initialRowGroup); + if (rowGroupIndex == null && (rowGroup == null || rowGroup == false)) { + rowGroupIndex = null; + rowGroup = null; + } + var pivotIndex = getValueOrNull(colDef.pivotIndex, colDef.initialPivotIndex); + var pivot = getValueOrNull(colDef.pivot, colDef.initialPivot); + if (pivotIndex == null && (pivot == null || pivot == false)) { + pivotIndex = null; + pivot = null; + } + var aggFunc = getValueOrNull(colDef.aggFunc, colDef.initialAggFunc); + var stateItem = { + colId: column.getColId(), + sort: sort, + sortIndex: sortIndex, + hide: hide, + pinned: pinned, + width: width, + flex: flex, + rowGroup: rowGroup, + rowGroupIndex: rowGroupIndex, + pivot: pivot, + pivotIndex: pivotIndex, + aggFunc: aggFunc, + }; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(rowGroupIndex) && rowGroup) { + stateItem.rowGroupIndex = letRowGroupIndex++; + } + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(pivotIndex) && pivot) { + stateItem.pivotIndex = letPivotIndex++; + } + columnStates.push(stateItem); + }); + this.applyColumnState({ state: columnStates, applyOrder: true }, source); + }; + ColumnModel.prototype.applyColumnState = function (params, source) { + var _this = this; + if (source === void 0) { source = "api"; } + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missingOrEmpty"])(this.primaryColumns)) { + return false; + } + if (params && params.state && !params.state.forEach) { + console.warn('AG Grid: applyColumnState() - the state attribute should be an array, however an array was not found. Please provide an array of items (one for each col you want to change) for state.'); + return false; + } + this.columnAnimationService.start(); + var raiseEventsFunc = this.compareColumnStatesAndRaiseEvents(source); + this.autoGroupsNeedBuilding = true; + // at the end below, this list will have all columns we got no state for + var columnsWithNoState = this.primaryColumns.slice(); + var success = true; + var rowGroupIndexes = {}; + var pivotIndexes = {}; + var autoGroupColumnStates = []; + var previousRowGroupCols = this.rowGroupColumns.slice(); + var previousPivotCols = this.pivotColumns.slice(); + if (params.state) { + params.state.forEach(function (state) { + var groupAutoColumnId = _constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].GROUP_AUTO_COLUMN_ID; + var colId = state.colId || ''; + // auto group columns are re-created so deferring syncing with ColumnState + var isAutoGroupColumn = colId.startsWith(groupAutoColumnId); + if (isAutoGroupColumn) { + autoGroupColumnStates.push(state); + return; + } + var column = _this.getPrimaryColumn(colId); + if (!column) { + // we don't log the failure, as it's possible the user is applying that has extra + // cols in it. for example they could of save while row-grouping (so state includes + // auto-group column) and then applied state when not grouping (so the auto-group + // column would be in the state but no used). + success = false; + } + else { + _this.syncColumnWithStateItem(column, state, params.defaultState, rowGroupIndexes, pivotIndexes, false, source); + Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["removeFromArray"])(columnsWithNoState, column); + } + }); + } + // anything left over, we got no data for, so add in the column as non-value, non-rowGroup and hidden + var applyDefaultsFunc = function (col) { + return _this.syncColumnWithStateItem(col, null, params.defaultState, rowGroupIndexes, pivotIndexes, false, source); + }; + columnsWithNoState.forEach(applyDefaultsFunc); + // sort the lists according to the indexes that were provided + var comparator = function (indexes, oldList, colA, colB) { + var indexA = indexes[colA.getId()]; + var indexB = indexes[colB.getId()]; + var aHasIndex = indexA != null; + var bHasIndex = indexB != null; + if (aHasIndex && bHasIndex) { + // both a and b are new cols with index, so sort on index + return indexA - indexB; + } + if (aHasIndex) { + // a has an index, so it should be before a + return -1; + } + if (bHasIndex) { + // b has an index, so it should be before a + return 1; + } + var oldIndexA = oldList.indexOf(colA); + var oldIndexB = oldList.indexOf(colB); + var aHasOldIndex = oldIndexA >= 0; + var bHasOldIndex = oldIndexB >= 0; + if (aHasOldIndex && bHasOldIndex) { + // both a and b are old cols, so sort based on last order + return oldIndexA - oldIndexB; + } + if (aHasOldIndex) { + // a is old, b is new, so b is first + return -1; + } + // this bit does matter, means both are new cols + // but without index or that b is old and a is new + return 1; + }; + this.rowGroupColumns.sort(comparator.bind(this, rowGroupIndexes, previousRowGroupCols)); + this.pivotColumns.sort(comparator.bind(this, pivotIndexes, previousPivotCols)); + this.updateGridColumns(); + // sync newly created auto group columns with ColumnState + var autoGroupColsCopy = this.groupAutoColumns ? this.groupAutoColumns.slice() : []; + autoGroupColumnStates.forEach(function (stateItem) { + var autoCol = _this.getAutoColumn(stateItem.colId); + Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["removeFromArray"])(autoGroupColsCopy, autoCol); + _this.syncColumnWithStateItem(autoCol, stateItem, params.defaultState, null, null, true, source); + }); + // autogroup cols with nothing else, apply the default + autoGroupColsCopy.forEach(applyDefaultsFunc); + this.applyOrderAfterApplyState(params); + this.updateDisplayedColumns(source); + this.dispatchEverythingChanged(source); + raiseEventsFunc(); + this.columnAnimationService.finish(); + return success; + }; + ColumnModel.prototype.applyOrderAfterApplyState = function (params) { + if (!this.gridColsArePrimary || !params.applyOrder || !params.state) { + return; + } + var newOrder = []; + var processedColIds = {}; + var gridColumnsMap = {}; + this.gridColumns.forEach(function (col) { return gridColumnsMap[col.getId()] = col; }); + params.state.forEach(function (item) { + if (!item.colId || processedColIds[item.colId]) { + return; + } + var col = gridColumnsMap[item.colId]; + if (col) { + newOrder.push(col); + processedColIds[item.colId] = true; + } + }); + // add in all other columns + var autoGroupInsertIndex = 0; + this.gridColumns.forEach(function (col) { + var colId = col.getColId(); + var alreadyProcessed = processedColIds[colId] != null; + if (alreadyProcessed) { + return; + } + var isAutoGroupCol = colId.startsWith(_constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].GROUP_AUTO_COLUMN_ID); + if (isAutoGroupCol) { + // auto group columns, if missing from state list, are added to the start. + // it's common to have autoGroup missing, as grouping could be on by default + // on a column, but the user could of since removed the grouping via the UI. + // if we don't inc the insert index, autoGroups will be inserted in reverse order + Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["insertIntoArray"])(newOrder, col, autoGroupInsertIndex++); + } + else { + // normal columns, if missing from state list, are added at the end + newOrder.push(col); + } + }); + // this is already done in updateGridColumns, however we changed the order above (to match the order of the state + // columns) so we need to do it again. we could of put logic into the order above to take into account fixed + // columns, however if we did then we would have logic for updating fixed columns twice. reusing the logic here + // is less sexy for the code here, but it keeps consistency. + newOrder = this.putFixedColumnsFirst(newOrder); + if (!this.doesMovePassMarryChildren(newOrder)) { + console.warn('AG Grid: Applying column order broke a group where columns should be married together. Applying new order has been discarded.'); + return; + } + this.gridColumns = newOrder; + }; + ColumnModel.prototype.compareColumnStatesAndRaiseEvents = function (source) { + var _this = this; + var startState = { + rowGroupColumns: this.rowGroupColumns.slice(), + pivotColumns: this.pivotColumns.slice(), + valueColumns: this.valueColumns.slice() + }; + var columnStateBefore = this.getColumnState(); + var columnStateBeforeMap = {}; + columnStateBefore.forEach(function (col) { + columnStateBeforeMap[col.colId] = col; + }); + return function () { + if (_this.gridOptionsWrapper.isSuppressColumnStateEvents()) { + return; + } + var colsForState = _this.getPrimaryAndAutoGroupCols(); + // raises generic ColumnEvents where all columns are returned rather than what has changed + var raiseWhenListsDifferent = function (eventType, colsBefore, colsAfter, idMapper) { + var beforeList = colsBefore.map(idMapper); + var afterList = colsAfter.map(idMapper); + var unchanged = Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["areEqual"])(beforeList, afterList); + if (unchanged) { + return; + } + // returning all columns rather than what has changed! + var event = { + type: eventType, + columns: colsAfter, + column: colsAfter.length === 1 ? colsAfter[0] : null, + api: _this.gridApi, + columnApi: _this.columnApi, + source: source + }; + _this.eventService.dispatchEvent(event); + }; + // determines which columns have changed according to supplied predicate + var getChangedColumns = function (changedPredicate) { + var changedColumns = []; + (colsForState || []).forEach(function (column) { + var colStateBefore = columnStateBeforeMap[column.getColId()]; + if (colStateBefore && changedPredicate(colStateBefore, column)) { + changedColumns.push(column); + } + }); + return changedColumns; + }; + var columnIdMapper = function (c) { return c.getColId(); }; + raiseWhenListsDifferent(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, startState.rowGroupColumns, _this.rowGroupColumns, columnIdMapper); + raiseWhenListsDifferent(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_CHANGED, startState.pivotColumns, _this.pivotColumns, columnIdMapper); + var valueChangePredicate = function (cs, c) { + var oldActive = cs.aggFunc != null; + var activeChanged = oldActive != c.isValueActive(); + // we only check aggFunc if the agg is active + var aggFuncChanged = oldActive && cs.aggFunc != c.getAggFunc(); + return activeChanged || aggFuncChanged; + }; + var changedValues = getChangedColumns(valueChangePredicate); + if (changedValues.length > 0) { + // we pass all value columns, now the ones that changed. this is the same + // as pivot and rowGroup cols, but different to all other properties below. + // this is more for backwards compatibility, as it's always been this way. + // really it should be the other way, as the order of the cols makes no difference + // for valueColumns (apart from displaying them in the tool panel). + _this.fireColumnEvent(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VALUE_CHANGED, _this.valueColumns, source); + } + var resizeChangePredicate = function (cs, c) { return cs.width != c.getActualWidth(); }; + _this.fireColumnResizedEvent(getChangedColumns(resizeChangePredicate), true, source); + var pinnedChangePredicate = function (cs, c) { return cs.pinned != c.getPinned(); }; + _this.raiseColumnPinnedEvent(getChangedColumns(pinnedChangePredicate), source); + var visibilityChangePredicate = function (cs, c) { return cs.hide == c.isVisible(); }; + _this.raiseColumnVisibleEvent(getChangedColumns(visibilityChangePredicate), source); + var sortChangePredicate = function (cs, c) { return cs.sort != c.getSort() || cs.sortIndex != c.getSortIndex(); }; + if (getChangedColumns(sortChangePredicate).length > 0) { + _this.sortController.dispatchSortChangedEvents(); + } + // special handling for moved column events + _this.raiseColumnMovedEvent(columnStateBefore, source); + }; + }; + ColumnModel.prototype.raiseColumnPinnedEvent = function (changedColumns, source) { + if (!changedColumns.length) { + return; + } + // if just one column, we use this, otherwise we don't include the col + var column = changedColumns.length === 1 ? changedColumns[0] : null; + // only include visible if it's common in all columns + var pinned = this.getCommonValue(changedColumns, function (col) { return col.getPinned(); }); + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PINNED, + // mistake in typing, 'undefined' should be allowed, as 'null' means 'not pinned' + pinned: pinned != null ? pinned : null, + columns: changedColumns, + column: column, + api: this.gridApi, + columnApi: this.columnApi, + source: source + }; + this.eventService.dispatchEvent(event); + }; + ColumnModel.prototype.getCommonValue = function (cols, valueGetter) { + if (!cols || cols.length == 0) { + return undefined; + } + // compare each value to the first value. if nothing differs, then value is common so return it. + var firstValue = valueGetter(cols[0]); + for (var i = 1; i < cols.length; i++) { + if (firstValue !== valueGetter(cols[i])) { + // values differ, no common value + return undefined; + } + } + return firstValue; + }; + ColumnModel.prototype.raiseColumnVisibleEvent = function (changedColumns, source) { + if (!changedColumns.length) { + return; + } + // if just one column, we use this, otherwise we don't include the col + var column = changedColumns.length === 1 ? changedColumns[0] : null; + // only include visible if it's common in all columns + var visible = this.getCommonValue(changedColumns, function (col) { return col.isVisible(); }); + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VISIBLE, + visible: visible, + columns: changedColumns, + column: column, + api: this.gridApi, + columnApi: this.columnApi, + source: source + }; + this.eventService.dispatchEvent(event); + }; + ColumnModel.prototype.raiseColumnMovedEvent = function (colStateBefore, source) { + // we are only interested in columns that were both present and visible before and after + var _this = this; + var colStateAfter = this.getColumnState(); + var colStateAfterMapped = {}; + colStateAfter.forEach(function (s) { return colStateAfterMapped[s.colId] = s; }); + // get id's of cols in both before and after lists + var colsIntersectIds = {}; + colStateBefore.forEach(function (s) { + if (colStateAfterMapped[s.colId]) { + colsIntersectIds[s.colId] = true; + } + }); + // filter state lists, so we only have cols that were present before and after + var beforeFiltered = colStateBefore.filter(function (c) { return colsIntersectIds[c.colId]; }); + var afterFiltered = colStateAfter.filter(function (c) { return colsIntersectIds[c.colId]; }); + // see if any cols are in a different location + var movedColumns = []; + afterFiltered.forEach(function (csAfter, index) { + var csBefore = beforeFiltered && beforeFiltered[index]; + if (csBefore && csBefore.colId !== csAfter.colId) { + var gridCol = _this.getGridColumn(csBefore.colId); + if (gridCol) { + movedColumns.push(gridCol); + } + } + }); + if (!movedColumns.length) { + return; + } + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_MOVED, + columns: movedColumns, + column: null, + api: this.gridApi, + columnApi: this.columnApi, + source: source + }; + this.eventService.dispatchEvent(event); + }; + ColumnModel.prototype.syncColumnWithStateItem = function (column, stateItem, defaultState, rowGroupIndexes, pivotIndexes, autoCol, source) { + if (!column) { + return; + } + var getValue = function (key1, key2) { + var obj = { value1: undefined, value2: undefined }; + var calculated = false; + if (stateItem) { + if (stateItem[key1] !== undefined) { + obj.value1 = stateItem[key1]; + calculated = true; + } + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(key2) && stateItem[key2] !== undefined) { + obj.value2 = stateItem[key2]; + calculated = true; + } + } + if (!calculated && defaultState) { + if (defaultState[key1] !== undefined) { + obj.value1 = defaultState[key1]; + } + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(key2) && defaultState[key2] !== undefined) { + obj.value2 = defaultState[key2]; + } + } + return obj; + }; + // following ensures we are left with boolean true or false, eg converts (null, undefined, 0) all to true + var hide = getValue('hide').value1; + if (hide !== undefined) { + column.setVisible(!hide, source); + } + // sets pinned to 'left' or 'right' + var pinned = getValue('pinned').value1; + if (pinned !== undefined) { + column.setPinned(pinned); + } + // if width provided and valid, use it, otherwise stick with the old width + var minColWidth = this.columnUtils.calculateColMinWidth(column.getColDef()); + // flex + var flex = getValue('flex').value1; + if (flex !== undefined) { + column.setFlex(flex); + } + // width - we only set width if column is not flexing + var noFlexThisCol = column.getFlex() <= 0; + if (noFlexThisCol) { + // both null and undefined means we skip, as it's not possible to 'clear' width (a column must have a width) + var width = getValue('width').value1; + if (width != null) { + if (minColWidth != null && width >= minColWidth) { + column.setActualWidth(width, source); + } + } + } + var sort = getValue('sort').value1; + if (sort !== undefined) { + if (sort === _constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].SORT_DESC || sort === _constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].SORT_ASC) { + column.setSort(sort); + } + else { + column.setSort(undefined); + } + } + var sortIndex = getValue('sortIndex').value1; + if (sortIndex !== undefined) { + column.setSortIndex(sortIndex); + } + // we do not do aggFunc, rowGroup or pivot for auto cols, as you can't do these with auto col + if (autoCol) { + return; + } + var aggFunc = getValue('aggFunc').value1; + if (aggFunc !== undefined) { + if (typeof aggFunc === 'string') { + column.setAggFunc(aggFunc); + if (!column.isValueActive()) { + column.setValueActive(true, source); + this.valueColumns.push(column); + } + } + else { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(aggFunc)) { + console.warn('AG Grid: stateItem.aggFunc must be a string. if using your own aggregation ' + + 'functions, register the functions first before using them in get/set state. This is because it is ' + + 'intended for the column state to be stored and retrieved as simple JSON.'); + } + // Note: we do not call column.setAggFunc(null), so that next time we aggregate + // by this column (eg drag the column to the agg section int he toolpanel) it will + // default to the last aggregation function. + if (column.isValueActive()) { + column.setValueActive(false, source); + Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["removeFromArray"])(this.valueColumns, column); + } + } + } + var _a = getValue('rowGroup', 'rowGroupIndex'), rowGroup = _a.value1, rowGroupIndex = _a.value2; + if (rowGroup !== undefined || rowGroupIndex !== undefined) { + if (typeof rowGroupIndex === 'number' || rowGroup) { + if (!column.isRowGroupActive()) { + column.setRowGroupActive(true, source); + this.rowGroupColumns.push(column); + } + if (rowGroupIndexes && typeof rowGroupIndex === 'number') { + rowGroupIndexes[column.getId()] = rowGroupIndex; + } + } + else { + if (column.isRowGroupActive()) { + column.setRowGroupActive(false, source); + Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["removeFromArray"])(this.rowGroupColumns, column); + } + } + } + var _b = getValue('pivot', 'pivotIndex'), pivot = _b.value1, pivotIndex = _b.value2; + if (pivot !== undefined || pivotIndex !== undefined) { + if (typeof pivotIndex === 'number' || pivot) { + if (!column.isPivotActive()) { + column.setPivotActive(true, source); + this.pivotColumns.push(column); + } + if (pivotIndexes && typeof pivotIndex === 'number') { + pivotIndexes[column.getId()] = pivotIndex; + } + } + else { + if (column.isPivotActive()) { + column.setPivotActive(false, source); + Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["removeFromArray"])(this.pivotColumns, column); + } + } + } + }; + ColumnModel.prototype.getGridColumns = function (keys) { + return this.getColumns(keys, this.getGridColumn.bind(this)); + }; + ColumnModel.prototype.getColumns = function (keys, columnLookupCallback) { + var foundColumns = []; + if (keys) { + keys.forEach(function (key) { + var column = columnLookupCallback(key); + if (column) { + foundColumns.push(column); + } + }); + } + return foundColumns; + }; + // used by growGroupPanel + ColumnModel.prototype.getColumnWithValidation = function (key) { + if (key == null) { + return null; + } + var column = this.getGridColumn(key); + if (!column) { + console.warn('AG Grid: could not find column ' + key); + } + return column; + }; + ColumnModel.prototype.getPrimaryColumn = function (key) { + if (!this.primaryColumns) { + return null; + } + return this.getColumn(key, this.primaryColumns, this.primaryColumnsMap); + }; + ColumnModel.prototype.getGridColumn = function (key) { + return this.getColumn(key, this.gridColumns, this.gridColumnsMap); + }; + ColumnModel.prototype.getColumn = function (key, columnList, columnMap) { + if (!key) { + return null; + } + // most of the time this method gets called the key is a string, so we put this shortcut in + // for performance reasons, to see if we can match for ID (it doesn't do auto columns, that's done below) + if (typeof key == 'string' && columnMap[key]) { + return columnMap[key]; + } + for (var i = 0; i < columnList.length; i++) { + if (this.columnsMatch(columnList[i], key)) { + return columnList[i]; + } + } + return this.getAutoColumn(key); + }; + ColumnModel.prototype.getAutoColumn = function (key) { + var _this = this; + if (!this.groupAutoColumns || + !Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(this.groupAutoColumns) || + Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(this.groupAutoColumns)) { + return null; + } + return this.groupAutoColumns.find(function (groupCol) { return _this.columnsMatch(groupCol, key); }) || null; + }; + ColumnModel.prototype.columnsMatch = function (column, key) { + var columnMatches = column === key; + var colDefMatches = column.getColDef() === key; + var idMatches = column.getColId() == key; + return columnMatches || colDefMatches || idMatches; + }; + ColumnModel.prototype.getDisplayNameForColumn = function (column, location, includeAggFunc) { + if (includeAggFunc === void 0) { includeAggFunc = false; } + if (!column) { + return null; + } + var headerName = this.getHeaderName(column.getColDef(), column, null, null, location); + if (includeAggFunc) { + return this.wrapHeaderNameWithAggFunc(column, headerName); + } + return headerName; + }; + ColumnModel.prototype.getDisplayNameForProvidedColumnGroup = function (columnGroup, providedColumnGroup, location) { + var colGroupDef = providedColumnGroup ? providedColumnGroup.getColGroupDef() : null; + if (colGroupDef) { + return this.getHeaderName(colGroupDef, null, columnGroup, providedColumnGroup, location); + } + return null; + }; + ColumnModel.prototype.getDisplayNameForColumnGroup = function (columnGroup, location) { + return this.getDisplayNameForProvidedColumnGroup(columnGroup, columnGroup.getProvidedColumnGroup(), location); + }; + // location is where the column is going to appear, ie who is calling us + ColumnModel.prototype.getHeaderName = function (colDef, column, columnGroup, providedColumnGroup, location) { + var headerValueGetter = colDef.headerValueGetter; + if (headerValueGetter) { + var params = { + colDef: colDef, + column: column, + columnGroup: columnGroup, + providedColumnGroup: providedColumnGroup, + location: location, + api: this.gridOptionsWrapper.getApi(), + context: this.gridOptionsWrapper.getContext() + }; + if (typeof headerValueGetter === 'function') { + // valueGetter is a function, so just call it + return headerValueGetter(params); + } + else if (typeof headerValueGetter === 'string') { + // valueGetter is an expression, so execute the expression + return this.expressionService.evaluate(headerValueGetter, params); + } + console.warn('ag-grid: headerValueGetter must be a function or a string'); + return ''; + } + else if (colDef.headerName != null) { + return colDef.headerName; + } + else if (colDef.field) { + return Object(_utils_string__WEBPACK_IMPORTED_MODULE_10__["camelCaseToHumanText"])(colDef.field); + } + return ''; + }; + ColumnModel.prototype.wrapHeaderNameWithAggFunc = function (column, headerName) { + if (this.gridOptionsWrapper.isSuppressAggFuncInHeader()) { + return headerName; + } + // only columns with aggregation active can have aggregations + var pivotValueColumn = column.getColDef().pivotValueColumn; + var pivotActiveOnThisColumn = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(pivotValueColumn); + var aggFunc = null; + var aggFuncFound; + // otherwise we have a measure that is active, and we are doing aggregation on it + if (pivotActiveOnThisColumn) { + aggFunc = pivotValueColumn ? pivotValueColumn.getAggFunc() : null; + aggFuncFound = true; + } + else { + var measureActive = column.isValueActive(); + var aggregationPresent = this.pivotMode || !this.isRowGroupEmpty(); + if (measureActive && aggregationPresent) { + aggFunc = column.getAggFunc(); + aggFuncFound = true; + } + else { + aggFuncFound = false; + } + } + if (aggFuncFound) { + var aggFuncString = (typeof aggFunc === 'string') ? aggFunc : 'func'; + var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc(); + var aggFuncStringTranslated = localeTextFunc(aggFuncString, aggFuncString); + return aggFuncStringTranslated + "(" + headerName + ")"; + } + return headerName; + }; + // returns the group with matching colId and instanceId. If instanceId is missing, + // matches only on the colId. + ColumnModel.prototype.getColumnGroup = function (colId, instanceId) { + if (!colId) { + return null; + } + if (colId instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) { + return colId; + } + var allColumnGroups = this.getAllDisplayedTrees(); + var checkInstanceId = typeof instanceId === 'number'; + var result = null; + this.columnUtils.depthFirstAllColumnTreeSearch(allColumnGroups, function (child) { + if (child instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) { + var columnGroup = child; + var matched = void 0; + if (checkInstanceId) { + matched = colId === columnGroup.getGroupId() && instanceId === columnGroup.getInstanceId(); + } + else { + matched = colId === columnGroup.getGroupId(); + } + if (matched) { + result = columnGroup; + } + } + }); + return result; + }; + ColumnModel.prototype.isReady = function () { + return this.ready; + }; + ColumnModel.prototype.extractValueColumns = function (source, oldPrimaryColumns) { + this.valueColumns = this.extractColumns(oldPrimaryColumns, this.valueColumns, function (col, flag) { return col.setValueActive(flag, source); }, + // aggFunc doesn't have index variant, cos order of value cols doesn't matter, so always return null + function () { return undefined; }, function () { return undefined; }, + // aggFunc is a string, so return it's existence + function (colDef) { + var aggFunc = colDef.aggFunc; + // null or empty string means clear + if (aggFunc === null || aggFunc === '') { + return null; + } + if (aggFunc === undefined) { + return; + } + return !!aggFunc; + }, function (colDef) { + // return false if any of the following: null, undefined, empty string + return colDef.initialAggFunc != null && colDef.initialAggFunc != ''; + }); + // all new columns added will have aggFunc missing, so set it to what is in the colDef + this.valueColumns.forEach(function (col) { + var colDef = col.getColDef(); + // if aggFunc provided, we always override, as reactive property + if (colDef.aggFunc != null && colDef.aggFunc != '') { + col.setAggFunc(colDef.aggFunc); + } + else { + // otherwise we use initialAggFunc only if no agg func set - which happens when new column only + if (!col.getAggFunc()) { + col.setAggFunc(colDef.initialAggFunc); + } + } + }); + }; + ColumnModel.prototype.extractRowGroupColumns = function (source, oldPrimaryColumns) { + this.rowGroupColumns = this.extractColumns(oldPrimaryColumns, this.rowGroupColumns, function (col, flag) { return col.setRowGroupActive(flag, source); }, function (colDef) { return colDef.rowGroupIndex; }, function (colDef) { return colDef.initialRowGroupIndex; }, function (colDef) { return colDef.rowGroup; }, function (colDef) { return colDef.initialRowGroup; }); + }; + ColumnModel.prototype.extractColumns = function (oldPrimaryColumns, previousCols, setFlagFunc, getIndexFunc, getInitialIndexFunc, getValueFunc, getInitialValueFunc) { + if (oldPrimaryColumns === void 0) { oldPrimaryColumns = []; } + if (previousCols === void 0) { previousCols = []; } + var colsWithIndex = []; + var colsWithValue = []; + // go though all cols. + // if value, change + // if default only, change only if new + (this.primaryColumns || []).forEach(function (col) { + var colIsNew = oldPrimaryColumns.indexOf(col) < 0; + var colDef = col.getColDef(); + var value = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["attrToBoolean"])(getValueFunc(colDef)); + var initialValue = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["attrToBoolean"])(getInitialValueFunc(colDef)); + var index = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["attrToNumber"])(getIndexFunc(colDef)); + var initialIndex = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["attrToNumber"])(getInitialIndexFunc(colDef)); + var include; + var valuePresent = value !== undefined; + var indexPresent = index !== undefined; + var initialValuePresent = initialValue !== undefined; + var initialIndexPresent = initialIndex !== undefined; + if (valuePresent) { + include = value; // boolean value is guaranteed as attrToBoolean() is used above + } + else if (indexPresent) { + if (index === null) { + // if col is new we don't want to use the default / initial if index is set to null. Similarly, + // we don't want to include the property for existing columns, i.e. we want to 'clear' it. + include = false; + } + else { + // note that 'null >= 0' evaluates to true which means 'rowGroupIndex = null' would enable row + // grouping if the null check didn't exist above. + include = index >= 0; + } + } + else { + if (colIsNew) { + // as no value or index is 'present' we use the default / initial when col is new + if (initialValuePresent) { + include = initialValue; + } + else if (initialIndexPresent) { + include = initialIndex != null && initialIndex >= 0; + } + else { + include = false; + } + } + else { + // otherwise include it if included last time, e.g. if we are extracting row group cols and this col + // is an existing row group col (i.e. it exists in 'previousCols') then we should include it. + include = previousCols.indexOf(col) >= 0; + } + } + if (include) { + var useIndex = colIsNew ? (index != null || initialIndex != null) : index != null; + useIndex ? colsWithIndex.push(col) : colsWithValue.push(col); + } + }); + var getIndexForCol = function (col) { + var index = getIndexFunc(col.getColDef()); + var defaultIndex = getInitialIndexFunc(col.getColDef()); + return index != null ? index : defaultIndex; + }; + // sort cols with index, and add these first + colsWithIndex.sort(function (colA, colB) { + var indexA = getIndexForCol(colA); + var indexB = getIndexForCol(colB); + if (indexA === indexB) { + return 0; + } + if (indexA < indexB) { + return -1; + } + return 1; + }); + var res = [].concat(colsWithIndex); + // second add columns that were there before and in the same order as they were before, + // so we are preserving order of current grouping of columns that simply have rowGroup=true + previousCols.forEach(function (col) { + if (colsWithValue.indexOf(col) >= 0) { + res.push(col); + } + }); + // lastly put in all remaining cols + colsWithValue.forEach(function (col) { + if (res.indexOf(col) < 0) { + res.push(col); + } + }); + // set flag=false for removed cols + previousCols.forEach(function (col) { + if (res.indexOf(col) < 0) { + setFlagFunc(col, false); + } + }); + // set flag=true for newly added cols + res.forEach(function (col) { + if (previousCols.indexOf(col) < 0) { + setFlagFunc(col, true); + } + }); + return res; + }; + ColumnModel.prototype.extractPivotColumns = function (source, oldPrimaryColumns) { + this.pivotColumns = this.extractColumns(oldPrimaryColumns, this.pivotColumns, function (col, flag) { return col.setPivotActive(flag, source); }, function (colDef) { return colDef.pivotIndex; }, function (colDef) { return colDef.initialPivotIndex; }, function (colDef) { return colDef.pivot; }, function (colDef) { return colDef.initialPivot; }); + }; + ColumnModel.prototype.resetColumnGroupState = function (source) { + if (source === void 0) { source = "api"; } + var stateItems = []; + this.columnUtils.depthFirstOriginalTreeSearch(null, this.primaryColumnTree, function (child) { + if (child instanceof _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_4__["ProvidedColumnGroup"]) { + var colGroupDef = child.getColGroupDef(); + var groupState = { + groupId: child.getGroupId(), + open: !colGroupDef ? undefined : colGroupDef.openByDefault + }; + stateItems.push(groupState); + } + }); + this.setColumnGroupState(stateItems, source); + }; + ColumnModel.prototype.getColumnGroupState = function () { + var columnGroupState = []; + this.columnUtils.depthFirstOriginalTreeSearch(null, this.gridBalancedTree, function (node) { + if (node instanceof _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_4__["ProvidedColumnGroup"]) { + var providedColumnGroup = node; + columnGroupState.push({ + groupId: providedColumnGroup.getGroupId(), + open: providedColumnGroup.isExpanded() + }); + } + }); + return columnGroupState; + }; + ColumnModel.prototype.setColumnGroupState = function (stateItems, source) { + var _this = this; + if (source === void 0) { source = "api"; } + this.columnAnimationService.start(); + var impactedGroups = []; + stateItems.forEach(function (stateItem) { + var groupKey = stateItem.groupId; + var newValue = stateItem.open; + var providedColumnGroup = _this.getProvidedColumnGroup(groupKey); + if (!providedColumnGroup) { + return; + } + if (providedColumnGroup.isExpanded() === newValue) { + return; + } + _this.logger.log('columnGroupOpened(' + providedColumnGroup.getGroupId() + ',' + newValue + ')'); + providedColumnGroup.setExpanded(newValue); + impactedGroups.push(providedColumnGroup); + }); + this.updateGroupsAndDisplayedColumns(source); + this.setFirstRightAndLastLeftPinned(source); + impactedGroups.forEach(function (providedColumnGroup) { + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_GROUP_OPENED, + columnGroup: providedColumnGroup, + api: _this.gridApi, + columnApi: _this.columnApi + }; + _this.eventService.dispatchEvent(event); + }); + this.columnAnimationService.finish(); + }; + // called by headerRenderer - when a header is opened or closed + ColumnModel.prototype.setColumnGroupOpened = function (key, newValue, source) { + if (source === void 0) { source = "api"; } + var keyAsString; + if (key instanceof _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_4__["ProvidedColumnGroup"]) { + keyAsString = key.getId(); + } + else { + keyAsString = key || ''; + } + this.setColumnGroupState([{ groupId: keyAsString, open: newValue }], source); + }; + ColumnModel.prototype.getProvidedColumnGroup = function (key) { + // if (key instanceof ProvidedColumnGroup) { return key; } + if (typeof key !== 'string') { + console.error('AG Grid: group key must be a string'); + } + // otherwise, search for the column group by id + var res = null; + this.columnUtils.depthFirstOriginalTreeSearch(null, this.gridBalancedTree, function (node) { + if (node instanceof _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_4__["ProvidedColumnGroup"]) { + var providedColumnGroup = node; + if (providedColumnGroup.getId() === key) { + res = providedColumnGroup; + } + } + }); + return res; + }; + ColumnModel.prototype.calculateColumnsForDisplay = function () { + var _this = this; + var columnsForDisplay; + if (this.pivotMode && !this.secondaryColumnsPresent) { + // pivot mode is on, but we are not pivoting, so we only + // show columns we are aggregating on + columnsForDisplay = this.gridColumns.filter(function (column) { + var isAutoGroupCol = _this.groupAutoColumns && Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["includes"])(_this.groupAutoColumns, column); + var isValueCol = _this.valueColumns && Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["includes"])(_this.valueColumns, column); + return isAutoGroupCol || isValueCol; + }); + } + else { + // otherwise continue as normal. this can be working on the primary + // or secondary columns, whatever the gridColumns are set to + columnsForDisplay = this.gridColumns.filter(function (column) { + // keep col if a) it's auto-group or b) it's visible + var isAutoGroupCol = _this.groupAutoColumns && Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["includes"])(_this.groupAutoColumns, column); + return isAutoGroupCol || column.isVisible(); + }); + } + return columnsForDisplay; + }; + ColumnModel.prototype.checkColSpanActiveInCols = function (columns) { + var result = false; + columns.forEach(function (col) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(col.getColDef().colSpan)) { + result = true; + } + }); + return result; + }; + ColumnModel.prototype.calculateColumnsForGroupDisplay = function () { + var _this = this; + this.groupDisplayColumns = []; + var checkFunc = function (col) { + var colDef = col.getColDef(); + if (colDef && Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(colDef.showRowGroup)) { + _this.groupDisplayColumns.push(col); + } + }; + this.gridColumns.forEach(checkFunc); + if (this.groupAutoColumns) { + this.groupAutoColumns.forEach(checkFunc); + } + }; + ColumnModel.prototype.getGroupDisplayColumns = function () { + return this.groupDisplayColumns; + }; + ColumnModel.prototype.updateDisplayedColumns = function (source) { + var columnsForDisplay = this.calculateColumnsForDisplay(); + this.buildDisplayedTrees(columnsForDisplay); + this.calculateColumnsForGroupDisplay(); + // also called when group opened/closed + this.updateGroupsAndDisplayedColumns(source); + // also called when group opened/closed + this.setFirstRightAndLastLeftPinned(source); + }; + ColumnModel.prototype.isSecondaryColumnsPresent = function () { + return this.secondaryColumnsPresent; + }; + ColumnModel.prototype.setSecondaryColumns = function (colDefs, source) { + if (source === void 0) { source = "api"; } + var newColsPresent = colDefs && colDefs.length > 0; + // if not cols passed, and we had to cols anyway, then do nothing + if (!newColsPresent && !this.secondaryColumnsPresent) { + return; + } + if (newColsPresent) { + this.processSecondaryColumnDefinitions(colDefs); + var balancedTreeResult = this.columnFactory.createColumnTree(colDefs, false); + this.secondaryBalancedTree = balancedTreeResult.columnTree; + this.secondaryHeaderRowCount = balancedTreeResult.treeDept + 1; + this.secondaryColumns = this.getColumnsFromTree(this.secondaryBalancedTree); + this.secondaryColumnsPresent = true; + } + else { + this.secondaryBalancedTree = null; + this.secondaryHeaderRowCount = -1; + this.secondaryColumns = null; + this.secondaryColumnsPresent = false; + } + this.updateGridColumns(); + this.updateDisplayedColumns(source); + }; + ColumnModel.prototype.processSecondaryColumnDefinitions = function (colDefs) { + var columnCallback = this.gridOptionsWrapper.getProcessSecondaryColDefFunc(); + var groupCallback = this.gridOptionsWrapper.getProcessSecondaryColGroupDefFunc(); + if (!columnCallback && !groupCallback) { + return undefined; + } + var searchForColDefs = function (colDefs2) { + colDefs2.forEach(function (abstractColDef) { + var isGroup = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(abstractColDef.children); + if (isGroup) { + var colGroupDef = abstractColDef; + if (groupCallback) { + groupCallback(colGroupDef); + } + searchForColDefs(colGroupDef.children); + } + else { + var colDef = abstractColDef; + if (columnCallback) { + columnCallback(colDef); + } + } + }); + }; + if (colDefs) { + searchForColDefs(colDefs); + } + }; + // called from: setColumnState, setColumnDefs, setSecondaryColumns + ColumnModel.prototype.updateGridColumns = function () { + var _this = this; + if (this.gridColsArePrimary) { + this.lastPrimaryOrder = this.gridColumns; + } + if (this.secondaryColumns && this.secondaryBalancedTree) { + this.gridBalancedTree = this.secondaryBalancedTree.slice(); + this.gridHeaderRowCount = this.secondaryHeaderRowCount; + this.gridColumns = this.secondaryColumns.slice(); + this.gridColsArePrimary = false; + } + else if (this.primaryColumns) { + this.gridBalancedTree = this.primaryColumnTree.slice(); + this.gridHeaderRowCount = this.primaryHeaderRowCount; + this.gridColumns = this.primaryColumns.slice(); + this.gridColsArePrimary = true; + // updateGridColumns gets called after user adds a row group. we want to maintain the order of the columns + // when this happens (eg if user moved a column) rather than revert back to the original column order. + // likewise if changing in/out of pivot mode, we want to maintain the order of the primary cols + this.orderGridColsLikeLastPrimary(); + } + this.addAutoGroupToGridColumns(); + this.gridColumns = this.putFixedColumnsFirst(this.gridColumns); + this.setupQuickFilterColumns(); + this.clearDisplayedAndViewportColumns(); + this.colSpanActive = this.checkColSpanActiveInCols(this.gridColumns); + this.gridColumnsMap = {}; + this.gridColumns.forEach(function (col) { return _this.gridColumnsMap[col.getId()] = col; }); + this.setAutoHeightActive(); + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_GRID_COLUMNS_CHANGED, + api: this.gridApi, + columnApi: this.columnApi + }; + this.eventService.dispatchEvent(event); + }; + ColumnModel.prototype.setAutoHeightActive = function () { + this.autoHeightActive = this.gridColumns.filter(function (col) { return col.isAutoHeight(); }).length > 0; + if (this.autoHeightActive) { + this.autoHeightActiveAtLeastOnce = true; + var rowModelType = this.rowModel.getType(); + var supportedRowModel = rowModelType === _constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE || rowModelType === _constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE; + if (!supportedRowModel) { + var message_1 = 'AG Grid - autoHeight columns only work with Client Side Row Model and Server Side Row Model.'; + Object(_utils_function__WEBPACK_IMPORTED_MODULE_12__["doOnce"])(function () { return console.warn(message_1); }, 'autoHeightActive.wrongRowModel'); + } + } + }; + ColumnModel.prototype.orderGridColsLikeLastPrimary = function () { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(this.lastPrimaryOrder)) { + return; + } + var lastPrimaryOrderMapped = Object(_utils_map__WEBPACK_IMPORTED_MODULE_11__["convertToMap"])(this.lastPrimaryOrder.map(function (col, index) { return [col, index]; })); + // only do the sort if at least one column is accounted for. columns will be not accounted for + // if changing from secondary to primary columns + var noColsFound = true; + this.gridColumns.forEach(function (col) { + if (lastPrimaryOrderMapped.has(col)) { + noColsFound = false; + } + }); + if (noColsFound) { + return; + } + // order cols in the same order as before. we need to make sure that all + // cols still exists, so filter out any that no longer exist. + var gridColsMap = Object(_utils_map__WEBPACK_IMPORTED_MODULE_11__["convertToMap"])(this.gridColumns.map(function (col) { return [col, true]; })); + var oldColsOrdered = this.lastPrimaryOrder.filter(function (col) { return gridColsMap.has(col); }); + var oldColsMap = Object(_utils_map__WEBPACK_IMPORTED_MODULE_11__["convertToMap"])(oldColsOrdered.map(function (col) { return [col, true]; })); + var newColsOrdered = this.gridColumns.filter(function (col) { return !oldColsMap.has(col); }); + // add in the new columns, at the end (if no group), or at the end of the group (if a group) + var newGridColumns = oldColsOrdered.slice(); + newColsOrdered.forEach(function (newCol) { + var parent = newCol.getOriginalParent(); + // if no parent, means we are not grouping, so just add the column to the end + if (!parent) { + newGridColumns.push(newCol); + return; + } + // find the group the column belongs to. if no siblings at the current level (eg col in group on it's + // own) then go up one level and look for siblings there. + var siblings = []; + while (!siblings.length && parent) { + var leafCols = parent.getLeafColumns(); + leafCols.forEach(function (leafCol) { + var presentInNewGriColumns = newGridColumns.indexOf(leafCol) >= 0; + var noYetInSiblings = siblings.indexOf(leafCol) < 0; + if (presentInNewGriColumns && noYetInSiblings) { + siblings.push(leafCol); + } + }); + parent = parent.getOriginalParent(); + } + // if no siblings exist at any level, this means the col is in a group (or parent groups) on it's own + if (!siblings.length) { + newGridColumns.push(newCol); + return; + } + // find index of last column in the group + var indexes = siblings.map(function (col) { return newGridColumns.indexOf(col); }); + var lastIndex = Math.max.apply(Math, __spread(indexes)); + Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["insertIntoArray"])(newGridColumns, newCol, lastIndex + 1); + }); + this.gridColumns = newGridColumns; + }; + ColumnModel.prototype.isPrimaryColumnGroupsPresent = function () { + return this.primaryHeaderRowCount > 1; + }; + // if we are using autoGroupCols, then they should be included for quick filter. this covers the + // following scenarios: + // a) user provides 'field' into autoGroupCol of normal grid, so now because a valid col to filter leafs on + // b) using tree data and user depends on autoGroupCol for first col, and we also want to filter on this + // (tree data is a bit different, as parent rows can be filtered on, unlike row grouping) + ColumnModel.prototype.setupQuickFilterColumns = function () { + if (this.groupAutoColumns) { + this.columnsForQuickFilter = (this.primaryColumns || []).concat(this.groupAutoColumns); + } + else if (this.primaryColumns) { + this.columnsForQuickFilter = this.primaryColumns; + } + }; + ColumnModel.prototype.putFixedColumnsFirst = function (cols) { + var locked = cols.filter(function (c) { return c.getColDef().lockPosition; }); + var unlocked = cols.filter(function (c) { return !c.getColDef().lockPosition; }); + return locked.concat(unlocked); + }; + ColumnModel.prototype.addAutoGroupToGridColumns = function () { + // add in auto-group here + this.createGroupAutoColumnsIfNeeded(); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(this.groupAutoColumns)) { + return; + } + this.gridColumns = this.groupAutoColumns ? this.groupAutoColumns.concat(this.gridColumns) : this.gridColumns; + var autoColBalancedTree = this.columnFactory.createForAutoGroups(this.groupAutoColumns, this.gridBalancedTree); + this.gridBalancedTree = autoColBalancedTree.concat(this.gridBalancedTree); + }; + // gets called after we copy down grid columns, to make sure any part of the gui + // that tries to draw, eg the header, it will get empty lists of columns rather + // than stale columns. for example, the header will received gridColumnsChanged + // event, so will try and draw, but it will draw successfully when it acts on the + // virtualColumnsChanged event + ColumnModel.prototype.clearDisplayedAndViewportColumns = function () { + this.displayedTreeLeft = []; + this.displayedTreeRight = []; + this.displayedTreeCentre = []; + this.viewportRowLeft = {}; + this.viewportRowRight = {}; + this.viewportRowCenter = {}; + this.displayedColumnsLeft = []; + this.displayedColumnsRight = []; + this.displayedColumnsCenter = []; + this.displayedColumns = []; + this.viewportColumns = []; + }; + ColumnModel.prototype.updateGroupsAndDisplayedColumns = function (source) { + this.updateOpenClosedVisibilityInColumnGroups(); + this.deriveDisplayedColumns(source); + this.refreshFlexedColumns(); + this.extractViewport(); + this.updateBodyWidths(); + // this event is picked up by the gui, headerRenderer and rowRenderer, to recalculate what columns to display + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, + api: this.gridApi, + columnApi: this.columnApi + }; + this.eventService.dispatchEvent(event); + }; + ColumnModel.prototype.deriveDisplayedColumns = function (source) { + this.derivedDisplayedColumnsFromDisplayedTree(this.displayedTreeLeft, this.displayedColumnsLeft); + this.derivedDisplayedColumnsFromDisplayedTree(this.displayedTreeCentre, this.displayedColumnsCenter); + this.derivedDisplayedColumnsFromDisplayedTree(this.displayedTreeRight, this.displayedColumnsRight); + this.joinDisplayedColumns(); + this.setLeftValues(source); + this.displayedAutoHeightCols = this.displayedColumns.filter(function (col) { return col.isAutoHeight(); }); + }; + ColumnModel.prototype.isAutoRowHeightActive = function () { + return this.autoHeightActive; + }; + ColumnModel.prototype.wasAutoRowHeightEverActive = function () { + return this.autoHeightActiveAtLeastOnce; + }; + ColumnModel.prototype.joinDisplayedColumns = function () { + if (this.gridOptionsWrapper.isEnableRtl()) { + this.displayedColumns = this.displayedColumnsRight + .concat(this.displayedColumnsCenter) + .concat(this.displayedColumnsLeft); + } + else { + this.displayedColumns = this.displayedColumnsLeft + .concat(this.displayedColumnsCenter) + .concat(this.displayedColumnsRight); + } + }; + // sets the left pixel position of each column + ColumnModel.prototype.setLeftValues = function (source) { + this.setLeftValuesOfColumns(source); + this.setLeftValuesOfGroups(); + }; + ColumnModel.prototype.setLeftValuesOfColumns = function (source) { + var _this = this; + if (!this.primaryColumns) { + return; + } + // go through each list of displayed columns + var allColumns = this.primaryColumns.slice(0); + // let totalColumnWidth = this.getWidthOfColsInList() + var doingRtl = this.gridOptionsWrapper.isEnableRtl(); + [ + this.displayedColumnsLeft, + this.displayedColumnsRight, + this.displayedColumnsCenter + ].forEach(function (columns) { + if (doingRtl) { + // when doing RTL, we start at the top most pixel (ie RHS) and work backwards + var left_1 = _this.getWidthOfColsInList(columns); + columns.forEach(function (column) { + left_1 -= column.getActualWidth(); + column.setLeft(left_1, source); + }); + } + else { + // otherwise normal LTR, we start at zero + var left_2 = 0; + columns.forEach(function (column) { + column.setLeft(left_2, source); + left_2 += column.getActualWidth(); + }); + } + Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["removeAllFromArray"])(allColumns, columns); + }); + // items left in allColumns are columns not displayed, so remove the left position. this is + // important for the rows, as if a col is made visible, then taken out, then made visible again, + // we don't want the animation of the cell floating in from the old position, whatever that was. + allColumns.forEach(function (column) { + column.setLeft(null, source); + }); + }; + ColumnModel.prototype.setLeftValuesOfGroups = function () { + // a groups left value is the lest left value of it's children + [ + this.displayedTreeLeft, + this.displayedTreeRight, + this.displayedTreeCentre + ].forEach(function (columns) { + columns.forEach(function (column) { + if (column instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) { + var columnGroup = column; + columnGroup.checkLeft(); + } + }); + }); + }; + ColumnModel.prototype.derivedDisplayedColumnsFromDisplayedTree = function (tree, columns) { + columns.length = 0; + this.columnUtils.depthFirstDisplayedColumnTreeSearch(tree, function (child) { + if (child instanceof _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"]) { + columns.push(child); + } + }); + }; + ColumnModel.prototype.extractViewportColumns = function () { + if (this.suppressColumnVirtualisation) { + // no virtualisation, so don't filter + this.viewportColumnsCenter = this.displayedColumnsCenter; + } + else { + // filter out what should be visible + this.viewportColumnsCenter = this.filterOutColumnsWithinViewport(); + } + this.viewportColumns = this.viewportColumnsCenter + .concat(this.displayedColumnsLeft) + .concat(this.displayedColumnsRight); + }; + ColumnModel.prototype.getVirtualHeaderGroupRow = function (type, dept) { + var result; + switch (type) { + case _constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT: + result = this.viewportRowLeft[dept]; + break; + case _constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT: + result = this.viewportRowRight[dept]; + break; + default: + result = this.viewportRowCenter[dept]; + break; + } + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(result)) { + result = []; + } + return result; + }; + ColumnModel.prototype.extractViewportRows = function () { + // go through each group, see if any of it's cols are displayed, and if yes, + // then this group is included + this.viewportRowLeft = {}; + this.viewportRowRight = {}; + this.viewportRowCenter = {}; + // for easy lookup when building the groups. + var virtualColIds = {}; + this.viewportColumns.forEach(function (col) { return virtualColIds[col.getId()] = true; }); + var testGroup = function (children, result, dept) { + var returnValue = false; + for (var i = 0; i < children.length; i++) { + // see if this item is within viewport + var child = children[i]; + var addThisItem = false; + if (child instanceof _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"]) { + // for column, test if column is included + addThisItem = virtualColIds[child.getId()] === true; + } + else { + // if group, base decision on children + var columnGroup = child; + var displayedChildren = columnGroup.getDisplayedChildren(); + if (displayedChildren) { + addThisItem = testGroup(displayedChildren, result, dept + 1); + } + } + if (addThisItem) { + returnValue = true; + if (!result[dept]) { + result[dept] = []; + } + result[dept].push(child); + } + } + return returnValue; + }; + testGroup(this.displayedTreeLeft, this.viewportRowLeft, 0); + testGroup(this.displayedTreeRight, this.viewportRowRight, 0); + testGroup(this.displayedTreeCentre, this.viewportRowCenter, 0); + }; + ColumnModel.prototype.extractViewport = function () { + this.extractViewportColumns(); + this.extractViewportRows(); + }; + ColumnModel.prototype.filterOutColumnsWithinViewport = function () { + return this.displayedColumnsCenter.filter(this.isColumnInViewport.bind(this)); + }; + ColumnModel.prototype.refreshFlexedColumns = function (params) { + var _this = this; + if (params === void 0) { params = {}; } + var source = params.source ? params.source : 'flex'; + if (params.viewportWidth != null) { + this.flexViewportWidth = params.viewportWidth; + } + if (!this.flexViewportWidth) { + return []; + } + // If the grid has left-over space, divide it between flexing columns in proportion to their flex value. + // A "flexing column" is one that has a 'flex' value set and is not currently being constrained by its + // minWidth or maxWidth rules. + var flexAfterDisplayIndex = -1; + if (params.resizingCols) { + params.resizingCols.forEach(function (col) { + var indexOfCol = _this.displayedColumnsCenter.indexOf(col); + if (flexAfterDisplayIndex < indexOfCol) { + flexAfterDisplayIndex = indexOfCol; + } + }); + } + var isColFlex = function (col) { + var afterResizingCols = _this.displayedColumnsCenter.indexOf(col) > flexAfterDisplayIndex; + return col.getFlex() && afterResizingCols; + }; + var knownWidthColumns = this.displayedColumnsCenter.filter(function (col) { return !isColFlex(col); }); + var flexingColumns = this.displayedColumnsCenter.filter(function (col) { return isColFlex(col); }); + var changedColumns = []; + if (!flexingColumns.length) { + return []; + } + var flexingColumnSizes = []; + var spaceForFlexingColumns; + outer: while (true) { + var totalFlex = flexingColumns.reduce(function (count, col) { return count + col.getFlex(); }, 0); + spaceForFlexingColumns = this.flexViewportWidth - this.getWidthOfColsInList(knownWidthColumns); + for (var i = 0; i < flexingColumns.length; i++) { + var col = flexingColumns[i]; + var widthByFlexRule = spaceForFlexingColumns * col.getFlex() / totalFlex; + var constrainedWidth = 0; + var minWidth = col.getMinWidth(); + var maxWidth = col.getMaxWidth(); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(minWidth) && widthByFlexRule < minWidth) { + constrainedWidth = minWidth; + } + else if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(maxWidth) && widthByFlexRule > maxWidth) { + constrainedWidth = maxWidth; + } + if (constrainedWidth) { + // This column is not in fact flexing as it is being constrained to a specific size + // so remove it from the list of flexing columns and start again + col.setActualWidth(constrainedWidth, source); + Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["removeFromArray"])(flexingColumns, col); + changedColumns.push(col); + knownWidthColumns.push(col); + continue outer; + } + flexingColumnSizes[i] = Math.round(widthByFlexRule); + } + break; + } + var remainingSpace = spaceForFlexingColumns; + flexingColumns.forEach(function (col, i) { + col.setActualWidth(Math.min(flexingColumnSizes[i], remainingSpace), source); + changedColumns.push(col); + remainingSpace -= flexingColumnSizes[i]; + }); + if (!params.skipSetLeft) { + this.setLeftValues(source); + } + if (params.updateBodyWidths) { + this.updateBodyWidths(); + } + if (params.fireResizedEvent) { + this.fireColumnResizedEvent(changedColumns, true, source, flexingColumns); + } + // if the user sets rowData directly into GridOptions, then the row data is set before + // grid is attached to the DOM. this means the columns are not flexed, and then the rows + // have the wrong height (as they depend on column widths). so once the columns have + // been flexed for the first time (only happens once grid is attached to DOM, as dependency + // on getting the grid width, which only happens after attached after ResizeObserver fires) + // we get get rows to re-calc their heights. + if (!this.flexColsCalculatedAtLestOnce) { + if (this.gridOptionsWrapper.isRowModelDefault()) { + this.rowModel.resetRowHeights(); + } + this.flexColsCalculatedAtLestOnce = true; + } + return flexingColumns; + }; + // called from api + ColumnModel.prototype.sizeColumnsToFit = function (gridWidth, source, silent) { + if (source === void 0) { source = "sizeColumnsToFit"; } + // avoid divide by zero + var allDisplayedColumns = this.getAllDisplayedColumns(); + if (gridWidth <= 0 || !allDisplayedColumns.length) { + return; + } + var colsToSpread = []; + var colsToNotSpread = []; + allDisplayedColumns.forEach(function (column) { + if (column.getColDef().suppressSizeToFit === true) { + colsToNotSpread.push(column); + } + else { + colsToSpread.push(column); + } + }); + // make a copy of the cols that are going to be resized + var colsToFireEventFor = colsToSpread.slice(0); + var finishedResizing = false; + var moveToNotSpread = function (column) { + Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["removeFromArray"])(colsToSpread, column); + colsToNotSpread.push(column); + }; + // resetting cols to their original width makes the sizeColumnsToFit more deterministic, + // rather than depending on the current size of the columns. most users call sizeColumnsToFit + // immediately after grid is created, so will make no difference. however if application is calling + // sizeColumnsToFit repeatedly (eg after column group is opened / closed repeatedly) we don't want + // the columns to start shrinking / growing over time. + // + // NOTE: the process below will assign values to `this.actualWidth` of each column without firing events + // for this reason we need to manually fire resize events after the resize has been done for each column. + colsToSpread.forEach(function (column) { return column.resetActualWidth(source); }); + while (!finishedResizing) { + finishedResizing = true; + var availablePixels = gridWidth - this.getWidthOfColsInList(colsToNotSpread); + if (availablePixels <= 0) { + // no width, set everything to minimum + colsToSpread.forEach(function (column) { + column.setMinimum(source); + }); + } + else { + var scale = availablePixels / this.getWidthOfColsInList(colsToSpread); + // we set the pixels for the last col based on what's left, as otherwise + // we could be a pixel or two short or extra because of rounding errors. + var pixelsForLastCol = availablePixels; + // backwards through loop, as we are removing items as we go + for (var i = colsToSpread.length - 1; i >= 0; i--) { + var column = colsToSpread[i]; + var minWidth = column.getMinWidth(); + var maxWidth = column.getMaxWidth(); + var newWidth = Math.round(column.getActualWidth() * scale); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(minWidth) && newWidth < minWidth) { + newWidth = minWidth; + moveToNotSpread(column); + finishedResizing = false; + } + else if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(maxWidth) && column.isGreaterThanMax(newWidth)) { + newWidth = maxWidth; + moveToNotSpread(column); + finishedResizing = false; + } + else if (i === 0) { // if this is the last column + newWidth = pixelsForLastCol; + } + column.setActualWidth(newWidth, source, true); + pixelsForLastCol -= newWidth; + } + } + } + // see notes above + colsToFireEventFor.forEach(function (col) { + col.fireColumnWidthChangedEvent(source); + }); + this.setLeftValues(source); + this.updateBodyWidths(); + if (silent) { + return; + } + this.fireColumnResizedEvent(colsToFireEventFor, true, source); + }; + ColumnModel.prototype.buildDisplayedTrees = function (visibleColumns) { + var leftVisibleColumns = []; + var rightVisibleColumns = []; + var centerVisibleColumns = []; + visibleColumns.forEach(function (column) { + switch (column.getPinned()) { + case "left": + leftVisibleColumns.push(column); + break; + case "right": + rightVisibleColumns.push(column); + break; + default: + centerVisibleColumns.push(column); + break; + } + }); + var groupInstanceIdCreator = new _groupInstanceIdCreator__WEBPACK_IMPORTED_MODULE_5__["GroupInstanceIdCreator"](); + this.displayedTreeLeft = this.displayedGroupCreator.createDisplayedGroups(leftVisibleColumns, this.gridBalancedTree, groupInstanceIdCreator, _constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT, this.displayedTreeLeft); + this.displayedTreeRight = this.displayedGroupCreator.createDisplayedGroups(rightVisibleColumns, this.gridBalancedTree, groupInstanceIdCreator, _constants_constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT, this.displayedTreeRight); + this.displayedTreeCentre = this.displayedGroupCreator.createDisplayedGroups(centerVisibleColumns, this.gridBalancedTree, groupInstanceIdCreator, null, this.displayedTreeCentre); + this.updateDisplayedMap(); + }; + ColumnModel.prototype.updateDisplayedMap = function () { + var _this = this; + this.displayedColumnsAndGroupsMap = {}; + var func = function (child) { + _this.displayedColumnsAndGroupsMap[child.getUniqueId()] = child; + }; + this.columnUtils.depthFirstAllColumnTreeSearch(this.displayedTreeCentre, func); + this.columnUtils.depthFirstAllColumnTreeSearch(this.displayedTreeLeft, func); + this.columnUtils.depthFirstAllColumnTreeSearch(this.displayedTreeRight, func); + }; + ColumnModel.prototype.isDisplayed = function (item) { + var fromMap = this.displayedColumnsAndGroupsMap[item.getUniqueId()]; + // check for reference, in case new column / group with same id is now present + return fromMap === item; + }; + ColumnModel.prototype.updateOpenClosedVisibilityInColumnGroups = function () { + var allColumnGroups = this.getAllDisplayedTrees(); + this.columnUtils.depthFirstAllColumnTreeSearch(allColumnGroups, function (child) { + if (child instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) { + var columnGroup = child; + columnGroup.calculateDisplayedColumns(); + } + }); + }; + ColumnModel.prototype.getGroupAutoColumns = function () { + return this.groupAutoColumns; + }; + ColumnModel.prototype.createGroupAutoColumnsIfNeeded = function () { + if (!this.autoGroupsNeedBuilding) { + return; + } + this.autoGroupsNeedBuilding = false; + var groupFullWidthRow = this.gridOptionsWrapper.isGroupUseEntireRow(this.pivotMode); + // we need to allow suppressing auto-column separately for group and pivot as the normal situation + // is CSRM and user provides group column themselves for normal view, but when they go into pivot the + // columns are generated by the grid so no opportunity for user to provide group column. so need a way + // to suppress auto-col for grouping only, and not pivot. + // however if using Viewport RM or SSRM and user is providing the columns, the user may wish full control + // of the group column in this instance. + var suppressAutoColumn = this.pivotMode ? + this.gridOptionsWrapper.isPivotSuppressAutoColumn() : this.gridOptionsWrapper.isGroupSuppressAutoColumn(); + var groupingActive = this.rowGroupColumns.length > 0 || this.usingTreeData; + var needAutoColumns = groupingActive && !suppressAutoColumn && !groupFullWidthRow; + if (needAutoColumns) { + var newAutoGroupCols = this.autoGroupColService.createAutoGroupColumns(this.rowGroupColumns); + var autoColsDifferent = !this.autoColsEqual(newAutoGroupCols, this.groupAutoColumns); + // we force recreate when suppressColumnStateEvents changes, so new group cols pick up the new + // definitions. otherwise we could ignore the new cols because they appear to be the same. + if (autoColsDifferent || this.forceRecreateAutoGroups) { + this.groupAutoColumns = newAutoGroupCols; + } + } + else { + this.groupAutoColumns = null; + } + }; + ColumnModel.prototype.autoColsEqual = function (colsA, colsB) { + return Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["areEqual"])(colsA, colsB, function (a, b) { return a.getColId() === b.getColId(); }); + }; + ColumnModel.prototype.getWidthOfColsInList = function (columnList) { + return columnList.reduce(function (width, col) { return width + col.getActualWidth(); }, 0); + }; + ColumnModel.prototype.getGridBalancedTree = function () { + return this.gridBalancedTree; + }; + ColumnModel.prototype.hasFloatingFilters = function () { + if (!this.gridColumns) { + return false; + } + var res = this.gridColumns.some(function (col) { return col.getColDef().floatingFilter; }); + return res; + }; + ColumnModel.prototype.getFirstDisplayedColumn = function () { + var isRtl = this.gridOptionsWrapper.isEnableRtl(); + var queryOrder = [ + 'getDisplayedLeftColumns', + 'getDisplayedCenterColumns', + 'getDisplayedRightColumns' + ]; + if (isRtl) { + queryOrder.reverse(); + } + for (var i = 0; i < queryOrder.length; i++) { + var container = this[queryOrder[i]](); + if (container.length) { + return isRtl ? Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["last"])(container) : container[0]; + } + } + return null; + }; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('expressionService') + ], ColumnModel.prototype, "expressionService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('columnFactory') + ], ColumnModel.prototype, "columnFactory", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('displayedGroupCreator') + ], ColumnModel.prototype, "displayedGroupCreator", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('ctrlsService') + ], ColumnModel.prototype, "ctrlsService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('autoWidthCalculator') + ], ColumnModel.prototype, "autoWidthCalculator", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('columnUtils') + ], ColumnModel.prototype, "columnUtils", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('columnAnimationService') + ], ColumnModel.prototype, "columnAnimationService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('autoGroupColService') + ], ColumnModel.prototype, "autoGroupColService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Optional"])('aggFuncService') + ], ColumnModel.prototype, "aggFuncService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Optional"])('valueCache') + ], ColumnModel.prototype, "valueCache", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Optional"])('animationFrameService') + ], ColumnModel.prototype, "animationFrameService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('rowModel') + ], ColumnModel.prototype, "rowModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('columnApi') + ], ColumnModel.prototype, "columnApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('gridApi') + ], ColumnModel.prototype, "gridApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('sortController') + ], ColumnModel.prototype, "sortController", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('columnDefFactory') + ], ColumnModel.prototype, "columnDefFactory", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_6__["PostConstruct"] + ], ColumnModel.prototype, "init", null); + __decorate([ + __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Qualifier"])('loggerFactory')) + ], ColumnModel.prototype, "setBeans", null); + ColumnModel = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Bean"])('columnModel') + ], ColumnModel); + return ColumnModel; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"])); + + + +/***/ }), +/* 23 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(24); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Events", function() { return _eventKeys__WEBPACK_IMPORTED_MODULE_0__["Events"]; }); + +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ + + + +/***/ }), +/* 24 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Events", function() { return Events; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var Events = /** @class */ (function () { + function Events() { + } + /** Everything has changed with the columns. Either complete new set of columns set, or user called setState() */ + /** @deprecated - grid no longer uses this, and setSate() also fires individual events */ + Events.EVENT_COLUMN_EVERYTHING_CHANGED = 'columnEverythingChanged'; + /** User has set in new columns. */ + Events.EVENT_NEW_COLUMNS_LOADED = 'newColumnsLoaded'; + /** The pivot mode flag was changed */ + Events.EVENT_COLUMN_PIVOT_MODE_CHANGED = 'columnPivotModeChanged'; + /** A row group column was added, removed or order changed. */ + Events.EVENT_COLUMN_ROW_GROUP_CHANGED = 'columnRowGroupChanged'; + /** expandAll / collapseAll was called from the api. */ + Events.EVENT_EXPAND_COLLAPSE_ALL = 'expandOrCollapseAll'; + /** A pivot column was added, removed or order changed. */ + Events.EVENT_COLUMN_PIVOT_CHANGED = 'columnPivotChanged'; + /** The list of grid columns has changed. */ + Events.EVENT_GRID_COLUMNS_CHANGED = 'gridColumnsChanged'; + /** A value column was added, removed or agg function was changed. */ + Events.EVENT_COLUMN_VALUE_CHANGED = 'columnValueChanged'; + /** A column was moved */ + Events.EVENT_COLUMN_MOVED = 'columnMoved'; + /** One or more columns was shown / hidden */ + Events.EVENT_COLUMN_VISIBLE = 'columnVisible'; + /** One or more columns was pinned / unpinned*/ + Events.EVENT_COLUMN_PINNED = 'columnPinned'; + /** A column group was opened / closed */ + Events.EVENT_COLUMN_GROUP_OPENED = 'columnGroupOpened'; + /** One or more columns was resized. If just one, the column in the event is set. */ + Events.EVENT_COLUMN_RESIZED = 'columnResized'; + /** The list of displayed columns has changed, can result from columns open / close, column move, pivot, group, etc */ + Events.EVENT_DISPLAYED_COLUMNS_CHANGED = 'displayedColumnsChanged'; + /** The list of virtual columns has changed, results from viewport changing */ + Events.EVENT_VIRTUAL_COLUMNS_CHANGED = 'virtualColumnsChanged'; + /** Async Transactions Executed */ + Events.EVENT_ASYNC_TRANSACTIONS_FLUSHED = 'asyncTransactionsFlushed'; + /** A row group was opened / closed */ + Events.EVENT_ROW_GROUP_OPENED = 'rowGroupOpened'; + /** The client has set new data into the grid */ + Events.EVENT_ROW_DATA_CHANGED = 'rowDataChanged'; + /** The client has updated data for the grid */ + Events.EVENT_ROW_DATA_UPDATED = 'rowDataUpdated'; + /** The client has set new floating data into the grid */ + Events.EVENT_PINNED_ROW_DATA_CHANGED = 'pinnedRowDataChanged'; + /** Range selection has changed */ + Events.EVENT_RANGE_SELECTION_CHANGED = 'rangeSelectionChanged'; + /** Chart was created */ + Events.EVENT_CHART_CREATED = 'chartCreated'; + /** Chart Range selection has changed */ + Events.EVENT_CHART_RANGE_SELECTION_CHANGED = 'chartRangeSelectionChanged'; + /** Chart Options have changed */ + Events.EVENT_CHART_OPTIONS_CHANGED = 'chartOptionsChanged'; + /** Chart was destroyed */ + Events.EVENT_CHART_DESTROYED = 'chartDestroyed'; + /** For when the tool panel is shown / hidden */ + Events.EVENT_TOOL_PANEL_VISIBLE_CHANGED = 'toolPanelVisibleChanged'; + Events.EVENT_COLUMN_PANEL_ITEM_DRAG_START = 'columnPanelItemDragStart'; + Events.EVENT_COLUMN_PANEL_ITEM_DRAG_END = 'columnPanelItemDragEnd'; + /** Model was updated - grid updates the drawn rows when this happens */ + Events.EVENT_MODEL_UPDATED = 'modelUpdated'; + Events.EVENT_PASTE_START = 'pasteStart'; + Events.EVENT_PASTE_END = 'pasteEnd'; + Events.EVENT_FILL_START = 'fillStart'; + Events.EVENT_FILL_END = 'fillEnd'; + Events.EVENT_CELL_CLICKED = 'cellClicked'; + Events.EVENT_CELL_DOUBLE_CLICKED = 'cellDoubleClicked'; + Events.EVENT_CELL_MOUSE_DOWN = 'cellMouseDown'; + Events.EVENT_CELL_CONTEXT_MENU = 'cellContextMenu'; + Events.EVENT_CELL_VALUE_CHANGED = 'cellValueChanged'; + Events.EVENT_CELL_EDIT_REQUEST = 'cellEditRequest'; + Events.EVENT_ROW_VALUE_CHANGED = 'rowValueChanged'; + Events.EVENT_CELL_FOCUSED = 'cellFocused'; + Events.EVENT_ROW_SELECTED = 'rowSelected'; + Events.EVENT_SELECTION_CHANGED = 'selectionChanged'; + Events.EVENT_CELL_KEY_DOWN = 'cellKeyDown'; + Events.EVENT_CELL_KEY_PRESS = 'cellKeyPress'; + Events.EVENT_CELL_MOUSE_OVER = 'cellMouseOver'; + Events.EVENT_CELL_MOUSE_OUT = 'cellMouseOut'; + /** 2 events for filtering. The grid LISTENS for filterChanged and afterFilterChanged */ + Events.EVENT_FILTER_CHANGED = 'filterChanged'; + /** Filter was change but not applied. Only useful if apply buttons are used in filters. */ + Events.EVENT_FILTER_MODIFIED = 'filterModified'; + Events.EVENT_FILTER_OPENED = 'filterOpened'; + Events.EVENT_SORT_CHANGED = 'sortChanged'; + /** A row was removed from the dom, for any reason. Use to clean up resources (if any) used by the row. */ + Events.EVENT_VIRTUAL_ROW_REMOVED = 'virtualRowRemoved'; + Events.EVENT_ROW_CLICKED = 'rowClicked'; + Events.EVENT_ROW_DOUBLE_CLICKED = 'rowDoubleClicked'; + /** Gets called once after the grid has finished initialising. */ + Events.EVENT_GRID_READY = 'gridReady'; + /** Width of height of the main grid div has changed. Grid listens for this and does layout of grid if it's + * changed, so always filling the space it was given. */ + Events.EVENT_GRID_SIZE_CHANGED = 'gridSizeChanged'; + /** The indexes of the rows rendered has changed, eg user has scrolled to a new vertical position. */ + Events.EVENT_VIEWPORT_CHANGED = 'viewportChanged'; + /* The width of the scrollbar has been calculated */ + Events.EVENT_SCROLLBAR_WIDTH_CHANGED = 'scrollbarWidthChanged'; + /** Rows were rendered for the first time (ie on async data load). */ + Events.EVENT_FIRST_DATA_RENDERED = 'firstDataRendered'; + /** A column drag has started, either resizing a column or moving a column. */ + Events.EVENT_DRAG_STARTED = 'dragStarted'; + /** A column drag has stopped */ + Events.EVENT_DRAG_STOPPED = 'dragStopped'; + Events.EVENT_CHECKBOX_CHANGED = 'checkboxChanged'; + Events.EVENT_ROW_EDITING_STARTED = 'rowEditingStarted'; + Events.EVENT_ROW_EDITING_STOPPED = 'rowEditingStopped'; + Events.EVENT_CELL_EDITING_STARTED = 'cellEditingStarted'; + Events.EVENT_CELL_EDITING_STOPPED = 'cellEditingStopped'; + /** Main body of grid has scrolled, either horizontally or vertically */ + Events.EVENT_BODY_SCROLL = 'bodyScroll'; + /** Main body of the grid has stopped scrolling, either horizontally or vertically */ + Events.EVENT_BODY_SCROLL_END = 'bodyScrollEnd'; + Events.EVENT_HEIGHT_SCALE_CHANGED = 'heightScaleChanged'; + /** The displayed page for pagination has changed. For example the data was filtered or sorted, + * or the user has moved to a different page. */ + Events.EVENT_PAGINATION_CHANGED = 'paginationChanged'; + /** Only used by React, Angular, Web Components and VueJS AG Grid components + * (not used if doing plain JavaScript). If the grid receives changes due + * to bound properties, this event fires after the grid has finished processing the change. */ + Events.EVENT_COMPONENT_STATE_CHANGED = 'componentStateChanged'; + /***************************** INTERNAL EVENTS: START ******************************************* */ + /** Please remember to add to ComponentUtil.EXCLUDED_INTERNAL_EVENTS to not have these events exposed to framework components. */ + /** All items from here down are used internally by the grid, not intended for external use. */ + // not documented, either experimental, or we just don't want users using an depending on them + Events.EVENT_BODY_HEIGHT_CHANGED = 'bodyHeightChanged'; + Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED = 'displayedColumnsWidthChanged'; + Events.EVENT_SCROLL_VISIBILITY_CHANGED = 'scrollVisibilityChanged'; + Events.EVENT_COLUMN_HOVER_CHANGED = 'columnHoverChanged'; + Events.EVENT_FLASH_CELLS = 'flashCells'; + Events.EVENT_PAGINATION_PIXEL_OFFSET_CHANGED = 'paginationPixelOffsetChanged'; + Events.EVENT_DISPLAYED_ROWS_CHANGED = 'displayedRowsChanged'; + Events.EVENT_LEFT_PINNED_WIDTH_CHANGED = 'leftPinnedWidthChanged'; + Events.EVENT_RIGHT_PINNED_WIDTH_CHANGED = 'rightPinnedWidthChanged'; + Events.EVENT_ROW_CONTAINER_HEIGHT_CHANGED = 'rowContainerHeightChanged'; + Events.EVENT_ROW_DRAG_ENTER = 'rowDragEnter'; + Events.EVENT_ROW_DRAG_MOVE = 'rowDragMove'; + Events.EVENT_ROW_DRAG_LEAVE = 'rowDragLeave'; + Events.EVENT_ROW_DRAG_END = 'rowDragEnd'; + // primarily for charts + Events.EVENT_POPUP_TO_FRONT = 'popupToFront'; + // these are used for server side group and agg - only used by CS with Viewport Row Model - intention is + // to design these better around server side functions and then release to general public when fully working with + // all the row models. + Events.EVENT_COLUMN_ROW_GROUP_CHANGE_REQUEST = 'columnRowGroupChangeRequest'; + Events.EVENT_COLUMN_PIVOT_CHANGE_REQUEST = 'columnPivotChangeRequest'; + Events.EVENT_COLUMN_VALUE_CHANGE_REQUEST = 'columnValueChangeRequest'; + Events.EVENT_COLUMN_AGG_FUNC_CHANGE_REQUEST = 'columnAggFuncChangeRequest'; + Events.EVENT_KEYBOARD_FOCUS = 'keyboardFocus'; + Events.EVENT_MOUSE_FOCUS = 'mouseFocus'; + Events.EVENT_STORE_UPDATED = 'storeUpdated'; + return Events; +}()); + + + +/***/ }), +/* 25 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GroupInstanceIdCreator", function() { return GroupInstanceIdCreator; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +// class returns unique instance id's for columns. +// eg, the following calls (in this order) will result in: +// +// getInstanceIdForKey('country') => 0 +// getInstanceIdForKey('country') => 1 +// getInstanceIdForKey('country') => 2 +// getInstanceIdForKey('country') => 3 +// getInstanceIdForKey('age') => 0 +// getInstanceIdForKey('age') => 1 +// getInstanceIdForKey('country') => 4 +var GroupInstanceIdCreator = /** @class */ (function () { + function GroupInstanceIdCreator() { + // this map contains keys to numbers, so we remember what the last call was + this.existingIds = {}; + } + GroupInstanceIdCreator.prototype.getInstanceIdForKey = function (key) { + var lastResult = this.existingIds[key]; + var result; + if (typeof lastResult !== 'number') { + // first time this key + result = 0; + } + else { + result = lastResult + 1; + } + this.existingIds[key] = result; + return result; + }; + return GroupInstanceIdCreator; +}()); + + + +/***/ }), +/* 26 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "utf8_encode", function() { return utf8_encode; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "camelCaseToHyphen", function() { return camelCaseToHyphen; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "hyphenToCamelCase", function() { return hyphenToCamelCase; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "capitalise", function() { return capitalise; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "escapeString", function() { return escapeString; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "camelCaseToHumanText", function() { return camelCaseToHumanText; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var reUnescapedHtml = /[&<>"']/g; +/** + * HTML Escapes. + */ +var HTML_ESCAPES = { + '&': '&', + '<': '<', + '>': '>', + '"': '"', + "'": ''' +}; +/** + * It encodes any string in UTF-8 format + * taken from https://github.com/mathiasbynens/utf8.js + * @param {string} s + * @returns {string} + */ +function utf8_encode(s) { + var stringFromCharCode = String.fromCharCode; + function ucs2decode(string) { + var output = []; + if (!string) { + return []; + } + var len = string.length; + var counter = 0; + var value; + var extra; + while (counter < len) { + value = string.charCodeAt(counter++); + if (value >= 0xD800 && value <= 0xDBFF && counter < len) { + // high surrogate, and there is a next character + extra = string.charCodeAt(counter++); + if ((extra & 0xFC00) == 0xDC00) { // low surrogate + output.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000); + } + else { + // unmatched surrogate; only append this code unit, in case the next + // code unit is the high surrogate of a surrogate pair + output.push(value); + counter--; + } + } + else { + output.push(value); + } + } + return output; + } + function checkScalarValue(point) { + if (point >= 0xD800 && point <= 0xDFFF) { + throw Error('Lone surrogate U+' + point.toString(16).toUpperCase() + + ' is not a scalar value'); + } + } + function createByte(point, shift) { + return stringFromCharCode(((point >> shift) & 0x3F) | 0x80); + } + function encodeCodePoint(point) { + if ((point >= 0 && point <= 31 && point !== 10)) { + var convertedCode = point.toString(16).toUpperCase(); + var paddedCode = convertedCode.padStart(4, '0'); + return "_x" + paddedCode + "_"; + } + if ((point & 0xFFFFFF80) == 0) { // 1-byte sequence + return stringFromCharCode(point); + } + var symbol = ''; + if ((point & 0xFFFFF800) == 0) { // 2-byte sequence + symbol = stringFromCharCode(((point >> 6) & 0x1F) | 0xC0); + } + else if ((point & 0xFFFF0000) == 0) { // 3-byte sequence + checkScalarValue(point); + symbol = stringFromCharCode(((point >> 12) & 0x0F) | 0xE0); + symbol += createByte(point, 6); + } + else if ((point & 0xFFE00000) == 0) { // 4-byte sequence + symbol = stringFromCharCode(((point >> 18) & 0x07) | 0xF0); + symbol += createByte(point, 12); + symbol += createByte(point, 6); + } + symbol += stringFromCharCode((point & 0x3F) | 0x80); + return symbol; + } + var codePoints = ucs2decode(s); + var length = codePoints.length; + var index = -1; + var codePoint; + var byteString = ''; + while (++index < length) { + codePoint = codePoints[index]; + byteString += encodeCodePoint(codePoint); + } + return byteString; +} +/** + * Converts a camelCase string into hyphenated string + * from https://gist.github.com/youssman/745578062609e8acac9f + * @param {string} str + * @return {string} + */ +function camelCaseToHyphen(str) { + if (str === null || str === undefined) { + return null; + } + return str.replace(/([A-Z])/g, function (g) { return '-' + g[0].toLowerCase(); }); +} +/** + * Converts a hyphenated string into camelCase string + * from https://stackoverflow.com/questions/6660977/convert-hyphens-to-camel-case-camelcase + * @param {string} str + * @return {string} + */ +function hyphenToCamelCase(str) { + if (str === null || str === undefined) { + return null; + } + return str.replace(/-([a-z])/g, function (g) { return g[1].toUpperCase(); }); +} +function capitalise(str) { + return str[0].toUpperCase() + str.substr(1).toLowerCase(); +} +function escapeString(toEscape) { + // we call toString() twice, in case value is an object, where user provides + // a toString() method, and first call to toString() returns back something other + // than a string (eg a number to render) + return toEscape == null ? null : toEscape.toString().toString().replace(reUnescapedHtml, function (chr) { return HTML_ESCAPES[chr]; }); +} +/** + * Converts a camelCase string into regular text + * from: https://stackoverflow.com/questions/15369566/putting-space-in-camel-case-string-using-regular-expression + * @param {string} camelCase + * @return {string} + */ +function camelCaseToHumanText(camelCase) { + if (!camelCase || camelCase == null) { + return null; + } + var rex = /([A-Z])([A-Z])([a-z])|([a-z])([A-Z])/g; + var words = camelCase.replace(rex, '$1$4 $2$3$5').replace('.', ' ').split(' '); + return words.map(function (word) { return word.substring(0, 1).toUpperCase() + ((word.length > 1) ? word.substring(1, word.length) : ''); }).join(' '); +} + + +/***/ }), +/* 27 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "convertToMap", function() { return convertToMap; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "mapById", function() { return mapById; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "keys", function() { return keys; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +function convertToMap(arr) { + var map = new Map(); + arr.forEach(function (pair) { return map.set(pair[0], pair[1]); }); + return map; +} +// handy for organising a list into a map, where each item is mapped by an attribute, eg mapping Columns by ID +function mapById(arr, callback) { + var map = new Map(); + arr.forEach(function (item) { return map.set(callback(item), item); }); + return map; +} +function keys(map) { + var arr = []; + map.forEach(function (_, key) { return arr.push(key); }); + return arr; +} + + +/***/ }), +/* 28 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnUtils", function() { return ColumnUtils; }); +/* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(9); +/* harmony import */ var _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(8); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(20); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + +// takes in a list of columns, as specified by the column definitions, and returns column groups +var ColumnUtils = /** @class */ (function (_super) { + __extends(ColumnUtils, _super); + function ColumnUtils() { + return _super !== null && _super.apply(this, arguments) || this; + } + ColumnUtils.prototype.calculateColMinWidth = function (colDef) { + return colDef.minWidth != null ? colDef.minWidth : this.gridOptionsWrapper.getMinColWidth(); + }; + ColumnUtils.prototype.calculateColMaxWidth = function (colDef) { + return colDef.maxWidth != null ? colDef.maxWidth : (this.gridOptionsWrapper.getMaxColWidth() || Number.MAX_SAFE_INTEGER); + }; + ColumnUtils.prototype.calculateColInitialWidth = function (colDef) { + var minColWidth = this.calculateColMinWidth(colDef); + var maxColWidth = this.calculateColMaxWidth(colDef); + var width; + var colDefWidth = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_4__["attrToNumber"])(colDef.width); + var colDefInitialWidth = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_4__["attrToNumber"])(colDef.initialWidth); + if (colDefWidth != null) { + width = colDefWidth; + } + else if (colDefInitialWidth != null) { + width = colDefInitialWidth; + } + else { + width = this.gridOptionsWrapper.getColWidth(); + } + return Math.max(Math.min(width, maxColWidth), minColWidth); + }; + ColumnUtils.prototype.getOriginalPathForColumn = function (column, originalBalancedTree) { + var result = []; + var found = false; + var recursePath = function (balancedColumnTree, dept) { + for (var i = 0; i < balancedColumnTree.length; i++) { + if (found) { + return; + } + // quit the search, so 'result' is kept with the found result + var node = balancedColumnTree[i]; + if (node instanceof _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_1__["ProvidedColumnGroup"]) { + var nextNode = node; + recursePath(nextNode.getChildren(), dept + 1); + result[dept] = node; + } + else if (node === column) { + found = true; + } + } + }; + recursePath(originalBalancedTree, 0); + // we should always find the path, but in case there is a bug somewhere, returning null + // will make it fail rather than provide a 'hard to track down' bug + return found ? result : null; + }; + ColumnUtils.prototype.depthFirstOriginalTreeSearch = function (parent, tree, callback) { + var _this = this; + if (!tree) { + return; + } + tree.forEach(function (child) { + if (child instanceof _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_1__["ProvidedColumnGroup"]) { + _this.depthFirstOriginalTreeSearch(child, child.getChildren(), callback); + } + callback(child, parent); + }); + }; + ColumnUtils.prototype.depthFirstAllColumnTreeSearch = function (tree, callback) { + var _this = this; + if (!tree) { + return; + } + tree.forEach(function (child) { + if (child instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) { + _this.depthFirstAllColumnTreeSearch(child.getChildren(), callback); + } + callback(child); + }); + }; + ColumnUtils.prototype.depthFirstDisplayedColumnTreeSearch = function (tree, callback) { + var _this = this; + if (!tree) { + return; + } + tree.forEach(function (child) { + if (child instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) { + _this.depthFirstDisplayedColumnTreeSearch(child.getDisplayedChildren(), callback); + } + callback(child); + }); + }; + ColumnUtils = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Bean"])('columnUtils') + ], ColumnUtils); + return ColumnUtils; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"])); + + + +/***/ }), +/* 29 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DisplayedGroupCreator", function() { return DisplayedGroupCreator; }); +/* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(9); +/* harmony import */ var _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(8); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(20); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(18); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + +// takes in a list of columns, as specified by the column definitions, and returns column groups +var DisplayedGroupCreator = /** @class */ (function (_super) { + __extends(DisplayedGroupCreator, _super); + function DisplayedGroupCreator() { + return _super !== null && _super.apply(this, arguments) || this; + } + DisplayedGroupCreator.prototype.createDisplayedGroups = function ( + // all displayed columns sorted - this is the columns the grid should show + sortedVisibleColumns, + // the tree of columns, as provided by the users, used to know what groups columns roll up into + balancedColumnTree, + // creates unique id's for the group + groupInstanceIdCreator, + // whether it's left, right or center col + pinned, + // we try to reuse old groups if we can, to allow gui to do animation + oldDisplayedGroups) { + var _this = this; + var result = []; + var previousRealPath; + var previousOriginalPath; + var oldColumnsMapped = this.mapOldGroupsById(oldDisplayedGroups); + // go through each column, then do a bottom up comparison to the previous column, and start + // to share groups if they converge at any point. + sortedVisibleColumns.forEach(function (currentColumn) { + var currentOriginalPath = _this.getOriginalPathForColumn(balancedColumnTree, currentColumn); + var currentRealPath = []; + var firstColumn = !previousOriginalPath; + for (var i = 0; i < currentOriginalPath.length; i++) { + if (firstColumn || currentOriginalPath[i] !== previousOriginalPath[i]) { + // new group needed + var newGroup = _this.createColumnGroup(currentOriginalPath[i], groupInstanceIdCreator, oldColumnsMapped, pinned); + currentRealPath[i] = newGroup; + // if top level, add to result, otherwise add to parent + if (i == 0) { + result.push(newGroup); + } + else { + currentRealPath[i - 1].addChild(newGroup); + } + } + else { + // reuse old group + currentRealPath[i] = previousRealPath[i]; + } + } + var noColumnGroups = currentRealPath.length === 0; + if (noColumnGroups) { + // if we are not grouping, then the result of the above is an empty + // path (no groups), and we just add the column to the root list. + result.push(currentColumn); + } + else { + var leafGroup = Object(_utils_array__WEBPACK_IMPORTED_MODULE_4__["last"])(currentRealPath); + leafGroup.addChild(currentColumn); + } + previousRealPath = currentRealPath; + previousOriginalPath = currentOriginalPath; + }); + this.setupParentsIntoColumns(result, null); + return result; + }; + DisplayedGroupCreator.prototype.createColumnGroup = function (providedGroup, groupInstanceIdCreator, oldColumnsMapped, pinned) { + var groupId = providedGroup.getGroupId(); + var instanceId = groupInstanceIdCreator.getInstanceIdForKey(groupId); + var uniqueId = _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"].createUniqueId(groupId, instanceId); + var columnGroup = oldColumnsMapped[uniqueId]; + // if the user is setting new colDefs, it is possible that the id's overlap, and we + // would have a false match from above. so we double check we are talking about the + // same original column group. + if (columnGroup && columnGroup.getProvidedColumnGroup() !== providedGroup) { + columnGroup = null; + } + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["exists"])(columnGroup)) { + // clean out the old column group here, as we will be adding children into it again + columnGroup.reset(); + } + else { + columnGroup = new _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"](providedGroup, groupId, instanceId, pinned); + this.context.createBean(columnGroup); + } + return columnGroup; + }; + // returns back a 2d map of ColumnGroup as follows: groupId -> instanceId -> ColumnGroup + DisplayedGroupCreator.prototype.mapOldGroupsById = function (displayedGroups) { + var result = {}; + var recursive = function (columnsOrGroups) { + columnsOrGroups.forEach(function (columnOrGroup) { + if (columnOrGroup instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) { + var columnGroup = columnOrGroup; + result[columnOrGroup.getUniqueId()] = columnGroup; + recursive(columnGroup.getChildren()); + } + }); + }; + if (displayedGroups) { + recursive(displayedGroups); + } + return result; + }; + DisplayedGroupCreator.prototype.setupParentsIntoColumns = function (columnsOrGroups, parent) { + var _this = this; + columnsOrGroups.forEach(function (columnsOrGroup) { + columnsOrGroup.setParent(parent); + if (columnsOrGroup instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) { + var columnGroup = columnsOrGroup; + _this.setupParentsIntoColumns(columnGroup.getChildren(), columnGroup); + } + }); + }; + DisplayedGroupCreator.prototype.getOriginalPathForColumn = function (balancedColumnTree, column) { + var result = []; + var found = false; + var recursePath = function (columnTree, dept) { + for (var i = 0; i < columnTree.length; i++) { + // quit the search, so 'result' is kept with the found result + if (found) { + return; + } + var node = columnTree[i]; + if (node instanceof _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_1__["ProvidedColumnGroup"]) { + var nextNode = node; + recursePath(nextNode.getChildren(), dept + 1); + result[dept] = node; + } + else if (node === column) { + found = true; + } + } + }; + recursePath(balancedColumnTree, 0); + // it's possible we didn't find a path. this happens if the column is generated + // by the grid (auto-group), in that the definition didn't come from the client. in this case, + // we create a fake original path. + if (found) { + return result; + } + console.warn('AG Grid: could not get path'); + return null; + }; + DisplayedGroupCreator = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Bean"])('displayedGroupCreator') + ], DisplayedGroupCreator); + return DisplayedGroupCreator; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"])); + + + +/***/ }), +/* 30 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ComponentUtil", function() { return ComponentUtil; }); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(23); +/* harmony import */ var _propertyKeys__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(31); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(13); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(18); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __assign = (undefined && undefined.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; +}; +var __spread = (undefined && undefined.__spread) || function () { + for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); + return ar; +}; + + + + + +var ComponentUtil = /** @class */ (function () { + function ComponentUtil() { + } + ComponentUtil.getEventCallbacks = function () { + if (!ComponentUtil.EVENT_CALLBACKS) { + ComponentUtil.EVENT_CALLBACKS = ComponentUtil.EVENTS.map(function (event) { return ComponentUtil.getCallbackForEvent(event); }); + } + return ComponentUtil.EVENT_CALLBACKS; + }; + ComponentUtil.copyAttributesToGridOptions = function (gridOptions, component, skipEventDeprecationCheck) { + if (skipEventDeprecationCheck === void 0) { skipEventDeprecationCheck = false; } + // create empty grid options if none were passed + if (typeof gridOptions !== 'object') { + gridOptions = {}; + } + // to allow array style lookup in TypeScript, take type away from 'this' and 'gridOptions' + var pGridOptions = gridOptions; + var keyExists = function (key) { return typeof component[key] !== 'undefined'; }; + // add in all the simple properties + __spread(ComponentUtil.ARRAY_PROPERTIES, ComponentUtil.STRING_PROPERTIES, ComponentUtil.OBJECT_PROPERTIES, ComponentUtil.FUNCTION_PROPERTIES, ComponentUtil.getEventCallbacks()).filter(keyExists) + .forEach(function (key) { return pGridOptions[key] = component[key]; }); + ComponentUtil.BOOLEAN_PROPERTIES + .filter(keyExists) + .forEach(function (key) { return pGridOptions[key] = ComponentUtil.toBoolean(component[key]); }); + ComponentUtil.NUMBER_PROPERTIES + .filter(keyExists) + .forEach(function (key) { return pGridOptions[key] = ComponentUtil.toNumber(component[key]); }); + return gridOptions; + }; + ComponentUtil.getCallbackForEvent = function (eventName) { + if (!eventName || eventName.length < 2) { + return eventName; + } + return 'on' + eventName[0].toUpperCase() + eventName.substr(1); + }; + ComponentUtil.processOnChange = function (changes, gridOptions, api, columnApi) { + if (!changes) { + return; + } + var changesToApply = __assign({}, changes); + // to allow array style lookup in TypeScript, take type away from 'this' and 'gridOptions' + var pGridOptions = gridOptions; + var keyExists = function (key) { return changesToApply[key]; }; + // check if any change for the simple types, and if so, then just copy in the new value + __spread(ComponentUtil.ARRAY_PROPERTIES, ComponentUtil.OBJECT_PROPERTIES, ComponentUtil.STRING_PROPERTIES, ComponentUtil.getEventCallbacks()).filter(keyExists) + .forEach(function (key) { return pGridOptions[key] = changesToApply[key].currentValue; }); + ComponentUtil.BOOLEAN_PROPERTIES + .filter(keyExists) + .forEach(function (key) { return pGridOptions[key] = ComponentUtil.toBoolean(changesToApply[key].currentValue); }); + ComponentUtil.NUMBER_PROPERTIES + .filter(keyExists) + .forEach(function (key) { return pGridOptions[key] = ComponentUtil.toNumber(changesToApply[key].currentValue); }); + if (changesToApply.enableCellTextSelection) { + api.setEnableCellTextSelection(ComponentUtil.toBoolean(changesToApply.enableCellTextSelection.currentValue)); + delete changesToApply.enableCellTextSelection; + } + if (changesToApply.quickFilterText) { + api.setQuickFilter(changesToApply.quickFilterText.currentValue); + delete changesToApply.quickFilterText; + } + if (changesToApply.autoGroupColumnDef) { + api.setAutoGroupColumnDef(changesToApply.autoGroupColumnDef.currentValue, "gridOptionsChanged"); + delete changesToApply.autoGroupColumnDef; + } + if (changesToApply.columnDefs) { + api.setColumnDefs(changesToApply.columnDefs.currentValue, "gridOptionsChanged"); + delete changesToApply.columnDefs; + } + if (changesToApply.defaultColDef) { + api.setDefaultColDef(changesToApply.defaultColDef.currentValue, "gridOptionsChanged"); + delete changesToApply.defaultColDef; + } + if (changesToApply.paginationPageSize) { + api.paginationSetPageSize(ComponentUtil.toNumber(changesToApply.paginationPageSize.currentValue)); + delete changesToApply.paginationPageSize; + } + if (changesToApply.pivotMode) { + columnApi.setPivotMode(ComponentUtil.toBoolean(changesToApply.pivotMode.currentValue)); + delete changesToApply.pivotMode; + } + if (changesToApply.groupRemoveSingleChildren) { + api.setGroupRemoveSingleChildren(ComponentUtil.toBoolean(changesToApply.groupRemoveSingleChildren.currentValue)); + delete changesToApply.groupRemoveSingleChildren; + } + if (changesToApply.suppressRowDrag) { + api.setSuppressRowDrag(ComponentUtil.toBoolean(changesToApply.suppressRowDrag.currentValue)); + delete changesToApply.suppressRowDrag; + } + if (changesToApply.suppressMoveWhenRowDragging) { + api.setSuppressMoveWhenRowDragging(ComponentUtil.toBoolean(changesToApply.suppressMoveWhenRowDragging.currentValue)); + delete changesToApply.suppressMoveWhenRowDragging; + } + if (changesToApply.suppressRowClickSelection) { + api.setSuppressRowClickSelection(ComponentUtil.toBoolean(changesToApply.suppressRowClickSelection.currentValue)); + delete changesToApply.suppressRowClickSelection; + } + if (changesToApply.suppressClipboardPaste) { + api.setSuppressClipboardPaste(ComponentUtil.toBoolean(changesToApply.suppressClipboardPaste.currentValue)); + delete changesToApply.suppressClipboardPaste; + } + if (changesToApply.headerHeight) { + api.setHeaderHeight(ComponentUtil.toNumber(changesToApply.headerHeight.currentValue)); + delete changesToApply.headerHeight; + } + // any remaining properties can be set in a generic way + // ie the setter takes the form of setXXX and the argument requires no formatting/translation first + var dynamicApi = api; + Object.keys(changesToApply) + .forEach(function (property) { + var setterName = "set" + property.charAt(0).toUpperCase() + property.substring(1); + if (dynamicApi[setterName]) { + dynamicApi[setterName](changes[property].currentValue); + } + }); + // copy changes into an event for dispatch + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COMPONENT_STATE_CHANGED, + api: gridOptions.api, + columnApi: gridOptions.columnApi + }; + Object(_utils_object__WEBPACK_IMPORTED_MODULE_2__["iterateObject"])(changes, function (key, value) { + event[key] = value; + }); + api.dispatchEvent(event); + }; + ComponentUtil.toBoolean = function (value) { + if (typeof value === 'boolean') { + return value; + } + if (typeof value === 'string') { + // for boolean, compare to empty String to allow attributes appearing with + // no value to be treated as 'true' + return value.toUpperCase() === 'TRUE' || value == ''; + } + return false; + }; + ComponentUtil.toNumber = function (value) { + if (typeof value === 'number') { + return value; + } + if (typeof value === 'string') { + return Number(value); + } + }; + // all the events are populated in here AFTER this class (at the bottom of the file). + ComponentUtil.EVENTS = []; + // events that are available for use by users of AG Grid and so should be documented + ComponentUtil.PUBLIC_EVENTS = []; + // events that are internal to AG Grid and should not be exposed to users via documentation or generated framework components + ComponentUtil.EXCLUDED_INTERNAL_EVENTS = []; + ComponentUtil.STRING_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].STRING_PROPERTIES; + ComponentUtil.OBJECT_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].OBJECT_PROPERTIES; + ComponentUtil.ARRAY_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].ARRAY_PROPERTIES; + ComponentUtil.NUMBER_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].NUMBER_PROPERTIES; + ComponentUtil.BOOLEAN_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].BOOLEAN_PROPERTIES; + ComponentUtil.FUNCTION_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].FUNCTION_PROPERTIES; + ComponentUtil.ALL_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].ALL_PROPERTIES; + return ComponentUtil; +}()); + +ComponentUtil.EVENTS = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_4__["values"])(_events__WEBPACK_IMPORTED_MODULE_0__["Events"]); +/** Exclude the following internal events from code generation to prevent exposing these events via framework components */ +ComponentUtil.EXCLUDED_INTERNAL_EVENTS = [ + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_SCROLLBAR_WIDTH_CHANGED, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_CHECKBOX_CHANGED, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_HEIGHT_SCALE_CHANGED, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_BODY_HEIGHT_CHANGED, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_SCROLL_VISIBILITY_CHANGED, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_HOVER_CHANGED, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_FLASH_CELLS, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_PAGINATION_PIXEL_OFFSET_CHANGED, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_DISPLAYED_ROWS_CHANGED, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_LEFT_PINNED_WIDTH_CHANGED, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_RIGHT_PINNED_WIDTH_CHANGED, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_ROW_CONTAINER_HEIGHT_CHANGED, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_POPUP_TO_FRONT, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_KEYBOARD_FOCUS, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_MOUSE_FOCUS, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_STORE_UPDATED, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PANEL_ITEM_DRAG_START, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PANEL_ITEM_DRAG_END, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_FILL_START, + _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_FILL_END, +]; +/** EVENTS that should be exposed via code generation for the framework components. */ +ComponentUtil.PUBLIC_EVENTS = ComponentUtil.EVENTS.filter(function (e) { return !Object(_utils_array__WEBPACK_IMPORTED_MODULE_3__["includes"])(ComponentUtil.EXCLUDED_INTERNAL_EVENTS, e); }); + + +/***/ }), +/* 31 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PropertyKeys", function() { return PropertyKeys; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; +}; +var __spread = (undefined && undefined.__spread) || function () { + for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); + return ar; +}; +/** + * These keys are used for validating properties supplied on a gridOptions object, and for code generation. + * If you change the properties on the gridOptions interface, you *must* update this file as well to be consistent. + */ +var PropertyKeys = /** @class */ (function () { + function PropertyKeys() { + } + PropertyKeys.STRING_PROPERTIES = [ + 'sortingOrder', 'rowClass', 'rowSelection', 'overlayLoadingTemplate', 'overlayNoRowsTemplate', + 'quickFilterText', 'rowModelType', 'editType', 'domLayout', 'clipboardDelimiter', 'rowGroupPanelShow', + 'multiSortKey', 'pivotColumnGroupTotals', 'pivotRowTotals', 'pivotPanelShow', 'fillHandleDirection', + 'serverSideStoreType', 'groupDisplayType', 'treeDataDisplayType' + ]; + PropertyKeys.OBJECT_PROPERTIES = [ + 'components', 'frameworkComponents', 'rowStyle', 'context', 'autoGroupColumnDef', 'localeText', 'icons', + 'datasource', 'serverSideDatasource', 'viewportDatasource', 'groupRowRendererParams', 'aggFuncs', 'fullWidthCellRendererParams', + 'defaultColGroupDef', 'defaultColDef', 'defaultExportParams', 'defaultCsvExportParams', 'defaultExcelExportParams', 'columnTypes', + 'rowClassRules', 'detailCellRendererParams', 'loadingCellRendererParams', 'loadingOverlayComponentParams', + 'noRowsOverlayComponentParams', 'popupParent', 'colResizeDefault', 'statusBar', 'sideBar', 'chartThemeOverrides', + 'customChartThemes' + ]; + PropertyKeys.ARRAY_PROPERTIES = [ + 'alignedGrids', 'rowData', 'columnDefs', 'excelStyles', 'pinnedTopRowData', 'pinnedBottomRowData', 'chartThemes' + ]; + PropertyKeys.NUMBER_PROPERTIES = [ + 'rowHeight', 'detailRowHeight', 'rowBuffer', 'colWidth', 'headerHeight', 'groupHeaderHeight', 'floatingFiltersHeight', + 'pivotHeaderHeight', 'pivotGroupHeaderHeight', 'groupDefaultExpanded', 'minColWidth', 'maxColWidth', 'viewportRowModelPageSize', + 'viewportRowModelBufferSize', 'autoSizePadding', 'maxBlocksInCache', 'maxConcurrentDatasourceRequests', 'tooltipShowDelay', + 'tooltipHideDelay', 'cacheOverflowSize', 'paginationPageSize', 'cacheBlockSize', 'infiniteInitialRowCount', 'scrollbarWidth', + 'batchUpdateWaitMillis', 'asyncTransactionWaitMillis', 'blockLoadDebounceMillis', 'keepDetailRowsCount', + 'undoRedoCellEditingLimit', 'cellFlashDelay', 'cellFadeDelay', 'tabIndex' + ]; + PropertyKeys.BOOLEAN_PROPERTIES = [ + 'suppressMakeColumnVisibleAfterUnGroup', 'suppressRowClickSelection', 'suppressCellSelection', 'suppressCellFocus', 'suppressHorizontalScroll', + 'alwaysShowHorizontalScroll', 'alwaysShowVerticalScroll', 'debug', 'enableBrowserTooltips', 'enableCellExpressions', + 'angularCompileRows', 'angularCompileFilters', 'groupSuppressAutoColumn', 'groupSelectsChildren', 'groupIncludeFooter', + 'groupIncludeTotalFooter', 'groupUseEntireRow', 'groupSuppressBlankHeader', 'suppressMenuHide', 'suppressRowDeselection', + 'unSortIcon', 'suppressMultiSort', 'singleClickEdit', 'suppressLoadingOverlay', 'suppressNoRowsOverlay', 'suppressAutoSize', + 'skipHeaderOnAutoSize', 'suppressParentsInRowNodes', 'suppressColumnMoveAnimation', 'suppressMovableColumns', + 'suppressFieldDotNotation', 'enableRangeSelection', 'enableRangeHandle', 'enableFillHandle', 'suppressClearOnFillReduction', + 'deltaSort', 'suppressTouch', 'suppressAsyncEvents', 'allowContextMenuWithControlKey', 'suppressContextMenu', + 'rememberGroupStateWhenNewData', 'enableCellChangeFlash', 'suppressDragLeaveHidesColumns', 'suppressMiddleClickScrolls', + 'suppressPreventDefaultOnMouseWheel', 'suppressCopyRowsToClipboard', 'copyHeadersToClipboard', 'copyGroupHeadersToClipboard', + 'pivotMode', 'suppressAggFuncInHeader', 'suppressColumnVirtualisation', 'suppressAggAtRootLevel', 'suppressFocusAfterRefresh', + 'functionsPassive', 'functionsReadOnly', 'animateRows', 'groupSelectsFiltered', 'groupRemoveSingleChildren', + 'groupRemoveLowestSingleChildren', 'enableRtl', 'suppressClickEdit', 'rowDragEntireRow', 'rowDragManaged', 'suppressRowDrag', + 'suppressMoveWhenRowDragging', 'rowDragMultiRow', 'enableGroupEdit', 'embedFullWidthRows', 'deprecatedEmbedFullWidthRows', + 'suppressPaginationPanel', 'groupHideOpenParents', 'groupMultiAutoColumn', 'pagination', + 'stopEditingWhenGridLosesFocus', 'paginationAutoPageSize', 'suppressScrollOnNewData', 'suppressScrollWhenPopupsAreOpen', + 'purgeClosedRowNodes', 'cacheQuickFilter', 'deltaRowDataMode', 'ensureDomOrder', 'accentedSort', 'suppressChangeDetection', + 'valueCache', 'valueCacheNeverExpires', 'aggregateOnlyChangedColumns', 'suppressAnimationFrame', 'suppressExcelExport', + 'suppressCsvExport', 'treeData', 'masterDetail', 'suppressMultiRangeSelection', 'enterMovesDownAfterEdit', 'enterMovesDown', + 'suppressPropertyNamesCheck', 'rowMultiSelectWithClick', 'suppressEnterpriseResetOnNewColumns', + 'suppressRowHoverHighlight', 'suppressRowTransform', 'suppressClipboardPaste', 'suppressLastEmptyLineOnPaste', + 'serverSideSortingAlwaysResets', 'suppressSetColumnStateEvents', 'suppressColumnStateEvents', 'enableCharts', 'deltaColumnMode', + 'suppressMaintainUnsortedOrder', 'enableCellTextSelection', 'suppressBrowserResizeObserver', 'suppressMaxRenderedRowRestriction', + 'excludeChildrenWhenTreeDataFiltering', 'tooltipMouseTrack', 'keepDetailRows', 'paginateChildRows', 'preventDefaultOnContextMenu', + 'undoRedoCellEditing', 'allowDragFromColumnsToolPanel', 'immutableData', 'immutableColumns', 'pivotSuppressAutoColumn', + 'suppressExpandablePivotGroups', 'applyColumnDefOrder', 'debounceVerticalScrollbar', 'detailRowAutoHeight', + 'serverSideFilteringAlwaysResets', 'suppressAggFilteredOnly', 'showOpenedGroup', 'suppressClipboardApi', + 'suppressModelUpdateAfterUpdateTransaction', 'stopEditingWhenCellsLoseFocus', 'maintainColumnOrder', 'groupMaintainOrder', + 'columnHoverHighlight', 'reactUi', 'suppressReactUi', 'readOnlyEdit', 'suppressRowVirtualisation' + ]; + /** You do not need to include event callbacks in this list, as they are generated automatically. */ + PropertyKeys.FUNCTION_PROPERTIES = [ + 'localeTextFunc', 'groupRowInnerRenderer', 'groupRowInnerRendererFramework', + 'groupRowRenderer', 'groupRowRendererFramework', 'isExternalFilterPresent', 'getRowHeight', 'doesExternalFilterPass', + 'getRowClass', 'getRowStyle', 'getContextMenuItems', 'getMainMenuItems', 'processRowPostCreate', 'processCellForClipboard', + 'groupRowAggNodes', 'getRowNodeId', 'isFullWidthCell', 'fullWidthCellRenderer', 'fullWidthCellRendererFramework', + 'processSecondaryColDef', 'processSecondaryColGroupDef', 'getBusinessKeyForNode', 'sendToClipboard', 'navigateToNextHeader', + 'tabToNextHeader', 'navigateToNextCell', 'tabToNextCell', 'processCellFromClipboard', 'getDocument', 'postProcessPopup', + 'getChildCount', 'getDataPath', 'loadingCellRenderer', 'loadingCellRendererFramework', 'loadingOverlayComponent', + 'loadingOverlayComponentFramework', 'noRowsOverlayComponent', 'noRowsOverlayComponentFramework', 'detailCellRenderer', + 'detailCellRendererFramework', 'isRowMaster', 'isRowSelectable', 'postSort', 'processHeaderForClipboard', 'processGroupHeaderForClipboard', + 'paginationNumberFormatter', 'processDataFromClipboard', 'getServerSideGroupKey', 'isServerSideGroup', 'suppressKeyboardEvent', + 'createChartContainer', 'getChartToolbarItems', 'fillOperation', 'isApplyServerSideTransaction', 'getServerSideStoreParams', + 'isServerSideGroupOpenByDefault', 'isGroupOpenByDefault', 'defaultGroupSortComparator', 'defaultGroupOrderComparator', + 'loadingCellRendererSelector', 'getRowId' + ]; + PropertyKeys.ALL_PROPERTIES = __spread(PropertyKeys.ARRAY_PROPERTIES, PropertyKeys.OBJECT_PROPERTIES, PropertyKeys.STRING_PROPERTIES, PropertyKeys.NUMBER_PROPERTIES, PropertyKeys.FUNCTION_PROPERTIES, PropertyKeys.BOOLEAN_PROPERTIES); + /** + * Used when performing property checks. This avoids noise caused when using frameworks, which can add their own + * framework-specific properties to colDefs, gridOptions etc. + */ + PropertyKeys.FRAMEWORK_PROPERTIES = [ + '__ob__', '__v_skip', '__metadata__', 'mappedColumnProperties', 'hasChildColumns', 'toColDef', 'createColDefFromGridColumn' + ]; + return PropertyKeys; +}()); + + + +/***/ }), +/* 32 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgStackComponentsRegistry", function() { return AgStackComponentsRegistry; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + +var AgStackComponentsRegistry = /** @class */ (function (_super) { + __extends(AgStackComponentsRegistry, _super); + function AgStackComponentsRegistry() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.componentsMappedByName = {}; + return _this; + } + AgStackComponentsRegistry.prototype.setupComponents = function (components) { + var _this = this; + if (components) { + components.forEach(function (componentMeta) { return _this.addComponent(componentMeta); }); + } + }; + AgStackComponentsRegistry.prototype.addComponent = function (componentMeta) { + // get name of the class as a string + // let className = getNameOfClass(ComponentClass); + // insert a dash after every capital letter + // let classEscaped = className.replace(/([A-Z])/g, "-$1").toLowerCase(); + var classEscaped = componentMeta.componentName.replace(/([a-z])([A-Z])/g, "$1-$2").toLowerCase(); + // put all to upper case + var classUpperCase = classEscaped.toUpperCase(); + // finally store + this.componentsMappedByName[classUpperCase] = componentMeta.componentClass; + }; + AgStackComponentsRegistry.prototype.getComponentClass = function (htmlTag) { + return this.componentsMappedByName[htmlTag]; + }; + AgStackComponentsRegistry = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('agStackComponentsRegistry') + ], AgStackComponentsRegistry); + return AgStackComponentsRegistry; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + + + +/***/ }), +/* 33 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColDefUtil", function() { return ColDefUtil; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; +}; +var __spread = (undefined && undefined.__spread) || function () { + for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); + return ar; +}; +var ColDefUtil = /** @class */ (function () { + function ColDefUtil() { + } + ColDefUtil.STRING_PROPERTIES = [ + 'headerName', + 'columnGroupShow', + 'headerClass', + 'toolPanelClass', + 'headerValueGetter', + 'pivotKeys', + 'groupId', + 'colId', + 'sort', + 'initialSort', + 'field', + 'type', + 'tooltipComponent', + 'tooltipField', + 'headerTooltip', + 'cellClass', + 'showRowGroup', + 'template', + 'templateUrl', + 'filter', + 'initialAggFunc', + 'aggFunc', + 'pinned', + 'initialPinned', + 'chartDataType', + 'cellEditorPopupPosition' + ]; + ColDefUtil.OBJECT_PROPERTIES = [ + 'headerGroupComponent', + 'headerGroupComponentFramework', + 'headerGroupComponentParams', + 'cellStyle', + 'cellRenderer', + 'cellRendererParams', + 'cellRendererFramework', + 'cellEditor', + 'cellEditorFramework', + 'cellEditorParams', + 'pinnedRowCellRendererFramework', + 'pinnedRowCellRendererParams', + 'filterFramework', + 'filterParams', + 'pivotValueColumn', + 'headerComponent', + 'headerComponentFramework', + 'headerComponentParams', + 'floatingFilterComponent', + 'floatingFilterComponentParams', + 'floatingFilterComponentFramework', + 'floatingFilterFramework', + 'tooltipComponent', + 'tooltipComponentParams', + 'tooltipComponentFramework', + 'refData', + 'columnsMenuParams' + ]; + ColDefUtil.ARRAY_PROPERTIES = [ + 'children', + 'sortingOrder', + 'allowedAggFuncs', + 'menuTabs', + 'pivotTotalColumnIds', + 'cellClassRules', + 'icons' + ]; + ColDefUtil.NUMBER_PROPERTIES = [ + 'sortedAt', + 'sortIndex', + 'initialSortIndex', + 'flex', + 'initialFlex', + 'width', + 'initialWidth', + 'minWidth', + 'maxWidth', + 'rowGroupIndex', + 'initialRowGroupIndex', + 'pivotIndex', + 'initialPivotIndex' + ]; + ColDefUtil.BOOLEAN_PROPERTIES = [ + 'suppressCellFlash', + 'suppressColumnsToolPanel', + 'suppressFiltersToolPanel', + 'openByDefault', + 'marryChildren', + 'hide', + 'initialHide', + 'rowGroup', + 'initialRowGroup', + 'pivot', + 'initialPivot', + 'checkboxSelection', + 'headerCheckboxSelection', + 'headerCheckboxSelectionFilteredOnly', + 'suppressMenu', + 'suppressMovable', + 'lockPosition', + 'lockVisible', + 'lockPinned', + 'unSortIcon', + 'suppressSizeToFit', + 'suppressAutoSize', + 'enableRowGroup', + 'enablePivot', + 'enableValue', + 'editable', + 'suppressPaste', + 'suppressNavigable', + 'enableCellChangeFlash', + 'rowDrag', + 'dndSource', + 'autoHeight', + 'wrapText', + 'sortable', + 'resizable', + 'singleClickEdit', + 'floatingFilter', + 'cellEditorPopup', + 'suppressFillHandle' + ]; + ColDefUtil.FUNCTION_PROPERTIES = [ + 'dndSourceOnRowDrag', + 'valueGetter', + 'valueSetter', + 'filterValueGetter', + 'keyCreator', + 'pinnedRowCellRenderer', + 'valueFormatter', + 'pinnedRowValueFormatter', + 'valueParser', + 'comparator', + 'equals', + 'pivotComparator', + 'suppressKeyboardEvent', + 'suppressHeaderKeyboardEvent', + 'colSpan', + 'rowSpan', + 'getQuickFilterText', + 'newValueHandler', + 'onCellValueChanged', + 'onCellClicked', + 'onCellDoubleClicked', + 'onCellContextMenu', + 'rowDragText', + 'tooltipValueGetter', + 'tooltipComponent', + 'tooltipComponentFramework', + 'cellRendererSelector', + 'cellEditorSelector' + ]; + ColDefUtil.ALL_PROPERTIES = __spread(ColDefUtil.ARRAY_PROPERTIES, ColDefUtil.OBJECT_PROPERTIES, ColDefUtil.STRING_PROPERTIES, ColDefUtil.NUMBER_PROPERTIES, ColDefUtil.FUNCTION_PROPERTIES, ColDefUtil.BOOLEAN_PROPERTIES); + // used when doing property checks - this causes noise when using frameworks which can add their own fw specific + // properties to colDefs, gridOptions etc + ColDefUtil.FRAMEWORK_PROPERTIES = [ + '__ob__', + '__v_skip', + '__metadata__', + 'mappedColumnProperties', + 'hasChildColumns', + 'toColDef', + 'createColDefFromGridColumn' + ]; + return ColDefUtil; +}()); + + + +/***/ }), +/* 34 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UserComponentRegistry", function() { return UserComponentRegistry; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _filter_floating_provided_readOnlyFloatingFilter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(35); +/* harmony import */ var _filter_provided_date_dateFilter__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(58); +/* harmony import */ var _filter_provided_date_dateFloatingFilter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(73); +/* harmony import */ var _filter_provided_date_defaultDateComponent__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(75); +/* harmony import */ var _filter_provided_number_numberFilter__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(76); +/* harmony import */ var _filter_provided_number_numberFloatingFilter__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(77); +/* harmony import */ var _filter_provided_text_textFilter__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(79); +/* harmony import */ var _filter_provided_text_textFloatingFilter__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(80); +/* harmony import */ var _headerRendering_cells_column_headerComp__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(81); +/* harmony import */ var _headerRendering_cells_columnGroup_headerGroupComp__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(83); +/* harmony import */ var _rendering_cellEditors_largeTextCellEditor__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(84); +/* harmony import */ var _rendering_cellEditors_popupSelectCellEditor__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(86); +/* harmony import */ var _rendering_cellEditors_popupTextCellEditor__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(88); +/* harmony import */ var _rendering_cellEditors_selectCellEditor__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(87); +/* harmony import */ var _rendering_cellEditors_textCellEditor__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(89); +/* harmony import */ var _rendering_cellRenderers_animateShowChangeCellRenderer__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(90); +/* harmony import */ var _rendering_cellRenderers_animateSlideCellRenderer__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(91); +/* harmony import */ var _rendering_cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(92); +/* harmony import */ var _rendering_cellRenderers_loadingCellRenderer__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(98); +/* harmony import */ var _rendering_overlays_loadingOverlayComponent__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(99); +/* harmony import */ var _rendering_overlays_noRowsOverlayComponent__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(100); +/* harmony import */ var _rendering_tooltipComponent__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(101); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_24__ = __webpack_require__(14); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_25__ = __webpack_require__(13); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + + + + + + + + + + + + + + + + + + + + +var UserComponentRegistry = /** @class */ (function (_super) { + __extends(UserComponentRegistry, _super); + function UserComponentRegistry() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.agGridDefaults = { + //date + agDateInput: _filter_provided_date_defaultDateComponent__WEBPACK_IMPORTED_MODULE_5__["DefaultDateComponent"], + //header + agColumnHeader: _headerRendering_cells_column_headerComp__WEBPACK_IMPORTED_MODULE_10__["HeaderComp"], + agColumnGroupHeader: _headerRendering_cells_columnGroup_headerGroupComp__WEBPACK_IMPORTED_MODULE_11__["HeaderGroupComp"], + //floating filters + agTextColumnFloatingFilter: _filter_provided_text_textFloatingFilter__WEBPACK_IMPORTED_MODULE_9__["TextFloatingFilter"], + agNumberColumnFloatingFilter: _filter_provided_number_numberFloatingFilter__WEBPACK_IMPORTED_MODULE_7__["NumberFloatingFilter"], + agDateColumnFloatingFilter: _filter_provided_date_dateFloatingFilter__WEBPACK_IMPORTED_MODULE_4__["DateFloatingFilter"], + agReadOnlyFloatingFilter: _filter_floating_provided_readOnlyFloatingFilter__WEBPACK_IMPORTED_MODULE_2__["ReadOnlyFloatingFilter"], + // renderers + agAnimateShowChangeCellRenderer: _rendering_cellRenderers_animateShowChangeCellRenderer__WEBPACK_IMPORTED_MODULE_17__["AnimateShowChangeCellRenderer"], + agAnimateSlideCellRenderer: _rendering_cellRenderers_animateSlideCellRenderer__WEBPACK_IMPORTED_MODULE_18__["AnimateSlideCellRenderer"], + agGroupCellRenderer: _rendering_cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_19__["GroupCellRenderer"], + agGroupRowRenderer: _rendering_cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_19__["GroupCellRenderer"], + agLoadingCellRenderer: _rendering_cellRenderers_loadingCellRenderer__WEBPACK_IMPORTED_MODULE_20__["LoadingCellRenderer"], + //editors + agCellEditor: _rendering_cellEditors_textCellEditor__WEBPACK_IMPORTED_MODULE_16__["TextCellEditor"], + agTextCellEditor: _rendering_cellEditors_textCellEditor__WEBPACK_IMPORTED_MODULE_16__["TextCellEditor"], + agSelectCellEditor: _rendering_cellEditors_selectCellEditor__WEBPACK_IMPORTED_MODULE_15__["SelectCellEditor"], + agPopupTextCellEditor: _rendering_cellEditors_popupTextCellEditor__WEBPACK_IMPORTED_MODULE_14__["PopupTextCellEditor"], + agPopupSelectCellEditor: _rendering_cellEditors_popupSelectCellEditor__WEBPACK_IMPORTED_MODULE_13__["PopupSelectCellEditor"], + agLargeTextCellEditor: _rendering_cellEditors_largeTextCellEditor__WEBPACK_IMPORTED_MODULE_12__["LargeTextCellEditor"], + //filter + agTextColumnFilter: _filter_provided_text_textFilter__WEBPACK_IMPORTED_MODULE_8__["TextFilter"], + agNumberColumnFilter: _filter_provided_number_numberFilter__WEBPACK_IMPORTED_MODULE_6__["NumberFilter"], + agDateColumnFilter: _filter_provided_date_dateFilter__WEBPACK_IMPORTED_MODULE_3__["DateFilter"], + //overlays + agLoadingOverlay: _rendering_overlays_loadingOverlayComponent__WEBPACK_IMPORTED_MODULE_21__["LoadingOverlayComponent"], + agNoRowsOverlay: _rendering_overlays_noRowsOverlayComponent__WEBPACK_IMPORTED_MODULE_22__["NoRowsOverlayComponent"], + // tooltips + agTooltipComponent: _rendering_tooltipComponent__WEBPACK_IMPORTED_MODULE_23__["TooltipComponent"] + }; + _this.agDeprecatedNames = { + set: { + newComponentName: 'agSetColumnFilter', + propertyHolder: 'filter' + }, + text: { + newComponentName: 'agTextColumnFilter', + propertyHolder: 'filter' + }, + number: { + newComponentName: 'agNumberColumnFilter', + propertyHolder: 'filter' + }, + date: { + newComponentName: 'agDateColumnFilter', + propertyHolder: 'filter' + }, + group: { + newComponentName: 'agGroupCellRenderer', + propertyHolder: 'cellRenderer' + }, + animateShowChange: { + newComponentName: 'agAnimateShowChangeCellRenderer', + propertyHolder: 'cellRenderer' + }, + animateSlide: { + newComponentName: 'agAnimateSlideCellRenderer', + propertyHolder: 'cellRenderer' + }, + select: { + newComponentName: 'agSelectCellEditor', + propertyHolder: 'cellEditor' + }, + largeText: { + newComponentName: 'agLargeTextCellEditor', + propertyHolder: 'cellEditor' + }, + popupSelect: { + newComponentName: 'agPopupSelectCellEditor', + propertyHolder: 'cellEditor' + }, + popupText: { + newComponentName: 'agPopupTextCellEditor', + propertyHolder: 'cellEditor' + }, + richSelect: { + newComponentName: 'agRichSelectCellEditor', + propertyHolder: 'cellEditor' + }, + headerComponent: { + newComponentName: 'agColumnHeader', + propertyHolder: 'headerComponent' + } + }; + _this.jsComps = {}; + _this.fwComps = {}; + return _this; + } + UserComponentRegistry.prototype.init = function () { + var _this = this; + if (this.gridOptions.components != null) { + Object(_utils_object__WEBPACK_IMPORTED_MODULE_25__["iterateObject"])(this.gridOptions.components, function (key, component) { return _this.registerJsComponent(key, component); }); + } + if (this.gridOptions.frameworkComponents != null) { + Object(_utils_object__WEBPACK_IMPORTED_MODULE_25__["iterateObject"])(this.gridOptions.frameworkComponents, function (key, component) { return _this.registerFwComponent(key, component); }); + } + }; + UserComponentRegistry.prototype.registerDefaultComponent = function (rawName, component) { + var name = this.translateIfDeprecated(rawName); + if (this.agGridDefaults[name]) { + console.error("Trying to overwrite a default component. You should call registerComponent"); + return; + } + this.agGridDefaults[name] = component; + }; + UserComponentRegistry.prototype.registerJsComponent = function (rawName, component) { + var name = this.translateIfDeprecated(rawName); + if (this.fwComps[name]) { + console.error("Trying to register a component that you have already registered for frameworks: " + name); + return; + } + this.jsComps[name] = component; + }; + /** + * B the business interface (ie IHeader) + * A the agGridComponent interface (ie IHeaderComp). The final object acceptable by ag-grid + */ + UserComponentRegistry.prototype.registerFwComponent = function (rawName, component) { + var warningMessage = "AG Grid: As of v27, registering components via grid property frameworkComponents is deprecated. Instead register both JavaScript AND Framework Components via the components property."; + Object(_utils_function__WEBPACK_IMPORTED_MODULE_24__["doOnce"])(function () { return console.warn(warningMessage); }, "UserComponentRegistry.frameworkComponentsDeprecated"); + var name = this.translateIfDeprecated(rawName); + this.fwComps[name] = component; + }; + UserComponentRegistry.prototype.retrieve = function (rawName) { + var name = this.translateIfDeprecated(rawName); + var createResult = function (component, componentFromFramework) { return ({ componentFromFramework: componentFromFramework, component: component }); }; + // FrameworkOverrides.frameworkComponent() is used in two locations: + // 1) for Vue, user provided components get registered via a framework specific way. + // 2) for React, it's how the React UI provides alternative default components (eg GroupCellRenderer and DetailCellRenderer) + var registeredViaFrameworkComp = this.getFrameworkOverrides().frameworkComponent(name); + if (registeredViaFrameworkComp != null) { + return createResult(registeredViaFrameworkComp, true); + } + var frameworkComponent = this.fwComps[name]; + if (frameworkComponent) { + return createResult(frameworkComponent, true); + } + var jsComponent = this.jsComps[name]; + if (jsComponent) { + var isFwkComp = this.getFrameworkOverrides().isFrameworkComponent(jsComponent); + return createResult(jsComponent, isFwkComp); + } + var defaultComponent = this.agGridDefaults[name]; + if (defaultComponent) { + return createResult(defaultComponent, false); + } + if (Object.keys(this.agGridDefaults).indexOf(name) < 0) { + console.warn("AG Grid: Looking for component [" + name + "] but it wasn't found."); + } + return null; + }; + UserComponentRegistry.prototype.translateIfDeprecated = function (raw) { + var deprecatedInfo = this.agDeprecatedNames[raw]; + if (deprecatedInfo != null) { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_24__["doOnce"])(function () { + console.warn("ag-grid. Since v15.0 component names have been renamed to be namespaced. You should rename " + deprecatedInfo.propertyHolder + ":" + raw + " to " + deprecatedInfo.propertyHolder + ":" + deprecatedInfo.newComponentName); + }, 'DEPRECATE_COMPONENT_' + raw); + return deprecatedInfo.newComponentName; + } + return raw; + }; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptions') + ], UserComponentRegistry.prototype, "gridOptions", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('agComponentUtils') + ], UserComponentRegistry.prototype, "agComponentUtils", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], UserComponentRegistry.prototype, "init", null); + UserComponentRegistry = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('userComponentRegistry') + ], UserComponentRegistry); + return UserComponentRegistry; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); + + + +/***/ }), +/* 35 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ReadOnlyFloatingFilter", function() { return ReadOnlyFloatingFilter; }); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + +// optional floating filter for user provided filters - instead of providing a floating filter, +// they can provide a getModelAsString() method on the filter instead. this class just displays +// the string returned from getModelAsString() +var ReadOnlyFloatingFilter = /** @class */ (function (_super) { + __extends(ReadOnlyFloatingFilter, _super); + function ReadOnlyFloatingFilter() { + return _super.call(this, /* html */ "\n
\n \n
") || this; + } + // this is a user component, and IComponent has "public destroy()" as part of the interface. + // so we need to override destroy() just to make the method public. + ReadOnlyFloatingFilter.prototype.destroy = function () { + _super.prototype.destroy.call(this); + }; + ReadOnlyFloatingFilter.prototype.init = function (params) { + this.params = params; + var displayName = this.columnModel.getDisplayNameForColumn(params.column, 'header', true); + var translate = this.gridOptionsWrapper.getLocaleTextFunc(); + this.eFloatingFilterText + .setDisabled(true) + .setInputAriaLabel(displayName + " " + translate('ariaFilterInput', 'Filter Input')); + }; + ReadOnlyFloatingFilter.prototype.onParentModelChanged = function (parentModel) { + var _this = this; + if (!parentModel) { + this.eFloatingFilterText.setValue(''); + return; + } + this.params.parentFilterInstance(function (filterInstance) { + // it would be nice to check if getModelAsString was present before creating this component, + // however that is not possible, as React Hooks and VueJS don't attached the methods to the Filter until + // AFTER the filter is created, not allowing inspection before this (we create floating filters as columns + // are drawn, but the parent filters are only created when needed). + if (filterInstance.getModelAsString) { + var modelAsString = filterInstance.getModelAsString(parentModel); + _this.eFloatingFilterText.setValue(modelAsString); + } + }); + }; + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eFloatingFilterText') + ], ReadOnlyFloatingFilter.prototype, "eFloatingFilterText", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnModel') + ], ReadOnlyFloatingFilter.prototype, "columnModel", void 0); + return ReadOnlyFloatingFilter; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); + + + +/***/ }), +/* 36 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CssClassManager", function() { return CssClassManager; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Component", function() { return Component; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(42); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(14); +/* harmony import */ var _customTooltipFeature__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(56); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + +var compIdSequence = new _utils__WEBPACK_IMPORTED_MODULE_2__["NumberSequence"](); +var CssClassManager = /** @class */ (function () { + function CssClassManager(getGui) { + // to minimise DOM hits, we only apply CSS classes if they have changed. as adding a CSS class that is already + // there, or removing one that wasn't present, all takes CPU. + this.cssClassStates = {}; + this.getGui = getGui; + } + CssClassManager.prototype.addCssClass = function (className) { + var updateNeeded = this.cssClassStates[className] !== true; + if (updateNeeded && className.length) { + this.getGui().classList.add(className); + this.cssClassStates[className] = true; + } + }; + CssClassManager.prototype.removeCssClass = function (className) { + var updateNeeded = this.cssClassStates[className] !== false; + if (updateNeeded && className.length) { + this.getGui().classList.remove(className); + this.cssClassStates[className] = false; + } + }; + CssClassManager.prototype.containsCssClass = function (className) { + return this.getGui().classList.contains(className); + }; + CssClassManager.prototype.addOrRemoveCssClass = function (className, addOrRemove) { + var updateNeeded = this.cssClassStates[className] !== addOrRemove; + if (updateNeeded && className.length) { + this.getGui().classList.toggle(className, addOrRemove); + this.cssClassStates[className] = addOrRemove; + } + }; + return CssClassManager; +}()); + +var Component = /** @class */ (function (_super) { + __extends(Component, _super); + function Component(template) { + var _this = _super.call(this) || this; + // if false, then CSS class "ag-hidden" is applied, which sets "display: none" + _this.displayed = true; + // if false, then CSS class "ag-invisible" is applied, which sets "visibility: hidden" + _this.visible = true; + // unique id for this row component. this is used for getting a reference to the HTML dom. + // we cannot use the RowNode id as this is not unique (due to animation, old rows can be lying + // around as we create a new rowComp instance for the same row node). + _this.compId = compIdSequence.next(); + _this.cssClassManager = new CssClassManager(function () { return _this.eGui; }); + if (template) { + _this.setTemplate(template); + } + return _this; + } + Component.prototype.preConstructOnComponent = function () { + this.usingBrowserTooltips = this.gridOptionsWrapper.isEnableBrowserTooltips(); + }; + Component.prototype.getCompId = function () { + return this.compId; + }; + Component.prototype.getTooltipParams = function () { + return { + value: this.tooltipText, + location: 'UNKNOWN' + }; + }; + Component.prototype.setTooltip = function (newTooltipText) { + var _this = this; + var removeTooltip = function () { + if (_this.usingBrowserTooltips) { + _this.getGui().removeAttribute('title'); + } + else { + _this.tooltipFeature = _this.destroyBean(_this.tooltipFeature); + } + }; + var addTooltip = function () { + if (_this.usingBrowserTooltips) { + _this.getGui().setAttribute('title', _this.tooltipText); + } + else { + _this.tooltipFeature = _this.createBean(new _customTooltipFeature__WEBPACK_IMPORTED_MODULE_5__["CustomTooltipFeature"](_this)); + } + }; + if (this.tooltipText != newTooltipText) { + if (this.tooltipText) { + removeTooltip(); + } + if (newTooltipText != null) { + this.tooltipText = newTooltipText; + if (this.tooltipText) { + addTooltip(); + } + } + } + }; + // for registered components only, eg creates AgCheckbox instance from ag-checkbox HTML tag + Component.prototype.createChildComponentsFromTags = function (parentNode, paramsMap) { + var _this = this; + // we MUST take a copy of the list first, as the 'swapComponentForNode' adds comments into the DOM + // which messes up the traversal order of the children. + var childNodeList = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["copyNodeList"])(parentNode.childNodes); + childNodeList.forEach(function (childNode) { + if (!(childNode instanceof HTMLElement)) { + return; + } + var childComp = _this.createComponentFromElement(childNode, function (childComp) { + // copy over all attributes, including css classes, so any attributes user put on the tag + // wll be carried across + var childGui = childComp.getGui(); + if (childGui) { + _this.copyAttributesFromNode(childNode, childComp.getGui()); + } + }, paramsMap); + if (childComp) { + if (childComp.addItems && childNode.children.length) { + _this.createChildComponentsFromTags(childNode, paramsMap); + // converting from HTMLCollection to Array + var items = Array.prototype.slice.call(childNode.children); + childComp.addItems(items); + } + // replace the tag (eg ag-checkbox) with the proper HTMLElement (eg 'div') in the dom + _this.swapComponentForNode(childComp, parentNode, childNode); + } + else if (childNode.childNodes) { + _this.createChildComponentsFromTags(childNode, paramsMap); + } + }); + }; + Component.prototype.createComponentFromElement = function (element, afterPreCreateCallback, paramsMap) { + var key = element.nodeName; + var componentParams = paramsMap ? paramsMap[element.getAttribute('ref')] : undefined; + var ComponentClass = this.agStackComponentsRegistry.getComponentClass(key); + if (ComponentClass) { + Component.elementGettingCreated = element; + var newComponent = new ComponentClass(componentParams); + newComponent.setParentComponent(this); + this.createBean(newComponent, null, afterPreCreateCallback); + return newComponent; + } + return null; + }; + Component.prototype.copyAttributesFromNode = function (source, dest) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["iterateNamedNodeMap"])(source.attributes, function (name, value) { return dest.setAttribute(name, value); }); + }; + Component.prototype.swapComponentForNode = function (newComponent, parentNode, childNode) { + var eComponent = newComponent.getGui(); + parentNode.replaceChild(eComponent, childNode); + parentNode.insertBefore(document.createComment(childNode.nodeName), eComponent); + this.addDestroyFunc(this.destroyBean.bind(this, newComponent)); + this.swapInComponentForQuerySelectors(newComponent, childNode); + }; + Component.prototype.swapInComponentForQuerySelectors = function (newComponent, childNode) { + var thisNoType = this; + this.iterateOverQuerySelectors(function (querySelector) { + if (thisNoType[querySelector.attributeName] === childNode) { + thisNoType[querySelector.attributeName] = newComponent; + } + }); + }; + Component.prototype.iterateOverQuerySelectors = function (action) { + var thisPrototype = Object.getPrototypeOf(this); + while (thisPrototype != null) { + var metaData = thisPrototype.__agComponentMetaData; + var currentProtoName = Object(_utils_function__WEBPACK_IMPORTED_MODULE_4__["getFunctionName"])(thisPrototype.constructor); + if (metaData && metaData[currentProtoName] && metaData[currentProtoName].querySelectors) { + metaData[currentProtoName].querySelectors.forEach(function (querySelector) { return action(querySelector); }); + } + thisPrototype = Object.getPrototypeOf(thisPrototype); + } + }; + Component.prototype.setTemplate = function (template, paramsMap) { + var eGui = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["loadTemplate"])(template); + this.setTemplateFromElement(eGui, paramsMap); + }; + Component.prototype.setTemplateFromElement = function (element, paramsMap) { + this.eGui = element; + this.eGui.__agComponent = this; + this.wireQuerySelectors(); + // context will not be available when user sets template in constructor + if (!!this.getContext()) { + this.createChildComponentsFromTags(this.getGui(), paramsMap); + } + }; + Component.prototype.createChildComponentsPreConstruct = function () { + // ui exists if user sets template in constructor. when this happens, we have to wait for the context + // to be autoWired first before we can create child components. + if (!!this.getGui()) { + this.createChildComponentsFromTags(this.getGui()); + } + }; + Component.prototype.wireQuerySelectors = function () { + var _this = this; + if (!this.eGui) { + return; + } + var thisNoType = this; + this.iterateOverQuerySelectors(function (querySelector) { + var setResult = function (result) { return thisNoType[querySelector.attributeName] = result; }; + // if it's a ref selector, and match is on top level component, we return + // the element. otherwise no way of components putting ref=xxx on the top + // level element as querySelector only looks at children. + var topLevelRefMatch = querySelector.refSelector + && _this.eGui.getAttribute('ref') === querySelector.refSelector; + if (topLevelRefMatch) { + setResult(_this.eGui); + } + else { + // otherwise use querySelector, which looks at children + var resultOfQuery = _this.eGui.querySelector(querySelector.querySelector); + if (resultOfQuery) { + setResult(resultOfQuery.__agComponent || resultOfQuery); + } + } + }); + }; + Component.prototype.getGui = function () { + return this.eGui; + }; + Component.prototype.getFocusableElement = function () { + return this.eGui; + }; + Component.prototype.setParentComponent = function (component) { + this.parentComponent = component; + }; + Component.prototype.getParentComponent = function () { + return this.parentComponent; + }; + // this method is for older code, that wants to provide the gui element, + // it is not intended for this to be in ag-Stack + Component.prototype.setGui = function (eGui) { + this.eGui = eGui; + }; + Component.prototype.queryForHtmlElement = function (cssSelector) { + return this.eGui.querySelector(cssSelector); + }; + Component.prototype.queryForHtmlInputElement = function (cssSelector) { + return this.eGui.querySelector(cssSelector); + }; + Component.prototype.appendChild = function (newChild, container) { + if (!container) { + container = this.eGui; + } + if (newChild == null) { + return; + } + if (Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["isNodeOrElement"])(newChild)) { + container.appendChild(newChild); + } + else { + var childComponent = newChild; + container.appendChild(childComponent.getGui()); + this.addDestroyFunc(this.destroyBean.bind(this, childComponent)); + } + }; + Component.prototype.isDisplayed = function () { + return this.displayed; + }; + Component.prototype.setVisible = function (visible) { + if (visible !== this.visible) { + this.visible = visible; + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["setVisible"])(this.eGui, visible); + } + }; + Component.prototype.setDisplayed = function (displayed) { + if (displayed !== this.displayed) { + this.displayed = displayed; + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["setDisplayed"])(this.eGui, displayed); + var event_1 = { + type: Component.EVENT_DISPLAYED_CHANGED, + visible: this.displayed + }; + this.dispatchEvent(event_1); + } + }; + Component.prototype.destroy = function () { + if (this.tooltipFeature) { + this.tooltipFeature = this.destroyBean(this.tooltipFeature); + } + _super.prototype.destroy.call(this); + }; + Component.prototype.addGuiEventListener = function (event, listener) { + var _this = this; + this.eGui.addEventListener(event, listener); + this.addDestroyFunc(function () { return _this.eGui.removeEventListener(event, listener); }); + }; + Component.prototype.addCssClass = function (className) { + this.cssClassManager.addCssClass(className); + }; + Component.prototype.removeCssClass = function (className) { + this.cssClassManager.removeCssClass(className); + }; + Component.prototype.containsCssClass = function (className) { + return this.cssClassManager.containsCssClass(className); + }; + Component.prototype.addOrRemoveCssClass = function (className, addOrRemove) { + this.cssClassManager.addOrRemoveCssClass(className, addOrRemove); + }; + Component.prototype.getAttribute = function (key) { + var eGui = this.eGui; + return eGui ? eGui.getAttribute(key) : null; + }; + Component.prototype.getRefElement = function (refName) { + return this.queryForHtmlElement("[ref=\"" + refName + "\"]"); + }; + Component.EVENT_DISPLAYED_CHANGED = 'displayedChanged'; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('agStackComponentsRegistry') + ], Component.prototype, "agStackComponentsRegistry", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PreConstruct"] + ], Component.prototype, "preConstructOnComponent", null); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PreConstruct"] + ], Component.prototype, "createChildComponentsPreConstruct", null); + return Component; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + + + +/***/ }), +/* 37 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _color__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(38); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Color", function() { return _color__WEBPACK_IMPORTED_MODULE_0__["Color"]; }); + +/* harmony import */ var _csv__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(39); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "stringToArray", function() { return _csv__WEBPACK_IMPORTED_MODULE_1__["stringToArray"]; }); + +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(40); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "_", function() { return _utils__WEBPACK_IMPORTED_MODULE_2__["_"]; }); + +/* harmony import */ var _numberSequence__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(53); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "NumberSequence", function() { return _numberSequence__WEBPACK_IMPORTED_MODULE_3__["NumberSequence"]; }); + +/* harmony import */ var _promise__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(54); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgPromiseStatus", function() { return _promise__WEBPACK_IMPORTED_MODULE_4__["AgPromiseStatus"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgPromise", function() { return _promise__WEBPACK_IMPORTED_MODULE_4__["AgPromise"]; }); + +/* harmony import */ var _timer__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(55); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Timer", function() { return _timer__WEBPACK_IMPORTED_MODULE_5__["Timer"]; }); + +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ + + + + + + + + +/***/ }), +/* 38 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Color", function() { return Color; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; +}; +var Color = /** @class */ (function () { + /** + * Every color component should be in the [0, 1] range. + * Some easing functions (such as elastic easing) can overshoot the target value by some amount. + * So, when animating colors, if the source or target color components are already near + * or at the edge of the allowed [0, 1] range, it is possible for the intermediate color + * component value to end up outside of that range mid-animation. For this reason the constructor + * performs range checking/constraining. + * @param r Red component. + * @param g Green component. + * @param b Blue component. + * @param a Alpha (opacity) component. + */ + function Color(r, g, b, a) { + if (a === void 0) { a = 1; } + // NaN is treated as 0. + this.r = Math.min(1, Math.max(0, r || 0)); + this.g = Math.min(1, Math.max(0, g || 0)); + this.b = Math.min(1, Math.max(0, b || 0)); + this.a = Math.min(1, Math.max(0, a || 0)); + } + /** + * The given string can be in one of the following formats: + * - #rgb + * - #rrggbb + * - rgb(r, g, b) + * - rgba(r, g, b, a) + * - CSS color name such as 'white', 'orange', 'cyan', etc. + * @param str + */ + Color.fromString = function (str) { + // hexadecimal notation + if (str.indexOf('#') >= 0) { // there can be some leading whitespace + return Color.fromHexString(str); + } + // color name + var hex = Color.nameToHex[str]; + if (hex) { + return Color.fromHexString(hex); + } + // rgb(a) notation + if (str.indexOf('rgb') >= 0) { + return Color.fromRgbaString(str); + } + throw new Error("Invalid color string: '" + str + "'"); + }; + // See https://drafts.csswg.org/css-color/#hex-notation + Color.parseHex = function (input) { + input = input.replace(/ /g, '').slice(1); + var parts; + switch (input.length) { + case 6: + case 8: + parts = []; + for (var i = 0; i < input.length; i += 2) { + parts.push(parseInt("" + input[i] + input[i + 1], 16)); + } + break; + case 3: + case 4: + parts = input.split('').map(function (p) { return parseInt(p, 16); }).map(function (p) { return p + p * 16; }); + break; + } + if (parts.length >= 3) { + if (parts.every(function (p) { return p >= 0; })) { + if (parts.length === 3) { + parts.push(255); + } + return parts; + } + } + }; + Color.fromHexString = function (str) { + var values = Color.parseHex(str); + if (values) { + var _a = __read(values, 4), r = _a[0], g = _a[1], b = _a[2], a = _a[3]; + return new Color(r / 255, g / 255, b / 255, a / 255); + } + throw new Error("Malformed hexadecimal color string: '" + str + "'"); + }; + Color.stringToRgba = function (str) { + // Find positions of opening and closing parentheses. + var _a = __read([NaN, NaN], 2), po = _a[0], pc = _a[1]; + for (var i = 0; i < str.length; i++) { + var c = str[i]; + if (!po && c === '(') { + po = i; + } + else if (c === ')') { + pc = i; + break; + } + } + var contents = po && pc && str.substring(po + 1, pc); + if (!contents) { + return; + } + var parts = contents.split(','); + var rgba = []; + for (var i = 0; i < parts.length; i++) { + var part = parts[i]; + var value = parseFloat(part); + if (isNaN(value)) { + return; + } + if (part.indexOf('%') >= 0) { // percentage r, g, or b value + value = Math.max(0, Math.min(100, value)); + value /= 100; + } + else { + if (i === 3) { // alpha component + value = Math.max(0, Math.min(1, value)); + } + else { // absolute r, g, or b value + value = Math.max(0, Math.min(255, value)); + value /= 255; + } + } + rgba.push(value); + } + return rgba; + }; + Color.fromRgbaString = function (str) { + var rgba = Color.stringToRgba(str); + if (rgba) { + if (rgba.length === 3) { + return new Color(rgba[0], rgba[1], rgba[2]); + } + else if (rgba.length === 4) { + return new Color(rgba[0], rgba[1], rgba[2], rgba[3]); + } + } + throw new Error("Malformed rgb/rgba color string: '" + str + "'"); + }; + Color.fromArray = function (arr) { + if (arr.length === 4) { + return new Color(arr[0], arr[1], arr[2], arr[3]); + } + if (arr.length === 3) { + return new Color(arr[0], arr[1], arr[2]); + } + throw new Error('The given array should contain 3 or 4 color components (numbers).'); + }; + Color.fromHSB = function (h, s, b, alpha) { + if (alpha === void 0) { alpha = 1; } + var rgb = Color.HSBtoRGB(h, s, b); + return new Color(rgb[0], rgb[1], rgb[2], alpha); + }; + Color.padHex = function (str) { + // Can't use `padStart(2, '0')` here because of IE. + return str.length === 1 ? '0' + str : str; + }; + Color.prototype.toHexString = function () { + var hex = '#' + + Color.padHex(Math.round(this.r * 255).toString(16)) + + Color.padHex(Math.round(this.g * 255).toString(16)) + + Color.padHex(Math.round(this.b * 255).toString(16)); + if (this.a < 1) { + hex += Color.padHex(Math.round(this.a * 255).toString(16)); + } + return hex; + }; + Color.prototype.toRgbaString = function (fractionDigits) { + if (fractionDigits === void 0) { fractionDigits = 3; } + var components = [ + Math.round(this.r * 255), + Math.round(this.g * 255), + Math.round(this.b * 255) + ]; + var k = Math.pow(10, fractionDigits); + if (this.a !== 1) { + components.push(Math.round(this.a * k) / k); + return "rgba(" + components.join(', ') + ")"; + } + return "rgb(" + components.join(', ') + ")"; + }; + Color.prototype.toString = function () { + if (this.a === 1) { + return this.toHexString(); + } + return this.toRgbaString(); + }; + Color.prototype.toHSB = function () { + return Color.RGBtoHSB(this.r, this.g, this.b); + }; + /** + * Converts the given RGB triple to an array of HSB (HSV) components. + * The hue component will be `NaN` for achromatic colors. + */ + Color.RGBtoHSB = function (r, g, b) { + var min = Math.min(r, g, b); + var max = Math.max(r, g, b); + var S = max !== 0 ? (max - min) / max : 0; + var H = NaN; + // min == max, means all components are the same + // and the color is a shade of gray with no hue (H is NaN) + if (min !== max) { + var delta = max - min; + var rc = (max - r) / delta; + var gc = (max - g) / delta; + var bc = (max - b) / delta; + if (r === max) { + H = bc - gc; + } + else if (g === max) { + H = 2.0 + rc - bc; + } + else { + H = 4.0 + gc - rc; + } + H /= 6.0; + if (H < 0) { + H = H + 1.0; + } + } + return [H * 360, S, max]; + }; + /** + * Converts the given HSB (HSV) triple to an array of RGB components. + */ + Color.HSBtoRGB = function (H, S, B) { + if (isNaN(H)) { + H = 0; + } + H = (((H % 360) + 360) % 360) / 360; // normalize hue to [0, 360] interval, then scale to [0, 1] + var r = 0; + var g = 0; + var b = 0; + if (S === 0) { + r = g = b = B; + } + else { + var h = (H - Math.floor(H)) * 6; + var f = h - Math.floor(h); + var p = B * (1 - S); + var q = B * (1 - S * f); + var t = B * (1 - (S * (1 - f))); + switch (h >> 0) { // discard the floating point part of the number + case 0: + r = B; + g = t; + b = p; + break; + case 1: + r = q; + g = B; + b = p; + break; + case 2: + r = p; + g = B; + b = t; + break; + case 3: + r = p; + g = q; + b = B; + break; + case 4: + r = t; + g = p; + b = B; + break; + case 5: + r = B; + g = p; + b = q; + break; + } + } + return [r, g, b]; + }; + Color.prototype.derive = function (hueShift, saturationFactor, brightnessFactor, opacityFactor) { + var hsb = Color.RGBtoHSB(this.r, this.g, this.b); + var b = hsb[2]; + if (b == 0 && brightnessFactor > 1.0) { + b = 0.05; + } + var h = (((hsb[0] + hueShift) % 360) + 360) % 360; + var s = Math.max(Math.min(hsb[1] * saturationFactor, 1.0), 0.0); + b = Math.max(Math.min(b * brightnessFactor, 1.0), 0.0); + var a = Math.max(Math.min(this.a * opacityFactor, 1.0), 0.0); + var rgba = Color.HSBtoRGB(h, s, b); + rgba.push(a); + return Color.fromArray(rgba); + }; + Color.prototype.brighter = function () { + return this.derive(0, 1.0, 1.0 / 0.7, 1.0); + }; + Color.prototype.darker = function () { + return this.derive(0, 1.0, 0.7, 1.0); + }; + /** + * CSS Color Module Level 4: + * https://drafts.csswg.org/css-color/#named-colors + */ + Color.nameToHex = Object.freeze({ + aliceblue: '#F0F8FF', + antiquewhite: '#FAEBD7', + aqua: '#00FFFF', + aquamarine: '#7FFFD4', + azure: '#F0FFFF', + beige: '#F5F5DC', + bisque: '#FFE4C4', + black: '#000000', + blanchedalmond: '#FFEBCD', + blue: '#0000FF', + blueviolet: '#8A2BE2', + brown: '#A52A2A', + burlywood: '#DEB887', + cadetblue: '#5F9EA0', + chartreuse: '#7FFF00', + chocolate: '#D2691E', + coral: '#FF7F50', + cornflowerblue: '#6495ED', + cornsilk: '#FFF8DC', + crimson: '#DC143C', + cyan: '#00FFFF', + darkblue: '#00008B', + darkcyan: '#008B8B', + darkgoldenrod: '#B8860B', + darkgray: '#A9A9A9', + darkgreen: '#006400', + darkgrey: '#A9A9A9', + darkkhaki: '#BDB76B', + darkmagenta: '#8B008B', + darkolivegreen: '#556B2F', + darkorange: '#FF8C00', + darkorchid: '#9932CC', + darkred: '#8B0000', + darksalmon: '#E9967A', + darkseagreen: '#8FBC8F', + darkslateblue: '#483D8B', + darkslategray: '#2F4F4F', + darkslategrey: '#2F4F4F', + darkturquoise: '#00CED1', + darkviolet: '#9400D3', + deeppink: '#FF1493', + deepskyblue: '#00BFFF', + dimgray: '#696969', + dimgrey: '#696969', + dodgerblue: '#1E90FF', + firebrick: '#B22222', + floralwhite: '#FFFAF0', + forestgreen: '#228B22', + fuchsia: '#FF00FF', + gainsboro: '#DCDCDC', + ghostwhite: '#F8F8FF', + gold: '#FFD700', + goldenrod: '#DAA520', + gray: '#808080', + green: '#008000', + greenyellow: '#ADFF2F', + grey: '#808080', + honeydew: '#F0FFF0', + hotpink: '#FF69B4', + indianred: '#CD5C5C', + indigo: '#4B0082', + ivory: '#FFFFF0', + khaki: '#F0E68C', + lavender: '#E6E6FA', + lavenderblush: '#FFF0F5', + lawngreen: '#7CFC00', + lemonchiffon: '#FFFACD', + lightblue: '#ADD8E6', + lightcoral: '#F08080', + lightcyan: '#E0FFFF', + lightgoldenrodyellow: '#FAFAD2', + lightgray: '#D3D3D3', + lightgreen: '#90EE90', + lightgrey: '#D3D3D3', + lightpink: '#FFB6C1', + lightsalmon: '#FFA07A', + lightseagreen: '#20B2AA', + lightskyblue: '#87CEFA', + lightslategray: '#778899', + lightslategrey: '#778899', + lightsteelblue: '#B0C4DE', + lightyellow: '#FFFFE0', + lime: '#00FF00', + limegreen: '#32CD32', + linen: '#FAF0E6', + magenta: '#FF00FF', + maroon: '#800000', + mediumaquamarine: '#66CDAA', + mediumblue: '#0000CD', + mediumorchid: '#BA55D3', + mediumpurple: '#9370DB', + mediumseagreen: '#3CB371', + mediumslateblue: '#7B68EE', + mediumspringgreen: '#00FA9A', + mediumturquoise: '#48D1CC', + mediumvioletred: '#C71585', + midnightblue: '#191970', + mintcream: '#F5FFFA', + mistyrose: '#FFE4E1', + moccasin: '#FFE4B5', + navajowhite: '#FFDEAD', + navy: '#000080', + oldlace: '#FDF5E6', + olive: '#808000', + olivedrab: '#6B8E23', + orange: '#FFA500', + orangered: '#FF4500', + orchid: '#DA70D6', + palegoldenrod: '#EEE8AA', + palegreen: '#98FB98', + paleturquoise: '#AFEEEE', + palevioletred: '#DB7093', + papayawhip: '#FFEFD5', + peachpuff: '#FFDAB9', + peru: '#CD853F', + pink: '#FFC0CB', + plum: '#DDA0DD', + powderblue: '#B0E0E6', + purple: '#800080', + rebeccapurple: '#663399', + red: '#FF0000', + rosybrown: '#BC8F8F', + royalblue: '#4169E1', + saddlebrown: '#8B4513', + salmon: '#FA8072', + sandybrown: '#F4A460', + seagreen: '#2E8B57', + seashell: '#FFF5EE', + sienna: '#A0522D', + silver: '#C0C0C0', + skyblue: '#87CEEB', + slateblue: '#6A5ACD', + slategray: '#708090', + slategrey: '#708090', + snow: '#FFFAFA', + springgreen: '#00FF7F', + steelblue: '#4682B4', + tan: '#D2B48C', + teal: '#008080', + thistle: '#D8BFD8', + tomato: '#FF6347', + turquoise: '#40E0D0', + violet: '#EE82EE', + wheat: '#F5DEB3', + white: '#FFFFFF', + whitesmoke: '#F5F5F5', + yellow: '#FFFF00', + yellowgreen: '#9ACD32' + }); + return Color; +}()); + + + +/***/ }), +/* 39 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "stringToArray", function() { return stringToArray; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +// Based on https://stackoverflow.com/a/14991797 +// This will parse a delimited string into an array of arrays. +function stringToArray(strData, delimiter) { + if (delimiter === void 0) { delimiter = ','; } + var data = []; + var isNewline = function (char) { return char === '\r' || char === '\n'; }; + var insideQuotedField = false; + if (strData === '') { + return [['']]; + } + var _loop_1 = function (row, column, position) { + var previousChar = strData[position - 1]; + var currentChar = strData[position]; + var nextChar = strData[position + 1]; + var ensureDataExists = function () { + if (!data[row]) { + // create row if it doesn't exist + data[row] = []; + } + if (!data[row][column]) { + // create column if it doesn't exist + data[row][column] = ''; + } + }; + ensureDataExists(); + if (currentChar === '"') { + if (insideQuotedField) { + if (nextChar === '"') { + // unescape double quote + data[row][column] += '"'; + position++; + } + else { + // exit quoted field + insideQuotedField = false; + } + return out_row_1 = row, out_column_1 = column, out_position_1 = position, "continue"; + } + else if (previousChar === undefined || previousChar === delimiter || isNewline(previousChar)) { + // enter quoted field + insideQuotedField = true; + return out_row_1 = row, out_column_1 = column, out_position_1 = position, "continue"; + } + } + if (!insideQuotedField) { + if (currentChar === delimiter) { + // move to next column + column++; + ensureDataExists(); + return out_row_1 = row, out_column_1 = column, out_position_1 = position, "continue"; + } + else if (isNewline(currentChar)) { + // move to next row + column = 0; + row++; + ensureDataExists(); + if (currentChar === '\r' && nextChar === '\n') { + // skip over second newline character if it exists + position++; + } + return out_row_1 = row, out_column_1 = column, out_position_1 = position, "continue"; + } + } + // add current character to current column + data[row][column] += currentChar; + out_row_1 = row; + out_column_1 = column; + out_position_1 = position; + }; + var out_row_1, out_column_1, out_position_1; + // iterate over each character, keep track of current row and column (of the returned array) + for (var row = 0, column = 0, position = 0; position < strData.length; position++) { + _loop_1(row, column, position); + row = out_row_1; + column = out_column_1; + position = out_position_1; + } + return data; +} + + +/***/ }), +/* 40 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "_", function() { return _; }); +/* harmony import */ var _general__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(41); +/* harmony import */ var _aria__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(44); +/* harmony import */ var _array__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(18); +/* harmony import */ var _browser__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43); +/* harmony import */ var _csv__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(39); +/* harmony import */ var _date__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(45); +/* harmony import */ var _dom__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(42); +/* harmony import */ var _event__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(21); +/* harmony import */ var _function__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(14); +/* harmony import */ var _fuzzyMatch__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(47); +/* harmony import */ var _generic__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(7); +/* harmony import */ var _icon__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(48); +/* harmony import */ var _keyboard__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(49); +/* harmony import */ var _map__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(27); +/* harmony import */ var _mouse__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(50); +/* harmony import */ var _number__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(46); +/* harmony import */ var _object__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(13); +/* harmony import */ var _rowNode__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(51); +/* harmony import */ var _set__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(52); +/* harmony import */ var _string__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(26); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __assign = (undefined && undefined.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; + + + + + + + + + + + + + + + + + + + + +var utils = __assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign({}, _general__WEBPACK_IMPORTED_MODULE_0__), _aria__WEBPACK_IMPORTED_MODULE_1__), _array__WEBPACK_IMPORTED_MODULE_2__), _browser__WEBPACK_IMPORTED_MODULE_3__), _csv__WEBPACK_IMPORTED_MODULE_4__), _date__WEBPACK_IMPORTED_MODULE_5__), _dom__WEBPACK_IMPORTED_MODULE_6__), _event__WEBPACK_IMPORTED_MODULE_7__), _function__WEBPACK_IMPORTED_MODULE_8__), _fuzzyMatch__WEBPACK_IMPORTED_MODULE_9__), _generic__WEBPACK_IMPORTED_MODULE_10__), _icon__WEBPACK_IMPORTED_MODULE_11__), _keyboard__WEBPACK_IMPORTED_MODULE_12__), _map__WEBPACK_IMPORTED_MODULE_13__), _mouse__WEBPACK_IMPORTED_MODULE_14__), _number__WEBPACK_IMPORTED_MODULE_15__), _object__WEBPACK_IMPORTED_MODULE_16__), _rowNode__WEBPACK_IMPORTED_MODULE_17__), _set__WEBPACK_IMPORTED_MODULE_18__), _string__WEBPACK_IMPORTED_MODULE_19__); +var _ = utils; + + +/***/ }), +/* 41 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getNameOfClass", function() { return getNameOfClass; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "findLineByLeastSquares", function() { return findLineByLeastSquares; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssStyleObjectToMarkup", function() { return cssStyleObjectToMarkup; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "message", function() { return message; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "bindCellRendererToHtmlElement", function() { return bindCellRendererToHtmlElement; }); +/* harmony import */ var _dom__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(42); +/* harmony import */ var _string__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(26); +/* harmony import */ var _object__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(13); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ * @license MIT */ @@ -1857,6 +10482,11 @@ function findLineByLeastSquares(values) { } for (var i = 0; i < values.length; i++) { var value = values[i]; + var splitExponent = value.toString().split('e-'); + if (splitExponent.length > 1) { + maxDecimals = Math.max(maxDecimals, parseInt(splitExponent[1], 10)); + continue; + } if (Math.floor(value) === value) { continue; } @@ -1901,7 +10531,7 @@ function cssStyleObjectToMarkup(stylesToUse) { /** * Displays a message to the browser. this is useful in iPad, where you can't easily see the console. * so the javascript code can use this to give feedback. this is NOT intended to be called in production. - * it is intended the ag-Grid developer calls this to troubleshoot, but then takes out the calls before + * it is intended the AG Grid developer calls this to troubleshoot, but then takes out the calls before * checking in. * @param {string} msg */ @@ -1921,7 +10551,7 @@ function message(msg) { /** * cell renderers are used in a few places. they bind to dom slightly differently to other cell renderes as they * can return back strings (instead of html elemnt) in the getGui() method. common code placed here to handle that. - * @param {Promise} cellRendererPromise + * @param {AgPromise} cellRendererPromise * @param {HTMLElement} eTarget */ function bindCellRendererToHtmlElement(cellRendererPromise, eTarget) { @@ -1940,16 +10570,13 @@ function bindCellRendererToHtmlElement(cellRendererPromise, eTarget) { /***/ }), -/* 12 */ +/* 42 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addCssClass", function() { return addCssClass; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeCssClass", function() { return removeCssClass; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addOrRemoveCssClass", function() { return addOrRemoveCssClass; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "radioCssClass", function() { return radioCssClass; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "containsClass", function() { return containsClass; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isFocusableFormField", function() { return isFocusableFormField; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setDisplayed", function() { return setDisplayed; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setVisible", function() { return setVisible; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setDisabled", function() { return setDisabled; }); @@ -1959,6 +10586,7 @@ __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getInnerWidth", function() { return getInnerWidth; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getAbsoluteHeight", function() { return getAbsoluteHeight; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getAbsoluteWidth", function() { return getAbsoluteWidth; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isRtlNegativeScroll", function() { return isRtlNegativeScroll; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getScrollLeft", function() { return getScrollLeft; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setScrollLeft", function() { return setScrollLeft; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "clearElement", function() { return clearElement; }); @@ -1972,7 +10600,7 @@ __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "offsetWidth", function() { return offsetWidth; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ensureDomOrder", function() { return ensureDomOrder; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setDomChildOrder", function() { return setDomChildOrder; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "insertTemplateWithDomOrder", function() { return insertTemplateWithDomOrder; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "insertWithDomOrder", function() { return insertWithDomOrder; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "prependDC", function() { return prependDC; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addStylesToElement", function() { return addStylesToElement; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isHorizontalScrollShowing", function() { return isHorizontalScrollShowing; }); @@ -1988,60 +10616,25 @@ __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "copyNodeList", function() { return copyNodeList; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "iterateNamedNodeMap", function() { return iterateNamedNodeMap; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setCheckboxState", function() { return setCheckboxState; }); -/* harmony import */ var _browser__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(13); -/* harmony import */ var _generic__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(14); -/* harmony import */ var _string__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(15); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addOrRemoveAttribute", function() { return addOrRemoveAttribute; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "nodeListForEach", function() { return nodeListForEach; }); +/* harmony import */ var _browser__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(43); +/* harmony import */ var _generic__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7); +/* harmony import */ var _object__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(13); +/* harmony import */ var _string__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(26); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(15); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -function addCssClass(element, className) { - if (!className || className.length === 0) { - return; - } - if (className.indexOf(' ') >= 0) { - className.split(' ').forEach(function (value) { return addCssClass(element, value); }); - return; - } - if (element.classList) { - element.classList.add(className); - } - else if (element.className && element.className.length > 0) { - var cssClasses = element.className.split(' '); - if (cssClasses.indexOf(className) < 0) { - cssClasses.push(className); - element.setAttribute('class', cssClasses.join(' ')); - } - } - else { - // do not use element.classList = className here, it will cause - // a read-only assignment error on some browsers (IE/Edge). - element.setAttribute('class', className); - } - return element; -} -function removeCssClass(element, className) { - if (element.classList) { - element.classList.remove(className); - } - else if (element.className && element.className.length > 0) { - var newClassName = element.className.split(' ').filter(function (c) { return c !== className; }).join(' '); - element.setAttribute('class', newClassName); - } -} -function addOrRemoveCssClass(element, className, addOrRemove) { - if (addOrRemove) { - addCssClass(element, className); - } - else { - removeCssClass(element, className); - } -} + + +var rtlNegativeScroll; /** * This method adds a class to an element and remove that class from all siblings. * Useful for toggling state. @@ -2051,56 +10644,43 @@ function addOrRemoveCssClass(element, className, addOrRemove) { */ function radioCssClass(element, elementClass, otherElementClass) { var parent = element.parentElement; - var sibling = parent.firstChild; + var sibling = parent && parent.firstChild; while (sibling) { if (elementClass) { - addOrRemoveCssClass(sibling, elementClass, sibling === element); + sibling.classList.toggle(elementClass, sibling === element); } if (otherElementClass) { - addOrRemoveCssClass(sibling, otherElementClass, sibling !== element); + sibling.classList.toggle(otherElementClass, sibling !== element); } sibling = sibling.nextSibling; } } -function containsClass(element, className) { - if (element.classList) { - // for modern browsers - return element.classList.contains(className); - } - if (element.className) { - // for older browsers, check against the string of class names - // if only one class, can check for exact match - var onlyClass = element.className === className; - // if many classes, check for class name, we have to pad with ' ' to stop other - // class names that are a substring of this class - var contains = element.className.indexOf(' ' + className + ' ') >= 0; - // the padding above then breaks when it's the first or last class names - var startsWithClass = element.className.indexOf(className + ' ') === 0; - var endsWithClass = element.className.lastIndexOf(' ' + className) === (element.className.length - className.length - 1); - return onlyClass || contains || startsWithClass || endsWithClass; - } - // if item is not a node - return false; +function isFocusableFormField(element) { + var matches = Element.prototype.matches || Element.prototype.msMatchesSelector; + var isFocusable = matches.call(element, _constants_constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].INPUT_SELECTOR); + var isNotFocusable = matches.call(element, _constants_constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].FOCUSABLE_EXCLUDE); + var isElementVisible = isVisible(element); + var focusable = isFocusable && !isNotFocusable && isElementVisible; + return focusable; } function setDisplayed(element, displayed) { - addOrRemoveCssClass(element, 'ag-hidden', !displayed); + element.classList.toggle('ag-hidden', !displayed); } function setVisible(element, visible) { - addOrRemoveCssClass(element, 'ag-invisible', !visible); + element.classList.toggle('ag-invisible', !visible); } function setDisabled(element, disabled) { var attributeName = 'disabled'; - if (disabled) { - element.setAttribute(attributeName, ''); - } - else { - element.removeAttribute(attributeName); - } + var addOrRemoveDisabledAttribute = disabled ? + function (e) { return e.setAttribute(attributeName, ''); } : + function (e) { return e.removeAttribute(attributeName); }; + addOrRemoveDisabledAttribute(element); + nodeListForEach(element.querySelectorAll('input'), function (input) { return addOrRemoveDisabledAttribute(input); }); } function isElementChildOfClass(element, cls, maxNest) { var counter = 0; while (element) { - if (containsClass(element, cls)) { + if (element.classList.contains(cls)) { return true; } element = element.parentElement; @@ -2110,6 +10690,10 @@ function isElementChildOfClass(element, cls, maxNest) { } return false; } +// returns back sizes as doubles instead of strings. similar to +// getBoundingClientRect, however getBoundingClientRect does not: +// a) work with fractions (eg browser is zooming) +// b) has CSS transitions applied (eg CSS scale, browser zoom), which we don't want, we want the un-transitioned values function getElementSize(el) { var _a = window.getComputedStyle(el), height = _a.height, width = _a.width, paddingTop = _a.paddingTop, paddingRight = _a.paddingRight, paddingBottom = _a.paddingBottom, paddingLeft = _a.paddingLeft, marginTop = _a.marginTop, marginRight = _a.marginRight, marginBottom = _a.marginBottom, marginLeft = _a.marginLeft, boxSizing = _a.boxSizing; return { @@ -2150,13 +10734,32 @@ function getAbsoluteWidth(el) { var marginWidth = size.marginLeft + size.marginRight; return Math.ceil(el.offsetWidth + marginWidth); } +function isRtlNegativeScroll() { + if (typeof rtlNegativeScroll === "boolean") { + return rtlNegativeScroll; + } + var template = document.createElement('div'); + template.style.direction = 'rtl'; + template.style.width = '1px'; + template.style.height = '1px'; + template.style.position = 'fixed'; + template.style.top = '0px'; + template.style.overflow = 'hidden'; + template.dir = 'rtl'; + template.innerHTML = /* html */ + "
\n \n \n
"; + document.body.appendChild(template); + template.scrollLeft = 1; + rtlNegativeScroll = Math.floor(template.scrollLeft) === 0; + document.body.removeChild(template); + return rtlNegativeScroll; +} function getScrollLeft(element, rtl) { var scrollLeft = element.scrollLeft; if (rtl) { // Absolute value - for FF that reports RTL scrolls in negative numbers scrollLeft = Math.abs(scrollLeft); - // Get Chrome to return the same value as well - if (Object(_browser__WEBPACK_IMPORTED_MODULE_0__["isBrowserChrome"])()) { + if (Object(_browser__WEBPACK_IMPORTED_MODULE_0__["isBrowserChrome"])() && !isRtlNegativeScroll()) { scrollLeft = element.scrollWidth - element.clientWidth - scrollLeft; } } @@ -2165,13 +10768,12 @@ function getScrollLeft(element, rtl) { function setScrollLeft(element, value, rtl) { if (rtl) { // Chrome and Safari when doing RTL have the END position of the scroll as zero, not the start - if (Object(_browser__WEBPACK_IMPORTED_MODULE_0__["isBrowserSafari"])() || Object(_browser__WEBPACK_IMPORTED_MODULE_0__["isBrowserChrome"])()) { - value = element.scrollWidth - element.clientWidth - value; - } - // Firefox uses negative numbers when doing RTL scrolling - if (Object(_browser__WEBPACK_IMPORTED_MODULE_0__["isBrowserFirefox"])()) { + if (isRtlNegativeScroll()) { value *= -1; } + else if (Object(_browser__WEBPACK_IMPORTED_MODULE_0__["isBrowserSafari"])() || Object(_browser__WEBPACK_IMPORTED_MODULE_0__["isBrowserChrome"])()) { + value = element.scrollWidth - element.clientWidth - value; + } } element.scrollLeft = value; } @@ -2199,6 +10801,12 @@ function isVisible(element) { * @returns {HTMLElement} */ function loadTemplate(template) { + // we try the DOMParser first, as SalesForce doesn't like using innerHTML on a div + if (DOMParser !== null) { + var parser = new DOMParser(); + var doc = parser.parseFromString(template, "text/html"); + return doc.body.firstChild; + } var tempDiv = document.createElement('div'); tempDiv.innerHTML = (template || '').trim(); return tempDiv.firstChild; @@ -2261,25 +10869,21 @@ function setDomChildOrder(eContainer, orderedChildren) { } } } -function insertTemplateWithDomOrder(eContainer, htmlTemplate, eChildBefore) { - var res; +function insertWithDomOrder(eContainer, eToInsert, eChildBefore) { if (eChildBefore) { // if previous element exists, just slot in after the previous element - eChildBefore.insertAdjacentHTML('afterend', htmlTemplate); - res = eChildBefore.nextSibling; + eChildBefore.insertAdjacentElement('afterend', eToInsert); } else { if (eContainer.firstChild) { // insert it at the first location - eContainer.insertAdjacentHTML('afterbegin', htmlTemplate); + eContainer.insertAdjacentElement('afterbegin', eToInsert); } else { // otherwise eContainer is empty, so just append it - eContainer.innerHTML = htmlTemplate; + eContainer.appendChild(eToInsert); } - res = eContainer.firstChild; } - return res; } /** @deprecated */ function prependDC(parent, documentFragment) { @@ -2295,7 +10899,7 @@ function addStylesToElement(eElement, styles) { return; } Object.keys(styles).forEach(function (key) { - var keyCamelCase = Object(_string__WEBPACK_IMPORTED_MODULE_2__["hyphenToCamelCase"])(key); + var keyCamelCase = Object(_string__WEBPACK_IMPORTED_MODULE_3__["hyphenToCamelCase"])(key); if (keyCamelCase) { eElement.style[keyCamelCase] = styles[key]; } @@ -2309,9 +10913,9 @@ function isVerticalScrollShowing(element) { } function setElementWidth(element, width) { if (width === 'flex') { - element.style.width = null; - element.style.minWidth = null; - element.style.maxWidth = null; + element.style.removeProperty('width'); + element.style.removeProperty('minWidth'); + element.style.removeProperty('maxWidth'); element.style.flex = '1 1 auto'; } else { @@ -2326,9 +10930,9 @@ function setFixedWidth(element, width) { } function setElementHeight(element, height) { if (height === 'flex') { - element.style.height = null; - element.style.minHeight = null; - element.style.maxHeight = null; + element.style.removeProperty('height'); + element.style.removeProperty('minHeight'); + element.style.removeProperty('maxHeight'); element.style.flex = '1 1 auto'; } else { @@ -2368,7 +10972,7 @@ function isNode(o) { function isElement(o) { return (typeof HTMLElement === 'function' ? o instanceof HTMLElement //DOM2 - : o && typeof o === 'object' && o !== null && o.nodeType === 1 && typeof o.nodeName === 'string'); + : o && Object(_object__WEBPACK_IMPORTED_MODULE_2__["isNonNullObject"])(o) && o.nodeType === 1 && typeof o.nodeName === 'string'); } function isNodeOrElement(o) { return isNode(o) || isElement(o); @@ -2379,12 +10983,12 @@ function isNodeOrElement(o) { * @returns {Node[]} */ function copyNodeList(nodeList) { - var childCount = nodeList ? nodeList.length : 0; - var res = []; - for (var i = 0; i < childCount; i++) { - res.push(nodeList[i]); + if (nodeList == null) { + return []; } - return res; + var result = []; + nodeListForEach(nodeList, function (node) { return result.push(node); }); + return result; } function iterateNamedNodeMap(map, callback) { if (!map) { @@ -2407,15 +11011,30 @@ function setCheckboxState(eCheckbox, state) { eCheckbox.indeterminate = true; } } +function addOrRemoveAttribute(element, name, value) { + if (value == null) { + element.removeAttribute(name); + } + else { + element.setAttribute(name, value.toString()); + } +} +function nodeListForEach(nodeList, action) { + if (nodeList == null) { + return; + } + for (var i = 0; i < nodeList.length; i++) { + action(nodeList[i]); + } +} /***/ }), -/* 13 */ +/* 43 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isBrowserIE", function() { return isBrowserIE; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isBrowserEdge", function() { return isBrowserEdge; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isBrowserSafari", function() { return isBrowserSafari; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isBrowserChrome", function() { return isBrowserChrome; }); @@ -2424,15 +11043,27 @@ __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getTabIndex", function() { return getTabIndex; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getMaxDivHeight", function() { return getMaxDivHeight; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getScrollbarWidth", function() { return getScrollbarWidth; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isInvisibleScrollbar", function() { return isInvisibleScrollbar; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "hasOverflowScrolling", function() { return hasOverflowScrolling; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getBodyWidth", function() { return getBodyWidth; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getBodyHeight", function() { return getBodyHeight; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ +var __values = (undefined && undefined.__values) || function(o) { + var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0; + if (m) return m.call(o); + if (o && typeof o.length === "number") return { + next: function () { + if (o && i >= o.length) o = void 0; + return { value: o && o[i++], done: !o }; + } + }; + throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined."); +}; /** * These variables are lazy loaded, as otherwise they try and get initialised when we are loading * unit tests and we don't have references to window or document in the unit tests @@ -2444,6 +11075,8 @@ var isEdge; var isChrome; var isFirefox; var isIOS; +var invisibleScrollbar; +var browserScrollbarWidth; function isBrowserIE() { if (isIE === undefined) { isIE = /*@cc_on!@*/ false || !!document.documentMode; // At least IE6 @@ -2458,11 +11091,8 @@ function isBrowserEdge() { } function isBrowserSafari() { if (isSafari === undefined) { - // taken from https://github.com/ag-grid/ag-grid/issues/550 - var anyWindow = window; - var hasNotification = function (p) { return p && p.toString() === '[object SafariRemoteNotification]'; }; - isSafari = Object.prototype.toString.call(anyWindow.HTMLElement).indexOf('Constructor') > 0 - || hasNotification(anyWindow.safari && anyWindow.safari.pushNotification); + // taken from https://stackoverflow.com/a/23522755/1388233 + isSafari = /^((?!chrome|android).)*safari/i.test(navigator.userAgent); } return isSafari; } @@ -2487,6 +11117,7 @@ function isIOSUserAgent() { isIOS = (/iPad|iPhone|iPod/.test(navigator.platform) || // eslint-disable-next-line (navigator.platform === 'MacIntel' && navigator.maxTouchPoints > 1)) && + // @ts-ignore !window.MSStream; } return isIOS; @@ -2497,22 +11128,6 @@ function getTabIndex(el) { } var numberTabIndex = el.tabIndex; var tabIndex = el.getAttribute('tabIndex'); - if (isBrowserIE() && numberTabIndex === 0 && el.getAttribute('tabIndex') === null) { - var map = { - a: true, - body: true, - button: true, - frame: true, - iframe: true, - img: true, - input: true, - isindex: true, - object: true, - select: true, - textarea: true - }; - return map[el.nodeName.toLowerCase()] === true ? '0' : null; - } if (numberTabIndex === -1 && (tabIndex === null || (tabIndex === '' && !isBrowserFirefox()))) { return null; } @@ -2528,19 +11143,25 @@ function getMaxDivHeight() { var div = document.createElement('div'); document.body.appendChild(div); while (true) { - var test_1 = res * 2; - div.style.height = test_1 + 'px'; - if (test_1 > testUpTo || div.clientHeight !== test_1) { + var test = res * 2; + div.style.height = test + 'px'; + if (test > testUpTo || div.clientHeight !== test) { break; } else { - res = test_1; + res = test; } } document.body.removeChild(div); return res; } function getScrollbarWidth() { + if (browserScrollbarWidth == null) { + initScrollbarWidthAndVisibility(); + } + return browserScrollbarWidth; +} +function initScrollbarWidthAndVisibility() { var body = document.body; var div = document.createElement('div'); div.style.width = div.style.height = '100px'; @@ -2550,14 +11171,28 @@ function getScrollbarWidth() { div.style.position = 'absolute'; body.appendChild(div); var width = div.offsetWidth - div.clientWidth; - // remove divs + // if width is 0 and client width is 0, means the DOM isn't ready + if (width === 0 && div.clientWidth === 0) { + width = null; + } + // remove div if (div.parentNode) { div.parentNode.removeChild(div); } - return width; + if (width != null) { + browserScrollbarWidth = width; + invisibleScrollbar = width === 0; + } +} +function isInvisibleScrollbar() { + if (invisibleScrollbar == null) { + initScrollbarWidthAndVisibility(); + } + return invisibleScrollbar; } /** @deprecated */ function hasOverflowScrolling() { + var e_1, _a; var prefixes = ['webkit', 'moz', 'o', 'ms']; var div = document.createElement('div'); var body = document.getElementsByTagName('body')[0]; @@ -2570,792 +11205,256 @@ function hasOverflowScrolling() { found = true; } if (!found) { - for (var _i = 0, prefixes_1 = prefixes; _i < prefixes_1.length; _i++) { - p = prefixes_1[_i]; - if (computedStyle[p + "OverflowScrolling"] === 'touch') { - found = true; - break; - } - } - } - if (div.parentNode) { - div.parentNode.removeChild(div); - } - return found; -} -/** - * Gets the document body width - * from: http://stackoverflow.com/questions/1038727/how-to-get-browser-width-using-javascript-code - * @returns {number} - */ -function getBodyWidth() { - if (document.body) { - return document.body.clientWidth; - } - if (window.innerHeight) { - return window.innerWidth; - } - if (document.documentElement && document.documentElement.clientWidth) { - return document.documentElement.clientWidth; - } - return -1; -} -/** - * Gets the body height - * from: http://stackoverflow.com/questions/1038727/how-to-get-browser-width-using-javascript-code - * @returns {number} - */ -function getBodyHeight() { - if (document.body) { - return document.body.clientHeight; - } - if (window.innerHeight) { - return window.innerHeight; - } - if (document.documentElement && document.documentElement.clientHeight) { - return document.documentElement.clientHeight; - } - return -1; -} - - -/***/ }), -/* 14 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "makeNull", function() { return makeNull; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "exists", function() { return exists; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "missing", function() { return missing; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "missingOrEmpty", function() { return missingOrEmpty; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "toStringOrNull", function() { return toStringOrNull; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "referenceCompare", function() { return referenceCompare; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "jsonEquals", function() { return jsonEquals; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "defaultComparator", function() { return defaultComparator; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "find", function() { return find; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "values", function() { return values; }); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -/** - * If value is undefined, null or blank, returns null, otherwise returns the value - * @param {T} value - * @returns {T | null} - */ -function makeNull(value) { - return value == null || value === '' ? null : value; -} -function exists(value, allowEmptyString) { - if (allowEmptyString === void 0) { allowEmptyString = false; } - return value != null && (allowEmptyString || value !== ''); -} -function missing(value) { - return !exists(value); -} -function missingOrEmpty(value) { - return !value || missing(value) || value.length === 0; -} -function toStringOrNull(value) { - return exists(value) && value.toString ? value.toString() : null; -} -/** @deprecated */ -function referenceCompare(left, right) { - if (left == null && right == null) { - return true; - } - if (left == null && right != null) { - return false; - } - if (left != null && right == null) { - return false; - } - return left === right; -} -function jsonEquals(val1, val2) { - var val1Json = val1 ? JSON.stringify(val1) : null; - var val2Json = val2 ? JSON.stringify(val2) : null; - return val1Json === val2Json; -} -function defaultComparator(valueA, valueB, accentedCompare) { - if (accentedCompare === void 0) { accentedCompare = false; } - var valueAMissing = valueA == null; - var valueBMissing = valueB == null; - // this is for aggregations sum and avg, where the result can be a number that is wrapped. - // if we didn't do this, then the toString() value would be used, which would result in - // the strings getting used instead of the numbers. - if (valueA && valueA.toNumber) { - valueA = valueA.toNumber(); - } - if (valueB && valueB.toNumber) { - valueB = valueB.toNumber(); - } - if (valueAMissing && valueBMissing) { - return 0; - } - if (valueAMissing) { - return -1; - } - if (valueBMissing) { - return 1; - } - function doQuickCompare(a, b) { - return (a > b ? 1 : (a < b ? -1 : 0)); - } - if (typeof valueA === 'string') { - if (!accentedCompare) { - return doQuickCompare(valueA, valueB); - } try { - // using local compare also allows chinese comparisons - return valueA.localeCompare(valueB); - } - catch (e) { - // if something wrong with localeCompare, eg not supported - // by browser, then just continue with the quick one - return doQuickCompare(valueA, valueB); - } - } - return doQuickCompare(valueA, valueB); -} -function find(collection, predicate, value) { - if (collection === null || collection === undefined) { - return null; - } - if (!Array.isArray(collection)) { - var objToArray = values(collection); - return find(objToArray, predicate, value); - } - var collectionAsArray = collection; - var firstMatchingItem = null; - for (var i = 0; i < collectionAsArray.length; i++) { - var item = collectionAsArray[i]; - if (typeof predicate === 'string') { - if (item[predicate] === value) { - firstMatchingItem = item; - break; - } - } - else { - var callback = predicate; - if (callback(item)) { - firstMatchingItem = item; - break; - } - } - } - return firstMatchingItem; -} -function values(object) { - if (object instanceof Set || object instanceof Map) { - var values_1 = []; - object.forEach(function (value) { return values_1.push(value); }); - return values_1; - } - return Object.keys(object).map(function (key) { return object[key]; }); -} - - -/***/ }), -/* 15 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "utf8_encode", function() { return utf8_encode; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "camelCaseToHyphen", function() { return camelCaseToHyphen; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "hyphenToCamelCase", function() { return hyphenToCamelCase; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "capitalise", function() { return capitalise; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "escape", function() { return escape; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "camelCaseToHumanText", function() { return camelCaseToHumanText; }); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var reUnescapedHtml = /[&<>"']/g; -/** - * HTML Escapes. - */ -var HTML_ESCAPES = { - '&': '&', - '<': '<', - '>': '>', - '"': '"', - "'": ''' -}; -/** - * It encodes any string in UTF-8 format - * taken from https://github.com/mathiasbynens/utf8.js - * @param {string} s - * @returns {string} - */ -function utf8_encode(s) { - var stringFromCharCode = String.fromCharCode; - function ucs2decode(string) { - var output = []; - var counter = 0; - var length = string.length; - var value; - var extra; - while (counter < length) { - value = string.charCodeAt(counter++); - if (value >= 0xD800 && value <= 0xDBFF && counter < length) { - // high surrogate, and there is a next character - extra = string.charCodeAt(counter++); - if ((extra & 0xFC00) == 0xDC00) { // low surrogate - output.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000); - } - else { - // unmatched surrogate; only append this code unit, in case the next - // code unit is the high surrogate of a surrogate pair - output.push(value); - counter--; - } - } - else { - output.push(value); - } - } - return output; - } - function checkScalarValue(codePoint) { - if (codePoint >= 0xD800 && codePoint <= 0xDFFF) { - throw Error('Lone surrogate U+' + codePoint.toString(16).toUpperCase() + - ' is not a scalar value'); - } - } - function createByte(codePoint, shift) { - return stringFromCharCode(((codePoint >> shift) & 0x3F) | 0x80); - } - function encodeCodePoint(codePoint) { - if ((codePoint & 0xFFFFFF80) == 0) { // 1-byte sequence - return stringFromCharCode(codePoint); - } - var symbol = ''; - if ((codePoint & 0xFFFFF800) == 0) { // 2-byte sequence - symbol = stringFromCharCode(((codePoint >> 6) & 0x1F) | 0xC0); - } - else if ((codePoint & 0xFFFF0000) == 0) { // 3-byte sequence - checkScalarValue(codePoint); - symbol = stringFromCharCode(((codePoint >> 12) & 0x0F) | 0xE0); - symbol += createByte(codePoint, 6); - } - else if ((codePoint & 0xFFE00000) == 0) { // 4-byte sequence - symbol = stringFromCharCode(((codePoint >> 18) & 0x07) | 0xF0); - symbol += createByte(codePoint, 12); - symbol += createByte(codePoint, 6); - } - symbol += stringFromCharCode((codePoint & 0x3F) | 0x80); - return symbol; - } - var codePoints = ucs2decode(s); - var length = codePoints.length; - var index = -1; - var codePoint; - var byteString = ''; - while (++index < length) { - codePoint = codePoints[index]; - byteString += encodeCodePoint(codePoint); - } - return byteString; -} -/** - * Converts a camelCase string into hyphenated string - * from https://gist.github.com/youssman/745578062609e8acac9f - * @param {string} str - * @return {string} - */ -function camelCaseToHyphen(str) { - if (str === null || str === undefined) { - return null; - } - return str.replace(/([A-Z])/g, function (g) { return '-' + g[0].toLowerCase(); }); -} -/** - * Converts a hyphenated string into camelCase string - * from https://stackoverflow.com/questions/6660977/convert-hyphens-to-camel-case-camelcase - * @param {string} str - * @return {string} - */ -function hyphenToCamelCase(str) { - if (str === null || str === undefined) { - return null; - } - return str.replace(/-([a-z])/g, function (g) { return g[1].toUpperCase(); }); -} -function capitalise(str) { - return str[0].toUpperCase() + str.substr(1).toLowerCase(); -} -function escape(toEscape) { - return toEscape == null || !toEscape.replace ? toEscape : toEscape.replace(reUnescapedHtml, function (chr) { return HTML_ESCAPES[chr]; }); -} -/** - * Converts a camelCase string into regular text - * from: https://stackoverflow.com/questions/15369566/putting-space-in-camel-case-string-using-regular-expression - * @param {string} camelCase - * @return {string} - */ -function camelCaseToHumanText(camelCase) { - if (!camelCase || camelCase == null) { - return null; - } - var rex = /([A-Z])([A-Z])([a-z])|([a-z])([A-Z])/g; - var words = camelCase.replace(rex, '$1$4 $2$3$5').replace('.', ' ').split(' '); - return words.map(function (word) { return word.substring(0, 1).toUpperCase() + ((word.length > 1) ? word.substring(1, word.length) : ''); }).join(' '); -} - - -/***/ }), -/* 16 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "iterateObject", function() { return iterateObject; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cloneObject", function() { return cloneObject; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "deepCloneObject", function() { return deepCloneObject; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getProperty", function() { return getProperty; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setProperty", function() { return setProperty; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "copyPropertiesIfPresent", function() { return copyPropertiesIfPresent; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "copyPropertyIfPresent", function() { return copyPropertyIfPresent; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getAllKeysInObjects", function() { return getAllKeysInObjects; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "mergeDeep", function() { return mergeDeep; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "assign", function() { return assign; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "missingOrEmptyObject", function() { return missingOrEmptyObject; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "get", function() { return get; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "set", function() { return set; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "deepFreeze", function() { return deepFreeze; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getValueUsingField", function() { return getValueUsingField; }); -/* harmony import */ var _generic__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(14); -/* harmony import */ var _array__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(17); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ - - -function iterateObject(object, callback) { - if (object == null) { - return; - } - if (Array.isArray(object)) { - Object(_array__WEBPACK_IMPORTED_MODULE_1__["forEach"])(object, function (value, index) { return callback("" + index, value); }); - } - else { - Object(_array__WEBPACK_IMPORTED_MODULE_1__["forEach"])(Object.keys(object), function (key) { return callback(key, object[key]); }); - } -} -function cloneObject(object) { - var copy = {}; - var keys = Object.keys(object); - for (var i = 0; i < keys.length; i++) { - var key = keys[i]; - var value = object[key]; - copy[key] = value; - } - return copy; -} -function deepCloneObject(object) { - return JSON.parse(JSON.stringify(object)); -} -function getProperty(object, key) { - return object[key]; -} -function setProperty(object, key, value) { - object[key] = value; -} -/** - * Will copy the specified properties from `source` into the equivalent properties on `target`, ignoring properties with - * a value of `undefined`. - */ -function copyPropertiesIfPresent(source, target) { - var properties = []; - for (var _i = 2; _i < arguments.length; _i++) { - properties[_i - 2] = arguments[_i]; - } - Object(_array__WEBPACK_IMPORTED_MODULE_1__["forEach"])(properties, function (p) { return copyPropertyIfPresent(source, target, p); }); -} -/** - * Will copy the specified property from `source` into the equivalent property on `target`, unless the property has a - * value of `undefined`. If a transformation is provided, it will be applied to the value before being set on `target`. - */ -function copyPropertyIfPresent(source, target, property, transform) { - var value = getProperty(source, property); - if (value !== undefined) { - setProperty(target, property, transform ? transform(value) : value); - } -} -function getAllKeysInObjects(objects) { - var allValues = {}; - objects.filter(function (obj) { return obj != null; }).forEach(function (obj) { - Object(_array__WEBPACK_IMPORTED_MODULE_1__["forEach"])(Object.keys(obj), function (key) { return allValues[key] = null; }); - }); - return Object.keys(allValues); -} -function mergeDeep(dest, source, copyUndefined) { - if (copyUndefined === void 0) { copyUndefined = true; } - if (!Object(_generic__WEBPACK_IMPORTED_MODULE_0__["exists"])(source)) { - return; - } - iterateObject(source, function (key, newValue) { - var oldValue = dest[key]; - if (oldValue === newValue) { - return; - } - if (typeof oldValue === 'object' && typeof newValue === 'object' && !Array.isArray(oldValue)) { - mergeDeep(oldValue, newValue); - } - else if (copyUndefined || newValue !== undefined) { - dest[key] = newValue; - } - }); -} -function assign(object) { - var sources = []; - for (var _i = 1; _i < arguments.length; _i++) { - sources[_i - 1] = arguments[_i]; - } - Object(_array__WEBPACK_IMPORTED_MODULE_1__["forEach"])(sources, function (source) { return iterateObject(source, function (key, value) { return object[key] = value; }); }); - return object; -} -function missingOrEmptyObject(value) { - return Object(_generic__WEBPACK_IMPORTED_MODULE_0__["missing"])(value) || Object.keys(value).length === 0; -} -function get(source, expression, defaultValue) { - if (source == null) { - return defaultValue; - } - var keys = expression.split('.'); - var objectToRead = source; - while (keys.length > 1) { - objectToRead = objectToRead[keys.shift()]; - if (objectToRead == null) { - return defaultValue; - } - } - var value = objectToRead[keys[0]]; - return value != null ? value : defaultValue; -} -function set(target, expression, value) { - if (target == null) { - return; - } - var keys = expression.split('.'); - var objectToUpdate = target; - while (keys.length > 1) { - objectToUpdate = objectToUpdate[keys.shift()]; - if (objectToUpdate == null) { - return; + for (var prefixes_1 = __values(prefixes), prefixes_1_1 = prefixes_1.next(); !prefixes_1_1.done; prefixes_1_1 = prefixes_1.next()) { + p = prefixes_1_1.value; + if (computedStyle[p + "OverflowScrolling"] === 'touch') { + found = true; + break; + } + } + } + catch (e_1_1) { e_1 = { error: e_1_1 }; } + finally { + try { + if (prefixes_1_1 && !prefixes_1_1.done && (_a = prefixes_1.return)) _a.call(prefixes_1); + } + finally { if (e_1) throw e_1.error; } } } - objectToUpdate[keys[0]] = value; + if (div.parentNode) { + div.parentNode.removeChild(div); + } + return found; } -function deepFreeze(object) { - Object.freeze(object); - Object(_array__WEBPACK_IMPORTED_MODULE_1__["forEach"])(Object(_generic__WEBPACK_IMPORTED_MODULE_0__["values"])(object), function (v) { - if (v != null && (typeof v === 'object' || typeof v === 'function')) { - deepFreeze(v); - } - }); - return object; +/** + * Gets the document body width + * from: http://stackoverflow.com/questions/1038727/how-to-get-browser-width-using-javascript-code + * @returns {number} + */ +function getBodyWidth() { + if (document.body) { + return document.body.clientWidth; + } + if (window.innerHeight) { + return window.innerWidth; + } + if (document.documentElement && document.documentElement.clientWidth) { + return document.documentElement.clientWidth; + } + return -1; } -function getValueUsingField(data, field, fieldContainsDots) { - if (!field || !data) { - return; +/** + * Gets the body height + * from: http://stackoverflow.com/questions/1038727/how-to-get-browser-width-using-javascript-code + * @returns {number} + */ +function getBodyHeight() { + if (document.body) { + return document.body.clientHeight; } - // if no '.', then it's not a deep value - if (!fieldContainsDots) { - return data[field]; + if (window.innerHeight) { + return window.innerHeight; } - // otherwise it is a deep value, so need to dig for it - var fields = field.split('.'); - var currentObject = data; - for (var i = 0; i < fields.length; i++) { - currentObject = currentObject[fields[i]]; - if (Object(_generic__WEBPACK_IMPORTED_MODULE_0__["missing"])(currentObject)) { - return null; - } + if (document.documentElement && document.documentElement.clientHeight) { + return document.documentElement.clientHeight; } - return currentObject; + return -1; } /***/ }), -/* 17 */ +/* 44 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "firstExistingValue", function() { return firstExistingValue; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "anyExists", function() { return anyExists; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "existsAndNotEmpty", function() { return existsAndNotEmpty; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "last", function() { return last; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "areEqual", function() { return areEqual; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "compareArrays", function() { return compareArrays; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "shallowCompare", function() { return shallowCompare; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "sortNumerically", function() { return sortNumerically; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeRepeatsFromArray", function() { return removeRepeatsFromArray; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeFromArray", function() { return removeFromArray; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeAllFromArray", function() { return removeAllFromArray; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "insertIntoArray", function() { return insertIntoArray; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "insertArrayIntoArray", function() { return insertArrayIntoArray; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "moveInArray", function() { return moveInArray; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "includes", function() { return includes; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "flatten", function() { return flatten; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "pushAll", function() { return pushAll; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "toStrings", function() { return toStrings; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "findIndex", function() { return findIndex; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "every", function() { return every; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "some", function() { return some; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "forEach", function() { return forEach; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "map", function() { return map; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "filter", function() { return filter; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "reduce", function() { return reduce; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "forEachSnapshotFirst", function() { return forEachSnapshotFirst; }); -/* harmony import */ var _generic__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(14); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaRole", function() { return setAriaRole; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getAriaSortState", function() { return getAriaSortState; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getAriaLevel", function() { return getAriaLevel; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getAriaPosInSet", function() { return getAriaPosInSet; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getAriaDescribedBy", function() { return getAriaDescribedBy; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaLabel", function() { return setAriaLabel; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaLabelledBy", function() { return setAriaLabelledBy; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaDescribedBy", function() { return setAriaDescribedBy; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaLevel", function() { return setAriaLevel; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaDisabled", function() { return setAriaDisabled; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaExpanded", function() { return setAriaExpanded; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeAriaExpanded", function() { return removeAriaExpanded; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaSetSize", function() { return setAriaSetSize; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaPosInSet", function() { return setAriaPosInSet; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaMultiSelectable", function() { return setAriaMultiSelectable; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaRowCount", function() { return setAriaRowCount; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaRowIndex", function() { return setAriaRowIndex; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaColCount", function() { return setAriaColCount; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaColIndex", function() { return setAriaColIndex; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaColSpan", function() { return setAriaColSpan; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaSort", function() { return setAriaSort; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeAriaSort", function() { return removeAriaSort; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaSelected", function() { return setAriaSelected; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setAriaChecked", function() { return setAriaChecked; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ - -function firstExistingValue() { - var values = []; - for (var _i = 0; _i < arguments.length; _i++) { - values[_i] = arguments[_i]; - } - for (var i = 0; i < values.length; i++) { - var value = values[i]; - if (Object(_generic__WEBPACK_IMPORTED_MODULE_0__["exists"])(value)) { - return value; - } - } - return null; +// ARIA HELPER FUNCTIONS +function setAriaAttribute(element, attribute, value) { + element.setAttribute(ariaAttributeName(attribute), value.toString()); } -/** @deprecated */ -function anyExists(values) { - return values && firstExistingValue(values) != null; +function removeAriaAttribute(element, attribute) { + element.removeAttribute(ariaAttributeName(attribute)); } -function existsAndNotEmpty(value) { - return value != null && value.length > 0; +function ariaAttributeName(attribute) { + return "aria-" + attribute; } -function last(arr) { - if (!arr || !arr.length) { - return undefined; +function setAriaRole(element, role) { + if (role) { + element.setAttribute('role', role); + } + else { + element.removeAttribute('role'); } - return arr[arr.length - 1]; } -function areEqual(a, b, comparator) { - if (a == null && b == null) { - return true; +function getAriaSortState(column) { + var sort; + if (column.isSortAscending()) { + sort = 'ascending'; } - return a != null && - b != null && - a.length === b.length && - every(a, function (value, index) { return comparator ? comparator(value, b[index]) : b[index] === value; }); + else if (column.isSortDescending()) { + sort = 'descending'; + } + else { + sort = 'none'; + } + return sort; } -/** @deprecated */ -function compareArrays(array1, array2) { - return areEqual(array1, array2); +// ARIA ATTRIBUTE GETTERS +function getAriaLevel(element) { + return parseInt(element.getAttribute('aria-level'), 10); } -/** @deprecated */ -function shallowCompare(arr1, arr2) { - return areEqual(arr1, arr2); +function getAriaPosInSet(element) { + return parseInt(element.getAttribute('aria-posinset'), 10); } -function sortNumerically(array) { - return array.sort(function (a, b) { return a - b; }); +function getAriaDescribedBy(element) { + return element.getAttribute('aria-describedby') || ''; } -function removeRepeatsFromArray(array, object) { - if (!array) { - return; +// ARIA ATTRIBUTE SETTERS +function setAriaLabel(element, label) { + var key = 'label'; + if (label) { + setAriaAttribute(element, key, label); } - for (var index = array.length - 2; index >= 0; index--) { - var thisOneMatches = array[index] === object; - var nextOneMatches = array[index + 1] === object; - if (thisOneMatches && nextOneMatches) { - array.splice(index + 1, 1); - } + else { + removeAriaAttribute(element, key); } } -function removeFromArray(array, object) { - var index = array.indexOf(object); - if (index >= 0) { - array.splice(index, 1); +function setAriaLabelledBy(element, labelledBy) { + var key = 'labelledby'; + if (labelledBy) { + setAriaAttribute(element, key, labelledBy); + } + else { + removeAriaAttribute(element, key); } } -function removeAllFromArray(array, toRemove) { - forEach(toRemove, function (item) { return removeFromArray(array, item); }); -} -function insertIntoArray(array, object, toIndex) { - array.splice(toIndex, 0, object); -} -function insertArrayIntoArray(dest, src, toIndex) { - if (dest == null || src == null) { - return; +function setAriaDescribedBy(element, describedby) { + var key = 'describedby'; + if (describedby) { + setAriaAttribute(element, key, describedby); } - // put items in backwards, otherwise inserted items end up in reverse order - for (var i = src.length - 1; i >= 0; i--) { - var item = src[i]; - insertIntoArray(dest, item, toIndex); + else { + removeAriaAttribute(element, key); } } -function moveInArray(array, objectsToMove, toIndex) { - // first take out items from the array - removeAllFromArray(array, objectsToMove); - // now add the objects, in same order as provided to us, that means we start at the end - // as the objects will be pushed to the right as they are inserted - forEach(objectsToMove.slice().reverse(), function (obj) { return insertIntoArray(array, obj, toIndex); }); +function setAriaLevel(element, level) { + setAriaAttribute(element, 'level', level); } -function includes(array, value) { - return array.indexOf(value) > -1; +function setAriaDisabled(element, disabled) { + setAriaAttribute(element, 'disabled', disabled); } -function flatten(arrayOfArrays) { - return [].concat.apply([], arrayOfArrays); +function setAriaExpanded(element, expanded) { + setAriaAttribute(element, 'expanded', expanded); } -function pushAll(target, source) { - if (source == null || target == null) { - return; - } - forEach(source, function (value) { return target.push(value); }); +function removeAriaExpanded(element) { + removeAriaAttribute(element, 'expanded'); } -function toStrings(array) { - return map(array, _generic__WEBPACK_IMPORTED_MODULE_0__["toStringOrNull"]); +function setAriaSetSize(element, setsize) { + setAriaAttribute(element, 'setsize', setsize); } -function findIndex(collection, predicate) { - for (var i = 0; i < collection.length; i++) { - if (predicate(collection[i], i, collection)) { - return i; - } - } - return -1; +function setAriaPosInSet(element, position) { + setAriaAttribute(element, 'posinset', position); } -/** - * The implementation of Array.prototype.every in browsers is always slower than just using a simple for loop, so - * use this for improved performance. - * https://jsbench.me/bek91dtit8/ - */ -function every(list, predicate) { - if (list == null) { - return true; - } - for (var i = 0; i < list.length; i++) { - if (!predicate(list[i], i)) { - return false; - } - } - return true; +function setAriaMultiSelectable(element, multiSelectable) { + setAriaAttribute(element, 'multiselectable', multiSelectable); } -/** - * The implementation of Array.prototype.some in browsers is always slower than just using a simple for loop, so - * use this for improved performance. - * https://jsbench.me/5dk91e4tmt/ - */ -function some(list, predicate) { - if (list == null) { - return false; - } - for (var i = 0; i < list.length; i++) { - if (predicate(list[i], i)) { - return true; - } - } - return false; +function setAriaRowCount(element, rowCount) { + setAriaAttribute(element, 'rowcount', rowCount); } -/** - * The implementation of Array.prototype.forEach in browsers is often slower than just using a simple for loop, so - * use this for improved performance. - * https://jsbench.me/apk91elt8a/ - */ -function forEach(list, action) { - if (list == null) { - return; - } - for (var i = 0; i < list.length; i++) { - action(list[i], i); - } +function setAriaRowIndex(element, rowIndex) { + setAriaAttribute(element, 'rowindex', rowIndex); } -/** - * The implementation of Array.prototype.map in browsers is generally the same as just using a simple for loop. However, - * Firefox does exhibit some difference, and this performs no worse in other browsers, so use this if you want improved - * performance. - * https://jsbench.me/njk91ez8pc/ - */ -function map(list, process) { - if (list == null) { - return null; - } - var mapped = []; - for (var i = 0; i < list.length; i++) { - mapped.push(process(list[i], i)); - } - return mapped; +function setAriaColCount(element, colCount) { + setAriaAttribute(element, 'colcount', colCount); } -/** - * The implementation of Array.prototype.filter in browsers is always slower than just using a simple for loop, so - * use this for improved performance. - * https://jsbench.me/7bk91fk08c/ - */ -function filter(list, predicate) { - if (list == null) { - return null; - } - var filtered = []; - for (var i = 0; i < list.length; i++) { - if (predicate(list[i], i)) { - filtered.push(list[i]); - } - } - return filtered; +function setAriaColIndex(element, colIndex) { + setAriaAttribute(element, 'colindex', colIndex); } -/** - * The implementation of Array.prototype.reduce in browsers is generally the same as just using a simple for loop. However, - * Chrome does exhibit some difference, and this performs no worse in other browsers, so use this if you want improved - * performance. - * https://jsbench.me/7vk92n6u1f/ - */ -function reduce(list, step, initial) { - if (list == null || initial == null) { - return null; +function setAriaColSpan(element, colSpan) { + setAriaAttribute(element, 'colspan', colSpan); +} +function setAriaSort(element, sort) { + setAriaAttribute(element, 'sort', sort); +} +function removeAriaSort(element) { + removeAriaAttribute(element, 'sort'); +} +function setAriaSelected(element, selected) { + var attributeName = 'selected'; + if (selected) { + setAriaAttribute(element, attributeName, selected); } - var result = initial; - for (var i = 0; i < list.length; i++) { - result = step(result, list[i], i); + else { + removeAriaAttribute(element, attributeName); } - return result; } -/** @deprecated */ -function forEachSnapshotFirst(list, callback) { - if (!list) { - return; - } - var arrayCopy = list.slice(0); - arrayCopy.forEach(callback); +function setAriaChecked(element, checked) { + setAriaAttribute(element, 'checked', checked === undefined ? 'mixed' : checked); } /***/ }), -/* 18 */ +/* 45 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "serialiseDate", function() { return serialiseDate; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "parseDateTimeFromString", function() { return parseDateTimeFromString; }); -/* harmony import */ var _number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(19); +/* harmony import */ var _number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(46); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; +}; /** * Serialises a Date to a string of format `yyyy-MM-dd HH:mm:ss`. @@ -3370,9 +11469,9 @@ function serialiseDate(date, includeTime, separator) { if (!date) { return null; } - var serialised = [date.getFullYear(), date.getMonth() + 1, date.getDate()].map(function (part) { return Object(_number__WEBPACK_IMPORTED_MODULE_0__["padStart"])(part, 2); }).join(separator); + var serialised = [date.getFullYear(), date.getMonth() + 1, date.getDate()].map(function (part) { return Object(_number__WEBPACK_IMPORTED_MODULE_0__["padStartWidthZeros"])(part, 2); }).join(separator); if (includeTime) { - serialised += ' ' + [date.getHours(), date.getMinutes(), date.getSeconds()].map(function (part) { return Object(_number__WEBPACK_IMPORTED_MODULE_0__["padStart"])(part, 2); }).join(':'); + serialised += ' ' + [date.getHours(), date.getMinutes(), date.getSeconds()].map(function (part) { return Object(_number__WEBPACK_IMPORTED_MODULE_0__["padStartWidthZeros"])(part, 2); }).join(':'); } return serialised; } @@ -3383,7 +11482,7 @@ function parseDateTimeFromString(value) { if (!value) { return null; } - var _a = value.split(' '), dateStr = _a[0], timeStr = _a[1]; + var _a = __read(value.split(' '), 2), dateStr = _a[0], timeStr = _a[1]; if (!dateStr) { return null; } @@ -3391,7 +11490,7 @@ function parseDateTimeFromString(value) { if (fields.filter(function (f) { return !isNaN(f); }).length !== 3) { return null; } - var year = fields[0], month = fields[1], day = fields[2]; + var _b = __read(fields, 3), year = _b[0], month = _b[1], day = _b[2]; var date = new Date(year, month - 1, day); if (date.getFullYear() !== year || date.getMonth() !== month - 1 || @@ -3402,7 +11501,7 @@ function parseDateTimeFromString(value) { if (!timeStr || timeStr === '00:00:00') { return date; } - var _b = timeStr.split(':').map(function (part) { return parseInt(part, 10); }), hours = _b[0], minutes = _b[1], seconds = _b[2]; + var _c = __read(timeStr.split(':').map(function (part) { return parseInt(part, 10); }), 3), hours = _c[0], minutes = _c[1], seconds = _c[2]; if (hours >= 0 && hours < 24) { date.setHours(hours); } @@ -3417,394 +11516,87 @@ function parseDateTimeFromString(value) { /***/ }), -/* 19 */ +/* 46 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "padStart", function() { return padStart; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "padStartWidthZeros", function() { return padStartWidthZeros; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "createArrayOfNumbers", function() { return createArrayOfNumbers; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isNumeric", function() { return isNumeric; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getMaxSafeInteger", function() { return getMaxSafeInteger; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cleanNumber", function() { return cleanNumber; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "decToHex", function() { return decToHex; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "formatNumberTwoDecimalPlacesAndCommas", function() { return formatNumberTwoDecimalPlacesAndCommas; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "formatNumberCommas", function() { return formatNumberCommas; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "sum", function() { return sum; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -function padStart(value, totalStringSize) { - var asString = "" + value; - while (asString.length < totalStringSize) { - asString = "0" + asString; - } - return asString; +function padStartWidthZeros(value, totalStringSize) { + return value.toString().padStart(totalStringSize, '0'); } function createArrayOfNumbers(first, last) { var result = []; - for (var i = first; i <= last; i++) { - result.push(i); - } - return result; -} -/** - * Check if a value is numeric - * from http://stackoverflow.com/questions/9716468/is-there-any-function-like-isnumeric-in-javascript-to-validate-numbers - * @param {any} value - * @return {boolean} - */ -function isNumeric(value) { - return value !== '' && !isNaN(parseFloat(value)) && isFinite(value); -} -function getMaxSafeInteger() { - // eslint-disable-next-line - return Number.MAX_SAFE_INTEGER || 9007199254740991; -} -function cleanNumber(value) { - if (typeof value === 'string') { - value = parseInt(value, 10); - } - if (typeof value === 'number') { - return Math.floor(value); - } - else { - return null; - } -} -function decToHex(number, bytes) { - var hex = ''; - for (var i = 0; i < bytes; i++) { - hex += String.fromCharCode(number & 0xff); - number >>>= 8; - } - return hex; -} -function formatNumberTwoDecimalPlacesAndCommas(value) { - if (typeof value !== 'number') { - return ''; - } - return formatNumberCommas(Math.round(value * 100) / 100); -} -/** - * the native method number.toLocaleString(undefined, {minimumFractionDigits: 0}) - * puts in decimal places in IE, so we use this method instead - * from: http://blog.tompawlak.org/number-currency-formatting-javascript - * @param {number} value - * @returns {string} - */ -function formatNumberCommas(value) { - if (typeof value !== 'number') { - return ''; - } - return value.toString().replace(/(\d)(?=(\d{3})+(?!\d))/g, "$1,"); -} -function sum(values) { - return values == null ? null : values.reduce(function (total, value) { return total + value; }, 0); -} - - -/***/ }), -/* 20 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "stopPropagationForAgGrid", function() { return stopPropagationForAgGrid; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isStopPropagationForAgGrid", function() { return isStopPropagationForAgGrid; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isEventSupported", function() { return isEventSupported; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getCellCompForEvent", function() { return getCellCompForEvent; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addChangeListener", function() { return addChangeListener; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getTarget", function() { return getTarget; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isElementInEventPath", function() { return isElementInEventPath; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "createEventPath", function() { return createEventPath; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addAgGridEventPath", function() { return addAgGridEventPath; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getEventPath", function() { return getEventPath; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addSafePassiveEventListener", function() { return addSafePassiveEventListener; }); -/* harmony import */ var _array__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(17); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ - -var AG_GRID_STOP_PROPAGATION = '__ag_Grid_Stop_Propagation'; -var PASSIVE_EVENTS = ['touchstart', 'touchend', 'touchmove', 'touchcancel']; -var OUTSIDE_ANGULAR_EVENTS = ['mouseover', 'mouseout', 'mouseenter', 'mouseleave']; -var supports = {}; -/** - * a user once raised an issue - they said that when you opened a popup (eg context menu) - * and then clicked on a selection checkbox, the popup wasn't closed. this is because the - * popup listens for clicks on the body, however ag-grid WAS stopping propagation on the - * checkbox clicks (so the rows didn't pick them up as row selection selection clicks). - * to get around this, we have a pattern to stop propagation for the purposes of ag-Grid, - * but we still let the event pass back to the body. - * @param {Event} event - */ -function stopPropagationForAgGrid(event) { - event[AG_GRID_STOP_PROPAGATION] = true; -} -function isStopPropagationForAgGrid(event) { - return event[AG_GRID_STOP_PROPAGATION] === true; -} -var isEventSupported = (function () { - var tags = { - select: 'input', - change: 'input', - submit: 'form', - reset: 'form', - error: 'img', - load: 'img', - abort: 'img' - }; - var isEventSupported = function (eventName) { - if (typeof supports[eventName] === 'boolean') { - return supports[eventName]; - } - var el = document.createElement(tags[eventName] || 'div'); - eventName = 'on' + eventName; - var isSupported = (eventName in el); - if (!isSupported) { - el.setAttribute(eventName, 'return;'); - isSupported = typeof el[eventName] == 'function'; - } - el = null; - return supports[eventName] = isSupported; - }; - return isEventSupported; -})(); -function getCellCompForEvent(gridOptionsWrapper, event) { - var sourceElement = getTarget(event); - while (sourceElement) { - var renderedCell = gridOptionsWrapper.getDomData(sourceElement, 'cellComp'); - if (renderedCell) { - return renderedCell; - } - sourceElement = sourceElement.parentElement; - } - return null; -} -/** - * @deprecated - * Adds all type of change listeners to an element, intended to be a text field - * @param {HTMLElement} element - * @param {EventListener} listener - */ -function addChangeListener(element, listener) { - element.addEventListener('changed', listener); - element.addEventListener('paste', listener); - element.addEventListener('input', listener); - // IE doesn't fire changed for special keys (eg delete, backspace), so need to - // listen for this further ones - element.addEventListener('keydown', listener); - element.addEventListener('keyup', listener); -} -/** - * srcElement is only available in IE. In all other browsers it is target - * http://stackoverflow.com/questions/5301643/how-can-i-make-event-srcelement-work-in-firefox-and-what-does-it-mean - * @param {Event} event - * @returns {Element} - */ -function getTarget(event) { - var eventNoType = event; - return eventNoType.target || eventNoType.srcElement; -} -function isElementInEventPath(element, event) { - if (!event || !element) { - return false; - } - return getEventPath(event).indexOf(element) >= 0; -} -function createEventPath(event) { - var res = []; - var pointer = getTarget(event); - while (pointer) { - res.push(pointer); - pointer = pointer.parentElement; - } - return res; -} -/** - * firefox doesn't have event.path set, or any alternative to it, so we hack - * it in. this is needed as it's to late to work out the path when the item is - * removed from the dom. used by MouseEventService, where it works out if a click - * was from the current grid, or a detail grid (master / detail). - * @param {Event} event - */ -function addAgGridEventPath(event) { - event.__agGridEventPath = getEventPath(event); -} -/** - * Gets the path for an Event. - * https://stackoverflow.com/questions/39245488/event-path-undefined-with-firefox-and-vue-js - * https://developer.mozilla.org/en-US/docs/Web/API/Event - * @param {Event} event - * @returns {EventTarget[]} - */ -function getEventPath(event) { - var eventNoType = event; - if (eventNoType.deepPath) { - // IE supports deep path - return eventNoType.deepPath(); - } - if (eventNoType.path) { - // Chrome supports path - return eventNoType.path; - } - if (eventNoType.composedPath) { - // Firefox supports composePath - return eventNoType.composedPath(); - } - if (eventNoType.__agGridEventPath) { - // Firefox supports composePath - return eventNoType.__agGridEventPath; - } - // and finally, if none of the above worked, - // we create the path ourselves - return createEventPath(event); -} -function addSafePassiveEventListener(frameworkOverrides, eElement, event, listener) { - var isPassive = Object(_array__WEBPACK_IMPORTED_MODULE_0__["includes"])(PASSIVE_EVENTS, event); - var isOutsideAngular = Object(_array__WEBPACK_IMPORTED_MODULE_0__["includes"])(OUTSIDE_ANGULAR_EVENTS, event); - var options = isPassive ? { passive: true } : undefined; - if (isOutsideAngular) { - // this happens in certain scenarios where I believe the user must be destroying the grid somehow but continuing - // for it to be used - // don't fall through to the else part either - just don't add the listener - if (frameworkOverrides && frameworkOverrides.addEventListenerOutsideAngular) { - frameworkOverrides.addEventListenerOutsideAngular(eElement, event, listener, options); - } - } - else { - eElement.addEventListener(event, listener, options); - } -} - - -/***/ }), -/* 21 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "doOnce", function() { return doOnce; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getFunctionParameters", function() { return getFunctionParameters; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isFunction", function() { return isFunction; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "executeInAWhile", function() { return executeInAWhile; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "executeNextVMTurn", function() { return executeNextVMTurn; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "executeAfter", function() { return executeAfter; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "debounce", function() { return debounce; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "compose", function() { return compose; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "callIfPresent", function() { return callIfPresent; }); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var FUNCTION_STRIP_COMMENTS = /((\/\/.*$)|(\/\*[\s\S]*?\*\/))/mg; -var FUNCTION_ARGUMENT_NAMES = /([^\s,]+)/g; -var doOnceFlags = {}; -/** - * If the key was passed before, then doesn't execute the func - * @param {Function} func - * @param {string} key - */ -function doOnce(func, key) { - if (doOnceFlags[key]) { - return; - } - func(); - doOnceFlags[key] = true; -} -/** @deprecated */ -function getFunctionParameters(func) { - var fnStr = func.toString().replace(FUNCTION_STRIP_COMMENTS, ''); - return fnStr.slice(fnStr.indexOf('(') + 1, fnStr.indexOf(')')).match(FUNCTION_ARGUMENT_NAMES) || []; -} -function isFunction(val) { - return !!(val && val.constructor && val.call && val.apply); -} -function executeInAWhile(funcs) { - executeAfter(funcs, 400); -} -function executeNextVMTurn(funcs) { - executeAfter(funcs, 0); -} -function executeAfter(funcs, milliseconds) { - if (milliseconds === void 0) { milliseconds = 0; } - if (funcs.length > 0) { - window.setTimeout(function () { return funcs.forEach(function (func) { return func(); }); }, milliseconds); - } -} -/** - * from https://stackoverflow.com/questions/24004791/can-someone-explain-the-debounce-function-in-javascript - * @param {Function} func The function to be debounced - * @param {number} wait The time in ms to debounce - * @param {boolean} immediate If it should run immediately or wait for the initial debounce delay - * @return {Function} The debounced function - */ -function debounce(func, wait, immediate) { - if (immediate === void 0) { immediate = false; } - // 'private' variable for instance - // The returned function will be able to reference this due to closure. - // Each call to the returned function will share this common timer. - var timeout; - // Calling debounce returns a new anonymous function - return function () { - var args = []; - for (var _i = 0; _i < arguments.length; _i++) { - args[_i] = arguments[_i]; - } - // reference the context and args for the setTimeout function - var context = this; - // Should the function be called now? If immediate is true - // and not already in a timeout then the answer is: Yes - var callNow = immediate && !timeout; - // This is the basic debounce behaviour where you can call this - // function several times, but it will only execute once - // [before or after imposing a delay]. - // Each time the returned function is called, the timer starts over. - window.clearTimeout(timeout); - // Set the new timeout - timeout = window.setTimeout(function () { - // Inside the timeout function, clear the timeout variable - // which will let the next execution run when in 'immediate' mode - timeout = null; - // Check if the function already ran with the immediate flag - if (!immediate) { - // Call the original function with apply - // apply lets you define the 'this' object as well as the arguments - // (both captured before setTimeout) - func.apply(context, args); - } - }, wait); - // Immediate mode and no wait timer? Execute the function.. - if (callNow) { - func.apply(context, args); - } - }; + for (var i = first; i <= last; i++) { + result.push(i); + } + return result; } -function compose() { - var fns = []; - for (var _i = 0; _i < arguments.length; _i++) { - fns[_i] = arguments[_i]; +/** + * Check if a value is numeric + * from http://stackoverflow.com/questions/9716468/is-there-any-function-like-isnumeric-in-javascript-to-validate-numbers + * @param {any} value + * @return {boolean} + */ +function isNumeric(value) { + return value !== '' && !isNaN(parseFloat(value)) && isFinite(value); +} +function cleanNumber(value) { + if (typeof value === 'string') { + value = parseInt(value, 10); } - return function (arg) { return fns.reduce(function (composed, f) { return f(composed); }, arg); }; + if (typeof value === 'number') { + return Math.floor(value); + } + return null; } -function callIfPresent(func) { - if (func) { - func(); +function decToHex(number, bytes) { + var hex = ''; + for (var i = 0; i < bytes; i++) { + hex += String.fromCharCode(number & 0xff); + number >>>= 8; + } + return hex; +} +function formatNumberTwoDecimalPlacesAndCommas(value, thousandSeparator, decimalSeparator) { + if (typeof value !== 'number') { + return ''; + } + return formatNumberCommas(Math.round(value * 100) / 100, thousandSeparator, decimalSeparator); +} +/** + * the native method number.toLocaleString(undefined, {minimumFractionDigits: 0}) + * puts in decimal places in IE, so we use this method instead + * from: http://blog.tompawlak.org/number-currency-formatting-javascript + * @param {number} value + * @returns {string} + */ +function formatNumberCommas(value, thousandSeparator, decimalSeparator) { + if (typeof value !== 'number') { + return ''; } + return value.toString().replace('.', decimalSeparator).replace(/(\d)(?=(\d{3})+(?!\d))/g, "$1" + thousandSeparator); +} +function sum(values) { + return values == null ? null : values.reduce(function (total, value) { return total + value; }, 0); } /***/ }), -/* 22 */ +/* 47 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -3815,8 +11607,8 @@ __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "string_distances", function() { return string_distances; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "string_weighted_distances", function() { return string_weighted_distances; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -3898,20 +11690,19 @@ function string_weighted_distances(str1, str2) { var weight = 0; var lastIndex = 0; for (var i = 0; i < a.length; i++) { - var idx = b.indexOf(a[i]); + var idx = b.indexOf(a[i], lastIndex); if (idx === -1) { continue; } lastIndex = idx; - weight += ((b.length - lastIndex) * 100) / b.length; - weight *= weight; + weight += (100 - (lastIndex * 100 / 10000) * 100); } return weight; } /***/ }), -/* 23 */ +/* 48 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -3919,14 +11710,16 @@ __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "iconNameClassMap", function() { return iconNameClassMap; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "createIcon", function() { return createIcon; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "createIconNoSpan", function() { return createIconNoSpan; }); -/* harmony import */ var _dom__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _dom__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(42); +/* harmony import */ var _aria__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(44); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ + // // IMPORTANT NOTE! // @@ -4025,6 +11818,10 @@ var iconNameClassMap = { rowDrag: 'grip', // context menu export item save: 'save', + // csv export + csvExport: 'csv', + // excel export, + excelExport: 'excel', // icon on dropdown editors smallDown: 'small-down', // version of small-right used in RTL mode @@ -4049,7 +11846,7 @@ var iconNameClassMap = { */ function createIcon(iconName, gridOptionsWrapper, column) { var iconContents = createIconNoSpan(iconName, gridOptionsWrapper, column); - if (iconContents.className.indexOf('ag-icon') > -1) { + if (iconContents && iconContents.className.indexOf('ag-icon') > -1) { return iconContents; } var eResult = document.createElement('span'); @@ -4085,19 +11882,17 @@ function createIconNoSpan(iconName, gridOptionsWrapper, column, forceCreate) { if (typeof rendererResult === 'string') { return Object(_dom__WEBPACK_IMPORTED_MODULE_0__["loadTemplate"])(rendererResult); } - else if (Object(_dom__WEBPACK_IMPORTED_MODULE_0__["isNodeOrElement"])(rendererResult)) { + if (Object(_dom__WEBPACK_IMPORTED_MODULE_0__["isNodeOrElement"])(rendererResult)) { return rendererResult; } - else { - console.warn('ag-Grid: iconRenderer should return back a string or a dom object'); - } + console.warn('AG Grid: iconRenderer should return back a string or a dom object'); } else { var span = document.createElement('span'); var cssClass = iconNameClassMap[iconName]; if (!cssClass) { if (!forceCreate) { - console.warn("ag-Grid: Did not find icon " + iconName); + console.warn("AG Grid: Did not find icon " + iconName); cssClass = ''; } else { @@ -4105,75 +11900,46 @@ function createIconNoSpan(iconName, gridOptionsWrapper, column, forceCreate) { } } span.setAttribute('class', "ag-icon ag-icon-" + cssClass); - span.setAttribute("unselectable", "on"); + span.setAttribute('unselectable', 'on'); + Object(_aria__WEBPACK_IMPORTED_MODULE_1__["setAriaRole"])(span, 'presentation'); return span; } } /***/ }), -/* 24 */ +/* 49 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isKeyPressed", function() { return isKeyPressed; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isCharacterKey", function() { return isCharacterKey; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isEventFromPrintableCharacter", function() { return isEventFromPrintableCharacter; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isUserSuppressingKeyboardEvent", function() { return isUserSuppressingKeyboardEvent; }); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(25); -/* harmony import */ var _generic__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(14); -/* harmony import */ var _browser__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(13); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isUserSuppressingHeaderKeyboardEvent", function() { return isUserSuppressingHeaderKeyboardEvent; }); +/* harmony import */ var _browser__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(43); +/* harmony import */ var _generic__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ - -var PRINTABLE_CHARACTERS = 'qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM1234567890!"£$%^&*()_+-=[];\'#,./\\|<>?:@~{}'; var NUMPAD_DEL_NUMLOCK_ON_KEY = 'Del'; var NUMPAD_DEL_NUMLOCK_ON_CHARCODE = 46; -function isKeyPressed(event, keyToCheck) { - return (event.which || event.keyCode) === keyToCheck; -} -function isCharacterKey(event) { - // from: https://stackoverflow.com/questions/4179708/how-to-detect-if-the-pressed-key-will-produce-a-character-inside-an-input-text - var which = event.which; - if (typeof which === 'number' && which) { - return !event.ctrlKey && !event.metaKey && !event.altKey && event.which !== 8 && event.which !== 16; - } - return which === undefined; -} function isEventFromPrintableCharacter(event) { - var pressedChar = String.fromCharCode(event.charCode); - // newline is an exception, as it counts as a printable character, but we don't - // want to start editing when it is pressed. without this check, if user is in chrome - // and editing a cell, and they press ctrl+enter, the cell stops editing, and then - // starts editing again with a blank value (two 'key down' events are fired). to - // test this, remove the line below, edit a cell in chrome and hit ctrl+enter while editing. - // https://ag-grid.atlassian.net/browse/AG-605 - if (isKeyPressed(event, _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_NEW_LINE)) { - return false; - } // no allowed printable chars have alt or ctrl key combinations - if (event.altKey || event.ctrlKey) { + if (event.altKey || event.ctrlKey || event.metaKey) { return false; } - if (Object(_generic__WEBPACK_IMPORTED_MODULE_1__["exists"])(event.key)) { - // modern browser will implement key, so we return if key is length 1, eg if it is 'a' for the - // a key, or '2' for the '2' key. non-printable characters have names, eg 'Enter' or 'Backspace'. - var printableCharacter = event.key.length === 1; - // IE11 & Edge treat the numpad del key differently - with numlock on we get "Del" for key, - // so this addition checks if its IE11/Edge and handles that specific case the same was as all other browsers - var numpadDelWithNumlockOnForEdgeOrIe = isNumpadDelWithNumlockOnForEdgeOrIe(event); - return printableCharacter || numpadDelWithNumlockOnForEdgeOrIe; - } - // otherwise, for older browsers, we test against a list of characters, which doesn't include - // accents for non-English, but don't care much, as most users are on modern browsers - return PRINTABLE_CHARACTERS.indexOf(pressedChar) >= 0; + // if key is length 1, eg if it is 'a' for the a key, or '2' for the '2' key. + // non-printable characters have names, eg 'Enter' or 'Backspace'. + var printableCharacter = event.key.length === 1; + // IE11 & Edge treat the numpad del key differently - with numlock on we get "Del" for key, + // so this addition checks if its IE11/Edge and handles that specific case the same was as all other browsers + var numpadDelWithNumlockOnForEdgeOrIe = isNumpadDelWithNumLockOnForEdge(event); + return printableCharacter || numpadDelWithNumlockOnForEdgeOrIe; } /** * Allows user to tell the grid to skip specific keyboard events @@ -4186,7 +11952,7 @@ function isEventFromPrintableCharacter(event) { */ function isUserSuppressingKeyboardEvent(gridOptionsWrapper, keyboardEvent, rowNode, column, editing) { var gridOptionsFunc = gridOptionsWrapper.getSuppressKeyboardEventFunc(); - var colDefFunc = column.getColDef().suppressKeyboardEvent; + var colDefFunc = column ? column.getColDef().suppressKeyboardEvent : undefined; // if no callbacks provided by user, then do nothing if (!gridOptionsFunc && !colDefFunc) { return false; @@ -4217,301 +11983,43 @@ function isUserSuppressingKeyboardEvent(gridOptionsWrapper, keyboardEvent, rowNo // otherwise return false, don't suppress, as colDef didn't suppress and no func on gridOptions return false; } -function isNumpadDelWithNumlockOnForEdgeOrIe(event) { - return (Object(_browser__WEBPACK_IMPORTED_MODULE_2__["isBrowserEdge"])() || Object(_browser__WEBPACK_IMPORTED_MODULE_2__["isBrowserIE"])()) && +function isUserSuppressingHeaderKeyboardEvent(gridOptionsWrapper, keyboardEvent, headerRowIndex, column) { + var colDef = column.getDefinition(); + var colDefFunc = colDef && colDef.suppressHeaderKeyboardEvent; + if (!Object(_generic__WEBPACK_IMPORTED_MODULE_1__["exists"])(colDefFunc)) { + return false; + } + var params = { + api: gridOptionsWrapper.getApi(), + columnApi: gridOptionsWrapper.getColumnApi(), + context: gridOptionsWrapper.getContext(), + colDef: colDef, + column: column, + headerRowIndex: headerRowIndex, + event: keyboardEvent + }; + return !!colDefFunc(params); +} +function isNumpadDelWithNumLockOnForEdge(event) { + return (Object(_browser__WEBPACK_IMPORTED_MODULE_0__["isBrowserEdge"])()) && event.key === NUMPAD_DEL_NUMLOCK_ON_KEY && event.charCode === NUMPAD_DEL_NUMLOCK_ON_CHARCODE; } /***/ }), -/* 25 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Constants", function() { return Constants; }); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var Constants = /** @class */ (function () { - function Constants() { - } - Constants.STEP_EVERYTHING = 0; - Constants.STEP_FILTER = 1; - Constants.STEP_SORT = 2; - Constants.STEP_MAP = 3; - Constants.STEP_AGGREGATE = 4; - Constants.STEP_PIVOT = 5; - Constants.ROW_BUFFER_SIZE = 10; - Constants.LAYOUT_INTERVAL = 500; - Constants.BATCH_WAIT_MILLIS = 50; - Constants.EXPORT_TYPE_DRAG_COPY = 'dragCopy'; - Constants.EXPORT_TYPE_CLIPBOARD = 'clipboard'; - Constants.EXPORT_TYPE_EXCEL = 'excel'; - Constants.EXPORT_TYPE_CSV = 'csv'; - Constants.KEY_BACKSPACE = 8; - Constants.KEY_TAB = 9; - Constants.KEY_NEW_LINE = 10; - Constants.KEY_ENTER = 13; - Constants.KEY_SHIFT = 16; - Constants.KEY_ESCAPE = 27; - Constants.KEY_SPACE = 32; - Constants.KEY_LEFT = 37; - Constants.KEY_UP = 38; - Constants.KEY_RIGHT = 39; - Constants.KEY_DOWN = 40; - Constants.KEY_DELETE = 46; - Constants.KEY_A = 65; - Constants.KEY_C = 67; - Constants.KEY_V = 86; - Constants.KEY_D = 68; - Constants.KEY_Z = 90; - Constants.KEY_Y = 89; - Constants.KEY_F2 = 113; - Constants.KEY_PAGE_UP = 33; - Constants.KEY_PAGE_DOWN = 34; - Constants.KEY_PAGE_HOME = 36; - Constants.KEY_PAGE_END = 35; - Constants.ROW_MODEL_TYPE_INFINITE = 'infinite'; - Constants.ROW_MODEL_TYPE_VIEWPORT = 'viewport'; - Constants.ROW_MODEL_TYPE_CLIENT_SIDE = 'clientSide'; - Constants.ROW_MODEL_TYPE_SERVER_SIDE = 'serverSide'; - Constants.DEPRECATED_ROW_MODEL_TYPE_NORMAL = 'normal'; - Constants.ALWAYS = 'always'; - Constants.ONLY_WHEN_GROUPING = 'onlyWhenGrouping'; - Constants.PINNED_TOP = 'top'; - Constants.PINNED_BOTTOM = 'bottom'; - Constants.DOM_LAYOUT_NORMAL = 'normal'; - Constants.DOM_LAYOUT_PRINT = 'print'; - Constants.DOM_LAYOUT_AUTO_HEIGHT = 'autoHeight'; - Constants.GROUP_AUTO_COLUMN_ID = 'ag-Grid-AutoColumn'; - Constants.SOURCE_PASTE = 'paste'; - Constants.PINNED_RIGHT = 'right'; - Constants.PINNED_LEFT = 'left'; - Constants.SORT_ASC = 'asc'; - Constants.SORT_DESC = 'desc'; - return Constants; -}()); - - - -/***/ }), -/* 26 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "keys", function() { return keys; }); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -function keys(map) { - var keys = []; - map.forEach(function (_, key) { return keys.push(key); }); - return keys; -} - - -/***/ }), -/* 27 */ +/* 50 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "normalizeWheel", function() { return normalizeWheel; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isLeftClick", function() { return isLeftClick; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "areEventsNear", function() { return areEventsNear; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -/** - * @deprecated - * Mouse wheel (and 2-finger trackpad) support on the web sucks. It is - * complicated, thus this doc is long and (hopefully) detailed enough to answer - * your questions. - * - * If you need to react to the mouse wheel in a predictable way, this code is - * like your bestest friend. * hugs * - * - * As of today, there are 4 DOM event types you can listen to: - * - * 'wheel' -- Chrome(31+), FF(17+), IE(9+) - * 'mousewheel' -- Chrome, IE(6+), Opera, Safari - * 'MozMousePixelScroll' -- FF(3.5 only!) (2010-2013) -- don't bother! - * 'DOMMouseScroll' -- FF(0.9.7+) since 2003 - * - * So what to do? The is the best: - * - * normalizeWheel.getEventType(); - * - * In your event callback, use this code to get sane interpretation of the - * deltas. This code will return an object with properties: - * - * spinX -- normalized spin speed (use for zoom) - x plane - * spinY -- " - y plane - * pixelX -- normalized distance (to pixels) - x plane - * pixelY -- " - y plane - * - * Wheel values are provided by the browser assuming you are using the wheel to - * scroll a web page by a number of lines or pixels (or pages). Values can vary - * significantly on different platforms and browsers, forgetting that you can - * scroll at different speeds. Some devices (like trackpads) emit more events - * at smaller increments with fine granularity, and some emit massive jumps with - * linear speed or acceleration. - * - * This code does its best to normalize the deltas for you: - * - * - spin is trying to normalize how far the wheel was spun (or trackpad - * dragged). This is super useful for zoom support where you want to - * throw away the chunky scroll steps on the PC and make those equal to - * the slow and smooth tiny steps on the Mac. Key data: This code tries to - * resolve a single slow step on a wheel to 1. - * - * - pixel is normalizing the desired scroll delta in pixel units. You'll - * get the crazy differences between browsers, but at least it'll be in - * pixels! - * - * - positive value indicates scrolling DOWN/RIGHT, negative UP/LEFT. This - * should translate to positive value zooming IN, negative zooming OUT. - * This matches the newer 'wheel' event. - * - * Why are there spinX, spinY (or pixels)? - * - * - spinX is a 2-finger side drag on the trackpad, and a shift + wheel turn - * with a mouse. It results in side-scrolling in the browser by default. - * - * - spinY is what you expect -- it's the classic axis of a mouse wheel. - * - * - I dropped spinZ/pixelZ. It is supported by the DOM 3 'wheel' event and - * probably is by browsers in conjunction with fancy 3D controllers .. but - * you know. - * - * Implementation info: - * - * Examples of 'wheel' event if you scroll slowly (down) by one step with an - * average mouse: - * - * OS X + Chrome (mouse) - 4 pixel delta (wheelDelta -120) - * OS X + Safari (mouse) - N/A pixel delta (wheelDelta -12) - * OS X + Firefox (mouse) - 0.1 line delta (wheelDelta N/A) - * Win8 + Chrome (mouse) - 100 pixel delta (wheelDelta -120) - * Win8 + Firefox (mouse) - 3 line delta (wheelDelta -120) - * - * On the trackpad: - * - * OS X + Chrome (trackpad) - 2 pixel delta (wheelDelta -6) - * OS X + Firefox (trackpad) - 1 pixel delta (wheelDelta N/A) - * - * On other/older browsers.. it's more complicated as there can be multiple and - * also missing delta values. - * - * The 'wheel' event is more standard: - * - * http://www.w3.org/TR/DOM-Level-3-Events/#events-wheelevents - * - * The basics is that it includes a unit, deltaMode (pixels, lines, pages), and - * deltaX, deltaY and deltaZ. Some browsers provide other values to maintain - * backward compatibility with older events. Those other values help us - * better normalize spin speed. Example of what the browsers provide: - * - * | event.wheelDelta | event.detail - * ------------------+------------------+-------------- - * Safari v5/OS X | -120 | 0 - * Safari v5/Win7 | -120 | 0 - * Chrome v17/OS X | -120 | 0 - * Chrome v17/Win7 | -120 | 0 - * IE9/Win7 | -120 | undefined - * Firefox v4/OS X | undefined | 1 - * Firefox v4/Win7 | undefined | 3 - * - * from: https://github.com/facebook/fixed-data-table/blob/master/src/vendor_upstream/dom/normalizeWheel.js - * @param {any} event - * @return {any} - */ -function normalizeWheel(event) { - var PIXEL_STEP = 10; - var LINE_HEIGHT = 40; - var PAGE_HEIGHT = 800; - // spinX, spinY - var sX = 0; - var sY = 0; - // pixelX, pixelY - var pX = 0; - var pY = 0; - // Legacy - if ('detail' in event) { - sY = event.detail; - } - if ('wheelDelta' in event) { - sY = -event.wheelDelta / 120; - } - if ('wheelDeltaY' in event) { - sY = -event.wheelDeltaY / 120; - } - if ('wheelDeltaX' in event) { - sX = -event.wheelDeltaX / 120; - } - // side scrolling on FF with DOMMouseScroll - if ('axis' in event && event.axis === event.HORIZONTAL_AXIS) { - sX = sY; - sY = 0; - } - pX = sX * PIXEL_STEP; - pY = sY * PIXEL_STEP; - if ('deltaY' in event) { - pY = event.deltaY; - } - if ('deltaX' in event) { - pX = event.deltaX; - } - if ((pX || pY) && event.deltaMode) { - if (event.deltaMode == 1) { // delta in LINE units - pX *= LINE_HEIGHT; - pY *= LINE_HEIGHT; - } - else { // delta in PAGE units - pX *= PAGE_HEIGHT; - pY *= PAGE_HEIGHT; - } - } - // Fall-back if spin cannot be determined - if (pX && !sX) { - sX = (pX < 1) ? -1 : 1; - } - if (pY && !sY) { - sY = (pY < 1) ? -1 : 1; - } - return { - spinX: sX, - spinY: sY, - pixelX: pX, - pixelY: pY - }; -} -/** - * @deprecated - * Checks if event was issued by a left click - * from https://stackoverflow.com/questions/3944122/detect-left-mouse-button-press - * @param {MouseEvent} mouseEvent - * @returns {boolean} - */ -function isLeftClick(mouseEvent) { - if ('buttons' in mouseEvent) { - return mouseEvent.buttons == 1; - } - var button = mouseEvent.which || mouseEvent.button; - return button == 1; -} /** * `True` if the event is close to the original event by X pixels either vertically or horizontally. * we only start dragging after X pixels so this allows us to know if we should start dragging yet. @@ -4532,7 +12040,7 @@ function areEventsNear(e1, e2, pixelCount) { /***/ }), -/* 28 */ +/* 51 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -4540,8 +12048,8 @@ __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "sortRowNodesByOrder", function() { return sortRowNodesByOrder; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "traverseNodesWithKey", function() { return traverseNodesWithKey; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -4606,6 +12114,9 @@ function traverseNodesWithKey(nodes, callback) { var keyParts = []; recursiveSearchNodes(nodes); function recursiveSearchNodes(currentNodes) { + if (!currentNodes) { + return; + } currentNodes.forEach(function (node) { // also checking for children for tree data if (node.group || node.hasChildren()) { @@ -4621,15 +12132,15 @@ function traverseNodesWithKey(nodes, callback) { /***/ }), -/* 29 */ +/* 52 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "convertToSet", function() { return convertToSet; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -4641,15 +12152,15 @@ function convertToSet(list) { /***/ }), -/* 30 */ +/* 53 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NumberSequence", function() { return NumberSequence; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -4677,39 +12188,37 @@ var NumberSequence = /** @class */ (function () { /***/ }), -/* 31 */ +/* 54 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PromiseStatus", function() { return PromiseStatus; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Promise", function() { return Promise; }); -/* harmony import */ var _array__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(17); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgPromiseStatus", function() { return AgPromiseStatus; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgPromise", function() { return AgPromise; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ - -var PromiseStatus; -(function (PromiseStatus) { - PromiseStatus[PromiseStatus["IN_PROGRESS"] = 0] = "IN_PROGRESS"; - PromiseStatus[PromiseStatus["RESOLVED"] = 1] = "RESOLVED"; -})(PromiseStatus || (PromiseStatus = {})); -var Promise = /** @class */ (function () { - function Promise(callback) { - var _this = this; - this.status = PromiseStatus.IN_PROGRESS; +var AgPromiseStatus; +(function (AgPromiseStatus) { + AgPromiseStatus[AgPromiseStatus["IN_PROGRESS"] = 0] = "IN_PROGRESS"; + AgPromiseStatus[AgPromiseStatus["RESOLVED"] = 1] = "RESOLVED"; +})(AgPromiseStatus || (AgPromiseStatus = {})); +var AgPromise = /** @class */ (function () { + function AgPromise(callback) { + var _this = this; + this.status = AgPromiseStatus.IN_PROGRESS; this.resolution = null; this.waiters = []; callback(function (value) { return _this.onDone(value); }, function (params) { return _this.onReject(params); }); } - Promise.all = function (promises) { - return new Promise(function (resolve) { + AgPromise.all = function (promises) { + return new AgPromise(function (resolve) { var remainingToResolve = promises.length; var combinedValues = new Array(remainingToResolve); - Object(_array__WEBPACK_IMPORTED_MODULE_0__["forEach"])(promises, function (promise, index) { + promises.forEach(function (promise, index) { promise.then(function (value) { combinedValues[index] = value; remainingToResolve--; @@ -4720,14 +12229,14 @@ var Promise = /** @class */ (function () { }); }); }; - Promise.resolve = function (value) { + AgPromise.resolve = function (value) { if (value === void 0) { value = null; } - return new Promise(function (resolve) { return resolve(value); }); + return new AgPromise(function (resolve) { return resolve(value); }); }; - Promise.prototype.then = function (func) { + AgPromise.prototype.then = function (func) { var _this = this; - return new Promise(function (resolve) { - if (_this.status === PromiseStatus.RESOLVED) { + return new AgPromise(function (resolve) { + if (_this.status === AgPromiseStatus.RESOLVED) { resolve(func(_this.resolution)); } else { @@ -4735,32 +12244,32 @@ var Promise = /** @class */ (function () { } }); }; - Promise.prototype.resolveNow = function (ifNotResolvedValue, ifResolved) { - return this.status === PromiseStatus.RESOLVED ? ifResolved(this.resolution) : ifNotResolvedValue; + AgPromise.prototype.resolveNow = function (ifNotResolvedValue, ifResolved) { + return this.status === AgPromiseStatus.RESOLVED ? ifResolved(this.resolution) : ifNotResolvedValue; }; - Promise.prototype.onDone = function (value) { - this.status = PromiseStatus.RESOLVED; + AgPromise.prototype.onDone = function (value) { + this.status = AgPromiseStatus.RESOLVED; this.resolution = value; - Object(_array__WEBPACK_IMPORTED_MODULE_0__["forEach"])(this.waiters, function (waiter) { return waiter(value); }); + this.waiters.forEach(function (waiter) { return waiter(value); }); }; - Promise.prototype.onReject = function (params) { + AgPromise.prototype.onReject = function (params) { console.warn('TBI'); }; - return Promise; + return AgPromise; }()); /***/ }), -/* 32 */ +/* 55 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Timer", function() { return Timer; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -4782,198 +12291,46 @@ var Timer = /** @class */ (function () { /***/ }), -/* 33 */ +/* 56 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "OriginalColumnGroup", function() { return OriginalColumnGroup; }); -/* harmony import */ var _columnGroup__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(34); -/* harmony import */ var _column__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(35); -/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(36); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CustomTooltipFeature", function() { return CustomTooltipFeature; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); +/* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ - - - -var OriginalColumnGroup = /** @class */ (function () { - function OriginalColumnGroup(colGroupDef, groupId, padding, level) { - this.localEventService = new _eventService__WEBPACK_IMPORTED_MODULE_2__["EventService"](); - this.expandable = false; - this.colGroupDef = colGroupDef; - this.groupId = groupId; - this.expanded = colGroupDef && !!colGroupDef.openByDefault; - this.padding = padding; - this.level = level; - } - OriginalColumnGroup.prototype.setOriginalParent = function (originalParent) { - this.originalParent = originalParent; - }; - OriginalColumnGroup.prototype.getOriginalParent = function () { - return this.originalParent; - }; - OriginalColumnGroup.prototype.getLevel = function () { - return this.level; - }; - OriginalColumnGroup.prototype.isVisible = function () { - // return true if at least one child is visible - if (this.children) { - return this.children.some(function (child) { return child.isVisible(); }); - } - return false; - }; - OriginalColumnGroup.prototype.isPadding = function () { - return this.padding; - }; - OriginalColumnGroup.prototype.setExpanded = function (expanded) { - this.expanded = expanded === undefined ? false : expanded; - var event = { - type: OriginalColumnGroup.EVENT_EXPANDED_CHANGED - }; - this.localEventService.dispatchEvent(event); - }; - OriginalColumnGroup.prototype.isExpandable = function () { - return this.expandable; - }; - OriginalColumnGroup.prototype.isExpanded = function () { - return this.expanded; - }; - OriginalColumnGroup.prototype.getGroupId = function () { - return this.groupId; - }; - OriginalColumnGroup.prototype.getId = function () { - return this.getGroupId(); - }; - OriginalColumnGroup.prototype.setChildren = function (children) { - this.children = children; - }; - OriginalColumnGroup.prototype.getChildren = function () { - return this.children; - }; - OriginalColumnGroup.prototype.getColGroupDef = function () { - return this.colGroupDef; - }; - OriginalColumnGroup.prototype.getLeafColumns = function () { - var result = []; - this.addLeafColumns(result); - return result; - }; - OriginalColumnGroup.prototype.addLeafColumns = function (leafColumns) { - if (!this.children) { - return; - } - this.children.forEach(function (child) { - if (child instanceof _column__WEBPACK_IMPORTED_MODULE_1__["Column"]) { - leafColumns.push(child); - } - else if (child instanceof OriginalColumnGroup) { - child.addLeafColumns(leafColumns); - } - }); - }; - OriginalColumnGroup.prototype.getColumnGroupShow = function () { - return this.padding ? _columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"].HEADER_GROUP_PADDING : this.colGroupDef.columnGroupShow; - }; - // need to check that this group has at least one col showing when both expanded and contracted. - // if not, then we don't allow expanding and contracting on this group - OriginalColumnGroup.prototype.setupExpandable = function () { - var _this = this; - this.setExpandable(); - // note - we should be removing this event listener - this.getLeafColumns().forEach(function (col) { return col.addEventListener(_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_VISIBLE_CHANGED, _this.onColumnVisibilityChanged.bind(_this)); }); +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - OriginalColumnGroup.prototype.setExpandable = function () { - if (this.isPadding()) { - return; - } - // want to make sure the group doesn't disappear when it's open - var atLeastOneShowingWhenOpen = false; - // want to make sure the group doesn't disappear when it's closed - var atLeastOneShowingWhenClosed = false; - // want to make sure the group has something to show / hide - var atLeastOneChangeable = false; - var children = this.findChildren(); - for (var i = 0, j = children.length; i < j; i++) { - var abstractColumn = children[i]; - if (!abstractColumn.isVisible()) { - continue; - } - // if the abstractColumn is a grid generated group, there will be no colDef - var headerGroupShow = abstractColumn.getColumnGroupShow(); - if (headerGroupShow === _columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"].HEADER_GROUP_SHOW_OPEN) { - atLeastOneShowingWhenOpen = true; - atLeastOneChangeable = true; - } - else if (headerGroupShow === _columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"].HEADER_GROUP_SHOW_CLOSED) { - atLeastOneShowingWhenClosed = true; - atLeastOneChangeable = true; - } - else { - atLeastOneShowingWhenOpen = true; - atLeastOneShowingWhenClosed = true; - if (headerGroupShow === _columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"].HEADER_GROUP_PADDING) { - var column = abstractColumn; - atLeastOneChangeable = atLeastOneChangeable || column.children.some(function (child) { return child.getColumnGroupShow() !== undefined; }); - } - } - } - var expandable = atLeastOneShowingWhenOpen && atLeastOneShowingWhenClosed && atLeastOneChangeable; - if (this.expandable !== expandable) { - this.expandable = expandable; - var event_1 = { - type: OriginalColumnGroup.EVENT_EXPANDABLE_CHANGED - }; - this.localEventService.dispatchEvent(event_1); - } + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - OriginalColumnGroup.prototype.findChildren = function () { - var children = this.children; - var firstChild = children[0]; - if (firstChild && (!firstChild.isPadding || !firstChild.isPadding())) { - return children; - } - while (children.length === 1 && children[0] instanceof OriginalColumnGroup) { - children = children[0].children; +})(); +var __assign = (undefined && undefined.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; } - return children; - }; - OriginalColumnGroup.prototype.onColumnVisibilityChanged = function () { - this.setExpandable(); - }; - OriginalColumnGroup.prototype.addEventListener = function (eventType, listener) { - this.localEventService.addEventListener(eventType, listener); - }; - OriginalColumnGroup.prototype.removeEventListener = function (eventType, listener) { - this.localEventService.removeEventListener(eventType, listener); + return t; }; - OriginalColumnGroup.EVENT_EXPANDED_CHANGED = 'expandedChanged'; - OriginalColumnGroup.EVENT_EXPANDABLE_CHANGED = 'expandableChanged'; - return OriginalColumnGroup; -}()); - - - -/***/ }), -/* 34 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnGroup", function() { return ColumnGroup; }); -/* harmony import */ var _column__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(35); -/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(36); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ + return __assign.apply(this, arguments); +}; var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); @@ -4984,301 +12341,311 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var ColumnGroup = /** @class */ (function () { - function ColumnGroup(originalColumnGroup, groupId, instanceId, pinned) { - // depends on the open/closed state of the group, only displaying columns are stored here - this.displayedChildren = []; - this.localEventService = new _eventService__WEBPACK_IMPORTED_MODULE_1__["EventService"](); - this.groupId = groupId; - this.instanceId = instanceId; - this.originalColumnGroup = originalColumnGroup; - this.pinned = pinned; +var TooltipStates; +(function (TooltipStates) { + TooltipStates[TooltipStates["NOTHING"] = 0] = "NOTHING"; + TooltipStates[TooltipStates["WAITING_TO_SHOW"] = 1] = "WAITING_TO_SHOW"; + TooltipStates[TooltipStates["SHOWING"] = 2] = "SHOWING"; +})(TooltipStates || (TooltipStates = {})); +var CustomTooltipFeature = /** @class */ (function (_super) { + __extends(CustomTooltipFeature, _super); + function CustomTooltipFeature(parentComp) { + var _this = _super.call(this) || this; + _this.DEFAULT_SHOW_TOOLTIP_DELAY = 2000; + _this.DEFAULT_HIDE_TOOLTIP_DELAY = 10000; + _this.SHOW_QUICK_TOOLTIP_DIFF = 1000; + _this.FADE_OUT_TOOLTIP_TIMEOUT = 1000; + _this.state = TooltipStates.NOTHING; + // when showing the tooltip, we need to make sure it's the most recent instance we request, as due to + // async we could request two tooltips before the first instance returns, in which case we should + // disregard the second instance. + _this.tooltipInstanceCount = 0; + _this.tooltipMouseTrack = false; + _this.parentComp = parentComp; + return _this; } - // this is static, a it is used outside of this class - ColumnGroup.createUniqueId = function (groupId, instanceId) { - return groupId + '_' + instanceId; - }; - // as the user is adding and removing columns, the groups are recalculated. - // this reset clears out all children, ready for children to be added again - ColumnGroup.prototype.reset = function () { - this.parent = null; - this.children = null; - this.displayedChildren = null; - }; - ColumnGroup.prototype.getParent = function () { - return this.parent; - }; - ColumnGroup.prototype.setParent = function (parent) { - this.parent = parent; - }; - ColumnGroup.prototype.getUniqueId = function () { - return ColumnGroup.createUniqueId(this.groupId, this.instanceId); - }; - ColumnGroup.prototype.isEmptyGroup = function () { - return this.displayedChildren.length === 0; - }; - ColumnGroup.prototype.isMoving = function () { - var allLeafColumns = this.getOriginalColumnGroup().getLeafColumns(); - if (!allLeafColumns || allLeafColumns.length === 0) { - return false; - } - return allLeafColumns.every(function (col) { return col.isMoving(); }); - }; - ColumnGroup.prototype.checkLeft = function () { - // first get all children to setLeft, as it impacts our decision below - this.displayedChildren.forEach(function (child) { - if (child instanceof ColumnGroup) { - child.checkLeft(); - } - }); - // set our left based on first displayed column - if (this.displayedChildren.length > 0) { - if (this.gridOptionsWrapper.isEnableRtl()) { - var lastChild = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].last(this.displayedChildren); - var lastChildLeft = lastChild.getLeft(); - this.setLeft(lastChildLeft); - } - else { - var firstChildLeft = this.displayedChildren[0].getLeft(); - this.setLeft(firstChildLeft); - } - } - else { - // this should never happen, as if we have no displayed columns, then - // this groups should not even exist. - this.setLeft(null); - } - }; - ColumnGroup.prototype.getLeft = function () { - return this.left; - }; - ColumnGroup.prototype.getOldLeft = function () { - return this.oldLeft; - }; - ColumnGroup.prototype.setLeft = function (left) { - this.oldLeft = left; - if (this.left !== left) { - this.left = left; - this.localEventService.dispatchEvent(this.createAgEvent(ColumnGroup.EVENT_LEFT_CHANGED)); - } - }; - ColumnGroup.prototype.getPinned = function () { - return this.pinned; - }; - ColumnGroup.prototype.createAgEvent = function (type) { - return { type: type }; - }; - ColumnGroup.prototype.addEventListener = function (eventType, listener) { - this.localEventService.addEventListener(eventType, listener); - }; - ColumnGroup.prototype.removeEventListener = function (eventType, listener) { - this.localEventService.removeEventListener(eventType, listener); - }; - ColumnGroup.prototype.getGroupId = function () { - return this.groupId; - }; - ColumnGroup.prototype.getInstanceId = function () { - return this.instanceId; - }; - ColumnGroup.prototype.isChildInThisGroupDeepSearch = function (wantedChild) { - var result = false; - this.children.forEach(function (foundChild) { - if (wantedChild === foundChild) { - result = true; - } - if (foundChild instanceof ColumnGroup) { - if (foundChild.isChildInThisGroupDeepSearch(wantedChild)) { - result = true; - } - } - }); - return result; - }; - ColumnGroup.prototype.getActualWidth = function () { - var groupActualWidth = 0; - if (this.displayedChildren) { - this.displayedChildren.forEach(function (child) { - groupActualWidth += child.getActualWidth(); - }); - } - return groupActualWidth; - }; - ColumnGroup.prototype.isResizable = function () { - if (!this.displayedChildren) { - return false; - } - // if at least one child is resizable, then the group is resizable - var result = false; - this.displayedChildren.forEach(function (child) { - if (child.isResizable()) { - result = true; - } - }); - return result; - }; - ColumnGroup.prototype.getMinWidth = function () { - var result = 0; - this.displayedChildren.forEach(function (groupChild) { - result += groupChild.getMinWidth(); - }); - return result; - }; - ColumnGroup.prototype.addChild = function (child) { - if (!this.children) { - this.children = []; - } - this.children.push(child); - }; - ColumnGroup.prototype.getDisplayedChildren = function () { - return this.displayedChildren; - }; - ColumnGroup.prototype.getLeafColumns = function () { - var result = []; - this.addLeafColumns(result); - return result; - }; - ColumnGroup.prototype.getDisplayedLeafColumns = function () { - var result = []; - this.addDisplayedLeafColumns(result); - return result; - }; - // why two methods here doing the same thing? - ColumnGroup.prototype.getDefinition = function () { - return this.originalColumnGroup.getColGroupDef(); + CustomTooltipFeature.prototype.postConstruct = function () { + this.tooltipShowDelay = this.gridOptionsWrapper.getTooltipDelay('show') || this.DEFAULT_SHOW_TOOLTIP_DELAY; + this.tooltipHideDelay = this.gridOptionsWrapper.getTooltipDelay('hide') || this.DEFAULT_HIDE_TOOLTIP_DELAY; + this.tooltipMouseTrack = this.gridOptionsWrapper.isTooltipMouseTrack(); + var el = this.parentComp.getGui(); + this.addManagedListener(el, 'mouseenter', this.onMouseEnter.bind(this)); + this.addManagedListener(el, 'mouseleave', this.onMouseLeave.bind(this)); + this.addManagedListener(el, 'mousemove', this.onMouseMove.bind(this)); + this.addManagedListener(el, 'mousedown', this.onMouseDown.bind(this)); + this.addManagedListener(el, 'keydown', this.onKeyDown.bind(this)); }; - ColumnGroup.prototype.getColGroupDef = function () { - return this.originalColumnGroup.getColGroupDef(); + CustomTooltipFeature.prototype.destroy = function () { + // if this component gets destroyed while tooltip is showing, need to make sure + // we don't end with no mouseLeave event resulting in zombie tooltip + this.setToDoNothing(); + _super.prototype.destroy.call(this); }; - ColumnGroup.prototype.isPadding = function () { - return this.originalColumnGroup.isPadding(); + CustomTooltipFeature.prototype.onMouseEnter = function (e) { + if (Object(_utils_browser__WEBPACK_IMPORTED_MODULE_3__["isIOSUserAgent"])()) { + return; + } + // every mouseenter should be following by a mouseleave, however for some unkonwn, it's possible for + // mouseenter to be called twice in a row, which can happen if editing the cell. this was reported + // in https://ag-grid.atlassian.net/browse/AG-4422. to get around this, we check the state, and if + // state is !=nothing, then we know mouseenter was already received. + if (this.state != TooltipStates.NOTHING) { + return; + } + // if another tooltip was hidden very recently, we only wait 200ms to show, not the normal waiting time + var delay = this.isLastTooltipHiddenRecently() ? 200 : this.tooltipShowDelay; + this.showTooltipTimeoutId = window.setTimeout(this.showTooltip.bind(this), delay); + this.lastMouseEvent = e; + this.state = TooltipStates.WAITING_TO_SHOW; }; - ColumnGroup.prototype.isExpandable = function () { - return this.originalColumnGroup.isExpandable(); + CustomTooltipFeature.prototype.onMouseLeave = function () { + this.setToDoNothing(); }; - ColumnGroup.prototype.isExpanded = function () { - return this.originalColumnGroup.isExpanded(); + CustomTooltipFeature.prototype.onKeyDown = function () { + this.setToDoNothing(); }; - ColumnGroup.prototype.setExpanded = function (expanded) { - this.originalColumnGroup.setExpanded(expanded); + CustomTooltipFeature.prototype.setToDoNothing = function () { + if (this.state === TooltipStates.SHOWING) { + this.hideTooltip(); + } + this.clearTimeouts(); + this.state = TooltipStates.NOTHING; }; - ColumnGroup.prototype.addDisplayedLeafColumns = function (leafColumns) { - this.displayedChildren.forEach(function (child) { - if (child instanceof _column__WEBPACK_IMPORTED_MODULE_0__["Column"]) { - leafColumns.push(child); - } - else if (child instanceof ColumnGroup) { - child.addDisplayedLeafColumns(leafColumns); - } - }); + CustomTooltipFeature.prototype.onMouseMove = function (e) { + // there is a delay from the time we mouseOver a component and the time the + // tooltip is displayed, so we need to track mousemove to be able to correctly + // position the tooltip when showTooltip is called. + this.lastMouseEvent = e; + if (this.tooltipMouseTrack && + this.state === TooltipStates.SHOWING && + this.tooltipComp) { + this.positionTooltipUnderLastMouseEvent(); + } }; - ColumnGroup.prototype.addLeafColumns = function (leafColumns) { - this.children.forEach(function (child) { - if (child instanceof _column__WEBPACK_IMPORTED_MODULE_0__["Column"]) { - leafColumns.push(child); - } - else if (child instanceof ColumnGroup) { - child.addLeafColumns(leafColumns); - } - }); + CustomTooltipFeature.prototype.onMouseDown = function () { + this.setToDoNothing(); }; - ColumnGroup.prototype.getChildren = function () { - return this.children; + CustomTooltipFeature.prototype.hideTooltip = function () { + // check if comp exists - due to async, although we asked for + // one, the instance may not be back yet + if (this.tooltipComp) { + this.destroyTooltipComp(); + CustomTooltipFeature.lastTooltipHideTime = new Date().getTime(); + } + this.state = TooltipStates.NOTHING; }; - ColumnGroup.prototype.getColumnGroupShow = function () { - return this.originalColumnGroup.getColumnGroupShow(); + CustomTooltipFeature.prototype.destroyTooltipComp = function () { + var _this = this; + // add class to fade out the tooltip + this.tooltipComp.getGui().classList.add('ag-tooltip-hiding'); + // make local copies of these variables, as we use them in the async function below, + // and we clear then to 'undefined' later, so need to take a copy before they are undefined. + var tooltipPopupDestroyFunc = this.tooltipPopupDestroyFunc; + var tooltipComp = this.tooltipComp; + window.setTimeout(function () { + tooltipPopupDestroyFunc(); + _this.getContext().destroyBean(tooltipComp); + }, this.FADE_OUT_TOOLTIP_TIMEOUT); + this.tooltipPopupDestroyFunc = undefined; + this.tooltipComp = undefined; }; - ColumnGroup.prototype.getOriginalColumnGroup = function () { - return this.originalColumnGroup; + CustomTooltipFeature.prototype.isLastTooltipHiddenRecently = function () { + // return true if <1000ms since last time we hid a tooltip + var now = new Date().getTime(); + var then = CustomTooltipFeature.lastTooltipHideTime; + return (now - then) < this.SHOW_QUICK_TOOLTIP_DIFF; }; - ColumnGroup.prototype.getPaddingLevel = function () { - var parent = this.getParent(); - if (!this.isPadding() || !parent || !parent.isPadding()) { - return 0; + CustomTooltipFeature.prototype.showTooltip = function () { + var params = __assign({ api: this.gridApi, columnApi: this.columnApi, context: this.gridOptionsWrapper.getContext() }, this.parentComp.getTooltipParams()); + if (!Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["exists"])(params.value)) { + this.setToDoNothing(); + return; } - return 1 + parent.getPaddingLevel(); + this.state = TooltipStates.SHOWING; + this.tooltipInstanceCount++; + // we pass in tooltipInstanceCount so the callback knows what the count was when + // we requested the tooltip, so if another tooltip was requested in the mean time + // we disregard it + var callback = this.newTooltipComponentCallback.bind(this, this.tooltipInstanceCount); + var userDetails = this.userComponentFactory.getTooltipCompDetails(params); + userDetails.newAgStackInstance().then(callback); }; - ColumnGroup.prototype.calculateDisplayedColumns = function () { - var _this = this; - // clear out last time we calculated - this.displayedChildren = []; - var topLevelGroup = this; - // find the column group that is controlling expandable. this is relevant when we have padding (empty) - // groups, where the expandable is actually the first parent that is not a padding group. - if (this.isPadding()) { - while (topLevelGroup.getParent() && topLevelGroup.isPadding()) { - topLevelGroup = topLevelGroup.getParent(); - } + CustomTooltipFeature.prototype.newTooltipComponentCallback = function (tooltipInstanceCopy, tooltipComp) { + var compNoLongerNeeded = this.state !== TooltipStates.SHOWING || this.tooltipInstanceCount !== tooltipInstanceCopy; + if (compNoLongerNeeded) { + this.getContext().destroyBean(tooltipComp); + return; } - var isExpandable = topLevelGroup.originalColumnGroup.isExpandable(); - // it not expandable, everything is visible - if (!isExpandable) { - this.displayedChildren = this.children; + var eGui = tooltipComp.getGui(); + this.tooltipComp = tooltipComp; + if (!eGui.classList.contains('ag-tooltip')) { + eGui.classList.add('ag-tooltip-custom'); } - else { - // Add cols based on columnGroupShow - // Note - the below also adds padding groups, these are always added because they never have - // colDef.columnGroupShow set. - this.children.forEach(function (abstractColumn) { - var headerGroupShow = abstractColumn.getColumnGroupShow(); - switch (headerGroupShow) { - case ColumnGroup.HEADER_GROUP_SHOW_OPEN: - // when set to open, only show col if group is open - if (topLevelGroup.originalColumnGroup.isExpanded()) { - _this.displayedChildren.push(abstractColumn); - } - break; - case ColumnGroup.HEADER_GROUP_SHOW_CLOSED: - // when set to open, only show col if group is open - if (!topLevelGroup.originalColumnGroup.isExpanded()) { - _this.displayedChildren.push(abstractColumn); - } - break; - default: - // if this abstractColumn is padding, we just want to add it - // to the displayedChildren list if it has displayedChildren itself. - if (!(abstractColumn instanceof ColumnGroup && - abstractColumn.isPadding() && - !abstractColumn.displayedChildren.length)) { - _this.displayedChildren.push(abstractColumn); - } - break; - } - }); + var translate = this.gridOptionsWrapper.getLocaleTextFunc(); + var addPopupRes = this.popupService.addPopup({ + eChild: eGui, + ariaLabel: translate('ariaLabelTooltip', 'Tooltip') + }); + if (addPopupRes) { + this.tooltipPopupDestroyFunc = addPopupRes.hideFunc; + } + // this.tooltipPopupDestroyFunc = this.popupService.addPopup(false, eGui, false); + this.positionTooltipUnderLastMouseEvent(); + this.hideTooltipTimeoutId = window.setTimeout(this.hideTooltip.bind(this), this.tooltipHideDelay); + }; + CustomTooltipFeature.prototype.positionTooltipUnderLastMouseEvent = function () { + this.popupService.positionPopupUnderMouseEvent({ + type: 'tooltip', + mouseEvent: this.lastMouseEvent, + ePopup: this.tooltipComp.getGui(), + nudgeY: 18 + }); + }; + CustomTooltipFeature.prototype.clearTimeouts = function () { + if (this.showTooltipTimeoutId) { + window.clearTimeout(this.showTooltipTimeoutId); + this.showTooltipTimeoutId = undefined; + } + if (this.hideTooltipTimeoutId) { + window.clearTimeout(this.hideTooltipTimeoutId); + this.hideTooltipTimeoutId = undefined; } - this.localEventService.dispatchEvent(this.createAgEvent(ColumnGroup.EVENT_DISPLAYED_CHILDREN_CHANGED)); }; - ColumnGroup.HEADER_GROUP_SHOW_OPEN = 'open'; - ColumnGroup.HEADER_GROUP_SHOW_CLOSED = 'closed'; - ColumnGroup.HEADER_GROUP_PADDING = 'padding'; - ColumnGroup.EVENT_LEFT_CHANGED = 'leftChanged'; - ColumnGroup.EVENT_DISPLAYED_CHILDREN_CHANGED = 'displayedChildrenChanged'; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper') - ], ColumnGroup.prototype, "gridOptionsWrapper", void 0); - return ColumnGroup; -}()); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('popupService') + ], CustomTooltipFeature.prototype, "popupService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('userComponentFactory') + ], CustomTooltipFeature.prototype, "userComponentFactory", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') + ], CustomTooltipFeature.prototype, "columnApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') + ], CustomTooltipFeature.prototype, "gridApi", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], CustomTooltipFeature.prototype, "postConstruct", null); + return CustomTooltipFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 35 */ +/* 57 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Column", function() { return Column; }); -/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25); -/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(38); -/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(39); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "QuerySelector", function() { return QuerySelector; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RefSelector", function() { return RefSelector; }); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(14); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ + +function QuerySelector(selector) { + return querySelectorFunc.bind(this, selector, undefined); +} +function RefSelector(ref) { + return querySelectorFunc.bind(this, "[ref=" + ref + "]", ref); +} +function querySelectorFunc(selector, refSelector, classPrototype, methodOrAttributeName, index) { + if (selector === null) { + console.error('AG Grid: QuerySelector selector should not be null'); + return; + } + if (typeof index === 'number') { + console.error('AG Grid: QuerySelector should be on an attribute'); + return; + } + addToObjectProps(classPrototype, 'querySelectors', { + attributeName: methodOrAttributeName, + querySelector: selector, + refSelector: refSelector + }); +} +// // think we should take this out, put property bindings on the +// export function Method(eventName?: string): Function { +// return methodFunc.bind(this, eventName); +// } +// +// function methodFunc(alias: string, target: Object, methodName: string) { +// if (alias === null) { +// console.error("AG Grid: EventListener eventName should not be null"); +// return; +// } +// +// addToObjectProps(target, 'methods', { +// methodName: methodName, +// alias: alias +// }); +// } +function addToObjectProps(target, key, value) { + // it's an attribute on the class + var props = getOrCreateProps(target, Object(_utils_function__WEBPACK_IMPORTED_MODULE_0__["getFunctionName"])(target.constructor)); + if (!props[key]) { + props[key] = []; + } + props[key].push(value); +} +function getOrCreateProps(target, instanceName) { + if (!target.__agComponentMetaData) { + target.__agComponentMetaData = {}; + } + if (!target.__agComponentMetaData[instanceName]) { + target.__agComponentMetaData[instanceName] = {}; + } + return target.__agComponentMetaData[instanceName]; +} + + +/***/ }), +/* 58 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DateFilter", function() { return DateFilter; }); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(59); +/* harmony import */ var _simpleFilter__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(60); +/* harmony import */ var _scalarFilter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(72); +/* harmony import */ var _utils_date__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(45); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __assign = (undefined && undefined.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); @@ -5291,1302 +12658,1712 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -// Wrapper around a user provide column definition. The grid treats the column definition as ready only. -// This class contains all the runtime information about a column, plus some logic (the definition has no logic). -// This class implements both interfaces ColumnGroupChild and OriginalColumnGroupChild as the class can -// appear as a child of either the original tree or the displayed tree. However the relevant group classes -// for each type only implements one, as each group can only appear in it's associated tree (eg OriginalColumnGroup -// can only appear in OriginalColumn tree). -var Column = /** @class */ (function () { - function Column(colDef, userProvidedColDef, colId, primary) { - this.moving = false; - this.menuVisible = false; - this.filterActive = false; - this.eventService = new _eventService__WEBPACK_IMPORTED_MODULE_0__["EventService"](); - this.rowGroupActive = false; - this.pivotActive = false; - this.aggregationActive = false; - this.colDef = colDef; - this.userProvidedColDef = userProvidedColDef; - this.visible = !colDef.hide; - this.sort = colDef.sort; - this.sortedAt = colDef.sortedAt; - this.colId = colId; - this.primary = primary; +var DEFAULT_MIN_YEAR = 1000; +var DEFAULT_MAX_YEAR = Infinity; +var DateFilter = /** @class */ (function (_super) { + __extends(DateFilter, _super); + function DateFilter() { + var _this = _super.call(this, 'dateFilter') || this; + _this.minValidYear = DEFAULT_MIN_YEAR; + _this.maxValidYear = DEFAULT_MAX_YEAR; + return _this; } - // gets called when user provides an alternative colDef, eg - Column.prototype.setColDef = function (colDef, userProvidedColDef) { - this.colDef = colDef; - this.userProvidedColDef = userProvidedColDef; - }; - Column.prototype.getUserProvidedColDef = function () { - return this.userProvidedColDef; - }; - Column.prototype.setParent = function (parent) { - this.parent = parent; - }; - Column.prototype.getParent = function () { - return this.parent; + DateFilter.prototype.afterGuiAttached = function (params) { + _super.prototype.afterGuiAttached.call(this, params); + this.dateCondition1FromComp.afterGuiAttached(params); }; - Column.prototype.setOriginalParent = function (originalParent) { - this.originalParent = originalParent; + DateFilter.prototype.mapValuesFromModel = function (filterModel) { + // unlike the other filters, we do two things here: + // 1) allow for different attribute names (same as done for other filters) (eg the 'from' and 'to' + // are in different locations in Date and Number filter models) + // 2) convert the type (because Date filter uses Dates, however model is 'string') + // + // NOTE: The conversion of string to date also removes the timezone - i.e. when user picks + // a date from the UI, it will have timezone info in it. This is lost when creating + // the model. When we recreate the date again here, it's without a timezone. + var _a = filterModel || {}, dateFrom = _a.dateFrom, dateTo = _a.dateTo, type = _a.type; + return [ + dateFrom && Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["parseDateTimeFromString"])(dateFrom) || null, + dateTo && Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["parseDateTimeFromString"])(dateTo) || null, + ].slice(0, this.getNumberOfInputs(type)); }; - Column.prototype.getOriginalParent = function () { - return this.originalParent; + DateFilter.prototype.comparator = function () { + return this.dateFilterParams.comparator ? this.dateFilterParams.comparator : this.defaultComparator.bind(this); }; - // this is done after constructor as it uses gridOptionsWrapper - Column.prototype.initialise = function () { - this.setPinned(this.colDef.pinned); - var minColWidth = this.gridOptionsWrapper.getMinColWidth(); - var maxColWidth = this.gridOptionsWrapper.getMaxColWidth(); - if (this.colDef.minWidth) { - this.minWidth = this.colDef.minWidth; - } - else { - this.minWidth = minColWidth; - } - if (this.colDef.maxWidth) { - this.maxWidth = this.colDef.maxWidth; - } - else { - this.maxWidth = maxColWidth; + DateFilter.prototype.defaultComparator = function (filterDate, cellValue) { + // The default comparator assumes that the cellValue is a date + var cellAsDate = cellValue; + if (cellValue == null || cellAsDate < filterDate) { + return -1; } - if (this.colDef.flex) { - this.flex = this.colDef.flex; + if (cellAsDate > filterDate) { + return 1; } - this.resetActualWidth(); - var suppressDotNotation = this.gridOptionsWrapper.isSuppressFieldDotNotation(); - this.fieldContainsDots = _utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(this.colDef.field) && this.colDef.field.indexOf('.') >= 0 && !suppressDotNotation; - this.tooltipFieldContainsDots = _utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(this.colDef.tooltipField) && this.colDef.tooltipField.indexOf('.') >= 0 && !suppressDotNotation; - this.validate(); - }; - Column.prototype.resetActualWidth = function () { - this.actualWidth = this.columnUtils.calculateColInitialWidth(this.colDef); - }; - Column.prototype.isEmptyGroup = function () { - return false; + return 0; }; - Column.prototype.isRowGroupDisplayed = function (colId) { - if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].missing(this.colDef) || _utils__WEBPACK_IMPORTED_MODULE_1__["_"].missing(this.colDef.showRowGroup)) { - return false; + DateFilter.prototype.setParams = function (params) { + _super.prototype.setParams.call(this, params); + this.dateFilterParams = params; + var yearParser = function (param, fallback) { + if (params[param] != null) { + if (!isNaN(params[param])) { + return params[param] == null ? fallback : Number(params[param]); + } + else { + console.warn("AG Grid: DateFilter " + param + " is not a number"); + } + } + return fallback; + }; + this.minValidYear = yearParser('minValidYear', DEFAULT_MIN_YEAR); + this.maxValidYear = yearParser('maxValidYear', DEFAULT_MAX_YEAR); + if (this.minValidYear > this.maxValidYear) { + console.warn("AG Grid: DateFilter minValidYear should be <= maxValidYear"); } - var showingAllGroups = this.colDef.showRowGroup === true; - var showingThisGroup = this.colDef.showRowGroup === colId; - return showingAllGroups || showingThisGroup; + this.createDateComponents(); }; - Column.prototype.getUniqueId = function () { - return this.getId(); + DateFilter.prototype.createDateComponents = function () { + var _this = this; + var createDateCompWrapper = function (element) { + return new _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__["DateCompWrapper"](_this.getContext(), _this.userComponentFactory, { + onDateChanged: function () { return _this.onUiChanged(); }, + filterParams: _this.dateFilterParams + }, element); + }; + this.dateCondition1FromComp = createDateCompWrapper(this.eCondition1PanelFrom); + this.dateCondition1ToComp = createDateCompWrapper(this.eCondition1PanelTo); + this.dateCondition2FromComp = createDateCompWrapper(this.eCondition2PanelFrom); + this.dateCondition2ToComp = createDateCompWrapper(this.eCondition2PanelTo); + this.addDestroyFunc(function () { + _this.forEachInput(function (element) { return element.destroy(); }); + }); }; - Column.prototype.isPrimary = function () { - return this.primary; + DateFilter.prototype.setElementValue = function (element, value, silent) { + element.setDate(value); }; - Column.prototype.isFilterAllowed = function () { - // filter defined means it's a string, class or true. - // if its false, null or undefined then it's false. - var filterDefined = !!this.colDef.filter || !!this.colDef.filterFramework; - return this.primary && filterDefined; + DateFilter.prototype.setElementDisplayed = function (element, displayed) { + element.setDisplayed(displayed); }; - Column.prototype.isFieldContainsDots = function () { - return this.fieldContainsDots; + DateFilter.prototype.setElementDisabled = function (element, disabled) { + element.setDisabled(disabled); }; - Column.prototype.isTooltipFieldContainsDots = function () { - return this.tooltipFieldContainsDots; + DateFilter.prototype.getDefaultFilterOptions = function () { + return DateFilter.DEFAULT_FILTER_OPTIONS; }; - Column.prototype.validate = function () { - var colDefAny = this.colDef; - function warnOnce(msg, key, obj) { - _utils__WEBPACK_IMPORTED_MODULE_1__["_"].doOnce(function () { - if (obj) { - console.warn(msg, obj); - } - else { - _utils__WEBPACK_IMPORTED_MODULE_1__["_"].doOnce(function () { return console.warn(msg); }, key); - } - }, key); - } - if (!_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].RowGroupingModule)) { - var rowGroupingItems = ['enableRowGroup', 'rowGroup', 'rowGroupIndex', 'enablePivot', 'enableValue', 'pivot', 'pivotIndex', 'aggFunc']; - rowGroupingItems.forEach(function (item) { - if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(colDefAny[item])) { - if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isPackageBased()) { - warnOnce("ag-Grid: " + item + " is only valid in ag-grid-enterprise, your column definition should not have " + item, 'ColumnRowGroupingMissing' + item); - } - else { - warnOnce("ag-Grid: " + item + " is only valid with ag-Grid Enterprise Module " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].RowGroupingModule + " - your column definition should not have " + item, 'ColumnRowGroupingMissing' + item); - } - } - }); - } - if (!_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].RichSelectModule)) { - if (this.colDef.cellEditor === 'agRichSelect' || this.colDef.cellEditor === 'agRichSelectCellEditor') { - if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isPackageBased()) { - warnOnce("ag-Grid: " + this.colDef.cellEditor + " can only be used with ag-grid-enterprise", 'ColumnRichSelectMissing'); - } - else { - warnOnce("ag-Grid: " + this.colDef.cellEditor + " can only be used with ag-Grid Enterprise Module " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].RichSelectModule, 'ColumnRichSelectMissing'); - } - } - } - if (!_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].DateTimeCellEditorModule)) { - if (this.colDef.cellEditor === 'agRichSelect' || this.colDef.cellEditor === 'agDateTimeCellEditor') { - if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isPackageBased()) { - warnOnce("ag-Grid: " + this.colDef.cellEditor + " can only be used with ag-grid-enterprise", 'ColumnDateTimeMissing'); - } - else { - warnOnce("ag-Grid: " + this.colDef.cellEditor + " can only be used with ag-Grid Enterprise Module " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].DateTimeCellEditorModule, 'ColumnDateTimeMissing'); - } - } - } - if (this.gridOptionsWrapper.isTreeData()) { - var itemsNotAllowedWithTreeData = ['rowGroup', 'rowGroupIndex', 'pivot', 'pivotIndex']; - itemsNotAllowedWithTreeData.forEach(function (item) { - if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(colDefAny[item])) { - warnOnce("ag-Grid: " + item + " is not possible when doing tree data, your column definition should not have " + item, 'TreeDataCannotRowGroup'); - } - }); - } - if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(this.colDef.width) && typeof this.colDef.width !== 'number') { - warnOnce('ag-Grid: colDef.width should be a number, not ' + typeof this.colDef.width, 'ColumnCheck_asdfawef'); - } - if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].get(this, 'colDef.cellRendererParams.restrictToOneGroup', null)) { - warnOnce('ag-Grid: Since ag-grid 11.0.0 cellRendererParams.restrictToOneGroup is deprecated. You should use showRowGroup', 'ColumnCheck_sksldjf'); - } - if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].get(this, 'colDef.cellRendererParams.keyMap', null)) { - warnOnce('ag-Grid: Since ag-grid 11.0.0 cellRendererParams.keyMap is deprecated. You should use colDef.keyCreator', 'ColumnCheck_ieiruhgdf'); - } - if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].get(this, 'colDef.cellRendererParams.keyMap', null)) { - warnOnce('ag-Grid: Since ag-grid 11.0.0 cellRendererParams.keyMap is deprecated. You should use colDef.keyCreator', 'ColumnCheck_uitolghj'); - } - if (colDefAny.floatingCellRenderer) { - warnOnce('ag-Grid: since v11, floatingCellRenderer is now pinnedRowCellRenderer', 'ColumnCheck_soihwewe'); - this.colDef.pinnedRowCellRenderer = colDefAny.floatingCellRenderer; - } - if (colDefAny.floatingRendererFramework) { - warnOnce('ag-Grid: since v11, floatingRendererFramework is now pinnedRowCellRendererFramework', 'ColumnCheck_zdkiouhwer'); - this.colDef.pinnedRowCellRendererFramework = colDefAny.floatingRendererFramework; - } - if (colDefAny.floatingRendererParams) { - console.warn('ag-Grid: since v11, floatingRendererParams is now pinnedRowCellRendererParams', 'ColumnCheck_retiuhjs'); - this.colDef.pinnedRowCellRendererParams = colDefAny.floatingRendererParams; - } - if (colDefAny.floatingValueFormatter) { - warnOnce('ag-Grid: since v11, floatingValueFormatter is now pinnedRowValueFormatter', 'ColumnCheck_qwroeihjdf'); - this.colDef.pinnedRowValueFormatter = colDefAny.floatingValueFormatter; + DateFilter.prototype.createValueTemplate = function (position) { + var pos = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_3__["ConditionPosition"].One ? '1' : '2'; + return /* html */ "\n
\n
\n
\n
"; + }; + DateFilter.prototype.isConditionUiComplete = function (position) { + var _this = this; + if (!_super.prototype.isConditionUiComplete.call(this, position)) { + return false; } - if (colDefAny.cellFormatter) { - warnOnce('ag-Grid: since v12, cellFormatter is now valueFormatter', 'ColumnCheck_eoireknml'); - if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].missing(this.colDef.valueFormatter)) { - this.colDef.valueFormatter = colDefAny.cellFormatter; + var isValidDate = function (value) { return value != null + && value.getUTCFullYear() >= _this.minValidYear + && value.getUTCFullYear() <= _this.maxValidYear; }; + var valid = true; + this.forEachInput(function (element, index, elPosition, numberOfInputs) { + if (elPosition !== position || !valid || index >= numberOfInputs) { + return; } - } - if (colDefAny.headerCellTemplate) { - warnOnce('ag-Grid: since v15, headerCellTemplate is gone, use header component instead.', 'ColumnCheck_eroihxcm'); - } - if (colDefAny.headerCellRenderer) { - warnOnce('ag-Grid: since v15, headerCellRenderer is gone, use header component instead.', 'ColumnCheck_terteuh'); - } - if (colDefAny.volatile) { - warnOnce('ag-Grid: since v16, colDef.volatile is gone, please check refresh docs on how to refresh specific cells.', 'ColumnCheck_weoihjxcv'); - } - if (colDefAny.suppressSorting) { - warnOnce("ag-Grid: since v20, colDef.suppressSorting is gone, instead use colDef.sortable=false.", 'ColumnCheck_43ljrer', this.colDef); - this.colDef.sortable = false; - } - if (colDefAny.suppressFilter) { - warnOnce("ag-Grid: since v20, colDef.suppressFilter is gone, instead use colDef.filter=false.", 'ColumnCheck_erlkhfdm', this.colDef); - this.colDef.filter = false; - } - if (colDefAny.suppressResize) { - warnOnce("ag-Grid: since v20, colDef.suppressResize is gone, instead use colDef.resizable=false.", 'ColumnCheck_weoihjxcv', this.colDef); - this.colDef.resizable = false; - } - if (colDefAny.tooltip) { - warnOnce("ag-Grid: since v20.1, colDef.tooltip is gone, instead use colDef.tooltipValueGetter.", 'ColumnCheck_adslknjwef', this.colDef); - this.colDef.tooltipValueGetter = colDefAny.tooltip; - } - if (colDefAny.suppressToolPanel) { - warnOnce("ag-Grid: since v22, colDef.suppressToolPanel is gone, instead use suppressColumnsToolPanel / suppressFiltersToolPanel.", 'ColumnCheck_weihjlsjkdf', this.colDef); - this.colDef.suppressColumnsToolPanel = true; - } - }; - Column.prototype.addEventListener = function (eventType, listener) { - this.eventService.addEventListener(eventType, listener); + valid = valid && isValidDate(element.getDate()); + }); + return valid; }; - Column.prototype.removeEventListener = function (eventType, listener) { - this.eventService.removeEventListener(eventType, listener); + DateFilter.prototype.areSimpleModelsEqual = function (aSimple, bSimple) { + return aSimple.dateFrom === bSimple.dateFrom + && aSimple.dateTo === bSimple.dateTo + && aSimple.type === bSimple.type; }; - Column.prototype.createIsColumnFuncParams = function (rowNode) { - return { - node: rowNode, - data: rowNode.data, - column: this, - colDef: this.colDef, - context: this.gridOptionsWrapper.getContext(), - api: this.gridOptionsWrapper.getApi(), - columnApi: this.gridOptionsWrapper.getColumnApi() - }; + DateFilter.prototype.getFilterType = function () { + return 'date'; }; - Column.prototype.isSuppressNavigable = function (rowNode) { - // if boolean set, then just use it - if (typeof this.colDef.suppressNavigable === 'boolean') { - return this.colDef.suppressNavigable; - } - // if function, then call the function to find out - if (typeof this.colDef.suppressNavigable === 'function') { - var params = this.createIsColumnFuncParams(rowNode); - var userFunc = this.colDef.suppressNavigable; - return userFunc(params); + DateFilter.prototype.createCondition = function (position) { + var type = this.getConditionTypes()[position]; + var model = {}; + var values = this.getValues(position); + if (values.length > 0) { + model.dateFrom = Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["serialiseDate"])(values[0]); } - return false; - }; - Column.prototype.isCellEditable = function (rowNode) { - // only allow editing of groups if the user has this option enabled - if (rowNode.group && !this.gridOptionsWrapper.isEnableGroupEdit()) { - return false; + if (values.length > 1) { + model.dateTo = Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["serialiseDate"])(values[1]); } - return this.isColumnFunc(rowNode, this.colDef.editable); + return __assign({ dateFrom: null, dateTo: null, filterType: this.getFilterType(), type: type }, model); }; - Column.prototype.isRowDrag = function (rowNode) { - return this.isColumnFunc(rowNode, this.colDef.rowDrag); - }; - Column.prototype.isDndSource = function (rowNode) { - return this.isColumnFunc(rowNode, this.colDef.dndSource); + DateFilter.prototype.resetPlaceholder = function () { + var globalTranslate = this.gridOptionsWrapper.getLocaleTextFunc(); + var placeholder = this.translate('dateFormatOoo'); + var ariaLabel = globalTranslate('ariaFilterValue', 'Filter Value'); + this.forEachInput(function (element) { + element.setInputPlaceholder(placeholder); + element.setInputAriaLabel(ariaLabel); + }); + }; + DateFilter.prototype.getInputs = function () { + return [ + [this.dateCondition1FromComp, this.dateCondition1ToComp], + [this.dateCondition2FromComp, this.dateCondition2ToComp], + ]; }; - Column.prototype.isCellCheckboxSelection = function (rowNode) { - return this.isColumnFunc(rowNode, this.colDef.checkboxSelection); + DateFilter.prototype.getValues = function (position) { + var result = []; + this.forEachInput(function (element, index, elPosition, numberOfInputs) { + if (position === elPosition && index < numberOfInputs) { + result.push(element.getDate()); + } + }); + return result; }; - Column.prototype.isSuppressPaste = function (rowNode) { - return this.isColumnFunc(rowNode, this.colDef ? this.colDef.suppressPaste : null); + DateFilter.DEFAULT_FILTER_OPTIONS = [ + _scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"].EQUALS, + _scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"].GREATER_THAN, + _scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"].LESS_THAN, + _scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"].NOT_EQUAL, + _scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"].IN_RANGE, + _scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"].BLANK, + _scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"].NOT_BLANK, + ]; + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eCondition1PanelFrom') + ], DateFilter.prototype, "eCondition1PanelFrom", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eCondition1PanelTo') + ], DateFilter.prototype, "eCondition1PanelTo", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eCondition2PanelFrom') + ], DateFilter.prototype, "eCondition2PanelFrom", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eCondition2PanelTo') + ], DateFilter.prototype, "eCondition2PanelTo", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('userComponentFactory') + ], DateFilter.prototype, "userComponentFactory", void 0); + return DateFilter; +}(_scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"])); + + + +/***/ }), +/* 59 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DateCompWrapper", function() { return DateCompWrapper; }); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(42); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ + +/** Provides sync access to async component. Date component can be lazy created - this class encapsulates + * this by keeping value locally until DateComp has loaded, then passing DateComp the value. */ +var DateCompWrapper = /** @class */ (function () { + function DateCompWrapper(context, userComponentFactory, dateComponentParams, eParent) { + var _this = this; + this.alive = true; + this.context = context; + this.eParent = eParent; + var compDetails = userComponentFactory.getDateCompDetails(dateComponentParams); + var promise = compDetails.newAgStackInstance(); + promise.then(function (dateComp) { + // because async, check the filter still exists after component comes back + if (!_this.alive) { + context.destroyBean(dateComp); + return; + } + _this.dateComp = dateComp; + if (!dateComp) { + return; + } + eParent.appendChild(dateComp.getGui()); + if (dateComp.afterGuiAttached) { + dateComp.afterGuiAttached(); + } + if (_this.tempValue) { + dateComp.setDate(_this.tempValue); + } + if (_this.disabled != null) { + _this.setDateCompDisabled(_this.disabled); + } + }); + } + DateCompWrapper.prototype.destroy = function () { + this.alive = false; + this.dateComp = this.context.destroyBean(this.dateComp); }; - Column.prototype.isResizable = function () { - return this.colDef.resizable === true; + DateCompWrapper.prototype.getDate = function () { + return this.dateComp ? this.dateComp.getDate() : this.tempValue; }; - Column.prototype.isColumnFunc = function (rowNode, value) { - // if boolean set, then just use it - if (typeof value === 'boolean') { - return value; + DateCompWrapper.prototype.setDate = function (value) { + if (this.dateComp) { + this.dateComp.setDate(value); } - // if function, then call the function to find out - if (typeof value === 'function') { - var params = this.createIsColumnFuncParams(rowNode); - var editableFunc = value; - return editableFunc(params); + else { + this.tempValue = value; } - return false; - }; - Column.prototype.setMoving = function (moving, source) { - if (source === void 0) { source = "api"; } - this.moving = moving; - this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_MOVING_CHANGED, source)); - }; - Column.prototype.createColumnEvent = function (type, source) { - return { - api: this.gridApi, - columnApi: this.columnApi, - type: type, - column: this, - columns: [this], - source: source - }; - }; - Column.prototype.isMoving = function () { - return this.moving; }; - Column.prototype.getSort = function () { - return this.sort; - }; - Column.prototype.setSort = function (sort, source) { - if (source === void 0) { source = "api"; } - if (this.sort !== sort) { - this.sort = sort; - this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_SORT_CHANGED, source)); + DateCompWrapper.prototype.setDisabled = function (disabled) { + if (this.dateComp) { + this.setDateCompDisabled(disabled); } - }; - Column.prototype.setMenuVisible = function (visible, source) { - if (source === void 0) { source = "api"; } - if (this.menuVisible !== visible) { - this.menuVisible = visible; - this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_MENU_VISIBLE_CHANGED, source)); + else { + this.disabled = disabled; } }; - Column.prototype.isMenuVisible = function () { - return this.menuVisible; - }; - Column.prototype.isSortAscending = function () { - return this.sort === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].SORT_ASC; + DateCompWrapper.prototype.setDisplayed = function (displayed) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_0__["setDisplayed"])(this.eParent, displayed); }; - Column.prototype.isSortDescending = function () { - return this.sort === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].SORT_DESC; - }; - Column.prototype.isSortNone = function () { - return _utils__WEBPACK_IMPORTED_MODULE_1__["_"].missing(this.sort); + DateCompWrapper.prototype.setInputPlaceholder = function (placeholder) { + if (this.dateComp && this.dateComp.setInputPlaceholder) { + this.dateComp.setInputPlaceholder(placeholder); + } }; - Column.prototype.isSorting = function () { - return _utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(this.sort); + DateCompWrapper.prototype.setInputAriaLabel = function (label) { + if (this.dateComp && this.dateComp.setInputAriaLabel) { + this.dateComp.setInputAriaLabel(label); + } }; - Column.prototype.getSortedAt = function () { - return this.sortedAt; + DateCompWrapper.prototype.afterGuiAttached = function (params) { + if (this.dateComp && typeof this.dateComp.afterGuiAttached === 'function') { + this.dateComp.afterGuiAttached(params); + } }; - Column.prototype.setSortedAt = function (sortedAt) { - this.sortedAt = sortedAt; + DateCompWrapper.prototype.setDateCompDisabled = function (disabled) { + if (this.dateComp == null) { + return; + } + if (this.dateComp.setDisabled == null) { + return; + } + this.dateComp.setDisabled(disabled); }; - Column.prototype.setAggFunc = function (aggFunc) { - this.aggFunc = aggFunc; + return DateCompWrapper; +}()); + + + +/***/ }), +/* 60 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ConditionPosition", function() { return ConditionPosition; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SimpleFilter", function() { return SimpleFilter; }); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57); +/* harmony import */ var _optionsFactory__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(61); +/* harmony import */ var _providedFilter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(62); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37); +/* harmony import */ var _widgets_agSelect__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(66); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(18); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(42); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(36); +/* harmony import */ var _widgets_agAbstractInputField__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(71); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - Column.prototype.getAggFunc = function () { - return this.aggFunc; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - Column.prototype.getLeft = function () { - return this.left; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + + + +var ConditionPosition; +(function (ConditionPosition) { + ConditionPosition[ConditionPosition["One"] = 0] = "One"; + ConditionPosition[ConditionPosition["Two"] = 1] = "Two"; +})(ConditionPosition || (ConditionPosition = {})); +/** + * Every filter with a dropdown where the user can specify a comparing type against the filter values. + * + * @param M type of filter-model managed by the concrete sub-class that extends this type + * @param V type of value managed by the concrete sub-class that extends this type + * @param E type of UI element used for collecting user-input + */ +var SimpleFilter = /** @class */ (function (_super) { + __extends(SimpleFilter, _super); + function SimpleFilter() { + return _super !== null && _super.apply(this, arguments) || this; + } + SimpleFilter.prototype.getNumberOfInputs = function (type) { + var customOpts = this.optionsFactory.getCustomOption(type); + if (customOpts) { + var numberOfInputs = customOpts.numberOfInputs; + return numberOfInputs != null ? numberOfInputs : 1; + } + var zeroInputTypes = [ + SimpleFilter.EMPTY, SimpleFilter.NOT_BLANK, SimpleFilter.BLANK, + ]; + if (type && zeroInputTypes.indexOf(type) >= 0) { + return 0; + } + else if (type === SimpleFilter.IN_RANGE) { + return 2; + } + return 1; }; - Column.prototype.getOldLeft = function () { - return this.oldLeft; + // floating filter calls this when user applies filter from floating filter + SimpleFilter.prototype.onFloatingFilterChanged = function (type, value) { + this.setTypeFromFloatingFilter(type); + this.setValueFromFloatingFilter(value); + this.onUiChanged(true); }; - Column.prototype.getRight = function () { - return this.left + this.actualWidth; + SimpleFilter.prototype.setTypeFromFloatingFilter = function (type) { + this.eType1.setValue(type); + this.eType2.setValue(this.optionsFactory.getDefaultOption()); + (this.isDefaultOperator('AND') ? this.eJoinOperatorAnd : this.eJoinOperatorOr).setValue(true); }; - Column.prototype.setLeft = function (left, source) { - if (source === void 0) { source = "api"; } - this.oldLeft = this.left; - if (this.left !== left) { - this.left = left; - this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_LEFT_CHANGED, source)); + SimpleFilter.prototype.getModelFromUi = function () { + if (!this.isConditionUiComplete(ConditionPosition.One)) { + return null; + } + if (this.isAllowTwoConditions() && this.isConditionUiComplete(ConditionPosition.Two)) { + return { + filterType: this.getFilterType(), + operator: this.getJoinOperator(), + condition1: this.createCondition(ConditionPosition.One), + condition2: this.createCondition(ConditionPosition.Two) + }; } + return this.createCondition(ConditionPosition.One); }; - Column.prototype.isFilterActive = function () { - return this.filterActive; + SimpleFilter.prototype.getConditionTypes = function () { + return [ + this.eType1.getValue(), + this.eType2.getValue(), + ]; }; - // additionalEventAttributes is used by provided simple floating filter, so it can add 'floatingFilter=true' to the event - Column.prototype.setFilterActive = function (active, source, additionalEventAttributes) { - if (source === void 0) { source = "api"; } - if (this.filterActive !== active) { - this.filterActive = active; - this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_FILTER_ACTIVE_CHANGED, source)); + SimpleFilter.prototype.getJoinOperator = function () { + return this.eJoinOperatorOr.getValue() === true ? 'OR' : 'AND'; + }; + SimpleFilter.prototype.areModelsEqual = function (a, b) { + // both are missing + if (!a && !b) { + return true; } - var filterChangedEvent = this.createColumnEvent(Column.EVENT_FILTER_CHANGED, source); - if (additionalEventAttributes) { - _utils__WEBPACK_IMPORTED_MODULE_1__["_"].mergeDeep(filterChangedEvent, additionalEventAttributes); + // one is missing, other present + if ((!a && b) || (a && !b)) { + return false; } - this.eventService.dispatchEvent(filterChangedEvent); - }; - Column.prototype.setPinned = function (pinned) { - if (pinned === true || pinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_LEFT) { - this.pinned = _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_LEFT; + // one is combined, the other is not + var aIsSimple = !a.operator; + var bIsSimple = !b.operator; + var oneSimpleOneCombined = (!aIsSimple && bIsSimple) || (aIsSimple && !bIsSimple); + if (oneSimpleOneCombined) { + return false; } - else if (pinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_RIGHT) { - this.pinned = _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_RIGHT; + var res; + // otherwise both present, so compare + if (aIsSimple) { + var aSimple = a; + var bSimple = b; + res = this.areSimpleModelsEqual(aSimple, bSimple); } else { - this.pinned = null; + var aCombined = a; + var bCombined = b; + res = aCombined.operator === bCombined.operator + && this.areSimpleModelsEqual(aCombined.condition1, bCombined.condition1) + && this.areSimpleModelsEqual(aCombined.condition2, bCombined.condition2); } + return res; }; - Column.prototype.setFirstRightPinned = function (firstRightPinned, source) { - if (source === void 0) { source = "api"; } - if (this.firstRightPinned !== firstRightPinned) { - this.firstRightPinned = firstRightPinned; - this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_FIRST_RIGHT_PINNED_CHANGED, source)); + SimpleFilter.prototype.setModelIntoUi = function (model) { + var isCombined = model.operator; + if (isCombined) { + var combinedModel = model; + var orChecked = combinedModel.operator === 'OR'; + this.eJoinOperatorAnd.setValue(!orChecked); + this.eJoinOperatorOr.setValue(orChecked); + this.eType1.setValue(combinedModel.condition1.type); + this.eType2.setValue(combinedModel.condition2.type); + this.setConditionIntoUi(combinedModel.condition1, ConditionPosition.One); + this.setConditionIntoUi(combinedModel.condition2, ConditionPosition.Two); } - }; - Column.prototype.setLastLeftPinned = function (lastLeftPinned, source) { - if (source === void 0) { source = "api"; } - if (this.lastLeftPinned !== lastLeftPinned) { - this.lastLeftPinned = lastLeftPinned; - this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_LAST_LEFT_PINNED_CHANGED, source)); + else { + var simpleModel = model; + this.eJoinOperatorAnd.setValue(this.isDefaultOperator('AND')); + this.eJoinOperatorOr.setValue(this.isDefaultOperator('OR')); + this.eType1.setValue(simpleModel.type); + this.eType2.setValue(this.optionsFactory.getDefaultOption()); + this.setConditionIntoUi(simpleModel, ConditionPosition.One); + this.setConditionIntoUi(null, ConditionPosition.Two); } + return _utils__WEBPACK_IMPORTED_MODULE_3__["AgPromise"].resolve(); }; - Column.prototype.isFirstRightPinned = function () { - return this.firstRightPinned; - }; - Column.prototype.isLastLeftPinned = function () { - return this.lastLeftPinned; - }; - Column.prototype.isPinned = function () { - return this.pinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_LEFT || this.pinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_RIGHT; - }; - Column.prototype.isPinnedLeft = function () { - return this.pinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_LEFT; - }; - Column.prototype.isPinnedRight = function () { - return this.pinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_RIGHT; - }; - Column.prototype.getPinned = function () { - return this.pinned; - }; - Column.prototype.setVisible = function (visible, source) { - if (source === void 0) { source = "api"; } - var newValue = visible === true; - if (this.visible !== newValue) { - this.visible = newValue; - this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_VISIBLE_CHANGED, source)); + SimpleFilter.prototype.doesFilterPass = function (params) { + var _this = this; + var model = this.getModel(); + if (model == null) { + return true; } + var operator = model.operator; + var models = []; + if (operator) { + var combinedModel = model; + models.push(combinedModel.condition1, combinedModel.condition2); + } + else { + models.push(model); + } + var combineFunction = operator && operator === 'OR' ? 'some' : 'every'; + return models[combineFunction](function (m) { return _this.individualConditionPasses(params, m); }); }; - Column.prototype.isVisible = function () { - return this.visible; - }; - Column.prototype.getColDef = function () { - return this.colDef; - }; - Column.prototype.getColumnGroupShow = function () { - return this.colDef.columnGroupShow; + SimpleFilter.prototype.setParams = function (params) { + _super.prototype.setParams.call(this, params); + this.optionsFactory = new _optionsFactory__WEBPACK_IMPORTED_MODULE_1__["OptionsFactory"](); + this.optionsFactory.init(params, this.getDefaultFilterOptions()); + this.allowTwoConditions = !params.suppressAndOrCondition; + this.alwaysShowBothConditions = !!params.alwaysShowBothConditions; + this.defaultJoinOperator = this.getDefaultJoinOperator(params.defaultJoinOperator); + this.putOptionsIntoDropdown(); + this.addChangedListeners(); }; - Column.prototype.getColId = function () { - return this.colId; + SimpleFilter.prototype.getDefaultJoinOperator = function (defaultJoinOperator) { + return Object(_utils_array__WEBPACK_IMPORTED_MODULE_5__["includes"])(['AND', 'OR'], defaultJoinOperator) ? defaultJoinOperator : 'AND'; }; - Column.prototype.getId = function () { - return this.getColId(); + SimpleFilter.prototype.putOptionsIntoDropdown = function () { + var _this = this; + var filterOptions = this.optionsFactory.getFilterOptions(); + var eTypes = [this.eType1, this.eType2]; + // Add specified options to all condition drop-downs. + filterOptions.forEach(function (option) { + var listOption = typeof option === 'string' ? + _this.createBoilerplateListOption(option) : + _this.createCustomListOption(option); + eTypes.forEach(function (eType) { return eType.addOption(listOption); }); + }); + // Make drop-downs read-only if there is only one option. + eTypes.forEach(function (eType) { return eType.setDisabled(filterOptions.length <= 1); }); + }; + SimpleFilter.prototype.createBoilerplateListOption = function (option) { + return { value: option, text: this.translate(option) }; + }; + SimpleFilter.prototype.createCustomListOption = function (option) { + var displayKey = option.displayKey; + var customOption = this.optionsFactory.getCustomOption(option.displayKey); + return { + value: displayKey, + text: customOption ? + this.gridOptionsWrapper.getLocaleTextFunc()(customOption.displayKey, customOption.displayName) : + this.translate(displayKey), + }; }; - Column.prototype.getDefinition = function () { - return this.colDef; + SimpleFilter.prototype.isAllowTwoConditions = function () { + return this.allowTwoConditions; }; - Column.prototype.getActualWidth = function () { - return this.actualWidth; + SimpleFilter.prototype.createBodyTemplate = function () { + return /* html */ "\n \n " + this.createValueTemplate(ConditionPosition.One) + "\n
\n \n \n
\n \n " + this.createValueTemplate(ConditionPosition.Two); }; - Column.prototype.createBaseColDefParams = function (rowNode) { - var params = { - node: rowNode, - data: rowNode.data, - colDef: this.colDef, - column: this, - api: this.gridOptionsWrapper.getApi(), - columnApi: this.gridOptionsWrapper.getColumnApi(), - context: this.gridOptionsWrapper.getContext() - }; - return params; + SimpleFilter.prototype.getCssIdentifier = function () { + return 'simple-filter'; }; - Column.prototype.getColSpan = function (rowNode) { - if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].missing(this.colDef.colSpan)) { - return 1; - } - var params = this.createBaseColDefParams(rowNode); - var colSpan = this.colDef.colSpan(params); - // colSpan must be number equal to or greater than 1 - return Math.max(colSpan, 1); + SimpleFilter.prototype.updateUiVisibility = function () { + var _this = this; + var elementConditionGroups = [ + [this.eType1], + [this.eType2, this.eJoinOperatorPanel, this.eJoinOperatorAnd, this.eJoinOperatorOr], + ]; + var elementBodies = [this.eCondition1Body, this.eCondition2Body]; + elementConditionGroups.forEach(function (group, position) { + var visible = _this.isConditionVisible(position); + var disabled = _this.isConditionDisabled(position); + group.forEach(function (element) { + if (element instanceof _widgets_agAbstractInputField__WEBPACK_IMPORTED_MODULE_8__["AgAbstractInputField"] || element instanceof _widgets_agSelect__WEBPACK_IMPORTED_MODULE_4__["AgSelect"]) { + element.setDisabled(disabled); + element.setDisplayed(visible); + } + else { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["setDisabled"])(element, disabled); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["setDisplayed"])(element, visible); + } + }); + }); + elementBodies.forEach(function (element, index) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["setDisplayed"])(element, _this.isConditionBodyVisible(index)); + }); + this.forEachInput(function (element, index, position, numberOfInputs) { + _this.setElementDisplayed(element, index < numberOfInputs); + _this.setElementDisabled(element, _this.isConditionDisabled(position)); + }); + this.resetPlaceholder(); }; - Column.prototype.getRowSpan = function (rowNode) { - if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].missing(this.colDef.rowSpan)) { - return 1; + SimpleFilter.prototype.afterGuiAttached = function (params) { + _super.prototype.afterGuiAttached.call(this, params); + this.resetPlaceholder(); + if (!params || (!params.suppressFocus && !this.isReadOnly())) { + var firstInput = this.getInputs()[0][0]; + if (!firstInput) { + return; + } + if (firstInput instanceof _widgets_agAbstractInputField__WEBPACK_IMPORTED_MODULE_8__["AgAbstractInputField"]) { + firstInput.getInputElement().focus(); + } } - var params = this.createBaseColDefParams(rowNode); - var rowSpan = this.colDef.rowSpan(params); - // rowSpan must be number equal to or greater than 1 - return Math.max(rowSpan, 1); }; - Column.prototype.setActualWidth = function (actualWidth, source) { - if (source === void 0) { source = "api"; } - if (this.minWidth != null) { - actualWidth = Math.max(actualWidth, this.minWidth); - } - if (this.maxWidth != null) { - actualWidth = Math.min(actualWidth, this.maxWidth); - } - if (this.actualWidth !== actualWidth) { - // disable flex for this column if it was manually resized. - if (this.flex && source !== 'flex') { - this.flex = 0; + // allow sub-classes to reset HTML placeholders after UI update. + SimpleFilter.prototype.resetPlaceholder = function () { + var _this = this; + var globalTranslate = this.gridOptionsWrapper.getLocaleTextFunc(); + this.forEachInput(function (element, index, _, numberOfInputs) { + if (!(element instanceof _widgets_agAbstractInputField__WEBPACK_IMPORTED_MODULE_8__["AgAbstractInputField"])) { + return; } - this.actualWidth = actualWidth; - this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_WIDTH_CHANGED, source)); - } + var placeholder = index === 0 && numberOfInputs > 1 ? 'inRangeStart' : + index === 0 ? 'filterOoo' : + 'inRangeEnd'; + var ariaLabel = index === 0 && numberOfInputs > 1 ? globalTranslate('ariaFilterFromValue', 'Filter from value') : + index === 0 ? globalTranslate('ariaFilterValue', 'Filter Value') : + globalTranslate('ariaFilterToValue', 'Filter to Value'); + element.setInputPlaceholder(_this.translate(placeholder)); + element.setInputAriaLabel(ariaLabel); + }); }; - Column.prototype.isGreaterThanMax = function (width) { - if (this.maxWidth != null) { - return width > this.maxWidth; + SimpleFilter.prototype.setElementValue = function (element, value, silent) { + if (element instanceof _widgets_agAbstractInputField__WEBPACK_IMPORTED_MODULE_8__["AgAbstractInputField"]) { + element.setValue(value != null ? String(value) : null, silent); } - return false; - }; - Column.prototype.getMinWidth = function () { - return this.minWidth; - }; - Column.prototype.getMaxWidth = function () { - return this.maxWidth; - }; - Column.prototype.getFlex = function () { - return this.flex || 0; }; - // this method should only be used by the columnController to - // change flex when required by the setColumnState method. - Column.prototype.setFlex = function (flex) { - if (this.flex !== flex) { - this.flex = flex; + SimpleFilter.prototype.setElementDisplayed = function (element, displayed) { + if (element instanceof _widgets_component__WEBPACK_IMPORTED_MODULE_7__["Component"]) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["setDisplayed"])(element.getGui(), displayed); } }; - Column.prototype.setMinimum = function (source) { - if (source === void 0) { source = "api"; } - this.setActualWidth(this.minWidth, source); + SimpleFilter.prototype.setElementDisabled = function (element, disabled) { + if (element instanceof _widgets_component__WEBPACK_IMPORTED_MODULE_7__["Component"]) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["setDisabled"])(element.getGui(), disabled); + } }; - Column.prototype.setRowGroupActive = function (rowGroup, source) { - if (source === void 0) { source = "api"; } - if (this.rowGroupActive !== rowGroup) { - this.rowGroupActive = rowGroup; - this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_ROW_GROUP_CHANGED, source)); + SimpleFilter.prototype.attachElementOnChange = function (element, listener) { + if (element instanceof _widgets_agAbstractInputField__WEBPACK_IMPORTED_MODULE_8__["AgAbstractInputField"]) { + element.onValueChange(listener); } }; - Column.prototype.isRowGroupActive = function () { - return this.rowGroupActive; + SimpleFilter.prototype.forEachInput = function (cb) { + var _this = this; + var inputs = this.getInputs(); + this.getConditionTypes().forEach(function (type, position) { + var numberOfInputs = _this.getNumberOfInputs(type); + for (var index = 0; index < inputs[position].length; index++) { + var input = inputs[position][index]; + if (input != null) { + cb(input, index, position, numberOfInputs); + } + } + }); }; - Column.prototype.setPivotActive = function (pivot, source) { - if (source === void 0) { source = "api"; } - if (this.pivotActive !== pivot) { - this.pivotActive = pivot; - this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_PIVOT_CHANGED, source)); + SimpleFilter.prototype.isConditionVisible = function (position) { + if (position === 0) { + return true; + } // Position 0 should always be visible. + if (!this.allowTwoConditions) { + return false; + } // Short-circuit if no tail conditions. + if (this.isReadOnly()) { + // Only display a condition when read-only if the condition is complete. + return this.isConditionUiComplete(position); } + if (this.alwaysShowBothConditions) { + return true; + } + // Only display a 2nd or later condition when the previous condition is complete. + return this.isConditionUiComplete(position - 1); }; - Column.prototype.isPivotActive = function () { - return this.pivotActive; - }; - Column.prototype.isAnyFunctionActive = function () { - return this.isPivotActive() || this.isRowGroupActive() || this.isValueActive(); + SimpleFilter.prototype.isConditionDisabled = function (position) { + if (this.isReadOnly()) { + return true; + } // Read-only mode trumps everything. + if (!this.isConditionVisible(position)) { + return true; + } // Invisible implies disabled. + if (position === 0) { + return false; + } // Position 0 should typically be editable. + // Only allow editing of a 2nd or later condition if the previous condition is complete. + return !this.isConditionUiComplete(position - 1); }; - Column.prototype.isAnyFunctionAllowed = function () { - return this.isAllowPivot() || this.isAllowRowGroup() || this.isAllowValue(); + SimpleFilter.prototype.isConditionBodyVisible = function (position) { + if (!this.isConditionVisible(position)) { + return false; + } + // Check that the condition needs inputs. + var type = this.getConditionTypes()[position]; + var numberOfInputs = this.getNumberOfInputs(type); + return numberOfInputs > 0; }; - Column.prototype.setValueActive = function (value, source) { - if (source === void 0) { source = "api"; } - if (this.aggregationActive !== value) { - this.aggregationActive = value; - this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_VALUE_CHANGED, source)); + // returns true if the UI represents a working filter, eg all parts are filled out. + // eg if text filter and textfield blank then returns false. + SimpleFilter.prototype.isConditionUiComplete = function (position) { + var type = this.getConditionTypes()[position]; + if (type === SimpleFilter.EMPTY) { + return false; + } + if (this.getValues(position).some(function (v) { return v == null; })) { + return false; } + return true; }; - Column.prototype.isValueActive = function () { - return this.aggregationActive; + SimpleFilter.prototype.resetUiToDefaults = function (silent) { + var _this = this; + var translate = this.gridOptionsWrapper.getLocaleTextFunc(); + var filteringLabel = translate('ariaFilteringOperator', 'Filtering operator'); + var uniqueGroupId = 'ag-simple-filter-and-or-' + this.getCompId(); + var defaultOption = this.optionsFactory.getDefaultOption(); + this.eType1 + .setValue(defaultOption, silent) + .setAriaLabel(filteringLabel) + .setDisabled(this.isReadOnly()); + this.eType2 + .setValue(this.optionsFactory.getDefaultOption(), silent) + .setAriaLabel(filteringLabel) + .setDisabled(this.isReadOnly()); + this.eJoinOperatorAnd + .setValue(this.isDefaultOperator('AND'), silent) + .setName(uniqueGroupId) + .setLabel(this.translate('andCondition')) + .setDisabled(this.isReadOnly()); + this.eJoinOperatorOr + .setValue(this.isDefaultOperator('OR'), silent) + .setName(uniqueGroupId) + .setLabel(this.translate('orCondition')) + .setDisabled(this.isReadOnly()); + this.forEachInput(function (element) { + _this.setElementValue(element, null, silent); + _this.setElementDisabled(element, _this.isReadOnly()); + }); + this.resetPlaceholder(); + return _utils__WEBPACK_IMPORTED_MODULE_3__["AgPromise"].resolve(); }; - Column.prototype.isAllowPivot = function () { - return this.colDef.enablePivot === true; + // puts model values into the UI + SimpleFilter.prototype.setConditionIntoUi = function (model, position) { + var _this = this; + var values = this.mapValuesFromModel(model); + this.forEachInput(function (element, index, elPosition, _) { + if (elPosition !== position) { + return; + } + _this.setElementValue(element, values[index] != null ? values[index] : null); + }); }; - Column.prototype.isAllowValue = function () { - return this.colDef.enableValue === true; + // after floating filter changes, this sets the 'value' section. this is implemented by the base class + // (as that's where value is controlled), the 'type' part from the floating filter is dealt with in this class. + SimpleFilter.prototype.setValueFromFloatingFilter = function (value) { + var _this = this; + this.forEachInput(function (element, index, position, _) { + _this.setElementValue(element, index === 0 && position === 0 ? value : null); + }); }; - Column.prototype.isAllowRowGroup = function () { - return this.colDef.enableRowGroup === true; + SimpleFilter.prototype.isDefaultOperator = function (operator) { + return operator === this.defaultJoinOperator; }; - Column.prototype.getMenuTabs = function (defaultValues) { - var menuTabs = this.getColDef().menuTabs; - if (menuTabs == null) { - menuTabs = defaultValues; + SimpleFilter.prototype.addChangedListeners = function () { + var _this = this; + if (this.isReadOnly()) { + return; } - return menuTabs; - }; - // this used to be needed, as previous version of ag-grid had lockPosition as column state, - // so couldn't depend on colDef version. - Column.prototype.isLockPosition = function () { - console.warn('ag-Grid: since v21, col.isLockPosition() should not be used, please use col.getColDef().lockPosition instead.'); - return this.colDef ? !!this.colDef.lockPosition : false; - }; - // this used to be needed, as previous version of ag-grid had lockVisible as column state, - // so couldn't depend on colDef version. - Column.prototype.isLockVisible = function () { - console.warn('ag-Grid: since v21, col.isLockVisible() should not be used, please use col.getColDef().lockVisible instead.'); - return this.colDef ? !!this.colDef.lockVisible : false; - }; - // this used to be needed, as previous version of ag-grid had lockPinned as column state, - // so couldn't depend on colDef version. - Column.prototype.isLockPinned = function () { - console.warn('ag-Grid: since v21, col.isLockPinned() should not be used, please use col.getColDef().lockPinned instead.'); - return this.colDef ? !!this.colDef.lockPinned : false; + var listener = function () { return _this.onUiChanged(); }; + this.eType1.onValueChange(listener); + this.eType2.onValueChange(listener); + this.eJoinOperatorOr.onValueChange(listener); + this.eJoinOperatorAnd.onValueChange(listener); + this.forEachInput(function (element) { + _this.attachElementOnChange(element, listener); + }); }; - // + renderedHeaderCell - for making header cell transparent when moving - Column.EVENT_MOVING_CHANGED = 'movingChanged'; - // + renderedCell - changing left position - Column.EVENT_LEFT_CHANGED = 'leftChanged'; - // + renderedCell - changing width - Column.EVENT_WIDTH_CHANGED = 'widthChanged'; - // + renderedCell - for changing pinned classes - Column.EVENT_LAST_LEFT_PINNED_CHANGED = 'lastLeftPinnedChanged'; - Column.EVENT_FIRST_RIGHT_PINNED_CHANGED = 'firstRightPinnedChanged'; - // + renderedColumn - for changing visibility icon - Column.EVENT_VISIBLE_CHANGED = 'visibleChanged'; - // + every time the filter changes, used in the floating filters - Column.EVENT_FILTER_CHANGED = 'filterChanged'; - // + renderedHeaderCell - marks the header with filter icon - Column.EVENT_FILTER_ACTIVE_CHANGED = 'filterActiveChanged'; - // + renderedHeaderCell - marks the header with sort icon - Column.EVENT_SORT_CHANGED = 'sortChanged'; - Column.EVENT_MENU_VISIBLE_CHANGED = 'menuVisibleChanged'; - // + toolpanel, for gui updates - Column.EVENT_ROW_GROUP_CHANGED = 'columnRowGroupChanged'; - // + toolpanel, for gui updates - Column.EVENT_PIVOT_CHANGED = 'columnPivotChanged'; - // + toolpanel, for gui updates - Column.EVENT_VALUE_CHANGED = 'columnValueChanged'; + /** returns true if the row passes the said condition */ + SimpleFilter.prototype.individualConditionPasses = function (params, filterModel) { + var cellValue = this.getCellValue(params.node); + var values = this.mapValuesFromModel(filterModel); + var customFilterOption = this.optionsFactory.getCustomOption(filterModel.type); + var customFilterResult = this.evaluateCustomFilter(customFilterOption, values, cellValue); + if (customFilterResult != null) { + return customFilterResult; + } + if (cellValue == null) { + return this.evaluateNullValue(filterModel.type); + } + return this.evaluateNonNullValue(values, cellValue, filterModel, params); + }; + SimpleFilter.prototype.evaluateCustomFilter = function (customFilterOption, values, cellValue) { + if (customFilterOption == null) { + return; + } + var predicate = customFilterOption.predicate; + // only execute the custom filter if a value exists or a value isn't required, i.e. input is hidden + if (predicate != null && !values.some(function (v) { return v == null; })) { + return predicate(values, cellValue); + } + // No custom filter invocation, indicate that to the caller. + return; + }; + SimpleFilter.prototype.isBlank = function (cellValue) { + return cellValue == null || + (typeof cellValue === 'string' && cellValue.trim().length === 0); + }; + SimpleFilter.EMPTY = 'empty'; + SimpleFilter.BLANK = 'blank'; + SimpleFilter.NOT_BLANK = 'notBlank'; + SimpleFilter.EQUALS = 'equals'; + SimpleFilter.NOT_EQUAL = 'notEqual'; + SimpleFilter.LESS_THAN = 'lessThan'; + SimpleFilter.LESS_THAN_OR_EQUAL = 'lessThanOrEqual'; + SimpleFilter.GREATER_THAN = 'greaterThan'; + SimpleFilter.GREATER_THAN_OR_EQUAL = 'greaterThanOrEqual'; + SimpleFilter.IN_RANGE = 'inRange'; + SimpleFilter.CONTAINS = 'contains'; + SimpleFilter.NOT_CONTAINS = 'notContains'; + SimpleFilter.STARTS_WITH = 'startsWith'; + SimpleFilter.ENDS_WITH = 'endsWith'; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper') - ], Column.prototype, "gridOptionsWrapper", void 0); + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eOptions1') + ], SimpleFilter.prototype, "eType1", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnUtils') - ], Column.prototype, "columnUtils", void 0); + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eOptions2') + ], SimpleFilter.prototype, "eType2", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnApi') - ], Column.prototype, "columnApi", void 0); + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eJoinOperatorPanel') + ], SimpleFilter.prototype, "eJoinOperatorPanel", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridApi') - ], Column.prototype, "gridApi", void 0); + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eJoinOperatorAnd') + ], SimpleFilter.prototype, "eJoinOperatorAnd", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('context') - ], Column.prototype, "context", void 0); + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eJoinOperatorOr') + ], SimpleFilter.prototype, "eJoinOperatorOr", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] - ], Column.prototype, "initialise", null); - return Column; -}()); + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eCondition1Body') + ], SimpleFilter.prototype, "eCondition1Body", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eCondition2Body') + ], SimpleFilter.prototype, "eCondition2Body", void 0); + return SimpleFilter; +}(_providedFilter__WEBPACK_IMPORTED_MODULE_2__["ProvidedFilter"])); /***/ }), -/* 36 */ +/* 61 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "EventService", function() { return EventService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "OptionsFactory", function() { return OptionsFactory; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { - return function (target, key) { decorator(target, key, paramIndex); } +var __assign = (undefined && undefined.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); }; - - -var EventService = /** @class */ (function () { - function EventService() { - this.allSyncListeners = new Map(); - this.allAsyncListeners = new Map(); - this.globalSyncListeners = new Set(); - this.globalAsyncListeners = new Set(); - this.asyncFunctionsQueue = []; - this.scheduled = false; - // using an object performs better than a Set for the number of different events we have - this.firedEvents = {}; +/* Common logic for options, used by both filters and floating filters. */ +var OptionsFactory = /** @class */ (function () { + function OptionsFactory() { + this.customFilterOptions = {}; } - // because this class is used both inside the context and outside the context, we do not - // use autowired attributes, as that would be confusing, as sometimes the attributes - // would be wired, and sometimes not. - // - // the global event servers used by ag-Grid is autowired by the context once, and this - // setBeans method gets called once. - // - // the times when this class is used outside of the context (eg RowNode has an instance of this - // class) then it is not a bean, and this setBeans method is not called. - EventService.prototype.setBeans = function (loggerFactory, gridOptionsWrapper, globalEventListener) { - if (globalEventListener === void 0) { globalEventListener = null; } - this.logger = loggerFactory.create('EventService'); - if (globalEventListener) { - var async = gridOptionsWrapper.useAsyncEvents(); - this.addGlobalListener(globalEventListener, async); - } + OptionsFactory.prototype.init = function (params, defaultOptions) { + this.filterOptions = params.filterOptions || defaultOptions; + this.mapCustomOptions(); + this.selectDefaultItem(params); + this.checkForDeprecatedParams(); }; - EventService.prototype.getListeners = function (eventType, async) { - var listenerMap = async ? this.allAsyncListeners : this.allSyncListeners; - var listeners = listenerMap.get(eventType); - if (!listeners) { - listeners = new Set(); - listenerMap.set(eventType, listeners); + OptionsFactory.prototype.checkForDeprecatedParams = function () { + if (this.filterOptions.some(function (opt) { return typeof opt != 'string' && opt.test != null; })) { + console.warn("AG Grid: [IFilterOptionDef] since v26.2.0, test() has been replaced with predicate()."); } - return listeners; - }; - EventService.prototype.addEventListener = function (eventType, listener, async) { - if (async === void 0) { async = false; } - this.getListeners(eventType, async).add(listener); - }; - EventService.prototype.removeEventListener = function (eventType, listener, async) { - if (async === void 0) { async = false; } - this.getListeners(eventType, async).delete(listener); - }; - EventService.prototype.addGlobalListener = function (listener, async) { - if (async === void 0) { async = false; } - (async ? this.globalAsyncListeners : this.globalSyncListeners).add(listener); - }; - EventService.prototype.removeGlobalListener = function (listener, async) { - if (async === void 0) { async = false; } - (async ? this.globalAsyncListeners : this.globalSyncListeners).delete(listener); - }; - EventService.prototype.dispatchEvent = function (event) { - this.dispatchToListeners(event, true); - this.dispatchToListeners(event, false); - this.firedEvents[event.type] = true; - }; - EventService.prototype.dispatchEventOnce = function (event) { - if (!this.firedEvents[event.type]) { - this.dispatchEvent(event); + if (this.filterOptions.some(function (opt) { return typeof opt != 'string' && opt.hideFilterInput != null; })) { + console.warn("AG Grid: [IFilterOptionDef] since v26.2.0, useOfHideFilterInput has been replaced with numberOfInputs."); } }; - EventService.prototype.dispatchToListeners = function (event, async) { + OptionsFactory.prototype.getFilterOptions = function () { + return this.filterOptions; + }; + OptionsFactory.prototype.mapCustomOptions = function () { var _this = this; - var eventType = event.type; - var processEventListeners = function (listeners) { return listeners.forEach(function (listener) { - if (async) { - _this.dispatchAsync(function () { return listener(event); }); + if (!this.filterOptions) { + return; + } + this.filterOptions.forEach(function (filterOption) { + if (typeof filterOption === 'string') { + return; } - else { - listener(event); + var requiredProperties = [['displayKey'], ['displayName'], ['predicate', 'test']]; + var propertyCheck = function (keys) { + if (!keys.some(function (key) { return filterOption[key] != null; })) { + console.warn("AG Grid: ignoring FilterOptionDef as it doesn't contain one of '" + keys + "'"); + return false; + } + return true; + }; + if (!requiredProperties.every(propertyCheck)) { + _this.filterOptions = _this.filterOptions.filter(function (v) { return v === filterOption; }) || []; + return; } - }); }; - processEventListeners(this.getListeners(eventType, async)); - var globalListeners = async ? this.globalAsyncListeners : this.globalSyncListeners; - globalListeners.forEach(function (listener) { - if (async) { - _this.dispatchAsync(function () { return listener(eventType, event); }); + var test = filterOption.test; + var mutatedFilterOptions = __assign({}, filterOption); + if (test != null && filterOption.predicate == null) { + mutatedFilterOptions.predicate = function (v, cv) { return test(v[0], cv); }; + delete mutatedFilterOptions.test; } - else { - listener(eventType, event); + if (mutatedFilterOptions.hideFilterInput && mutatedFilterOptions.numberOfInputs == null) { + mutatedFilterOptions.numberOfInputs = 0; + delete mutatedFilterOptions.hideFilterInput; } + _this.customFilterOptions[filterOption.displayKey] = mutatedFilterOptions; }); }; - // this gets called inside the grid's thread, for each event that it - // wants to set async. the grid then batches the events into one setTimeout() - // because setTimeout() is an expensive operation. ideally we would have - // each event in it's own setTimeout(), but we batch for performance. - EventService.prototype.dispatchAsync = function (func) { - // add to the queue for executing later in the next VM turn - this.asyncFunctionsQueue.push(func); - // check if timeout is already scheduled. the first time the grid calls - // this within it's thread turn, this should be false, so it will schedule - // the 'flush queue' method the first time it comes here. then the flag is - // set to 'true' so it will know it's already scheduled for subsequent calls. - if (!this.scheduled) { - // if not scheduled, schedule one - window.setTimeout(this.flushAsyncQueue.bind(this), 0); - // mark that it is scheduled - this.scheduled = true; + OptionsFactory.prototype.selectDefaultItem = function (params) { + if (params.defaultOption) { + this.defaultOption = params.defaultOption; + } + else if (this.filterOptions.length >= 1) { + var firstFilterOption = this.filterOptions[0]; + if (typeof firstFilterOption === 'string') { + this.defaultOption = firstFilterOption; + } + else if (firstFilterOption.displayKey) { + this.defaultOption = firstFilterOption.displayKey; + } + else { + console.warn("AG Grid: invalid FilterOptionDef supplied as it doesn't contain a 'displayKey'"); + } + } + else { + console.warn('AG Grid: no filter options for filter'); } }; - // this happens in the next VM turn only, and empties the queue of events - EventService.prototype.flushAsyncQueue = function () { - this.scheduled = false; - // we take a copy, because the event listener could be using - // the grid, which would cause more events, which would be potentially - // added to the queue, so safe to take a copy, the new events will - // get executed in a later VM turn rather than risk updating the - // queue as we are flushing it. - var queueCopy = this.asyncFunctionsQueue.slice(); - this.asyncFunctionsQueue = []; - // execute the queue - queueCopy.forEach(function (func) { return func(); }); + OptionsFactory.prototype.getDefaultOption = function () { + return this.defaultOption; }; - __decorate([ - __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('loggerFactory')), - __param(1, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('gridOptionsWrapper')), - __param(2, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('globalEventListener')) - ], EventService.prototype, "setBeans", null); - EventService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('eventService') - ], EventService); - return EventService; + OptionsFactory.prototype.getCustomOption = function (name) { + return this.customFilterOptions[name]; + }; + return OptionsFactory; }()); /***/ }), -/* 37 */ +/* 62 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Context", function() { return Context; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PreConstruct", function() { return PreConstruct; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PostConstruct", function() { return PostConstruct; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PreDestroy", function() { return PreDestroy; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Bean", function() { return Bean; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Autowired", function() { return Autowired; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Optional", function() { return Optional; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Qualifier", function() { return Qualifier; }); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ProvidedFilter", function() { return ProvidedFilter; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(42); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(14); +/* harmony import */ var _filterLocaleText__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(63); +/* harmony import */ var _widgets_managedFocusFeature__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(64); +/* harmony import */ var _utils_set__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(52); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(36); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; -var Context = /** @class */ (function () { - function Context(params, logger) { - this.beanWrappers = {}; - this.destroyed = false; - if (!params || !params.beanClasses) { - return; - } - this.contextParams = params; - this.logger = logger; - this.logger.log(">> creating ag-Application Context"); - this.createBeans(); - var beanInstances = this.getBeanInstances(); - this.wireBeans(beanInstances); - this.logger.log(">> ag-Application Context ready - component is alive"); + + + + + + +/** + * Contains common logic to all provided filters (apply button, clear button, etc). + * All the filters that come with AG Grid extend this class. User filters do not + * extend this class. + * + * @param M type of filter-model managed by the concrete sub-class that extends this type + * @param V type of value managed by the concrete sub-class that extends this type + */ +var ProvidedFilter = /** @class */ (function (_super) { + __extends(ProvidedFilter, _super); + function ProvidedFilter(filterNameKey) { + var _this = _super.call(this) || this; + _this.filterNameKey = filterNameKey; + _this.applyActive = false; + _this.hidePopup = null; + // after the user hits 'apply' the model gets copied to here. this is then the model that we use for + // all filtering. so if user changes UI but doesn't hit apply, then the UI will be out of sync with this model. + // this is what we want, as the UI should only become the 'active' filter once it's applied. when apply is + // inactive, this model will be in sync (following the debounce ms). if the UI is not a valid filter + // (eg the value is missing so nothing to filter on, or for set filter all checkboxes are checked so filter + // not active) then this appliedModel will be null/undefined. + _this.appliedModel = null; + return _this; } - Context.prototype.getBeanInstances = function () { - return _utils__WEBPACK_IMPORTED_MODULE_0__["_"].values(this.beanWrappers).map(function (beanEntry) { return beanEntry.beanInstance; }); + ProvidedFilter.prototype.postConstruct = function () { + this.resetTemplate(); // do this first to create the DOM + this.createManagedBean(new _widgets_managedFocusFeature__WEBPACK_IMPORTED_MODULE_4__["ManagedFocusFeature"](this.getFocusableElement(), { + handleKeyDown: this.handleKeyDown.bind(this) + })); }; - Context.prototype.createBean = function (bean, afterPreCreateCallback) { - if (!bean) { - throw Error("Can't wire to bean since it is null"); - } - this.wireBeans([bean], afterPreCreateCallback); - return bean; + // override + ProvidedFilter.prototype.handleKeyDown = function (e) { }; + ProvidedFilter.prototype.getFilterTitle = function () { + return this.translate(this.filterNameKey); }; - Context.prototype.wireBeans = function (beanInstances, afterPreCreateCallback) { - this.autoWireBeans(beanInstances); - this.methodWireBeans(beanInstances); - this.callLifeCycleMethods(beanInstances, 'preConstructMethods'); - // the callback sets the attributes, so the component has access to attributes - // before postConstruct methods in the component are executed - if (_utils__WEBPACK_IMPORTED_MODULE_0__["_"].exists(afterPreCreateCallback)) { - beanInstances.forEach(afterPreCreateCallback); - } - this.callLifeCycleMethods(beanInstances, 'postConstructMethods'); + ProvidedFilter.prototype.isFilterActive = function () { + // filter is active if we have a valid applied model + return !!this.appliedModel; }; - Context.prototype.createBeans = function () { + ProvidedFilter.prototype.resetTemplate = function (paramsMap) { + var templateString = /* html */ "\n
\n
\n " + this.createBodyTemplate() + "\n
\n
"; + this.setTemplate(templateString, paramsMap); + }; + ProvidedFilter.prototype.isReadOnly = function () { + return !!this.providedFilterParams.readOnly; + }; + ProvidedFilter.prototype.init = function (params) { var _this = this; - // register all normal beans - this.contextParams.beanClasses.forEach(this.createBeanWrapper.bind(this)); - // register override beans, these will overwrite beans above of same name - // instantiate all beans - overridden beans will be left out - _utils__WEBPACK_IMPORTED_MODULE_0__["_"].iterateObject(this.beanWrappers, function (key, beanEntry) { - var constructorParamsMeta; - if (beanEntry.bean.__agBeanMetaData && beanEntry.bean.__agBeanMetaData.autowireMethods && beanEntry.bean.__agBeanMetaData.autowireMethods.agConstructor) { - constructorParamsMeta = beanEntry.bean.__agBeanMetaData.autowireMethods.agConstructor; - } - var constructorParams = _this.getBeansForParameters(constructorParamsMeta, beanEntry.bean.name); - var newInstance = applyToConstructor(beanEntry.bean, constructorParams); - beanEntry.beanInstance = newInstance; + this.setParams(params); + this.resetUiToDefaults(true).then(function () { + _this.updateUiVisibility(); + _this.setupOnBtApplyDebounce(); }); - var createdBeanNames = Object.keys(this.beanWrappers).join(', '); - this.logger.log("created beans: " + createdBeanNames); }; - // tslint:disable-next-line - Context.prototype.createBeanWrapper = function (Bean) { - var metaData = Bean.__agBeanMetaData; - if (!metaData) { - var beanName = void 0; - if (Bean.prototype.constructor) { - beanName = Bean.prototype.constructor.name; - } - else { - beanName = "" + Bean; - } - console.error("context item " + beanName + " is not a bean"); + ProvidedFilter.prototype.setParams = function (params) { + this.providedFilterParams = params; + this.applyActive = ProvidedFilter.isUseApplyButton(params); + this.createButtonPanel(); + }; + ProvidedFilter.prototype.createButtonPanel = function () { + var _this = this; + var buttons = this.providedFilterParams.buttons; + if (!buttons || buttons.length < 1 || this.isReadOnly()) { return; } - var beanEntry = { - bean: Bean, - beanInstance: null, - beanName: metaData.beanName + var eButtonsPanel = document.createElement('div'); + eButtonsPanel.classList.add('ag-filter-apply-panel'); + var addButton = function (type) { + var text; + var clickListener; + switch (type) { + case 'apply': + text = _this.translate('applyFilter'); + clickListener = function (e) { return _this.onBtApply(false, false, e); }; + break; + case 'clear': + text = _this.translate('clearFilter'); + clickListener = function () { return _this.onBtClear(); }; + break; + case 'reset': + text = _this.translate('resetFilter'); + clickListener = function () { return _this.onBtReset(); }; + break; + case 'cancel': + text = _this.translate('cancelFilter'); + clickListener = function (e) { _this.onBtCancel(e); }; + break; + default: + console.warn('AG Grid: Unknown button type specified'); + return; + } + var button = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["loadTemplate"])( + /* html */ + "" + text + "\n "); + eButtonsPanel.appendChild(button); + _this.addManagedListener(button, 'click', clickListener); }; - this.beanWrappers[metaData.beanName] = beanEntry; + Object(_utils_set__WEBPACK_IMPORTED_MODULE_5__["convertToSet"])(buttons).forEach(function (type) { return addButton(type); }); + this.getGui().appendChild(eButtonsPanel); }; - Context.prototype.autoWireBeans = function (beanInstances) { - var _this = this; - beanInstances.forEach(function (beanInstance) { - _this.forEachMetaDataInHierarchy(beanInstance, function (metaData, beanName) { - var attributes = metaData.agClassAttributes; - if (!attributes) { - return; - } - attributes.forEach(function (attribute) { - var otherBean = _this.lookupBeanInstance(beanName, attribute.beanName, attribute.optional); - beanInstance[attribute.attributeName] = otherBean; - }); - }); - }); + // subclasses can override this to provide alternative debounce defaults + ProvidedFilter.prototype.getDefaultDebounceMs = function () { + return 0; }; - Context.prototype.methodWireBeans = function (beanInstances) { + ProvidedFilter.prototype.setupOnBtApplyDebounce = function () { + var debounceMs = ProvidedFilter.getDebounceMs(this.providedFilterParams, this.getDefaultDebounceMs()); + this.onBtApplyDebounce = Object(_utils_function__WEBPACK_IMPORTED_MODULE_2__["debounce"])(this.onBtApply.bind(this), debounceMs); + }; + ProvidedFilter.prototype.getModel = function () { + return this.appliedModel ? this.appliedModel : null; + }; + ProvidedFilter.prototype.setModel = function (model) { var _this = this; - beanInstances.forEach(function (beanInstance) { - _this.forEachMetaDataInHierarchy(beanInstance, function (metaData, beanName) { - _utils__WEBPACK_IMPORTED_MODULE_0__["_"].iterateObject(metaData.autowireMethods, function (methodName, wireParams) { - // skip constructor, as this is dealt with elsewhere - if (methodName === "agConstructor") { - return; - } - var initParams = _this.getBeansForParameters(wireParams, beanName); - beanInstance[methodName].apply(beanInstance, initParams); - }); - }); + var promise = model != null ? this.setModelIntoUi(model) : this.resetUiToDefaults(); + return promise.then(function () { + _this.updateUiVisibility(); + // we set the model from the GUI, rather than the provided model, + // so the model is consistent, e.g. handling of null/undefined will be the same, + // or if model is case insensitive, then casing is removed. + _this.applyModel(); }); }; - Context.prototype.forEachMetaDataInHierarchy = function (beanInstance, callback) { - var prototype = Object.getPrototypeOf(beanInstance); - while (prototype != null) { - var constructor = prototype.constructor; - if (constructor.hasOwnProperty('__agBeanMetaData')) { - var metaData = constructor.__agBeanMetaData; - var beanName = this.getBeanName(constructor); - callback(metaData, beanName); + ProvidedFilter.prototype.onBtCancel = function (e) { + var _this = this; + var currentModel = this.getModel(); + var afterAppliedFunc = function () { + _this.onUiChanged(false, 'prevent'); + if (_this.providedFilterParams.closeOnApply) { + _this.close(e); } - prototype = Object.getPrototypeOf(prototype); + }; + if (currentModel != null) { + this.setModelIntoUi(currentModel).then(afterAppliedFunc); } - }; - Context.prototype.getBeanName = function (constructor) { - if (constructor.__agBeanMetaData && constructor.__agBeanMetaData.beanName) { - return constructor.__agBeanMetaData.beanName; + else { + this.resetUiToDefaults().then(afterAppliedFunc); } - var constructorString = constructor.toString(); - var beanName = constructorString.substring(9, constructorString.indexOf("(")); - return beanName; }; - Context.prototype.getBeansForParameters = function (parameters, beanName) { + ProvidedFilter.prototype.onBtClear = function () { var _this = this; - var beansList = []; - if (parameters) { - _utils__WEBPACK_IMPORTED_MODULE_0__["_"].iterateObject(parameters, function (paramIndex, otherBeanName) { - var otherBean = _this.lookupBeanInstance(beanName, otherBeanName); - beansList[Number(paramIndex)] = otherBean; - }); - } - return beansList; + this.resetUiToDefaults().then(function () { return _this.onUiChanged(); }); }; - Context.prototype.lookupBeanInstance = function (wiringBean, beanName, optional) { - if (optional === void 0) { optional = false; } - if (beanName === "context") { - return this; - } - else if (this.contextParams.providedBeanInstances && this.contextParams.providedBeanInstances.hasOwnProperty(beanName)) { - return this.contextParams.providedBeanInstances[beanName]; - } - else { - var beanEntry = this.beanWrappers[beanName]; - if (beanEntry) { - return beanEntry.beanInstance; - } - if (!optional) { - console.error("ag-Grid: unable to find bean reference " + beanName + " while initialising " + wiringBean); - } - return null; + ProvidedFilter.prototype.onBtReset = function () { + this.onBtClear(); + this.onBtApply(); + }; + /** + * Applies changes made in the UI to the filter, and returns true if the model has changed. + */ + ProvidedFilter.prototype.applyModel = function () { + var newModel = this.getModelFromUi(); + if (!this.isModelValid(newModel)) { + return false; } + var previousModel = this.appliedModel; + this.appliedModel = newModel; + // models can be same if user pasted same content into text field, or maybe just changed the case + // and it's a case insensitive filter + return !this.areModelsEqual(previousModel, newModel); }; - Context.prototype.callLifeCycleMethods = function (beanInstances, lifeCycleMethod) { - var _this = this; - beanInstances.forEach(function (beanInstance) { - _this.callLifeCycleMethodsOneBean(beanInstance, lifeCycleMethod); - }); + ProvidedFilter.prototype.isModelValid = function (model) { + return true; }; - Context.prototype.callLifeCycleMethodsOneBean = function (beanInstance, lifeCycleMethod, methodToIgnore) { - // putting all methods into a map removes duplicates - var allMethods = {}; - // dump methods from each level of the metadata hierarchy - this.forEachMetaDataInHierarchy(beanInstance, function (metaData) { - var methods = metaData[lifeCycleMethod]; - if (methods) { - methods.forEach(function (methodName) { - if (methodName != methodToIgnore) { - allMethods[methodName] = true; - } - }); - } - }); - var allMethodsList = Object.keys(allMethods); - allMethodsList.forEach(function (methodName) { return beanInstance[methodName](); }); + ProvidedFilter.prototype.onBtApply = function (afterFloatingFilter, afterDataChange, e) { + if (afterFloatingFilter === void 0) { afterFloatingFilter = false; } + if (afterDataChange === void 0) { afterDataChange = false; } + if (this.applyModel()) { + // the floating filter uses 'afterFloatingFilter' info, so it doesn't refresh after filter changed if change + // came from floating filter + this.providedFilterParams.filterChangedCallback({ afterFloatingFilter: afterFloatingFilter, afterDataChange: afterDataChange }); + } + var closeOnApply = this.providedFilterParams.closeOnApply; + // only close if an apply button is visible, otherwise we'd be closing every time a change was made! + if (closeOnApply && this.applyActive && !afterFloatingFilter && !afterDataChange) { + this.close(e); + } }; - Context.prototype.getBean = function (name) { - return this.lookupBeanInstance("getBean", name, true); + ProvidedFilter.prototype.onNewRowsLoaded = function () { }; - Context.prototype.destroy = function () { - // should only be able to destroy once - if (this.destroyed) { + ProvidedFilter.prototype.close = function (e) { + if (!this.hidePopup) { return; } - this.logger.log(">> Shutting down ag-Application Context"); - var beanInstances = this.getBeanInstances(); - this.destroyBeans(beanInstances); - this.contextParams.providedBeanInstances = null; - this.destroyed = true; - this.logger.log(">> ag-Application Context shut down - component is dead"); + var keyboardEvent = e; + var key = keyboardEvent && keyboardEvent.key; + var params; + if (key === 'Enter' || key === 'Space') { + params = { keyboardEvent: keyboardEvent }; + } + this.hidePopup(params); + this.hidePopup = null; }; - Context.prototype.destroyBean = function (bean) { - if (!bean) { - return undefined; + /** + * By default, if the change came from a floating filter it will be applied immediately, otherwise if there is no + * apply button it will be applied after a debounce, otherwise it will not be applied at all. This behaviour can + * be adjusted by using the apply parameter. + */ + ProvidedFilter.prototype.onUiChanged = function (fromFloatingFilter, apply) { + if (fromFloatingFilter === void 0) { fromFloatingFilter = false; } + this.updateUiVisibility(); + this.providedFilterParams.filterModifiedCallback(); + if (this.applyActive && !this.isReadOnly) { + var isValid = this.isModelValid(this.getModelFromUi()); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["setDisabled"])(this.getRefElement('applyFilterButton'), !isValid); + } + if ((fromFloatingFilter && !apply) || apply === 'immediately') { + this.onBtApply(fromFloatingFilter); + } + else if ((!this.applyActive && !apply) || apply === 'debounce') { + this.onBtApplyDebounce(); } - this.destroyBeans([bean]); - return undefined; }; - Context.prototype.destroyBeans = function (beans) { - var _this = this; - if (!beans) { - return []; + ProvidedFilter.prototype.afterGuiAttached = function (params) { + if (params == null) { + return; } - beans.forEach(function (bean) { - _this.callLifeCycleMethodsOneBean(bean, 'preDestroyMethods', 'destroy'); - // call destroy() explicitly if it exists - if (bean.destroy) { - bean.destroy(); + this.hidePopup = params.hidePopup; + }; + // static, as used by floating filter also + ProvidedFilter.getDebounceMs = function (params, debounceDefault) { + if (ProvidedFilter.isUseApplyButton(params)) { + if (params.debounceMs != null) { + console.warn('AG Grid: debounceMs is ignored when apply button is present'); } + return 0; + } + return params.debounceMs != null ? params.debounceMs : debounceDefault; + }; + // static, as used by floating filter also + ProvidedFilter.isUseApplyButton = function (params) { + return !!params.buttons && params.buttons.indexOf('apply') >= 0; + }; + ProvidedFilter.prototype.destroy = function () { + this.hidePopup = null; + _super.prototype.destroy.call(this); + }; + ProvidedFilter.prototype.translate = function (key) { + var translate = this.gridOptionsWrapper.getLocaleTextFunc(); + return translate(key, _filterLocaleText__WEBPACK_IMPORTED_MODULE_3__["DEFAULT_FILTER_LOCALE_TEXT"][key]); + }; + ProvidedFilter.prototype.getCellValue = function (rowNode) { + var _a = this.providedFilterParams, api = _a.api, colDef = _a.colDef, column = _a.column, columnApi = _a.columnApi, context = _a.context; + return this.providedFilterParams.valueGetter({ + api: api, + colDef: colDef, + column: column, + columnApi: columnApi, + context: context, + data: rowNode.data, + getValue: function (field) { return rowNode.data[field]; }, + node: rowNode, }); - return []; }; - return Context; -}()); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel') + ], ProvidedFilter.prototype, "rowModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueService') + ], ProvidedFilter.prototype, "valueService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], ProvidedFilter.prototype, "postConstruct", null); + return ProvidedFilter; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_6__["Component"])); -// taken from: http://stackoverflow.com/questions/3362471/how-can-i-call-a-javascript-constructor-using-call-or-apply -// allows calling 'apply' on a constructor -function applyToConstructor(constructor, argArray) { - var args = [null].concat(argArray); - var factoryFunction = constructor.bind.apply(constructor, args); - return new factoryFunction(); -} -function PreConstruct(target, methodName, descriptor) { - var props = getOrCreateProps(target.constructor); - if (!props.preConstructMethods) { - props.preConstructMethods = []; - } - props.preConstructMethods.push(methodName); -} -function PostConstruct(target, methodName, descriptor) { - var props = getOrCreateProps(target.constructor); - if (!props.postConstructMethods) { - props.postConstructMethods = []; - } - props.postConstructMethods.push(methodName); -} -function PreDestroy(target, methodName, descriptor) { - var props = getOrCreateProps(target.constructor); - if (!props.preDestroyMethods) { - props.preDestroyMethods = []; - } - props.preDestroyMethods.push(methodName); -} -function Bean(beanName) { - return function (classConstructor) { - var props = getOrCreateProps(classConstructor); - props.beanName = beanName; + + +/***/ }), +/* 63 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DEFAULT_FILTER_LOCALE_TEXT", function() { return DEFAULT_FILTER_LOCALE_TEXT; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var DEFAULT_FILTER_LOCALE_TEXT = { + applyFilter: 'Apply', + clearFilter: 'Clear', + resetFilter: 'Reset', + cancelFilter: 'Cancel', + textFilter: 'Text Filter', + numberFilter: 'Number Filter', + dateFilter: 'Date Filter', + setFilter: 'Set Filter', + filterOoo: 'Filter...', + empty: 'Choose One', + equals: 'Equals', + notEqual: 'Not equal', + lessThan: 'Less than', + greaterThan: 'Greater than', + inRange: 'In range', + inRangeStart: 'From', + inRangeEnd: 'To', + lessThanOrEqual: 'Less than or equals', + greaterThanOrEqual: 'Greater than or equals', + contains: 'Contains', + notContains: 'Not contains', + startsWith: 'Starts with', + endsWith: 'Ends with', + blank: 'Blank', + notBlank: 'Not blank', + andCondition: 'AND', + orCondition: 'OR', + dateFormatOoo: 'yyyy-mm-dd', +}; + + +/***/ }), +/* 64 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ManagedFocusFeature", function() { return ManagedFocusFeature; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(65); +/* harmony import */ var _utils_event__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(21); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(20); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; -} -function Autowired(name) { - return function (target, propertyKey, descriptor) { - autowiredFunc(target, name, false, target, propertyKey, null); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; -} -function Optional(name) { - return function (target, propertyKey, descriptor) { - autowiredFunc(target, name, true, target, propertyKey, null); +})(); +var __assign = (undefined && undefined.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; }; -} -function autowiredFunc(target, name, optional, classPrototype, methodOrAttributeName, index) { - if (name === null) { - console.error("ag-Grid: Autowired name should not be null"); - return; - } - if (typeof index === "number") { - console.error("ag-Grid: Autowired should be on an attribute"); - return; - } - // it's an attribute on the class - var props = getOrCreateProps(target.constructor); - if (!props.agClassAttributes) { - props.agClassAttributes = []; + return __assign.apply(this, arguments); +}; +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + +var ManagedFocusFeature = /** @class */ (function (_super) { + __extends(ManagedFocusFeature, _super); + function ManagedFocusFeature(eFocusableElement, callbacks) { + if (callbacks === void 0) { callbacks = {}; } + var _this = _super.call(this) || this; + _this.eFocusableElement = eFocusableElement; + _this.callbacks = callbacks; + _this.callbacks = __assign({ shouldStopEventPropagation: function () { return false; }, onTabKeyDown: function (e) { + if (e.defaultPrevented) { + return; + } + var nextRoot = _this.focusService.findNextFocusableElement(_this.eFocusableElement, false, e.shiftKey); + if (!nextRoot) { + return; + } + nextRoot.focus(); + e.preventDefault(); + } }, callbacks); + return _this; } - props.agClassAttributes.push({ - attributeName: methodOrAttributeName, - beanName: name, - optional: optional - }); -} -function Qualifier(name) { - return function (classPrototype, methodOrAttributeName, index) { - var constructor = typeof classPrototype == "function" ? classPrototype : classPrototype.constructor; - var props; - if (typeof index === "number") { - // it's a parameter on a method - var methodName = void 0; - if (methodOrAttributeName) { - props = getOrCreateProps(constructor); - methodName = methodOrAttributeName; + ManagedFocusFeature.prototype.postConstruct = function () { + this.eFocusableElement.classList.add(ManagedFocusFeature.FOCUS_MANAGED_CLASS); + this.addKeyDownListeners(this.eFocusableElement); + if (this.callbacks.onFocusIn) { + this.addManagedListener(this.eFocusableElement, 'focusin', this.callbacks.onFocusIn); + } + if (this.callbacks.onFocusOut) { + this.addManagedListener(this.eFocusableElement, 'focusout', this.callbacks.onFocusOut); + } + }; + ManagedFocusFeature.prototype.addKeyDownListeners = function (eGui) { + var _this = this; + this.addManagedListener(eGui, 'keydown', function (e) { + if (e.defaultPrevented || Object(_utils_event__WEBPACK_IMPORTED_MODULE_2__["isStopPropagationForAgGrid"])(e)) { + return; } - else { - props = getOrCreateProps(constructor); - methodName = "agConstructor"; + if (_this.callbacks.shouldStopEventPropagation(e)) { + Object(_utils_event__WEBPACK_IMPORTED_MODULE_2__["stopPropagationForAgGrid"])(e); + return; } - if (!props.autowireMethods) { - props.autowireMethods = {}; + if (e.key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].TAB) { + _this.callbacks.onTabKeyDown(e); } - if (!props.autowireMethods[methodName]) { - props.autowireMethods[methodName] = {}; + else if (_this.callbacks.handleKeyDown) { + _this.callbacks.handleKeyDown(e); } - props.autowireMethods[methodName][index] = name; - } + }); }; -} -function getOrCreateProps(target) { - if (!target.hasOwnProperty("__agBeanMetaData")) { - target.__agBeanMetaData = {}; - } - return target.__agBeanMetaData; -} + ManagedFocusFeature.FOCUS_MANAGED_CLASS = 'ag-focus-managed'; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusService') + ], ManagedFocusFeature.prototype, "focusService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], ManagedFocusFeature.prototype, "postConstruct", null); + return ManagedFocusFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"])); + /***/ }), -/* 38 */ +/* 65 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ModuleNames", function() { return ModuleNames; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "KeyCode", function() { return KeyCode; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var ModuleNames; -(function (ModuleNames) { - // when using modules, user references this - ModuleNames["CommunityCoreModule"] = "@ag-grid-community/core"; - // when not using modules, user references this - ModuleNames["CommunityAllModules"] = "@ag-grid-community/all"; - // community modules - ModuleNames["InfiniteRowModelModule"] = "@ag-grid-community/infinite-row-model"; - ModuleNames["ClientSideRowModelModule"] = "@ag-grid-community/client-side-row-model"; - ModuleNames["CsvExportModule"] = "@ag-grid-community/csv-export"; - ModuleNames["RowNodeCache"] = "@ag-grid-community/row-node-cache"; - // enterprise core - users never import on this, but other enterprise modules do - ModuleNames["EnterpriseCoreModule"] = "@ag-grid-enterprise/core"; - // when not using modules, user references this - ModuleNames["EnterpriseAllModules"] = "@ag-grid-enterprise/all"; - // enterprise modules - ModuleNames["RowGroupingModule"] = "@ag-grid-enterprise/row-grouping"; - ModuleNames["ColumnToolPanelModule"] = "@ag-grid-enterprise/column-tool-panel"; - ModuleNames["FiltersToolPanelModule"] = "@ag-grid-enterprise/filters-tool-panel"; - ModuleNames["MenuModule"] = "@ag-grid-enterprise/menu"; - ModuleNames["SetFilterModule"] = "@ag-grid-enterprise/set-filter"; - ModuleNames["StatusBarModule"] = "@ag-grid-enterprise/status-bar"; - ModuleNames["SideBarModule"] = "@ag-grid-enterprise/side-bar"; - ModuleNames["RangeSelectionModule"] = "@ag-grid-enterprise/range-selection"; - ModuleNames["MasterDetailModule"] = "@ag-grid-enterprise/master-detail"; - ModuleNames["RichSelectModule"] = "@ag-grid-enterprise/rich-select"; - ModuleNames["GridChartsModule"] = "@ag-grid-enterprise/charts"; - ModuleNames["ViewportRowModelModule"] = "@ag-grid-enterprise/viewport-row-model"; - ModuleNames["ServerSideRowModelModule"] = "@ag-grid-enterprise/server-side-row-model"; - ModuleNames["ExcelExportModule"] = "@ag-grid-enterprise/excel-export"; - ModuleNames["ClipboardModule"] = "@ag-grid-enterprise/clipboard"; - ModuleNames["DateTimeCellEditorModule"] = "@ag-grid-enterprise/date-time-cell-editor"; - // framework wrappers currently don't provide beans, comps etc, so no need to be modules, - // however i argue they should be as in theory they 'could' provide beans etc - ModuleNames["AngularModule"] = "@ag-grid-community/angular"; - ModuleNames["ReactModule"] = "@ag-grid-community/react"; - ModuleNames["VueModule"] = "@ag-grid-community/vue"; - ModuleNames["PolymerModule"] = "@ag-grid-community/polymer"; - // and then this, which is definitely not a grid module, as it should not have any dependency - // on the grid (ie shouldn't even reference the Module interface) - // ChartsModule = "@ag-grid-community/charts-core", -})(ModuleNames || (ModuleNames = {})); +var KeyCode = /** @class */ (function () { + function KeyCode() { + } + KeyCode.BACKSPACE = 'Backspace'; + KeyCode.TAB = 'Tab'; + KeyCode.ENTER = 'Enter'; + KeyCode.ESCAPE = 'Escape'; + KeyCode.SPACE = ' '; + KeyCode.LEFT = 'ArrowLeft'; + KeyCode.UP = 'ArrowUp'; + KeyCode.RIGHT = 'ArrowRight'; + KeyCode.DOWN = 'ArrowDown'; + KeyCode.DELETE = 'Delete'; + KeyCode.A = 'A'; + KeyCode.C = 'C'; + KeyCode.V = 'V'; + KeyCode.D = 'D'; + KeyCode.Z = 'Z'; + KeyCode.Y = 'Y'; + KeyCode.F2 = 'F2'; + KeyCode.PAGE_UP = 'PageUp'; + KeyCode.PAGE_DOWN = 'PageDown'; + KeyCode.PAGE_HOME = 'Home'; + KeyCode.PAGE_END = 'End'; + return KeyCode; +}()); + /***/ }), -/* 39 */ +/* 66 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ModuleRegistry", function() { return ModuleRegistry; }); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgSelect", function() { return AgSelect; }); +/* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(67); +/* harmony import */ var _agPickerField__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(69); +/* harmony import */ var _agList__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(70); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(12); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(42); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(44); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; -var ModuleRegistry = /** @class */ (function () { - function ModuleRegistry() { + + + + + +var AgSelect = /** @class */ (function (_super) { + __extends(AgSelect, _super); + function AgSelect(config) { + return _super.call(this, config, 'ag-select', 'smallDown', 'listbox') || this; } - ModuleRegistry.register = function (module, moduleBased) { - if (moduleBased === void 0) { moduleBased = true; } - ModuleRegistry.modulesMap[module.moduleName] = module; - if (ModuleRegistry.moduleBased === undefined) { - ModuleRegistry.moduleBased = moduleBased; - } - else { - if (ModuleRegistry.moduleBased !== moduleBased) { - _utils__WEBPACK_IMPORTED_MODULE_0__["_"].doOnce(function () { - console.warn("ag-Grid: You are mixing modules (i.e. @ag-grid-community/core) and packages (ag-grid-community) - you can only use one or the other of these mechanisms."); - console.warn('Please see https://www.ag-grid.com/javascript-grid-packages-modules/ for more information.'); - }, 'ModulePackageCheck'); + AgSelect.prototype.init = function () { + var _this = this; + this.listComponent = this.createBean(new _agList__WEBPACK_IMPORTED_MODULE_2__["AgList"]('select')); + this.listComponent.setParentComponent(this); + this.eWrapper.tabIndex = 0; + this.listComponent.addManagedListener(this.listComponent, _agList__WEBPACK_IMPORTED_MODULE_2__["AgList"].EVENT_ITEM_SELECTED, function () { if (_this.hideList) { + _this.hideList(); + } }); + this.listComponent.addManagedListener(this.listComponent, _agAbstractField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractField"].EVENT_CHANGED, function () { + _this.setValue(_this.listComponent.getValue(), false, true); + if (_this.hideList) { + _this.hideList(); } - } + }); }; - // noinspection JSUnusedGlobalSymbols - ModuleRegistry.registerModules = function (modules, moduleBased) { - if (moduleBased === void 0) { moduleBased = true; } - if (!modules) { - return; + AgSelect.prototype.showPicker = function () { + var _this = this; + var listGui = this.listComponent.getGui(); + var eDocument = this.gridOptionsWrapper.getDocument(); + var destroyMouseWheelFunc = this.addManagedListener(eDocument.body, 'wheel', function (e) { + if (!listGui.contains(e.target) && _this.hideList) { + _this.hideList(); + } + }); + var destroyFocusOutFunc = this.addManagedListener(listGui, 'focusout', function (e) { + if (!listGui.contains(e.relatedTarget) && _this.hideList) { + _this.hideList(); + } + }); + var translate = this.gridOptionsWrapper.getLocaleTextFunc(); + var addPopupRes = this.popupService.addPopup({ + modal: true, + eChild: listGui, + closeOnEsc: true, + closedCallback: function () { + _this.hideList = null; + _this.isPickerDisplayed = false; + destroyFocusOutFunc(); + destroyMouseWheelFunc(); + if (_this.isAlive()) { + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_5__["setAriaExpanded"])(_this.eWrapper, false); + _this.getFocusableElement().focus(); + } + }, + ariaLabel: translate('ariaLabelSelectField', 'Select Field') + }); + if (addPopupRes) { + this.hideList = addPopupRes.hideFunc; } - modules.forEach(function (module) { return ModuleRegistry.register(module, moduleBased); }); + this.isPickerDisplayed = true; + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setElementWidth"])(listGui, Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["getAbsoluteWidth"])(this.eWrapper)); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_5__["setAriaExpanded"])(this.eWrapper, true); + listGui.style.maxHeight = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["getInnerHeight"])(this.popupService.getPopupParent()) + 'px'; + listGui.style.position = 'absolute'; + this.popupService.positionPopupUnderComponent({ + type: 'ag-list', + eventSource: this.eWrapper, + ePopup: listGui, + keepWithinBounds: true + }); + this.listComponent.refreshHighlighted(); + return this.listComponent; }; - ModuleRegistry.assertRegistered = function (moduleName, reason) { - if (this.isRegistered(moduleName)) { - return true; - } - var warningKey = reason + moduleName; - var warningMessage = "ag-Grid: unable to use " + reason + " as module " + moduleName + " is not present. Please see: https://www.ag-grid.com/javascript-grid-modules/"; - _utils__WEBPACK_IMPORTED_MODULE_0__["_"].doOnce(function () { - console.warn(warningMessage); - }, warningKey); - return false; + AgSelect.prototype.addOptions = function (options) { + var _this = this; + options.forEach(function (option) { return _this.addOption(option); }); + return this; }; - ModuleRegistry.isRegistered = function (moduleName) { - return !!ModuleRegistry.modulesMap[moduleName]; + AgSelect.prototype.addOption = function (option) { + this.listComponent.addOption(option); + return this; }; - ModuleRegistry.getRegisteredModules = function () { - return _utils__WEBPACK_IMPORTED_MODULE_0__["_"].values(ModuleRegistry.modulesMap); + AgSelect.prototype.setValue = function (value, silent, fromPicker) { + if (this.value === value) { + return this; + } + if (!fromPicker) { + this.listComponent.setValue(value, true); + } + var newValue = this.listComponent.getValue(); + if (newValue === this.getValue()) { + return this; + } + this.eDisplayField.innerHTML = this.listComponent.getDisplayValue(); + return _super.prototype.setValue.call(this, value, silent); }; - ModuleRegistry.isPackageBased = function () { - return !ModuleRegistry.moduleBased; + AgSelect.prototype.destroy = function () { + if (this.hideList) { + this.hideList(); + } + this.destroyBean(this.listComponent); + _super.prototype.destroy.call(this); }; - // having in a map a) removes duplicates and b) allows fast lookup - ModuleRegistry.modulesMap = {}; - return ModuleRegistry; -}()); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('popupService') + ], AgSelect.prototype, "popupService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"] + ], AgSelect.prototype, "init", null); + return AgSelect; +}(_agPickerField__WEBPACK_IMPORTED_MODULE_1__["AgPickerField"])); /***/ }), -/* 40 */ +/* 67 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DefaultColumnTypes", function() { return DefaultColumnTypes; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgAbstractField", function() { return AgAbstractField; }); +/* harmony import */ var _agAbstractLabel__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(68); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(42); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var DefaultColumnTypes = { - numericColumn: { - headerClass: 'ag-right-aligned-header', - cellClass: 'ag-right-aligned-cell' - }, - rightAligned: { - headerClass: 'ag-right-aligned-header', - cellClass: 'ag-right-aligned-cell' +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); + + +var AgAbstractField = /** @class */ (function (_super) { + __extends(AgAbstractField, _super); + function AgAbstractField(config, template, className) { + var _this = _super.call(this, config, template) || this; + _this.className = className; + _this.disabled = false; + return _this; } -}; + AgAbstractField.prototype.postConstruct = function () { + _super.prototype.postConstruct.call(this); + if (this.className) { + this.addCssClass(this.className); + } + }; + AgAbstractField.prototype.onValueChange = function (callbackFn) { + var _this = this; + this.addManagedListener(this, AgAbstractField.EVENT_CHANGED, function () { return callbackFn(_this.getValue()); }); + return this; + }; + AgAbstractField.prototype.getWidth = function () { + return this.getGui().clientWidth; + }; + AgAbstractField.prototype.setWidth = function (width) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["setFixedWidth"])(this.getGui(), width); + return this; + }; + AgAbstractField.prototype.getPreviousValue = function () { + return this.previousValue; + }; + AgAbstractField.prototype.getValue = function () { + return this.value; + }; + AgAbstractField.prototype.setValue = function (value, silent) { + if (this.value === value) { + return this; + } + this.previousValue = this.value; + this.value = value; + if (!silent) { + this.dispatchEvent({ type: AgAbstractField.EVENT_CHANGED }); + } + return this; + }; + AgAbstractField.prototype.setDisabled = function (disabled) { + disabled = !!disabled; + var element = this.getGui(); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["setDisabled"])(element, disabled); + element.classList.toggle('ag-disabled', disabled); + this.disabled = disabled; + return this; + }; + AgAbstractField.prototype.isDisabled = function () { + return !!this.disabled; + }; + AgAbstractField.EVENT_CHANGED = 'valueChange'; + return AgAbstractField; +}(_agAbstractLabel__WEBPACK_IMPORTED_MODULE_0__["AgAbstractLabel"])); + /***/ }), -/* 41 */ +/* 68 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BeanStub", function() { return BeanStub; }); -/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); -/* harmony import */ var _context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgAbstractLabel", function() { return AgAbstractLabel; }); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(42); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(44); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); @@ -6596,146 +14373,115 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var BeanStub = /** @class */ (function () { - function BeanStub() { - var _this = this; - this.destroyFunctions = []; - this.destroyed = false; - this.getContext = function () { return _this.context; }; - this.isAlive = function () { return !_this.destroyed; }; + +var AgAbstractLabel = /** @class */ (function (_super) { + __extends(AgAbstractLabel, _super); + function AgAbstractLabel(config, template) { + var _this = _super.call(this, template) || this; + _this.labelSeparator = ''; + _this.labelAlignment = 'left'; + _this.label = ''; + _this.config = config || {}; + return _this; } - // this was a test constructor niall built, when active, it prints after 5 seconds all beans/components that are - // not destroyed. to use, create a new grid, then api.destroy() before 5 seconds. then anything that gets printed - // points to a bean or component that was not properly disposed of. - // constructor() { - // setTimeout(()=> { - // if (this.isAlive()) { - // let prototype: any = Object.getPrototypeOf(this); - // const constructor: any = prototype.constructor; - // const constructorString = constructor.toString(); - // const beanName = constructorString.substring(9, constructorString.indexOf("(")); - // console.log('is alive ' + beanName); - // } - // }, 5000); - // } - // CellComp and GridComp and override this because they get the FrameworkOverrides from the Beans bean - BeanStub.prototype.getFrameworkOverrides = function () { - return this.frameworkOverrides; - }; - BeanStub.prototype.destroy = function () { - // let prototype: any = Object.getPrototypeOf(this); - // const constructor: any = prototype.constructor; - // const constructorString = constructor.toString(); - // const beanName = constructorString.substring(9, constructorString.indexOf("(")); - this.destroyFunctions.forEach(function (func) { return func(); }); - this.destroyFunctions.length = 0; - this.destroyed = true; - this.dispatchEvent({ type: BeanStub.EVENT_DESTROYED }); - }; - BeanStub.prototype.addEventListener = function (eventType, listener) { - if (!this.localEventService) { - this.localEventService = new _eventService__WEBPACK_IMPORTED_MODULE_0__["EventService"](); + AgAbstractLabel.prototype.postConstruct = function () { + this.addCssClass('ag-labeled'); + this.eLabel.classList.add('ag-label'); + var _a = this.config, labelSeparator = _a.labelSeparator, label = _a.label, labelWidth = _a.labelWidth, labelAlignment = _a.labelAlignment; + if (labelSeparator != null) { + this.setLabelSeparator(labelSeparator); } - this.localEventService.addEventListener(eventType, listener); - }; - BeanStub.prototype.removeEventListener = function (eventType, listener) { - if (this.localEventService) { - this.localEventService.removeEventListener(eventType, listener); + if (label != null) { + this.setLabel(label); } - }; - BeanStub.prototype.dispatchEventAsync = function (event) { - var _this = this; - window.setTimeout(function () { return _this.dispatchEvent(event); }, 0); - }; - BeanStub.prototype.dispatchEvent = function (event) { - if (this.localEventService) { - this.localEventService.dispatchEvent(event); + if (labelWidth != null) { + this.setLabelWidth(labelWidth); } + this.setLabelAlignment(labelAlignment || this.labelAlignment); + this.refreshLabel(); }; - BeanStub.prototype.addManagedListener = function (object, event, listener) { - var _this = this; - if (this.destroyed) { - return; + AgAbstractLabel.prototype.refreshLabel = function () { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["clearElement"])(this.eLabel); + if (typeof this.label === 'string') { + this.eLabel.innerText = this.label + this.labelSeparator; } - if (object instanceof HTMLElement) { - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addSafePassiveEventListener(this.getFrameworkOverrides(), object, event, listener); + else if (this.label) { + this.eLabel.appendChild(this.label); + } + if (this.label === '') { + this.eLabel.classList.add('ag-hidden'); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_3__["setAriaRole"])(this.eLabel, 'presentation'); } else { - object.addEventListener(event, listener); + this.eLabel.classList.remove('ag-hidden'); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_3__["setAriaRole"])(this.eLabel, null); } - var destroyFunc = function () { - object.removeEventListener(event, listener); - _this.destroyFunctions = _this.destroyFunctions.filter(function (fn) { return fn !== destroyFunc; }); - return null; - }; - this.destroyFunctions.push(destroyFunc); - return destroyFunc; }; - BeanStub.prototype.addDestroyFunc = function (func) { - // if we are already destroyed, we execute the func now - if (this.isAlive()) { - this.destroyFunctions.push(func); + AgAbstractLabel.prototype.setLabelSeparator = function (labelSeparator) { + if (this.labelSeparator === labelSeparator) { + return this; } - else { - func(); + this.labelSeparator = labelSeparator; + if (this.label != null) { + this.refreshLabel(); } + return this; }; - BeanStub.prototype.createManagedBean = function (bean, context) { - var res = this.createBean(bean, context); - this.addDestroyFunc(this.destroyBean.bind(this, bean, context)); - return res; + AgAbstractLabel.prototype.getLabelId = function () { + this.eLabel.id = this.eLabel.id || "ag-" + this.getCompId() + "-label"; + return this.eLabel.id; }; - BeanStub.prototype.createBean = function (bean, context, afterPreCreateCallback) { - return (context || this.getContext()).createBean(bean, afterPreCreateCallback); + AgAbstractLabel.prototype.getLabel = function () { + return this.label; }; - BeanStub.prototype.destroyBean = function (bean, context) { - return (context || this.getContext()).destroyBean(bean); + AgAbstractLabel.prototype.setLabel = function (label) { + if (this.label === label) { + return this; + } + this.label = label; + this.refreshLabel(); + return this; }; - BeanStub.prototype.destroyBeans = function (beans, context) { - var _this = this; - if (beans) { - beans.forEach(function (bean) { return _this.destroyBean(bean, context); }); + AgAbstractLabel.prototype.setLabelAlignment = function (alignment) { + var eGui = this.getGui(); + var eGuiClassList = eGui.classList; + eGuiClassList.toggle('ag-label-align-left', alignment === 'left'); + eGuiClassList.toggle('ag-label-align-right', alignment === 'right'); + eGuiClassList.toggle('ag-label-align-top', alignment === 'top'); + return this; + }; + AgAbstractLabel.prototype.setLabelWidth = function (width) { + if (this.label == null) { + return this; } - return []; + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["setElementWidth"])(this.eLabel, width); + return this; }; - BeanStub.EVENT_DESTROYED = 'destroyed'; - __decorate([ - Object(_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('frameworkOverrides') - ], BeanStub.prototype, "frameworkOverrides", void 0); - __decorate([ - Object(_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('context') - ], BeanStub.prototype, "context", void 0); - __decorate([ - Object(_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('eventService') - ], BeanStub.prototype, "eventService", void 0); __decorate([ - _context__WEBPACK_IMPORTED_MODULE_1__["PreDestroy"] - ], BeanStub.prototype, "destroy", null); - return BeanStub; -}()); + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], AgAbstractLabel.prototype, "postConstruct", null); + return AgAbstractLabel; +}(_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); /***/ }), -/* 42 */ +/* 69 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnController", function() { return ColumnController; }); -/* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(34); -/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(35); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41); -/* harmony import */ var _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(33); -/* harmony import */ var _groupInstanceIdCreator__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(45); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(37); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(25); -/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(17); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgPickerField", function() { return AgPickerField; }); +/* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(67); +/* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(44); +/* harmony import */ var _utils_icon__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(48); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(42); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(65); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -6758,12 +14504,6 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; -var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { - return function (target, key) { decorator(target, key, paramIndex); } -}; - - - @@ -6771,2913 +14511,2402 @@ var __param = (undefined && undefined.__param) || function (paramIndex, decorato -var ColumnController = /** @class */ (function (_super) { - __extends(ColumnController, _super); - function ColumnController() { - var _this = _super !== null && _super.apply(this, arguments) || this; - // header row count, based on user provided columns - _this.primaryHeaderRowCount = 0; - _this.secondaryHeaderRowCount = 0; - _this.secondaryColumnsPresent = false; - // header row count, either above, or based on pivoting if we are pivoting - _this.gridHeaderRowCount = 0; - // these are the lists used by the rowRenderer to render nodes. almost the leaf nodes of the above - // displayed trees, however it also takes into account if the groups are open or not. - _this.displayedLeftColumns = []; - _this.displayedRightColumns = []; - _this.displayedCenterColumns = []; - // all three lists above combined - _this.allDisplayedColumns = []; - // same as above, except trimmed down to only columns within the viewport - _this.allDisplayedVirtualColumns = []; - _this.allDisplayedCenterVirtualColumns = []; - _this.rowGroupColumns = []; - _this.valueColumns = []; - _this.pivotColumns = []; - _this.ready = false; - _this.autoGroupsNeedBuilding = false; - _this.forceRecreateAutoGroups = false; - _this.pivotMode = false; - _this.bodyWidth = 0; - _this.leftWidth = 0; - _this.rightWidth = 0; - _this.bodyWidthDirty = true; - _this.flexActive = false; +var AgPickerField = /** @class */ (function (_super) { + __extends(AgPickerField, _super); + function AgPickerField(config, className, pickerIcon, ariaRole) { + var _this = _super.call(this, config, + /* html */ "
\n
\n
\n
\n
\n
\n
", className) || this; + _this.pickerIcon = pickerIcon; + _this.isPickerDisplayed = false; + _this.isDestroyingPicker = false; + _this.skipClick = false; return _this; - } - ColumnController.prototype.init = function () { - this.suppressColumnVirtualisation = this.gridOptionsWrapper.isSuppressColumnVirtualisation(); - var pivotMode = this.gridOptionsWrapper.isPivotMode(); - if (this.isPivotSettingAllowed(pivotMode)) { - this.pivotMode = pivotMode; - } - this.usingTreeData = this.gridOptionsWrapper.isTreeData(); - this.addManagedListener(this.gridOptionsWrapper, 'autoGroupColumnDef', this.onAutoGroupColumnDefChanged.bind(this)); - }; - ColumnController.prototype.onAutoGroupColumnDefChanged = function () { - this.autoGroupsNeedBuilding = true; - this.forceRecreateAutoGroups = true; - this.updateGridColumns(); - this.updateDisplayedColumns('gridOptionsChanged'); - }; - ColumnController.prototype.setColumnDefs = function (columnDefs, source) { - if (source === void 0) { source = 'api'; } - var colsPreviouslyExisted = !!this.columnDefs; - this.columnDefs = columnDefs; - // always invalidate cache on changing columns, as the column id's for the new columns - // could overlap with the old id's, so the cache would return old values for new columns. - this.valueCache.expire(); - // NOTE ================== - // we should be destroying the existing columns and groups if they exist, for example, the original column - // group adds a listener to the columns, it should be also removing the listeners - this.autoGroupsNeedBuilding = true; - var oldPrimaryColumns = this.primaryColumns; - var balancedTreeResult = this.columnFactory.createColumnTree(columnDefs, true, oldPrimaryColumns); - this.primaryColumnTree = balancedTreeResult.columnTree; - this.primaryHeaderRowCount = balancedTreeResult.treeDept + 1; - this.primaryColumns = this.getColumnsFromTree(this.primaryColumnTree); - this.extractRowGroupColumns(source, oldPrimaryColumns); - this.extractPivotColumns(source, oldPrimaryColumns); - this.createValueColumns(source, oldPrimaryColumns); - this.ready = true; - this.updateGridColumns(); - this.updateDisplayedColumns(source); - this.checkDisplayedVirtualColumns(); - if (this.gridOptionsWrapper.isImmutableColumns() && colsPreviouslyExisted) { - this.resetColumnState(true, source); - } - var eventEverythingChanged = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_EVERYTHING_CHANGED, - api: this.gridApi, - columnApi: this.columnApi, - source: source - }; - this.eventService.dispatchEvent(eventEverythingChanged); - var newColumnsLoadedEvent = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_NEW_COLUMNS_LOADED, - api: this.gridApi, - columnApi: this.columnApi - }; - this.eventService.dispatchEvent(newColumnsLoadedEvent); - this.flexActive = this.getDisplayedCenterColumns().some(function (col) { return !!col.getFlex(); }); - }; - ColumnController.prototype.isAutoRowHeightActive = function () { - return this.autoRowHeightColumns && this.autoRowHeightColumns.length > 0; - }; - ColumnController.prototype.getAllAutoRowHeightCols = function () { - return this.autoRowHeightColumns; - }; - ColumnController.prototype.setVirtualViewportLeftAndRight = function () { - if (this.gridOptionsWrapper.isEnableRtl()) { - this.viewportLeft = this.bodyWidth - this.scrollPosition - this.scrollWidth; - this.viewportRight = this.bodyWidth - this.scrollPosition; - } - else { - this.viewportLeft = this.scrollPosition; - this.viewportRight = this.scrollWidth + this.scrollPosition; - } - }; - // used by clipboard service, to know what columns to paste into - ColumnController.prototype.getDisplayedColumnsStartingAt = function (column) { - var currentColumn = column; - var columns = []; - while (currentColumn != null) { - columns.push(currentColumn); - currentColumn = this.getDisplayedColAfter(currentColumn); - } - return columns; - }; - // checks what columns are currently displayed due to column virtualisation. fires an event - // if the list of columns has changed. - // + setColumnWidth(), setVirtualViewportPosition(), setColumnDefs(), sizeColumnsToFit() - ColumnController.prototype.checkDisplayedVirtualColumns = function () { - // check displayCenterColumnTree exists first, as it won't exist when grid is initialising - if (this.displayedCenterColumns == null) { - return; - } - var hashBefore = this.allDisplayedVirtualColumns.map(function (column) { return column.getId(); }).join('#'); - this.updateVirtualSets(); - var hashAfter = this.allDisplayedVirtualColumns.map(function (column) { return column.getId(); }).join('#'); - if (hashBefore !== hashAfter) { - var event_1 = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_VIRTUAL_COLUMNS_CHANGED, - api: this.gridApi, - columnApi: this.columnApi - }; - this.eventService.dispatchEvent(event_1); - } - }; - ColumnController.prototype.setVirtualViewportPosition = function (scrollWidth, scrollPosition) { - if (scrollWidth !== this.scrollWidth || scrollPosition !== this.scrollPosition || this.bodyWidthDirty) { - this.scrollWidth = scrollWidth; - this.scrollPosition = scrollPosition; - // we need to call setVirtualViewportLeftAndRight() at least once after the body width changes, - // as the viewport can stay the same, but in RTL, if body width changes, we need to work out the - // virtual columns again - this.bodyWidthDirty = true; - this.setVirtualViewportLeftAndRight(); - if (this.ready) { - this.checkDisplayedVirtualColumns(); - } - } - }; - ColumnController.prototype.isPivotMode = function () { - return this.pivotMode; - }; - ColumnController.prototype.isPivotSettingAllowed = function (pivot) { - if (pivot && this.gridOptionsWrapper.isTreeData()) { - console.warn("ag-Grid: Pivot mode not available in conjunction Tree Data i.e. 'gridOptions.treeData: true'"); - return false; - } - return true; - }; - ColumnController.prototype.setPivotMode = function (pivotMode, source) { - if (source === void 0) { source = 'api'; } - if (pivotMode === this.pivotMode || !this.isPivotSettingAllowed(this.pivotMode)) { - return; - } - this.pivotMode = pivotMode; - // we need to update grid columns to cover the scenario where user has groupSuppressAutoColumn=true, as - // this means we don't use auto group column UNLESS we are in pivot mode (it's mandatory in pivot mode), - // so need to updateGridColumn() to check it autoGroupCol needs to be added / removed - this.autoGroupsNeedBuilding = true; - this.updateGridColumns(); - this.updateDisplayedColumns(source); - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_MODE_CHANGED, - api: this.gridApi, - columnApi: this.columnApi - }; - this.eventService.dispatchEvent(event); - }; - ColumnController.prototype.getSecondaryPivotColumn = function (pivotKeys, valueColKey) { - if (!this.secondaryColumnsPresent || !this.secondaryColumns) { - return null; - } - var valueColumnToFind = this.getPrimaryColumn(valueColKey); - var foundColumn = null; - this.secondaryColumns.forEach(function (column) { - var thisPivotKeys = column.getColDef().pivotKeys; - var pivotValueColumn = column.getColDef().pivotValueColumn; - var pivotKeyMatches = Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["areEqual"])(thisPivotKeys, pivotKeys); - var pivotValueMatches = pivotValueColumn === valueColumnToFind; - if (pivotKeyMatches && pivotValueMatches) { - foundColumn = column; - } - }); - return foundColumn; - }; - ColumnController.prototype.setBeans = function (loggerFactory) { - this.logger = loggerFactory.create('ColumnController'); - }; - ColumnController.prototype.setFirstRightAndLastLeftPinned = function (source) { - var lastLeft; - var firstRight; - if (this.gridOptionsWrapper.isEnableRtl()) { - lastLeft = this.displayedLeftColumns ? this.displayedLeftColumns[0] : null; - firstRight = this.displayedRightColumns ? _utils__WEBPACK_IMPORTED_MODULE_9__["_"].last(this.displayedRightColumns) : null; - } - else { - lastLeft = this.displayedLeftColumns ? _utils__WEBPACK_IMPORTED_MODULE_9__["_"].last(this.displayedLeftColumns) : null; - firstRight = this.displayedRightColumns ? this.displayedRightColumns[0] : null; - } - this.gridColumns.forEach(function (column) { - column.setLastLeftPinned(column === lastLeft, source); - column.setFirstRightPinned(column === firstRight, source); - }); - }; - ColumnController.prototype.autoSizeColumns = function (keys, skipHeader, source) { - // because of column virtualisation, we can only do this function on columns that are - // actually rendered, as non-rendered columns (outside the viewport and not rendered - // due to column virtualisation) are not present. this can result in all rendered columns - // getting narrowed, which in turn introduces more rendered columns on the RHS which - // did not get autosized in the original run, leaving the visible grid with columns on - // the LHS sized, but RHS no. so we keep looping through the visible columns until - // no more cols are available (rendered) to be resized - var _this = this; - if (source === void 0) { source = "api"; } - // we autosize after animation frames finish in case any cell renderers need to complete first. this can - // happen eg if client code is calling api.autoSizeAllColumns() straight after grid is initialised, but grid - // hasn't fully drawn out all the cells yet (due to cell renderers in animation frames). - this.animationFrameService.flushAllFrames(); - // keep track of which cols we have resized in here - var columnsAutosized = []; - // initialise with anything except 0 so that while loop executes at least once - var changesThisTimeAround = -1; - if (skipHeader == null) { - skipHeader = this.gridOptionsWrapper.isSkipHeaderOnAutoSize(); - } - while (changesThisTimeAround !== 0) { - changesThisTimeAround = 0; - this.actionOnGridColumns(keys, function (column) { - // if already autosized, skip it - if (columnsAutosized.indexOf(column) >= 0) { - return false; - } - // get how wide this col should be - var preferredWidth = _this.autoWidthCalculator.getPreferredWidthForColumn(column, skipHeader); - // preferredWidth = -1 if this col is not on the screen - if (preferredWidth > 0) { - var newWidth = _this.normaliseColumnWidth(column, preferredWidth); - column.setActualWidth(newWidth, source); - columnsAutosized.push(column); - changesThisTimeAround++; - } - return true; - }, source); - } - if (columnsAutosized.length) { - var event_2 = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_RESIZED, - columns: columnsAutosized, - column: columnsAutosized.length === 1 ? columnsAutosized[0] : null, - finished: true, - api: this.gridApi, - columnApi: this.columnApi, - source: "autosizeColumns" - }; - this.eventService.dispatchEvent(event_2); - } - }; - ColumnController.prototype.autoSizeColumn = function (key, skipHeader, source) { - if (source === void 0) { source = "api"; } - if (key) { - this.autoSizeColumns([key], skipHeader, source); - } - }; - ColumnController.prototype.autoSizeAllColumns = function (skipHeader, source) { - if (source === void 0) { source = "api"; } - var allDisplayedColumns = this.getAllDisplayedColumns(); - this.autoSizeColumns(allDisplayedColumns, skipHeader, source); - }; - ColumnController.prototype.getColumnsFromTree = function (rootColumns) { - var result = []; - var recursiveFindColumns = function (childColumns) { - for (var i = 0; i < childColumns.length; i++) { - var child = childColumns[i]; - if (child instanceof _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"]) { - result.push(child); - } - else if (child instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"]) { - recursiveFindColumns(child.getChildren()); - } - } - }; - recursiveFindColumns(rootColumns); - return result; - }; - ColumnController.prototype.getAllDisplayedColumnGroups = function () { - if (this.displayedLeftColumnTree && this.displayedRightColumnTree && this.displayedCentreColumnTree) { - return this.displayedLeftColumnTree - .concat(this.displayedCentreColumnTree) - .concat(this.displayedRightColumnTree); - } - return null; - }; - // + columnSelectPanel - ColumnController.prototype.getPrimaryColumnTree = function () { - return this.primaryColumnTree; - }; - // + gridPanel -> for resizing the body and setting top margin - ColumnController.prototype.getHeaderRowCount = function () { - return this.gridHeaderRowCount; - }; - // + headerRenderer -> setting pinned body width - ColumnController.prototype.getLeftDisplayedColumnGroups = function () { - return this.displayedLeftColumnTree; - }; - // + headerRenderer -> setting pinned body width - ColumnController.prototype.getRightDisplayedColumnGroups = function () { - return this.displayedRightColumnTree; - }; - // + headerRenderer -> setting pinned body width - ColumnController.prototype.getCenterDisplayedColumnGroups = function () { - return this.displayedCentreColumnTree; - }; - ColumnController.prototype.getDisplayedColumnGroups = function (type) { - switch (type) { - case _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT: - return this.getLeftDisplayedColumnGroups(); - case _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT: - return this.getRightDisplayedColumnGroups(); - default: - return this.getCenterDisplayedColumnGroups(); - } - }; - // gridPanel -> ensureColumnVisible - ColumnController.prototype.isColumnDisplayed = function (column) { - return this.getAllDisplayedColumns().indexOf(column) >= 0; - }; - // + csvCreator - ColumnController.prototype.getAllDisplayedColumns = function () { - return this.allDisplayedColumns; - }; - ColumnController.prototype.getAllDisplayedVirtualColumns = function () { - return this.allDisplayedVirtualColumns; - }; - ColumnController.prototype.getDisplayedLeftColumnsForRow = function (rowNode) { - if (!this.colSpanActive) { - return this.displayedLeftColumns; - } - return this.getDisplayedColumnsForRow(rowNode, this.displayedLeftColumns); - }; - ColumnController.prototype.getDisplayedRightColumnsForRow = function (rowNode) { - if (!this.colSpanActive) { - return this.displayedRightColumns; - } - return this.getDisplayedColumnsForRow(rowNode, this.displayedRightColumns); - }; - ColumnController.prototype.getDisplayedColumnsForRow = function (rowNode, displayedColumns, filterCallback, emptySpaceBeforeColumn) { - var result = []; - var lastConsideredCol = null; - var _loop_1 = function (i) { - var col = displayedColumns[i]; - var maxAllowedColSpan = displayedColumns.length - i; - var colSpan = Math.min(col.getColSpan(rowNode), maxAllowedColSpan); - var columnsToCheckFilter = [col]; - if (colSpan > 1) { - var colsToRemove = colSpan - 1; - for (var j = 1; j <= colsToRemove; j++) { - columnsToCheckFilter.push(displayedColumns[i + j]); - } - i += colsToRemove; - } - // see which cols we should take out for column virtualisation - var filterPasses; - if (filterCallback) { - // if user provided a callback, means some columns may not be in the viewport. - // the user will NOT provide a callback if we are talking about pinned areas, - // as pinned areas have no horizontal scroll and do not virtualise the columns. - // if lots of columns, that means column spanning, and we set filterPasses = true - // if one or more of the columns spanned pass the filter. - filterPasses = false; - columnsToCheckFilter.forEach(function (colForFilter) { - if (filterCallback(colForFilter)) { - filterPasses = true; - } - }); - } - else { - filterPasses = true; - } - if (filterPasses) { - if (result.length === 0 && lastConsideredCol) { - var gapBeforeColumn = emptySpaceBeforeColumn ? emptySpaceBeforeColumn(col) : false; - if (gapBeforeColumn) { - result.push(lastConsideredCol); - } - } - result.push(col); - } - lastConsideredCol = col; - out_i_1 = i; - }; - var out_i_1; - for (var i = 0; i < displayedColumns.length; i++) { - _loop_1(i); - i = out_i_1; - } - return result; - }; - // + rowRenderer - // if we are not column spanning, this just returns back the virtual centre columns, - // however if we are column spanning, then different rows can have different virtual - // columns, so we have to work out the list for each individual row. - ColumnController.prototype.getAllDisplayedCenterVirtualColumnsForRow = function (rowNode) { - var _this = this; - if (!this.colSpanActive) { - return this.allDisplayedCenterVirtualColumns; - } - var emptySpaceBeforeColumn = function (col) { return col.getLeft() > _this.viewportLeft; }; - // if doing column virtualisation, then we filter based on the viewport. - var filterCallback = this.suppressColumnVirtualisation ? null : this.isColumnInViewport.bind(this); - return this.getDisplayedColumnsForRow(rowNode, this.displayedCenterColumns, filterCallback, emptySpaceBeforeColumn); - }; - ColumnController.prototype.isColumnInViewport = function (col) { - var columnLeft = col.getLeft(); - var columnRight = col.getLeft() + col.getActualWidth(); - // adding 200 for buffer size, so some cols off viewport are rendered. - // this helps horizontal scrolling so user rarely sees white space (unless - // they scroll horizontally fast). however we are conservative, as the more - // buffer the slower the vertical redraw speed - var leftBounds = this.viewportLeft - 200; - var rightBounds = this.viewportRight + 200; - var columnToMuchLeft = columnLeft < leftBounds && columnRight < leftBounds; - var columnToMuchRight = columnLeft > rightBounds && columnRight > rightBounds; - return !columnToMuchLeft && !columnToMuchRight; - }; - // used by: - // + angularGrid -> setting pinned body width - // note: this should be cached - ColumnController.prototype.getPinnedLeftContainerWidth = function () { - return this.getWidthOfColsInList(this.displayedLeftColumns); - }; - // note: this should be cached - ColumnController.prototype.getPinnedRightContainerWidth = function () { - return this.getWidthOfColsInList(this.displayedRightColumns); - }; - ColumnController.prototype.updatePrimaryColumnList = function (keys, masterList, actionIsAdd, columnCallback, eventType, source) { - var _this = this; - if (source === void 0) { source = "api"; } - if (!keys || _utils__WEBPACK_IMPORTED_MODULE_9__["_"].missingOrEmpty(keys)) { - return; - } - var atLeastOne = false; - keys.forEach(function (key) { - var columnToAdd = _this.getPrimaryColumn(key); - if (!columnToAdd) { + } + AgPickerField.prototype.postConstruct = function () { + var _this = this; + _super.prototype.postConstruct.call(this); + var displayId = this.getCompId() + "-display"; + this.eDisplayField.setAttribute('id', displayId); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_2__["setAriaDescribedBy"])(this.eWrapper, displayId); + var clickHandler = function () { + if (_this.skipClick) { + _this.skipClick = false; return; } - if (actionIsAdd) { - if (masterList.indexOf(columnToAdd) >= 0) { - return; - } - masterList.push(columnToAdd); + if (_this.isDisabled()) { + return; } - else { - if (masterList.indexOf(columnToAdd) < 0) { - return; - } - _utils__WEBPACK_IMPORTED_MODULE_9__["_"].removeFromArray(masterList, columnToAdd); + _this.pickerComponent = _this.showPicker(); + }; + var eGui = this.getGui(); + this.addManagedListener(eGui, 'mousedown', function (e) { + if (!_this.skipClick && + _this.pickerComponent && + _this.pickerComponent.isAlive() && + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["isVisible"])(_this.pickerComponent.getGui()) && + eGui.contains(e.target)) { + _this.skipClick = true; } - columnCallback(columnToAdd); - atLeastOne = true; }); - if (!atLeastOne) { - return; - } - if (this.autoGroupsNeedBuilding) { - this.updateGridColumns(); + this.addManagedListener(eGui, 'keydown', function (e) { + switch (e.key) { + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_6__["KeyCode"].UP: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_6__["KeyCode"].DOWN: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_6__["KeyCode"].ENTER: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_6__["KeyCode"].SPACE: + clickHandler(); + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_6__["KeyCode"].ESCAPE: + if (_this.isPickerDisplayed) { + e.preventDefault(); + } + break; + } + }); + this.addManagedListener(this.eWrapper, 'click', clickHandler); + this.addManagedListener(this.eLabel, 'click', clickHandler); + if (this.pickerIcon) { + var icon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_3__["createIconNoSpan"])(this.pickerIcon, this.gridOptionsWrapper); + if (icon) { + this.eIcon.appendChild(icon); + } } - this.updateDisplayedColumns(source); - var event = { - type: eventType, - columns: masterList, - column: masterList.length === 1 ? masterList[0] : null, - api: this.gridApi, - columnApi: this.columnApi, - source: source - }; - this.eventService.dispatchEvent(event); - }; - ColumnController.prototype.setRowGroupColumns = function (colKeys, source) { - if (source === void 0) { source = "api"; } - this.autoGroupsNeedBuilding = true; - this.setPrimaryColumnList(colKeys, this.rowGroupColumns, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, this.setRowGroupActive.bind(this), source); }; - ColumnController.prototype.setRowGroupActive = function (active, column, source) { - if (active === column.isRowGroupActive()) { - return; + AgPickerField.prototype.refreshLabel = function () { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_4__["exists"])(this.getLabel())) { + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_2__["setAriaLabelledBy"])(this.eWrapper, this.getLabelId()); } - column.setRowGroupActive(active, source); - if (!active && !this.gridOptionsWrapper.isSuppressMakeColumnVisibleAfterUnGroup()) { - column.setVisible(true, source); + else { + this.eWrapper.removeAttribute('aria-labelledby'); } + _super.prototype.refreshLabel.call(this); }; - ColumnController.prototype.addRowGroupColumn = function (key, source) { - if (source === void 0) { source = "api"; } - if (key) { - this.addRowGroupColumns([key], source); - } + AgPickerField.prototype.setAriaLabel = function (label) { + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_2__["setAriaLabel"])(this.eWrapper, label); + return this; }; - ColumnController.prototype.addRowGroupColumns = function (keys, source) { - if (source === void 0) { source = "api"; } - this.autoGroupsNeedBuilding = true; - this.updatePrimaryColumnList(keys, this.rowGroupColumns, true, this.setRowGroupActive.bind(this, true), _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, source); + AgPickerField.prototype.setInputWidth = function (width) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["setElementWidth"])(this.eWrapper, width); + return this; }; - ColumnController.prototype.removeRowGroupColumns = function (keys, source) { - if (source === void 0) { source = "api"; } - this.autoGroupsNeedBuilding = true; - this.updatePrimaryColumnList(keys, this.rowGroupColumns, false, this.setRowGroupActive.bind(this, false), _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, source); + AgPickerField.prototype.getFocusableElement = function () { + return this.eWrapper; }; - ColumnController.prototype.removeRowGroupColumn = function (key, source) { - if (source === void 0) { source = "api"; } - if (key) { - this.removeRowGroupColumns([key], source); - } + __decorate([ + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eLabel') + ], AgPickerField.prototype, "eLabel", void 0); + __decorate([ + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eWrapper') + ], AgPickerField.prototype, "eWrapper", void 0); + __decorate([ + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eDisplayField') + ], AgPickerField.prototype, "eDisplayField", void 0); + __decorate([ + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eIcon') + ], AgPickerField.prototype, "eIcon", void 0); + return AgPickerField; +}(_agAbstractField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractField"])); + + + +/***/ }), +/* 70 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgList", function() { return AgList; }); +/* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(67); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(36); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _utils_string__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(26); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(65); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(44); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - ColumnController.prototype.addPivotColumns = function (keys, source) { - if (source === void 0) { source = "api"; } - this.updatePrimaryColumnList(keys, this.pivotColumns, true, function (column) { return column.setPivotActive(true, source); }, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_CHANGED, source); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - ColumnController.prototype.setPivotColumns = function (colKeys, source) { - if (source === void 0) { source = "api"; } - this.setPrimaryColumnList(colKeys, this.pivotColumns, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_CHANGED, function (added, column) { - column.setPivotActive(added, source); - }, source); +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + +var AgList = /** @class */ (function (_super) { + __extends(AgList, _super); + function AgList(cssIdentifier) { + if (cssIdentifier === void 0) { cssIdentifier = 'default'; } + var _this = _super.call(this, /* html */ "
") || this; + _this.cssIdentifier = cssIdentifier; + _this.options = []; + _this.itemEls = []; + return _this; + } + AgList.prototype.init = function () { + this.addManagedListener(this.getGui(), 'keydown', this.handleKeyDown.bind(this)); }; - ColumnController.prototype.addPivotColumn = function (key, source) { - if (source === void 0) { source = "api"; } - this.addPivotColumns([key], source); + AgList.prototype.handleKeyDown = function (e) { + var key = e.key; + switch (key) { + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].ENTER: + if (!this.highlightedEl) { + this.setValue(this.getValue()); + } + else { + var pos = this.itemEls.indexOf(this.highlightedEl); + this.setValueByIndex(pos); + } + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].DOWN: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].UP: + var isDown = key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].DOWN; + var itemToHighlight = void 0; + e.preventDefault(); + if (!this.highlightedEl) { + itemToHighlight = this.itemEls[isDown ? 0 : this.itemEls.length - 1]; + } + else { + var currentIdx = this.itemEls.indexOf(this.highlightedEl); + var nextPos = currentIdx + (isDown ? 1 : -1); + nextPos = Math.min(Math.max(nextPos, 0), this.itemEls.length - 1); + itemToHighlight = this.itemEls[nextPos]; + } + this.highlightItem(itemToHighlight); + break; + } }; - ColumnController.prototype.removePivotColumns = function (keys, source) { - if (source === void 0) { source = "api"; } - this.updatePrimaryColumnList(keys, this.pivotColumns, false, function (column) { return column.setPivotActive(false, source); }, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_CHANGED, source); + AgList.prototype.addOptions = function (listOptions) { + var _this = this; + listOptions.forEach(function (listOption) { return _this.addOption(listOption); }); + return this; }; - ColumnController.prototype.removePivotColumn = function (key, source) { - if (source === void 0) { source = "api"; } - this.removePivotColumns([key], source); + AgList.prototype.addOption = function (listOption) { + var value = listOption.value, text = listOption.text; + var sanitisedText = Object(_utils_string__WEBPACK_IMPORTED_MODULE_3__["escapeString"])(text || value); + this.options.push({ value: value, text: sanitisedText }); + this.renderOption(value, sanitisedText); + this.updateIndices(); + return this; }; - ColumnController.prototype.setPrimaryColumnList = function (colKeys, masterList, eventName, columnCallback, source) { - var _this = this; - masterList.length = 0; - if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(colKeys)) { - colKeys.forEach(function (key) { - var column = _this.getPrimaryColumn(key); - if (column) { - masterList.push(column); - } - }); - } - this.primaryColumns.forEach(function (column) { - var added = masterList.indexOf(column) >= 0; - columnCallback(added, column); + AgList.prototype.updateIndices = function () { + var options = this.getGui().querySelectorAll('.ag-list-item'); + options.forEach(function (option, idx) { + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_5__["setAriaPosInSet"])(option, idx + 1); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_5__["setAriaSetSize"])(option, options.length); }); - if (this.autoGroupsNeedBuilding) { - this.updateGridColumns(); - } - this.updateDisplayedColumns(source); - var event = { - type: eventName, - columns: masterList, - column: masterList.length === 1 ? masterList[0] : null, - api: this.gridApi, - columnApi: this.columnApi, - source: source - }; - this.eventService.dispatchEvent(event); }; - ColumnController.prototype.setValueColumns = function (colKeys, source) { - if (source === void 0) { source = "api"; } - this.setPrimaryColumnList(colKeys, this.valueColumns, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VALUE_CHANGED, this.setValueActive.bind(this), source); + AgList.prototype.renderOption = function (value, text) { + var _this = this; + var itemEl = document.createElement('div'); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_5__["setAriaRole"])(itemEl, 'option'); + itemEl.classList.add('ag-list-item', "ag-" + this.cssIdentifier + "-list-item"); + itemEl.innerHTML = "" + text + ""; + itemEl.tabIndex = -1; + this.itemEls.push(itemEl); + this.addManagedListener(itemEl, 'mouseover', function () { return _this.highlightItem(itemEl); }); + this.addManagedListener(itemEl, 'mouseleave', function () { return _this.clearHighlighted(); }); + this.addManagedListener(itemEl, 'click', function () { return _this.setValue(value); }); + this.getGui().appendChild(itemEl); }; - ColumnController.prototype.setValueActive = function (active, column, source) { - if (active === column.isValueActive()) { - return; + AgList.prototype.setValue = function (value, silent) { + if (this.value === value) { + this.fireItemSelected(); + return this; } - column.setValueActive(active, source); - if (active && !column.getAggFunc()) { - var defaultAggFunc = this.aggFuncService.getDefaultAggFunc(column); - column.setAggFunc(defaultAggFunc); + if (value == null) { + this.reset(); + return this; } - }; - ColumnController.prototype.addValueColumns = function (keys, source) { - if (source === void 0) { source = "api"; } - this.updatePrimaryColumnList(keys, this.valueColumns, true, this.setValueActive.bind(this, true), _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VALUE_CHANGED, source); - }; - ColumnController.prototype.addValueColumn = function (colKey, source) { - if (source === void 0) { source = "api"; } - if (colKey) { - this.addValueColumns([colKey], source); + var idx = this.options.findIndex(function (option) { return option.value === value; }); + if (idx !== -1) { + var option = this.options[idx]; + this.value = option.value; + this.displayValue = option.text != null ? option.text : option.value; + this.highlightItem(this.itemEls[idx]); + if (!silent) { + this.fireChangeEvent(); + } } + return this; }; - ColumnController.prototype.removeValueColumn = function (colKey, source) { - if (source === void 0) { source = "api"; } - this.removeValueColumns([colKey], source); - }; - ColumnController.prototype.removeValueColumns = function (keys, source) { - if (source === void 0) { source = "api"; } - this.updatePrimaryColumnList(keys, this.valueColumns, false, this.setValueActive.bind(this, false), _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VALUE_CHANGED, source); + AgList.prototype.setValueByIndex = function (idx) { + return this.setValue(this.options[idx].value); }; - // returns the width we can set to this col, taking into consideration min and max widths - ColumnController.prototype.normaliseColumnWidth = function (column, newWidth) { - if (newWidth < column.getMinWidth()) { - newWidth = column.getMinWidth(); - } - if (column.isGreaterThanMax(newWidth)) { - newWidth = column.getMaxWidth(); - } - return newWidth; + AgList.prototype.getValue = function () { + return this.value; }; - ColumnController.prototype.getPrimaryOrGridColumn = function (key) { - var column = this.getPrimaryColumn(key); - return column || this.getGridColumn(key); + AgList.prototype.getDisplayValue = function () { + return this.displayValue; }; - ColumnController.prototype.setColumnWidths = function (columnWidths, shiftKey, // @takeFromAdjacent - if user has 'shift' pressed, then pixels are taken from adjacent column - finished, // @finished - ends up in the event, tells the user if more events are to come - source) { + AgList.prototype.refreshHighlighted = function () { var _this = this; - if (source === void 0) { source = "api"; } - var sets = []; - columnWidths.forEach(function (columnWidth) { - var col = _this.getPrimaryOrGridColumn(columnWidth.key); - if (!col) { - return; - } - sets.push({ - width: columnWidth.newWidth, - ratios: [1], - columns: [col] - }); - // if user wants to do shift resize by default, then we invert the shift operation - var defaultIsShift = _this.gridOptionsWrapper.getColResizeDefault() === 'shift'; - if (defaultIsShift) { - shiftKey = !shiftKey; - } - if (shiftKey) { - var otherCol = _this.getDisplayedColAfter(col); - if (!otherCol) { - return; - } - var widthDiff = col.getActualWidth() - columnWidth.newWidth; - var otherColWidth = otherCol.getActualWidth() + widthDiff; - sets.push({ - width: otherColWidth, - ratios: [1], - columns: [otherCol] - }); - } - }); - if (sets.length === 0) { - return; - } - this.resizeColumnSets(sets, finished, source); - if (this.flexActive) { - this.refreshFlexedColumns(); + this.clearHighlighted(); + var idx = this.options.findIndex(function (option) { return option.value === _this.value; }); + if (idx !== -1) { + this.highlightItem(this.itemEls[idx]); } }; - ColumnController.prototype.checkMinAndMaxWidthsForSet = function (columnResizeSet) { - var columns = columnResizeSet.columns, width = columnResizeSet.width; - // every col has a min width, so sum them all up and see if we have enough room - // for all the min widths - var minWidthAccumulated = 0; - var maxWidthAccumulated = 0; - var maxWidthActive = true; - columns.forEach(function (col) { - minWidthAccumulated += col.getMinWidth(); - if (col.getMaxWidth() > 0) { - maxWidthAccumulated += col.getMaxWidth(); - } - else { - // if at least one columns has no max width, it means the group of columns - // then has no max width, as at least one column can take as much width as possible - maxWidthActive = false; - } - }); - var minWidthPasses = width >= minWidthAccumulated; - var maxWidthPasses = !maxWidthActive || (width <= maxWidthAccumulated); - return minWidthPasses && maxWidthPasses; + AgList.prototype.reset = function () { + this.value = null; + this.displayValue = null; + this.clearHighlighted(); + this.fireChangeEvent(); }; - // method takes sets of columns and resizes them. either all sets will be resized, or nothing - // be resized. this is used for example when user tries to resize a group and holds shift key, - // then both the current group (grows), and the adjacent group (shrinks), will get resized, - // so that's two sets for this method. - ColumnController.prototype.resizeColumnSets = function (resizeSets, finished, source) { - var passMinMaxCheck = !resizeSets || resizeSets.every(this.checkMinAndMaxWidthsForSet.bind(this)); - if (!passMinMaxCheck) { - // even though we are not going to resize beyond min/max size, we still need to raise event when finished - if (finished) { - var columns = resizeSets && resizeSets.length > 0 ? resizeSets[0].columns : null; - var event_3 = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_RESIZED, - columns: columns, - column: columns && columns.length === 1 ? columns[0] : null, - finished: finished, - api: this.gridApi, - columnApi: this.columnApi, - source: source - }; - this.eventService.dispatchEvent(event_3); - } - return; // don't resize! - } - var changedCols = []; - var allCols = []; - resizeSets.forEach(function (set) { - var width = set.width, columns = set.columns, ratios = set.ratios; - // keep track of pixels used, and last column gets the remaining, - // to cater for rounding errors, and min width adjustments - var newWidths = {}; - var finishedCols = {}; - columns.forEach(function (col) { return allCols.push(col); }); - // the loop below goes through each col. if a col exceeds it's min/max width, - // it then gets set to its min/max width and the column is removed marked as 'finished' - // and the calculation is done again leaving this column out. take for example columns - // {A, width: 50, maxWidth: 100} - // {B, width: 50} - // {C, width: 50} - // and then the set is set to width 600 - on the first pass the grid tries to set each column - // to 200. it checks A and sees 200 > 100 and so sets the width to 100. col A is then marked - // as 'finished' and the calculation is done again with the remaining cols B and C, which end up - // splitting the remaining 500 pixels. - var finishedColsGrew = true; - var loopCount = 0; - var _loop_2 = function () { - loopCount++; - if (loopCount > 1000) { - // this should never happen, but in the future, someone might introduce a bug here, - // so we stop the browser from hanging and report bug properly - console.error('ag-Grid: infinite loop in resizeColumnSets'); - return "break"; - } - finishedColsGrew = false; - var subsetCols = []; - var subsetRatios = []; - var subsetRatioTotal = 0; - var pixelsToDistribute = width; - columns.forEach(function (col, index) { - var thisColFinished = finishedCols[col.getId()]; - if (thisColFinished) { - pixelsToDistribute -= newWidths[col.getId()]; - } - else { - subsetCols.push(col); - var ratioThisCol = ratios[index]; - subsetRatioTotal += ratioThisCol; - subsetRatios.push(ratioThisCol); - } - }); - // because we are not using all of the ratios (cols can be missing), - // we scale the ratio. if all columns are included, then subsetRatioTotal=1, - // and so the ratioScale will be 1. - var ratioScale = 1 / subsetRatioTotal; - subsetCols.forEach(function (col, index) { - var lastCol = index === (subsetCols.length - 1); - var colNewWidth; - if (lastCol) { - colNewWidth = pixelsToDistribute; - } - else { - colNewWidth = Math.round(ratios[index] * width * ratioScale); - pixelsToDistribute -= colNewWidth; - } - if (colNewWidth < col.getMinWidth()) { - colNewWidth = col.getMinWidth(); - finishedCols[col.getId()] = true; - finishedColsGrew = true; - } - else if (col.getMaxWidth() > 0 && colNewWidth > col.getMaxWidth()) { - colNewWidth = col.getMaxWidth(); - finishedCols[col.getId()] = true; - finishedColsGrew = true; - } - newWidths[col.getId()] = colNewWidth; - }); - }; - while (finishedColsGrew) { - var state_1 = _loop_2(); - if (state_1 === "break") - break; - } - columns.forEach(function (col) { - var newWidth = newWidths[col.getId()]; - if (col.getActualWidth() !== newWidth) { - col.setActualWidth(newWidth, source); - changedCols.push(col); - } - }); - }); - // if no cols changed, then no need to update more or send event. - var atLeastOneColChanged = changedCols.length > 0; - if (atLeastOneColChanged) { - this.setLeftValues(source); - this.updateBodyWidths(); - this.checkDisplayedVirtualColumns(); - } - // check for change first, to avoid unnecessary firing of events - // however we always fire 'finished' events. this is important - // when groups are resized, as if the group is changing slowly, - // eg 1 pixel at a time, then each change will fire change events - // in all the columns in the group, but only one with get the pixel. - if (atLeastOneColChanged || finished) { - var event_4 = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_RESIZED, - columns: allCols, - column: allCols.length === 1 ? allCols[0] : null, - finished: finished, - api: this.gridApi, - columnApi: this.columnApi, - source: source - }; - this.eventService.dispatchEvent(event_4); + AgList.prototype.highlightItem = function (el) { + if (!el.offsetParent) { + return; } + this.clearHighlighted(); + this.highlightedEl = el; + this.highlightedEl.classList.add(AgList.ACTIVE_CLASS); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_5__["setAriaSelected"])(this.highlightedEl, true); + this.highlightedEl.focus(); }; - ColumnController.prototype.setColumnAggFunc = function (column, aggFunc, source) { - if (source === void 0) { source = "api"; } - if (!column) { + AgList.prototype.clearHighlighted = function () { + if (!this.highlightedEl || !this.highlightedEl.offsetParent) { return; } - column.setAggFunc(aggFunc); - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VALUE_CHANGED, - columns: [column], - column: column, - api: this.gridApi, - columnApi: this.columnApi, - source: source - }; - this.eventService.dispatchEvent(event); + this.highlightedEl.classList.remove(AgList.ACTIVE_CLASS); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_5__["setAriaSelected"])(this.highlightedEl, false); + this.highlightedEl = null; }; - ColumnController.prototype.moveRowGroupColumn = function (fromIndex, toIndex, source) { - if (source === void 0) { source = "api"; } - var column = this.rowGroupColumns[fromIndex]; - this.rowGroupColumns.splice(fromIndex, 1); - this.rowGroupColumns.splice(toIndex, 0, column); - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, - columns: this.rowGroupColumns, - column: this.rowGroupColumns.length === 1 ? this.rowGroupColumns[0] : null, - api: this.gridApi, - columnApi: this.columnApi, - source: source - }; - this.eventService.dispatchEvent(event); + AgList.prototype.fireChangeEvent = function () { + this.dispatchEvent({ type: _agAbstractField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractField"].EVENT_CHANGED }); + this.fireItemSelected(); }; - ColumnController.prototype.moveColumns = function (columnsToMoveKeys, toIndex, source) { - if (source === void 0) { source = "api"; } - this.columnAnimationService.start(); - if (toIndex > this.gridColumns.length - columnsToMoveKeys.length) { - console.warn('ag-Grid: tried to insert columns in invalid location, toIndex = ' + toIndex); - console.warn('ag-Grid: remember that you should not count the moving columns when calculating the new index'); - return; + AgList.prototype.fireItemSelected = function () { + this.dispatchEvent({ type: AgList.EVENT_ITEM_SELECTED }); + }; + AgList.EVENT_ITEM_SELECTED = 'selectedItem'; + AgList.ACTIVE_CLASS = 'ag-active-item'; + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] + ], AgList.prototype, "init", null); + return AgList; +}(_component__WEBPACK_IMPORTED_MODULE_1__["Component"])); + + + +/***/ }), +/* 71 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgAbstractInputField", function() { return AgAbstractInputField; }); +/* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57); +/* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(67); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(42); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(44); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + +var AgAbstractInputField = /** @class */ (function (_super) { + __extends(AgAbstractInputField, _super); + function AgAbstractInputField(config, className, inputType, displayFieldTag) { + if (inputType === void 0) { inputType = 'text'; } + if (displayFieldTag === void 0) { displayFieldTag = 'input'; } + var _this = _super.call(this, config, /* html */ "\n
\n
\n
\n <" + displayFieldTag + " ref=\"eInput\" class=\"ag-input-field-input\">\n
\n
", className) || this; + _this.inputType = inputType; + _this.displayFieldTag = displayFieldTag; + return _this; + } + AgAbstractInputField.prototype.postConstruct = function () { + _super.prototype.postConstruct.call(this); + this.setInputType(); + this.eLabel.classList.add(this.className + "-label"); + this.eWrapper.classList.add(this.className + "-input-wrapper"); + this.eInput.classList.add(this.className + "-input"); + this.addCssClass('ag-input-field'); + this.eInput.id = this.eInput.id || "ag-" + this.getCompId() + "-input"; + var _a = this.config, width = _a.width, value = _a.value; + if (width != null) { + this.setWidth(width); } - // we want to pull all the columns out first and put them into an ordered list - var columnsToMove = this.getGridColumns(columnsToMoveKeys); - var failedRules = !this.doesMovePassRules(columnsToMove, toIndex); - if (failedRules) { - return; + if (value != null) { + this.setValue(value); } - _utils__WEBPACK_IMPORTED_MODULE_9__["_"].moveInArray(this.gridColumns, columnsToMove, toIndex); - this.updateDisplayedColumns(source); - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_MOVED, - columns: columnsToMove, - column: columnsToMove.length === 1 ? columnsToMove[0] : null, - toIndex: toIndex, - api: this.gridApi, - columnApi: this.columnApi, - source: source - }; - this.eventService.dispatchEvent(event); - this.columnAnimationService.finish(); + this.addInputListeners(); }; - ColumnController.prototype.doesMovePassRules = function (columnsToMove, toIndex) { - // make a copy of what the grid columns would look like after the move - var proposedColumnOrder = this.gridColumns.slice(); - _utils__WEBPACK_IMPORTED_MODULE_9__["_"].moveInArray(proposedColumnOrder, columnsToMove, toIndex); - // then check that the new proposed order of the columns passes all rules - if (!this.doesMovePassMarryChildren(proposedColumnOrder)) { - return false; + AgAbstractInputField.prototype.refreshLabel = function () { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_4__["exists"])(this.getLabel())) { + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_3__["setAriaLabelledBy"])(this.eInput, this.getLabelId()); } - if (!this.doesMovePassLockedPositions(proposedColumnOrder)) { - return false; + else { + this.eInput.removeAttribute('aria-labelledby'); } - return true; + _super.prototype.refreshLabel.call(this); }; - ColumnController.prototype.doesMovePassLockedPositions = function (proposedColumnOrder) { - var foundNonLocked = false; - var rulePassed = true; - // go though the cols, see if any non-locked appear before any locked - proposedColumnOrder.forEach(function (col) { - if (col.getColDef().lockPosition) { - if (foundNonLocked) { - rulePassed = false; - } - } - else { - foundNonLocked = true; - } - }); - return rulePassed; + AgAbstractInputField.prototype.addInputListeners = function () { + var _this = this; + this.addManagedListener(this.eInput, 'input', function (e) { return _this.setValue(e.target.value); }); }; - ColumnController.prototype.doesMovePassMarryChildren = function (allColumnsCopy) { - var rulePassed = true; - this.columnUtils.depthFirstOriginalTreeSearch(null, this.gridBalancedTree, function (child) { - if (!(child instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"])) { - return; - } - var columnGroup = child; - var marryChildren = columnGroup.getColGroupDef() && columnGroup.getColGroupDef().marryChildren; - if (!marryChildren) { - return; - } - var newIndexes = []; - columnGroup.getLeafColumns().forEach(function (col) { - var newColIndex = allColumnsCopy.indexOf(col); - newIndexes.push(newColIndex); - }); - var maxIndex = Math.max.apply(Math, newIndexes); - var minIndex = Math.min.apply(Math, newIndexes); - // spread is how far the first column in this group is away from the last column - var spread = maxIndex - minIndex; - var maxSpread = columnGroup.getLeafColumns().length - 1; - // if the columns - if (spread > maxSpread) { - rulePassed = false; - } - // console.log(`maxIndex = ${maxIndex}, minIndex = ${minIndex}, spread = ${spread}, maxSpread = ${maxSpread}, fail = ${spread > (count-1)}`) - // console.log(allColumnsCopy.map( col => col.getColDef().field).join(',')); - }); - return rulePassed; + AgAbstractInputField.prototype.setInputType = function () { + if (this.displayFieldTag === 'input') { + this.eInput.setAttribute('type', this.inputType); + } }; - ColumnController.prototype.moveColumn = function (key, toIndex, source) { - if (source === void 0) { source = "api"; } - this.moveColumns([key], toIndex, source); + AgAbstractInputField.prototype.getInputElement = function () { + return this.eInput; }; - ColumnController.prototype.moveColumnByIndex = function (fromIndex, toIndex, source) { - if (source === void 0) { source = "api"; } - var column = this.gridColumns[fromIndex]; - this.moveColumn(column, toIndex, source); + AgAbstractInputField.prototype.setInputWidth = function (width) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["setElementWidth"])(this.eWrapper, width); + return this; }; - // used by: - // + angularGrid -> for setting body width - // + rowController -> setting main row widths (when inserting and resizing) - // need to cache this - ColumnController.prototype.getBodyContainerWidth = function () { - return this.bodyWidth; + AgAbstractInputField.prototype.setInputName = function (name) { + this.getInputElement().setAttribute('name', name); + return this; }; - ColumnController.prototype.getContainerWidth = function (pinned) { - switch (pinned) { - case _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT: - return this.leftWidth; - case _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT: - return this.rightWidth; - default: - return this.bodyWidth; - } + AgAbstractInputField.prototype.getFocusableElement = function () { + return this.eInput; }; - // after setColumnWidth or updateGroupsAndDisplayedColumns - ColumnController.prototype.updateBodyWidths = function () { - var newBodyWidth = this.getWidthOfColsInList(this.displayedCenterColumns); - var newLeftWidth = this.getWidthOfColsInList(this.displayedLeftColumns); - var newRightWidth = this.getWidthOfColsInList(this.displayedRightColumns); - // this is used by virtual col calculation, for RTL only, as a change to body width can impact displayed - // columns, due to RTL inverting the y coordinates - this.bodyWidthDirty = this.bodyWidth !== newBodyWidth; - var atLeastOneChanged = this.bodyWidth !== newBodyWidth || this.leftWidth !== newLeftWidth || this.rightWidth !== newRightWidth; - if (atLeastOneChanged) { - this.bodyWidth = newBodyWidth; - this.leftWidth = newLeftWidth; - this.rightWidth = newRightWidth; - // when this fires, it is picked up by the gridPanel, which ends up in - // gridPanel calling setWidthAndScrollPosition(), which in turn calls setVirtualViewportPosition() - var event_5 = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, - api: this.gridApi, - columnApi: this.columnApi - }; - this.eventService.dispatchEvent(event_5); - } + AgAbstractInputField.prototype.setMaxLength = function (length) { + var eInput = this.eInput; + eInput.maxLength = length; + return this; }; - // + rowController - ColumnController.prototype.getValueColumns = function () { - return this.valueColumns ? this.valueColumns : []; + AgAbstractInputField.prototype.setInputPlaceholder = function (placeholder) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["addOrRemoveAttribute"])(this.eInput, 'placeholder', placeholder); + return this; }; - // + rowController - ColumnController.prototype.getPivotColumns = function () { - return this.pivotColumns ? this.pivotColumns : []; + AgAbstractInputField.prototype.setInputAriaLabel = function (label) { + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_3__["setAriaLabel"])(this.eInput, label); + return this; }; - // + clientSideRowModel - ColumnController.prototype.isPivotActive = function () { - return this.pivotColumns && this.pivotColumns.length > 0 && this.pivotMode; + AgAbstractInputField.prototype.setDisabled = function (disabled) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["setDisabled"])(this.eInput, disabled); + return _super.prototype.setDisabled.call(this, disabled); }; - // + toolPanel - ColumnController.prototype.getRowGroupColumns = function () { - return this.rowGroupColumns ? this.rowGroupColumns : []; + __decorate([ + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eLabel') + ], AgAbstractInputField.prototype, "eLabel", void 0); + __decorate([ + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eWrapper') + ], AgAbstractInputField.prototype, "eWrapper", void 0); + __decorate([ + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eInput') + ], AgAbstractInputField.prototype, "eInput", void 0); + return AgAbstractInputField; +}(_agAbstractField__WEBPACK_IMPORTED_MODULE_1__["AgAbstractField"])); + + + +/***/ }), +/* 72 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ScalarFilter", function() { return ScalarFilter; }); +/* harmony import */ var _simpleFilter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(60); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - // + rowController -> while inserting rows - ColumnController.prototype.getDisplayedCenterColumns = function () { - return this.displayedCenterColumns; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - // + rowController -> while inserting rows - ColumnController.prototype.getDisplayedLeftColumns = function () { - return this.displayedLeftColumns; +})(); + +var ScalarFilter = /** @class */ (function (_super) { + __extends(ScalarFilter, _super); + function ScalarFilter() { + return _super !== null && _super.apply(this, arguments) || this; + } + ScalarFilter.prototype.setParams = function (params) { + _super.prototype.setParams.call(this, params); + this.scalarFilterParams = params; }; - ColumnController.prototype.getDisplayedRightColumns = function () { - return this.displayedRightColumns; + ScalarFilter.prototype.evaluateNullValue = function (filterType) { + switch (filterType) { + case ScalarFilter.EQUALS: + case ScalarFilter.NOT_EQUAL: + if (this.scalarFilterParams.includeBlanksInEquals) { + return true; + } + break; + case ScalarFilter.GREATER_THAN: + case ScalarFilter.GREATER_THAN_OR_EQUAL: + if (this.scalarFilterParams.includeBlanksInGreaterThan) { + return true; + } + break; + case ScalarFilter.LESS_THAN: + case ScalarFilter.LESS_THAN_OR_EQUAL: + if (this.scalarFilterParams.includeBlanksInLessThan) { + return true; + } + break; + case ScalarFilter.IN_RANGE: + if (this.scalarFilterParams.includeBlanksInRange) { + return true; + } + break; + case ScalarFilter.BLANK: + return true; + case ScalarFilter.NOT_BLANK: + return false; + } + return false; }; - ColumnController.prototype.getDisplayedColumns = function (type) { - switch (type) { - case _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT: - return this.getDisplayedLeftColumns(); - case _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT: - return this.getDisplayedRightColumns(); + ScalarFilter.prototype.evaluateNonNullValue = function (values, cellValue, filterModel) { + var comparator = this.comparator(); + var compareResult = values[0] != null ? comparator(values[0], cellValue) : 0; + switch (filterModel.type) { + case ScalarFilter.EQUALS: + return compareResult === 0; + case ScalarFilter.NOT_EQUAL: + return compareResult !== 0; + case ScalarFilter.GREATER_THAN: + return compareResult > 0; + case ScalarFilter.GREATER_THAN_OR_EQUAL: + return compareResult >= 0; + case ScalarFilter.LESS_THAN: + return compareResult < 0; + case ScalarFilter.LESS_THAN_OR_EQUAL: + return compareResult <= 0; + case ScalarFilter.IN_RANGE: { + var compareToResult = comparator(values[1], cellValue); + return this.scalarFilterParams.inRangeInclusive ? + compareResult >= 0 && compareToResult <= 0 : + compareResult > 0 && compareToResult < 0; + } + case ScalarFilter.BLANK: + return this.isBlank(cellValue); + case ScalarFilter.NOT_BLANK: + return !this.isBlank(cellValue); default: - return this.getDisplayedCenterColumns(); + console.warn('AG Grid: Unexpected type of filter "' + filterModel.type + '", it looks like the filter was configured with incorrect Filter Options'); + return true; } }; - // used by: - // + clientSideRowController -> sorting, building quick filter text - // + headerRenderer -> sorting (clearing icon) - ColumnController.prototype.getAllPrimaryColumns = function () { - return this.primaryColumns ? this.primaryColumns.slice() : null; + return ScalarFilter; +}(_simpleFilter__WEBPACK_IMPORTED_MODULE_0__["SimpleFilter"])); + + + +/***/ }), +/* 73 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DateFloatingFilter", function() { return DateFloatingFilter; }); +/* harmony import */ var _dateFilter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(58); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(59); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(57); +/* harmony import */ var _simpleFilter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(60); +/* harmony import */ var _floating_provided_simpleFloatingFilter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(74); +/* harmony import */ var _providedFilter__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(62); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(42); +/* harmony import */ var _utils_date__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(45); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(14); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - ColumnController.prototype.getSecondaryColumns = function () { - return this.secondaryColumns ? this.secondaryColumns.slice() : null; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - ColumnController.prototype.getAllColumnsForQuickFilter = function () { - return this.columnsForQuickFilter; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + + + + +var DateFloatingFilter = /** @class */ (function (_super) { + __extends(DateFloatingFilter, _super); + function DateFloatingFilter() { + return _super.call(this, /* html */ "\n
\n \n
\n
") || this; + } + DateFloatingFilter.prototype.getDefaultFilterOptions = function () { + return _dateFilter__WEBPACK_IMPORTED_MODULE_0__["DateFilter"].DEFAULT_FILTER_OPTIONS; }; - // + moveColumnController - ColumnController.prototype.getAllGridColumns = function () { - return this.gridColumns; + DateFloatingFilter.prototype.conditionToString = function (condition, options) { + var type = condition.type; + var numberOfInputs = (options || {}).numberOfInputs; + var isRange = type == _simpleFilter__WEBPACK_IMPORTED_MODULE_4__["SimpleFilter"].IN_RANGE || numberOfInputs === 2; + var dateFrom = Object(_utils_date__WEBPACK_IMPORTED_MODULE_8__["parseDateTimeFromString"])(condition.dateFrom); + var dateTo = Object(_utils_date__WEBPACK_IMPORTED_MODULE_8__["parseDateTimeFromString"])(condition.dateTo); + if (isRange) { + return Object(_utils_date__WEBPACK_IMPORTED_MODULE_8__["serialiseDate"])(dateFrom, false) + "-" + Object(_utils_date__WEBPACK_IMPORTED_MODULE_8__["serialiseDate"])(dateTo, false); + } + if (dateFrom != null) { + return "" + Object(_utils_date__WEBPACK_IMPORTED_MODULE_8__["serialiseDate"])(dateFrom, false); + } + // cater for when the type doesn't need a value + return "" + type; }; - ColumnController.prototype.isEmpty = function () { - return _utils__WEBPACK_IMPORTED_MODULE_9__["_"].missingOrEmpty(this.gridColumns); + DateFloatingFilter.prototype.init = function (params) { + _super.prototype.init.call(this, params); + this.params = params; + this.createDateComponent(); + var translate = this.gridOptionsWrapper.getLocaleTextFunc(); + this.eReadOnlyText + .setDisabled(true) + .setInputAriaLabel(translate('ariaDateFilterInput', 'Date Filter Input')); }; - ColumnController.prototype.isRowGroupEmpty = function () { - return _utils__WEBPACK_IMPORTED_MODULE_9__["_"].missingOrEmpty(this.rowGroupColumns); + DateFloatingFilter.prototype.setEditable = function (editable) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_7__["setDisplayed"])(this.eDateWrapper, editable); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_7__["setDisplayed"])(this.eReadOnlyText.getGui(), !editable); }; - ColumnController.prototype.setColumnVisible = function (key, visible, source) { - if (source === void 0) { source = "api"; } - this.setColumnsVisible([key], visible, source); + DateFloatingFilter.prototype.onParentModelChanged = function (model, event) { + // We don't want to update the floating filter if the floating filter caused the change, + // because the UI is already in sync. if we didn't do this, the UI would behave strangely + // as it would be updating as the user is typing + if (this.isEventFromFloatingFilter(event)) { + return; + } + _super.prototype.setLastTypeFromModel.call(this, model); + var allowEditing = !this.isReadOnly() && + this.canWeEditAfterModelFromParentFilter(model); + this.setEditable(allowEditing); + if (allowEditing) { + if (model) { + var dateModel = model; + this.dateComp.setDate(Object(_utils_date__WEBPACK_IMPORTED_MODULE_8__["parseDateTimeFromString"])(dateModel.dateFrom)); + } + else { + this.dateComp.setDate(null); + } + this.eReadOnlyText.setValue(''); + } + else { + this.eReadOnlyText.setValue(this.getTextFromModel(model)); + this.dateComp.setDate(null); + } }; - ColumnController.prototype.setColumnsVisible = function (keys, visible, source) { + DateFloatingFilter.prototype.onDateChanged = function () { var _this = this; - if (source === void 0) { source = "api"; } - this.columnAnimationService.start(); - this.actionOnGridColumns(keys, function (column) { - if (column.isVisible() !== visible) { - column.setVisible(visible, source); - return true; + var filterValueDate = this.dateComp.getDate(); + var filterValueText = Object(_utils_date__WEBPACK_IMPORTED_MODULE_8__["serialiseDate"])(filterValueDate); + this.params.parentFilterInstance(function (filterInstance) { + if (filterInstance) { + var date = Object(_utils_date__WEBPACK_IMPORTED_MODULE_8__["parseDateTimeFromString"])(filterValueText); + filterInstance.onFloatingFilterChanged(_this.getLastType() || null, date); } - return false; - }, source, function () { - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VISIBLE, - visible: visible, - column: null, - columns: null, - api: _this.gridApi, - columnApi: _this.columnApi, - source: source - }; - return event; }); - this.columnAnimationService.finish(); }; - ColumnController.prototype.setColumnPinned = function (key, pinned, source) { - if (source === void 0) { source = "api"; } - if (key) { - this.setColumnsPinned([key], pinned, source); - } + DateFloatingFilter.prototype.createDateComponent = function () { + var _this = this; + var debounceMs = _providedFilter__WEBPACK_IMPORTED_MODULE_6__["ProvidedFilter"].getDebounceMs(this.params.filterParams, this.getDefaultDebounceMs()); + var dateComponentParams = { + onDateChanged: Object(_utils_function__WEBPACK_IMPORTED_MODULE_9__["debounce"])(this.onDateChanged.bind(this), debounceMs), + filterParams: this.params.column.getColDef().filterParams + }; + this.dateComp = new _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__["DateCompWrapper"](this.getContext(), this.userComponentFactory, dateComponentParams, this.eDateWrapper); + this.addDestroyFunc(function () { return _this.dateComp.destroy(); }); + }; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('userComponentFactory') + ], DateFloatingFilter.prototype, "userComponentFactory", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eReadOnlyText') + ], DateFloatingFilter.prototype, "eReadOnlyText", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eDateWrapper') + ], DateFloatingFilter.prototype, "eDateWrapper", void 0); + return DateFloatingFilter; +}(_floating_provided_simpleFloatingFilter__WEBPACK_IMPORTED_MODULE_5__["SimpleFloatingFilter"])); + + + +/***/ }), +/* 74 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SimpleFloatingFilter", function() { return SimpleFloatingFilter; }); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/* harmony import */ var _provided_simpleFilter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(60); +/* harmony import */ var _provided_optionsFactory__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(61); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); + + + +var SimpleFloatingFilter = /** @class */ (function (_super) { + __extends(SimpleFloatingFilter, _super); + function SimpleFloatingFilter() { + return _super !== null && _super.apply(this, arguments) || this; + } + SimpleFloatingFilter.prototype.getDefaultDebounceMs = function () { + return 0; + }; + // this is a user component, and IComponent has "public destroy()" as part of the interface. + // so we need to override destroy() just to make the method public. + SimpleFloatingFilter.prototype.destroy = function () { + _super.prototype.destroy.call(this); + }; + // used by: + // 1) NumberFloatingFilter & TextFloatingFilter: Always, for both when editable and read only. + // 2) DateFloatingFilter: Only when read only (as we show text rather than a date picker when read only) + SimpleFloatingFilter.prototype.getTextFromModel = function (model) { + if (!model) { + return null; + } + var isCombined = model.operator != null; + if (isCombined) { + var combinedModel = model; + var _a = combinedModel || {}, condition1 = _a.condition1, condition2 = _a.condition2; + var customOption1 = this.optionsFactory.getCustomOption(condition1.type); + var customOption2 = this.optionsFactory.getCustomOption(condition2.type); + return [ + this.conditionToString(condition1, customOption1), + combinedModel.operator, + this.conditionToString(condition2, customOption2), + ].join(' '); + } + else { + var condition = model; + var customOption = this.optionsFactory.getCustomOption(condition.type); + // For custom filter options we display the Name of the filter instead + // of displaying the `from` value, as it wouldn't be relevant + var _b = customOption || {}, displayKey = _b.displayKey, displayName = _b.displayName, numberOfInputs = _b.numberOfInputs; + if (displayKey && displayName && numberOfInputs === 0) { + this.gridOptionsWrapper.getLocaleTextFunc()(displayKey, displayName); + return displayName; + } + return this.conditionToString(condition, customOption); + } + }; + SimpleFloatingFilter.prototype.isEventFromFloatingFilter = function (event) { + return event && event.afterFloatingFilter; + }; + SimpleFloatingFilter.prototype.getLastType = function () { + return this.lastType; + }; + SimpleFloatingFilter.prototype.isReadOnly = function () { + return this.readOnly; + }; + SimpleFloatingFilter.prototype.setLastTypeFromModel = function (model) { + // if no model provided by the parent filter use default + if (!model) { + this.lastType = this.optionsFactory.getDefaultOption(); + return; + } + var isCombined = model.operator; + var condition; + if (isCombined) { + var combinedModel = model; + condition = combinedModel.condition1; + } + else { + condition = model; + } + this.lastType = condition.type; + }; + SimpleFloatingFilter.prototype.canWeEditAfterModelFromParentFilter = function (model) { + if (!model) { + // if no model, then we can edit as long as the lastType is something we can edit, as this + // is the type we will provide to the parent filter if the user decides to use the floating filter. + return this.isTypeEditable(this.lastType); + } + // never allow editing if the filter is combined (ie has two parts) + var isCombined = model.operator; + if (isCombined) { + return false; + } + var simpleModel = model; + return this.isTypeEditable(simpleModel.type); + }; + SimpleFloatingFilter.prototype.init = function (params) { + this.optionsFactory = new _provided_optionsFactory__WEBPACK_IMPORTED_MODULE_2__["OptionsFactory"](); + this.optionsFactory.init(params.filterParams, this.getDefaultFilterOptions()); + this.lastType = this.optionsFactory.getDefaultOption(); + // readOnly is a property of IProvidedFilterParams - we need to find a better (type-safe) + // way to support reading this in the future. + this.readOnly = !!params.filterParams.readOnly; + // we are editable if: + // 1) there is a type (user has configured filter wrong if not type) + // AND + // 2) the default type is not 'in range' + var editable = this.isTypeEditable(this.lastType); + this.setEditable(editable); + }; + SimpleFloatingFilter.prototype.doesFilterHaveSingleInput = function (filterType) { + var customFilterOption = this.optionsFactory.getCustomOption(filterType); + var numberOfInputs = (customFilterOption || {}).numberOfInputs; + return numberOfInputs == null || numberOfInputs == 1; + }; + SimpleFloatingFilter.prototype.isTypeEditable = function (type) { + var uneditableTypes = [ + _provided_simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].IN_RANGE, _provided_simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].EMPTY, _provided_simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].BLANK, _provided_simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].NOT_BLANK, + ]; + return !!type && + !this.isReadOnly() && + this.doesFilterHaveSingleInput(type) && + uneditableTypes.indexOf(type) < 0; + }; + return SimpleFloatingFilter; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); + + + +/***/ }), +/* 75 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DefaultDateComponent", function() { return DefaultDateComponent; }); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); +/* harmony import */ var _utils_date__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(45); +/* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + +var DefaultDateComponent = /** @class */ (function (_super) { + __extends(DefaultDateComponent, _super); + function DefaultDateComponent() { + return _super.call(this, /* html */ "\n
\n \n
") || this; + } + // this is a user component, and IComponent has "public destroy()" as part of the interface. + // so we need to override destroy() just to make the method public. + DefaultDateComponent.prototype.destroy = function () { + _super.prototype.destroy.call(this); }; - ColumnController.prototype.setColumnsPinned = function (keys, pinned, source) { + DefaultDateComponent.prototype.init = function (params) { var _this = this; - if (source === void 0) { source = "api"; } - if (this.gridOptionsWrapper.getDomLayout() === 'print') { - console.warn("Changing the column pinning status is not allowed with domLayout='print'"); - return; - } - this.columnAnimationService.start(); - var actualPinned; - if (pinned === true || pinned === _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT) { - actualPinned = _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT; - } - else if (pinned === _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT) { - actualPinned = _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT; - } - else { - actualPinned = null; + var eDocument = this.gridOptionsWrapper.getDocument(); + var inputElement = this.eDateInput.getInputElement(); + if (this.shouldUseBrowserDatePicker(params)) { + inputElement.type = 'date'; } - this.actionOnGridColumns(keys, function (col) { - if (col.getPinned() !== actualPinned) { - col.setPinned(actualPinned); - return true; + // ensures that the input element is focussed when a clear button is clicked + this.addManagedListener(inputElement, 'mousedown', function () { + if (_this.eDateInput.isDisabled()) { + return; } - return false; - }, source, function () { - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PINNED, - pinned: actualPinned, - column: null, - columns: null, - api: _this.gridApi, - columnApi: _this.columnApi, - source: source - }; - return event; + inputElement.focus(); }); - this.columnAnimationService.finish(); - }; - // does an action on a set of columns. provides common functionality for looking up the - // columns based on key, getting a list of effected columns, and then updated the event - // with either one column (if it was just one col) or a list of columns - // used by: autoResize, setVisible, setPinned - ColumnController.prototype.actionOnGridColumns = function (// the column keys this action will be on - keys, - // the action to do - if this returns false, the column was skipped - // and won't be included in the event - action, - // should return back a column event of the right type - source, createEvent) { - var _this = this; - if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].missingOrEmpty(keys)) { - return; - } - var updatedColumns = []; - keys.forEach(function (key) { - var column = _this.getGridColumn(key); - if (!column) { + this.addManagedListener(inputElement, 'input', function (e) { + if (e.target !== eDocument.activeElement) { return; } - // need to check for false with type (ie !== instead of !=) - // as not returning anything (undefined) would also be false - var resultOfAction = action(column); - if (resultOfAction !== false) { - updatedColumns.push(column); + if (_this.eDateInput.isDisabled()) { + return; } + params.onDateChanged(); }); - if (!updatedColumns.length) { - return; + var _a = params.filterParams || {}, minValidYear = _a.minValidYear, maxValidYear = _a.maxValidYear; + if (minValidYear) { + inputElement.min = minValidYear + "-01-01"; } - this.updateDisplayedColumns(source); - if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(createEvent) && createEvent) { - var event_6 = createEvent(); - event_6.columns = updatedColumns; - event_6.column = updatedColumns.length === 1 ? updatedColumns[0] : null; - this.eventService.dispatchEvent(event_6); + if (maxValidYear) { + inputElement.max = maxValidYear + "-12-31"; } }; - ColumnController.prototype.getDisplayedColBefore = function (col) { - var allDisplayedColumns = this.getAllDisplayedColumns(); - var oldIndex = allDisplayedColumns.indexOf(col); - if (oldIndex > 0) { - return allDisplayedColumns[oldIndex - 1]; - } - return null; + DefaultDateComponent.prototype.getDate = function () { + return Object(_utils_date__WEBPACK_IMPORTED_MODULE_2__["parseDateTimeFromString"])(this.eDateInput.getValue()); }; - // used by: - // + rowRenderer -> for navigation - ColumnController.prototype.getDisplayedColAfter = function (col) { - var allDisplayedColumns = this.getAllDisplayedColumns(); - var oldIndex = allDisplayedColumns.indexOf(col); - if (oldIndex < (allDisplayedColumns.length - 1)) { - return allDisplayedColumns[oldIndex + 1]; - } - return null; + DefaultDateComponent.prototype.setDate = function (date) { + this.eDateInput.setValue(Object(_utils_date__WEBPACK_IMPORTED_MODULE_2__["serialiseDate"])(date, false)); }; - ColumnController.prototype.getDisplayedGroupAfter = function (columnGroup) { - return this.getDisplayedGroupAtDirection(columnGroup, 'After'); + DefaultDateComponent.prototype.setInputPlaceholder = function (placeholder) { + this.eDateInput.setInputPlaceholder(placeholder); }; - ColumnController.prototype.getDisplayedGroupBefore = function (columnGroup) { - return this.getDisplayedGroupAtDirection(columnGroup, 'Before'); + DefaultDateComponent.prototype.setDisabled = function (disabled) { + this.eDateInput.setDisabled(disabled); }; - ColumnController.prototype.getDisplayedGroupAtDirection = function (columnGroup, direction) { - // pick the last displayed column in this group - var requiredLevel = columnGroup.getOriginalColumnGroup().getLevel() + columnGroup.getPaddingLevel(); - var colGroupLeafColumns = columnGroup.getDisplayedLeafColumns(); - var col = direction === 'After' ? _utils__WEBPACK_IMPORTED_MODULE_9__["_"].last(colGroupLeafColumns) : colGroupLeafColumns[0]; - var getDisplayColMethod = "getDisplayedCol" + direction; - while (true) { - // keep moving to the next col, until we get to another group - var column = this[getDisplayColMethod](col); - if (!column) { - return null; - } - var groupPointer = this.getColumnGroupAtLevel(column, requiredLevel); - if (groupPointer !== columnGroup) { - return groupPointer; - } + DefaultDateComponent.prototype.afterGuiAttached = function (params) { + if (!params || !params.suppressFocus) { + this.eDateInput.getInputElement().focus(); } }; - ColumnController.prototype.getColumnGroupAtLevel = function (column, level) { - // get group at same level as the one we are looking for - var groupPointer = column.getParent(); - var originalGroupLevel; - var groupPointerLevel; - while (true) { - var groupPointerOriginalColumnGroup = groupPointer.getOriginalColumnGroup(); - originalGroupLevel = groupPointerOriginalColumnGroup.getLevel(); - groupPointerLevel = groupPointer.getPaddingLevel(); - if (originalGroupLevel + groupPointerLevel <= level) { - break; - } - groupPointer = groupPointer.getParent(); + DefaultDateComponent.prototype.shouldUseBrowserDatePicker = function (params) { + if (params.filterParams && params.filterParams.browserDatePicker != null) { + return params.filterParams.browserDatePicker; } - return groupPointer; + return Object(_utils_browser__WEBPACK_IMPORTED_MODULE_3__["isBrowserChrome"])() || Object(_utils_browser__WEBPACK_IMPORTED_MODULE_3__["isBrowserFirefox"])(); }; - ColumnController.prototype.isPinningLeft = function () { - return this.displayedLeftColumns.length > 0; + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eDateInput') + ], DefaultDateComponent.prototype, "eDateInput", void 0); + return DefaultDateComponent; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); + + + +/***/ }), +/* 76 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NumberFilter", function() { return NumberFilter; }); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57); +/* harmony import */ var _simpleFilter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(60); +/* harmony import */ var _scalarFilter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(72); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(43); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - ColumnController.prototype.isPinningRight = function () { - return this.displayedRightColumns.length > 0; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - ColumnController.prototype.getPrimaryAndSecondaryAndAutoColumns = function () { - var result = this.primaryColumns ? this.primaryColumns.slice(0) : []; - if (this.groupAutoColumns && _utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(this.groupAutoColumns)) { - this.groupAutoColumns.forEach(function (col) { return result.push(col); }); - } - if (this.secondaryColumnsPresent && this.secondaryColumns) { - this.secondaryColumns.forEach(function (column) { return result.push(column); }); - } - return result; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + +var NumberFilter = /** @class */ (function (_super) { + __extends(NumberFilter, _super); + function NumberFilter() { + return _super.call(this, 'numberFilter') || this; + } + NumberFilter.prototype.mapValuesFromModel = function (filterModel) { + var _a = filterModel || {}, filter = _a.filter, filterTo = _a.filterTo, type = _a.type; + return [ + filter == null ? null : filter, + filterTo == null ? null : filterTo, + ].slice(0, this.getNumberOfInputs(type)); }; - ColumnController.prototype.createStateItemFromColumn = function (column) { - var rowGroupIndex = column.isRowGroupActive() ? this.rowGroupColumns.indexOf(column) : null; - var pivotIndex = column.isPivotActive() ? this.pivotColumns.indexOf(column) : null; - var aggFunc = column.isValueActive() ? column.getAggFunc() : null; - return { - colId: column.getColId(), - hide: !column.isVisible(), - aggFunc: aggFunc, - width: column.getActualWidth(), - pivotIndex: pivotIndex, - pinned: column.getPinned(), - rowGroupIndex: rowGroupIndex, - flex: column.getFlex() + NumberFilter.prototype.getDefaultDebounceMs = function () { + return 500; + }; + NumberFilter.prototype.comparator = function () { + return function (left, right) { + if (left === right) { + return 0; + } + return left < right ? 1 : -1; }; }; - ColumnController.prototype.getColumnState = function () { - if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].missing(this.primaryColumns)) { - return []; - } - var primaryColumnState = this.primaryColumns.map(this.createStateItemFromColumn.bind(this)); - var groupAutoColumnState = this.groupAutoColumns - // if groupAutoCols, then include them - ? this.groupAutoColumns.map(this.createStateItemFromColumn.bind(this)) - // otherwise no - : []; - var columnStateList = groupAutoColumnState.concat(primaryColumnState); - if (!this.pivotMode) { - this.orderColumnStateList(columnStateList); + NumberFilter.prototype.setParams = function (params) { + this.numberFilterParams = params; + var allowedCharPattern = this.getAllowedCharPattern(); + if (allowedCharPattern) { + var config = { allowedCharPattern: allowedCharPattern }; + this.resetTemplate({ + 'eValue-index0-1': config, + 'eValue-index1-1': config, + 'eValue-index0-2': config, + 'eValue-index1-2': config, + }); } - return columnStateList; + _super.prototype.setParams.call(this, params); }; - ColumnController.prototype.orderColumnStateList = function (columnStateList) { - var gridColumnIds = this.gridColumns.map(function (column) { return column.getColId(); }); - columnStateList.sort(function (itemA, itemB) { - var posA = gridColumnIds.indexOf(itemA.colId); - var posB = gridColumnIds.indexOf(itemB.colId); - return posA - posB; - }); + NumberFilter.prototype.getDefaultFilterOptions = function () { + return NumberFilter.DEFAULT_FILTER_OPTIONS; }; - ColumnController.prototype.resetColumnState = function (suppressEverythingEvent, source) { - // NOTE = there is one bug here that no customer has noticed - if a column has colDef.lockPosition, - // this is ignored below when ordering the cols. to work, we should always put lockPosition cols first. - // As a work around, developers should just put lockPosition columns first in their colDef list. - if (suppressEverythingEvent === void 0) { suppressEverythingEvent = false; } - if (source === void 0) { source = "api"; } - // we can't use 'allColumns' as the order might of messed up, so get the primary ordered list - var primaryColumns = this.getColumnsFromTree(this.primaryColumnTree); - var columnStates = []; - // we start at 1000, so if user has mix of rowGroup and group specified, it will work with both. - // eg IF user has ColA.rowGroupIndex=0, ColB.rowGroupIndex=1, ColC.rowGroup=true, - // THEN result will be ColA.rowGroupIndex=0, ColB.rowGroupIndex=1, ColC.rowGroup=1000 - var letRowGroupIndex = 1000; - var letPivotIndex = 1000; - if (primaryColumns) { - primaryColumns.forEach(function (column) { - var rowGroupIndex = column.getColDef().rowGroupIndex; - var rowGroup = column.getColDef().rowGroup; - var pivotIndex = column.getColDef().pivotIndex; - var pivot = column.getColDef().pivot; - var stateItem = { - colId: column.getColId(), - aggFunc: column.getColDef().aggFunc, - hide: column.getColDef().hide, - pinned: column.getColDef().pinned, - rowGroupIndex: rowGroupIndex, - pivotIndex: column.getColDef().pivotIndex, - width: column.getColDef().width - }; - if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].missing(rowGroupIndex) && rowGroup) { - stateItem.rowGroupIndex = letRowGroupIndex++; - } - if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].missing(pivotIndex) && pivot) { - stateItem.pivotIndex = letPivotIndex++; - } - columnStates.push(stateItem); - }); - } - this.setColumnState(columnStates, suppressEverythingEvent, source); + NumberFilter.prototype.createValueTemplate = function (position) { + var pos = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One ? '1' : '2'; + var allowedCharPattern = this.getAllowedCharPattern(); + var agElementTag = allowedCharPattern ? 'ag-input-text-field' : 'ag-input-number-field'; + return /* html */ "\n
\n <" + agElementTag + " class=\"ag-filter-from ag-filter-filter\" ref=\"eValue-index0-" + pos + "\">\n <" + agElementTag + " class=\"ag-filter-to ag-filter-filter\" ref=\"eValue-index1-" + pos + "\">\n
"; }; - ColumnController.prototype.setColumnState = function (columnStates, suppressEverythingEvent, source) { + NumberFilter.prototype.getValues = function (position) { var _this = this; - if (suppressEverythingEvent === void 0) { suppressEverythingEvent = false; } - if (source === void 0) { source = "api"; } - if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].missingOrEmpty(this.primaryColumns)) { - return false; - } - var columnStateBefore = this.getColumnState(); - this.autoGroupsNeedBuilding = true; - // at the end below, this list will have all columns we got no state for - var columnsWithNoState = this.primaryColumns.slice(); - this.rowGroupColumns = []; - this.valueColumns = []; - this.pivotColumns = []; - var success = true; - var rowGroupIndexes = {}; - var pivotIndexes = {}; - var autoGroupColumnStates = []; - if (columnStates) { - columnStates.forEach(function (state) { - // auto group columns are re-created so deferring syncing with ColumnState - if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(_this.getAutoColumn(state.colId))) { - autoGroupColumnStates.push(state); - return; - } - var column = _this.getPrimaryColumn(state.colId); - if (!column) { - console.warn('ag-grid: column ' + state.colId + ' not found'); - success = false; - } - else { - _this.syncColumnWithStateItem(column, state, rowGroupIndexes, pivotIndexes, source); - _utils__WEBPACK_IMPORTED_MODULE_9__["_"].removeFromArray(columnsWithNoState, column); - } - }); - if (this.flexActive) { - this.refreshFlexedColumns(undefined, undefined, true); + var result = []; + this.forEachInput(function (element, index, elPosition, numberOfInputs) { + if (position === elPosition && index < numberOfInputs) { + result.push(_this.stringToFloat(element.getValue())); } - } - // anything left over, we got no data for, so add in the column as non-value, non-rowGroup and hidden - columnsWithNoState.forEach(this.syncColumnWithNoState.bind(this)); - // sort the lists according to the indexes that were provided - this.rowGroupColumns.sort(this.sortColumnListUsingIndexes.bind(this, rowGroupIndexes)); - this.pivotColumns.sort(this.sortColumnListUsingIndexes.bind(this, pivotIndexes)); - this.updateGridColumns(); - // sync newly created auto group columns with ColumnState - autoGroupColumnStates.forEach(function (stateItem) { - var autoCol = _this.getAutoColumn(stateItem.colId); - _this.syncColumnWithStateItem(autoCol, stateItem, rowGroupIndexes, pivotIndexes, source); }); - if (columnStates) { - var orderOfColIds_1 = columnStates.map(function (stateItem) { return stateItem.colId; }); - this.gridColumns.sort(function (colA, colB) { - var indexA = orderOfColIds_1.indexOf(colA.getId()); - var indexB = orderOfColIds_1.indexOf(colB.getId()); - return indexA - indexB; - }); + return result; + }; + NumberFilter.prototype.areSimpleModelsEqual = function (aSimple, bSimple) { + return aSimple.filter === bSimple.filter + && aSimple.filterTo === bSimple.filterTo + && aSimple.type === bSimple.type; + }; + NumberFilter.prototype.getFilterType = function () { + return 'number'; + }; + NumberFilter.prototype.stringToFloat = function (value) { + if (typeof value === 'number') { + return value; } - // this is already done in updateGridColumns, however we changed the order above (to match the order of the state - // columns) so we need to do it again. we could of put logic into the order above to take into account fixed - // columns, however if we did then we would have logic for updating fixed columns twice. reusing the logic here - // is less sexy for the code here, but it keeps consistency. - this.putFixedColumnsFirst(); - this.updateDisplayedColumns(source); - if (!suppressEverythingEvent) { - var event_7 = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_EVERYTHING_CHANGED, - api: this.gridApi, - columnApi: this.columnApi, - source: source - }; - this.eventService.dispatchEvent(event_7); + var filterText = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["makeNull"])(value); + if (filterText != null && filterText.trim() === '') { + filterText = null; } - this.raiseColumnEvents(columnStateBefore, source); - return success; - }; - ColumnController.prototype.raiseColumnEvents = function (columnStateBefore, source) { - var _this = this; - if (this.gridOptionsWrapper.isSuppressSetColumnStateEvents()) { - return; + if (this.numberFilterParams.numberParser) { + return this.numberFilterParams.numberParser(filterText); } - var columnStateAfter = this.getColumnState(); - // raises generic ColumnEvents where all columns are returned rather than what has changed - var raiseEventWithAllColumns = function (eventType, idMapper, columns) { - var unchanged = Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["areEqual"])(columnStateBefore.map(idMapper).sort(), columnStateAfter.map(idMapper).sort()); - if (unchanged) { - return; - } - // returning all columns rather than what has changed! - var event = { - type: eventType, - columns: columns, - column: columns.length === 1 ? columns[0] : null, - api: _this.gridApi, - columnApi: _this.columnApi, - source: source - }; - _this.eventService.dispatchEvent(event); + return filterText == null || filterText.trim() === '-' ? null : parseFloat(filterText); + }; + NumberFilter.prototype.createCondition = function (position) { + var type = this.getConditionTypes()[position]; + var model = { + filterType: this.getFilterType(), + type: type }; - // determines which columns have changed according to supplied predicate - var getChangedColumns = function (changedPredicate) { - var changedColumns = []; - var columnStateBeforeMap = {}; - columnStateBefore.forEach(function (col) { - columnStateBeforeMap[col.colId] = col; - }); - _this.gridColumns.forEach(function (column) { - var colStateBefore = columnStateBeforeMap[column.getColId()]; - if (!colStateBefore || changedPredicate(colStateBefore, column)) { - changedColumns.push(column); - } - }); - return changedColumns; - }; - // generic ColumnEvents which return current column list - var valueColumnIdMapper = function (cs) { return cs.colId + '-' + cs.aggFunc; }; - raiseEventWithAllColumns(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VALUE_CHANGED, valueColumnIdMapper, this.valueColumns); - var pivotColumnIdMapper = function (cs) { return cs.colId + '-' + cs.pivotIndex; }; - raiseEventWithAllColumns(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_CHANGED, pivotColumnIdMapper, this.pivotColumns); - var rowGroupColumnIdMapper = function (cs) { return cs.colId + '-' + cs.rowGroupIndex; }; - raiseEventWithAllColumns(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, rowGroupColumnIdMapper, this.rowGroupColumns); - // specific ColumnEvents which return what's changed - var pinnedChangePredicate = function (cs, c) { return cs.pinned !== c.getPinned(); }; - this.raiseColumnPinnedEvent(getChangedColumns(pinnedChangePredicate), source); - var visibilityChangePredicate = function (cs, c) { return cs.hide === c.isVisible(); }; - var cols = getChangedColumns(visibilityChangePredicate); - this.raiseColumnVisibleEvent(cols, source); - var resizeChangePredicate = function (cs, c) { return cs.width !== c.getActualWidth(); }; - this.raiseColumnResizeEvent(getChangedColumns(resizeChangePredicate), source); - // special handling for moved column events - this.raiseColumnMovedEvent(columnStateBefore, source); - }; - ColumnController.prototype.raiseColumnPinnedEvent = function (changedColumns, source) { - if (!changedColumns.length) { - return; + var values = this.getValues(position); + if (values.length > 0) { + model.filter = values[0]; } - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PINNED, - pinned: null, - columns: changedColumns, - column: null, - api: this.gridApi, - columnApi: this.columnApi, - source: source - }; - this.eventService.dispatchEvent(event); - }; - ColumnController.prototype.raiseColumnVisibleEvent = function (changedColumns, source) { - if (!changedColumns.length) { - return; + if (values.length > 1) { + model.filterTo = values[1]; } - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VISIBLE, - visible: undefined, - columns: changedColumns, - column: null, - api: this.gridApi, - columnApi: this.columnApi, - source: source - }; - this.eventService.dispatchEvent(event); + return model; }; - ColumnController.prototype.raiseColumnResizeEvent = function (changedColumns, source) { - if (!changedColumns.length) { - return; - } - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_RESIZED, - columns: changedColumns, - column: null, - finished: true, - api: this.gridApi, - columnApi: this.columnApi, - source: source - }; - this.eventService.dispatchEvent(event); + NumberFilter.prototype.getInputs = function () { + return [ + [this.eValueFrom1, this.eValueTo1], + [this.eValueFrom2, this.eValueTo2], + ]; }; - ColumnController.prototype.raiseColumnMovedEvent = function (columnStateBefore, source) { - var movedColumns = []; - var columnStateAfter = this.getColumnState(); - var _loop_3 = function (i) { - var before = columnStateBefore[i]; - var after = columnStateAfter[i]; - // don't consider column if reintroduced or hidden - if (!before || after.hide) { - return "continue"; - } - if (before.colId !== after.colId) { - var predicate = function (column) { return column.getColId() === after.colId; }; - var movedColumn = _utils__WEBPACK_IMPORTED_MODULE_9__["_"].find(this_1.allDisplayedColumns, predicate); - movedColumns.push(movedColumn); - } - }; - var this_1 = this; - for (var i = 0; i < columnStateAfter.length; i++) { - _loop_3(i); + NumberFilter.prototype.getAllowedCharPattern = function () { + var allowedCharPattern = (this.numberFilterParams || {}).allowedCharPattern; + if (allowedCharPattern) { + return allowedCharPattern; } - if (!movedColumns.length) { - return; + if (!Object(_utils_browser__WEBPACK_IMPORTED_MODULE_4__["isBrowserChrome"])() && !Object(_utils_browser__WEBPACK_IMPORTED_MODULE_4__["isBrowserEdge"])()) { + // only Chrome and Edge support the HTML5 number field, so for other browsers we provide an equivalent + // constraint instead + return '\\d\\-\\.'; } - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_MOVED, - columns: movedColumns, - column: null, - toIndex: undefined, - api: this.gridApi, - columnApi: this.columnApi, - source: source - }; - this.eventService.dispatchEvent(event); + return null; }; - ColumnController.prototype.sortColumnListUsingIndexes = function (indexes, colA, colB) { - var indexA = indexes[colA.getId()]; - var indexB = indexes[colB.getId()]; - return indexA - indexB; + NumberFilter.DEFAULT_FILTER_OPTIONS = [ + _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].EQUALS, + _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].NOT_EQUAL, + _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].LESS_THAN, + _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].LESS_THAN_OR_EQUAL, + _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].GREATER_THAN, + _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].GREATER_THAN_OR_EQUAL, + _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].IN_RANGE, + _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].BLANK, + _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].NOT_BLANK, + ]; + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValue-index0-1') + ], NumberFilter.prototype, "eValueFrom1", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValue-index1-1') + ], NumberFilter.prototype, "eValueTo1", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValue-index0-2') + ], NumberFilter.prototype, "eValueFrom2", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValue-index1-2') + ], NumberFilter.prototype, "eValueTo2", void 0); + return NumberFilter; +}(_scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"])); + + + +/***/ }), +/* 77 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NumberFloatingFilter", function() { return NumberFloatingFilter; }); +/* harmony import */ var _numberFilter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(76); +/* harmony import */ var _floating_provided_textInputFloatingFilter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(78); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - ColumnController.prototype.syncColumnWithNoState = function (column, source) { - column.setVisible(false, source); - column.setAggFunc(null); - column.setPinned(null); - column.setRowGroupActive(false, source); - column.setPivotActive(false, source); - column.setValueActive(false, source); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - ColumnController.prototype.syncColumnWithStateItem = function (column, stateItem, rowGroupIndexes, pivotIndexes, source) { - if (!column) { - return; - } - // following ensures we are left with boolean true or false, eg converts (null, undefined, 0) all to true - column.setVisible(!stateItem.hide, source); - // sets pinned to 'left' or 'right' - column.setPinned(stateItem.pinned); - // if width provided and valid, use it, otherwise stick with the old width - var minColWidth = this.gridOptionsWrapper.getMinColWidth(); - if (stateItem.flex != null) { - column.setFlex(stateItem.flex); - if (!this.flexActive && stateItem.flex) { - this.flexActive = true; - } - } - if (stateItem.width && minColWidth && - (stateItem.width >= minColWidth)) { - column.setActualWidth(stateItem.width, source); - } - if (typeof stateItem.aggFunc === 'string') { - column.setAggFunc(stateItem.aggFunc); - column.setValueActive(true, source); - this.valueColumns.push(column); - } - else { - if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(stateItem.aggFunc)) { - console.warn('ag-Grid: stateItem.aggFunc must be a string. if using your own aggregation ' + - 'functions, register the functions first before using them in get/set state. This is because it is ' + - 'intended for the column state to be stored and retrieved as simple JSON.'); - } - column.setAggFunc(null); - column.setValueActive(false, source); - } - if (typeof stateItem.rowGroupIndex === 'number') { - this.rowGroupColumns.push(column); - column.setRowGroupActive(true, source); - rowGroupIndexes[column.getId()] = stateItem.rowGroupIndex; - } - else { - column.setRowGroupActive(false, source); - } - if (typeof stateItem.pivotIndex === 'number') { - this.pivotColumns.push(column); - column.setPivotActive(true, source); - pivotIndexes[column.getId()] = stateItem.pivotIndex; - } - else { - column.setPivotActive(false, source); - } +})(); + + +var NumberFloatingFilter = /** @class */ (function (_super) { + __extends(NumberFloatingFilter, _super); + function NumberFloatingFilter() { + return _super !== null && _super.apply(this, arguments) || this; + } + NumberFloatingFilter.prototype.getDefaultFilterOptions = function () { + return _numberFilter__WEBPACK_IMPORTED_MODULE_0__["NumberFilter"].DEFAULT_FILTER_OPTIONS; }; - ColumnController.prototype.getGridColumns = function (keys) { - return this.getColumns(keys, this.getGridColumn.bind(this)); + return NumberFloatingFilter; +}(_floating_provided_textInputFloatingFilter__WEBPACK_IMPORTED_MODULE_1__["TextInputFloatingFilter"])); + + + +/***/ }), +/* 78 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TextInputFloatingFilter", function() { return TextInputFloatingFilter; }); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(14); +/* harmony import */ var _provided_providedFilter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(62); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(12); +/* harmony import */ var _simpleFloatingFilter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(74); +/* harmony import */ var _provided_simpleFilter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(60); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(65); +/* harmony import */ var _provided_text_textFilter__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(79); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - ColumnController.prototype.getColumns = function (keys, columnLookupCallback) { - var foundColumns = []; - if (keys) { - keys.forEach(function (key) { - var column = columnLookupCallback(key); - if (column) { - foundColumns.push(column); - } - }); - } - return foundColumns; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + + +var TextInputFloatingFilter = /** @class */ (function (_super) { + __extends(TextInputFloatingFilter, _super); + function TextInputFloatingFilter() { + return _super !== null && _super.apply(this, arguments) || this; + } + TextInputFloatingFilter.prototype.postConstruct = function () { + this.resetTemplate(); }; - // used by growGroupPanel - ColumnController.prototype.getColumnWithValidation = function (key) { - if (key == null) { - return null; - } - var column = this.getGridColumn(key); - if (!column) { - console.warn('ag-Grid: could not find column ' + key); - } - return column; + TextInputFloatingFilter.prototype.resetTemplate = function (paramsMap) { + this.setTemplate(/* html */ "\n
\n \n
\n ", paramsMap); }; - ColumnController.prototype.getPrimaryColumn = function (key) { - return this.getColumn(key, this.primaryColumns); + TextInputFloatingFilter.prototype.getDefaultDebounceMs = function () { + return 500; }; - ColumnController.prototype.getGridColumn = function (key) { - return this.getColumn(key, this.gridColumns); + TextInputFloatingFilter.prototype.onParentModelChanged = function (model, event) { + if (this.isEventFromFloatingFilter(event)) { + // if the floating filter triggered the change, it is already in sync + return; + } + this.setLastTypeFromModel(model); + this.eFloatingFilterInput.setValue(this.getTextFromModel(model)); + this.setEditable(this.canWeEditAfterModelFromParentFilter(model)); }; - ColumnController.prototype.getColumn = function (key, columnList) { - if (!key) { - return null; + TextInputFloatingFilter.prototype.init = function (params) { + _super.prototype.init.call(this, params); + this.params = params; + this.applyActive = _provided_providedFilter__WEBPACK_IMPORTED_MODULE_2__["ProvidedFilter"].isUseApplyButton(this.params.filterParams); + var allowedCharPattern = this.params.filterParams.allowedCharPattern; + if (allowedCharPattern != null) { + this.resetTemplate({ eFloatingFilterInput: { allowedCharPattern: allowedCharPattern } }); + } + if (!this.isReadOnly()) { + var debounceMs = _provided_providedFilter__WEBPACK_IMPORTED_MODULE_2__["ProvidedFilter"].getDebounceMs(this.params.filterParams, this.getDefaultDebounceMs()); + var toDebounce = Object(_utils_function__WEBPACK_IMPORTED_MODULE_1__["debounce"])(this.syncUpWithParentFilter.bind(this), debounceMs); + var filterGui = this.eFloatingFilterInput.getGui(); + this.addManagedListener(filterGui, 'input', toDebounce); + this.addManagedListener(filterGui, 'keypress', toDebounce); + this.addManagedListener(filterGui, 'keydown', toDebounce); } - for (var i = 0; i < columnList.length; i++) { - if (this.columnsMatch(columnList[i], key)) { - return columnList[i]; - } + var columnDef = params.column.getDefinition(); + if (this.isReadOnly() || (columnDef.filterParams && + columnDef.filterParams.filterOptions && + columnDef.filterParams.filterOptions.length === 1 && + columnDef.filterParams.filterOptions[0] === 'inRange')) { + this.eFloatingFilterInput.setDisabled(true); } - return this.getAutoColumn(key); + var displayName = this.columnModel.getDisplayNameForColumn(params.column, 'header', true); + var translate = this.gridOptionsWrapper.getLocaleTextFunc(); + this.eFloatingFilterInput.setInputAriaLabel(displayName + " " + translate('ariaFilterInput', 'Filter Input')); }; - ColumnController.prototype.getAutoColumn = function (key) { + TextInputFloatingFilter.prototype.syncUpWithParentFilter = function (e) { var _this = this; - if (!this.groupAutoColumns || - !_utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(this.groupAutoColumns) || - _utils__WEBPACK_IMPORTED_MODULE_9__["_"].missing(this.groupAutoColumns)) { - return null; + var enterKeyPressed = e.key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_6__["KeyCode"].ENTER; + if (this.applyActive && !enterKeyPressed) { + return; } - return _utils__WEBPACK_IMPORTED_MODULE_9__["_"].find(this.groupAutoColumns, function (groupCol) { return _this.columnsMatch(groupCol, key); }); - }; - ColumnController.prototype.columnsMatch = function (column, key) { - var columnMatches = column === key; - var colDefMatches = column.getColDef() === key; - var idMatches = column.getColId() == key; - return columnMatches || colDefMatches || idMatches; + var value = this.eFloatingFilterInput.getValue(); + if (this.params.filterParams.trimInput) { + value = _provided_text_textFilter__WEBPACK_IMPORTED_MODULE_7__["TextFilter"].trimInput(value); + this.eFloatingFilterInput.setValue(value, true); // ensure visible value is trimmed + } + this.params.parentFilterInstance(function (filterInstance) { + if (filterInstance) { + filterInstance.onFloatingFilterChanged(_this.getLastType() || null, value || null); + } + }); }; - ColumnController.prototype.getDisplayNameForColumn = function (column, location, includeAggFunc) { - if (includeAggFunc === void 0) { includeAggFunc = false; } - if (!column) { - return null; + TextInputFloatingFilter.prototype.conditionToString = function (condition, options) { + var numberOfInputs = (options || {}).numberOfInputs; + var isRange = condition.type == _provided_simpleFilter__WEBPACK_IMPORTED_MODULE_5__["SimpleFilter"].IN_RANGE || numberOfInputs === 2; + if (isRange) { + return condition.filter + "-" + condition.filterTo; } - var headerName = this.getHeaderName(column.getColDef(), column, null, null, location); - if (includeAggFunc) { - return this.wrapHeaderNameWithAggFunc(column, headerName); + // cater for when the type doesn't need a value + if (condition.filter != null) { + return "" + condition.filter; } - return headerName; + return "" + condition.type; }; - ColumnController.prototype.getDisplayNameForOriginalColumnGroup = function (columnGroup, originalColumnGroup, location) { - var colGroupDef = originalColumnGroup ? originalColumnGroup.getColGroupDef() : null; - if (colGroupDef) { - return this.getHeaderName(colGroupDef, null, columnGroup, originalColumnGroup, location); - } - return null; + TextInputFloatingFilter.prototype.setEditable = function (editable) { + this.eFloatingFilterInput.setDisabled(!editable); }; - ColumnController.prototype.getDisplayNameForColumnGroup = function (columnGroup, location) { - return this.getDisplayNameForOriginalColumnGroup(columnGroup, columnGroup.getOriginalColumnGroup(), location); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('columnModel') + ], TextInputFloatingFilter.prototype, "columnModel", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eFloatingFilterInput') + ], TextInputFloatingFilter.prototype, "eFloatingFilterInput", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"] + ], TextInputFloatingFilter.prototype, "postConstruct", null); + return TextInputFloatingFilter; +}(_simpleFloatingFilter__WEBPACK_IMPORTED_MODULE_4__["SimpleFloatingFilter"])); + + + +/***/ }), +/* 79 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TextFilter", function() { return TextFilter; }); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57); +/* harmony import */ var _simpleFilter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(60); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - // location is where the column is going to appear, ie who is calling us - ColumnController.prototype.getHeaderName = function (colDef, column, columnGroup, originalColumnGroup, location) { - var headerValueGetter = colDef.headerValueGetter; - if (headerValueGetter) { - var params = { - colDef: colDef, - column: column, - columnGroup: columnGroup, - originalColumnGroup: originalColumnGroup, - location: location, - api: this.gridOptionsWrapper.getApi(), - context: this.gridOptionsWrapper.getContext() - }; - if (typeof headerValueGetter === 'function') { - // valueGetter is a function, so just call it - return headerValueGetter(params); - } - else if (typeof headerValueGetter === 'string') { - // valueGetter is an expression, so execute the expression - return this.expressionService.evaluate(headerValueGetter, params); - } - console.warn('ag-grid: headerValueGetter must be a function or a string'); - return ''; - } - else if (colDef.headerName != null) { - return colDef.headerName; - } - else if (colDef.field) { - return _utils__WEBPACK_IMPORTED_MODULE_9__["_"].camelCaseToHumanText(colDef.field); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __assign = (undefined && undefined.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; } - return ''; + return t; }; - /* - private getHeaderGroupName(columnGroup: ColumnGroup): string { - let colGroupDef = columnGroup.getOriginalColumnGroup().getColGroupDef(); - let headerValueGetter = colGroupDef.headerValueGetter; + return __assign.apply(this, arguments); +}; +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; - if (headerValueGetter) { - let params = { - columnGroup: columnGroup, - colDef: colGroupDef, - api: this.gridOptionsWrapper.getApi(), - context: this.gridOptionsWrapper.getContext() - }; - if (typeof headerValueGetter === 'function') { - // valueGetter is a function, so just call it - return headerValueGetter(params); - } else if (typeof headerValueGetter === 'string') { - // valueGetter is an expression, so execute the expression - return this.expressionService.evaluate(headerValueGetter, params); - } else { - console.warn('ag-grid: headerValueGetter must be a function or a string'); - return ''; - } - } else { - return colGroupDef.headerName; - } - } - */ - ColumnController.prototype.wrapHeaderNameWithAggFunc = function (column, headerName) { - if (this.gridOptionsWrapper.isSuppressAggFuncInHeader()) { - return headerName; - } - // only columns with aggregation active can have aggregations - var pivotValueColumn = column.getColDef().pivotValueColumn; - var pivotActiveOnThisColumn = _utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(pivotValueColumn); - var aggFunc = null; - var aggFuncFound; - // otherwise we have a measure that is active, and we are doing aggregation on it - if (pivotActiveOnThisColumn) { - aggFunc = pivotValueColumn ? pivotValueColumn.getAggFunc() : null; - aggFuncFound = true; - } - else { - var measureActive = column.isValueActive(); - var aggregationPresent = this.pivotMode || !this.isRowGroupEmpty(); - if (measureActive && aggregationPresent) { - aggFunc = column.getAggFunc(); - aggFuncFound = true; - } - else { - aggFuncFound = false; - } - } - if (aggFuncFound) { - var aggFuncString = (typeof aggFunc === 'string') ? aggFunc : 'func'; - var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc(); - var aggFuncStringTranslated = localeTextFunc(aggFuncString, aggFuncString); - return aggFuncStringTranslated + "(" + headerName + ")"; + + +var TextFilter = /** @class */ (function (_super) { + __extends(TextFilter, _super); + function TextFilter() { + return _super.call(this, 'textFilter') || this; + } + TextFilter.trimInput = function (value) { + var trimmedInput = value && value.trim(); + // trim the input, unless it is all whitespace (this is consistent with Excel behaviour) + return trimmedInput === '' ? value : trimmedInput; + }; + TextFilter.prototype.getDefaultDebounceMs = function () { + return 500; + }; + TextFilter.prototype.setParams = function (params) { + _super.prototype.setParams.call(this, params); + this.textFilterParams = params; + this.matcher = this.getTextMatcher(); + this.formatter = this.textFilterParams.textFormatter || + (this.textFilterParams.caseSensitive ? TextFilter.DEFAULT_FORMATTER : TextFilter.DEFAULT_LOWERCASE_FORMATTER); + }; + TextFilter.prototype.getTextMatcher = function () { + var legacyComparator = this.textFilterParams.textCustomComparator; + if (legacyComparator) { + _utils__WEBPACK_IMPORTED_MODULE_3__["_"].doOnce(function () { return console.warn('AG Grid - textCustomComparator is deprecated, use textMatcher instead.'); }, 'textCustomComparator.deprecated'); + return function (_a) { + var filterOption = _a.filterOption, value = _a.value, filterText = _a.filterText; + return legacyComparator(filterOption, value, filterText); + }; } - return headerName; + return this.textFilterParams.textMatcher || TextFilter.DEFAULT_MATCHER; }; - // returns the group with matching colId and instanceId. If instanceId is missing, - // matches only on the colId. - ColumnController.prototype.getColumnGroup = function (colId, instanceId) { - if (!colId) { - return null; + TextFilter.prototype.createCondition = function (position) { + var type = this.getConditionTypes()[position]; + var model = { + filterType: this.getFilterType(), + type: type, + }; + var values = this.getValues(position); + if (values.length > 0) { + model.filter = values[0]; } - if (colId instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) { - return colId; + if (values.length > 1) { + model.filterTo = values[1]; } - var allColumnGroups = this.getAllDisplayedColumnGroups(); - var checkInstanceId = typeof instanceId === 'number'; - var result = null; - this.columnUtils.depthFirstAllColumnTreeSearch(allColumnGroups, function (child) { - if (child instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) { - var columnGroup = child; - var matched = void 0; - if (checkInstanceId) { - matched = colId === columnGroup.getGroupId() && instanceId === columnGroup.getInstanceId(); - } - else { - matched = colId === columnGroup.getGroupId(); - } - if (matched) { - result = columnGroup; - } - } - }); - return result; - }; - ColumnController.prototype.isReady = function () { - return this.ready; + return model; }; - ColumnController.prototype.createValueColumns = function (source, oldPrimaryColumns) { - this.valueColumns = this.extractColumns(oldPrimaryColumns, this.valueColumns, function (col, flag) { return col.setValueActive(flag, source); }, - // aggFunc doesn't have index variant, cos order of value cols doesn't matter, so always return null - function () { return null; }, - // aggFunc is a string, so return it's existence - function (colDef) { return !!colDef.aggFunc; }); - // all new columns added will have aggFunc missing, so set it to what is in the colDef - this.valueColumns.forEach(function (col) { - if (!col.getAggFunc()) { - col.setAggFunc(col.getColDef().aggFunc); - } - }); + TextFilter.prototype.getFilterType = function () { + return 'text'; }; - ColumnController.prototype.extractRowGroupColumns = function (source, oldPrimaryColumns) { - this.rowGroupColumns = this.extractColumns(oldPrimaryColumns, this.rowGroupColumns, function (col, flag) { return col.setRowGroupActive(flag, source); }, function (colDef) { return colDef.rowGroupIndex; }, function (colDef) { return colDef.rowGroup; }); + TextFilter.prototype.areSimpleModelsEqual = function (aSimple, bSimple) { + return aSimple.filter === bSimple.filter && + aSimple.filterTo === bSimple.filterTo && + aSimple.type === bSimple.type; + }; + TextFilter.prototype.getInputs = function () { + return [ + [this.eValueFrom1, this.eValueTo1], + [this.eValueFrom2, this.eValueTo2], + ]; }; - ColumnController.prototype.extractColumns = function (oldPrimaryColumns, previousCols, setFlagFunc, getIndexFunc, getValueFunc) { + TextFilter.prototype.getValues = function (position) { var _this = this; - if (!previousCols) { - previousCols = []; - } - // remove cols that no longer exist - var colPresentInPrimaryFunc = function (col) { return _this.primaryColumns.indexOf(col) >= 0; }; - var colMissingFromPrimaryFunc = function (col) { return _this.primaryColumns.indexOf(col) < 0; }; - var colNewFunc = function (col) { return !oldPrimaryColumns || oldPrimaryColumns.indexOf(col) < 0; }; - var removedCols = previousCols.filter(colMissingFromPrimaryFunc); - var existingCols = previousCols.filter(colPresentInPrimaryFunc); - var newPrimaryCols = this.primaryColumns.filter(colNewFunc); - removedCols.forEach(function (col) { return setFlagFunc(col, false); }); - var newCols = []; - // we only want to work on new columns, as old columns already got processed first time around - // pull out items with xxxIndex - newPrimaryCols.forEach(function (col) { - var index = getIndexFunc(col.getColDef()); - if (typeof index === 'number') { - newCols.push(col); - } - }); - // then sort them - newCols.sort(function (colA, colB) { - var indexA = getIndexFunc(colA.getColDef()); - var indexB = getIndexFunc(colB.getColDef()); - if (indexA === indexB) { - return 0; - } - else if (indexA < indexB) { - return -1; - } - return 1; - }); - // now just pull out items xxx (boolean value), they will be added at the end - // after the indexed ones, but in the order the columns appear - newPrimaryCols.forEach(function (col) { - var booleanValue = getValueFunc(col.getColDef()); - if (booleanValue) { - // if user already specified xxxIndex then we skip it as this col already included - if (newCols.indexOf(col) >= 0) { - return; - } - newCols.push(col); + var result = []; + this.forEachInput(function (element, index, elPosition, numberOfInputs) { + if (position === elPosition && index < numberOfInputs) { + var value = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["makeNull"])(element.getValue()); + var cleanValue = (_this.textFilterParams.trimInput ? TextFilter.trimInput(value) : value) || null; + result.push(cleanValue); + element.setValue(cleanValue, true); // ensure clean value is visible } }); - newCols.forEach(function (col) { return setFlagFunc(col, true); }); - var res = existingCols.concat(newCols); - return res; - }; - ColumnController.prototype.extractPivotColumns = function (source, oldPrimaryColumns) { - this.pivotColumns = this.extractColumns(oldPrimaryColumns, this.pivotColumns, function (col, flag) { return col.setPivotActive(flag, source); }, function (colDef) { return colDef.pivotIndex; }, function (colDef) { return colDef.pivot; }); + return result; }; - ColumnController.prototype.resetColumnGroupState = function (source) { - if (source === void 0) { source = "api"; } - var stateItems = []; - this.columnUtils.depthFirstOriginalTreeSearch(null, this.primaryColumnTree, function (child) { - if (child instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"]) { - var groupState = { - groupId: child.getGroupId(), - open: child.getColGroupDef().openByDefault - }; - stateItems.push(groupState); - } - }); - this.setColumnGroupState(stateItems, source); + TextFilter.prototype.getDefaultFilterOptions = function () { + return TextFilter.DEFAULT_FILTER_OPTIONS; }; - ColumnController.prototype.getColumnGroupState = function () { - var columnGroupState = []; - this.columnUtils.depthFirstOriginalTreeSearch(null, this.gridBalancedTree, function (node) { - if (node instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"]) { - var originalColumnGroup = node; - columnGroupState.push({ - groupId: originalColumnGroup.getGroupId(), - open: originalColumnGroup.isExpanded() - }); - } - }); - return columnGroupState; + TextFilter.prototype.createValueTemplate = function (position) { + var pos = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One ? '1' : '2'; + return /* html */ "\n
\n \n \n
"; + }; + TextFilter.prototype.mapValuesFromModel = function (filterModel) { + var _a = filterModel || {}, filter = _a.filter, filterTo = _a.filterTo, type = _a.type; + return [ + filter || null, + filterTo || null, + ].slice(0, this.getNumberOfInputs(type)); + }; + TextFilter.prototype.evaluateNullValue = function (filterType) { + var filterTypesAllowNulls = [ + _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].NOT_EQUAL, _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].NOT_CONTAINS, _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].BLANK, + ]; + return filterType ? filterTypesAllowNulls.indexOf(filterType) >= 0 : false; }; - ColumnController.prototype.setColumnGroupState = function (stateItems, source) { + TextFilter.prototype.evaluateNonNullValue = function (values, cellValue, filterModel, params) { var _this = this; - if (source === void 0) { source = "api"; } - this.columnAnimationService.start(); - var impactedGroups = []; - stateItems.forEach(function (stateItem) { - var groupKey = stateItem.groupId; - var newValue = stateItem.open; - var originalColumnGroup = _this.getOriginalColumnGroup(groupKey); - if (!originalColumnGroup) { - return; - } - if (originalColumnGroup.isExpanded() === newValue) { - return; - } - _this.logger.log('columnGroupOpened(' + originalColumnGroup.getGroupId() + ',' + newValue + ')'); - originalColumnGroup.setExpanded(newValue); - impactedGroups.push(originalColumnGroup); - }); - this.updateGroupsAndDisplayedColumns(source); - this.setFirstRightAndLastLeftPinned(source); - impactedGroups.forEach(function (originalColumnGroup) { - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_GROUP_OPENED, - columnGroup: originalColumnGroup, - api: _this.gridApi, - columnApi: _this.columnApi - }; - _this.eventService.dispatchEvent(event); - }); - this.columnAnimationService.finish(); - }; - // called by headerRenderer - when a header is opened or closed - ColumnController.prototype.setColumnGroupOpened = function (key, newValue, source) { - if (source === void 0) { source = "api"; } - var keyAsString; - if (key instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"]) { - keyAsString = key.getId(); - } - else { - keyAsString = key; - } - this.setColumnGroupState([{ groupId: keyAsString, open: newValue }], source); - }; - ColumnController.prototype.getOriginalColumnGroup = function (key) { - if (key instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"]) { - return key; + var formattedValues = values.map(function (v) { return _this.formatter(v); }) || []; + var cellValueFormatted = this.formatter(cellValue); + var _a = this.textFilterParams, api = _a.api, colDef = _a.colDef, column = _a.column, columnApi = _a.columnApi, context = _a.context, textFormatter = _a.textFormatter; + if (filterModel.type === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].BLANK) { + return this.isBlank(cellValue); } - if (typeof key !== 'string') { - console.error('ag-Grid: group key must be a string'); + else if (filterModel.type === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].NOT_BLANK) { + return !this.isBlank(cellValue); } - // otherwise, search for the column group by id - var res = null; - this.columnUtils.depthFirstOriginalTreeSearch(null, this.gridBalancedTree, function (node) { - if (node instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"]) { - var originalColumnGroup = node; - if (originalColumnGroup.getId() === key) { - res = originalColumnGroup; - } - } - }); - return res; + var matcherParams = { + api: api, + colDef: colDef, + column: column, + columnApi: columnApi, + context: context, + node: params.node, + data: params.data, + filterOption: filterModel.type, + value: cellValueFormatted, + textFormatter: textFormatter, + }; + return formattedValues.some(function (v) { return _this.matcher(__assign(__assign({}, matcherParams), { filterText: v })); }); }; - ColumnController.prototype.calculateColumnsForDisplay = function () { - var _this = this; - var columnsForDisplay; - if (this.pivotMode && !this.secondaryColumnsPresent) { - // pivot mode is on, but we are not pivoting, so we only - // show columns we are aggregating on - columnsForDisplay = this.gridColumns.filter(function (column) { - var isAutoGroupCol = _this.groupAutoColumns && _utils__WEBPACK_IMPORTED_MODULE_9__["_"].includes(_this.groupAutoColumns, column); - var isValueCol = _this.valueColumns && _utils__WEBPACK_IMPORTED_MODULE_9__["_"].includes(_this.valueColumns, column); - return isAutoGroupCol || isValueCol; - }); + TextFilter.DEFAULT_FILTER_OPTIONS = [ + _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].CONTAINS, + _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].NOT_CONTAINS, + _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].EQUALS, + _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].NOT_EQUAL, + _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].STARTS_WITH, + _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].ENDS_WITH, + _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].BLANK, + _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].NOT_BLANK, + ]; + TextFilter.DEFAULT_FORMATTER = function (from) { return from; }; + TextFilter.DEFAULT_LOWERCASE_FORMATTER = function (from) { return from == null ? null : from.toString().toLowerCase(); }; + TextFilter.DEFAULT_MATCHER = function (_a) { + var filterOption = _a.filterOption, value = _a.value, filterText = _a.filterText; + if (filterText == null) { + return false; } - else { - // otherwise continue as normal. this can be working on the primary - // or secondary columns, whatever the gridColumns are set to - columnsForDisplay = this.gridColumns.filter(function (column) { - // keep col if a) it's auto-group or b) it's visible - var isAutoGroupCol = _this.groupAutoColumns && _utils__WEBPACK_IMPORTED_MODULE_9__["_"].includes(_this.groupAutoColumns, column); - return isAutoGroupCol || column.isVisible(); - }); + switch (filterOption) { + case TextFilter.CONTAINS: + return value.indexOf(filterText) >= 0; + case TextFilter.NOT_CONTAINS: + return value.indexOf(filterText) < 0; + case TextFilter.EQUALS: + return value === filterText; + case TextFilter.NOT_EQUAL: + return value != filterText; + case TextFilter.STARTS_WITH: + return value.indexOf(filterText) === 0; + case TextFilter.ENDS_WITH: + var index = value.lastIndexOf(filterText); + return index >= 0 && index === (value.length - filterText.length); + default: + return false; } - return columnsForDisplay; }; - ColumnController.prototype.checkColSpanActiveInCols = function (columns) { - var result = false; - columns.forEach(function (col) { - if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(col.getColDef().colSpan)) { - result = true; - } - }); - return result; + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValue-index0-1') + ], TextFilter.prototype, "eValueFrom1", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValue-index1-1') + ], TextFilter.prototype, "eValueTo1", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValue-index0-2') + ], TextFilter.prototype, "eValueFrom2", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValue-index1-2') + ], TextFilter.prototype, "eValueTo2", void 0); + return TextFilter; +}(_simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"])); + + + +/***/ }), +/* 80 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TextFloatingFilter", function() { return TextFloatingFilter; }); +/* harmony import */ var _textFilter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(79); +/* harmony import */ var _floating_provided_textInputFloatingFilter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(78); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - ColumnController.prototype.calculateColumnsForGroupDisplay = function () { - var _this = this; - this.groupDisplayColumns = []; - var checkFunc = function (col) { - var colDef = col.getColDef(); - if (colDef && _utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(colDef.showRowGroup)) { - _this.groupDisplayColumns.push(col); - } - }; - this.gridColumns.forEach(checkFunc); - if (this.groupAutoColumns) { - this.groupAutoColumns.forEach(checkFunc); - } + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - ColumnController.prototype.getGroupDisplayColumns = function () { - return this.groupDisplayColumns; +})(); + + +var TextFloatingFilter = /** @class */ (function (_super) { + __extends(TextFloatingFilter, _super); + function TextFloatingFilter() { + return _super !== null && _super.apply(this, arguments) || this; + } + TextFloatingFilter.prototype.getDefaultFilterOptions = function () { + return _textFilter__WEBPACK_IMPORTED_MODULE_0__["TextFilter"].DEFAULT_FILTER_OPTIONS; }; - ColumnController.prototype.updateDisplayedColumns = function (source) { - var columnsForDisplay = this.calculateColumnsForDisplay(); - this.buildDisplayedTrees(columnsForDisplay); - this.calculateColumnsForGroupDisplay(); - // also called when group opened/closed - this.updateGroupsAndDisplayedColumns(source); - // also called when group opened/closed - this.setFirstRightAndLastLeftPinned(source); + return TextFloatingFilter; +}(_floating_provided_textInputFloatingFilter__WEBPACK_IMPORTED_MODULE_1__["TextInputFloatingFilter"])); + + + +/***/ }), +/* 81 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderComp", function() { return HeaderComp; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(10); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(23); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(18); +/* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(43); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(42); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7); +/* harmony import */ var _utils_icon__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(48); +/* harmony import */ var _utils_string__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(26); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(36); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(57); +/* harmony import */ var _widgets_touchListener__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(82); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - ColumnController.prototype.isSecondaryColumnsPresent = function () { - return this.secondaryColumnsPresent; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - ColumnController.prototype.setSecondaryColumns = function (colDefs, source) { - if (source === void 0) { source = "api"; } - var newColsPresent = colDefs && colDefs.length > 0; - // if not cols passed, and we had to cols anyway, then do nothing - if (!newColsPresent && !this.secondaryColumnsPresent) { - return; - } - if (newColsPresent) { - this.processSecondaryColumnDefinitions(colDefs); - var balancedTreeResult = this.columnFactory.createColumnTree(colDefs, false); - this.secondaryBalancedTree = balancedTreeResult.columnTree; - this.secondaryHeaderRowCount = balancedTreeResult.treeDept + 1; - this.secondaryColumns = this.getColumnsFromTree(this.secondaryBalancedTree); - this.secondaryColumnsPresent = true; - } - else { - this.secondaryBalancedTree = null; - this.secondaryHeaderRowCount = -1; - this.secondaryColumns = null; - this.secondaryColumnsPresent = false; - } - this.updateGridColumns(); - this.updateDisplayedColumns(source); +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + + + + + + +var HeaderComp = /** @class */ (function (_super) { + __extends(HeaderComp, _super); + function HeaderComp() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.lastMovingChanged = 0; + return _this; + } + // this is a user component, and IComponent has "public destroy()" as part of the interface. + // so we need to override destroy() just to make the method public. + HeaderComp.prototype.destroy = function () { + _super.prototype.destroy.call(this); }; - ColumnController.prototype.processSecondaryColumnDefinitions = function (colDefs) { - var columnCallback = this.gridOptionsWrapper.getProcessSecondaryColDefFunc(); - var groupCallback = this.gridOptionsWrapper.getProcessSecondaryColGroupDefFunc(); - if (!columnCallback && !groupCallback) { - return undefined; + HeaderComp.prototype.refresh = function (params) { + this.params = params; + // if template changed, then recreate the whole comp, the code required to manage + // a changing template is to difficult for what it's worth. + if (this.workOutTemplate() != this.currentTemplate) { + return false; } - var searchForColDefs = function (colDefs2) { - colDefs2.forEach(function (abstractColDef) { - var isGroup = _utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(abstractColDef.children); - if (isGroup) { - var colGroupDef = abstractColDef; - if (groupCallback) { - groupCallback(colGroupDef); - } - searchForColDefs(colGroupDef.children); - } - else { - var colDef = abstractColDef; - if (columnCallback) { - columnCallback(colDef); - } - } - }); - }; - if (colDefs) { - searchForColDefs(colDefs); + if (this.workOutShowMenu() != this.currentShowMenu) { + return false; + } + if (this.workOutSort() != this.currentSort) { + return false; } + this.setDisplayName(params); + return true; }; - // called from: setColumnState, setColumnDefs, setSecondaryColumns - ColumnController.prototype.updateGridColumns = function () { - if (this.gridColsArePrimary) { - this.lastPrimaryOrder = this.gridColumns; + HeaderComp.prototype.workOutTemplate = function () { + var template = Object(_utils_array__WEBPACK_IMPORTED_MODULE_3__["firstExistingValue"])(this.params.template, HeaderComp.TEMPLATE); + // take account of any newlines & whitespace before/after the actual template + template = template && template.trim ? template.trim() : template; + return template; + }; + HeaderComp.prototype.init = function (params) { + this.params = params; + this.currentTemplate = this.workOutTemplate(); + this.setTemplate(this.currentTemplate); + this.setupTap(); + this.setupIcons(params.column); + this.setMenu(); + this.setupSort(); + this.setupFilterIcon(); + this.setDisplayName(params); + }; + HeaderComp.prototype.setDisplayName = function (params) { + if (this.currentDisplayName != params.displayName) { + this.currentDisplayName = params.displayName; + var displayNameSanitised = Object(_utils_string__WEBPACK_IMPORTED_MODULE_8__["escapeString"])(this.currentDisplayName); + if (this.eText) { + this.eText.innerHTML = displayNameSanitised; + } } - if (this.secondaryColumns && this.secondaryBalancedTree) { - this.gridBalancedTree = this.secondaryBalancedTree.slice(); - this.gridHeaderRowCount = this.secondaryHeaderRowCount; - this.gridColumns = this.secondaryColumns.slice(); - this.gridColsArePrimary = false; + }; + HeaderComp.prototype.setupIcons = function (column) { + this.addInIcon('sortAscending', this.eSortAsc, column); + this.addInIcon('sortDescending', this.eSortDesc, column); + this.addInIcon('sortUnSort', this.eSortNone, column); + this.addInIcon('menu', this.eMenu, column); + this.addInIcon('filter', this.eFilter, column); + }; + HeaderComp.prototype.addInIcon = function (iconName, eParent, column) { + if (eParent == null) { + return; } - else { - this.gridBalancedTree = this.primaryColumnTree.slice(); - this.gridHeaderRowCount = this.primaryHeaderRowCount; - this.gridColumns = this.primaryColumns.slice(); - this.gridColsArePrimary = true; - // updateGridColumns gets called after user adds a row group. we want to maintain the order of the columns - // when this happens (eg if user moved a column) rather than revert back to the original column order. - // likewise if changing in/out of pivot mode, we want to maintain the order of the primary cols - this.orderGridColsLikeLastPrimary(); + var eIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_7__["createIconNoSpan"])(iconName, this.gridOptionsWrapper, column); + if (eIcon) { + eParent.appendChild(eIcon); } - this.addAutoGroupToGridColumns(); - this.autoRowHeightColumns = this.gridColumns.filter(function (col) { return col.getColDef().autoHeight; }); - this.putFixedColumnsFirst(); - this.setupQuickFilterColumns(); - this.clearDisplayedColumns(); - this.colSpanActive = this.checkColSpanActiveInCols(this.gridColumns); - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_GRID_COLUMNS_CHANGED, - api: this.gridApi, - columnApi: this.columnApi - }; - this.eventService.dispatchEvent(event); }; - ColumnController.prototype.orderGridColsLikeLastPrimary = function () { + HeaderComp.prototype.setupTap = function () { var _this = this; - if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].missing(this.lastPrimaryOrder)) { + var options = this.gridOptionsWrapper; + if (options.isSuppressTouch()) { return; } - // only do the sort if at least one column is accounted for. columns will be not accounted for - // if changing from secondary to primary columns - var noColsFound = true; - this.gridColumns.forEach(function (col) { - if (_this.lastPrimaryOrder.indexOf(col) >= 0) { - noColsFound = false; - } - }); - if (noColsFound) { - return; + var touchListener = new _widgets_touchListener__WEBPACK_IMPORTED_MODULE_11__["TouchListener"](this.getGui(), true); + var suppressMenuHide = options.isSuppressMenuHide(); + var tapMenuButton = suppressMenuHide && Object(_utils_generic__WEBPACK_IMPORTED_MODULE_6__["exists"])(this.eMenu); + var menuTouchListener = tapMenuButton ? new _widgets_touchListener__WEBPACK_IMPORTED_MODULE_11__["TouchListener"](this.eMenu, true) : touchListener; + if (this.params.enableMenu) { + var eventType = tapMenuButton ? 'EVENT_TAP' : 'EVENT_LONG_TAP'; + var showMenuFn = function (event) { + options.getApi().showColumnMenuAfterMouseClick(_this.params.column, event.touchStart); + }; + this.addManagedListener(menuTouchListener, _widgets_touchListener__WEBPACK_IMPORTED_MODULE_11__["TouchListener"][eventType], showMenuFn); } - // order cols in the same order as before. we need to make sure that all - // cols still exists, so filter out any that no longer exist. - var oldColsOrdered = this.lastPrimaryOrder.filter(function (col) { return _this.gridColumns.indexOf(col) >= 0; }); - var newColsOrdered = this.gridColumns.filter(function (col) { return oldColsOrdered.indexOf(col) < 0; }); - // add in the new columns, at the end (if no group), or at the end of the group (if a group) - var newGridColumns = oldColsOrdered.slice(); - newColsOrdered.forEach(function (newCol) { - var parent = newCol.getOriginalParent(); - // if no parent, means we are not grouping, so just add the column to the end - if (!parent) { - newGridColumns.push(newCol); - return; - } - // find the group the column belongs to. if no siblings at the current level (eg col in group on it's - // own) then go up one level and look for siblings there. - var siblings = []; - while (!siblings.length && parent) { - var leafCols = parent.getLeafColumns(); - leafCols.forEach(function (leafCol) { - var presentInNewGriColumns = newGridColumns.indexOf(leafCol) >= 0; - var noYetInSiblings = siblings.indexOf(leafCol) < 0; - if (presentInNewGriColumns && noYetInSiblings) { - siblings.push(leafCol); - } - }); - parent = parent.getOriginalParent(); - } - // if no siblings exist at any level, this means the col is in a group (or parent groups) on it's own - if (!siblings.length) { - newGridColumns.push(newCol); - return; - } - // find index of last column in the group - var indexes = siblings.map(function (col) { return newGridColumns.indexOf(col); }); - var lastIndex = Math.max.apply(Math, indexes); - _utils__WEBPACK_IMPORTED_MODULE_9__["_"].insertIntoArray(newGridColumns, newCol, lastIndex + 1); - }); - this.gridColumns = newGridColumns; - }; - ColumnController.prototype.isPrimaryColumnGroupsPresent = function () { - return this.primaryHeaderRowCount > 1; - }; - // if we are using autoGroupCols, then they should be included for quick filter. this covers the - // following scenarios: - // a) user provides 'field' into autoGroupCol of normal grid, so now because a valid col to filter leafs on - // b) using tree data and user depends on autoGroupCol for first col, and we also want to filter on this - // (tree data is a bit different, as parent rows can be filtered on, unlike row grouping) - ColumnController.prototype.setupQuickFilterColumns = function () { - if (this.groupAutoColumns) { - this.columnsForQuickFilter = this.primaryColumns.concat(this.groupAutoColumns); + if (this.params.enableSorting) { + var tapListener = function (event) { + var target = event.touchStart.target; + // When suppressMenuHide is true, a tap on the menu icon will bubble up + // to the header container, in that case we should not sort + if (suppressMenuHide && _this.eMenu.contains(target)) { + return; + } + _this.sortController.progressSort(_this.params.column, false, "uiColumnSorted"); + }; + this.addManagedListener(touchListener, _widgets_touchListener__WEBPACK_IMPORTED_MODULE_11__["TouchListener"].EVENT_TAP, tapListener); } - else { - this.columnsForQuickFilter = this.primaryColumns; + // if tapMenuButton is true `touchListener` and `menuTouchListener` are different + // so we need to make sure to destroy both listeners here + this.addDestroyFunc(function () { return touchListener.destroy(); }); + if (tapMenuButton) { + this.addDestroyFunc(function () { return menuTouchListener.destroy(); }); } }; - ColumnController.prototype.putFixedColumnsFirst = function () { - var locked = this.gridColumns.filter(function (c) { return c.getColDef().lockPosition; }); - var unlocked = this.gridColumns.filter(function (c) { return !c.getColDef().lockPosition; }); - this.gridColumns = locked.concat(unlocked); + HeaderComp.prototype.workOutShowMenu = function () { + // we don't show the menu if on an iPad/iPhone, as the user cannot have a pointer device/ + // However if suppressMenuHide is set to true the menu will be displayed alwasys, so it's ok + // to show it on iPad in this case (as hover isn't needed). If suppressMenuHide + // is false (default) user will need to use longpress to display the menu. + var menuHides = !this.gridOptionsWrapper.isSuppressMenuHide(); + var onIpadAndMenuHides = Object(_utils_browser__WEBPACK_IMPORTED_MODULE_4__["isIOSUserAgent"])() && menuHides; + var showMenu = this.params.enableMenu && !onIpadAndMenuHides; + return showMenu; }; - ColumnController.prototype.addAutoGroupToGridColumns = function () { - // add in auto-group here - this.createGroupAutoColumnsIfNeeded(); - if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].missing(this.groupAutoColumns)) { + HeaderComp.prototype.setMenu = function () { + var _this = this; + // if no menu provided in template, do nothing + if (!this.eMenu) { return; } - this.gridColumns = this.groupAutoColumns ? this.groupAutoColumns.concat(this.gridColumns) : this.gridColumns; - var autoColBalancedTree = this.columnFactory.createForAutoGroups(this.groupAutoColumns, this.gridBalancedTree); - this.gridBalancedTree = autoColBalancedTree.concat(this.gridBalancedTree); - }; - // gets called after we copy down grid columns, to make sure any part of the gui - // that tries to draw, eg the header, it will get empty lists of columns rather - // than stale columns. for example, the header will received gridColumnsChanged - // event, so will try and draw, but it will draw successfully when it acts on the - // virtualColumnsChanged event - ColumnController.prototype.clearDisplayedColumns = function () { - this.displayedLeftColumnTree = []; - this.displayedRightColumnTree = []; - this.displayedCentreColumnTree = []; - this.displayedLeftHeaderRows = {}; - this.displayedRightHeaderRows = {}; - this.displayedCentreHeaderRows = {}; - this.displayedLeftColumns = []; - this.displayedRightColumns = []; - this.displayedCenterColumns = []; - this.allDisplayedColumns = []; - this.allDisplayedVirtualColumns = []; - }; - ColumnController.prototype.updateGroupsAndDisplayedColumns = function (source) { - this.updateOpenClosedVisibilityInColumnGroups(); - this.updateDisplayedColumnsFromTrees(source); - this.updateVirtualSets(); - this.refreshFlexedColumns(undefined, undefined, true); - this.updateBodyWidths(); - // this event is picked up by the gui, headerRenderer and rowRenderer, to recalculate what columns to display - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, - api: this.gridApi, - columnApi: this.columnApi - }; - this.eventService.dispatchEvent(event); - }; - ColumnController.prototype.updateDisplayedColumnsFromTrees = function (source) { - this.addToDisplayedColumns(this.displayedLeftColumnTree, this.displayedLeftColumns); - this.addToDisplayedColumns(this.displayedCentreColumnTree, this.displayedCenterColumns); - this.addToDisplayedColumns(this.displayedRightColumnTree, this.displayedRightColumns); - this.setupAllDisplayedColumns(); - this.setLeftValues(source); - }; - ColumnController.prototype.setupAllDisplayedColumns = function () { - if (this.gridOptionsWrapper.isEnableRtl()) { - this.allDisplayedColumns = this.displayedRightColumns - .concat(this.displayedCenterColumns) - .concat(this.displayedLeftColumns); + this.currentShowMenu = this.workOutShowMenu(); + if (!this.currentShowMenu) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["removeFromParent"])(this.eMenu); + return; } - else { - this.allDisplayedColumns = this.displayedLeftColumns - .concat(this.displayedCenterColumns) - .concat(this.displayedRightColumns); + var suppressMenuHide = this.gridOptionsWrapper.isSuppressMenuHide(); + this.addManagedListener(this.eMenu, 'click', function () { return _this.showMenu(_this.eMenu); }); + this.eMenu.classList.toggle('ag-header-menu-always-show', suppressMenuHide); + }; + HeaderComp.prototype.showMenu = function (eventSource) { + if (!eventSource) { + eventSource = this.eMenu; } + this.menuFactory.showMenuAfterButtonClick(this.params.column, eventSource, 'columnMenu'); }; - // sets the left pixel position of each column - ColumnController.prototype.setLeftValues = function (source) { - this.setLeftValuesOfColumns(source); - this.setLeftValuesOfGroups(); + HeaderComp.prototype.removeSortIcons = function () { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["removeFromParent"])(this.eSortAsc); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["removeFromParent"])(this.eSortDesc); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["removeFromParent"])(this.eSortNone); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["removeFromParent"])(this.eSortOrder); }; - ColumnController.prototype.setLeftValuesOfColumns = function (source) { + HeaderComp.prototype.workOutSort = function () { + return this.params.enableSorting; + }; + HeaderComp.prototype.setupSort = function () { var _this = this; - // go through each list of displayed columns - var allColumns = this.primaryColumns.slice(0); - // let totalColumnWidth = this.getWidthOfColsInList() - var doingRtl = this.gridOptionsWrapper.isEnableRtl(); - [ - this.displayedLeftColumns, - this.displayedRightColumns, - this.displayedCenterColumns - ].forEach(function (columns) { - if (doingRtl) { - // when doing RTL, we start at the top most pixel (ie RHS) and work backwards - var left_1 = _this.getWidthOfColsInList(columns); - columns.forEach(function (column) { - left_1 -= column.getActualWidth(); - column.setLeft(left_1, source); - }); - } - else { - // otherwise normal LTR, we start at zero - var left_2 = 0; - columns.forEach(function (column) { - column.setLeft(left_2, source); - left_2 += column.getActualWidth(); - }); - } - _utils__WEBPACK_IMPORTED_MODULE_9__["_"].removeAllFromArray(allColumns, columns); - }); - // items left in allColumns are columns not displayed, so remove the left position. this is - // important for the rows, as if a col is made visible, then taken out, then made visible again, - // we don't want the animation of the cell floating in from the old position, whatever that was. - allColumns.forEach(function (column) { - column.setLeft(null, source); + this.currentSort = this.params.enableSorting; + if (!this.currentSort) { + this.removeSortIcons(); + return; + } + var sortUsingCtrl = this.gridOptionsWrapper.isMultiSortKeyCtrl(); + // keep track of last time the moving changed flag was set + this.addManagedListener(this.params.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_MOVING_CHANGED, function () { + _this.lastMovingChanged = new Date().getTime(); }); - }; - ColumnController.prototype.setLeftValuesOfGroups = function () { - // a groups left value is the lest left value of it's children - [ - this.displayedLeftColumnTree, - this.displayedRightColumnTree, - this.displayedCentreColumnTree - ].forEach(function (columns) { - columns.forEach(function (column) { - if (column instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) { - var columnGroup = column; - columnGroup.checkLeft(); + // add the event on the header, so when clicked, we do sorting + if (this.eLabel) { + this.addManagedListener(this.eLabel, 'click', function (event) { + // sometimes when moving a column via dragging, this was also firing a clicked event. + // here is issue raised by user: https://ag-grid.zendesk.com/agent/tickets/1076 + // this check stops sort if a) column is moving or b) column moved less than 200ms ago (so caters for race condition) + var moving = _this.params.column.isMoving(); + var nowTime = new Date().getTime(); + // typically there is <2ms if moving flag was set recently, as it would be done in same VM turn + var movedRecently = (nowTime - _this.lastMovingChanged) < 50; + var columnMoving = moving || movedRecently; + if (!columnMoving) { + var multiSort = sortUsingCtrl ? (event.ctrlKey || event.metaKey) : event.shiftKey; + _this.params.progressSort(multiSort); } }); - }); + } + this.addManagedListener(this.params.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_SORT_CHANGED, this.onSortChanged.bind(this)); + this.onSortChanged(); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_SORT_CHANGED, this.setMultiSortOrder.bind(this)); + this.setMultiSortOrder(); }; - ColumnController.prototype.addToDisplayedColumns = function (displayedColumnTree, displayedColumns) { - displayedColumns.length = 0; - this.columnUtils.depthFirstDisplayedColumnTreeSearch(displayedColumnTree, function (child) { - if (child instanceof _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"]) { - displayedColumns.push(child); - } - }); + HeaderComp.prototype.onSortChanged = function () { + this.addOrRemoveCssClass('ag-header-cell-sorted-asc', this.params.column.isSortAscending()); + this.addOrRemoveCssClass('ag-header-cell-sorted-desc', this.params.column.isSortDescending()); + this.addOrRemoveCssClass('ag-header-cell-sorted-none', this.params.column.isSortNone()); + if (this.eSortAsc) { + this.eSortAsc.classList.toggle('ag-hidden', !this.params.column.isSortAscending()); + } + if (this.eSortDesc) { + this.eSortDesc.classList.toggle('ag-hidden', !this.params.column.isSortDescending()); + } + if (this.eSortNone) { + var alwaysHideNoSort = !this.params.column.getColDef().unSortIcon && !this.gridOptionsWrapper.isUnSortIcon(); + this.eSortNone.classList.toggle('ag-hidden', alwaysHideNoSort || !this.params.column.isSortNone()); + } }; - ColumnController.prototype.updateDisplayedCenterVirtualColumns = function () { - if (this.suppressColumnVirtualisation) { - // no virtualisation, so don't filter - this.allDisplayedCenterVirtualColumns = this.displayedCenterColumns; + // we listen here for global sort events, NOT column sort events, as we want to do this + // when sorting has been set on all column (if we listened just for our col (where we + // set the asc / desc icons) then it's possible other cols are yet to get their sorting state. + HeaderComp.prototype.setMultiSortOrder = function () { + if (!this.eSortOrder) { + return; + } + var col = this.params.column; + var allColumnsWithSorting = this.sortController.getColumnsWithSortingOrdered(); + var indexThisCol = allColumnsWithSorting.indexOf(col); + var moreThanOneColSorting = allColumnsWithSorting.length > 1; + var showIndex = col.isSorting() && moreThanOneColSorting; + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["setDisplayed"])(this.eSortOrder, showIndex); + if (indexThisCol >= 0) { + this.eSortOrder.innerHTML = (indexThisCol + 1).toString(); } else { - // filter out what should be visible - this.allDisplayedCenterVirtualColumns = this.filterOutColumnsWithinViewport(); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["clearElement"])(this.eSortOrder); } - this.allDisplayedVirtualColumns = this.allDisplayedCenterVirtualColumns - .concat(this.displayedLeftColumns) - .concat(this.displayedRightColumns); - // return map of virtual col id's, for easy lookup when building the groups. - // the map will be colId=>true, ie col id's mapping to 'true'. - var result = {}; - this.allDisplayedVirtualColumns.forEach(function (col) { - result[col.getId()] = true; - }); - return result; }; - ColumnController.prototype.getVirtualHeaderGroupRow = function (type, dept) { - var result; - switch (type) { - case _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT: - result = this.displayedLeftHeaderRows[dept]; - break; - case _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT: - result = this.displayedRightHeaderRows[dept]; - break; - default: - result = this.displayedCentreHeaderRows[dept]; - break; - } - if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].missing(result)) { - result = []; + HeaderComp.prototype.setupFilterIcon = function () { + if (!this.eFilter) { + return; } - return result; + this.addManagedListener(this.params.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_FILTER_CHANGED, this.onFilterChanged.bind(this)); + this.onFilterChanged(); }; - ColumnController.prototype.updateDisplayedVirtualGroups = function (virtualColIds) { - // go through each group, see if any of it's cols are displayed, and if yes, - // then this group is included - this.displayedLeftHeaderRows = {}; - this.displayedRightHeaderRows = {}; - this.displayedCentreHeaderRows = {}; - var testGroup = function (children, result, dept) { - var returnValue = false; - for (var i = 0; i < children.length; i++) { - // see if this item is within viewport - var child = children[i]; - var addThisItem = void 0; - if (child instanceof _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"]) { - // for column, test if column is included - addThisItem = virtualColIds[child.getId()] === true; - } - else { - // if group, base decision on children - var columnGroup = child; - addThisItem = testGroup(columnGroup.getDisplayedChildren(), result, dept + 1); - } - if (addThisItem) { - returnValue = true; - if (!result[dept]) { - result[dept] = []; - } - result[dept].push(child); - } + HeaderComp.prototype.onFilterChanged = function () { + var filterPresent = this.params.column.isFilterActive(); + this.eFilter.classList.toggle('ag-hidden', !filterPresent); + }; + HeaderComp.TEMPLATE = "
\n \n
\n \n \n \n \n \n \n
\n
"; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('sortController') + ], HeaderComp.prototype, "sortController", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('menuFactory') + ], HeaderComp.prototype, "menuFactory", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_10__["RefSelector"])('eFilter') + ], HeaderComp.prototype, "eFilter", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_10__["RefSelector"])('eSortAsc') + ], HeaderComp.prototype, "eSortAsc", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_10__["RefSelector"])('eSortDesc') + ], HeaderComp.prototype, "eSortDesc", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_10__["RefSelector"])('eSortNone') + ], HeaderComp.prototype, "eSortNone", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_10__["RefSelector"])('eSortOrder') + ], HeaderComp.prototype, "eSortOrder", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_10__["RefSelector"])('eMenu') + ], HeaderComp.prototype, "eMenu", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_10__["RefSelector"])('eLabel') + ], HeaderComp.prototype, "eLabel", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_10__["RefSelector"])('eText') + ], HeaderComp.prototype, "eText", void 0); + return HeaderComp; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_9__["Component"])); + + + +/***/ }), +/* 82 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TouchListener", function() { return TouchListener; }); +/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(11); +/* harmony import */ var _utils_mouse__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(50); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ + + +var TouchListener = /** @class */ (function () { + function TouchListener(eElement, preventMouseClick) { + var _this = this; + if (preventMouseClick === void 0) { preventMouseClick = false; } + this.destroyFuncs = []; + this.touching = false; + this.eventService = new _eventService__WEBPACK_IMPORTED_MODULE_0__["EventService"](); + this.eElement = eElement; + this.preventMouseClick = preventMouseClick; + var startListener = this.onTouchStart.bind(this); + var moveListener = this.onTouchMove.bind(this); + var endListener = this.onTouchEnd.bind(this); + this.eElement.addEventListener("touchstart", startListener, { passive: true }); + this.eElement.addEventListener("touchmove", moveListener, { passive: true }); + // we set passive=false, as we want to prevent default on this event + this.eElement.addEventListener("touchend", endListener, { passive: false }); + this.destroyFuncs.push(function () { + _this.eElement.removeEventListener("touchstart", startListener, { passive: true }); + _this.eElement.removeEventListener("touchmove", moveListener, { passive: true }); + _this.eElement.removeEventListener("touchend", endListener, { passive: false }); + }); + } + TouchListener.prototype.getActiveTouch = function (touchList) { + for (var i = 0; i < touchList.length; i++) { + var matches = touchList[i].identifier === this.touchStart.identifier; + if (matches) { + return touchList[i]; } - return returnValue; - }; - testGroup(this.displayedLeftColumnTree, this.displayedLeftHeaderRows, 0); - testGroup(this.displayedRightColumnTree, this.displayedRightHeaderRows, 0); - testGroup(this.displayedCentreColumnTree, this.displayedCentreHeaderRows, 0); + } + return null; }; - ColumnController.prototype.updateVirtualSets = function () { - var virtualColIds = this.updateDisplayedCenterVirtualColumns(); - this.updateDisplayedVirtualGroups(virtualColIds); + TouchListener.prototype.addEventListener = function (eventType, listener) { + this.eventService.addEventListener(eventType, listener); }; - ColumnController.prototype.filterOutColumnsWithinViewport = function () { - return this.displayedCenterColumns.filter(this.isColumnInViewport.bind(this)); + TouchListener.prototype.removeEventListener = function (eventType, listener) { + this.eventService.removeEventListener(eventType, listener); }; - ColumnController.prototype.refreshFlexedColumns = function (updatedFlexViewportWidth, source, silent) { - if (source === void 0) { source = 'flex'; } - if (!this.flexActive) { + TouchListener.prototype.onTouchStart = function (touchEvent) { + var _this = this; + // only looking at one touch point at any time + if (this.touching) { return; } - this.flexViewportWidth = updatedFlexViewportWidth || this.flexViewportWidth; - if (!this.flexViewportWidth) { + this.touchStart = touchEvent.touches[0]; + this.touching = true; + this.moved = false; + var touchStartCopy = this.touchStart; + window.setTimeout(function () { + var touchesMatch = _this.touchStart === touchStartCopy; + if (_this.touching && touchesMatch && !_this.moved) { + _this.moved = true; + var event_1 = { + type: TouchListener.EVENT_LONG_TAP, + touchStart: _this.touchStart, + touchEvent: touchEvent + }; + _this.eventService.dispatchEvent(event_1); + } + }, 500); + }; + TouchListener.prototype.onTouchMove = function (touchEvent) { + if (!this.touching) { return; } - // If the grid has left-over space, divide it between flexing columns in proportion to their flex value. - // A "flexing column" is one that has a 'flex' value set and is not currently being constrained by its - // minWidth or maxWidth rules. - var knownWidthColumns = this.displayedCenterColumns.filter(function (col) { return !col.getFlex(); }); - var flexingColumns = this.displayedCenterColumns.filter(function (col) { return col.getFlex(); }); - if (!flexingColumns.length) { - this.flexActive = false; + var touch = this.getActiveTouch(touchEvent.touches); + if (!touch) { return; } - var flexingColumnSizes = []; - var spaceForFlexingColumns; - outer: while (true) { - var totalFlex = flexingColumns.reduce(function (count, col) { return count + col.getFlex(); }, 0); - spaceForFlexingColumns = this.flexViewportWidth - this.getWidthOfColsInList(knownWidthColumns); - for (var i = 0; i < flexingColumns.length; i++) { - var col = flexingColumns[i]; - var widthByFlexRule = spaceForFlexingColumns * col.getFlex() / totalFlex; - var constrainedWidth = void 0; - if (widthByFlexRule < col.getMinWidth()) { - constrainedWidth = col.getMinWidth(); - } - else if (col.getMaxWidth() != null && widthByFlexRule > col.getMaxWidth()) { - constrainedWidth = col.getMaxWidth(); - } - if (constrainedWidth) { - // This column is not in fact flexing as it is being constrained to a specific size - // so remove it from the list of flexing columns and start again - col.setActualWidth(constrainedWidth, source); - _utils__WEBPACK_IMPORTED_MODULE_9__["_"].removeFromArray(flexingColumns, col); - knownWidthColumns.push(col); - continue outer; - } - flexingColumnSizes[i] = Math.round(widthByFlexRule); - } - break; - } - var remainingSpace = spaceForFlexingColumns; - flexingColumns.forEach(function (col, i) { - col.setActualWidth(Math.min(flexingColumnSizes[i], remainingSpace), source); - remainingSpace -= flexingColumnSizes[i]; - }); - this.setLeftValues(source); - if (!silent) { - this.updateBodyWidths(); - this.fireResizedEventForColumns(flexingColumns, source); + var eventIsFarAway = !Object(_utils_mouse__WEBPACK_IMPORTED_MODULE_1__["areEventsNear"])(touch, this.touchStart, 4); + if (eventIsFarAway) { + this.moved = true; } }; - // called from api - ColumnController.prototype.sizeColumnsToFit = function (gridWidth, source, silent) { - if (source === void 0) { source = "sizeColumnsToFit"; } - // avoid divide by zero - var allDisplayedColumns = this.getAllDisplayedColumns(); - if (gridWidth <= 0 || !allDisplayedColumns.length) { + TouchListener.prototype.onTouchEnd = function (touchEvent) { + if (!this.touching) { return; } - var colsToSpread = []; - var colsToNotSpread = []; - allDisplayedColumns.forEach(function (column) { - if (column.getColDef().suppressSizeToFit === true) { - colsToNotSpread.push(column); - } - else { - colsToSpread.push(column); - } - }); - // make a copy of the cols that are going to be resized - var colsToFireEventFor = colsToSpread.slice(0); - var finishedResizing = false; - var moveToNotSpread = function (column) { - _utils__WEBPACK_IMPORTED_MODULE_9__["_"].removeFromArray(colsToSpread, column); - colsToNotSpread.push(column); - }; - // resetting cols to their original width makes the sizeColumnsToFit more deterministic, - // rather than depending on the current size of the columns. most users call sizeColumnsToFit - // immediately after grid is created, so will make no difference. however if application is calling - // sizeColumnsToFit repeatedly (eg after column group is opened / closed repeatedly) we don't want - // the columns to start shrinking / growing over time. - colsToSpread.forEach(function (column) { return column.resetActualWidth(); }); - while (!finishedResizing) { - finishedResizing = true; - var availablePixels = gridWidth - this.getWidthOfColsInList(colsToNotSpread); - if (availablePixels <= 0) { - // no width, set everything to minimum - colsToSpread.forEach(function (column) { - column.setMinimum(source); - }); + if (!this.moved) { + var event_2 = { + type: TouchListener.EVENT_TAP, + touchStart: this.touchStart + }; + this.eventService.dispatchEvent(event_2); + this.checkForDoubleTap(); + } + // stops the tap from also been processed as a mouse click + if (this.preventMouseClick) { + touchEvent.preventDefault(); + } + this.touching = false; + }; + TouchListener.prototype.checkForDoubleTap = function () { + var now = new Date().getTime(); + if (this.lastTapTime && this.lastTapTime > 0) { + // if previous tap, see if duration is short enough to be considered double tap + var interval = now - this.lastTapTime; + if (interval > TouchListener.DOUBLE_TAP_MILLIS) { + // dispatch double tap event + var event_3 = { + type: TouchListener.EVENT_DOUBLE_TAP, + touchStart: this.touchStart + }; + this.eventService.dispatchEvent(event_3); + // this stops a tripple tap ending up as two double taps + this.lastTapTime = null; } else { - var scale = availablePixels / this.getWidthOfColsInList(colsToSpread); - // we set the pixels for the last col based on what's left, as otherwise - // we could be a pixel or two short or extra because of rounding errors. - var pixelsForLastCol = availablePixels; - // backwards through loop, as we are removing items as we go - for (var i = colsToSpread.length - 1; i >= 0; i--) { - var column = colsToSpread[i]; - var newWidth = Math.round(column.getActualWidth() * scale); - if (newWidth < column.getMinWidth()) { - column.setMinimum(source); - moveToNotSpread(column); - finishedResizing = false; - } - else if (column.isGreaterThanMax(newWidth)) { - column.setActualWidth(column.getMaxWidth(), source); - moveToNotSpread(column); - finishedResizing = false; - } - else { - var onLastCol = i === 0; - if (onLastCol) { - column.setActualWidth(pixelsForLastCol, source); - } - else { - column.setActualWidth(newWidth, source); - } - } - pixelsForLastCol -= newWidth; - } + this.lastTapTime = now; } } - this.setLeftValues(source); - this.updateBodyWidths(); - if (silent) { - return; + else { + this.lastTapTime = now; } - this.fireResizedEventForColumns(colsToFireEventFor, source); }; - ColumnController.prototype.fireResizedEventForColumns = function (columns, source) { - var _this = this; - columns.forEach(function (column) { - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_RESIZED, - column: column, - columns: [column], - finished: true, - api: _this.gridApi, - columnApi: _this.columnApi, - source: source - }; - _this.eventService.dispatchEvent(event); - }); + TouchListener.prototype.destroy = function () { + this.destroyFuncs.forEach(function (func) { return func(); }); }; - ColumnController.prototype.buildDisplayedTrees = function (visibleColumns) { - var leftVisibleColumns = []; - var rightVisibleColumns = []; - var centerVisibleColumns = []; - visibleColumns.forEach(function (column) { - switch (column.getPinned()) { - case "left": - leftVisibleColumns.push(column); - break; - case "right": - rightVisibleColumns.push(column); - break; - default: - centerVisibleColumns.push(column); - break; - } - }); - var groupInstanceIdCreator = new _groupInstanceIdCreator__WEBPACK_IMPORTED_MODULE_5__["GroupInstanceIdCreator"](); - this.displayedLeftColumnTree = this.displayedGroupCreator.createDisplayedGroups(leftVisibleColumns, this.gridBalancedTree, groupInstanceIdCreator, _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT, this.displayedLeftColumnTree); - this.displayedRightColumnTree = this.displayedGroupCreator.createDisplayedGroups(rightVisibleColumns, this.gridBalancedTree, groupInstanceIdCreator, _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT, this.displayedRightColumnTree); - this.displayedCentreColumnTree = this.displayedGroupCreator.createDisplayedGroups(centerVisibleColumns, this.gridBalancedTree, groupInstanceIdCreator, null, this.displayedCentreColumnTree); + TouchListener.EVENT_TAP = "tap"; + TouchListener.EVENT_DOUBLE_TAP = "doubleTap"; + TouchListener.EVENT_LONG_TAP = "longTap"; + TouchListener.DOUBLE_TAP_MILLIS = 500; + return TouchListener; +}()); + + + +/***/ }), +/* 83 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderGroupComp", function() { return HeaderGroupComp; }); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _widgets_touchListener__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(82); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(57); +/* harmony import */ var _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(8); +/* harmony import */ var _utils_string__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(26); +/* harmony import */ var _utils_event__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(21); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(42); +/* harmony import */ var _utils_icon__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(48); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(7); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(14); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - ColumnController.prototype.updateOpenClosedVisibilityInColumnGroups = function () { - var allColumnGroups = this.getAllDisplayedColumnGroups(); - this.columnUtils.depthFirstAllColumnTreeSearch(allColumnGroups, function (child) { - if (child instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) { - var columnGroup = child; - columnGroup.calculateDisplayedColumns(); - } - }); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - ColumnController.prototype.getGroupAutoColumns = function () { - return this.groupAutoColumns; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + + + + + +var HeaderGroupComp = /** @class */ (function (_super) { + __extends(HeaderGroupComp, _super); + function HeaderGroupComp() { + return _super.call(this, HeaderGroupComp.TEMPLATE) || this; + } + // this is a user component, and IComponent has "public destroy()" as part of the interface. + // so we need to override destroy() just to make the method public. + HeaderGroupComp.prototype.destroy = function () { + _super.prototype.destroy.call(this); }; - ColumnController.prototype.createGroupAutoColumnsIfNeeded = function () { - if (!this.autoGroupsNeedBuilding) { - return; + HeaderGroupComp.prototype.init = function (params) { + this.params = params; + this.checkWarnings(); + this.setupLabel(); + this.addGroupExpandIcon(); + this.setupExpandIcons(); + }; + HeaderGroupComp.prototype.checkWarnings = function () { + var paramsAny = this.params; + if (paramsAny.template) { + var message_1 = "AG Grid: A template was provided for Header Group Comp - templates are only supported for Header Comps (not groups)"; + Object(_utils_function__WEBPACK_IMPORTED_MODULE_10__["doOnce"])(function () { return console.warn(message_1); }, 'HeaderGroupComp.templateNotSupported'); } - this.autoGroupsNeedBuilding = false; - var groupFullWidthRow = this.gridOptionsWrapper.isGroupUseEntireRow(this.pivotMode); - // we need to allow suppressing auto-column separately for group and pivot as the normal situation - // is CSRM and user provides group column themselves for normal view, but when they go into pivot the - // columns are generated by the grid so no opportunity for user to provide group column. so need a way - // to suppress auto-col for grouping only, and not pivot. - // however if using Viewport RM or SSRM and user is providing the columns, the user may wish full control - // of the group column in this instance. - var suppressAutoColumn = this.pivotMode ? - this.gridOptionsWrapper.isPivotSuppressAutoColumn() : this.gridOptionsWrapper.isGroupSuppressAutoColumn(); - // const groupSuppressAutoColumn = this.gridOptionsWrapper.isGroupSuppressAutoColumn() && !this.pivotMode; - var groupSuppressRow = this.gridOptionsWrapper.isGroupSuppressRow(); - var groupingActive = this.rowGroupColumns.length > 0 || this.usingTreeData; - var needAutoColumns = groupingActive && !suppressAutoColumn && !groupFullWidthRow && !groupSuppressRow; - if (needAutoColumns) { - var newAutoGroupCols = this.autoGroupColService.createAutoGroupColumns(this.rowGroupColumns); - var autoColsDifferent = !this.autoColsEqual(newAutoGroupCols, this.groupAutoColumns); - // we force recreate when suppressSetColumnStateEvents changes, so new group cols pick up the new - // definitions. otherwise we could ignore the new cols becasue they appear to be the same. - if (autoColsDifferent || this.forceRecreateAutoGroups) { - this.groupAutoColumns = newAutoGroupCols; + }; + HeaderGroupComp.prototype.setupExpandIcons = function () { + var _this = this; + this.addInIcon("columnGroupOpened", "agOpened"); + this.addInIcon("columnGroupClosed", "agClosed"); + var expandAction = function (event) { + if (Object(_utils_event__WEBPACK_IMPORTED_MODULE_6__["isStopPropagationForAgGrid"])(event)) { + return; } + var newExpandedValue = !_this.params.columnGroup.isExpanded(); + _this.columnModel.setColumnGroupOpened(_this.params.columnGroup.getProvidedColumnGroup(), newExpandedValue, "uiColumnExpanded"); + }; + this.addTouchAndClickListeners(this.eCloseIcon, expandAction); + this.addTouchAndClickListeners(this.eOpenIcon, expandAction); + var stopPropagationAction = function (event) { + Object(_utils_event__WEBPACK_IMPORTED_MODULE_6__["stopPropagationForAgGrid"])(event); + }; + // adding stopPropagation to the double click for the icons prevents double click action happening + // when the icons are clicked. if the icons are double clicked, then the groups should open and + // then close again straight away. if we also listened to double click, then the group would open, + // close, then open, which is not what we want. double click should only action if the user double + // clicks outside of the icons. + this.addManagedListener(this.eCloseIcon, "dblclick", stopPropagationAction); + this.addManagedListener(this.eOpenIcon, "dblclick", stopPropagationAction); + this.addManagedListener(this.getGui(), "dblclick", expandAction); + this.updateIconVisibility(); + var providedColumnGroup = this.params.columnGroup.getProvidedColumnGroup(); + this.addManagedListener(providedColumnGroup, _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_4__["ProvidedColumnGroup"].EVENT_EXPANDED_CHANGED, this.updateIconVisibility.bind(this)); + this.addManagedListener(providedColumnGroup, _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_4__["ProvidedColumnGroup"].EVENT_EXPANDABLE_CHANGED, this.updateIconVisibility.bind(this)); + }; + HeaderGroupComp.prototype.addTouchAndClickListeners = function (eElement, action) { + var touchListener = new _widgets_touchListener__WEBPACK_IMPORTED_MODULE_2__["TouchListener"](eElement, true); + this.addManagedListener(touchListener, _widgets_touchListener__WEBPACK_IMPORTED_MODULE_2__["TouchListener"].EVENT_TAP, action); + this.addDestroyFunc(function () { return touchListener.destroy(); }); + this.addManagedListener(eElement, "click", action); + }; + HeaderGroupComp.prototype.updateIconVisibility = function () { + var columnGroup = this.params.columnGroup; + if (columnGroup.isExpandable()) { + var expanded = this.params.columnGroup.isExpanded(); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_7__["setDisplayed"])(this.eOpenIcon, expanded); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_7__["setDisplayed"])(this.eCloseIcon, !expanded); } else { - this.groupAutoColumns = null; + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_7__["setDisplayed"])(this.eOpenIcon, false); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_7__["setDisplayed"])(this.eCloseIcon, false); } }; - ColumnController.prototype.autoColsEqual = function (colsA, colsB) { - return Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["areEqual"])(colsA, colsB, function (a, b) { return a.getColId() === b.getColId(); }); - }; - ColumnController.prototype.getWidthOfColsInList = function (columnList) { - return columnList.reduce(function (width, col) { return width + col.getActualWidth(); }, 0); - }; - ColumnController.prototype.getGridBalancedTree = function () { - return this.gridBalancedTree; - }; - ColumnController.prototype.hasFloatingFilters = function () { - var defaultColDef = this.gridOptionsWrapper.getDefaultColDef(); - return (defaultColDef != null && defaultColDef.floatingFilter === true) || - (this.columnDefs != null && this.columnDefs.some(function (c) { return c.floatingFilter === true; })); + HeaderGroupComp.prototype.addInIcon = function (iconName, refName) { + var eIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_8__["createIconNoSpan"])(iconName, this.gridOptionsWrapper, null); + if (eIcon) { + this.getRefElement(refName).appendChild(eIcon); + } }; - ColumnController.prototype.getFirstDisplayedColumn = function () { - var isRtl = this.gridOptionsWrapper.isEnableRtl(); - var queryOrder = [ - 'getDisplayedLeftColumns', - 'getDisplayedCenterColumns', - 'getDisplayedRightColumns' - ]; - if (isRtl) { - queryOrder.reverse(); + HeaderGroupComp.prototype.addGroupExpandIcon = function () { + if (!this.params.columnGroup.isExpandable()) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_7__["setDisplayed"])(this.eOpenIcon, false); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_7__["setDisplayed"])(this.eCloseIcon, false); + return; } - for (var i = 0; i < queryOrder.length; i++) { - var container = this[queryOrder[i]](); - if (container.length) { - return isRtl ? _utils__WEBPACK_IMPORTED_MODULE_9__["_"].last(container) : container[0]; - } + }; + HeaderGroupComp.prototype.setupLabel = function () { + // no renderer, default text render + var displayName = this.params.displayName; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(displayName)) { + var displayNameSanitised = Object(_utils_string__WEBPACK_IMPORTED_MODULE_5__["escapeString"])(displayName); + this.getRefElement('agLabel').innerHTML = displayNameSanitised; } - return null; }; + HeaderGroupComp.TEMPLATE = "
\n \n \n \n
"; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('gridOptionsWrapper') - ], ColumnController.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('expressionService') - ], ColumnController.prototype, "expressionService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('columnFactory') - ], ColumnController.prototype, "columnFactory", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('displayedGroupCreator') - ], ColumnController.prototype, "displayedGroupCreator", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('autoWidthCalculator') - ], ColumnController.prototype, "autoWidthCalculator", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('columnUtils') - ], ColumnController.prototype, "columnUtils", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('columnAnimationService') - ], ColumnController.prototype, "columnAnimationService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('autoGroupColService') - ], ColumnController.prototype, "autoGroupColService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Optional"])('aggFuncService') - ], ColumnController.prototype, "aggFuncService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Optional"])('valueCache') - ], ColumnController.prototype, "valueCache", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Optional"])('animationFrameService') - ], ColumnController.prototype, "animationFrameService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('columnApi') - ], ColumnController.prototype, "columnApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('gridApi') - ], ColumnController.prototype, "gridApi", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])("columnModel") + ], HeaderGroupComp.prototype, "columnModel", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_6__["PostConstruct"] - ], ColumnController.prototype, "init", null); + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])("agOpened") + ], HeaderGroupComp.prototype, "eOpenIcon", void 0); __decorate([ - __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Qualifier"])('loggerFactory')) - ], ColumnController.prototype, "setBeans", null); - ColumnController = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Bean"])('columnController') - ], ColumnController); - return ColumnController; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"])); + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])("agClosed") + ], HeaderGroupComp.prototype, "eCloseIcon", void 0); + return HeaderGroupComp; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); /***/ }), -/* 43 */ +/* 84 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(44); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Events", function() { return _eventKeys__WEBPACK_IMPORTED_MODULE_0__["Events"]; }); - +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LargeTextCellEditor", function() { return LargeTextCellEditor; }); +/* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(85); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(65); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + +var LargeTextCellEditor = /** @class */ (function (_super) { + __extends(LargeTextCellEditor, _super); + function LargeTextCellEditor() { + return _super.call(this, LargeTextCellEditor.TEMPLATE) || this; + } + LargeTextCellEditor.prototype.init = function (params) { + this.params = params; + this.focusAfterAttached = params.cellStartedEdit; + this.eTextArea + .setMaxLength(params.maxLength || 200) + .setCols(params.cols || 60) + .setRows(params.rows || 10); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["exists"])(params.value)) { + this.eTextArea.setValue(params.value.toString(), true); + } + this.addGuiEventListener('keydown', this.onKeyDown.bind(this)); + }; + LargeTextCellEditor.prototype.onKeyDown = function (event) { + var key = event.key; + if (key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].LEFT || + key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].UP || + key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].RIGHT || + key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].DOWN || + (event.shiftKey && key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].ENTER)) { // shift+enter allows for newlines + event.stopPropagation(); + } + }; + LargeTextCellEditor.prototype.afterGuiAttached = function () { + var translate = this.gridOptionsWrapper.getLocaleTextFunc(); + this.eTextArea.setInputAriaLabel(translate('ariaInputEditor', 'Input Editor')); + if (this.focusAfterAttached) { + this.eTextArea.getFocusableElement().focus(); + } + }; + LargeTextCellEditor.prototype.getValue = function () { + return this.params.parseValue(this.eTextArea.getValue()); + }; + LargeTextCellEditor.TEMPLATE = "
\n \n
"; + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])("eTextArea") + ], LargeTextCellEditor.prototype, "eTextArea", void 0); + return LargeTextCellEditor; +}(_widgets_popupComponent__WEBPACK_IMPORTED_MODULE_0__["PopupComponent"])); /***/ }), -/* 44 */ +/* 85 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Events", function() { return Events; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PopupComponent", function() { return PopupComponent; }); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var Events = /** @class */ (function () { - function Events() { +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); + +var PopupComponent = /** @class */ (function (_super) { + __extends(PopupComponent, _super); + function PopupComponent() { + return _super !== null && _super.apply(this, arguments) || this; } - /** Everything has changed with the columns. Either complete new set of columns set, or user called setState()*/ - Events.EVENT_COLUMN_EVERYTHING_CHANGED = 'columnEverythingChanged'; - /** User has set in new columns. */ - Events.EVENT_NEW_COLUMNS_LOADED = 'newColumnsLoaded'; - /** The pivot mode flag was changed */ - Events.EVENT_COLUMN_PIVOT_MODE_CHANGED = 'columnPivotModeChanged'; - /** A row group column was added, removed or order changed. */ - Events.EVENT_COLUMN_ROW_GROUP_CHANGED = 'columnRowGroupChanged'; - /** expandAll / collapseAll was called from the api. */ - Events.EVENT_EXPAND_COLLAPSE_ALL = 'expandOrCollapseAll'; - /** A pivot column was added, removed or order changed. */ - Events.EVENT_COLUMN_PIVOT_CHANGED = 'columnPivotChanged'; - /** The list of grid columns has changed. */ - Events.EVENT_GRID_COLUMNS_CHANGED = 'gridColumnsChanged'; - /** A value column was added, removed or agg function was changed. */ - Events.EVENT_COLUMN_VALUE_CHANGED = 'columnValueChanged'; - /** A column was moved */ - Events.EVENT_COLUMN_MOVED = 'columnMoved'; - /** One or more columns was shown / hidden */ - Events.EVENT_COLUMN_VISIBLE = 'columnVisible'; - /** One or more columns was pinned / unpinned*/ - Events.EVENT_COLUMN_PINNED = 'columnPinned'; - /** A column group was opened / closed */ - Events.EVENT_COLUMN_GROUP_OPENED = 'columnGroupOpened'; - /** One or more columns was resized. If just one, the column in the event is set. */ - Events.EVENT_COLUMN_RESIZED = 'columnResized'; - /** The list of displayed columns has changed, can result from columns open / close, column move, pivot, group, etc */ - Events.EVENT_DISPLAYED_COLUMNS_CHANGED = 'displayedColumnsChanged'; - /** The list of virtual columns has changed, results from viewport changing */ - Events.EVENT_VIRTUAL_COLUMNS_CHANGED = 'virtualColumnsChanged'; - /** A row group was opened / closed */ - Events.EVENT_ROW_GROUP_OPENED = 'rowGroupOpened'; - /** The client has set new data into the grid */ - Events.EVENT_ROW_DATA_CHANGED = 'rowDataChanged'; - /** The client has updated data for the grid */ - Events.EVENT_ROW_DATA_UPDATED = 'rowDataUpdated'; - /** The client has set new floating data into the grid */ - Events.EVENT_PINNED_ROW_DATA_CHANGED = 'pinnedRowDataChanged'; - /** Range selection has changed */ - Events.EVENT_RANGE_SELECTION_CHANGED = 'rangeSelectionChanged'; - /** Chart was created */ - Events.EVENT_CHART_CREATED = 'chartCreated'; - /** Chart Range selection has changed */ - Events.EVENT_CHART_RANGE_SELECTION_CHANGED = 'chartRangeSelectionChanged'; - /** Chart Options have changed */ - Events.EVENT_CHART_OPTIONS_CHANGED = 'chartOptionsChanged'; - /** Chart was destroyed */ - Events.EVENT_CHART_DESTROYED = 'chartDestroyed'; - /** For when the tool panel is shown / hidden */ - Events.EVENT_TOOL_PANEL_VISIBLE_CHANGED = 'toolPanelVisibleChanged'; - /** Model was updated - grid updates the drawn rows when this happens */ - Events.EVENT_MODEL_UPDATED = 'modelUpdated'; - Events.EVENT_PASTE_START = 'pasteStart'; - Events.EVENT_PASTE_END = 'pasteEnd'; - Events.EVENT_FILL_START = 'fillStart'; - Events.EVENT_FILL_END = 'fillEnd'; - Events.EVENT_CELL_CLICKED = 'cellClicked'; - Events.EVENT_CELL_DOUBLE_CLICKED = 'cellDoubleClicked'; - Events.EVENT_CELL_MOUSE_DOWN = 'cellMouseDown'; - Events.EVENT_CELL_CONTEXT_MENU = 'cellContextMenu'; - Events.EVENT_CELL_VALUE_CHANGED = 'cellValueChanged'; - Events.EVENT_ROW_VALUE_CHANGED = 'rowValueChanged'; - Events.EVENT_CELL_FOCUSED = 'cellFocused'; - Events.EVENT_ROW_SELECTED = 'rowSelected'; - Events.EVENT_SELECTION_CHANGED = 'selectionChanged'; - Events.EVENT_CELL_KEY_DOWN = 'cellKeyDown'; - Events.EVENT_CELL_KEY_PRESS = 'cellKeyPress'; - Events.EVENT_CELL_MOUSE_OVER = 'cellMouseOver'; - Events.EVENT_CELL_MOUSE_OUT = 'cellMouseOut'; - /** 2 events for filtering. The grid LISTENS for filterChanged and afterFilterChanged */ - Events.EVENT_FILTER_CHANGED = 'filterChanged'; - /** Filter was change but not applied. Only useful if apply buttons are used in filters. */ - Events.EVENT_FILTER_MODIFIED = 'filterModified'; - Events.EVENT_FILTER_OPENED = 'filterOpened'; - Events.EVENT_SORT_CHANGED = 'sortChanged'; - /** A row was removed from the dom, for any reason. Use to clean up resources (if any) used by the row. */ - Events.EVENT_VIRTUAL_ROW_REMOVED = 'virtualRowRemoved'; - Events.EVENT_ROW_CLICKED = 'rowClicked'; - Events.EVENT_ROW_DOUBLE_CLICKED = 'rowDoubleClicked'; - /** Gets called once after the grid has finished initialising. */ - Events.EVENT_GRID_READY = 'gridReady'; - /** Width of height of the main grid div has changed. Grid listens for this and does layout of grid if it's - * changed, so always filling the space it was given. */ - Events.EVENT_GRID_SIZE_CHANGED = 'gridSizeChanged'; - /** The indexes of the rows rendered has changed, eg user has scrolled to a new vertical position. */ - Events.EVENT_VIEWPORT_CHANGED = 'viewportChanged'; - /** Rows were rendered for the first time (ie on async data load). */ - Events.EVENT_FIRST_DATA_RENDERED = 'firstDataRendered'; - /** A column drag has started, either resizing a column or moving a column. */ - Events.EVENT_DRAG_STARTED = 'dragStarted'; - /** A column drag has stopped */ - Events.EVENT_DRAG_STOPPED = 'dragStopped'; - Events.EVENT_CHECKBOX_CHANGED = 'checkboxChanged'; - Events.EVENT_ROW_EDITING_STARTED = 'rowEditingStarted'; - Events.EVENT_ROW_EDITING_STOPPED = 'rowEditingStopped'; - Events.EVENT_CELL_EDITING_STARTED = 'cellEditingStarted'; - Events.EVENT_CELL_EDITING_STOPPED = 'cellEditingStopped'; - /** Main body of grid has scrolled, either horizontally or vertically */ - Events.EVENT_BODY_SCROLL = 'bodyScroll'; - Events.EVENT_ANIMATION_QUEUE_EMPTY = 'animationQueueEmpty'; - Events.EVENT_HEIGHT_SCALE_CHANGED = 'heightScaleChanged'; - /** The displayed page for pagination has changed. For example the data was filtered or sorted, - * or the user has moved to a different page. */ - Events.EVENT_PAGINATION_CHANGED = 'paginationChanged'; - /** Only used by React, Angular 2+, Web Components and VueJS ag-Grid components - * (not used if doing plain JavaScript or Angular 1.x). If the grid receives changes due - * to bound properties, this event fires after the grid has finished processing the change. */ - Events.EVENT_COMPONENT_STATE_CHANGED = 'componentStateChanged'; - /** All items from here down are used internally by the grid, not intended for external use. */ - // not documented, either experimental, or we just don't want users using an depending on them - Events.EVENT_BODY_HEIGHT_CHANGED = 'bodyHeightChanged'; - Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED = 'displayedColumnsWidthChanged'; - Events.EVENT_SCROLL_VISIBILITY_CHANGED = 'scrollVisibilityChanged'; - Events.EVENT_COLUMN_HOVER_CHANGED = 'columnHoverChanged'; - Events.EVENT_FLASH_CELLS = 'flashCells'; - Events.EVENT_ROW_DRAG_ENTER = 'rowDragEnter'; - Events.EVENT_ROW_DRAG_MOVE = 'rowDragMove'; - Events.EVENT_ROW_DRAG_LEAVE = 'rowDragLeave'; - Events.EVENT_ROW_DRAG_END = 'rowDragEnd'; - // primarily for charts - Events.EVENT_POPUP_TO_FRONT = 'popupToFront'; - // these are used for server side group and agg - only used by CS with Viewport Row Model - intention is - // to design these better around server side functions and then release to general public when fully working with - // all the row models. - Events.EVENT_COLUMN_ROW_GROUP_CHANGE_REQUEST = 'columnRowGroupChangeRequest'; - Events.EVENT_COLUMN_PIVOT_CHANGE_REQUEST = 'columnPivotChangeRequest'; - Events.EVENT_COLUMN_VALUE_CHANGE_REQUEST = 'columnValueChangeRequest'; - Events.EVENT_COLUMN_AGG_FUNC_CHANGE_REQUEST = 'columnAggFuncChangeRequest'; - Events.EVENT_KEYBOARD_FOCUS = 'keyboardFocus'; - Events.EVENT_MOUSE_FOCUS = 'mouseFocus'; - return Events; -}()); + PopupComponent.prototype.isPopup = function () { + return true; + }; + PopupComponent.prototype.setParentComponent = function (container) { + container.addCssClass('ag-has-popup'); + _super.prototype.setParentComponent.call(this, container); + }; + PopupComponent.prototype.destroy = function () { + var parentComp = this.parentComponent; + var hasParent = parentComp && parentComp.isAlive(); + if (hasParent) { + parentComp.getGui().classList.remove('ag-has-popup'); + } + _super.prototype.destroy.call(this); + }; + return PopupComponent; +}(_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); /***/ }), -/* 45 */ +/* 86 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GroupInstanceIdCreator", function() { return GroupInstanceIdCreator; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PopupSelectCellEditor", function() { return PopupSelectCellEditor; }); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(14); +/* harmony import */ var _selectCellEditor__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(87); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -// class returns unique instance id's for columns. -// eg, the following calls (in this order) will result in: -// -// getInstanceIdForKey('country') => 0 -// getInstanceIdForKey('country') => 1 -// getInstanceIdForKey('country') => 2 -// getInstanceIdForKey('country') => 3 -// getInstanceIdForKey('age') => 0 -// getInstanceIdForKey('age') => 1 -// getInstanceIdForKey('country') => 4 -var GroupInstanceIdCreator = /** @class */ (function () { - function GroupInstanceIdCreator() { - // this map contains keys to numbers, so we remember what the last call was - this.existingIds = {}; +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); + + +var PopupSelectCellEditor = /** @class */ (function (_super) { + __extends(PopupSelectCellEditor, _super); + function PopupSelectCellEditor() { + var _this = _super.call(this) || this; + Object(_utils_function__WEBPACK_IMPORTED_MODULE_0__["doOnce"])(function () { return console.warn('AG Grid: The PopupSelectCellEditor (agPopupSelectCellEditor) is deprecated. Instead use {cellEditor: "agSelectCellEditor", cellEditorPopup: true} '); }, 'PopupSelectCellEditor.deprecated'); + return _this; } - GroupInstanceIdCreator.prototype.getInstanceIdForKey = function (key) { - var lastResult = this.existingIds[key]; - var result; - if (typeof lastResult !== 'number') { - // first time this key - result = 0; - } - else { - result = lastResult + 1; - } - this.existingIds[key] = result; - return result; + PopupSelectCellEditor.prototype.isPopup = function () { + return true; }; - return GroupInstanceIdCreator; -}()); + return PopupSelectCellEditor; +}(_selectCellEditor__WEBPACK_IMPORTED_MODULE_1__["SelectCellEditor"])); /***/ }), -/* 46 */ +/* 87 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnUtils", function() { return ColumnUtils; }); -/* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(34); -/* harmony import */ var _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(33); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(41); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SelectCellEditor", function() { return SelectCellEditor; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(85); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(65); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -9705,141 +16934,82 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta - -// takes in a list of columns, as specified by the column definitions, and returns column groups -var ColumnUtils = /** @class */ (function (_super) { - __extends(ColumnUtils, _super); - function ColumnUtils() { - return _super !== null && _super.apply(this, arguments) || this; +var SelectCellEditor = /** @class */ (function (_super) { + __extends(SelectCellEditor, _super); + function SelectCellEditor() { + var _this = _super.call(this, '
') || this; + _this.startedByEnter = false; + return _this; } - ColumnUtils.prototype.calculateColInitialWidth = function (colDef) { - var optionsWrapper = this.gridOptionsWrapper; - var minColWidth = colDef.minWidth != null ? colDef.minWidth : optionsWrapper.getMinColWidth(); - var maxColWidth = colDef.maxWidth != null ? colDef.maxWidth : (optionsWrapper.getMaxColWidth() || _utils__WEBPACK_IMPORTED_MODULE_3__["_"].getMaxSafeInteger()); - var width = colDef.width != null ? colDef.width : optionsWrapper.getColWidth(); - return Math.max(Math.min(width, maxColWidth), minColWidth); - }; - ColumnUtils.prototype.getOriginalPathForColumn = function (column, originalBalancedTree) { - var result = []; - var found = false; - var recursePath = function (balancedColumnTree, dept) { - for (var i = 0; i < balancedColumnTree.length; i++) { - if (found) { - return; - } - // quit the search, so 'result' is kept with the found result - var node = balancedColumnTree[i]; - if (node instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"]) { - var nextNode = node; - recursePath(nextNode.getChildren(), dept + 1); - result[dept] = node; - } - else if (node === column) { - found = true; - } - } - }; - recursePath(originalBalancedTree, 0); - // we should always find the path, but in case there is a bug somewhere, returning null - // will make it fail rather than provide a 'hard to track down' bug - return found ? result : null; - }; - /* public getPathForColumn(column: Column, allDisplayedColumnGroups: ColumnGroupChild[]): ColumnGroup[] { - let result: ColumnGroup[] = []; - let found = false; - - recursePath(allDisplayedColumnGroups, 0); - - // we should always find the path, but in case there is a bug somewhere, returning null - // will make it fail rather than provide a 'hard to track down' bug - if (found) { - return result; - } else { - return null; - } - - function recursePath(balancedColumnTree: ColumnGroupChild[], dept: number): void { - - for (let i = 0; i node; - recursePath(nextNode.getChildren(), dept+1); - result[dept] = node; - } else { - if (node === column) { - found = true; - } - } - } - } - }*/ - ColumnUtils.prototype.depthFirstOriginalTreeSearch = function (parent, tree, callback) { + SelectCellEditor.prototype.init = function (params) { var _this = this; - if (!tree) { + this.focusAfterAttached = params.cellStartedEdit; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["missing"])(params.values)) { + console.warn('AG Grid: no values found for select cellEditor'); return; } - tree.forEach(function (child) { - if (child instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"]) { - _this.depthFirstOriginalTreeSearch(child, child.getChildren(), callback); - } - callback(child, parent); + this.startedByEnter = params.eventKey != null ? params.eventKey === _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].ENTER : false; + var hasValue = false; + params.values.forEach(function (value) { + var option = { value: value }; + var valueFormatted = _this.valueFormatterService.formatValue(params.column, null, null, value); + var valueFormattedExits = valueFormatted !== null && valueFormatted !== undefined; + option.text = valueFormattedExits ? valueFormatted : value; + _this.eSelect.addOption(option); + hasValue = hasValue || params.value === value; }); - }; - ColumnUtils.prototype.depthFirstAllColumnTreeSearch = function (tree, callback) { - var _this = this; - if (!tree) { - return; + if (hasValue) { + this.eSelect.setValue(params.value, true); + } + else if (params.values.length) { + this.eSelect.setValue(params.values[0], true); + } + // we don't want to add this if full row editing, otherwise selecting will stop the + // full row editing. + if (!this.gridOptionsWrapper.isFullRowEdit()) { + this.eSelect.onValueChange(function () { return params.stopEditing(); }); } - tree.forEach(function (child) { - if (child instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) { - _this.depthFirstAllColumnTreeSearch(child.getChildren(), callback); - } - callback(child); - }); }; - ColumnUtils.prototype.depthFirstDisplayedColumnTreeSearch = function (tree, callback) { - var _this = this; - if (!tree) { - return; + SelectCellEditor.prototype.afterGuiAttached = function () { + if (this.focusAfterAttached) { + this.eSelect.getFocusableElement().focus(); } - tree.forEach(function (child) { - if (child instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) { - _this.depthFirstDisplayedColumnTreeSearch(child.getDisplayedChildren(), callback); - } - callback(child); - }); + if (this.startedByEnter) { + this.eSelect.showPicker(); + } + }; + SelectCellEditor.prototype.focusIn = function () { + this.eSelect.getFocusableElement().focus(); + }; + SelectCellEditor.prototype.getValue = function () { + return this.eSelect.getValue(); + }; + SelectCellEditor.prototype.isPopup = function () { + return false; }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper') - ], ColumnUtils.prototype, "gridOptionsWrapper", void 0); - ColumnUtils = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Bean"])('columnUtils') - ], ColumnUtils); - return ColumnUtils; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_4__["BeanStub"])); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueFormatterService') + ], SelectCellEditor.prototype, "valueFormatterService", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('eSelect') + ], SelectCellEditor.prototype, "eSelect", void 0); + return SelectCellEditor; +}(_widgets_popupComponent__WEBPACK_IMPORTED_MODULE_1__["PopupComponent"])); /***/ }), -/* 47 */ +/* 88 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DisplayedGroupCreator", function() { return DisplayedGroupCreator; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(34); -/* harmony import */ var _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(33); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(41); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PopupTextCellEditor", function() { return PopupTextCellEditor; }); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(14); +/* harmony import */ var _textCellEditor__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(89); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -9856,2214 +17026,2937 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - -// takes in a list of columns, as specified by the column definitions, and returns column groups -var DisplayedGroupCreator = /** @class */ (function (_super) { - __extends(DisplayedGroupCreator, _super); - function DisplayedGroupCreator() { - return _super !== null && _super.apply(this, arguments) || this; +var PopupTextCellEditor = /** @class */ (function (_super) { + __extends(PopupTextCellEditor, _super); + function PopupTextCellEditor() { + var _this = _super.call(this) || this; + Object(_utils_function__WEBPACK_IMPORTED_MODULE_0__["doOnce"])(function () { return console.warn('AG Grid: The PopupTextCellEditor (agPopupTextCellEditor) is deprecated. Instead use {cellEditor: "agTextCellEditor", cellEditorPopup: true} '); }, 'PopupTextCellEditor.deprecated'); + return _this; } - DisplayedGroupCreator.prototype.createDisplayedGroups = function ( - // all displayed columns sorted - this is the columns the grid should show - sortedVisibleColumns, - // the tree of columns, as provided by the users, used to know what groups columns roll up into - balancedColumnTree, - // creates unique id's for the group - groupInstanceIdCreator, - // whether it's left, right or center col - pinned, - // we try to reuse old groups if we can, to allow gui to do animation - oldDisplayedGroups) { - var _this = this; - var result = []; - var previousRealPath; - var previousOriginalPath; - var oldColumnsMapped = this.mapOldGroupsById(oldDisplayedGroups); - // go through each column, then do a bottom up comparison to the previous column, and start - // to share groups if they converge at any point. - sortedVisibleColumns.forEach(function (currentColumn) { - var currentOriginalPath = _this.getOriginalPathForColumn(balancedColumnTree, currentColumn); - var currentRealPath = []; - var firstColumn = !previousOriginalPath; - for (var i = 0; i < currentOriginalPath.length; i++) { - if (firstColumn || currentOriginalPath[i] !== previousOriginalPath[i]) { - // new group needed - var newGroup = _this.createColumnGroup(currentOriginalPath[i], groupInstanceIdCreator, oldColumnsMapped, pinned); - currentRealPath[i] = newGroup; - // if top level, add to result, otherwise add to parent - if (i == 0) { - result.push(newGroup); - } - else { - currentRealPath[i - 1].addChild(newGroup); - } - } - else { - // reuse old group - currentRealPath[i] = previousRealPath[i]; - } - } - var noColumnGroups = currentRealPath.length === 0; - if (noColumnGroups) { - // if we are not grouping, then the result of the above is an empty - // path (no groups), and we just add the column to the root list. - result.push(currentColumn); - } - else { - var leafGroup = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].last(currentRealPath); - leafGroup.addChild(currentColumn); - } - previousRealPath = currentRealPath; - previousOriginalPath = currentOriginalPath; - }); - this.setupParentsIntoColumns(result, null); - return result; - }; - DisplayedGroupCreator.prototype.createColumnGroup = function (originalGroup, groupInstanceIdCreator, oldColumnsMapped, pinned) { - var groupId = originalGroup.getGroupId(); - var instanceId = groupInstanceIdCreator.getInstanceIdForKey(groupId); - var uniqueId = _entities_columnGroup__WEBPACK_IMPORTED_MODULE_1__["ColumnGroup"].createUniqueId(groupId, instanceId); - var columnGroup = oldColumnsMapped[uniqueId]; - // if the user is setting new colDefs, it is possible that the id's overlap, and we - // would have a false match from above. so we double check we are talking about the - // same original column group. - if (columnGroup && columnGroup.getOriginalColumnGroup() !== originalGroup) { - columnGroup = null; - } - if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(columnGroup)) { - // clean out the old column group here, as we will be adding children into it again - columnGroup.reset(); - } - else { - columnGroup = new _entities_columnGroup__WEBPACK_IMPORTED_MODULE_1__["ColumnGroup"](originalGroup, groupId, instanceId, pinned); - this.context.createBean(columnGroup); - } - return columnGroup; - }; - // returns back a 2d map of ColumnGroup as follows: groupId -> instanceId -> ColumnGroup - DisplayedGroupCreator.prototype.mapOldGroupsById = function (displayedGroups) { - var result = {}; - var recursive = function (columnsOrGroups) { - columnsOrGroups.forEach(function (columnOrGroup) { - if (columnOrGroup instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_1__["ColumnGroup"]) { - var columnGroup = columnOrGroup; - result[columnOrGroup.getUniqueId()] = columnGroup; - recursive(columnGroup.getChildren()); - } - }); - }; - if (displayedGroups) { - recursive(displayedGroups); - } - return result; - }; - DisplayedGroupCreator.prototype.setupParentsIntoColumns = function (columnsOrGroups, parent) { - var _this = this; - columnsOrGroups.forEach(function (columnsOrGroup) { - columnsOrGroup.setParent(parent); - if (columnsOrGroup instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_1__["ColumnGroup"]) { - var columnGroup = columnsOrGroup; - _this.setupParentsIntoColumns(columnGroup.getChildren(), columnGroup); - } - }); - }; - DisplayedGroupCreator.prototype.getOriginalPathForColumn = function (balancedColumnTree, column) { - var result = []; - var found = false; - var recursePath = function (balancedColumnTree, dept) { - for (var i = 0; i < balancedColumnTree.length; i++) { - // quit the search, so 'result' is kept with the found result - if (found) { - return; - } - var node = balancedColumnTree[i]; - if (node instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_2__["OriginalColumnGroup"]) { - var nextNode = node; - recursePath(nextNode.getChildren(), dept + 1); - result[dept] = node; - } - else if (node === column) { - found = true; - } - } - }; - recursePath(balancedColumnTree, 0); - // it's possible we didn't find a path. this happens if the column is generated - // by the grid (auto-group), in that the definition didn't come from the client. in this case, - // we create a fake original path. - if (found) { - return result; - } - console.warn('could not get path'); - return null; + PopupTextCellEditor.prototype.isPopup = function () { + return true; }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnUtils') - ], DisplayedGroupCreator.prototype, "columnUtils", void 0); - DisplayedGroupCreator = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('displayedGroupCreator') - ], DisplayedGroupCreator); - return DisplayedGroupCreator; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_4__["BeanStub"])); + return PopupTextCellEditor; +}(_textCellEditor__WEBPACK_IMPORTED_MODULE_1__["TextCellEditor"])); /***/ }), -/* 48 */ +/* 89 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ComponentUtil", function() { return ComponentUtil; }); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(43); -/* harmony import */ var _propertyKeys__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(49); -/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(50); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TextCellEditor", function() { return TextCellEditor; }); +/* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(85); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); +/* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(65); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var __spreadArrays = (undefined && undefined.__spreadArrays) || function () { - for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; - for (var r = Array(s), k = 0, i = 0; i < il; i++) - for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) - r[k] = a[j]; - return r; +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; }; -var ComponentUtil = /** @class */ (function () { - function ComponentUtil() { + +var TextCellEditor = /** @class */ (function (_super) { + __extends(TextCellEditor, _super); + function TextCellEditor() { + return _super.call(this, TextCellEditor.TEMPLATE) || this; } - ComponentUtil.getEventCallbacks = function () { - if (!ComponentUtil.EVENT_CALLBACKS) { - ComponentUtil.EVENT_CALLBACKS = ComponentUtil.EVENTS.map(function (event) { return ComponentUtil.getCallbackForEvent(event); }); - } - return ComponentUtil.EVENT_CALLBACKS; - }; - ComponentUtil.copyAttributesToGridOptions = function (gridOptions, component, skipEventDeprecationCheck) { - if (skipEventDeprecationCheck === void 0) { skipEventDeprecationCheck = false; } - checkForDeprecated(component); - // create empty grid options if none were passed - if (typeof gridOptions !== 'object') { - gridOptions = {}; - } - // to allow array style lookup in TypeScript, take type away from 'this' and 'gridOptions' - var pGridOptions = gridOptions; - var keyExists = function (key) { return typeof component[key] !== 'undefined'; }; - // add in all the simple properties - __spreadArrays(ComponentUtil.ARRAY_PROPERTIES, ComponentUtil.STRING_PROPERTIES, ComponentUtil.OBJECT_PROPERTIES, ComponentUtil.FUNCTION_PROPERTIES, ComponentUtil.getEventCallbacks()).filter(keyExists) - .forEach(function (key) { return pGridOptions[key] = component[key]; }); - ComponentUtil.BOOLEAN_PROPERTIES - .filter(keyExists) - .forEach(function (key) { return pGridOptions[key] = ComponentUtil.toBoolean(component[key]); }); - ComponentUtil.NUMBER_PROPERTIES - .filter(keyExists) - .forEach(function (key) { return pGridOptions[key] = ComponentUtil.toNumber(component[key]); }); - // purely for event deprecation checks (for frameworks - wouldn't apply for non-fw versions) - if (!skipEventDeprecationCheck) { - ComponentUtil.EVENTS - // React uses onXXX, not sure why this is different to the other frameworks - .filter(function (event) { return keyExists(event) || keyExists(ComponentUtil.getCallbackForEvent(event)); }) - .forEach(function (event) { return _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__["GridOptionsWrapper"].checkEventDeprecation(event); }); - } - return gridOptions; - }; - ComponentUtil.getCallbackForEvent = function (eventName) { - if (!eventName || eventName.length < 2) { - return eventName; + TextCellEditor.prototype.init = function (params) { + this.params = params; + var eInput = this.eInput; + var startValue; + // cellStartedEdit is only false if we are doing fullRow editing + if (params.cellStartedEdit) { + this.focusAfterAttached = true; + if (params.eventKey === _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].BACKSPACE || params.eventKey === _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].DELETE) { + startValue = ''; + } + else if (params.charPress) { + startValue = params.charPress; + } + else { + startValue = this.getStartValue(params); + if (params.eventKey !== _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].F2) { + this.highlightAllOnFocus = true; + } + } } else { - return 'on' + eventName[0].toUpperCase() + eventName.substr(1); - } - }; - ComponentUtil.processOnChange = function (changes, gridOptions, api, columnApi) { - if (!changes) { - return; - } - checkForDeprecated(changes); - // to allow array style lookup in TypeScript, take type away from 'this' and 'gridOptions' - var pGridOptions = gridOptions; - var keyExists = function (key) { return changes[key]; }; - // check if any change for the simple types, and if so, then just copy in the new value - __spreadArrays(ComponentUtil.ARRAY_PROPERTIES, ComponentUtil.OBJECT_PROPERTIES, ComponentUtil.STRING_PROPERTIES, ComponentUtil.getEventCallbacks()).filter(keyExists) - .forEach(function (key) { return pGridOptions[key] = changes[key].currentValue; }); - ComponentUtil.BOOLEAN_PROPERTIES - .filter(keyExists) - .forEach(function (key) { return pGridOptions[key] = ComponentUtil.toBoolean(changes[key].currentValue); }); - ComponentUtil.NUMBER_PROPERTIES - .filter(keyExists) - .forEach(function (key) { return pGridOptions[key] = ComponentUtil.toNumber(changes[key].currentValue); }); - if (changes.enableCellTextSelection) { - api.setEnableCellTextSelection(ComponentUtil.toBoolean(changes.enableCellTextSelection.currentValue)); - } - if (changes.showToolPanel) { - api.showToolPanel(ComponentUtil.toBoolean(changes.showToolPanel.currentValue)); - } - if (changes.quickFilterText) { - api.setQuickFilter(changes.quickFilterText.currentValue); - } - if (changes.rowData) { - api.setRowData(changes.rowData.currentValue); - } - if (changes.pinnedTopRowData) { - api.setPinnedTopRowData(changes.pinnedTopRowData.currentValue); - } - if (changes.pinnedBottomRowData) { - api.setPinnedBottomRowData(changes.pinnedBottomRowData.currentValue); - } - if (changes.autoGroupColumnDef) { - api.setAutoGroupColumnDef(changes.autoGroupColumnDef.currentValue, "gridOptionsChanged"); - } - if (changes.columnDefs) { - api.setColumnDefs(changes.columnDefs.currentValue, "gridOptionsChanged"); - } - if (changes.datasource) { - api.setDatasource(changes.datasource.currentValue); - } - if (changes.headerHeight) { - api.setHeaderHeight(ComponentUtil.toNumber(changes.headerHeight.currentValue)); - } - if (changes.paginationPageSize) { - api.paginationSetPageSize(ComponentUtil.toNumber(changes.paginationPageSize.currentValue)); - } - if (changes.pivotMode) { - columnApi.setPivotMode(ComponentUtil.toBoolean(changes.pivotMode.currentValue)); - } - if (changes.groupRemoveSingleChildren) { - api.setGroupRemoveSingleChildren(ComponentUtil.toBoolean(changes.groupRemoveSingleChildren.currentValue)); - } - if (changes.suppressRowDrag) { - api.setSuppressRowDrag(ComponentUtil.toBoolean(changes.suppressRowDrag.currentValue)); - } - if (changes.suppressMoveWhenRowDragging) { - api.setSuppressMoveWhenRowDragging(ComponentUtil.toBoolean(changes.suppressMoveWhenRowDragging.currentValue)); - } - if (changes.suppressRowClickSelection) { - api.setSuppressRowClickSelection(ComponentUtil.toBoolean(changes.suppressRowClickSelection.currentValue)); - } - if (changes.gridAutoHeight) { - api.setGridAutoHeight(ComponentUtil.toBoolean(changes.gridAutoHeight.currentValue)); - } - if (changes.suppressClipboardPaste) { - api.setSuppressClipboardPaste(ComponentUtil.toBoolean(changes.suppressClipboardPaste.currentValue)); + this.focusAfterAttached = false; + startValue = this.getStartValue(params); } - if (changes.sideBar) { - api.setSideBar(changes.sideBar.currentValue); + if (startValue != null) { + eInput.setValue(startValue, true); } - // copy changes into an event for dispatch - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COMPONENT_STATE_CHANGED, - api: gridOptions.api, - columnApi: gridOptions.columnApi - }; - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].iterateObject(changes, function (key, value) { - event[key] = value; + this.addManagedListener(eInput.getGui(), 'keydown', function (event) { + var key = event.key; + if (key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].PAGE_UP || key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].PAGE_DOWN) { + event.preventDefault(); + } }); - api.dispatchEvent(event); }; - ComponentUtil.toBoolean = function (value) { - if (typeof value === 'boolean') { - return value; - } - else if (typeof value === 'string') { - // for boolean, compare to empty String to allow attributes appearing with - // no value to be treated as 'true' - return value.toUpperCase() === 'TRUE' || value == ''; - } - else { - return false; + TextCellEditor.prototype.afterGuiAttached = function () { + var translate = this.gridOptionsWrapper.getLocaleTextFunc(); + var eInput = this.eInput; + eInput.setInputAriaLabel(translate('ariaInputEditor', 'Input Editor')); + if (!this.focusAfterAttached) { + return; } - }; - ComponentUtil.toNumber = function (value) { - if (typeof value === 'number') { - return value; + // Added for AG-3238. We can't remove this explicit focus() because Chrome requires an input + // to be focused before setSelectionRange will work. But it triggers a bug in Safari where + // explicitly focusing then blurring an empty field will cause the parent container to scroll. + if (!Object(_utils_browser__WEBPACK_IMPORTED_MODULE_3__["isBrowserSafari"])()) { + eInput.getFocusableElement().focus(); } - else if (typeof value === 'string') { - return Number(value); + var inputEl = eInput.getInputElement(); + if (this.highlightAllOnFocus) { + inputEl.select(); } else { - return undefined; - } - }; - // all the events are populated in here AFTER this class (at the bottom of the file). - ComponentUtil.EVENTS = []; - ComponentUtil.STRING_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].STRING_PROPERTIES; - ComponentUtil.OBJECT_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].OBJECT_PROPERTIES; - ComponentUtil.ARRAY_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].ARRAY_PROPERTIES; - ComponentUtil.NUMBER_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].NUMBER_PROPERTIES; - ComponentUtil.BOOLEAN_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].BOOLEAN_PROPERTIES; - ComponentUtil.FUNCTION_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].FUNCTION_PROPERTIES; - ComponentUtil.ALL_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].ALL_PROPERTIES; - return ComponentUtil; -}()); - -ComponentUtil.EVENTS = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].values(_events__WEBPACK_IMPORTED_MODULE_0__["Events"]); -function checkForDeprecated(changes) { - if (changes.rowDeselected || changes.onRowDeselected) { - console.warn('ag-grid: as of v3.4 rowDeselected no longer exists. Please check the docs.'); - } -} - - -/***/ }), -/* 49 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PropertyKeys", function() { return PropertyKeys; }); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __spreadArrays = (undefined && undefined.__spreadArrays) || function () { - for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; - for (var r = Array(s), k = 0, i = 0; i < il; i++) - for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) - r[k] = a[j]; - return r; -}; -/** - * These keys are used for validating properties supplied on a gridOptions object, and for code generation. - * If you change the properties on the gridOptions interface, you *must* update this file as well to be consistent. - */ -var PropertyKeys = /** @class */ (function () { - function PropertyKeys() { - } - PropertyKeys.STRING_PROPERTIES = [ - 'sortingOrder', 'rowClass', 'rowSelection', 'overlayLoadingTemplate', - 'overlayNoRowsTemplate', 'quickFilterText', 'rowModelType', - 'editType', 'domLayout', 'clipboardDeliminator', 'rowGroupPanelShow', - 'multiSortKey', 'pivotColumnGroupTotals', 'pivotRowTotals', 'pivotPanelShow' - ]; - PropertyKeys.OBJECT_PROPERTIES = [ - 'components', 'frameworkComponents', 'rowStyle', 'context', 'autoGroupColumnDef', 'groupColumnDef', 'localeText', - 'icons', 'datasource', 'serverSideDatasource', 'viewportDatasource', 'groupRowRendererParams', 'aggFuncs', - 'fullWidthCellRendererParams', 'defaultColGroupDef', 'defaultColDef', 'defaultExportParams', 'columnTypes', - 'rowClassRules', 'detailGridOptions', 'detailCellRendererParams', 'loadingCellRendererParams', 'loadingOverlayComponentParams', - 'noRowsOverlayComponentParams', 'popupParent', 'colResizeDefault', 'reduxStore', 'statusBar', 'sideBar' - ]; - PropertyKeys.ARRAY_PROPERTIES = [ - 'slaveGrids', 'alignedGrids', 'rowData', 'columnDefs', 'excelStyles', 'pinnedTopRowData', 'pinnedBottomRowData' - ]; - PropertyKeys.NUMBER_PROPERTIES = [ - 'rowHeight', 'detailRowHeight', 'rowBuffer', 'colWidth', 'headerHeight', 'groupHeaderHeight', 'floatingFiltersHeight', - 'pivotHeaderHeight', 'pivotGroupHeaderHeight', 'groupDefaultExpanded', 'minColWidth', 'maxColWidth', 'viewportRowModelPageSize', - 'viewportRowModelBufferSize', 'autoSizePadding', 'maxBlocksInCache', 'maxConcurrentDatasourceRequests', 'tooltipShowDelay', - 'cacheOverflowSize', 'paginationPageSize', 'cacheBlockSize', 'infiniteInitialRowCount', 'scrollbarWidth', 'paginationStartPage', - 'infiniteBlockSize', 'batchUpdateWaitMillis', 'asyncTransactionWaitMillis', 'blockLoadDebounceMillis', 'keepDetailRowsCount', - 'undoRedoCellEditingLimit', 'cellFlashDelay', 'cellFadeDelay' - ]; - PropertyKeys.BOOLEAN_PROPERTIES = [ - 'toolPanelSuppressRowGroups', 'toolPanelSuppressValues', 'toolPanelSuppressPivots', 'toolPanelSuppressPivotMode', - 'toolPanelSuppressSideButtons', 'toolPanelSuppressColumnFilter', 'toolPanelSuppressColumnSelectAll', - 'toolPanelSuppressColumnExpandAll', 'suppressMakeColumnVisibleAfterUnGroup', 'suppressRowClickSelection', - 'suppressCellSelection', 'suppressHorizontalScroll', 'alwaysShowVerticalScroll', 'debug', 'enableBrowserTooltips', - 'enableColResize', 'enableCellExpressions', 'enableSorting', 'enableServerSideSorting', 'enableFilter', 'enableServerSideFilter', - 'angularCompileRows', 'angularCompileFilters', 'angularCompileHeaders', 'groupSuppressAutoColumn', 'groupSelectsChildren', - 'groupIncludeFooter', 'groupIncludeTotalFooter', 'groupUseEntireRow', 'groupSuppressRow', 'groupSuppressBlankHeader', - 'forPrint', 'suppressMenuHide', 'rowDeselection', 'unSortIcon', 'suppressMultiSort', 'singleClickEdit', 'suppressLoadingOverlay', - 'suppressNoRowsOverlay', 'suppressAutoSize', 'skipHeaderOnAutoSize', 'suppressParentsInRowNodes', 'showToolPanel', - 'suppressColumnMoveAnimation', 'suppressMovableColumns', 'suppressFieldDotNotation', 'enableRangeSelection', 'enableRangeHandle', - 'enableFillHandle', 'suppressClearOnFillReduction', 'deltaSort', 'suppressTouch', 'suppressAsyncEvents', 'allowContextMenuWithControlKey', - 'suppressContextMenu', 'suppressMenuFilterPanel', 'suppressMenuMainPanel', 'suppressMenuColumnPanel', 'rememberGroupStateWhenNewData', - 'enableCellChangeFlash', 'suppressDragLeaveHidesColumns', 'suppressMiddleClickScrolls', 'suppressPreventDefaultOnMouseWheel', - 'suppressUseColIdForGroups', 'suppressCopyRowsToClipboard', 'copyHeadersToClipboard', 'pivotMode', 'suppressAggFuncInHeader', - 'suppressColumnVirtualisation', 'suppressAggAtRootLevel', 'suppressFocusAfterRefresh', 'functionsPassive', 'functionsReadOnly', - 'animateRows', 'groupSelectsFiltered', 'groupRemoveSingleChildren', 'groupRemoveLowestSingleChildren', 'enableRtl', 'suppressClickEdit', - 'rowDragManaged', 'suppressRowDrag', 'suppressMoveWhenRowDragging', 'enableMultiRowDragging', 'enableGroupEdit', 'embedFullWidthRows', - 'deprecatedEmbedFullWidthRows', 'suppressTabbing', 'suppressPaginationPanel', 'floatingFilter', 'groupHideOpenParents', 'groupMultiAutoColumn', - 'pagination', 'stopEditingWhenGridLosesFocus', 'paginationAutoPageSize', 'suppressScrollOnNewData', 'purgeClosedRowNodes', 'cacheQuickFilter', - 'deltaRowDataMode', 'ensureDomOrder', 'accentedSort', 'pivotTotals', 'suppressChangeDetection', 'valueCache', 'valueCacheNeverExpires', - 'aggregateOnlyChangedColumns', 'suppressAnimationFrame', 'suppressExcelExport', 'suppressCsvExport', 'treeData', 'masterDetail', - 'suppressMultiRangeSelection', 'enterMovesDownAfterEdit', 'enterMovesDown', 'suppressPropertyNamesCheck', 'rowMultiSelectWithClick', - 'contractColumnSelection', 'suppressEnterpriseResetOnNewColumns', 'enableOldSetFilterModel', 'suppressRowHoverHighlight', 'gridAutoHeight', - 'suppressRowTransform', 'suppressClipboardPaste', 'suppressLastEmptyLineOnPaste', 'serverSideSortingAlwaysResets', 'reactNext', - 'suppressSetColumnStateEvents', 'enableCharts', 'deltaColumnMode', 'suppressMaintainUnsortedOrder', 'enableCellTextSelection', - 'suppressBrowserResizeObserver', 'suppressMaxRenderedRowRestriction', 'excludeChildrenWhenTreeDataFiltering', 'tooltipMouseTrack', - 'keepDetailRows', 'paginateChildRows', 'preventDefaultOnContextMenu', 'undoRedoCellEditing', 'allowDragFromColumnsToolPanel', - 'immutableData', 'immutableColumns', 'pivotSuppressAutoColumn' - ]; - /** You do not need to include event callbacks in this list, as they are generated automatically. */ - PropertyKeys.FUNCTION_PROPERTIES = [ - 'localeTextFunc', 'groupRowInnerRenderer', 'groupRowInnerRendererFramework', 'dateComponent', 'dateComponentFramework', 'groupRowRenderer', - 'groupRowRendererFramework', 'isExternalFilterPresent', 'getRowHeight', 'doesExternalFilterPass', 'getRowClass', 'getRowStyle', - 'getRowClassRules', 'traverseNode', 'getContextMenuItems', 'getMainMenuItems', 'processRowPostCreate', 'processCellForClipboard', - 'getNodeChildDetails', 'groupRowAggNodes', 'getRowNodeId', 'isFullWidthCell', 'fullWidthCellRenderer', 'fullWidthCellRendererFramework', - 'doesDataFlower', 'processSecondaryColDef', 'processSecondaryColGroupDef', 'getBusinessKeyForNode', 'sendToClipboard', 'navigateToNextCell', - 'tabToNextCell', 'getDetailRowData', 'processCellFromClipboard', 'getDocument', 'postProcessPopup', 'getChildCount', 'getDataPath', - 'loadingCellRenderer', 'loadingCellRendererFramework', 'loadingOverlayComponent', 'loadingOverlayComponentFramework', 'noRowsOverlayComponent', - 'noRowsOverlayComponentFramework', 'detailCellRenderer', 'detailCellRendererFramework', 'defaultGroupSortComparator', 'isRowMaster', - 'isRowSelectable', 'postSort', 'processHeaderForClipboard', 'paginationNumberFormatter', 'processDataFromClipboard', 'getServerSideGroupKey', - 'isServerSideGroup', 'suppressKeyboardEvent', 'createChartContainer', 'processChartOptions', 'getChartToolbarItems', 'fillOperation' - ]; - PropertyKeys.ALL_PROPERTIES = __spreadArrays(PropertyKeys.ARRAY_PROPERTIES, PropertyKeys.OBJECT_PROPERTIES, PropertyKeys.STRING_PROPERTIES, PropertyKeys.NUMBER_PROPERTIES, PropertyKeys.FUNCTION_PROPERTIES, PropertyKeys.BOOLEAN_PROPERTIES); - /** - * Used when performing property checks. This avoids noise caused when using frameworks, which can add their own - * framework-specific properties to colDefs, gridOptions etc. - */ - PropertyKeys.FRAMEWORK_PROPERTIES = [ - '__ob__', '__metadata__', 'mappedColumnProperties', 'hasChildColumns', 'toColDef', 'createColDefFromGridColumn' - ]; - return PropertyKeys; -}()); + // when we started editing, we want the caret at the end, not the start. + // this comes into play in two scenarios: + // a) when user hits F2 + // b) when user hits a printable character + var value = eInput.getValue(); + var len = (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["exists"])(value) && value.length) || 0; + if (len) { + inputEl.setSelectionRange(len, len); + } + } + }; + // gets called when tabbing trough cells and in full row edit mode + TextCellEditor.prototype.focusIn = function () { + var eInput = this.eInput; + var focusEl = eInput.getFocusableElement(); + var inputEl = eInput.getInputElement(); + focusEl.focus(); + inputEl.select(); + }; + TextCellEditor.prototype.getValue = function () { + var eInput = this.eInput; + return this.params.parseValue(eInput.getValue()); + }; + TextCellEditor.prototype.getStartValue = function (params) { + var formatValue = params.useFormatter || params.column.getColDef().refData; + return formatValue ? params.formatValue(params.value) : params.value; + }; + TextCellEditor.prototype.isPopup = function () { + return false; + }; + TextCellEditor.TEMPLATE = '
'; + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eInput') + ], TextCellEditor.prototype, "eInput", void 0); + return TextCellEditor; +}(_widgets_popupComponent__WEBPACK_IMPORTED_MODULE_0__["PopupComponent"])); /***/ }), -/* 50 */ +/* 90 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridOptionsWrapper", function() { return GridOptionsWrapper; }); -/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(25); -/* harmony import */ var _components_componentUtil__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(48); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37); -/* harmony import */ var _propertyKeys__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(49); -/* harmony import */ var _components_colDefUtil__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(51); -/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(44); -/* harmony import */ var _entities_sideBar__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(52); -/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(38); -/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(39); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AnimateShowChangeCellRenderer", function() { return AnimateShowChangeCellRenderer; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(36); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(42); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; -var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { - return function (target, key) { decorator(target, key, paramIndex); } -}; -var __spreadArrays = (undefined && undefined.__spreadArrays) || function () { - for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; - for (var r = Array(s), k = 0, i = 0; i < il; i++) - for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) - r[k] = a[j]; - return r; -}; - - - - - - - -var DEFAULT_ROW_HEIGHT = 25; -var DEFAULT_DETAIL_ROW_HEIGHT = 300; -var DEFAULT_VIEWPORT_ROW_MODEL_PAGE_SIZE = 5; -var DEFAULT_VIEWPORT_ROW_MODEL_BUFFER_SIZE = 5; -var DEFAULT_KEEP_DETAIL_ROW_COUNT = 10; -function isTrue(value) { - return value === true || value === 'true'; -} -function zeroOrGreater(value, defaultValue) { - if (value >= 0) { - return value; - } - // zero gets returned if number is missing or the wrong type - return defaultValue; -} -function oneOrGreater(value, defaultValue) { - if (value > 0) { - return value; - } - // zero gets returned if number is missing or the wrong type - return defaultValue; -} -var GridOptionsWrapper = /** @class */ (function () { - function GridOptionsWrapper() { - this.propertyEventService = new _eventService__WEBPACK_IMPORTED_MODULE_0__["EventService"](); - this.domDataKey = '__AG_' + Math.random().toString(); - this.layoutElements = []; +var ARROW_UP = '\u2191'; +var ARROW_DOWN = '\u2193'; +var AnimateShowChangeCellRenderer = /** @class */ (function (_super) { + __extends(AnimateShowChangeCellRenderer, _super); + function AnimateShowChangeCellRenderer() { + var _this = _super.call(this, AnimateShowChangeCellRenderer.TEMPLATE) || this; + _this.refreshCount = 0; + return _this; } - GridOptionsWrapper_1 = GridOptionsWrapper; - GridOptionsWrapper.prototype.agWire = function (gridApi, columnApi) { - this.gridOptions.api = gridApi; - this.gridOptions.columnApi = columnApi; - this.checkForDeprecated(); - this.checkForViolations(); - }; - GridOptionsWrapper.prototype.destroy = function () { - // need to remove these, as we don't own the lifecycle of the gridOptions, we need to - // remove the references in case the user keeps the grid options, we want the rest - // of the grid to be picked up by the garbage collector - this.gridOptions.api = null; - this.gridOptions.columnApi = null; - this.removeEventListener(GridOptionsWrapper_1.PROP_DOM_LAYOUT, this.updateLayoutClassesListener); + AnimateShowChangeCellRenderer.prototype.init = function (params) { + // this.params = params; + this.eValue = this.queryForHtmlElement('.ag-value-change-value'); + this.eDelta = this.queryForHtmlElement('.ag-value-change-delta'); + this.refresh(params); }; - GridOptionsWrapper.prototype.init = function () { - var _this = this; - if (!(this.gridOptions.suppressPropertyNamesCheck === true)) { - this.checkGridOptionsProperties(); - this.checkColumnDefProperties(); + AnimateShowChangeCellRenderer.prototype.showDelta = function (params, delta) { + var absDelta = Math.abs(delta); + var valueFormatted = params.formatValue(absDelta); + var valueToUse = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["exists"])(valueFormatted) ? valueFormatted : absDelta; + var deltaUp = (delta >= 0); + if (deltaUp) { + this.eDelta.innerHTML = ARROW_UP + valueToUse; } - var async = this.useAsyncEvents(); - this.eventService.addGlobalListener(this.globalEventHandler.bind(this), async); - if (this.isGroupSelectsChildren() && this.isSuppressParentsInRowNodes()) { - console.warn("ag-Grid: 'groupSelectsChildren' does not work with 'suppressParentsInRowNodes', this selection method needs the part in rowNode to work"); + else { + // because negative, use ABS to remove sign + this.eDelta.innerHTML = ARROW_DOWN + valueToUse; } - if (this.isGroupSelectsChildren()) { - if (!this.isRowSelectionMulti()) { - console.warn("ag-Grid: rowSelection must be 'multiple' for groupSelectsChildren to make sense"); - } - if (this.isRowModelServerSide()) { - console.warn('ag-Grid: group selects children is NOT support for Server Side Row Model. ' + - 'This is because the rows are lazy loaded, so selecting a group is not possible as' + - 'the grid has no way of knowing what the children are.'); + this.eDelta.classList.toggle('ag-value-change-delta-up', deltaUp); + this.eDelta.classList.toggle('ag-value-change-delta-down', !deltaUp); + }; + AnimateShowChangeCellRenderer.prototype.setTimerToRemoveDelta = function () { + var _this = this; + // the refreshCount makes sure that if the value updates again while + // the below timer is waiting, then the below timer will realise it + // is not the most recent and will not try to remove the delta value. + this.refreshCount++; + var refreshCountCopy = this.refreshCount; + window.setTimeout(function () { + if (refreshCountCopy === _this.refreshCount) { + _this.hideDeltaValue(); } + }, 2000); + }; + AnimateShowChangeCellRenderer.prototype.hideDeltaValue = function () { + this.eValue.classList.remove('ag-value-change-value-highlight'); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["clearElement"])(this.eDelta); + }; + AnimateShowChangeCellRenderer.prototype.refresh = function (params) { + var value = params.value; + if (value === this.lastValue) { + return false; } - if (this.isGroupRemoveSingleChildren() && this.isGroupHideOpenParents()) { - console.warn("ag-Grid: groupRemoveSingleChildren and groupHideOpenParents do not work with each other, you need to pick one. And don't ask us how to us these together on our support forum either you will get the same answer!"); - } - if (this.isRowModelServerSide()) { - var msg = function (prop) { return "ag-Grid: '" + prop + "' is not supported on the Server-Side Row Model"; }; - if (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(this.gridOptions.groupDefaultExpanded)) { - console.warn(msg('groupDefaultExpanded')); - } - if (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(this.gridOptions.groupDefaultExpanded)) { - console.warn(msg('groupIncludeFooter')); - } - if (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(this.gridOptions.groupDefaultExpanded)) { - console.warn(msg('groupIncludeTotalFooter')); - } + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["exists"])(params.valueFormatted)) { + this.eValue.innerHTML = params.valueFormatted; } - if (this.isEnableRangeSelection()) { - _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_9__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__["ModuleNames"].RangeSelectionModule, 'enableRangeSelection'); + else if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["exists"])(params.value)) { + this.eValue.innerHTML = value; } - if (!this.isEnableRangeSelection() && (this.isEnableRangeHandle() || this.isEnableFillHandle())) { - console.warn("ag-Grid: 'enableRangeHandle' and 'enableFillHandle' will not work unless 'enableRangeSelection' is set to true"); + else { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["clearElement"])(this.eValue); } - var warnOfDeprecaredIcon = function (name) { - if (_this.gridOptions.icons && _this.gridOptions.icons[name]) { - console.warn("gridOptions.icons." + name + " is no longer supported. For information on how to style checkboxes and radio buttons, see https://www.ag-grid.com/javascript-grid-icons/"); - } - }; - warnOfDeprecaredIcon('radioButtonOff'); - warnOfDeprecaredIcon('radioButtonOn'); - warnOfDeprecaredIcon('checkboxChecked'); - warnOfDeprecaredIcon('checkboxUnchecked'); - warnOfDeprecaredIcon('checkboxIndeterminate'); - this.updateLayoutClassesListener = this.updateLayoutClasses.bind(this); - this.addEventListener(GridOptionsWrapper_1.PROP_DOM_LAYOUT, this.updateLayoutClassesListener); - }; - GridOptionsWrapper.prototype.checkColumnDefProperties = function () { - var _this = this; - if (this.gridOptions.columnDefs == null) { - return; + // we don't show the delta if we are in the middle of a filter. see comment on FilterManager + // with regards processingFilterChange + if (this.filterManager.isSuppressFlashingCellsBecauseFiltering()) { + return false; } - this.gridOptions.columnDefs.forEach(function (colDef) { - var userProperties = Object.getOwnPropertyNames(colDef); - var validProperties = __spreadArrays(_components_colDefUtil__WEBPACK_IMPORTED_MODULE_5__["ColDefUtil"].ALL_PROPERTIES, _components_colDefUtil__WEBPACK_IMPORTED_MODULE_5__["ColDefUtil"].FRAMEWORK_PROPERTIES); - _this.checkProperties(userProperties, validProperties, validProperties, 'colDef', 'https://www.ag-grid.com/javascript-grid-column-properties/'); - }); - }; - GridOptionsWrapper.prototype.checkGridOptionsProperties = function () { - var userProperties = Object.getOwnPropertyNames(this.gridOptions); - var validProperties = __spreadArrays(_propertyKeys__WEBPACK_IMPORTED_MODULE_4__["PropertyKeys"].ALL_PROPERTIES, _propertyKeys__WEBPACK_IMPORTED_MODULE_4__["PropertyKeys"].FRAMEWORK_PROPERTIES, _utils__WEBPACK_IMPORTED_MODULE_10__["_"].values(_eventKeys__WEBPACK_IMPORTED_MODULE_6__["Events"]).map(function (event) { return _components_componentUtil__WEBPACK_IMPORTED_MODULE_2__["ComponentUtil"].getCallbackForEvent(event); })); - var validPropertiesAndExceptions = __spreadArrays(validProperties, ['api', 'columnApi']); - this.checkProperties(userProperties, validPropertiesAndExceptions, validProperties, 'gridOptions', 'https://www.ag-grid.com/javascript-grid-properties/'); - }; - GridOptionsWrapper.prototype.checkProperties = function (userProperties, validPropertiesAndExceptions, validProperties, containerName, docsUrl) { - var invalidProperties = _utils__WEBPACK_IMPORTED_MODULE_10__["_"].fuzzyCheckStrings(userProperties, validPropertiesAndExceptions, validProperties); - _utils__WEBPACK_IMPORTED_MODULE_10__["_"].iterateObject(invalidProperties, function (key, value) { - console.warn("ag-grid: invalid " + containerName + " property '" + key + "' did you mean any of these: " + value.slice(0, 8).join(", ")); - }); - if (Object.keys(invalidProperties).length > 0) { - console.warn("ag-grid: to see all the valid " + containerName + " properties please check: " + docsUrl); + if (typeof value === 'number' && typeof this.lastValue === 'number') { + var delta = value - this.lastValue; + this.showDelta(params, delta); } - }; - // returns the dom data, or undefined if not found - GridOptionsWrapper.prototype.getDomData = function (element, key) { - var domData = element[this.domDataKey]; - return domData ? domData[key] : undefined; - }; - GridOptionsWrapper.prototype.setDomData = function (element, key, value) { - var domData = element[this.domDataKey]; - if (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].missing(domData)) { - domData = {}; - element[this.domDataKey] = domData; + // highlight the current value, but only if it's not new, otherwise it + // would get highlighted first time the value is shown + if (this.lastValue) { + this.eValue.classList.add('ag-value-change-value-highlight'); } - domData[key] = value; - }; - GridOptionsWrapper.prototype.isRowSelection = function () { - return this.gridOptions.rowSelection === 'single' || this.gridOptions.rowSelection === 'multiple'; - }; - GridOptionsWrapper.prototype.isRowDeselection = function () { - return isTrue(this.gridOptions.rowDeselection); - }; - GridOptionsWrapper.prototype.isRowSelectionMulti = function () { - return this.gridOptions.rowSelection === 'multiple'; - }; - GridOptionsWrapper.prototype.isRowMultiSelectWithClick = function () { - return isTrue(this.gridOptions.rowMultiSelectWithClick); - }; - GridOptionsWrapper.prototype.getContext = function () { - return this.gridOptions.context; - }; - GridOptionsWrapper.prototype.isPivotMode = function () { - return isTrue(this.gridOptions.pivotMode); - }; - GridOptionsWrapper.prototype.isPivotTotals = function () { - return isTrue(this.gridOptions.pivotTotals); - }; - GridOptionsWrapper.prototype.getPivotColumnGroupTotals = function () { - return this.gridOptions.pivotColumnGroupTotals; - }; - GridOptionsWrapper.prototype.getPivotRowTotals = function () { - return this.gridOptions.pivotRowTotals; - }; - GridOptionsWrapper.prototype.isRowModelInfinite = function () { - return this.gridOptions.rowModelType === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_INFINITE; - }; - GridOptionsWrapper.prototype.isRowModelViewport = function () { - return this.gridOptions.rowModelType === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_VIEWPORT; - }; - GridOptionsWrapper.prototype.isRowModelServerSide = function () { - return this.gridOptions.rowModelType === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE; - }; - GridOptionsWrapper.prototype.isRowModelDefault = function () { - return (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].missing(this.gridOptions.rowModelType) || - this.gridOptions.rowModelType === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE || - this.gridOptions.rowModelType === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DEPRECATED_ROW_MODEL_TYPE_NORMAL); - }; - GridOptionsWrapper.prototype.isFullRowEdit = function () { - return this.gridOptions.editType === 'fullRow'; - }; - GridOptionsWrapper.prototype.isSuppressFocusAfterRefresh = function () { - return isTrue(this.gridOptions.suppressFocusAfterRefresh); - }; - GridOptionsWrapper.prototype.isSuppressBrowserResizeObserver = function () { - return isTrue(this.gridOptions.suppressBrowserResizeObserver); - }; - GridOptionsWrapper.prototype.isSuppressMaintainUnsortedOrder = function () { - return isTrue(this.gridOptions.suppressMaintainUnsortedOrder); - }; - GridOptionsWrapper.prototype.isSuppressClearOnFillReduction = function () { - return isTrue(this.gridOptions.suppressClearOnFillReduction); - }; - GridOptionsWrapper.prototype.isShowToolPanel = function () { - return isTrue(this.gridOptions.sideBar && Array.isArray(this.getSideBar().toolPanels)); - }; - GridOptionsWrapper.prototype.getSideBar = function () { - return this.gridOptions.sideBar; - }; - GridOptionsWrapper.prototype.isSuppressTouch = function () { - return isTrue(this.gridOptions.suppressTouch); - }; - GridOptionsWrapper.prototype.isSuppressRowTransform = function () { - return isTrue(this.gridOptions.suppressRowTransform); - }; - GridOptionsWrapper.prototype.isSuppressSetColumnStateEvents = function () { - return isTrue(this.gridOptions.suppressSetColumnStateEvents); - }; - GridOptionsWrapper.prototype.isAllowDragFromColumnsToolPanel = function () { - return isTrue(this.gridOptions.allowDragFromColumnsToolPanel); - }; - GridOptionsWrapper.prototype.useAsyncEvents = function () { - return !isTrue(this.gridOptions.suppressAsyncEvents); + this.setTimerToRemoveDelta(); + this.lastValue = value; + return true; }; - GridOptionsWrapper.prototype.isEnableCellChangeFlash = function () { - return isTrue(this.gridOptions.enableCellChangeFlash); + AnimateShowChangeCellRenderer.TEMPLATE = '' + + '' + + '' + + ''; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager') + ], AnimateShowChangeCellRenderer.prototype, "filterManager", void 0); + return AnimateShowChangeCellRenderer; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_1__["Component"])); + + + +/***/ }), +/* 91 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AnimateSlideCellRenderer", function() { return AnimateSlideCellRenderer; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(36); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(42); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - GridOptionsWrapper.prototype.getCellFlashDelay = function () { - return this.gridOptions.cellFlashDelay || 500; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - GridOptionsWrapper.prototype.getCellFadeDelay = function () { - return this.gridOptions.cellFadeDelay || 1000; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + +var AnimateSlideCellRenderer = /** @class */ (function (_super) { + __extends(AnimateSlideCellRenderer, _super); + function AnimateSlideCellRenderer() { + var _this = _super.call(this, AnimateSlideCellRenderer.TEMPLATE) || this; + _this.refreshCount = 0; + _this.eCurrent = _this.queryForHtmlElement('.ag-value-slide-current'); + return _this; + } + AnimateSlideCellRenderer.prototype.init = function (params) { + this.refresh(params); }; - GridOptionsWrapper.prototype.isGroupSelectsChildren = function () { - var result = isTrue(this.gridOptions.groupSelectsChildren); - if (result && this.isTreeData()) { - console.warn('ag-Grid: groupSelectsChildren does not work with tree data'); - return false; + AnimateSlideCellRenderer.prototype.addSlideAnimation = function () { + var _this = this; + this.refreshCount++; + // below we keep checking this, and stop working on the animation + // if it no longer matches - this means another animation has started + // and this one is stale. + var refreshCountCopy = this.refreshCount; + // if old animation, remove it + if (this.ePrevious) { + this.getGui().removeChild(this.ePrevious); } - return result; - }; - GridOptionsWrapper.prototype.isSuppressRowHoverHighlight = function () { - return isTrue(this.gridOptions.suppressRowHoverHighlight); - }; - GridOptionsWrapper.prototype.isGroupSelectsFiltered = function () { - return isTrue(this.gridOptions.groupSelectsFiltered); - }; - GridOptionsWrapper.prototype.isGroupHideOpenParents = function () { - return isTrue(this.gridOptions.groupHideOpenParents); - }; - // if we are doing hideOpenParents, then we always have groupMultiAutoColumn, otherwise hideOpenParents would not work - GridOptionsWrapper.prototype.isGroupMultiAutoColumn = function () { - return isTrue(this.gridOptions.groupMultiAutoColumn) || isTrue(this.gridOptions.groupHideOpenParents); - }; - GridOptionsWrapper.prototype.isGroupRemoveSingleChildren = function () { - return isTrue(this.gridOptions.groupRemoveSingleChildren); - }; - GridOptionsWrapper.prototype.isGroupRemoveLowestSingleChildren = function () { - return isTrue(this.gridOptions.groupRemoveLowestSingleChildren); - }; - GridOptionsWrapper.prototype.isGroupIncludeFooter = function () { - return isTrue(this.gridOptions.groupIncludeFooter); - }; - GridOptionsWrapper.prototype.isGroupIncludeTotalFooter = function () { - return isTrue(this.gridOptions.groupIncludeTotalFooter); - }; - GridOptionsWrapper.prototype.isGroupSuppressBlankHeader = function () { - return isTrue(this.gridOptions.groupSuppressBlankHeader); - }; - GridOptionsWrapper.prototype.isSuppressRowClickSelection = function () { - return isTrue(this.gridOptions.suppressRowClickSelection); - }; - GridOptionsWrapper.prototype.isSuppressCellSelection = function () { - return isTrue(this.gridOptions.suppressCellSelection); - }; - GridOptionsWrapper.prototype.isSuppressMultiSort = function () { - return isTrue(this.gridOptions.suppressMultiSort); - }; - GridOptionsWrapper.prototype.isMultiSortKeyCtrl = function () { - return this.gridOptions.multiSortKey === 'ctrl'; - }; - GridOptionsWrapper.prototype.isGroupSuppressAutoColumn = function () { - return isTrue(this.gridOptions.groupSuppressAutoColumn); - }; - GridOptionsWrapper.prototype.isPivotSuppressAutoColumn = function () { - return isTrue(this.gridOptions.pivotSuppressAutoColumn); - }; - GridOptionsWrapper.prototype.isSuppressDragLeaveHidesColumns = function () { - return isTrue(this.gridOptions.suppressDragLeaveHidesColumns); - }; - GridOptionsWrapper.prototype.isSuppressScrollOnNewData = function () { - return isTrue(this.gridOptions.suppressScrollOnNewData); - }; - GridOptionsWrapper.prototype.isRowDragManaged = function () { - return isTrue(this.gridOptions.rowDragManaged); - }; - GridOptionsWrapper.prototype.isSuppressRowDrag = function () { - return isTrue(this.gridOptions.suppressRowDrag); - }; - GridOptionsWrapper.prototype.isSuppressMoveWhenRowDragging = function () { - return isTrue(this.gridOptions.suppressMoveWhenRowDragging); - }; - GridOptionsWrapper.prototype.isEnableMultiRowDragging = function () { - return isTrue(this.gridOptions.enableMultiRowDragging); + this.ePrevious = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["loadTemplate"])(''); + this.ePrevious.innerHTML = this.eCurrent.innerHTML; + this.getGui().insertBefore(this.ePrevious, this.eCurrent); + // having timeout of 0 allows use to skip to the next css turn, + // so we know the previous css classes have been applied. so the + // complex set of setTimeout below creates the animation + window.setTimeout(function () { + if (refreshCountCopy !== _this.refreshCount) { + return; + } + _this.ePrevious.classList.add('ag-value-slide-out-end'); + }, 50); + window.setTimeout(function () { + if (refreshCountCopy !== _this.refreshCount) { + return; + } + _this.getGui().removeChild(_this.ePrevious); + _this.ePrevious = null; + }, 3000); }; - // returns either 'print', 'autoHeight' or 'normal' (normal is the default) - GridOptionsWrapper.prototype.getDomLayout = function () { - var domLayout = this.gridOptions.domLayout || _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_NORMAL; - var validLayouts = [ - _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_PRINT, - _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_AUTO_HEIGHT, - _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_NORMAL - ]; - if (validLayouts.indexOf(domLayout) === -1) { - _utils__WEBPACK_IMPORTED_MODULE_10__["_"].doOnce(function () { - return console.warn("ag-Grid: " + domLayout + " is not valid for DOM Layout, valid values are " + _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_NORMAL + ", " + _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_AUTO_HEIGHT + " and " + _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_PRINT); - }, 'warn about dom layout values'); - return _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_NORMAL; + AnimateSlideCellRenderer.prototype.refresh = function (params) { + var value = params.value; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["missing"])(value)) { + value = ''; } - return domLayout; - }; - GridOptionsWrapper.prototype.isSuppressHorizontalScroll = function () { - return isTrue(this.gridOptions.suppressHorizontalScroll); - }; - GridOptionsWrapper.prototype.isSuppressMaxRenderedRowRestriction = function () { - return isTrue(this.gridOptions.suppressMaxRenderedRowRestriction); - }; - GridOptionsWrapper.prototype.isExcludeChildrenWhenTreeDataFiltering = function () { - return isTrue(this.gridOptions.excludeChildrenWhenTreeDataFiltering); - }; - GridOptionsWrapper.prototype.isAlwaysShowVerticalScroll = function () { - return isTrue(this.gridOptions.alwaysShowVerticalScroll); - }; - GridOptionsWrapper.prototype.isSuppressLoadingOverlay = function () { - return isTrue(this.gridOptions.suppressLoadingOverlay); - }; - GridOptionsWrapper.prototype.isSuppressNoRowsOverlay = function () { - return isTrue(this.gridOptions.suppressNoRowsOverlay); - }; - GridOptionsWrapper.prototype.isSuppressFieldDotNotation = function () { - return isTrue(this.gridOptions.suppressFieldDotNotation); - }; - GridOptionsWrapper.prototype.getPinnedTopRowData = function () { - return this.gridOptions.pinnedTopRowData; - }; - GridOptionsWrapper.prototype.getPinnedBottomRowData = function () { - return this.gridOptions.pinnedBottomRowData; - }; - GridOptionsWrapper.prototype.isFunctionsPassive = function () { - return isTrue(this.gridOptions.functionsPassive); - }; - GridOptionsWrapper.prototype.isSuppressTabbing = function () { - return isTrue(this.gridOptions.suppressTabbing); - }; - GridOptionsWrapper.prototype.isSuppressChangeDetection = function () { - return isTrue(this.gridOptions.suppressChangeDetection); - }; - GridOptionsWrapper.prototype.isSuppressAnimationFrame = function () { - return isTrue(this.gridOptions.suppressAnimationFrame); - }; - GridOptionsWrapper.prototype.getQuickFilterText = function () { - return this.gridOptions.quickFilterText; - }; - GridOptionsWrapper.prototype.isCacheQuickFilter = function () { - return isTrue(this.gridOptions.cacheQuickFilter); - }; - GridOptionsWrapper.prototype.isUnSortIcon = function () { - return isTrue(this.gridOptions.unSortIcon); - }; - GridOptionsWrapper.prototype.isSuppressMenuHide = function () { - return isTrue(this.gridOptions.suppressMenuHide); - }; - GridOptionsWrapper.prototype.isEnterMovesDownAfterEdit = function () { - return isTrue(this.gridOptions.enterMovesDownAfterEdit); - }; - GridOptionsWrapper.prototype.isEnterMovesDown = function () { - return isTrue(this.gridOptions.enterMovesDown); - }; - GridOptionsWrapper.prototype.isUndoRedoCellEditing = function () { - return isTrue(this.gridOptions.undoRedoCellEditing); - }; - GridOptionsWrapper.prototype.getUndoRedoCellEditingLimit = function () { - return this.gridOptions.undoRedoCellEditingLimit; - }; - GridOptionsWrapper.prototype.getRowStyle = function () { - return this.gridOptions.rowStyle; - }; - GridOptionsWrapper.prototype.getRowClass = function () { - return this.gridOptions.rowClass; - }; - GridOptionsWrapper.prototype.getRowStyleFunc = function () { - return this.gridOptions.getRowStyle; - }; - GridOptionsWrapper.prototype.getRowClassFunc = function () { - return this.gridOptions.getRowClass; + if (value === this.lastValue) { + return false; + } + // we don't show the delta if we are in the middle of a filter. see comment on FilterManager + // with regards processingFilterChange + if (this.filterManager.isSuppressFlashingCellsBecauseFiltering()) { + return false; + } + this.addSlideAnimation(); + this.lastValue = value; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["exists"])(params.valueFormatted)) { + this.eCurrent.innerHTML = params.valueFormatted; + } + else if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["exists"])(params.value)) { + this.eCurrent.innerHTML = value; + } + else { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["clearElement"])(this.eCurrent); + } + return true; }; - GridOptionsWrapper.prototype.rowClassRules = function () { - return this.gridOptions.rowClassRules; + AnimateSlideCellRenderer.TEMPLATE = "\n \n "; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager') + ], AnimateSlideCellRenderer.prototype, "filterManager", void 0); + return AnimateSlideCellRenderer; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_1__["Component"])); + + + +/***/ }), +/* 92 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GroupCellRenderer", function() { return GroupCellRenderer; }); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(44); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(42); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(36); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(57); +/* harmony import */ var _groupCellRendererCtrl__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(93); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - GridOptionsWrapper.prototype.getCreateChartContainerFunc = function () { - return this.gridOptions.createChartContainer; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - GridOptionsWrapper.prototype.getPopupParent = function () { - return this.gridOptions.popupParent; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + +var GroupCellRenderer = /** @class */ (function (_super) { + __extends(GroupCellRenderer, _super); + function GroupCellRenderer() { + return _super.call(this, GroupCellRenderer.TEMPLATE) || this; + } + GroupCellRenderer.prototype.init = function (params) { + var _this = this; + var compProxy = { + setInnerRenderer: function (compDetails, valueToDisplay) { return _this.setRenderDetails(compDetails, valueToDisplay); }, + setChildCount: function (count) { return _this.eChildCount.innerHTML = count; }, + addOrRemoveCssClass: function (cssClass, value) { return _this.addOrRemoveCssClass(cssClass, value); }, + setContractedDisplayed: function (expanded) { return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["setDisplayed"])(_this.eContracted, expanded); }, + setExpandedDisplayed: function (expanded) { return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["setDisplayed"])(_this.eExpanded, expanded); }, + setCheckboxVisible: function (visible) { return _this.eCheckbox.classList.toggle('ag-invisible', !visible); } + }; + var ctrl = this.createManagedBean(new _groupCellRendererCtrl__WEBPACK_IMPORTED_MODULE_4__["GroupCellRendererCtrl"]()); + var fullWidth = !params.colDef; + var eGui = this.getGui(); + ctrl.init(compProxy, eGui, this.eCheckbox, this.eExpanded, this.eContracted, this.constructor, params); + if (fullWidth) { + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_0__["setAriaRole"])(eGui, 'gridcell'); + } }; - GridOptionsWrapper.prototype.getBlockLoadDebounceMillis = function () { - return this.gridOptions.blockLoadDebounceMillis; + GroupCellRenderer.prototype.setRenderDetails = function (compDetails, valueToDisplay) { + var _this = this; + if (compDetails) { + var componentPromise = compDetails.newAgStackInstance(); + if (!componentPromise) { + return; + } + componentPromise.then(function (comp) { + if (!comp) { + return; + } + var destroyComp = function () { return _this.context.destroyBean(comp); }; + if (_this.isAlive()) { + _this.eValue.appendChild(comp.getGui()); + _this.addDestroyFunc(destroyComp); + } + else { + destroyComp(); + } + }); + } + else { + this.eValue.innerText = valueToDisplay; + } }; - GridOptionsWrapper.prototype.getPostProcessPopupFunc = function () { - return this.gridOptions.postProcessPopup; + // this is a user component, and IComponent has "public destroy()" as part of the interface. + // so we need to have public here instead of private or protected + GroupCellRenderer.prototype.destroy = function () { + this.getContext().destroyBean(this.innerCellRenderer); + _super.prototype.destroy.call(this); }; - GridOptionsWrapper.prototype.getDoesDataFlowerFunc = function () { - return this.gridOptions.doesDataFlower; + GroupCellRenderer.prototype.refresh = function () { + return false; }; - GridOptionsWrapper.prototype.getPaginationNumberFormatterFunc = function () { - return this.gridOptions.paginationNumberFormatter; + GroupCellRenderer.TEMPLATE = "\n \n \n \n \n \n "; + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eExpanded') + ], GroupCellRenderer.prototype, "eExpanded", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eContracted') + ], GroupCellRenderer.prototype, "eContracted", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eCheckbox') + ], GroupCellRenderer.prototype, "eCheckbox", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eValue') + ], GroupCellRenderer.prototype, "eValue", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eChildCount') + ], GroupCellRenderer.prototype, "eChildCount", void 0); + return GroupCellRenderer; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_2__["Component"])); + + + +/***/ }), +/* 93 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GroupCellRendererCtrl", function() { return GroupCellRendererCtrl; }); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(15); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(65); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(12); +/* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(94); +/* harmony import */ var _utils_event__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(21); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(14); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(7); +/* harmony import */ var _utils_icon__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(48); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(13); +/* harmony import */ var _checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(95); +/* harmony import */ var _row_rowDragComp__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(96); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - GridOptionsWrapper.prototype.getChildCountFunc = function () { - return this.gridOptions.getChildCount; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - GridOptionsWrapper.prototype.getDefaultGroupSortComparator = function () { - return this.gridOptions.defaultGroupSortComparator; +})(); +var __assign = (undefined && undefined.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; }; - GridOptionsWrapper.prototype.getIsFullWidthCellFunc = function () { - return this.gridOptions.isFullWidthCell; + return __assign.apply(this, arguments); +}; +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + + + + + + +var GroupCellRendererCtrl = /** @class */ (function (_super) { + __extends(GroupCellRendererCtrl, _super); + function GroupCellRendererCtrl() { + return _super !== null && _super.apply(this, arguments) || this; + } + GroupCellRendererCtrl.prototype.init = function (comp, eGui, eCheckbox, eExpanded, eContracted, compClass, params) { + this.params = params; + this.eGui = eGui; + this.eCheckbox = eCheckbox; + this.eExpanded = eExpanded; + this.eContracted = eContracted; + this.comp = comp; + this.compClass = compClass; + var topLevelFooter = this.isTopLevelFooter(); + var embeddedRowMismatch = this.isEmbeddedRowMismatch(); + // This allows for empty strings to appear as groups since + // it will only return for null or undefined. + var nullValue = params.value == null; + var skipCell = false; + // if the groupCellRenderer is inside of a footer and groupHideOpenParents is true + // we should only display the groupCellRenderer if the current column is the rowGroupedColumn + if (this.gridOptionsWrapper.isGroupIncludeFooter() && this.gridOptionsWrapper.isGroupHideOpenParents()) { + var node = params.node; + if (node.footer) { + var showRowGroup = params.colDef && params.colDef.showRowGroup; + var rowGroupColumnId = node.rowGroupColumn && node.rowGroupColumn.getColId(); + skipCell = showRowGroup !== rowGroupColumnId; + } + } + this.cellIsBlank = topLevelFooter ? false : (embeddedRowMismatch || nullValue || skipCell); + if (this.cellIsBlank) { + return; + } + this.setupShowingValueForOpenedParent(); + this.findDisplayedGroupNode(); + this.addFullWidthRowDraggerIfNeeded(); + this.addExpandAndContract(); + this.addCheckboxIfNeeded(); + this.addValueElement(); + this.setupIndent(); }; - GridOptionsWrapper.prototype.getFullWidthCellRendererParams = function () { - return this.gridOptions.fullWidthCellRendererParams; + GroupCellRendererCtrl.prototype.isTopLevelFooter = function () { + if (!this.gridOptionsWrapper.isGroupIncludeTotalFooter()) { + return false; + } + if (this.params.value != null || this.params.node.level != -1) { + return false; + } + // at this point, we know it's the root node and there is no value present, so it's a footer cell. + // the only thing to work out is if we are displaying groups across multiple + // columns (groupMultiAutoColumn=true), we only want 'total' to appear in the first column. + var colDef = this.params.colDef; + var doingFullWidth = colDef == null; + if (doingFullWidth) { + return true; + } + if (colDef.showRowGroup === true) { + return true; + } + var rowGroupCols = this.columnModel.getRowGroupColumns(); + // this is a sanity check, rowGroupCols should always be present + if (!rowGroupCols || rowGroupCols.length === 0) { + return true; + } + var firstRowGroupCol = rowGroupCols[0]; + return firstRowGroupCol.getId() === colDef.showRowGroup; }; - GridOptionsWrapper.prototype.isEmbedFullWidthRows = function () { - return isTrue(this.gridOptions.embedFullWidthRows) || isTrue(this.gridOptions.deprecatedEmbedFullWidthRows); + // if we are doing embedded full width rows, we only show the renderer when + // in the body, or if pinning in the pinned section, or if pinning and RTL, + // in the right section. otherwise we would have the cell repeated in each section. + GroupCellRendererCtrl.prototype.isEmbeddedRowMismatch = function () { + if (!this.params.fullWidth || !this.gridOptionsWrapper.isEmbedFullWidthRows()) { + return false; + } + var pinnedLeftCell = this.params.pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_LEFT; + var pinnedRightCell = this.params.pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_RIGHT; + var bodyCell = !pinnedLeftCell && !pinnedRightCell; + if (this.gridOptionsWrapper.isEnableRtl()) { + if (this.columnModel.isPinningLeft()) { + return !pinnedRightCell; + } + return !bodyCell; + } + if (this.columnModel.isPinningLeft()) { + return !pinnedLeftCell; + } + return !bodyCell; }; - GridOptionsWrapper.prototype.getSuppressKeyboardEventFunc = function () { - return this.gridOptions.suppressKeyboardEvent; + GroupCellRendererCtrl.prototype.findDisplayedGroupNode = function () { + var column = this.params.column; + var rowNode = this.params.node; + if (this.showingValueForOpenedParent) { + var pointer = rowNode.parent; + while (pointer != null) { + if (pointer.rowGroupColumn && column.isRowGroupDisplayed(pointer.rowGroupColumn.getId())) { + this.displayedGroupNode = pointer; + break; + } + pointer = pointer.parent; + } + } + // if we didn't find a displayed group, set it to the row node + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_7__["missing"])(this.displayedGroupNode)) { + this.displayedGroupNode = rowNode; + } }; - GridOptionsWrapper.prototype.getBusinessKeyForNodeFunc = function () { - return this.gridOptions.getBusinessKeyForNode; + GroupCellRendererCtrl.prototype.setupShowingValueForOpenedParent = function () { + // note - this code depends on sortService.updateGroupDataForHiddenOpenParents, where group data + // is updated to reflect the dragged down parents + var rowNode = this.params.node; + var column = this.params.column; + if (!this.gridOptionsWrapper.isGroupHideOpenParents()) { + this.showingValueForOpenedParent = false; + return; + } + // hideOpenParents means rowNode.groupData can have data for the group this column is displaying, even though + // this rowNode isn't grouping by the column we are displaying + // if no groupData at all, we are not showing a parent value + if (!rowNode.groupData) { + this.showingValueForOpenedParent = false; + return; + } + // this is the normal case, in that we are showing a group for which this column is configured. note that + // this means the Row Group is closed (if it was open, we would not be displaying it) + var showingGroupNode = rowNode.rowGroupColumn != null; + if (showingGroupNode) { + var keyOfGroupingColumn = rowNode.rowGroupColumn.getId(); + var configuredToShowThisGroupLevel = column.isRowGroupDisplayed(keyOfGroupingColumn); + // if showing group as normal, we didn't take group info from parent + if (configuredToShowThisGroupLevel) { + this.showingValueForOpenedParent = false; + return; + } + } + // see if we are showing a Group Value for the Displayed Group. if we are showing a group value, and this Row Node + // is not grouping by this Displayed Group, we must of gotten the value from a parent node + var valPresent = rowNode.groupData[column.getId()] != null; + this.showingValueForOpenedParent = valPresent; }; - GridOptionsWrapper.prototype.getApi = function () { - return this.gridOptions.api; + GroupCellRendererCtrl.prototype.addValueElement = function () { + if (this.displayedGroupNode.footer) { + this.addFooterValue(); + } + else { + this.addGroupValue(); + this.addChildCount(); + } }; - GridOptionsWrapper.prototype.getColumnApi = function () { - return this.gridOptions.columnApi; + GroupCellRendererCtrl.prototype.addGroupValue = function () { + // we try and use the cellRenderer of the column used for the grouping if we can + var paramsAdjusted = this.adjustParamsWithDetailsFromRelatedColumn(); + var innerCompDetails = this.getInnerCompDetails(paramsAdjusted); + var valueFormatted = paramsAdjusted.valueFormatted, value = paramsAdjusted.value; + var valueWhenNoRenderer = valueFormatted != null ? valueFormatted : value; + this.comp.setInnerRenderer(innerCompDetails, valueWhenNoRenderer); + }; + GroupCellRendererCtrl.prototype.adjustParamsWithDetailsFromRelatedColumn = function () { + var relatedColumn = this.displayedGroupNode.rowGroupColumn; + var column = this.params.column; + if (!relatedColumn) { + return this.params; + } + var notFullWidth = column != null; + if (notFullWidth) { + var showingThisRowGroup = column.isRowGroupDisplayed(relatedColumn.getId()); + if (!showingThisRowGroup) { + return this.params; + } + } + var params = this.params; + var _a = this.params, value = _a.value, scope = _a.scope, node = _a.node; + var valueFormatted = this.valueFormatterService.formatValue(relatedColumn, node, scope, value); + // we don't update the original params, as they could of come through React, + // as react has RowGroupCellRenderer, which means the params could be props which + // would be read only + var paramsAdjusted = __assign(__assign({}, params), { valueFormatted: valueFormatted }); + return paramsAdjusted; + }; + GroupCellRendererCtrl.prototype.addFooterValue = function () { + var footerValueGetter = this.params.footerValueGetter; + var footerValue = ''; + if (footerValueGetter) { + // params is same as we were given, except we set the value as the item to display + var paramsClone = Object(_utils_object__WEBPACK_IMPORTED_MODULE_9__["cloneObject"])(this.params); + paramsClone.value = this.params.value; + if (typeof footerValueGetter === 'function') { + footerValue = footerValueGetter(paramsClone); + } + else if (typeof footerValueGetter === 'string') { + footerValue = this.expressionService.evaluate(footerValueGetter, paramsClone); + } + else { + console.warn('AG Grid: footerValueGetter should be either a function or a string (expression)'); + } + } + else { + footerValue = 'Total ' + (this.params.value != null ? this.params.value : ''); + } + var innerCompDetails = this.getInnerCompDetails(this.params); + this.comp.setInnerRenderer(innerCompDetails, footerValue); }; - GridOptionsWrapper.prototype.isImmutableData = function () { - return isTrue(this.gridOptions.immutableData); + GroupCellRendererCtrl.prototype.getInnerCompDetails = function (params) { + var _this = this; + // for full width rows, we don't do any of the below + if (params.fullWidth) { + return this.userComponentFactory.getFullWidthGroupRowInnerCellRenderer(this.gridOptions.groupRowRendererParams, params); + } + // when grouping, the normal case is we use the cell renderer of the grouped column. eg if grouping by country + // and then rating, we will use the country cell renderer for each country group row and likewise the rating + // cell renderer for each rating group row. + // + // however if the user has innerCellRenderer defined, this gets preference and we don't use cell renderers + // of the grouped columns. + // + // so we check and use in the following order: + // + // 1) thisColDef.cellRendererParams.innerRenderer of the column showing the groups (eg auto group column) + // 2) groupedColDef.cellRenderer of the grouped column + // 3) groupedColDef.cellRendererParams.innerRenderer + // we check if cell renderer provided for the group cell renderer, eg colDef.cellRendererParams.innerRenderer + var innerCompDetails = this.userComponentFactory + .getInnerRendererDetails(params, params); + // avoid using GroupCellRenderer again, otherwise stack overflow, as we insert same renderer again and again. + // this covers off chance user is grouping by a column that is also configured with GroupCellRenderer + var isGroupRowRenderer = function (details) { return details && details.componentClass == _this.compClass; }; + if (innerCompDetails && !isGroupRowRenderer(innerCompDetails)) { + // use the renderer defined in cellRendererParams.innerRenderer + return innerCompDetails; + } + var relatedColumn = this.displayedGroupNode.rowGroupColumn; + var relatedColDef = relatedColumn ? relatedColumn.getColDef() : undefined; + if (!relatedColDef) { + return; + } + // otherwise see if we can use the cellRenderer of the column we are grouping by + var relatedCompDetails = this.userComponentFactory + .getCellRendererDetails(relatedColDef, params); + if (relatedCompDetails && !isGroupRowRenderer(relatedCompDetails)) { + // Only if the original column is using a specific renderer, it it is a using a DEFAULT one ignore it + return relatedCompDetails; + } + if (isGroupRowRenderer(relatedCompDetails) && + relatedColDef.cellRendererParams && + relatedColDef.cellRendererParams.innerRenderer) { + // edge case - this comes from a column which has been grouped dynamically, that has a renderer 'group' + // and has an inner cell renderer + var res = this.userComponentFactory.getInnerRendererDetails(relatedColDef.cellRendererParams, params); + return res; + } }; - GridOptionsWrapper.prototype.isImmutableColumns = function () { - return isTrue(this.gridOptions.immutableColumns); + GroupCellRendererCtrl.prototype.addChildCount = function () { + // only include the child count if it's included, eg if user doing custom aggregation, + // then this could be left out, or set to -1, ie no child count + if (this.params.suppressCount) { + return; + } + this.addManagedListener(this.displayedGroupNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_4__["RowNode"].EVENT_ALL_CHILDREN_COUNT_CHANGED, this.updateChildCount.bind(this)); + // filtering changes the child count, so need to cater for it + this.updateChildCount(); }; - GridOptionsWrapper.prototype.isEnsureDomOrder = function () { - return isTrue(this.gridOptions.ensureDomOrder); + GroupCellRendererCtrl.prototype.updateChildCount = function () { + var allChildrenCount = this.displayedGroupNode.allChildrenCount; + var showingGroupForThisNode = this.isShowRowGroupForThisRow(); + var showCount = showingGroupForThisNode && allChildrenCount != null && allChildrenCount >= 0; + var countString = showCount ? "(" + allChildrenCount + ")" : ""; + this.comp.setChildCount(countString); }; - GridOptionsWrapper.prototype.isEnableCharts = function () { - if (isTrue(this.gridOptions.enableCharts)) { - return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_9__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__["ModuleNames"].GridChartsModule, 'enableCharts'); + GroupCellRendererCtrl.prototype.isShowRowGroupForThisRow = function () { + if (this.gridOptionsWrapper.isTreeData()) { + return true; } - return false; + var rowGroupColumn = this.displayedGroupNode.rowGroupColumn; + if (!rowGroupColumn) { + return false; + } + // column is null for fullWidthRows + var column = this.params.column; + var thisColumnIsInterested = column == null || column.isRowGroupDisplayed(rowGroupColumn.getId()); + return thisColumnIsInterested; }; - GridOptionsWrapper.prototype.getColResizeDefault = function () { - return this.gridOptions.colResizeDefault; + GroupCellRendererCtrl.prototype.addExpandAndContract = function () { + var params = this.params; + var eExpandedIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_8__["createIconNoSpan"])('groupExpanded', this.gridOptionsWrapper, null); + var eContractedIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_8__["createIconNoSpan"])('groupContracted', this.gridOptionsWrapper, null); + if (eExpandedIcon) { + this.eExpanded.appendChild(eExpandedIcon); + } + if (eContractedIcon) { + this.eContracted.appendChild(eContractedIcon); + } + var eGroupCell = params.eGridCell; + // if editing groups, then double click is to start editing + if (!this.gridOptionsWrapper.isEnableGroupEdit() && this.isExpandable() && !params.suppressDoubleClickExpand) { + this.addManagedListener(eGroupCell, 'dblclick', this.onCellDblClicked.bind(this)); + } + this.addManagedListener(this.eExpanded, 'click', this.onExpandClicked.bind(this)); + this.addManagedListener(this.eContracted, 'click', this.onExpandClicked.bind(this)); + // expand / contract as the user hits enter + this.addManagedListener(eGroupCell, 'keydown', this.onKeyDown.bind(this)); + this.addManagedListener(params.node, _entities_rowNode__WEBPACK_IMPORTED_MODULE_4__["RowNode"].EVENT_EXPANDED_CHANGED, this.showExpandAndContractIcons.bind(this)); + this.showExpandAndContractIcons(); + // because we don't show the expand / contract when there are no children, we need to check every time + // the number of children change. + var expandableChangedListener = this.onRowNodeIsExpandableChanged.bind(this); + this.addManagedListener(this.displayedGroupNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_4__["RowNode"].EVENT_ALL_CHILDREN_COUNT_CHANGED, expandableChangedListener); + this.addManagedListener(this.displayedGroupNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_4__["RowNode"].EVENT_MASTER_CHANGED, expandableChangedListener); + this.addManagedListener(this.displayedGroupNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_4__["RowNode"].EVENT_GROUP_CHANGED, expandableChangedListener); + this.addManagedListener(this.displayedGroupNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_4__["RowNode"].EVENT_HAS_CHILDREN_CHANGED, expandableChangedListener); }; - GridOptionsWrapper.prototype.isSingleClickEdit = function () { - return isTrue(this.gridOptions.singleClickEdit); + GroupCellRendererCtrl.prototype.onExpandClicked = function (mouseEvent) { + if (Object(_utils_event__WEBPACK_IMPORTED_MODULE_5__["isStopPropagationForAgGrid"])(mouseEvent)) { + return; + } + // so if we expand a node, it does not also get selected. + Object(_utils_event__WEBPACK_IMPORTED_MODULE_5__["stopPropagationForAgGrid"])(mouseEvent); + this.onExpandOrContract(); }; - GridOptionsWrapper.prototype.isSuppressClickEdit = function () { - return isTrue(this.gridOptions.suppressClickEdit); + GroupCellRendererCtrl.prototype.onExpandOrContract = function () { + // must use the displayedGroup, so if data was dragged down, we expand the parent, not this row + var rowNode = this.displayedGroupNode; + var nextExpandState = !rowNode.expanded; + rowNode.setExpanded(nextExpandState); }; - GridOptionsWrapper.prototype.isStopEditingWhenGridLosesFocus = function () { - return isTrue(this.gridOptions.stopEditingWhenGridLosesFocus); + GroupCellRendererCtrl.prototype.isExpandable = function () { + if (this.showingValueForOpenedParent) { + return true; + } + var rowNode = this.displayedGroupNode; + var reducedLeafNode = this.columnModel.isPivotMode() && rowNode.leafGroup; + var expandableGroup = rowNode.isExpandable() && !rowNode.footer && !reducedLeafNode; + if (!expandableGroup) { + return false; + } + // column is null for fullWidthRows + var column = this.params.column; + var displayingForOneColumnOnly = column != null && typeof column.getColDef().showRowGroup === 'string'; + if (displayingForOneColumnOnly) { + var showing = this.isShowRowGroupForThisRow(); + return showing; + } + return true; }; - GridOptionsWrapper.prototype.getGroupDefaultExpanded = function () { - return this.gridOptions.groupDefaultExpanded; + GroupCellRendererCtrl.prototype.showExpandAndContractIcons = function () { + var _a = this, params = _a.params, displayedGroup = _a.displayedGroupNode, columnModel = _a.columnModel; + var node = params.node; + var isExpandable = this.isExpandable(); + if (isExpandable) { + // if expandable, show one based on expand state. + // if we were dragged down, means our parent is always expanded + var expanded = this.showingValueForOpenedParent ? true : node.expanded; + this.comp.setExpandedDisplayed(expanded); + this.comp.setContractedDisplayed(!expanded); + } + else { + // it not expandable, show neither + this.comp.setExpandedDisplayed(false); + this.comp.setContractedDisplayed(false); + } + // compensation padding for leaf nodes, so there is blank space instead of the expand icon + var pivotMode = columnModel.isPivotMode(); + var pivotModeAndLeafGroup = pivotMode && displayedGroup.leafGroup; + var addExpandableCss = isExpandable && !pivotModeAndLeafGroup; + var isTotalFooterNode = node.footer && node.level === -1; + this.comp.addOrRemoveCssClass('ag-cell-expandable', addExpandableCss); + this.comp.addOrRemoveCssClass('ag-row-group', addExpandableCss); + if (pivotMode) { + this.comp.addOrRemoveCssClass('ag-pivot-leaf-group', pivotModeAndLeafGroup); + } + else if (!isTotalFooterNode) { + this.comp.addOrRemoveCssClass('ag-row-group-leaf-indent', !addExpandableCss); + } }; - GridOptionsWrapper.prototype.getMaxConcurrentDatasourceRequests = function () { - return this.gridOptions.maxConcurrentDatasourceRequests; + GroupCellRendererCtrl.prototype.onRowNodeIsExpandableChanged = function () { + // maybe if no children now, we should hide the expand / contract icons + this.showExpandAndContractIcons(); + // if we have no children, this impacts the indent + this.setIndent(); }; - GridOptionsWrapper.prototype.getMaxBlocksInCache = function () { - return this.gridOptions.maxBlocksInCache; + GroupCellRendererCtrl.prototype.setupIndent = function () { + // only do this if an indent - as this overwrites the padding that + // the theme set, which will make things look 'not aligned' for the + // first group level. + var node = this.params.node; + var suppressPadding = this.params.suppressPadding; + if (!suppressPadding) { + this.addManagedListener(node, _entities_rowNode__WEBPACK_IMPORTED_MODULE_4__["RowNode"].EVENT_UI_LEVEL_CHANGED, this.setIndent.bind(this)); + this.setIndent(); + } }; - GridOptionsWrapper.prototype.getCacheOverflowSize = function () { - return this.gridOptions.cacheOverflowSize; + GroupCellRendererCtrl.prototype.setIndent = function () { + if (this.gridOptionsWrapper.isGroupHideOpenParents()) { + return; + } + var params = this.params; + var rowNode = params.node; + // if we are only showing one group column, we don't want to be indenting based on level + var fullWithRow = !!params.colDef; + var treeData = this.gridOptionsWrapper.isTreeData(); + var manyDimensionThisColumn = !fullWithRow || treeData || params.colDef.showRowGroup === true; + var paddingCount = manyDimensionThisColumn ? rowNode.uiLevel : 0; + var userProvidedPaddingPixelsTheDeprecatedWay = params.padding >= 0; + if (userProvidedPaddingPixelsTheDeprecatedWay) { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_6__["doOnce"])(function () { return console.warn('AG Grid: cellRendererParams.padding no longer works, it was deprecated in since v14.2 and removed in v26, configuring padding for groupCellRenderer should be done with Sass variables and themes. Please see the AG Grid documentation page for Themes, in particular the property $row-group-indent-size.'); }, 'groupCellRenderer->doDeprecatedWay'); + } + if (this.indentClass) { + this.comp.addOrRemoveCssClass(this.indentClass, false); + } + this.indentClass = 'ag-row-group-indent-' + paddingCount; + this.comp.addOrRemoveCssClass(this.indentClass, true); }; - GridOptionsWrapper.prototype.getPaginationPageSize = function () { - return this.gridOptions.paginationPageSize; + GroupCellRendererCtrl.prototype.addFullWidthRowDraggerIfNeeded = function () { + var _this = this; + if (!this.params.fullWidth || !this.params.rowDrag) { + return; + } + var rowDragComp = new _row_rowDragComp__WEBPACK_IMPORTED_MODULE_11__["RowDragComp"](function () { return _this.params.value; }, this.params.node); + this.createManagedBean(rowDragComp, this.context); + this.eGui.insertAdjacentElement('afterbegin', rowDragComp.getGui()); }; - GridOptionsWrapper.prototype.isPaginateChildRows = function () { - // if using groupSuppressRow, means we are not showing parent rows, - // so we always paginate on the child rows here as there are no parent rows - var shouldPaginate = this.isGroupSuppressRow() || this.isGroupRemoveSingleChildren() || this.isGroupRemoveLowestSingleChildren(); - if (shouldPaginate) { - return true; + GroupCellRendererCtrl.prototype.isUserWantsSelected = function () { + var paramsCheckbox = this.params.checkbox; + if (typeof paramsCheckbox === 'function') { + return paramsCheckbox(this.params); } - return isTrue(this.gridOptions.paginateChildRows); + return paramsCheckbox === true; }; - GridOptionsWrapper.prototype.getCacheBlockSize = function () { - return this.gridOptions.cacheBlockSize; + GroupCellRendererCtrl.prototype.addCheckboxIfNeeded = function () { + var _this = this; + var rowNode = this.displayedGroupNode; + var checkboxNeeded = this.isUserWantsSelected() && + // footers cannot be selected + !rowNode.footer && + // pinned rows cannot be selected + !rowNode.rowPinned && + // details cannot be selected + !rowNode.detail; + if (checkboxNeeded) { + var cbSelectionComponent_1 = new _checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_10__["CheckboxSelectionComponent"](); + this.getContext().createBean(cbSelectionComponent_1); + cbSelectionComponent_1.init({ rowNode: rowNode, column: this.params.column }); + this.eCheckbox.appendChild(cbSelectionComponent_1.getGui()); + this.addDestroyFunc(function () { return _this.getContext().destroyBean(cbSelectionComponent_1); }); + } + this.comp.setCheckboxVisible(checkboxNeeded); }; - GridOptionsWrapper.prototype.getInfiniteInitialRowCount = function () { - return this.gridOptions.infiniteInitialRowCount; + GroupCellRendererCtrl.prototype.onKeyDown = function (event) { + var enterKeyPressed = event.key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].ENTER; + if (!enterKeyPressed || this.params.suppressEnterExpand) { + return; + } + var cellEditable = this.params.column && this.params.column.isCellEditable(this.params.node); + if (cellEditable) { + return; + } + this.onExpandOrContract(); }; - GridOptionsWrapper.prototype.isPurgeClosedRowNodes = function () { - return isTrue(this.gridOptions.purgeClosedRowNodes); + GroupCellRendererCtrl.prototype.onCellDblClicked = function (mouseEvent) { + if (Object(_utils_event__WEBPACK_IMPORTED_MODULE_5__["isStopPropagationForAgGrid"])(mouseEvent)) { + return; + } + // we want to avoid acting on double click events on the expand / contract icon, + // as that icons already has expand / collapse functionality on it. otherwise if + // the icon was double clicked, we would get 'click', 'click', 'dblclick' which + // is open->close->open, however double click should be open->close only. + var targetIsExpandIcon = Object(_utils_event__WEBPACK_IMPORTED_MODULE_5__["isElementInEventPath"])(this.eExpanded, mouseEvent) + || Object(_utils_event__WEBPACK_IMPORTED_MODULE_5__["isElementInEventPath"])(this.eContracted, mouseEvent); + if (!targetIsExpandIcon) { + this.onExpandOrContract(); + } }; - GridOptionsWrapper.prototype.isSuppressPaginationPanel = function () { - return isTrue(this.gridOptions.suppressPaginationPanel); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('expressionService') + ], GroupCellRendererCtrl.prototype, "expressionService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('valueFormatterService') + ], GroupCellRendererCtrl.prototype, "valueFormatterService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('columnModel') + ], GroupCellRendererCtrl.prototype, "columnModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('userComponentFactory') + ], GroupCellRendererCtrl.prototype, "userComponentFactory", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('gridOptions') + ], GroupCellRendererCtrl.prototype, "gridOptions", void 0); + return GroupCellRendererCtrl; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"])); + + + +/***/ }), +/* 94 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowHighlightPosition", function() { return RowHighlightPosition; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowNode", function() { return RowNode; }); +/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(11); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(23); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(15); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(13); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(14); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ + + + + + + +var RowHighlightPosition; +(function (RowHighlightPosition) { + RowHighlightPosition[RowHighlightPosition["Above"] = 0] = "Above"; + RowHighlightPosition[RowHighlightPosition["Below"] = 1] = "Below"; +})(RowHighlightPosition || (RowHighlightPosition = {})); +var RowNode = /** @class */ (function () { + function RowNode(beans) { + /** The current row index. If the row is filtered out or in a collapsed group, this value will be `null`. */ + this.rowIndex = null; + /** The key for the group eg Ireland, UK, USA */ + this.key = null; + /** Children mapped by the pivot columns. */ + this.childrenMapped = {}; + /** + * This will be `true` if it has a rowIndex assigned, otherwise `false`. + */ + this.displayed = false; + /** The row top position in pixels. */ + this.rowTop = null; + /** The top pixel for this row last time, makes sense if data set was ordered or filtered, + * it is used so new rows can animate in from their old position. */ + this.oldRowTop = null; + /** `true` by default - can be overridden via gridOptions.isRowSelectable(rowNode) */ + this.selectable = true; + /** Used by sorting service - to give deterministic sort to groups. Previously we + * just id for this, however id is a string and had slower sorting compared to numbers. */ + this.__objectId = RowNode.OBJECT_ID_SEQUENCE++; + /** When one or more Columns are using autoHeight, this keeps track of height of each autoHeight Cell, + * indexed by the Column ID. */ + this.__autoHeights = {}; + /** `true` when nodes with the same id are being removed and added as part of the same batch transaction */ + this.alreadyRendered = false; + this.highlighted = null; + this.selected = false; + this.beans = beans; + } + /** Replaces the data on the `rowNode`. When complete, the grid will refresh the the entire rendered row if it is showing. */ + RowNode.prototype.setData = function (data) { + this.setDataCommon(data, false); }; - GridOptionsWrapper.prototype.getRowData = function () { - return this.gridOptions.rowData; + // similar to setRowData, however it is expected that the data is the same data item. this + // is intended to be used with Redux type stores, where the whole data can be changed. we are + // guaranteed that the data is the same entity (so grid doesn't need to worry about the id of the + // underlying data changing, hence doesn't need to worry about selection). the grid, upon receiving + // dataChanged event, will refresh the cells rather than rip them all out (so user can show transitions). + RowNode.prototype.updateData = function (data) { + this.setDataCommon(data, true); }; - // this property is different - we never allow groupUseEntireRow if in pivot mode, - // as otherwise we don't see the pivot values. - GridOptionsWrapper.prototype.isGroupUseEntireRow = function (pivotMode) { - return pivotMode ? false : isTrue(this.gridOptions.groupUseEntireRow); + RowNode.prototype.setDataCommon = function (data, update) { + var oldData = this.data; + this.data = data; + this.beans.valueCache.onDataChanged(); + this.updateDataOnDetailNode(); + this.checkRowSelectable(); + var event = this.createDataChangedEvent(data, oldData, update); + this.dispatchLocalEvent(event); }; - GridOptionsWrapper.prototype.isEnableRtl = function () { - return isTrue(this.gridOptions.enableRtl); + // when we are doing master / detail, the detail node is lazy created, but then kept around. + // so if we show / hide the detail, the same detail rowNode is used. so we need to keep the data + // in sync, otherwise expand/collapse of the detail would still show the old values. + RowNode.prototype.updateDataOnDetailNode = function () { + if (this.detailNode) { + this.detailNode.data = this.data; + } }; - GridOptionsWrapper.prototype.getAutoGroupColumnDef = function () { - return this.gridOptions.autoGroupColumnDef; + RowNode.prototype.createDataChangedEvent = function (newData, oldData, update) { + return { + type: RowNode.EVENT_DATA_CHANGED, + node: this, + oldData: oldData, + newData: newData, + update: update + }; }; - GridOptionsWrapper.prototype.isGroupSuppressRow = function () { - return isTrue(this.gridOptions.groupSuppressRow); + RowNode.prototype.createLocalRowEvent = function (type) { + return { + type: type, + node: this + }; }; - GridOptionsWrapper.prototype.getRowGroupPanelShow = function () { - return this.gridOptions.rowGroupPanelShow; + RowNode.prototype.getRowIndexString = function () { + if (this.rowPinned === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP) { + return 't-' + this.rowIndex; + } + if (this.rowPinned === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM) { + return 'b-' + this.rowIndex; + } + return this.rowIndex.toString(); }; - GridOptionsWrapper.prototype.getPivotPanelShow = function () { - return this.gridOptions.pivotPanelShow; + RowNode.prototype.createDaemonNode = function () { + var oldNode = new RowNode(this.beans); + // just copy the id and data, this is enough for the node to be used + // in the selection controller (the selection controller is the only + // place where daemon nodes can live). + oldNode.id = this.id; + oldNode.data = this.data; + oldNode.daemon = true; + oldNode.selected = this.selected; + oldNode.level = this.level; + return oldNode; }; - GridOptionsWrapper.prototype.isAngularCompileRows = function () { - return isTrue(this.gridOptions.angularCompileRows); + RowNode.prototype.setDataAndId = function (data, id) { + var oldNode = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["exists"])(this.id) ? this.createDaemonNode() : null; + var oldData = this.data; + this.data = data; + this.updateDataOnDetailNode(); + this.setId(id); + this.beans.selectionService.syncInRowNode(this, oldNode); + this.checkRowSelectable(); + var event = this.createDataChangedEvent(data, oldData, false); + this.dispatchLocalEvent(event); }; - GridOptionsWrapper.prototype.isAngularCompileFilters = function () { - return isTrue(this.gridOptions.angularCompileFilters); + RowNode.prototype.checkRowSelectable = function () { + var isRowSelectableFunc = this.beans.gridOptionsWrapper.getIsRowSelectableFunc(); + this.setRowSelectable(isRowSelectableFunc ? isRowSelectableFunc(this) : true); }; - GridOptionsWrapper.prototype.isAngularCompileHeaders = function () { - return isTrue(this.gridOptions.angularCompileHeaders); + RowNode.prototype.setRowSelectable = function (newVal) { + if (this.selectable !== newVal) { + this.selectable = newVal; + if (this.eventService) { + this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_SELECTABLE_CHANGED)); + } + } }; - GridOptionsWrapper.prototype.isDebug = function () { - return isTrue(this.gridOptions.debug); + RowNode.prototype.setId = function (id) { + // see if user is providing the id's + var getRowIdFunc = this.beans.gridOptionsWrapper.getRowIdFunc(); + if (getRowIdFunc) { + // if user is providing the id's, then we set the id only after the data has been set. + // this is important for virtual pagination and viewport, where empty rows exist. + if (this.data) { + // we pass 'true' as we skip this level when generating keys, + // as we don't always have the key for this level (eg when updating + // data via transaction on SSRM, we are getting key to look up the + // RowNode, don't have the RowNode yet, thus no way to get the current key) + var parentKeys = this.getGroupKeys(true); + this.id = getRowIdFunc({ + api: this.beans.gridApi, + columnApi: this.beans.columnApi, + data: this.data, + parentKeys: parentKeys.length > 0 ? parentKeys : undefined, + level: this.level + }); + // make sure id provided doesn't start with 'row-group-' as this is reserved. also check that + // it has 'startsWith' in case the user provided a number. + if (this.id !== null && typeof this.id === 'string' && this.id.startsWith(RowNode.ID_PREFIX_ROW_GROUP)) { + console.error("AG Grid: Row IDs cannot start with " + RowNode.ID_PREFIX_ROW_GROUP + ", this is a reserved prefix for AG Grid's row grouping feature."); + } + // force id to be a string + if (this.id !== null && typeof this.id !== 'string') { + this.id = '' + this.id; + } + } + else { + // this can happen if user has set blank into the rowNode after the row previously + // having data. this happens in virtual page row model, when data is delete and + // the page is refreshed. + this.id = undefined; + } + } + else { + this.id = id; + } }; - GridOptionsWrapper.prototype.getColumnDefs = function () { - return this.gridOptions.columnDefs; + RowNode.prototype.getGroupKeys = function (excludeSelf) { + if (excludeSelf === void 0) { excludeSelf = false; } + var keys = []; + var pointer = this; + if (excludeSelf) { + pointer = pointer.parent; + } + while (pointer && pointer.level >= 0) { + keys.push(pointer.key); + pointer = pointer.parent; + } + keys.reverse(); + return keys; }; - GridOptionsWrapper.prototype.getColumnTypes = function () { - return this.gridOptions.columnTypes; + RowNode.prototype.isPixelInRange = function (pixel) { + if (!Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["exists"])(this.rowTop) || !Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["exists"])(this.rowHeight)) { + return false; + } + return pixel >= this.rowTop && pixel < (this.rowTop + this.rowHeight); }; - GridOptionsWrapper.prototype.getDatasource = function () { - return this.gridOptions.datasource; + RowNode.prototype.setFirstChild = function (firstChild) { + if (this.firstChild === firstChild) { + return; + } + this.firstChild = firstChild; + if (this.eventService) { + this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_FIRST_CHILD_CHANGED)); + } }; - GridOptionsWrapper.prototype.getViewportDatasource = function () { - return this.gridOptions.viewportDatasource; + RowNode.prototype.setLastChild = function (lastChild) { + if (this.lastChild === lastChild) { + return; + } + this.lastChild = lastChild; + if (this.eventService) { + this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_LAST_CHILD_CHANGED)); + } }; - GridOptionsWrapper.prototype.getServerSideDatasource = function () { - return this.gridOptions.serverSideDatasource; + RowNode.prototype.setChildIndex = function (childIndex) { + if (this.childIndex === childIndex) { + return; + } + this.childIndex = childIndex; + if (this.eventService) { + this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_CHILD_INDEX_CHANGED)); + } }; - GridOptionsWrapper.prototype.isAccentedSort = function () { - return isTrue(this.gridOptions.accentedSort); + RowNode.prototype.setRowTop = function (rowTop) { + this.oldRowTop = this.rowTop; + if (this.rowTop === rowTop) { + return; + } + this.rowTop = rowTop; + if (this.eventService) { + this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_TOP_CHANGED)); + } + this.setDisplayed(rowTop !== null); }; - GridOptionsWrapper.prototype.isEnableBrowserTooltips = function () { - return isTrue(this.gridOptions.enableBrowserTooltips); + RowNode.prototype.clearRowTopAndRowIndex = function () { + this.oldRowTop = null; + this.setRowTop(null); + this.setRowIndex(null); }; - GridOptionsWrapper.prototype.isEnableCellExpressions = function () { - return isTrue(this.gridOptions.enableCellExpressions); + RowNode.prototype.setDisplayed = function (displayed) { + if (this.displayed === displayed) { + return; + } + this.displayed = displayed; + if (this.eventService) { + this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_DISPLAYED_CHANGED)); + } }; - GridOptionsWrapper.prototype.isEnableGroupEdit = function () { - return isTrue(this.gridOptions.enableGroupEdit); + RowNode.prototype.setDragging = function (dragging) { + if (this.dragging === dragging) { + return; + } + this.dragging = dragging; + if (this.eventService) { + this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_DRAGGING_CHANGED)); + } }; - GridOptionsWrapper.prototype.isSuppressMiddleClickScrolls = function () { - return isTrue(this.gridOptions.suppressMiddleClickScrolls); + RowNode.prototype.setHighlighted = function (highlighted) { + if (highlighted === this.highlighted) { + return; + } + this.highlighted = highlighted; + if (this.eventService) { + this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_HIGHLIGHT_CHANGED)); + } }; - GridOptionsWrapper.prototype.isPreventDefaultOnContextMenu = function () { - return isTrue(this.gridOptions.preventDefaultOnContextMenu); + RowNode.prototype.setAllChildrenCount = function (allChildrenCount) { + if (this.allChildrenCount === allChildrenCount) { + return; + } + this.allChildrenCount = allChildrenCount; + if (this.eventService) { + this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_ALL_CHILDREN_COUNT_CHANGED)); + } }; - GridOptionsWrapper.prototype.isSuppressPreventDefaultOnMouseWheel = function () { - return isTrue(this.gridOptions.suppressPreventDefaultOnMouseWheel); + RowNode.prototype.setMaster = function (master) { + if (this.master === master) { + return; + } + // if changing AWAY from master, then unexpand, otherwise + // next time it's shown it is expanded again + if (this.master && !master) { + this.expanded = false; + } + this.master = master; + if (this.eventService) { + this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_MASTER_CHANGED)); + } }; - GridOptionsWrapper.prototype.isSuppressColumnVirtualisation = function () { - return isTrue(this.gridOptions.suppressColumnVirtualisation); + RowNode.prototype.setGroup = function (group) { + if (this.group === group) { + return; + } + // if we used to be a group, and no longer, then close the node + if (this.group && !group) { + this.expanded = false; + } + this.group = group; + this.updateHasChildren(); + if (this.eventService) { + this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_GROUP_CHANGED)); + } }; - GridOptionsWrapper.prototype.isSuppressContextMenu = function () { - return isTrue(this.gridOptions.suppressContextMenu); + /** + * Sets the row height. + * Call if you want to change the height initially assigned to the row. + * After calling, you must call `api.onRowHeightChanged()` so the grid knows it needs to work out the placement of the rows. */ + RowNode.prototype.setRowHeight = function (rowHeight, estimated) { + if (estimated === void 0) { estimated = false; } + this.rowHeight = rowHeight; + this.rowHeightEstimated = estimated; + if (this.eventService) { + this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_HEIGHT_CHANGED)); + } }; - GridOptionsWrapper.prototype.isAllowContextMenuWithControlKey = function () { - return isTrue(this.gridOptions.allowContextMenuWithControlKey); + RowNode.prototype.setRowAutoHeight = function (cellHeight, column) { + if (!this.__autoHeights) { + this.__autoHeights = {}; + } + var autoHeights = this.__autoHeights; + autoHeights[column.getId()] = cellHeight; + if (cellHeight != null) { + if (this.checkAutoHeightsDebounced == null) { + this.checkAutoHeightsDebounced = Object(_utils_function__WEBPACK_IMPORTED_MODULE_5__["debounce"])(this.checkAutoHeights.bind(this), 1); + } + this.checkAutoHeightsDebounced(); + } }; - GridOptionsWrapper.prototype.isSuppressCopyRowsToClipboard = function () { - return isTrue(this.gridOptions.suppressCopyRowsToClipboard); + RowNode.prototype.checkAutoHeights = function () { + var notAllPresent = false; + var nonePresent = true; + var newRowHeight = 0; + var autoHeights = this.__autoHeights; + if (autoHeights == null) { + return; + } + var displayedAutoHeightCols = this.beans.columnModel.getAllDisplayedAutoHeightCols(); + displayedAutoHeightCols.forEach(function (col) { + var cellHeight = autoHeights[col.getId()]; + if (cellHeight == null) { + notAllPresent = true; + return; + } + nonePresent = false; + if (cellHeight > newRowHeight) { + newRowHeight = cellHeight; + } + }); + if (notAllPresent) { + return; + } + // we take min of 10, so we don't adjust for empty rows. if <10, we put to default. + // this prevents the row starting very small when waiting for async components, + // which would then mean the grid squashes in far to many rows (as small heights + // means more rows fit in) which looks crap. so best ignore small values and assume + // we are still waiting for values to render. + if (nonePresent || newRowHeight < 10) { + newRowHeight = this.beans.gridOptionsWrapper.getRowHeightForNode(this).height; + } + if (newRowHeight == this.rowHeight) { + return; + } + this.setRowHeight(newRowHeight); + var rowModel = this.beans.rowModel; + if (rowModel.onRowHeightChanged) { + rowModel.onRowHeightChanged(); + } }; - GridOptionsWrapper.prototype.isCopyHeadersToClipboard = function () { - return isTrue(this.gridOptions.copyHeadersToClipboard); + RowNode.prototype.setRowIndex = function (rowIndex) { + if (this.rowIndex === rowIndex) { + return; + } + this.rowIndex = rowIndex; + if (this.eventService) { + this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_ROW_INDEX_CHANGED)); + } }; - GridOptionsWrapper.prototype.isSuppressClipboardPaste = function () { - return isTrue(this.gridOptions.suppressClipboardPaste); + RowNode.prototype.setUiLevel = function (uiLevel) { + if (this.uiLevel === uiLevel) { + return; + } + this.uiLevel = uiLevel; + if (this.eventService) { + this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_UI_LEVEL_CHANGED)); + } }; - GridOptionsWrapper.prototype.isSuppressLastEmptyLineOnPaste = function () { - return isTrue(this.gridOptions.suppressLastEmptyLineOnPaste); + RowNode.prototype.setExpanded = function (expanded) { + if (this.expanded === expanded) { + return; + } + this.expanded = expanded; + if (this.eventService) { + this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_EXPANDED_CHANGED)); + } + var event = Object.assign({}, this.createGlobalRowEvent(_events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_ROW_GROUP_OPENED), { + expanded: expanded + }); + this.beans.rowNodeEventThrottle.dispatchExpanded(event); + // when using footers we need to refresh the group row, as the aggregation + // values jump between group and footer + if (this.beans.gridOptionsWrapper.isGroupIncludeFooter()) { + this.beans.rowRenderer.refreshCells({ rowNodes: [this] }); + } }; - GridOptionsWrapper.prototype.isPagination = function () { - return isTrue(this.gridOptions.pagination); + RowNode.prototype.createGlobalRowEvent = function (type) { + return { + type: type, + node: this, + data: this.data, + rowIndex: this.rowIndex, + rowPinned: this.rowPinned, + context: this.beans.gridOptionsWrapper.getContext(), + api: this.beans.gridOptionsWrapper.getApi(), + columnApi: this.beans.gridOptionsWrapper.getColumnApi() + }; }; - GridOptionsWrapper.prototype.isSuppressEnterpriseResetOnNewColumns = function () { - return isTrue(this.gridOptions.suppressEnterpriseResetOnNewColumns); + RowNode.prototype.dispatchLocalEvent = function (event) { + if (this.eventService) { + this.eventService.dispatchEvent(event); + } }; - GridOptionsWrapper.prototype.getProcessDataFromClipboardFunc = function () { - return this.gridOptions.processDataFromClipboard; + // we also allow editing the value via the editors. when it is done via + // the editors, no 'cell changed' event gets fired, as it's assumed that + // the cell knows about the change given it's in charge of the editing. + // this method is for the client to call, so the cell listens for the change + // event, and also flashes the cell when the change occurs. + /** Replaces the value on the `rowNode` for the specified column. When complete, the grid will refresh the rendered cell on the required row only. */ + RowNode.prototype.setDataValue = function (colKey, newValue, eventSource) { + var column = this.beans.columnModel.getPrimaryColumn(colKey); + var oldValue = this.beans.valueService.getValue(column, this); + this.beans.valueService.setValue(this, column, newValue, eventSource); + this.dispatchCellChangedEvent(column, newValue, oldValue); }; - GridOptionsWrapper.prototype.getAsyncTransactionWaitMillis = function () { - return _utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(this.gridOptions.asyncTransactionWaitMillis) ? this.gridOptions.asyncTransactionWaitMillis : _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].BATCH_WAIT_MILLIS; + RowNode.prototype.setGroupValue = function (colKey, newValue) { + var column = this.beans.columnModel.getGridColumn(colKey); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["missing"])(this.groupData)) { + this.groupData = {}; + } + var columnId = column.getColId(); + var oldValue = this.groupData[columnId]; + if (oldValue === newValue) { + return; + } + this.groupData[columnId] = newValue; + this.dispatchCellChangedEvent(column, newValue, oldValue); }; - GridOptionsWrapper.prototype.isSuppressMovableColumns = function () { - return isTrue(this.gridOptions.suppressMovableColumns); + // sets the data for an aggregation + RowNode.prototype.setAggData = function (newAggData) { + var _this = this; + // find out all keys that could potentially change + var colIds = Object(_utils_object__WEBPACK_IMPORTED_MODULE_4__["getAllKeysInObjects"])([this.aggData, newAggData]); + var oldAggData = this.aggData; + this.aggData = newAggData; + // if no event service, nobody has registered for events, so no need fire event + if (this.eventService) { + colIds.forEach(function (colId) { + var column = _this.beans.columnModel.getGridColumn(colId); + var value = _this.aggData ? _this.aggData[colId] : undefined; + var oldValue = oldAggData ? oldAggData[colId] : undefined; + _this.dispatchCellChangedEvent(column, value, oldValue); + }); + } }; - GridOptionsWrapper.prototype.isAnimateRows = function () { - // never allow animating if enforcing the row order - if (this.isEnsureDomOrder()) { - return false; + RowNode.prototype.updateHasChildren = function () { + // we need to return true when this.group=true, as this is used by server side row model + // (as children are lazy loaded and stored in a cache anyway). otherwise we return true + // if children exist. + var newValue = (this.group && !this.footer) || (this.childrenAfterGroup && this.childrenAfterGroup.length > 0); + if (newValue !== this.__hasChildren) { + this.__hasChildren = !!newValue; + if (this.eventService) { + this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_HAS_CHILDREN_CHANGED)); + } } - return isTrue(this.gridOptions.animateRows); }; - GridOptionsWrapper.prototype.isSuppressColumnMoveAnimation = function () { - return isTrue(this.gridOptions.suppressColumnMoveAnimation); + RowNode.prototype.hasChildren = function () { + if (this.__hasChildren == null) { + this.updateHasChildren(); + } + return this.__hasChildren; }; - GridOptionsWrapper.prototype.isSuppressAggFuncInHeader = function () { - return isTrue(this.gridOptions.suppressAggFuncInHeader); + RowNode.prototype.isEmptyRowGroupNode = function () { + return this.group && Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["missingOrEmpty"])(this.childrenAfterGroup); }; - GridOptionsWrapper.prototype.isSuppressAggAtRootLevel = function () { - return isTrue(this.gridOptions.suppressAggAtRootLevel); + RowNode.prototype.dispatchCellChangedEvent = function (column, newValue, oldValue) { + var cellChangedEvent = { + type: RowNode.EVENT_CELL_CHANGED, + node: this, + column: column, + newValue: newValue, + oldValue: oldValue + }; + this.dispatchLocalEvent(cellChangedEvent); }; - GridOptionsWrapper.prototype.isEnableRangeSelection = function () { - return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_9__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__["ModuleNames"].RangeSelectionModule) && isTrue(this.gridOptions.enableRangeSelection); + /** + * The first time `quickFilter` runs, the grid creates a one-off string representation of the row. + * This string is then used for the quick filter instead of hitting each column separately. + * When you edit, using grid editing, this string gets cleared down. + * However if you edit without using grid editing, you will need to clear this string down for the row to be updated with the new values. + * Otherwise new values will not work with the `quickFilter`. */ + RowNode.prototype.resetQuickFilterAggregateText = function () { + this.quickFilterAggregateText = null; }; - GridOptionsWrapper.prototype.isEnableRangeHandle = function () { - return isTrue(this.gridOptions.enableRangeHandle); + RowNode.prototype.isExpandable = function () { + return (this.hasChildren() && !this.footer) || this.master ? true : false; }; - GridOptionsWrapper.prototype.isEnableFillHandle = function () { - return isTrue(this.gridOptions.enableFillHandle); + /** Returns: + * - `true` if node is selected, + * - `false` if the node isn't selected + * - `undefined` if it's partially selected (group where not all children are selected). */ + RowNode.prototype.isSelected = function () { + // for footers, we just return what our sibling selected state is, as cannot select a footer + if (this.footer) { + return this.sibling.isSelected(); + } + return this.selected; }; - GridOptionsWrapper.prototype.getFillOperation = function () { - return this.gridOptions.fillOperation; + /** Perform a depth-first search of this node and its children. */ + RowNode.prototype.depthFirstSearch = function (callback) { + if (this.childrenAfterGroup) { + this.childrenAfterGroup.forEach(function (child) { return child.depthFirstSearch(callback); }); + } + callback(this); }; - GridOptionsWrapper.prototype.isSuppressMultiRangeSelection = function () { - return isTrue(this.gridOptions.suppressMultiRangeSelection); + // + rowController.updateGroupsInSelection() + // + selectionController.calculatedSelectedForAllGroupNodes() + RowNode.prototype.calculateSelectedFromChildren = function () { + var atLeastOneSelected = false; + var atLeastOneDeSelected = false; + var atLeastOneMixed = false; + var newSelectedValue; + if (this.childrenAfterGroup) { + for (var i = 0; i < this.childrenAfterGroup.length; i++) { + var child = this.childrenAfterGroup[i]; + // skip non-selectable nodes to prevent inconsistent selection values + if (!child.selectable) { + continue; + } + var childState = child.isSelected(); + switch (childState) { + case true: + atLeastOneSelected = true; + break; + case false: + atLeastOneDeSelected = true; + break; + default: + atLeastOneMixed = true; + break; + } + } + } + if (atLeastOneMixed) { + newSelectedValue = undefined; + } + else if (atLeastOneSelected && !atLeastOneDeSelected) { + newSelectedValue = true; + } + else if (!atLeastOneSelected && atLeastOneDeSelected) { + newSelectedValue = false; + } + else { + newSelectedValue = undefined; + } + this.selectThisNode(newSelectedValue); }; - GridOptionsWrapper.prototype.isPaginationAutoPageSize = function () { - return isTrue(this.gridOptions.paginationAutoPageSize); + RowNode.prototype.setSelectedInitialValue = function (selected) { + this.selected = selected; }; - GridOptionsWrapper.prototype.isRememberGroupStateWhenNewData = function () { - return isTrue(this.gridOptions.rememberGroupStateWhenNewData); + /** + * Select (or deselect) the node. + * @param newValue -`true` for selection, `false` for deselection. + * @param clearSelection - If selecting, then passing `true` will select the node exclusively (i.e. NOT do multi select). If doing deselection, `clearSelection` has no impact. + * @param suppressFinishActions - Pass `true` to prevent the `selectionChanged` from being fired. Note that the `rowSelected` event will still be fired. + */ + RowNode.prototype.setSelected = function (newValue, clearSelection, suppressFinishActions) { + if (clearSelection === void 0) { clearSelection = false; } + if (suppressFinishActions === void 0) { suppressFinishActions = false; } + this.setSelectedParams({ + newValue: newValue, + clearSelection: clearSelection, + suppressFinishActions: suppressFinishActions, + rangeSelect: false + }); }; - GridOptionsWrapper.prototype.getIcons = function () { - return this.gridOptions.icons; + RowNode.prototype.isRowPinned = function () { + return this.rowPinned === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP || this.rowPinned === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM; }; - GridOptionsWrapper.prototype.getAggFuncs = function () { - return this.gridOptions.aggFuncs; + // to make calling code more readable, this is the same method as setSelected except it takes names parameters + RowNode.prototype.setSelectedParams = function (params) { + var groupSelectsChildren = this.beans.gridOptionsWrapper.isGroupSelectsChildren(); + var newValue = params.newValue === true; + var clearSelection = params.clearSelection === true; + var suppressFinishActions = params.suppressFinishActions === true; + var rangeSelect = params.rangeSelect === true; + // groupSelectsFiltered only makes sense when group selects children + var groupSelectsFiltered = groupSelectsChildren && (params.groupSelectsFiltered === true); + if (this.id === undefined) { + console.warn('AG Grid: cannot select node until id for node is known'); + return 0; + } + if (this.rowPinned) { + console.warn('AG Grid: cannot select pinned rows'); + return 0; + } + // if we are a footer, we don't do selection, just pass the info + // to the sibling (the parent of the group) + if (this.footer) { + return this.sibling.setSelectedParams(params); + } + if (rangeSelect && this.beans.selectionService.getLastSelectedNode()) { + var newRowClicked = this.beans.selectionService.getLastSelectedNode() !== this; + var allowMultiSelect = this.beans.gridOptionsWrapper.isRowSelectionMulti(); + if (newRowClicked && allowMultiSelect) { + var nodesChanged = this.doRowRangeSelection(params.newValue); + this.beans.selectionService.setLastSelectedNode(this); + return nodesChanged; + } + } + var updatedCount = 0; + // when groupSelectsFiltered, then this node may end up intermediate despite + // trying to set it to true / false. this group will be calculated further on + // down when we call calculatedSelectedForAllGroupNodes(). we need to skip it + // here, otherwise the updatedCount would include it. + var skipThisNode = groupSelectsFiltered && this.group; + if (!skipThisNode) { + var thisNodeWasSelected = this.selectThisNode(newValue); + if (thisNodeWasSelected) { + updatedCount++; + } + } + if (groupSelectsChildren && this.group) { + updatedCount += this.selectChildNodes(newValue, groupSelectsFiltered); + } + // clear other nodes if not doing multi select + if (!suppressFinishActions) { + var clearOtherNodes = newValue && (clearSelection || !this.beans.gridOptionsWrapper.isRowSelectionMulti()); + if (clearOtherNodes) { + updatedCount += this.beans.selectionService.clearOtherNodes(this); + } + // only if we selected something, then update groups and fire events + if (updatedCount > 0) { + this.beans.selectionService.updateGroupsFromChildrenSelections(); + // this is the very end of the 'action node', so we are finished all the updates, + // include any parent / child changes that this method caused + var event_1 = { + type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_SELECTION_CHANGED, + api: this.beans.gridApi, + columnApi: this.beans.columnApi + }; + this.beans.eventService.dispatchEvent(event_1); + } + // so if user next does shift-select, we know where to start the selection from + if (newValue) { + this.beans.selectionService.setLastSelectedNode(this); + } + } + return updatedCount; }; - GridOptionsWrapper.prototype.getSortingOrder = function () { - return this.gridOptions.sortingOrder; + // selects all rows between this node and the last selected node (or the top if this is the first selection). + // not to be mixed up with 'cell range selection' where you drag the mouse, this is row range selection, by + // holding down 'shift'. + RowNode.prototype.doRowRangeSelection = function (value) { + var _this = this; + if (value === void 0) { value = true; } + var groupsSelectChildren = this.beans.gridOptionsWrapper.isGroupSelectsChildren(); + var lastSelectedNode = this.beans.selectionService.getLastSelectedNode(); + var nodesToSelect = this.beans.rowModel.getNodesInRangeForSelection(this, lastSelectedNode); + var updatedCount = 0; + nodesToSelect.forEach(function (rowNode) { + if (rowNode.group && groupsSelectChildren || (value === false && _this === rowNode)) { + return; + } + var nodeWasSelected = rowNode.selectThisNode(value); + if (nodeWasSelected) { + updatedCount++; + } + }); + this.beans.selectionService.updateGroupsFromChildrenSelections(); + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_SELECTION_CHANGED, + api: this.beans.gridApi, + columnApi: this.beans.columnApi + }; + this.beans.eventService.dispatchEvent(event); + return updatedCount; }; - GridOptionsWrapper.prototype.getAlignedGrids = function () { - return this.gridOptions.alignedGrids; + RowNode.prototype.isParentOfNode = function (potentialParent) { + var parentNode = this.parent; + while (parentNode) { + if (parentNode === potentialParent) { + return true; + } + parentNode = parentNode.parent; + } + return false; + }; + RowNode.prototype.selectThisNode = function (newValue) { + // we only check selectable when newValue=true (ie selecting) to allow unselecting values, + // as selectable is dynamic, need a way to unselect rows when selectable becomes false. + var selectionNotAllowed = !this.selectable && newValue; + var selectionNotChanged = this.selected === newValue; + if (selectionNotAllowed || selectionNotChanged) { + return false; + } + this.selected = newValue; + if (this.eventService) { + this.dispatchLocalEvent(this.createLocalRowEvent(RowNode.EVENT_ROW_SELECTED)); + } + var event = this.createGlobalRowEvent(_events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_ROW_SELECTED); + this.beans.eventService.dispatchEvent(event); + return true; }; - GridOptionsWrapper.prototype.isMasterDetail = function () { - var masterDetail = isTrue(this.gridOptions.masterDetail); - if (masterDetail) { - return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_9__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__["ModuleNames"].MasterDetailModule, 'masterDetail'); + RowNode.prototype.selectChildNodes = function (newValue, groupSelectsFiltered) { + var children = groupSelectsFiltered ? this.childrenAfterFilter : this.childrenAfterGroup; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["missing"])(children)) { + return 0; } - else { - return false; + var updatedCount = 0; + for (var i = 0; i < children.length; i++) { + updatedCount += children[i].setSelectedParams({ + newValue: newValue, + clearSelection: false, + suppressFinishActions: true, + groupSelectsFiltered: groupSelectsFiltered + }); } + return updatedCount; }; - GridOptionsWrapper.prototype.isKeepDetailRows = function () { - return isTrue(this.gridOptions.keepDetailRows); - }; - GridOptionsWrapper.prototype.getKeepDetailRowsCount = function () { - if (this.gridOptions.keepDetailRowsCount > 0) { - return this.gridOptions.keepDetailRowsCount; + /** Add an event listener. */ + RowNode.prototype.addEventListener = function (eventType, listener) { + if (!this.eventService) { + this.eventService = new _eventService__WEBPACK_IMPORTED_MODULE_0__["EventService"](); } - return DEFAULT_KEEP_DETAIL_ROW_COUNT; - }; - GridOptionsWrapper.prototype.getIsRowMasterFunc = function () { - return this.gridOptions.isRowMaster; - }; - GridOptionsWrapper.prototype.getIsRowSelectableFunc = function () { - return this.gridOptions.isRowSelectable; - }; - GridOptionsWrapper.prototype.getGroupRowRendererParams = function () { - return this.gridOptions.groupRowRendererParams; - }; - GridOptionsWrapper.prototype.getOverlayLoadingTemplate = function () { - return this.gridOptions.overlayLoadingTemplate; - }; - GridOptionsWrapper.prototype.getOverlayNoRowsTemplate = function () { - return this.gridOptions.overlayNoRowsTemplate; - }; - GridOptionsWrapper.prototype.isSuppressAutoSize = function () { - return isTrue(this.gridOptions.suppressAutoSize); - }; - GridOptionsWrapper.prototype.isEnableCellTextSelection = function () { - return isTrue(this.gridOptions.enableCellTextSelection); - }; - GridOptionsWrapper.prototype.isSuppressParentsInRowNodes = function () { - return isTrue(this.gridOptions.suppressParentsInRowNodes); - }; - GridOptionsWrapper.prototype.isFunctionsReadOnly = function () { - return isTrue(this.gridOptions.functionsReadOnly); + this.eventService.addEventListener(eventType, listener); }; - GridOptionsWrapper.prototype.isFloatingFilter = function () { - return this.gridOptions.floatingFilter; + /** Remove event listener. */ + RowNode.prototype.removeEventListener = function (eventType, listener) { + if (!this.eventService) { + return; + } + this.eventService.removeEventListener(eventType, listener); + if (this.eventService.noRegisteredListenersExist()) { + this.eventService = null; + } }; - GridOptionsWrapper.prototype.isEnableCellTextSelect = function () { - return isTrue(this.gridOptions.enableCellTextSelection); + RowNode.prototype.onMouseEnter = function () { + this.dispatchLocalEvent(this.createLocalRowEvent(RowNode.EVENT_MOUSE_ENTER)); }; - GridOptionsWrapper.prototype.isEnableOldSetFilterModel = function () { - return isTrue(this.gridOptions.enableOldSetFilterModel); + RowNode.prototype.onMouseLeave = function () { + this.dispatchLocalEvent(this.createLocalRowEvent(RowNode.EVENT_MOUSE_LEAVE)); }; - GridOptionsWrapper.prototype.getDefaultColDef = function () { - return this.gridOptions.defaultColDef; + RowNode.prototype.getFirstChildOfFirstChild = function (rowGroupColumn) { + var currentRowNode = this; + var isCandidate = true; + var foundFirstChildPath = false; + var nodeToSwapIn = null; + // if we are hiding groups, then if we are the first child, of the first child, + // all the way up to the column we are interested in, then we show the group cell. + while (isCandidate && !foundFirstChildPath) { + var parentRowNode = currentRowNode.parent; + var firstChild = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["exists"])(parentRowNode) && currentRowNode.firstChild; + if (firstChild) { + if (parentRowNode.rowGroupColumn === rowGroupColumn) { + foundFirstChildPath = true; + nodeToSwapIn = parentRowNode; + } + } + else { + isCandidate = false; + } + currentRowNode = parentRowNode; + } + return foundFirstChildPath ? nodeToSwapIn : null; }; - GridOptionsWrapper.prototype.getDefaultColGroupDef = function () { - return this.gridOptions.defaultColGroupDef; + RowNode.prototype.isFullWidthCell = function () { + var isFullWidthCellFunc = this.beans.gridOptionsWrapper.getIsFullWidthCellFunc(); + return isFullWidthCellFunc ? isFullWidthCellFunc(this) : false; }; - GridOptionsWrapper.prototype.getDefaultExportParams = function () { - return this.gridOptions.defaultExportParams; + /** + * Returns the route of the row node. If the Row Node is a group, it returns the route to that Row Node. + * If the Row Node is not a group, it returns `undefined`. + */ + RowNode.prototype.getRoute = function () { + if (this.key == null) { + return; + } + var res = []; + var pointer = this; + while (pointer.key != null) { + res.push(pointer.key); + pointer = pointer.parent; + } + return res.reverse(); }; - GridOptionsWrapper.prototype.isSuppressCsvExport = function () { - return isTrue(this.gridOptions.suppressCsvExport); + RowNode.ID_PREFIX_ROW_GROUP = 'row-group-'; + RowNode.ID_PREFIX_TOP_PINNED = 't-'; + RowNode.ID_PREFIX_BOTTOM_PINNED = 'b-'; + RowNode.OBJECT_ID_SEQUENCE = 0; + RowNode.EVENT_ROW_SELECTED = 'rowSelected'; + RowNode.EVENT_DATA_CHANGED = 'dataChanged'; + RowNode.EVENT_CELL_CHANGED = 'cellChanged'; + RowNode.EVENT_ALL_CHILDREN_COUNT_CHANGED = 'allChildrenCountChanged'; + RowNode.EVENT_MASTER_CHANGED = 'masterChanged'; + RowNode.EVENT_GROUP_CHANGED = 'groupChanged'; + RowNode.EVENT_MOUSE_ENTER = 'mouseEnter'; + RowNode.EVENT_MOUSE_LEAVE = 'mouseLeave'; + RowNode.EVENT_HEIGHT_CHANGED = 'heightChanged'; + RowNode.EVENT_TOP_CHANGED = 'topChanged'; + RowNode.EVENT_DISPLAYED_CHANGED = 'displayedChanged'; + RowNode.EVENT_FIRST_CHILD_CHANGED = 'firstChildChanged'; + RowNode.EVENT_LAST_CHILD_CHANGED = 'lastChildChanged'; + RowNode.EVENT_CHILD_INDEX_CHANGED = 'childIndexChanged'; + RowNode.EVENT_ROW_INDEX_CHANGED = 'rowIndexChanged'; + RowNode.EVENT_EXPANDED_CHANGED = 'expandedChanged'; + RowNode.EVENT_HAS_CHILDREN_CHANGED = 'hasChildrenChanged'; + RowNode.EVENT_SELECTABLE_CHANGED = 'selectableChanged'; + RowNode.EVENT_UI_LEVEL_CHANGED = 'uiLevelChanged'; + RowNode.EVENT_HIGHLIGHT_CHANGED = 'rowHighlightChanged'; + RowNode.EVENT_DRAGGING_CHANGED = 'draggingChanged'; + return RowNode; +}()); + + + +/***/ }), +/* 95 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CheckboxSelectionComponent", function() { return CheckboxSelectionComponent; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(36); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(23); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(57); +/* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(94); +/* harmony import */ var _utils_event__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(21); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - GridOptionsWrapper.prototype.isAllowShowChangeAfterFilter = function () { - return isTrue(this.gridOptions.allowShowChangeAfterFilter); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - GridOptionsWrapper.prototype.isSuppressExcelExport = function () { - return isTrue(this.gridOptions.suppressExcelExport); +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + +var CheckboxSelectionComponent = /** @class */ (function (_super) { + __extends(CheckboxSelectionComponent, _super); + function CheckboxSelectionComponent() { + return _super.call(this, /* html*/ "\n
\n \n
") || this; + } + CheckboxSelectionComponent.prototype.postConstruct = function () { + this.eCheckbox.setPassive(true); }; - GridOptionsWrapper.prototype.isSuppressMakeColumnVisibleAfterUnGroup = function () { - return isTrue(this.gridOptions.suppressMakeColumnVisibleAfterUnGroup); + CheckboxSelectionComponent.prototype.getCheckboxId = function () { + return this.eCheckbox.getInputElement().id; }; - GridOptionsWrapper.prototype.getNodeChildDetailsFunc = function () { - return this.gridOptions.getNodeChildDetails; + CheckboxSelectionComponent.prototype.onDataChanged = function () { + // when rows are loaded for the second time, this can impact the selection, as a row + // could be loaded as already selected (if user scrolls down, and then up again). + this.onSelectionChanged(); }; - GridOptionsWrapper.prototype.getDataPathFunc = function () { - return this.gridOptions.getDataPath; + CheckboxSelectionComponent.prototype.onSelectableChanged = function () { + this.showOrHideSelect(); }; - GridOptionsWrapper.prototype.getIsServerSideGroupFunc = function () { - return this.gridOptions.isServerSideGroup; + CheckboxSelectionComponent.prototype.onSelectionChanged = function () { + var translate = this.gridOptionsWrapper.getLocaleTextFunc(); + var state = this.rowNode.isSelected(); + var stateName = state === undefined + ? translate('ariaIndeterminate', 'indeterminate') + : (state === true + ? translate('ariaChecked', 'checked') + : translate('ariaUnchecked', 'unchecked')); + var ariaLabel = translate('ariaRowToggleSelection', 'Press Space to toggle row selection'); + this.eCheckbox.setValue(state, true); + this.eCheckbox.setInputAriaLabel(ariaLabel + " (" + stateName + ")"); }; - GridOptionsWrapper.prototype.getServerSideGroupKeyFunc = function () { - return this.gridOptions.getServerSideGroupKey; + CheckboxSelectionComponent.prototype.onCheckedClicked = function (event) { + var groupSelectsFiltered = this.gridOptionsWrapper.isGroupSelectsFiltered(); + var updatedCount = this.rowNode.setSelectedParams({ newValue: false, rangeSelect: event.shiftKey, groupSelectsFiltered: groupSelectsFiltered }); + return updatedCount; }; - GridOptionsWrapper.prototype.getGroupRowAggNodesFunc = function () { - return this.gridOptions.groupRowAggNodes; + CheckboxSelectionComponent.prototype.onUncheckedClicked = function (event) { + var groupSelectsFiltered = this.gridOptionsWrapper.isGroupSelectsFiltered(); + var updatedCount = this.rowNode.setSelectedParams({ newValue: true, rangeSelect: event.shiftKey, groupSelectsFiltered: groupSelectsFiltered }); + return updatedCount; }; - GridOptionsWrapper.prototype.getContextMenuItemsFunc = function () { - return this.gridOptions.getContextMenuItems; + CheckboxSelectionComponent.prototype.init = function (params) { + var _this = this; + this.rowNode = params.rowNode; + this.column = params.column; + this.onSelectionChanged(); + // we don't want the row clicked event to fire when selecting the checkbox, otherwise the row + // would possibly get selected twice + this.addGuiEventListener('click', function (event) { return Object(_utils_event__WEBPACK_IMPORTED_MODULE_5__["stopPropagationForAgGrid"])(event); }); + // likewise we don't want double click on this icon to open a group + this.addGuiEventListener('dblclick', function (event) { return Object(_utils_event__WEBPACK_IMPORTED_MODULE_5__["stopPropagationForAgGrid"])(event); }); + this.addManagedListener(this.eCheckbox.getInputElement(), 'click', function (event) { + var isSelected = _this.eCheckbox.getValue(); + var previousValue = _this.eCheckbox.getPreviousValue(); + if (previousValue === undefined || isSelected === undefined) { + // Indeterminate state - try toggling children to determine action. + var result = _this.onUncheckedClicked(event || {}); + if (result === 0) { + _this.onCheckedClicked(event); + } + } + else if (isSelected) { + _this.onCheckedClicked(event); + } + else { + _this.onUncheckedClicked(event || {}); + } + }); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_4__["RowNode"].EVENT_ROW_SELECTED, this.onSelectionChanged.bind(this)); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_4__["RowNode"].EVENT_DATA_CHANGED, this.onDataChanged.bind(this)); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_4__["RowNode"].EVENT_SELECTABLE_CHANGED, this.onSelectableChanged.bind(this)); + var isRowSelectableFunc = this.gridOptionsWrapper.getIsRowSelectableFunc(); + var checkboxVisibleIsDynamic = isRowSelectableFunc || this.checkboxCallbackExists(); + if (checkboxVisibleIsDynamic) { + var showOrHideSelectListener = this.showOrHideSelect.bind(this); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, showOrHideSelectListener); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_4__["RowNode"].EVENT_DATA_CHANGED, showOrHideSelectListener); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_4__["RowNode"].EVENT_CELL_CHANGED, showOrHideSelectListener); + this.showOrHideSelect(); + } + this.eCheckbox.getInputElement().setAttribute('tabindex', '-1'); }; - GridOptionsWrapper.prototype.getMainMenuItemsFunc = function () { - return this.gridOptions.getMainMenuItems; + CheckboxSelectionComponent.prototype.showOrHideSelect = function () { + // if the isRowSelectable() is not provided the row node is selectable by default + var selectable = this.rowNode.selectable; + // checkboxSelection callback is deemed a legacy solution however we will still consider it's result. + // If selectable, then also check the colDef callback. if not selectable, this it short circuits - no need + // to call the colDef callback. + if (selectable && this.checkboxCallbackExists()) { + selectable = this.column.isCellCheckboxSelection(this.rowNode); + } + // show checkbox if both conditions are true + this.setVisible(selectable); }; - GridOptionsWrapper.prototype.getChartToolbarItemsFunc = function () { - return this.gridOptions.getChartToolbarItems; + CheckboxSelectionComponent.prototype.checkboxCallbackExists = function () { + // column will be missing if groupUseEntireRow=true + var colDef = this.column ? this.column.getColDef() : null; + return !!colDef && typeof colDef.checkboxSelection === 'function'; }; - GridOptionsWrapper.prototype.getRowNodeIdFunc = function () { - return this.gridOptions.getRowNodeId; + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eCheckbox') + ], CheckboxSelectionComponent.prototype, "eCheckbox", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], CheckboxSelectionComponent.prototype, "postConstruct", null); + return CheckboxSelectionComponent; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_1__["Component"])); + + + +/***/ }), +/* 96 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowDragComp", function() { return RowDragComp; }); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(94); +/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(97); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(24); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(20); +/* harmony import */ var _utils_icon__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(48); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(14); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - GridOptionsWrapper.prototype.getNavigateToNextCellFunc = function () { - return this.gridOptions.navigateToNextCell; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - GridOptionsWrapper.prototype.getTabToNextCellFunc = function () { - return this.gridOptions.tabToNextCell; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + + +var RowDragComp = /** @class */ (function (_super) { + __extends(RowDragComp, _super); + function RowDragComp(cellValueFn, rowNode, column, customGui, dragStartPixels, suppressVisibilityChange) { + var _this = _super.call(this) || this; + _this.cellValueFn = cellValueFn; + _this.rowNode = rowNode; + _this.column = column; + _this.customGui = customGui; + _this.dragStartPixels = dragStartPixels; + _this.suppressVisibilityChange = suppressVisibilityChange; + _this.dragSource = null; + return _this; + } + RowDragComp.prototype.isCustomGui = function () { + return this.customGui != null; }; - GridOptionsWrapper.prototype.isTreeData = function () { - var usingTreeData = isTrue(this.gridOptions.treeData); - if (usingTreeData) { - return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_9__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__["ModuleNames"].RowGroupingModule, 'Tree Data'); + RowDragComp.prototype.postConstruct = function () { + if (!this.customGui) { + this.setTemplate(/* html */ "
"); + this.getGui().appendChild(Object(_utils_icon__WEBPACK_IMPORTED_MODULE_6__["createIconNoSpan"])('rowDrag', this.beans.gridOptionsWrapper, null)); + this.addDragSource(); } else { - return false; + this.setDragElement(this.customGui, this.dragStartPixels); + } + this.checkCompatibility(); + if (!this.suppressVisibilityChange) { + var strategy = this.beans.gridOptionsWrapper.isRowDragManaged() ? + new ManagedVisibilityStrategy(this, this.beans, this.rowNode, this.column) : + new NonManagedVisibilityStrategy(this, this.beans, this.rowNode, this.column); + this.createManagedBean(strategy, this.beans.context); } }; - GridOptionsWrapper.prototype.isValueCache = function () { - return isTrue(this.gridOptions.valueCache); - }; - GridOptionsWrapper.prototype.isValueCacheNeverExpires = function () { - return isTrue(this.gridOptions.valueCacheNeverExpires); - }; - GridOptionsWrapper.prototype.isDeltaSort = function () { - return isTrue(this.gridOptions.deltaSort); - }; - GridOptionsWrapper.prototype.isAggregateOnlyChangedColumns = function () { - return isTrue(this.gridOptions.aggregateOnlyChangedColumns); - }; - GridOptionsWrapper.prototype.getProcessSecondaryColDefFunc = function () { - return this.gridOptions.processSecondaryColDef; - }; - GridOptionsWrapper.prototype.getProcessSecondaryColGroupDefFunc = function () { - return this.gridOptions.processSecondaryColGroupDef; - }; - GridOptionsWrapper.prototype.getSendToClipboardFunc = function () { - return this.gridOptions.sendToClipboard; - }; - GridOptionsWrapper.prototype.getProcessRowPostCreateFunc = function () { - return this.gridOptions.processRowPostCreate; - }; - GridOptionsWrapper.prototype.getProcessCellForClipboardFunc = function () { - return this.gridOptions.processCellForClipboard; - }; - GridOptionsWrapper.prototype.getProcessHeaderForClipboardFunc = function () { - return this.gridOptions.processHeaderForClipboard; - }; - GridOptionsWrapper.prototype.getProcessCellFromClipboardFunc = function () { - return this.gridOptions.processCellFromClipboard; - }; - GridOptionsWrapper.prototype.getViewportRowModelPageSize = function () { - return oneOrGreater(this.gridOptions.viewportRowModelPageSize, DEFAULT_VIEWPORT_ROW_MODEL_PAGE_SIZE); - }; - GridOptionsWrapper.prototype.getViewportRowModelBufferSize = function () { - return zeroOrGreater(this.gridOptions.viewportRowModelBufferSize, DEFAULT_VIEWPORT_ROW_MODEL_BUFFER_SIZE); - }; - GridOptionsWrapper.prototype.isServerSideSortingAlwaysResets = function () { - return isTrue(this.gridOptions.serverSideSortingAlwaysResets); - }; - GridOptionsWrapper.prototype.getPostSortFunc = function () { - return this.gridOptions.postSort; - }; - GridOptionsWrapper.prototype.getProcessChartOptionsFunc = function () { - return this.gridOptions.processChartOptions; - }; - GridOptionsWrapper.prototype.getClipboardDeliminator = function () { - return _utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(this.gridOptions.clipboardDeliminator) ? this.gridOptions.clipboardDeliminator : '\t'; + RowDragComp.prototype.setDragElement = function (dragElement, dragStartPixels) { + this.setTemplateFromElement(dragElement); + this.addDragSource(dragStartPixels); }; - GridOptionsWrapper.prototype.setProperty = function (key, value, force) { - if (force === void 0) { force = false; } - var gridOptionsNoType = this.gridOptions; - var previousValue = gridOptionsNoType[key]; - if (force || previousValue !== value) { - gridOptionsNoType[key] = value; - var event_1 = { - type: key, - currentValue: value, - previousValue: previousValue - }; - this.propertyEventService.dispatchEvent(event_1); + RowDragComp.prototype.getSelectedCount = function () { + var isRowDragMultiRow = this.beans.gridOptionsWrapper.isRowDragMultiRow(); + if (!isRowDragMultiRow) { + return 1; } + var selection = this.beans.selectionService.getSelectedNodes(); + return selection.indexOf(this.rowNode) !== -1 ? selection.length : 1; }; - // this logic is repeated in lots of places. any element that had different CSS - // dependent on the layout needs to have the layout class added ot it. - GridOptionsWrapper.prototype.addLayoutElement = function (element) { - this.layoutElements.push(element); - this.updateLayoutClasses(); - }; - GridOptionsWrapper.prototype.updateLayoutClasses = function () { - var domLayout = this.getDomLayout(); - var domLayoutAutoHeight = domLayout === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_AUTO_HEIGHT; - var domLayoutPrint = domLayout === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_PRINT; - var domLayoutNormal = domLayout === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_NORMAL; - this.layoutElements.forEach(function (e) { - _utils__WEBPACK_IMPORTED_MODULE_10__["_"].addOrRemoveCssClass(e, 'ag-layout-auto-height', domLayoutAutoHeight); - _utils__WEBPACK_IMPORTED_MODULE_10__["_"].addOrRemoveCssClass(e, 'ag-layout-normal', domLayoutNormal); - _utils__WEBPACK_IMPORTED_MODULE_10__["_"].addOrRemoveCssClass(e, 'ag-layout-print', domLayoutPrint); - }); + // returns true if all compatibility items work out + RowDragComp.prototype.checkCompatibility = function () { + var managed = this.beans.gridOptionsWrapper.isRowDragManaged(); + var treeData = this.beans.gridOptionsWrapper.isTreeData(); + if (treeData && managed) { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_7__["doOnce"])(function () { + return console.warn('AG Grid: If using row drag with tree data, you cannot have rowDragManaged=true'); + }, 'RowDragComp.managedAndTreeData'); + } }; - GridOptionsWrapper.prototype.addEventListener = function (key, listener) { - GridOptionsWrapper_1.checkEventDeprecation(key); - this.propertyEventService.addEventListener(key, listener); + RowDragComp.prototype.addDragSource = function (dragStartPixels) { + var _this = this; + if (dragStartPixels === void 0) { dragStartPixels = 4; } + // if this is changing the drag element, delete the previous dragSource + if (this.dragSource) { + this.removeDragSource(); + } + var dragItem = { + rowNode: this.rowNode, + columns: this.column ? [this.column] : undefined, + defaultTextValue: this.cellValueFn(), + }; + var rowDragText = this.column && this.column.getColDef().rowDragText; + var translate = this.gridOptionsWrapper.getLocaleTextFunc(); + this.dragSource = { + type: _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_3__["DragSourceType"].RowDrag, + eElement: this.getGui(), + dragItemName: function () { + var dragItemCount = _this.getSelectedCount(); + if (rowDragText) { + return rowDragText(dragItem, dragItemCount); + } + return dragItemCount === 1 ? _this.cellValueFn() : dragItemCount + " " + translate('rowDragRows', 'rows'); + }, + getDragItem: function () { return dragItem; }, + dragStartPixels: dragStartPixels, + dragSourceDomDataKey: this.beans.gridOptionsWrapper.getDomDataKey() + }; + this.beans.dragAndDropService.addDragSource(this.dragSource, true); }; - GridOptionsWrapper.checkEventDeprecation = function (eventName) { - if (eventName === 'floatingRowDataChanged') { - console.warn('ag-Grid: floatingRowDataChanged is now called pinnedRowDataChanged'); + RowDragComp.prototype.removeDragSource = function () { + if (this.dragSource) { + this.beans.dragAndDropService.removeDragSource(this.dragSource); } + this.dragSource = null; }; - GridOptionsWrapper.prototype.removeEventListener = function (key, listener) { - this.propertyEventService.removeEventListener(key, listener); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('beans') + ], RowDragComp.prototype, "beans", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], RowDragComp.prototype, "postConstruct", null); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PreDestroy"] + ], RowDragComp.prototype, "removeDragSource", null); + return RowDragComp; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); + +var VisibilityStrategy = /** @class */ (function (_super) { + __extends(VisibilityStrategy, _super); + function VisibilityStrategy(parent, rowNode, column) { + var _this = _super.call(this) || this; + _this.parent = parent; + _this.rowNode = rowNode; + _this.column = column; + return _this; + } + VisibilityStrategy.prototype.setDisplayedOrVisible = function (neverDisplayed) { + if (neverDisplayed) { + this.parent.setDisplayed(false); + } + else { + var shown = true; + var isShownSometimes = false; + if (this.column) { + shown = this.column.isRowDrag(this.rowNode) || this.parent.isCustomGui(); + isShownSometimes = Object(_utils_function__WEBPACK_IMPORTED_MODULE_7__["isFunction"])(this.column.getColDef().rowDrag); + } + // if shown sometimes, them some rows can have drag handle while other don't, + // so we use setVisible to keep the handles horizontally aligned (as setVisible + // keeps the empty space, whereas setDisplayed looses the space) + if (isShownSometimes) { + this.parent.setDisplayed(true); + this.parent.setVisible(shown); + } + else { + this.parent.setDisplayed(shown); + this.parent.setVisible(true); + } + } }; - GridOptionsWrapper.prototype.isSkipHeaderOnAutoSize = function () { - return !!this.gridOptions.skipHeaderOnAutoSize; + return VisibilityStrategy; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_5__["BeanStub"])); +// when non managed, the visibility depends on suppressRowDrag property only +var NonManagedVisibilityStrategy = /** @class */ (function (_super) { + __extends(NonManagedVisibilityStrategy, _super); + function NonManagedVisibilityStrategy(parent, beans, rowNode, column) { + var _this = _super.call(this, parent, rowNode, column) || this; + _this.beans = beans; + return _this; + } + NonManagedVisibilityStrategy.prototype.postConstruct = function () { + this.addManagedListener(this.beans.gridOptionsWrapper, 'suppressRowDrag', this.onSuppressRowDrag.bind(this)); + // in case data changes, then we need to update visibility of drag item + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_DATA_CHANGED, this.workOutVisibility.bind(this)); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_CELL_CHANGED, this.workOutVisibility.bind(this)); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_CELL_CHANGED, this.workOutVisibility.bind(this)); + this.addManagedListener(this.beans.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_NEW_COLUMNS_LOADED, this.workOutVisibility.bind(this)); + this.workOutVisibility(); }; - GridOptionsWrapper.prototype.getAutoSizePadding = function () { - return this.gridOptions.autoSizePadding && this.gridOptions.autoSizePadding > 0 ? this.gridOptions.autoSizePadding : 20; + NonManagedVisibilityStrategy.prototype.onSuppressRowDrag = function () { + this.workOutVisibility(); }; - // properties - GridOptionsWrapper.prototype.getHeaderHeight = function () { - if (typeof this.gridOptions.headerHeight === 'number') { - return this.gridOptions.headerHeight; - } - return this.getFromTheme(25, 'headerHeight'); + NonManagedVisibilityStrategy.prototype.workOutVisibility = function () { + // only show the drag if both sort and filter are not present + var neverDisplayed = this.beans.gridOptionsWrapper.isSuppressRowDrag(); + this.setDisplayedOrVisible(neverDisplayed); }; - GridOptionsWrapper.prototype.getFloatingFiltersHeight = function () { - if (typeof this.gridOptions.floatingFiltersHeight === 'number') { - return this.gridOptions.floatingFiltersHeight; - } - return this.getFromTheme(25, 'headerHeight'); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], NonManagedVisibilityStrategy.prototype, "postConstruct", null); + return NonManagedVisibilityStrategy; +}(VisibilityStrategy)); +// when managed, the visibility depends on sort, filter and row group, as well as suppressRowDrag property +var ManagedVisibilityStrategy = /** @class */ (function (_super) { + __extends(ManagedVisibilityStrategy, _super); + function ManagedVisibilityStrategy(parent, beans, rowNode, column) { + var _this = _super.call(this, parent, rowNode, column) || this; + _this.beans = beans; + return _this; + } + ManagedVisibilityStrategy.prototype.postConstruct = function () { + // we do not show the component if sort, filter or grouping is active + this.addManagedListener(this.beans.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_SORT_CHANGED, this.workOutVisibility.bind(this)); + this.addManagedListener(this.beans.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_FILTER_CHANGED, this.workOutVisibility.bind(this)); + this.addManagedListener(this.beans.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, this.workOutVisibility.bind(this)); + this.addManagedListener(this.beans.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_NEW_COLUMNS_LOADED, this.workOutVisibility.bind(this)); + // in case data changes, then we need to update visibility of drag item + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_DATA_CHANGED, this.workOutVisibility.bind(this)); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_CELL_CHANGED, this.workOutVisibility.bind(this)); + this.addManagedListener(this.beans.gridOptionsWrapper, 'suppressRowDrag', this.onSuppressRowDrag.bind(this)); + this.workOutVisibility(); }; - GridOptionsWrapper.prototype.getGroupHeaderHeight = function () { - if (typeof this.gridOptions.groupHeaderHeight === 'number') { - return this.gridOptions.groupHeaderHeight; - } - return this.getHeaderHeight(); + ManagedVisibilityStrategy.prototype.onSuppressRowDrag = function () { + this.workOutVisibility(); }; - GridOptionsWrapper.prototype.getPivotHeaderHeight = function () { - if (typeof this.gridOptions.pivotHeaderHeight === 'number') { - return this.gridOptions.pivotHeaderHeight; - } - return this.getHeaderHeight(); + ManagedVisibilityStrategy.prototype.workOutVisibility = function () { + // only show the drag if both sort and filter are not present + var gridBodyCon = this.beans.ctrlsService.getGridBodyCtrl(); + var rowDragFeature = gridBodyCon.getRowDragFeature(); + var shouldPreventRowMove = rowDragFeature && rowDragFeature.shouldPreventRowMove(); + var suppressRowDrag = this.beans.gridOptionsWrapper.isSuppressRowDrag(); + var hasExternalDropZones = this.beans.dragAndDropService.hasExternalDropZones(); + var neverDisplayed = (shouldPreventRowMove && !hasExternalDropZones) || suppressRowDrag; + this.setDisplayedOrVisible(neverDisplayed); }; - GridOptionsWrapper.prototype.getPivotGroupHeaderHeight = function () { - if (typeof this.gridOptions.pivotGroupHeaderHeight === 'number') { - return this.gridOptions.pivotGroupHeaderHeight; - } - return this.getGroupHeaderHeight(); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], ManagedVisibilityStrategy.prototype, "postConstruct", null); + return ManagedVisibilityStrategy; +}(VisibilityStrategy)); + + +/***/ }), +/* 97 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DragSourceType", function() { return DragSourceType; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "VerticalDirection", function() { return VerticalDirection; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HorizontalDirection", function() { return HorizontalDirection; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DragAndDropService", function() { return DragAndDropService; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _utils_string__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(26); +/* harmony import */ var _utils_icon__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(48); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(18); +/* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(43); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(42); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(14); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - GridOptionsWrapper.prototype.isExternalFilterPresent = function () { - if (typeof this.gridOptions.isExternalFilterPresent === 'function') { - return this.gridOptions.isExternalFilterPresent(); - } - return false; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - GridOptionsWrapper.prototype.doesExternalFilterPass = function (node) { - if (typeof this.gridOptions.doesExternalFilterPass === 'function') { - return this.gridOptions.doesExternalFilterPass(node); +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; +var __values = (undefined && undefined.__values) || function(o) { + var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0; + if (m) return m.call(o); + if (o && typeof o.length === "number") return { + next: function () { + if (o && i >= o.length) o = void 0; + return { value: o && o[i++], done: !o }; } - return false; }; - GridOptionsWrapper.prototype.getTooltipShowDelay = function () { - var tooltipShowDelay = this.gridOptions.tooltipShowDelay; - if (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(tooltipShowDelay)) { - if (tooltipShowDelay < 0) { - console.warn('ag-grid: tooltipShowDelay should not be lower than 0'); - } - return Math.max(200, tooltipShowDelay); - } - return null; + throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined."); +}; + + + + + + + + +var DragSourceType; +(function (DragSourceType) { + DragSourceType[DragSourceType["ToolPanel"] = 0] = "ToolPanel"; + DragSourceType[DragSourceType["HeaderCell"] = 1] = "HeaderCell"; + DragSourceType[DragSourceType["RowDrag"] = 2] = "RowDrag"; + DragSourceType[DragSourceType["ChartPanel"] = 3] = "ChartPanel"; +})(DragSourceType || (DragSourceType = {})); +var VerticalDirection; +(function (VerticalDirection) { + VerticalDirection[VerticalDirection["Up"] = 0] = "Up"; + VerticalDirection[VerticalDirection["Down"] = 1] = "Down"; +})(VerticalDirection || (VerticalDirection = {})); +var HorizontalDirection; +(function (HorizontalDirection) { + HorizontalDirection[HorizontalDirection["Left"] = 0] = "Left"; + HorizontalDirection[HorizontalDirection["Right"] = 1] = "Right"; +})(HorizontalDirection || (HorizontalDirection = {})); +var DragAndDropService = /** @class */ (function (_super) { + __extends(DragAndDropService, _super); + function DragAndDropService() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.dragSourceAndParamsList = []; + _this.dropTargets = []; + return _this; + } + DragAndDropService_1 = DragAndDropService; + DragAndDropService.prototype.init = function () { + this.ePinnedIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_3__["createIcon"])('columnMovePin', this.gridOptionsWrapper, null); + this.eHideIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_3__["createIcon"])('columnMoveHide', this.gridOptionsWrapper, null); + this.eMoveIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_3__["createIcon"])('columnMoveMove', this.gridOptionsWrapper, null); + this.eLeftIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_3__["createIcon"])('columnMoveLeft', this.gridOptionsWrapper, null); + this.eRightIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_3__["createIcon"])('columnMoveRight', this.gridOptionsWrapper, null); + this.eGroupIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_3__["createIcon"])('columnMoveGroup', this.gridOptionsWrapper, null); + this.eAggregateIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_3__["createIcon"])('columnMoveValue', this.gridOptionsWrapper, null); + this.ePivotIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_3__["createIcon"])('columnMovePivot', this.gridOptionsWrapper, null); + this.eDropNotAllowedIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_3__["createIcon"])('dropNotAllowed', this.gridOptionsWrapper, null); }; - GridOptionsWrapper.prototype.isTooltipMouseTrack = function () { - return isTrue(this.gridOptions.tooltipMouseTrack); + DragAndDropService.prototype.addDragSource = function (dragSource, allowTouch) { + if (allowTouch === void 0) { allowTouch = false; } + var params = { + eElement: dragSource.eElement, + dragStartPixels: dragSource.dragStartPixels, + onDragStart: this.onDragStart.bind(this, dragSource), + onDragStop: this.onDragStop.bind(this), + onDragging: this.onDragging.bind(this) + }; + this.dragSourceAndParamsList.push({ params: params, dragSource: dragSource }); + this.dragService.addDragSource(params, allowTouch); }; - GridOptionsWrapper.prototype.getDocument = function () { - // if user is providing document, we use the users one, - // otherwise we use the document on the global namespace. - var result = null; - if (this.gridOptions.getDocument && _utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(this.gridOptions.getDocument)) { - result = this.gridOptions.getDocument(); - } - if (result && _utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(result)) { - return result; + DragAndDropService.prototype.removeDragSource = function (dragSource) { + var sourceAndParams = this.dragSourceAndParamsList.find(function (item) { return item.dragSource === dragSource; }); + if (sourceAndParams) { + this.dragService.removeDragSource(sourceAndParams.params); + Object(_utils_array__WEBPACK_IMPORTED_MODULE_4__["removeFromArray"])(this.dragSourceAndParamsList, sourceAndParams); } - return document; }; - GridOptionsWrapper.prototype.getMinColWidth = function () { - if (this.gridOptions.minColWidth > GridOptionsWrapper_1.MIN_COL_WIDTH) { - return this.gridOptions.minColWidth; - } - var measuredMin = this.getFromTheme(null, 'headerCellMinWidth'); - return Math.max(measuredMin, GridOptionsWrapper_1.MIN_COL_WIDTH); + DragAndDropService.prototype.clearDragSourceParamsList = function () { + var _this = this; + this.dragSourceAndParamsList.forEach(function (sourceAndParams) { return _this.dragService.removeDragSource(sourceAndParams.params); }); + this.dragSourceAndParamsList.length = 0; }; - GridOptionsWrapper.prototype.getMaxColWidth = function () { - if (this.gridOptions.maxColWidth && this.gridOptions.maxColWidth > GridOptionsWrapper_1.MIN_COL_WIDTH) { - return this.gridOptions.maxColWidth; + DragAndDropService.prototype.nudge = function () { + if (this.dragging) { + this.onDragging(this.eventLastTime, true); } - return null; }; - GridOptionsWrapper.prototype.getColWidth = function () { - if (typeof this.gridOptions.colWidth !== 'number' || this.gridOptions.colWidth < GridOptionsWrapper_1.MIN_COL_WIDTH) { - return 200; + DragAndDropService.prototype.onDragStart = function (dragSource, mouseEvent) { + this.dragging = true; + this.dragSource = dragSource; + this.eventLastTime = mouseEvent; + this.dragItem = this.dragSource.getDragItem(); + this.lastDropTarget = this.dragSource.dragSourceDropTarget; + if (this.dragSource.onDragStarted) { + this.dragSource.onDragStarted(); } - return this.gridOptions.colWidth; + this.createGhost(); }; - GridOptionsWrapper.prototype.getRowBuffer = function () { - var rowBuffer = this.gridOptions.rowBuffer; - if (typeof rowBuffer === 'number') { - if (rowBuffer < 0) { - _utils__WEBPACK_IMPORTED_MODULE_10__["_"].doOnce(function () { return console.warn("ag-Grid: rowBuffer should not be negative"); }, 'warn rowBuffer negative'); - this.gridOptions.rowBuffer = rowBuffer = 0; - } - } - else { - rowBuffer = _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_BUFFER_SIZE; + DragAndDropService.prototype.onDragStop = function (mouseEvent) { + this.eventLastTime = null; + this.dragging = false; + if (this.dragSource.onDragStopped) { + this.dragSource.onDragStopped(); } - return rowBuffer; - }; - GridOptionsWrapper.prototype.getRowBufferInPixels = function () { - var rowsToBuffer = this.getRowBuffer(); - var defaultRowHeight = this.getRowHeightAsNumber(); - return rowsToBuffer * defaultRowHeight; - }; - // the user might be using some non-standard scrollbar, eg a scrollbar that has zero - // width and overlays (like the Safari scrollbar, but presented in Chrome). so we - // allow the user to provide the scroll width before we work it out. - GridOptionsWrapper.prototype.getScrollbarWidth = function () { - if (this.scrollWidth == null) { - var useGridOptions = typeof this.gridOptions.scrollbarWidth === 'number' && this.gridOptions.scrollbarWidth >= 0; - this.scrollWidth = useGridOptions ? this.gridOptions.scrollbarWidth : _utils__WEBPACK_IMPORTED_MODULE_10__["_"].getScrollbarWidth(); + if (this.lastDropTarget && this.lastDropTarget.onDragStop) { + var draggingEvent = this.createDropTargetEvent(this.lastDropTarget, mouseEvent, null, null, false); + this.lastDropTarget.onDragStop(draggingEvent); } - return this.scrollWidth; + this.lastDropTarget = null; + this.dragItem = null; + this.removeGhost(); }; - GridOptionsWrapper.prototype.checkForDeprecated = function () { + DragAndDropService.prototype.onDragging = function (mouseEvent, fromNudge) { var _this = this; - // casting to generic object, so typescript compiles even though - // we are looking for attributes that don't exist - var options = this.gridOptions; - if (options.suppressUnSort) { - console.warn('ag-grid: as of v1.12.4 suppressUnSort is not used. Please use sortingOrder instead.'); - } - if (options.suppressDescSort) { - console.warn('ag-grid: as of v1.12.4 suppressDescSort is not used. Please use sortingOrder instead.'); - } - if (options.groupAggFields) { - console.warn('ag-grid: as of v3 groupAggFields is not used. Please add appropriate agg fields to your columns.'); - } - if (options.groupHidePivotColumns) { - console.warn('ag-grid: as of v3 groupHidePivotColumns is not used as pivot columns are now called rowGroup columns. Please refer to the documentation'); - } - if (options.groupKeys) { - console.warn('ag-grid: as of v3 groupKeys is not used. You need to set rowGroupIndex on the columns to group. Please refer to the documentation'); - } - if (typeof options.groupDefaultExpanded === 'boolean') { - console.warn('ag-grid: groupDefaultExpanded can no longer be boolean. for groupDefaultExpanded=true, use groupDefaultExpanded=9999 instead, to expand all the groups'); - } - if (options.onRowDeselected || options.rowDeselected) { - console.warn('ag-grid: since version 3.4 event rowDeselected no longer exists, please check the docs'); - } - if (options.rowsAlreadyGrouped) { - console.warn('ag-grid: since version 3.4 rowsAlreadyGrouped no longer exists, please use getNodeChildDetails() instead'); - } - if (options.groupAggFunction) { - console.warn('ag-grid: since version 4.3.x groupAggFunction is now called groupRowAggNodes'); - } - if (options.checkboxSelection) { - console.warn('ag-grid: since version 8.0.x checkboxSelection is not supported as a grid option. ' + 'If you want this on all columns, use defaultColDef instead and set it there'); - } - if (options.paginationInitialRowCount) { - console.warn('ag-grid: since version 9.0.x paginationInitialRowCount is now called infiniteInitialRowCount'); - } - if (options.infinitePageSize) { - console.warn('ag-grid: since version 9.0.x infinitePageSize is now called cacheBlockSize'); - } - if (options.infiniteBlockSize) { - console.warn('ag-grid: since version 10.0.x infiniteBlockSize is now called cacheBlockSize'); - } - if (options.maxPagesInCache) { - console.warn('ag-grid: since version 10.0.x maxPagesInCache is now called maxBlocksInCache'); - } - if (options.paginationOverflowSize) { - console.warn('ag-grid: since version 10.0.x paginationOverflowSize is now called cacheOverflowSize'); - } - // if (options.forPrint) { - // console.warn('ag-grid: since version 10.1.x, use property domLayout="forPrint" instead of forPrint=true'); - // } - if (options.suppressMenuFilterPanel) { - console.warn("ag-grid: since version 11.0.x, use property colDef.menuTabs=['generalMenuTab','columnsMenuTab'] instead of suppressMenuFilterPanel=true"); - } - if (options.suppressMenuMainPanel) { - console.warn("ag-grid: since version 11.0.x, use property colDef.menuTabs=['filterMenuTab','columnsMenuTab'] instead of suppressMenuMainPanel=true"); - } - if (options.suppressMenuColumnPanel) { - console.warn("ag-grid: since version 11.0.x, use property colDef.menuTabs=['generalMenuTab','filterMenuTab'] instead of suppressMenuColumnPanel=true"); - } - if (options.suppressUseColIdForGroups) { - console.warn("ag-grid: since version 11.0.x, this is not in use anymore. You should be able to remove it from your definition"); - } - if (options.groupSuppressRow) { - console.warn("ag-grid: since version 18.2.x, 'groupSuppressRow' should not be used anymore. Instead remove row groups and perform custom sorting."); - } - if (options.groupColumnDef) { - console.warn("ag-grid: since version 11.0.x, groupColumnDef has been renamed, this property is now called autoGroupColumnDef. Please change your configuration accordingly"); - } - if (options.slaveGrids) { - console.warn("ag-grid: since version 12.x, slaveGrids has been renamed, this property is now called alignedGrids. Please change your configuration accordingly"); - } - if (options.floatingTopRowData) { - console.warn("ag-grid: since version 12.x, floatingTopRowData is now called pinnedTopRowData"); - } - if (options.floatingBottomRowData) { - console.warn("ag-grid: since version 12.x, floatingBottomRowData is now called pinnedBottomRowData"); - } - if (options.paginationStartPage) { - console.warn("ag-grid: since version 12.x, paginationStartPage is gone, please call api.paginationGoToPage(" + options.paginationStartPage + ") instead."); - } - if (options.getHeaderCellTemplate) { - console.warn("ag-grid: since version 15.x, getHeaderCellTemplate is gone, please check the header documentation on how to set header templates."); - } - if (options.headerCellTemplate) { - console.warn("ag-grid: since version 15.x, headerCellTemplate is gone, please check the header documentation on how to set header templates."); - } - if (options.headerCellRenderer) { - console.warn("ag-grid: since version 15.x, headerCellRenderer is gone, please check the header documentation on how to set header templates."); - } - if (options.angularCompileHeaders) { - console.warn("ag-grid: since version 15.x, angularCompileHeaders is gone, please see the getting started for Angular 1 docs to see how to do headers in Angular 1.x."); - } - if (options.pivotTotals) { - console.warn("ag-grid: since version 18.x, pivotTotals has been removed, instead if using pivotTotals, set pivotColumnGroupTotals='before'|'after'."); - options.pivotColumnGroupTotals = 'before'; + var hDirection = this.getHorizontalDirection(mouseEvent); + var vDirection = this.getVerticalDirection(mouseEvent); + this.eventLastTime = mouseEvent; + this.positionGhost(mouseEvent); + // check if mouseEvent intersects with any of the drop targets + var validDropTargets = this.dropTargets.filter(function (target) { return _this.isMouseOnDropTarget(mouseEvent, target); }); + var len = validDropTargets.length; + var dropTarget = null; + if (len > 0) { + dropTarget = len === 1 + ? validDropTargets[0] + // the current mouse position could intersect with more than 1 element + // if they are nested. In that case we need to get the most specific + // container, which is the one that does not contain any other targets. + : validDropTargets.reduce(function (prevTarget, currTarget) { + if (!prevTarget) { + return currTarget; + } + var prevContainer = prevTarget.getContainer(); + var currContainer = currTarget.getContainer(); + if (prevContainer.contains(currContainer)) { + return currTarget; + } + return prevTarget; + }); } - if (options.rowModelType === 'inMemory') { - console.warn("ag-grid: since version 18.x, The In Memory Row Model has been renamed to the Client Side Row Model, set rowModelType='clientSide' instead."); - options.rowModelType = 'clientSide'; + if (dropTarget !== this.lastDropTarget) { + this.leaveLastTargetIfExists(mouseEvent, hDirection, vDirection, fromNudge); + this.enterDragTargetIfExists(dropTarget, mouseEvent, hDirection, vDirection, fromNudge); + this.lastDropTarget = dropTarget; } - if (options.rowModelType === 'enterprise') { - console.warn("ag-grid: since version 18.x, The Enterprise Row Model has been renamed to the Server Side Row Model, set rowModelType='serverSide' instead."); - options.rowModelType = 'serverSide'; + else if (dropTarget && dropTarget.onDragging) { + var draggingEvent = this.createDropTargetEvent(dropTarget, mouseEvent, hDirection, vDirection, fromNudge); + dropTarget.onDragging(draggingEvent); } - if (options.layoutInterval) { - console.warn("ag-grid: since version 18.x, layoutInterval is no longer a property. This is because the grid now uses CSS Flex for layout."); + }; + DragAndDropService.prototype.enterDragTargetIfExists = function (dropTarget, mouseEvent, hDirection, vDirection, fromNudge) { + if (!dropTarget) { + return; } - if (options.gridAutoHeight) { - console.warn("ag-grid: since version 19.x, gridAutoHeight is gone, please use domLayout=autoHeight instead"); - options.domLayout = 'autoHeight'; + if (dropTarget.onDragEnter) { + var dragEnterEvent = this.createDropTargetEvent(dropTarget, mouseEvent, hDirection, vDirection, fromNudge); + dropTarget.onDragEnter(dragEnterEvent); } - if (options.showToolPanel === true) { - console.warn("ag-grid: since version 19.x, showToolPanel is gone, please specify toolPanel components. See https://www.ag-grid.com/javascript-grid-tool-panel/"); - options.showToolPanel = undefined; - options.sideBar = options.sideBar || true; + this.setGhostIcon(dropTarget.getIconName ? dropTarget.getIconName() : null); + }; + DragAndDropService.prototype.leaveLastTargetIfExists = function (mouseEvent, hDirection, vDirection, fromNudge) { + if (!this.lastDropTarget) { + return; } - if (options.showToolPanel === false) { - console.warn("ag-grid: since version 19.x, showToolPanel is gone, please specify toolPanel components. See https://www.ag-grid.com/javascript-grid-tool-panel/"); - options.showToolPanel = undefined; - options.sideBar = options.sideBar || false; + if (this.lastDropTarget.onDragLeave) { + var dragLeaveEvent = this.createDropTargetEvent(this.lastDropTarget, mouseEvent, hDirection, vDirection, fromNudge); + this.lastDropTarget.onDragLeave(dragLeaveEvent); } - var oldToolPanelProperties = { - toolPanelSuppressRowGroups: 'suppressRowGroups', - toolPanelSuppressValues: 'suppressValues', - toolPanelSuppressPivots: 'suppressPivots', - toolPanelSuppressPivotMode: 'suppressPivotMode', - toolPanelSuppressColumnFilter: 'suppressColumnFilter', - toolPanelSuppressColumnSelectAll: 'suppressColumnSelectAll', - toolPanelSuppressSideButtons: 'suppressSideButtons', - toolPanelSuppressColumnExpandAll: 'suppressColumnExpandAll', - contractColumnSelection: 'contractColumnSelection' - }; - var toolPanelColumnsCompProps = {}; - Object.keys(oldToolPanelProperties).forEach(function (key) { - var translation = oldToolPanelProperties[key]; - var value = _this.gridOptions[key]; - if (value !== undefined) { - if (key === 'toolPanelSuppressSideButtons') { - console.warn('ag-grid: since v19.0 toolPanelSuppressSideButtons has been completely removed. See https://www.ag-grid.com/javascript-grid-tool-panel/'); - return; + this.setGhostIcon(null); + }; + DragAndDropService.prototype.getAllContainersFromDropTarget = function (dropTarget) { + var secondaryContainers = dropTarget.getSecondaryContainers ? dropTarget.getSecondaryContainers() : null; + var containers = [[dropTarget.getContainer()]]; + return secondaryContainers ? containers.concat(secondaryContainers) : containers; + }; + DragAndDropService.prototype.allContainersIntersect = function (mouseEvent, containers) { + var e_1, _a; + try { + for (var containers_1 = __values(containers), containers_1_1 = containers_1.next(); !containers_1_1.done; containers_1_1 = containers_1.next()) { + var container = containers_1_1.value; + var rect = container.getBoundingClientRect(); + // if element is not visible, then width and height are zero + if (rect.width === 0 || rect.height === 0) { + return false; + } + var horizontalFit = mouseEvent.clientX >= rect.left && mouseEvent.clientX < rect.right; + var verticalFit = mouseEvent.clientY >= rect.top && mouseEvent.clientY < rect.bottom; + if (!horizontalFit || !verticalFit) { + return false; } - console.warn("ag-grid: since v19.0 gridOptions." + key + " is deprecated, please use gridOptions.sideBar.toolPanel[columnsIndex].componentParams." + translation); - toolPanelColumnsCompProps[translation] = value; } - }); - if (Object.keys(toolPanelColumnsCompProps).length > 0 && !_utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(options.sideBar)) { - console.warn("ag-grid: since version 19.x, sideBar is mandatory if using toolPanel related properties. See https://www.ag-grid.com/javascript-grid-tool-panel/"); - options.sideBar = true; } - if (options.sideBar != null) { - options.sideBar = _entities_sideBar__WEBPACK_IMPORTED_MODULE_7__["SideBarDefParser"].parse(options.sideBar); - } - var sideBarDef = this.gridOptions.sideBar; - if (Object.keys(toolPanelColumnsCompProps).length > 0 && sideBarDef && sideBarDef.toolPanels) { - var columnsDef = sideBarDef.toolPanels.filter(function (it) { return it.id === 'columns'; }); - if (columnsDef.length === 1) { - _utils__WEBPACK_IMPORTED_MODULE_10__["_"].mergeDeep(columnsDef[0], { - componentParams: toolPanelColumnsCompProps - }); + catch (e_1_1) { e_1 = { error: e_1_1 }; } + finally { + try { + if (containers_1_1 && !containers_1_1.done && (_a = containers_1.return)) _a.call(containers_1); } + finally { if (e_1) throw e_1.error; } } - if (options.enableStatusBar) { - console.warn("ag-grid: since version 19.x, enableStatusBar is gone, please specify statusBar components"); - options.statusBar = options.statusBar || { - components: [{ component: 'agAggregationComponent' }] - }; - } - if (options.alwaysShowStatusBar) { - console.warn("ag-grid: since version 19.x, alwaysShowStatusBar is gone. Please specify a min-height on the ag-status-bar css class, eg .ag-status-bar {min-height: 35px; }"); - } - if (options.enableServerSideSorting || options.enableSorting) { - console.warn("ag-Grid: since v20, grid options enableSorting and enableServerSideSorting are gone. Instead set sortable=true on the column definition for the columns sorting are allowed on. To migrate from gridOption.enableSorting=true, set gridOptions.defaultColDef.sortable=true"); - if (!options.defaultColDef) { - options.defaultColDef = {}; - } - if (!options.defaultColDef.sortable) { - options.defaultColDef.sortable = true; + return true; + }; + // checks if the mouse is on the drop target. it checks eContainer and eSecondaryContainers + DragAndDropService.prototype.isMouseOnDropTarget = function (mouseEvent, dropTarget) { + var e_2, _a; + var allContainersFromDropTarget = this.getAllContainersFromDropTarget(dropTarget); + var mouseOverTarget = false; + try { + for (var allContainersFromDropTarget_1 = __values(allContainersFromDropTarget), allContainersFromDropTarget_1_1 = allContainersFromDropTarget_1.next(); !allContainersFromDropTarget_1_1.done; allContainersFromDropTarget_1_1 = allContainersFromDropTarget_1.next()) { + var currentContainers = allContainersFromDropTarget_1_1.value; + if (this.allContainersIntersect(mouseEvent, currentContainers)) { + mouseOverTarget = true; + break; + } } } - if (options.enableFilter || options.enableServerSideFilter) { - console.warn("ag-Grid: since v20, grid options enableFilter and enableServerSideFilter are gone. Instead set filter=true (if not already specifying a specific filter) on the column definition for the columns filtering is allowed on. To migrate from gridOptions.enableFilter=true, set gridOptions.defaultColDef.filter=true. If you are explicitly setting specific filters for each column (ie colDef.filter is already set) the you don't need to do anything."); - if (!options.defaultColDef) { - options.defaultColDef = {}; - } - if (!options.defaultColDef.filter) { - options.defaultColDef.filter = true; + catch (e_2_1) { e_2 = { error: e_2_1 }; } + finally { + try { + if (allContainersFromDropTarget_1_1 && !allContainersFromDropTarget_1_1.done && (_a = allContainersFromDropTarget_1.return)) _a.call(allContainersFromDropTarget_1); } + finally { if (e_2) throw e_2.error; } } - if (options.enableColResize) { - console.warn("ag-Grid: since v20, grid options enableColResize is gone. Instead set resizable=true on the column definition for the columns resizing are allowed on. To migrate from gridOption.enableColResize=true, set gridOptions.defaultColDef.resizable=true"); - if (!options.defaultColDef) { - options.defaultColDef = {}; - } - if (!options.defaultColDef.resizable) { - options.defaultColDef.resizable = true; - } + return mouseOverTarget && dropTarget.isInterestedIn(this.dragSource.type); + }; + DragAndDropService.prototype.addDropTarget = function (dropTarget) { + this.dropTargets.push(dropTarget); + }; + DragAndDropService.prototype.removeDropTarget = function (dropTarget) { + this.dropTargets = this.dropTargets.filter(function (target) { return target.getContainer() !== dropTarget.getContainer(); }); + }; + DragAndDropService.prototype.hasExternalDropZones = function () { + return this.dropTargets.some(function (zones) { return zones.external; }); + }; + DragAndDropService.prototype.findExternalZone = function (params) { + var externalTargets = this.dropTargets.filter(function (target) { return target.external; }); + return externalTargets.find(function (zone) { return zone.getContainer() === params.getContainer(); }) || null; + }; + DragAndDropService.prototype.getHorizontalDirection = function (event) { + var clientX = this.eventLastTime && this.eventLastTime.clientX; + var eClientX = event.clientX; + if (clientX === eClientX) { + return null; } - if (options.deprecatedEmbedFullWidthRows) { - console.warn("ag-Grid: since v21.2, deprecatedEmbedFullWidthRows has been replaced with embedFullWidthRows."); + return clientX > eClientX ? HorizontalDirection.Left : HorizontalDirection.Right; + }; + DragAndDropService.prototype.getVerticalDirection = function (event) { + var clientY = this.eventLastTime && this.eventLastTime.clientY; + var eClientY = event.clientY; + if (clientY === eClientY) { + return null; } - if (options.suppressTabbing) { - console.warn("ag-Grid: since v20.1, suppressTabbing is replaced with the more powerful grid callback suppressKeyboardEvent(params) which can suppress any keyboard event including tabbing."); + return clientY > eClientY ? VerticalDirection.Up : VerticalDirection.Down; + }; + DragAndDropService.prototype.createDropTargetEvent = function (dropTarget, event, hDirection, vDirection, fromNudge) { + // localise x and y to the target + var dropZoneTarget = dropTarget.getContainer(); + var rect = dropZoneTarget.getBoundingClientRect(); + var _a = this, api = _a.gridApi, columnApi = _a.columnApi, dragItem = _a.dragItem, dragSource = _a.dragSource; + var x = event.clientX - rect.left; + var y = event.clientY - rect.top; + return { event: event, x: x, y: y, vDirection: vDirection, hDirection: hDirection, dragSource: dragSource, fromNudge: fromNudge, dragItem: dragItem, api: api, columnApi: columnApi, dropZoneTarget: dropZoneTarget }; + }; + DragAndDropService.prototype.positionGhost = function (event) { + var ghost = this.eGhost; + if (!ghost) { + return; } - if (options.doesDataFlower) { - console.warn('ag-Grid: since v21.1, doesDataFlower is deprecated. Master/Detail is the new way for showing child data for a row and was introduced over a year ago. Please migrate your code to use master/detail instead.'); + var ghostRect = ghost.getBoundingClientRect(); + var ghostHeight = ghostRect.height; + // for some reason, without the '-2', it still overlapped by 1 or 2 pixels, which + // then brought in scrollbars to the browser. no idea why, but putting in -2 here + // works around it which is good enough for me. + var browserWidth = Object(_utils_browser__WEBPACK_IMPORTED_MODULE_5__["getBodyWidth"])() - 2; + var browserHeight = Object(_utils_browser__WEBPACK_IMPORTED_MODULE_5__["getBodyHeight"])() - 2; + var top = event.pageY - (ghostHeight / 2); + var left = event.pageX - 10; + var eDocument = this.gridOptionsWrapper.getDocument(); + var win = (eDocument.defaultView || window); + var windowScrollY = win.pageYOffset || eDocument.documentElement.scrollTop; + var windowScrollX = win.pageXOffset || eDocument.documentElement.scrollLeft; + // check ghost is not positioned outside of the browser + if (browserWidth > 0 && ((left + ghost.clientWidth) > (browserWidth + windowScrollX))) { + left = browserWidth + windowScrollX - ghost.clientWidth; } - if (options.enableOldSetFilterModel) { - console.warn('ag-Grid: since v22.x, enableOldSetFilterModel is deprecated. Please move to the new Set Filter Model as the old one may not be supported in v23 onwards.'); + if (left < 0) { + left = 0; } - if (options.floatingFilter) { - console.warn('ag-Grid: since v23.1, floatingFilter on the gridOptions is deprecated. Please use floatingFilter on the colDef instead.'); - if (!options.defaultColDef) { - options.defaultColDef = {}; - } - if (options.defaultColDef.floatingFilter == null) { - options.defaultColDef.floatingFilter = true; - } + if (browserHeight > 0 && ((top + ghost.clientHeight) > (browserHeight + windowScrollY))) { + top = browserHeight + windowScrollY - ghost.clientHeight; } - var checkRenamedProperty = function (oldProp, newProp, version) { - if (options[oldProp] != null) { - console.warn("ag-grid: since version " + version + ", '" + oldProp + "' is deprecated / renamed, please use the new property name '" + newProp + "' instead."); - if (options[newProp] == null) { - options[newProp] = options[oldProp]; - } - } - }; - checkRenamedProperty('batchUpdateWaitMillis', 'asyncTransactionWaitMillis', '23.1.x'); - checkRenamedProperty('deltaRowDataMode', 'immutableData', '23.1.x'); - checkRenamedProperty('deltaColumnMode', 'immutableColumns', '23.1.x'); - }; - GridOptionsWrapper.prototype.checkForViolations = function () { - if (this.isTreeData()) { - this.treeDataViolations(); + if (top < 0) { + top = 0; } + ghost.style.left = left + "px"; + ghost.style.top = top + "px"; }; - GridOptionsWrapper.prototype.treeDataViolations = function () { - if (this.isRowModelDefault()) { - if (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].missing(this.getDataPathFunc())) { - console.warn('ag-Grid: property usingTreeData=true with rowModel=clientSide, but you did not ' + - 'provide getDataPath function, please provide getDataPath function if using tree data.'); - } - } - if (this.isRowModelServerSide()) { - if (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].missing(this.getIsServerSideGroupFunc())) { - console.warn('ag-Grid: property usingTreeData=true with rowModel=serverSide, but you did not ' + - 'provide isServerSideGroup function, please provide isServerSideGroup function if using tree data.'); - } - if (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].missing(this.getServerSideGroupKeyFunc())) { - console.warn('ag-Grid: property usingTreeData=true with rowModel=serverSide, but you did not ' + - 'provide getServerSideGroupKey function, please provide getServerSideGroupKey function if using tree data.'); - } + DragAndDropService.prototype.removeGhost = function () { + if (this.eGhost && this.eGhostParent) { + this.eGhostParent.removeChild(this.eGhost); } + this.eGhost = null; }; - GridOptionsWrapper.prototype.getLocaleTextFunc = function () { - if (this.gridOptions.localeTextFunc) { - return this.gridOptions.localeTextFunc; + DragAndDropService.prototype.createGhost = function () { + this.eGhost = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["loadTemplate"])(DragAndDropService_1.GHOST_TEMPLATE); + var theme = this.environment.getTheme().theme; + if (theme) { + this.eGhost.classList.add(theme); } - var localeText = this.gridOptions.localeText; - return function (key, defaultValue) { - return localeText && localeText[key] ? localeText[key] : defaultValue; - }; - }; - // responsible for calling the onXXX functions on gridOptions - GridOptionsWrapper.prototype.globalEventHandler = function (eventName, event) { - var callbackMethodName = _components_componentUtil__WEBPACK_IMPORTED_MODULE_2__["ComponentUtil"].getCallbackForEvent(eventName); - if (typeof this.gridOptions[callbackMethodName] === 'function') { - this.gridOptions[callbackMethodName](event); + this.eGhostIcon = this.eGhost.querySelector('.ag-dnd-ghost-icon'); + this.setGhostIcon(null); + var eText = this.eGhost.querySelector('.ag-dnd-ghost-label'); + var dragItemName = this.dragSource.dragItemName; + if (Object(_utils_function__WEBPACK_IMPORTED_MODULE_7__["isFunction"])(dragItemName)) { + dragItemName = dragItemName(); } - }; - // we don't allow dynamic row height for virtual paging - GridOptionsWrapper.prototype.getRowHeightAsNumber = function () { - if (!this.gridOptions.rowHeight || _utils__WEBPACK_IMPORTED_MODULE_10__["_"].missing(this.gridOptions.rowHeight)) { - return this.getDefaultRowHeight(); + eText.innerHTML = Object(_utils_string__WEBPACK_IMPORTED_MODULE_2__["escapeString"])(dragItemName) || ''; + this.eGhost.style.height = '25px'; + this.eGhost.style.top = '20px'; + this.eGhost.style.left = '20px'; + var eDocument = this.gridOptionsWrapper.getDocument(); + var targetEl = null; + try { + targetEl = eDocument.fullscreenElement; } - else if (this.gridOptions.rowHeight && this.isNumeric(this.gridOptions.rowHeight)) { - return this.gridOptions.rowHeight; + catch (e) { + // some environments like SalesForce will throw errors + // simply by trying to read the fullscreenElement property } - console.warn('ag-Grid row height must be a number if not using standard row model'); - return this.getDefaultRowHeight(); - }; - GridOptionsWrapper.prototype.getRowHeightForNode = function (rowNode, allowEstimate) { - // check the function first, in case use set both function and - // number, when using virtual pagination then function can be - // used for pinned rows and the number for the body rows. - if (allowEstimate === void 0) { allowEstimate = false; } - if (typeof this.gridOptions.getRowHeight === 'function') { - if (allowEstimate) { - return { height: this.getDefaultRowHeight(), estimated: true }; - } - var params = { - node: rowNode, - data: rowNode.data, - api: this.gridOptions.api, - context: this.gridOptions.context - }; - var height = this.gridOptions.getRowHeight(params); - if (height != null) { - return { height: height, estimated: false }; + finally { + if (!targetEl) { + targetEl = eDocument.querySelector('body'); } } - if (rowNode.detail && this.isMasterDetail()) { - if (this.isNumeric(this.gridOptions.detailRowHeight)) { - return { height: this.gridOptions.detailRowHeight, estimated: false }; - } - return { height: DEFAULT_DETAIL_ROW_HEIGHT, estimated: false }; + this.eGhostParent = targetEl; + if (!this.eGhostParent) { + console.warn('AG Grid: could not find document body, it is needed for dragging columns'); } - var defaultRowHeight = this.getDefaultRowHeight(); - var rowHeight = this.gridOptions.rowHeight && this.isNumeric(this.gridOptions.rowHeight) ? this.gridOptions.rowHeight : defaultRowHeight; - var minRowHeight = Math.min(defaultRowHeight, rowHeight); - if (this.columnController.isAutoRowHeightActive()) { - if (allowEstimate) { - return { height: rowHeight, estimated: true }; - } - var autoHeight = this.autoHeightCalculator.getPreferredHeightForRow(rowNode); - // never return less than the default row height - covers when auto height - // cells are blank. - return { height: Math.max(autoHeight, minRowHeight), estimated: false }; + else { + this.eGhostParent.appendChild(this.eGhost); } - return { height: rowHeight, estimated: false }; - }; - GridOptionsWrapper.prototype.isDynamicRowHeight = function () { - return typeof this.gridOptions.getRowHeight === 'function'; - }; - GridOptionsWrapper.prototype.getListItemHeight = function () { - return this.getFromTheme(20, 'listItemHeight'); - }; - GridOptionsWrapper.prototype.chartMenuPanelWidth = function () { - return this.environment.chartMenuPanelWidth(); - }; - GridOptionsWrapper.prototype.isNumeric = function (value) { - return !isNaN(value) && typeof value === 'number'; }; - // Material data table has strict guidelines about whitespace, and these values are different than the ones - // ag-grid uses by default. We override the default ones for the sake of making it better out of the box - GridOptionsWrapper.prototype.getFromTheme = function (defaultValue, sassVariableName) { - var theme = this.environment.getTheme().theme; - if (theme && theme.indexOf('ag-theme') === 0) { - return this.environment.getSassVariable(theme, sassVariableName); + DragAndDropService.prototype.setGhostIcon = function (iconName, shake) { + if (shake === void 0) { shake = false; } + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["clearElement"])(this.eGhostIcon); + var eIcon = null; + if (!iconName) { + iconName = this.dragSource.defaultIconName || DragAndDropService_1.ICON_NOT_ALLOWED; + } + switch (iconName) { + case DragAndDropService_1.ICON_PINNED: + eIcon = this.ePinnedIcon; + break; + case DragAndDropService_1.ICON_MOVE: + eIcon = this.eMoveIcon; + break; + case DragAndDropService_1.ICON_LEFT: + eIcon = this.eLeftIcon; + break; + case DragAndDropService_1.ICON_RIGHT: + eIcon = this.eRightIcon; + break; + case DragAndDropService_1.ICON_GROUP: + eIcon = this.eGroupIcon; + break; + case DragAndDropService_1.ICON_AGGREGATE: + eIcon = this.eAggregateIcon; + break; + case DragAndDropService_1.ICON_PIVOT: + eIcon = this.ePivotIcon; + break; + case DragAndDropService_1.ICON_NOT_ALLOWED: + eIcon = this.eDropNotAllowedIcon; + break; + case DragAndDropService_1.ICON_HIDE: + eIcon = this.eHideIcon; + break; + } + this.eGhostIcon.classList.toggle('ag-shake-left-to-right', shake); + if (eIcon === this.eHideIcon && this.gridOptionsWrapper.isSuppressDragLeaveHidesColumns()) { + return; + } + if (eIcon) { + this.eGhostIcon.appendChild(eIcon); } - return defaultValue; - }; - GridOptionsWrapper.prototype.getDefaultRowHeight = function () { - return this.getFromTheme(DEFAULT_ROW_HEIGHT, 'rowHeight'); }; - var GridOptionsWrapper_1; - GridOptionsWrapper.MIN_COL_WIDTH = 10; - GridOptionsWrapper.PROP_HEADER_HEIGHT = 'headerHeight'; - GridOptionsWrapper.PROP_GROUP_REMOVE_SINGLE_CHILDREN = 'groupRemoveSingleChildren'; - GridOptionsWrapper.PROP_GROUP_REMOVE_LOWEST_SINGLE_CHILDREN = 'groupRemoveLowestSingleChildren'; - GridOptionsWrapper.PROP_PIVOT_HEADER_HEIGHT = 'pivotHeaderHeight'; - GridOptionsWrapper.PROP_SUPPRESS_CLIPBOARD_PASTE = 'suppressClipboardPaste'; - GridOptionsWrapper.PROP_GROUP_HEADER_HEIGHT = 'groupHeaderHeight'; - GridOptionsWrapper.PROP_PIVOT_GROUP_HEADER_HEIGHT = 'pivotGroupHeaderHeight'; - GridOptionsWrapper.PROP_FLOATING_FILTERS_HEIGHT = 'floatingFiltersHeight'; - GridOptionsWrapper.PROP_SUPPRESS_ROW_CLICK_SELECTION = 'suppressRowClickSelection'; - GridOptionsWrapper.PROP_SUPPRESS_ROW_DRAG = 'suppressRowDrag'; - GridOptionsWrapper.PROP_SUPPRESS_MOVE_WHEN_ROW_DRAG = 'suppressMoveWhenRowDragging'; - GridOptionsWrapper.PROP_POPUP_PARENT = 'popupParent'; - GridOptionsWrapper.PROP_DOM_LAYOUT = 'domLayout'; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('gridOptions') - ], GridOptionsWrapper.prototype, "gridOptions", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('columnController') - ], GridOptionsWrapper.prototype, "columnController", void 0); + var DragAndDropService_1; + DragAndDropService.ICON_PINNED = 'pinned'; + DragAndDropService.ICON_MOVE = 'move'; + DragAndDropService.ICON_LEFT = 'left'; + DragAndDropService.ICON_RIGHT = 'right'; + DragAndDropService.ICON_GROUP = 'group'; + DragAndDropService.ICON_AGGREGATE = 'aggregate'; + DragAndDropService.ICON_PIVOT = 'pivot'; + DragAndDropService.ICON_NOT_ALLOWED = 'notAllowed'; + DragAndDropService.ICON_HIDE = 'hide'; + DragAndDropService.GHOST_TEMPLATE = "
\n \n
\n
"; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('eventService') - ], GridOptionsWrapper.prototype, "eventService", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('dragService') + ], DragAndDropService.prototype, "dragService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('environment') - ], GridOptionsWrapper.prototype, "environment", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('environment') + ], DragAndDropService.prototype, "environment", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('autoHeightCalculator') - ], GridOptionsWrapper.prototype, "autoHeightCalculator", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnApi') + ], DragAndDropService.prototype, "columnApi", void 0); __decorate([ - __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Qualifier"])('gridApi')), __param(1, Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Qualifier"])('columnApi')) - ], GridOptionsWrapper.prototype, "agWire", null); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridApi') + ], DragAndDropService.prototype, "gridApi", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_3__["PreDestroy"] - ], GridOptionsWrapper.prototype, "destroy", null); + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], DragAndDropService.prototype, "init", null); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"] - ], GridOptionsWrapper.prototype, "init", null); - GridOptionsWrapper = GridOptionsWrapper_1 = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Bean"])('gridOptionsWrapper') - ], GridOptionsWrapper); - return GridOptionsWrapper; -}()); + _context_context__WEBPACK_IMPORTED_MODULE_1__["PreDestroy"] + ], DragAndDropService.prototype, "clearDragSourceParamsList", null); + DragAndDropService = DragAndDropService_1 = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('dragAndDropService') + ], DragAndDropService); + return DragAndDropService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 51 */ +/* 98 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColDefUtil", function() { return ColDefUtil; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LoadingCellRenderer", function() { return LoadingCellRenderer; }); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); +/* harmony import */ var _utils_icon__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(48); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var __spreadArrays = (undefined && undefined.__spreadArrays) || function () { - for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; - for (var r = Array(s), k = 0, i = 0; i < il; i++) - for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) - r[k] = a[j]; - return r; +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; }; -var ColDefUtil = /** @class */ (function () { - function ColDefUtil() { + + + +var LoadingCellRenderer = /** @class */ (function (_super) { + __extends(LoadingCellRenderer, _super); + function LoadingCellRenderer() { + return _super.call(this, LoadingCellRenderer.TEMPLATE) || this; } - ColDefUtil.STRING_PROPERTIES = [ - 'headerName', - 'columnGroupShow', - 'headerClass', - 'toolPanelClass', - 'headerValueGetter', - 'pivotKeys', - 'groupId', - 'colId', - 'sort', - 'field', - 'type', - 'tooltipComponent', - 'tooltipField', - 'headerTooltip', - 'cellClass', - 'showRowGroup', - 'template', - 'templateUrl', - 'filter', - 'aggFunc', - 'cellRenderer', - 'cellEditor', - 'pinned', - 'chartDataType' - ]; - ColDefUtil.OBJECT_PROPERTIES = [ - 'headerGroupComponent', - 'headerGroupComponentFramework', - 'headerGroupComponentParams', - 'cellStyle', - 'cellRendererParams', - 'cellEditorFramework', - 'cellEditorParams', - 'pinnedRowCellRendererFramework', - 'pinnedRowCellRendererParams', - 'filterFramework', - 'filterParams', - 'pivotValueColumn', - 'headerComponent', - 'headerComponentFramework', - 'headerComponentParams', - 'floatingFilterComponent', - 'floatingFilterComponentParams', - 'floatingFilterComponentFramework', - 'tooltipComponent', - 'tooltipComponentParams', - 'tooltipComponentFramework', - 'refData' - ]; - ColDefUtil.ARRAY_PROPERTIES = [ - 'children', - 'sortingOrder', - 'allowedAggFuncs', - 'menuTabs', - 'pivotTotalColumnIds', - 'cellClassRules', - 'icons' - ]; - ColDefUtil.NUMBER_PROPERTIES = [ - 'sortedAt', - 'flex', - 'width', - 'minWidth', - 'maxWidth', - 'rowGroupIndex', - 'pivotIndex' - ]; - ColDefUtil.BOOLEAN_PROPERTIES = [ - 'suppressCellFlash', - 'suppressColumnsToolPanel', - 'suppressFiltersToolPanel', - 'openByDefault', - 'marryChildren', - 'hide', - 'rowGroup', - 'pivot', - 'checkboxSelection', - 'headerCheckboxSelection', - 'headerCheckboxSelectionFilteredOnly', - 'suppressMenu', - 'suppressSorting', - 'suppressMovable', - 'suppressFilter', - 'lockPosition', - 'lockVisible', - 'lockPinned', - 'unSortIcon', - 'suppressSizeToFit', - 'suppressResize', - 'suppressAutoSize', - 'enableRowGroup', - 'enablePivot', - 'enableValue', - 'editable', - 'suppressPaste', - 'suppressNavigable', - 'enableCellChangeFlash', - 'rowDrag', - 'dndSource', - 'autoHeight', - 'sortable', - 'resizable', - 'singleClickEdit', - 'floatingFilter', - ]; - ColDefUtil.FUNCTION_PROPERTIES = [ - 'dndSourceOnRowDrag', - 'valueGetter', - 'valueSetter', - 'filterValueGetter', - 'keyCreator', - 'cellRenderer', - 'cellRendererFramework', - 'pinnedRowCellRenderer', - 'valueFormatter', - 'pinnedRowValueFormatter', - 'valueParser', - 'comparator', - 'equals', - 'pivotComparator', - 'suppressKeyboardEvent', - 'colSpan', - 'rowSpan', - 'getQuickFilterText', - 'newValueHandler', - 'onCellValueChanged', - 'onCellClicked', - 'onCellDoubleClicked', - 'onCellContextMenu', - 'rowDragText', - 'tooltip', - 'tooltipValueGetter', - 'tooltipComponent', - 'tooltipComponentFramework', - 'cellRendererSelector', - 'cellEditorSelector' - ]; - ColDefUtil.ALL_PROPERTIES = __spreadArrays(ColDefUtil.ARRAY_PROPERTIES, ColDefUtil.OBJECT_PROPERTIES, ColDefUtil.STRING_PROPERTIES, ColDefUtil.NUMBER_PROPERTIES, ColDefUtil.FUNCTION_PROPERTIES, ColDefUtil.BOOLEAN_PROPERTIES); - // used when doing property checks - this causes noise when using frameworks which can add their own fw specific - // properties to colDefs, gridOptions etc - ColDefUtil.FRAMEWORK_PROPERTIES = ['__ob__', '__metadata__', 'mappedColumnProperties', 'hasChildColumns', - 'toColDef', 'createColDefFromGridColumn']; - return ColDefUtil; -}()); + LoadingCellRenderer.prototype.init = function (params) { + params.node.failedLoad ? this.setupFailed() : this.setupLoading(); + }; + LoadingCellRenderer.prototype.setupFailed = function () { + this.eLoadingText.innerText = 'ERR'; + }; + LoadingCellRenderer.prototype.setupLoading = function () { + var eLoadingIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_2__["createIconNoSpan"])('groupLoading', this.gridOptionsWrapper, null); + if (eLoadingIcon) { + this.eLoadingIcon.appendChild(eLoadingIcon); + } + var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc(); + this.eLoadingText.innerText = localeTextFunc('loadingOoo', 'Loading'); + }; + LoadingCellRenderer.prototype.refresh = function (params) { + return false; + }; + // this is a user component, and IComponent has "public destroy()" as part of the interface. + // so we need to override destroy() just to make the method public. + LoadingCellRenderer.prototype.destroy = function () { + _super.prototype.destroy.call(this); + }; + LoadingCellRenderer.TEMPLATE = "
\n \n \n
"; + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eLoadingIcon') + ], LoadingCellRenderer.prototype, "eLoadingIcon", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eLoadingText') + ], LoadingCellRenderer.prototype, "eLoadingText", void 0); + return LoadingCellRenderer; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); /***/ }), -/* 52 */ +/* 99 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SideBarDefParser", function() { return SideBarDefParser; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LoadingOverlayComponent", function() { return LoadingOverlayComponent; }); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var SideBarDefParser = /** @class */ (function () { - function SideBarDefParser() { - } - SideBarDefParser.parse = function (toParse) { - if (!toParse) { - return null; - } - if (toParse === true) { - return { - toolPanels: [ - SideBarDefParser.DEFAULT_COLUMN_COMP, - SideBarDefParser.DEFAULT_FILTER_COMP, - ], - defaultToolPanel: 'columns' - }; - } - if (typeof toParse === 'string') { - return SideBarDefParser.parse([toParse]); - } - if (Array.isArray(toParse)) { - var comps_1 = []; - toParse.forEach(function (key) { - var lookupResult = SideBarDefParser.DEFAULT_BY_KEY[key]; - if (!lookupResult) { - console.warn("ag-grid: the key " + key + " is not a valid key for specifying a tool panel, valid keys are: " + Object.keys(SideBarDefParser.DEFAULT_BY_KEY).join(',')); - return; - } - comps_1.push(lookupResult); - }); - if (comps_1.length === 0) { - return null; - } - return { - toolPanels: comps_1, - defaultToolPanel: comps_1[0].id - }; - } - var result = { - toolPanels: SideBarDefParser.parseComponents(toParse.toolPanels), - defaultToolPanel: toParse.defaultToolPanel, - hiddenByDefault: toParse.hiddenByDefault, - position: toParse.position - }; - return result; - }; - SideBarDefParser.parseComponents = function (from) { - var result = []; - from.forEach(function (it) { - var toAdd = null; - if (typeof it === 'string') { - var lookupResult = SideBarDefParser.DEFAULT_BY_KEY[it]; - if (!lookupResult) { - console.warn("ag-grid: the key " + it + " is not a valid key for specifying a tool panel, valid keys are: " + Object.keys(SideBarDefParser.DEFAULT_BY_KEY).join(',')); - return; - } - toAdd = lookupResult; - } - else { - toAdd = it; - } - result.push(toAdd); - }); - return result; +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - SideBarDefParser.DEFAULT_COLUMN_COMP = { - id: 'columns', - labelDefault: 'Columns', - labelKey: 'columns', - iconKey: 'columns', - toolPanel: 'agColumnsToolPanel', + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - SideBarDefParser.DEFAULT_FILTER_COMP = { - id: 'filters', - labelDefault: 'Filters', - labelKey: 'filters', - iconKey: 'filter', - toolPanel: 'agFiltersToolPanel', +})(); + +var LoadingOverlayComponent = /** @class */ (function (_super) { + __extends(LoadingOverlayComponent, _super); + function LoadingOverlayComponent() { + return _super.call(this) || this; + } + // this is a user component, and IComponent has "public destroy()" as part of the interface. + // so we need to override destroy() just to make the method public. + LoadingOverlayComponent.prototype.destroy = function () { + _super.prototype.destroy.call(this); }; - SideBarDefParser.DEFAULT_BY_KEY = { - columns: SideBarDefParser.DEFAULT_COLUMN_COMP, - filters: SideBarDefParser.DEFAULT_FILTER_COMP + LoadingOverlayComponent.prototype.init = function (params) { + var template = this.gridOptionsWrapper.getOverlayLoadingTemplate() ? + this.gridOptionsWrapper.getOverlayLoadingTemplate() : LoadingOverlayComponent.DEFAULT_LOADING_OVERLAY_TEMPLATE; + var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc(); + var localisedTemplate = template.replace('[LOADING...]', localeTextFunc('loadingOoo', 'Loading...')); + this.setTemplate(localisedTemplate); }; - return SideBarDefParser; -}()); + LoadingOverlayComponent.DEFAULT_LOADING_OVERLAY_TEMPLATE = '[LOADING...]'; + return LoadingOverlayComponent; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); /***/ }), -/* 53 */ +/* 100 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RegisteredComponentSource", function() { return RegisteredComponentSource; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UserComponentRegistry", function() { return UserComponentRegistry; }); -/* harmony import */ var _rendering_cellEditors_textCellEditor__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(54); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _filter_provided_date_dateFilter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(58); -/* harmony import */ var _headerRendering_header_headerComp__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(64); -/* harmony import */ var _headerRendering_headerGroup_headerGroupComp__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(66); -/* harmony import */ var _rendering_cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(67); -/* harmony import */ var _rendering_cellRenderers_animateShowChangeCellRenderer__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(76); -/* harmony import */ var _rendering_cellRenderers_animateSlideCellRenderer__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(77); -/* harmony import */ var _rendering_cellRenderers_loadingCellRenderer__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(78); -/* harmony import */ var _rendering_cellEditors_selectCellEditor__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(79); -/* harmony import */ var _rendering_cellEditors_popupTextCellEditor__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(80); -/* harmony import */ var _rendering_cellEditors_popupSelectCellEditor__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(81); -/* harmony import */ var _rendering_cellEditors_largeTextCellEditor__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(82); -/* harmony import */ var _filter_provided_number_numberFilter__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(83); -/* harmony import */ var _rendering_overlays_loadingOverlayComponent__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(84); -/* harmony import */ var _rendering_overlays_noRowsOverlayComponent__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(85); -/* harmony import */ var _rendering_tooltipComponent__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(86); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(7); -/* harmony import */ var _filter_provided_date_defaultDateComponent__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(87); -/* harmony import */ var _filter_provided_date_dateFloatingFilter__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(88); -/* harmony import */ var _filter_provided_text_textFilter__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(90); -/* harmony import */ var _filter_provided_number_numberFloatingFilter__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(91); -/* harmony import */ var _filter_provided_text_textFloatingFilter__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(93); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(41); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NoRowsOverlayComponent", function() { return NoRowsOverlayComponent; }); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -12080,249 +19973,94 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - - - - - - - - - - - - - - - - +var NoRowsOverlayComponent = /** @class */ (function (_super) { + __extends(NoRowsOverlayComponent, _super); + function NoRowsOverlayComponent() { + return _super.call(this) || this; + } + // this is a user component, and IComponent has "public destroy()" as part of the interface. + // so we need to override destroy() just to make the method public. + NoRowsOverlayComponent.prototype.destroy = function () { + _super.prototype.destroy.call(this); + }; + NoRowsOverlayComponent.prototype.init = function (params) { + var template = this.gridOptionsWrapper.getOverlayNoRowsTemplate() ? + this.gridOptionsWrapper.getOverlayNoRowsTemplate() : NoRowsOverlayComponent.DEFAULT_NO_ROWS_TEMPLATE; + var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc(); + var localisedTemplate = template.replace('[NO_ROWS_TO_SHOW]', localeTextFunc('noRowsToShow', 'No Rows To Show')); + this.setTemplate(localisedTemplate); + }; + NoRowsOverlayComponent.DEFAULT_NO_ROWS_TEMPLATE = '[NO_ROWS_TO_SHOW]'; + return NoRowsOverlayComponent; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); +/***/ }), +/* 101 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { -var RegisteredComponentSource; -(function (RegisteredComponentSource) { - RegisteredComponentSource[RegisteredComponentSource["DEFAULT"] = 0] = "DEFAULT"; - RegisteredComponentSource[RegisteredComponentSource["REGISTERED"] = 1] = "REGISTERED"; -})(RegisteredComponentSource || (RegisteredComponentSource = {})); -var UserComponentRegistry = /** @class */ (function (_super) { - __extends(UserComponentRegistry, _super); - function UserComponentRegistry() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.agGridDefaults = { - //date - agDateInput: _filter_provided_date_defaultDateComponent__WEBPACK_IMPORTED_MODULE_18__["DefaultDateComponent"], - //header - agColumnHeader: _headerRendering_header_headerComp__WEBPACK_IMPORTED_MODULE_3__["HeaderComp"], - agColumnGroupHeader: _headerRendering_headerGroup_headerGroupComp__WEBPACK_IMPORTED_MODULE_4__["HeaderGroupComp"], - //floating filters - agTextColumnFloatingFilter: _filter_provided_text_textFloatingFilter__WEBPACK_IMPORTED_MODULE_22__["TextFloatingFilter"], - agNumberColumnFloatingFilter: _filter_provided_number_numberFloatingFilter__WEBPACK_IMPORTED_MODULE_21__["NumberFloatingFilter"], - agDateColumnFloatingFilter: _filter_provided_date_dateFloatingFilter__WEBPACK_IMPORTED_MODULE_19__["DateFloatingFilter"], - // renderers - agAnimateShowChangeCellRenderer: _rendering_cellRenderers_animateShowChangeCellRenderer__WEBPACK_IMPORTED_MODULE_6__["AnimateShowChangeCellRenderer"], - agAnimateSlideCellRenderer: _rendering_cellRenderers_animateSlideCellRenderer__WEBPACK_IMPORTED_MODULE_7__["AnimateSlideCellRenderer"], - agGroupCellRenderer: _rendering_cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_5__["GroupCellRenderer"], - agGroupRowRenderer: _rendering_cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_5__["GroupCellRenderer"], - agLoadingCellRenderer: _rendering_cellRenderers_loadingCellRenderer__WEBPACK_IMPORTED_MODULE_8__["LoadingCellRenderer"], - //editors - agCellEditor: _rendering_cellEditors_textCellEditor__WEBPACK_IMPORTED_MODULE_0__["TextCellEditor"], - agTextCellEditor: _rendering_cellEditors_textCellEditor__WEBPACK_IMPORTED_MODULE_0__["TextCellEditor"], - agSelectCellEditor: _rendering_cellEditors_selectCellEditor__WEBPACK_IMPORTED_MODULE_9__["SelectCellEditor"], - agPopupTextCellEditor: _rendering_cellEditors_popupTextCellEditor__WEBPACK_IMPORTED_MODULE_10__["PopupTextCellEditor"], - agPopupSelectCellEditor: _rendering_cellEditors_popupSelectCellEditor__WEBPACK_IMPORTED_MODULE_11__["PopupSelectCellEditor"], - agLargeTextCellEditor: _rendering_cellEditors_largeTextCellEditor__WEBPACK_IMPORTED_MODULE_12__["LargeTextCellEditor"], - //filter - agTextColumnFilter: _filter_provided_text_textFilter__WEBPACK_IMPORTED_MODULE_20__["TextFilter"], - agNumberColumnFilter: _filter_provided_number_numberFilter__WEBPACK_IMPORTED_MODULE_13__["NumberFilter"], - agDateColumnFilter: _filter_provided_date_dateFilter__WEBPACK_IMPORTED_MODULE_2__["DateFilter"], - //overlays - agLoadingOverlay: _rendering_overlays_loadingOverlayComponent__WEBPACK_IMPORTED_MODULE_14__["LoadingOverlayComponent"], - agNoRowsOverlay: _rendering_overlays_noRowsOverlayComponent__WEBPACK_IMPORTED_MODULE_15__["NoRowsOverlayComponent"], - // tooltips - agTooltipComponent: _rendering_tooltipComponent__WEBPACK_IMPORTED_MODULE_16__["TooltipComponent"] - }; - _this.agDeprecatedNames = { - set: { - newComponentName: 'agSetColumnFilter', - propertyHolder: 'filter' - }, - text: { - newComponentName: 'agTextColumnFilter', - propertyHolder: 'filter' - }, - number: { - newComponentName: 'agNumberColumnFilter', - propertyHolder: 'filter' - }, - date: { - newComponentName: 'agDateColumnFilter', - propertyHolder: 'filter' - }, - group: { - newComponentName: 'agGroupCellRenderer', - propertyHolder: 'cellRenderer' - }, - animateShowChange: { - newComponentName: 'agAnimateShowChangeCellRenderer', - propertyHolder: 'cellRenderer' - }, - animateSlide: { - newComponentName: 'agAnimateSlideCellRenderer', - propertyHolder: 'cellRenderer' - }, - select: { - newComponentName: 'agSelectCellEditor', - propertyHolder: 'cellEditor' - }, - largeText: { - newComponentName: 'agLargeTextCellEditor', - propertyHolder: 'cellEditor' - }, - popupSelect: { - newComponentName: 'agPopupSelectCellEditor', - propertyHolder: 'cellEditor' - }, - popupText: { - newComponentName: 'agPopupTextCellEditor', - propertyHolder: 'cellEditor' - }, - richSelect: { - newComponentName: 'agRichSelectCellEditor', - propertyHolder: 'cellEditor' - }, - headerComponent: { - newComponentName: 'agColumnHeader', - propertyHolder: 'headerComponent' - } - }; - _this.jsComponents = {}; - _this.frameworkComponents = {}; - return _this; - } - UserComponentRegistry.prototype.init = function () { - var _this = this; - if (this.gridOptions.components != null) { - Object.keys(this.gridOptions.components).forEach(function (it) { - _this.registerComponent(it, _this.gridOptions.components[it]); - }); - } - if (this.gridOptions.frameworkComponents != null) { - Object.keys(this.gridOptions.frameworkComponents).forEach(function (it) { - _this.registerFwComponent(it, _this.gridOptions.frameworkComponents[it]); - }); - } - }; - UserComponentRegistry.prototype.registerDefaultComponent = function (rawName, component) { - var name = this.translateIfDeprecated(rawName); - if (this.agGridDefaults[name]) { - console.error("Trying to overwrite a default component. You should call registerComponent"); - return; - } - this.agGridDefaults[name] = component; - }; - UserComponentRegistry.prototype.registerComponent = function (rawName, component) { - var name = this.translateIfDeprecated(rawName); - if (this.frameworkComponents[name]) { - console.error("Trying to register a component that you have already registered for frameworks: " + name); - return; - } - this.jsComponents[name] = component; - }; - /** - * B the business interface (ie IHeader) - * A the agGridComponent interface (ie IHeaderComp). The final object acceptable by ag-grid - */ - UserComponentRegistry.prototype.registerFwComponent = function (rawName, component) { - var name = this.translateIfDeprecated(rawName); - if (this.jsComponents[name]) { - console.error("Trying to register a component that you have already registered for plain javascript: " + name); - return; - } - this.frameworkComponents[name] = component; - }; - /** - * B the business interface (ie IHeader) - * A the agGridComponent interface (ie IHeaderComp). The final object acceptable by ag-grid - */ - UserComponentRegistry.prototype.retrieve = function (rawName) { - var name = this.translateIfDeprecated(rawName); - if (this.frameworkComponents[name]) { - return { - componentFromFramework: true, - component: this.frameworkComponents[name], - source: RegisteredComponentSource.REGISTERED - }; - } - if (this.jsComponents[name]) { - return { - componentFromFramework: false, - component: this.jsComponents[name], - source: RegisteredComponentSource.REGISTERED - }; - } - if (this.agGridDefaults[name]) { - return this.agGridDefaults[name] ? - { - componentFromFramework: false, - component: this.agGridDefaults[name], - source: RegisteredComponentSource.DEFAULT - } : - null; - } - if (Object.keys(this.agGridDefaults).indexOf(name) < 0) { - console.warn("ag-Grid: Looking for component [" + name + "] but it wasn't found."); - } - return null; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TooltipComponent", function() { return TooltipComponent; }); +/* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(85); +/* harmony import */ var _utils_string__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(26); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - UserComponentRegistry.prototype.translateIfDeprecated = function (raw) { - var deprecatedInfo = this.agDeprecatedNames[raw]; - if (deprecatedInfo != null) { - _utils__WEBPACK_IMPORTED_MODULE_17__["_"].doOnce(function () { - console.warn("ag-grid. Since v15.0 component names have been renamed to be namespaced. You should rename " + deprecatedInfo.propertyHolder + ":" + raw + " to " + deprecatedInfo.propertyHolder + ":" + deprecatedInfo.newComponentName); - }, 'DEPRECATE_COMPONENT_' + raw); - return deprecatedInfo.newComponentName; - } - return raw; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptions') - ], UserComponentRegistry.prototype, "gridOptions", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], UserComponentRegistry.prototype, "init", null); - UserComponentRegistry = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('userComponentRegistry') - ], UserComponentRegistry); - return UserComponentRegistry; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_23__["BeanStub"])); +})(); + + +var TooltipComponent = /** @class */ (function (_super) { + __extends(TooltipComponent, _super); + function TooltipComponent() { + return _super.call(this, /* html */ "
") || this; + } + // will need to type params + TooltipComponent.prototype.init = function (params) { + var value = params.value; + this.getGui().innerHTML = Object(_utils_string__WEBPACK_IMPORTED_MODULE_1__["escapeString"])(value); + }; + return TooltipComponent; +}(_widgets_popupComponent__WEBPACK_IMPORTED_MODULE_0__["PopupComponent"])); /***/ }), -/* 54 */ +/* 102 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TextCellEditor", function() { return TextCellEditor; }); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(25); -/* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(55); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UserComponentFactory", function() { return UserComponentFactory; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(13); +/* harmony import */ var _componentTypes__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(103); +/* harmony import */ var _filter_floating_floatingFilterMapper__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(104); +/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(16); +/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(17); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(14); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -12349,2125 +20087,2567 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var TextCellEditor = /** @class */ (function (_super) { - __extends(TextCellEditor, _super); - function TextCellEditor() { - return _super.call(this, TextCellEditor.TEMPLATE) || this; + + + + + +var ANNOTATIONS = '__annotations__'; +var UserComponentFactory = /** @class */ (function (_super) { + __extends(UserComponentFactory, _super); + function UserComponentFactory() { + return _super !== null && _super.apply(this, arguments) || this; } - TextCellEditor.prototype.init = function (params) { - this.params = params; - var eInput = this.eInput; - var startValue; - // cellStartedEdit is only false if we are doing fullRow editing - if (params.cellStartedEdit) { - this.focusAfterAttached = true; - var keyPressBackspaceOrDelete = params.keyPress === _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_BACKSPACE - || params.keyPress === _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_DELETE; - if (keyPressBackspaceOrDelete) { - startValue = ''; + UserComponentFactory.prototype.getHeaderCompDetails = function (colDef, params) { + return this.getCompDetails(colDef, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["HeaderComponent"], 'agColumnHeader', params); + }; + UserComponentFactory.prototype.getHeaderGroupCompDetails = function (params) { + var colGroupDef = params.columnGroup.getColGroupDef(); + return this.getCompDetails(colGroupDef, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["HeaderGroupComponent"], 'agColumnGroupHeader', params); + }; + // this one is unusual, as it can be LoadingCellRenderer, DetailCellRenderer, FullWidthCellRenderer or GroupRowRenderer. + // so we have to pass the type in. + UserComponentFactory.prototype.getFullWidthCellRendererDetails = function (params) { + return this.getCompDetails(this.gridOptions, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["FullWidth"], null, params, true); + }; + UserComponentFactory.prototype.getFullWidthLoadingCellRendererDetails = function (params) { + return this.getCompDetails(this.gridOptions, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["FullWidthLoading"], 'agLoadingCellRenderer', params, true); + }; + UserComponentFactory.prototype.getFullWidthGroupCellRendererDetails = function (params) { + return this.getCompDetails(this.gridOptions, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["FullWidthGroup"], 'agGroupRowRenderer', params, true); + }; + UserComponentFactory.prototype.getFullWidthDetailCellRendererDetails = function (params) { + return this.getCompDetails(this.gridOptions, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["FullWidthDetail"], 'agDetailCellRenderer', params, true); + }; + // CELL RENDERER + UserComponentFactory.prototype.getInnerRendererDetails = function (def, params) { + return this.getCompDetails(def, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["InnerRendererComponent"], null, params); + }; + UserComponentFactory.prototype.getFullWidthGroupRowInnerCellRenderer = function (def, params) { + return this.getCompDetails(def, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["InnerRendererComponent"], null, params); + }; + UserComponentFactory.prototype.getCellRendererDetails = function (def, params) { + return this.getCompDetails(def, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["CellRendererComponent"], null, params); + }; + // CELL EDITOR + UserComponentFactory.prototype.getCellEditorDetails = function (def, params) { + return this.getCompDetails(def, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["CellEditorComponent"], 'agCellEditor', params, true); + }; + // FILTER + UserComponentFactory.prototype.getFilterDetails = function (def, params, defaultFilter) { + return this.getCompDetails(def, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["FilterComponent"], defaultFilter, params, true); + }; + UserComponentFactory.prototype.getDateCompDetails = function (params) { + return this.getCompDetails(this.gridOptions, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["DateComponent"], 'agDateInput', params, true); + }; + UserComponentFactory.prototype.getLoadingOverlayCompDetails = function (params) { + return this.getCompDetails(this.gridOptions, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["LoadingOverlayComponent"], 'agLoadingOverlay', params, true); + }; + UserComponentFactory.prototype.getNoRowsOverlayCompDetails = function (params) { + return this.getCompDetails(this.gridOptions, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["NoRowsOverlayComponent"], 'agNoRowsOverlay', params, true); + }; + UserComponentFactory.prototype.getTooltipCompDetails = function (params) { + return this.getCompDetails(params.colDef, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["TooltipComponent"], 'agTooltipComponent', params, true); + }; + UserComponentFactory.prototype.getSetFilterCellRendererDetails = function (def, params) { + return this.getCompDetails(def, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["CellRendererComponent"], null, params); + }; + UserComponentFactory.prototype.getFloatingFilterCompDetails = function (def, params, defaultFloatingFilter) { + return this.getCompDetails(def, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["FloatingFilterComponent"], defaultFloatingFilter, params); + }; + UserComponentFactory.prototype.getToolPanelCompDetails = function (toolPanelDef, params) { + return this.getCompDetails(toolPanelDef, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["ToolPanelComponent"], null, params, true); + }; + UserComponentFactory.prototype.getStatusPanelCompDetails = function (def, params) { + return this.getCompDetails(def, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["StatusPanelComponent"], null, params, true); + }; + UserComponentFactory.prototype.getCompDetails = function (defObject, type, defaultName, params, mandatory) { + var _this = this; + if (mandatory === void 0) { mandatory = false; } + var propertyName = type.propertyName, cellRenderer = type.cellRenderer; + var _a = this.getCompKeys(defObject, type, params), compName = _a.compName, jsComp = _a.jsComp, fwComp = _a.fwComp, paramsFromSelector = _a.paramsFromSelector, popupFromSelector = _a.popupFromSelector, popupPositionFromSelector = _a.popupPositionFromSelector; + var lookupFromRegistry = function (key) { + var item = _this.userComponentRegistry.retrieve(key); + if (item) { + jsComp = !item.componentFromFramework ? item.component : undefined; + fwComp = item.componentFromFramework ? item.component : undefined; } - else if (params.charPress) { - startValue = params.charPress; + }; + // if compOption is a string, means we need to look the item up + if (compName != null) { + lookupFromRegistry(compName); + } + // if lookup brought nothing back, and we have a default, lookup the default + if (jsComp == null && fwComp == null && defaultName != null) { + lookupFromRegistry(defaultName); + } + // if we have a comp option, and it's a function, replace it with an object equivalent adaptor + if (jsComp && cellRenderer && !this.agComponentUtils.doesImplementIComponent(jsComp)) { + jsComp = this.agComponentUtils.adaptFunction(propertyName, jsComp); + } + if (!jsComp && !fwComp) { + if (mandatory) { + console.error("Could not find component " + compName + ", did you forget to configure this component?"); } - else { - startValue = this.getStartValue(params); - if (params.keyPress !== _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_F2) { - this.highlightAllOnFocus = true; + return; + } + var paramsMerged = this.mergeParamsWithApplicationProvidedParams(defObject, type, params, paramsFromSelector); + var componentFromFramework = jsComp == null; + var componentClass = jsComp ? jsComp : fwComp; + return { + componentFromFramework: componentFromFramework, + componentClass: componentClass, + params: paramsMerged, + type: type, + popupFromSelector: popupFromSelector, + popupPositionFromSelector: popupPositionFromSelector, + newAgStackInstance: function () { return _this.newAgStackInstance(componentClass, componentFromFramework, paramsMerged, type); } + }; + }; + UserComponentFactory.prototype.getCompKeys = function (defObject, type, params) { + var _this = this; + var propertyName = type.propertyName; + var compName; + var jsComp; + var fwComp; + var paramsFromSelector; + var popupFromSelector; + var popupPositionFromSelector; + // there are two types of js comps, class based and func based. we can only check for + // class based, by checking if getGui() exists. no way to differentiate js func based vs eg react func based + // const isJsClassComp = (comp: any) => this.agComponentUtils.doesImplementIComponent(comp); + // const fwActive = this.frameworkComponentWrapper != null; + // pull from defObject if available + if (defObject) { + var defObjectAny = defObject; + // if selector, use this + var selectorFunc = defObjectAny[propertyName + 'Selector']; + var selectorRes = selectorFunc ? selectorFunc(params) : null; + var assignComp = function (providedJsComp, providedFwComp) { + var xxxFrameworkDeprecatedWarn = function () { + var warningMessage = "AG Grid: As of v27, the property " + propertyName + "Framework is deprecated. The property " + propertyName + " can now be used for JavaScript AND Framework Components."; + Object(_utils_function__WEBPACK_IMPORTED_MODULE_8__["doOnce"])(function () { return console.warn(warningMessage); }, "UserComponentFactory." + propertyName + "FrameworkDeprecated"); + }; + if (typeof providedJsComp === 'string') { + compName = providedJsComp; + } + else if (typeof providedFwComp === 'string') { + xxxFrameworkDeprecatedWarn(); + compName = providedFwComp; + // comp===true for filters, which means use the default comp + } + else if (providedJsComp != null && providedJsComp !== true) { + var isFwkComp = _this.getFrameworkOverrides().isFrameworkComponent(providedJsComp); + if (isFwkComp) { + fwComp = providedJsComp; + } + else { + jsComp = providedJsComp; + } + } + else if (providedFwComp != null) { + xxxFrameworkDeprecatedWarn(); + fwComp = providedFwComp; + } + }; + if (selectorRes) { + if (selectorRes.frameworkComponent != null) { + var warningMessage_1 = "AG Grid: As of v27, the return for " + propertyName + "Selector has attributes [component, params] only. The attribute frameworkComponent is deprecated. You should now return back Framework Components using the 'component' attribute and the grid works out if it's a framework component or not."; + Object(_utils_function__WEBPACK_IMPORTED_MODULE_8__["doOnce"])(function () { return console.warn(warningMessage_1); }, "UserComponentFactory." + propertyName + "FrameworkSelectorDeprecated"); + assignComp(selectorRes.frameworkComponent, undefined); + } + else { + assignComp(selectorRes.component, undefined); } + paramsFromSelector = selectorRes.params; + popupFromSelector = selectorRes.popup; + popupPositionFromSelector = selectorRes.popupPosition; + } + else { + // if no selector, or result of selector is empty, take from defObject + assignComp(defObjectAny[propertyName], defObjectAny[propertyName + 'Framework']); } } + return { compName: compName, jsComp: jsComp, fwComp: fwComp, paramsFromSelector: paramsFromSelector, popupFromSelector: popupFromSelector, popupPositionFromSelector: popupPositionFromSelector }; + }; + UserComponentFactory.prototype.newAgStackInstance = function (ComponentClass, componentFromFramework, params, type) { + var propertyName = type.propertyName; + var jsComponent = !componentFromFramework; + // using javascript component + var instance; + if (jsComponent) { + instance = new ComponentClass(); + } else { - this.focusAfterAttached = false; - startValue = this.getStartValue(params); + // Using framework component + var thisComponentConfig = this.componentMetadataProvider.retrieve(propertyName); + instance = this.frameworkComponentWrapper.wrap(ComponentClass, thisComponentConfig.mandatoryMethodList, thisComponentConfig.optionalMethodList, type); } - if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(startValue)) { - eInput.setValue(startValue, true); + var deferredInit = this.initComponent(instance, params); + if (deferredInit == null) { + return _utils__WEBPACK_IMPORTED_MODULE_2__["AgPromise"].resolve(instance); } - this.addManagedListener(eInput.getGui(), 'keydown', function (event) { - var pageUp = event.keyCode === _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_PAGE_UP; - var pageDown = event.keyCode === _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_PAGE_DOWN; - if (pageUp || pageDown) { - event.preventDefault(); - } - }); + return deferredInit.then(function () { return instance; }); }; - TextCellEditor.prototype.afterGuiAttached = function () { - if (!this.focusAfterAttached) { + // used by Floating Filter + UserComponentFactory.prototype.mergeParamsWithApplicationProvidedParams = function (defObject, type, paramsFromGrid, paramsFromSelector) { + if (paramsFromSelector === void 0) { paramsFromSelector = null; } + var params = {}; + Object(_utils_object__WEBPACK_IMPORTED_MODULE_3__["mergeDeep"])(params, paramsFromGrid); + // pull user params from either the old prop name and new prop name + // eg either cellRendererParams and cellCompParams + var defObjectAny = defObject; + var userParams = defObjectAny && defObjectAny[type.propertyName + 'Params']; + if (typeof userParams === 'function') { + var userParamsFromFunc = userParams(paramsFromGrid); + Object(_utils_object__WEBPACK_IMPORTED_MODULE_3__["mergeDeep"])(params, userParamsFromFunc); + } + else if (typeof userParams === 'object') { + Object(_utils_object__WEBPACK_IMPORTED_MODULE_3__["mergeDeep"])(params, userParams); + } + Object(_utils_object__WEBPACK_IMPORTED_MODULE_3__["mergeDeep"])(params, paramsFromSelector); + return params; + }; + UserComponentFactory.prototype.initComponent = function (component, params) { + this.context.createBean(component); + if (component.init == null) { return; } - var eInput = this.eInput; - // Added for AG-3238. We can't remove this explicit focus() because Chrome requires an input - // to be focused before setSelectionRange will work. But it triggers a bug in Safari where - // explicitly focusing then blurring an empty field will cause the parent container to scroll. - if (!_utils__WEBPACK_IMPORTED_MODULE_3__["_"].isBrowserSafari()) { - eInput.getFocusableElement().focus(); + return component.init(params); + }; + UserComponentFactory.prototype.getDefaultFloatingFilterType = function (def) { + if (def == null) { + return null; } - var inputEl = eInput.getInputElement(); - if (this.highlightAllOnFocus) { - inputEl.select(); + var defaultFloatingFilterType = null; + var _a = this.getCompKeys(def, _componentTypes__WEBPACK_IMPORTED_MODULE_4__["FilterComponent"]), compName = _a.compName, jsComp = _a.jsComp, fwComp = _a.fwComp; + if (compName) { + // will be undefined if not in the map + defaultFloatingFilterType = _filter_floating_floatingFilterMapper__WEBPACK_IMPORTED_MODULE_5__["FloatingFilterMapper"].getFloatingFilterType(compName); } else { - // when we started editing, we want the caret at the end, not the start. - // this comes into play in two scenarios: a) when user hits F2 and b) - // when user hits a printable character, then on IE (and only IE) the caret - // was placed after the first character, thus 'apply' would end up as 'pplea' - var value = eInput.getValue(); - var len = (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(value) && value.length) || 0; - if (len) { - inputEl.setSelectionRange(len, len); + var usingDefaultFilter = (jsComp == null && fwComp == null) && (def.filter === true); + if (usingDefaultFilter) { + var setFilterModuleLoaded = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_6__["ModuleNames"].SetFilterModule); + defaultFloatingFilterType = setFilterModuleLoaded ? 'agSetColumnFloatingFilter' : 'agTextColumnFloatingFilter'; } } + return defaultFloatingFilterType; }; - // gets called when tabbing trough cells and in full row edit mode - TextCellEditor.prototype.focusIn = function () { - var eInput = this.eInput; - var focusEl = eInput.getFocusableElement(); - var inputEl = eInput.getInputElement(); - focusEl.focus(); - inputEl.select(); - }; - TextCellEditor.prototype.focusOut = function () { - var inputEl = this.eInput.getInputElement(); - if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].isBrowserIE()) { - inputEl.setSelectionRange(0, 0); - } - }; - TextCellEditor.prototype.getValue = function () { - var eInput = this.eInput; - return this.params.parseValue(eInput.getValue()); - }; - TextCellEditor.prototype.getStartValue = function (params) { - var formatValue = params.useFormatter || params.column.getColDef().refData; - return formatValue ? params.formatValue(params.value) : params.value; - }; - TextCellEditor.prototype.isPopup = function () { - return false; - }; - TextCellEditor.TEMPLATE = '
'; __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('eInput') - ], TextCellEditor.prototype, "eInput", void 0); - return TextCellEditor; -}(_widgets_popupComponent__WEBPACK_IMPORTED_MODULE_1__["PopupComponent"])); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptions') + ], UserComponentFactory.prototype, "gridOptions", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('agComponentUtils') + ], UserComponentFactory.prototype, "agComponentUtils", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('componentMetadataProvider') + ], UserComponentFactory.prototype, "componentMetadataProvider", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('userComponentRegistry') + ], UserComponentFactory.prototype, "userComponentRegistry", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Optional"])('frameworkComponentWrapper') + ], UserComponentFactory.prototype, "frameworkComponentWrapper", void 0); + UserComponentFactory = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('userComponentFactory') + ], UserComponentFactory); + return UserComponentFactory; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 55 */ +/* 103 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PopupComponent", function() { return PopupComponent; }); -/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DateComponent", function() { return DateComponent; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderComponent", function() { return HeaderComponent; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderGroupComponent", function() { return HeaderGroupComponent; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellRendererComponent", function() { return CellRendererComponent; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellEditorComponent", function() { return CellEditorComponent; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "InnerRendererComponent", function() { return InnerRendererComponent; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LoadingOverlayComponent", function() { return LoadingOverlayComponent; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NoRowsOverlayComponent", function() { return NoRowsOverlayComponent; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TooltipComponent", function() { return TooltipComponent; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FilterComponent", function() { return FilterComponent; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FloatingFilterComponent", function() { return FloatingFilterComponent; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ToolPanelComponent", function() { return ToolPanelComponent; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "StatusPanelComponent", function() { return StatusPanelComponent; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FullWidth", function() { return FullWidth; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FullWidthLoading", function() { return FullWidthLoading; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FullWidthGroup", function() { return FullWidthGroup; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FullWidthDetail", function() { return FullWidthDetail; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); +var DateComponent = { + propertyName: 'dateComponent', + cellRenderer: false +}; +var HeaderComponent = { + propertyName: 'headerComponent', + cellRenderer: false +}; +var HeaderGroupComponent = { + propertyName: 'headerGroupComponent', + cellRenderer: false +}; +var CellRendererComponent = { + propertyName: 'cellRenderer', + cellRenderer: true +}; +var CellEditorComponent = { + propertyName: 'cellEditor', + cellRenderer: false +}; +var InnerRendererComponent = { + propertyName: 'innerRenderer', + cellRenderer: true +}; +var LoadingOverlayComponent = { + propertyName: 'loadingOverlayComponent', + cellRenderer: false +}; +var NoRowsOverlayComponent = { + propertyName: 'noRowsOverlayComponent', + cellRenderer: false +}; +var TooltipComponent = { + propertyName: 'tooltipComponent', + cellRenderer: false +}; +var FilterComponent = { + propertyName: 'filter', + cellRenderer: false +}; +var FloatingFilterComponent = { + propertyName: 'floatingFilterComponent', + cellRenderer: false +}; +var ToolPanelComponent = { + propertyName: 'toolPanel', + cellRenderer: false +}; +var StatusPanelComponent = { + propertyName: 'statusPanel', + cellRenderer: false +}; +var FullWidth = { + propertyName: 'fullWidthCellRenderer', + cellRenderer: true +}; +var FullWidthLoading = { + propertyName: 'loadingCellRenderer', + cellRenderer: true +}; +var FullWidthGroup = { + propertyName: 'groupRowRenderer', + cellRenderer: true +}; +var FullWidthDetail = { + propertyName: 'detailCellRenderer', + cellRenderer: true +}; + + +/***/ }), +/* 104 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FloatingFilterMapper", function() { return FloatingFilterMapper; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var FloatingFilterMapper = /** @class */ (function () { + function FloatingFilterMapper() { + } + FloatingFilterMapper.getFloatingFilterType = function (filterType) { + return this.filterToFloatingFilterMapping[filterType]; }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + FloatingFilterMapper.filterToFloatingFilterMapping = { + set: 'agSetColumnFloatingFilter', + agSetColumnFilter: 'agSetColumnFloatingFilter', + multi: 'agMultiColumnFloatingFilter', + agMultiColumnFilter: 'agMultiColumnFloatingFilter', + number: 'agNumberColumnFloatingFilter', + agNumberColumnFilter: 'agNumberColumnFloatingFilter', + date: 'agDateColumnFloatingFilter', + agDateColumnFilter: 'agDateColumnFloatingFilter', + text: 'agTextColumnFloatingFilter', + agTextColumnFilter: 'agTextColumnFloatingFilter' }; -})(); + return FloatingFilterMapper; +}()); -var PopupComponent = /** @class */ (function (_super) { - __extends(PopupComponent, _super); - function PopupComponent() { - return _super !== null && _super.apply(this, arguments) || this; + +/***/ }), +/* 105 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "initialiseAgGridWithAngular1", function() { return initialiseAgGridWithAngular1; }); +/* harmony import */ var _grid__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(106); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ + +function initialiseAgGridWithAngular1(angular) { + var angularModule = angular.module("agGrid", []); + angularModule.directive("agGrid", function () { + return { + restrict: "A", + controller: ['$element', '$scope', '$compile', '$attrs', AngularDirectiveController], + scope: true + }; + }); +} +function AngularDirectiveController($element, $scope, $compile, $attrs) { + var gridOptions; + var keyOfGridInScope = $attrs.agGrid; + gridOptions = $scope.$eval(keyOfGridInScope); + if (!gridOptions) { + console.warn("WARNING - grid options for AG Grid not found. Please ensure the attribute ag-grid points to a valid object on the scope"); + return; } - PopupComponent.prototype.isPopup = function () { - return true; + var eGridDiv = $element[0]; + var gridParams = { + $scope: $scope, + $compile: $compile + }; + var grid = new _grid__WEBPACK_IMPORTED_MODULE_0__["Grid"](eGridDiv, gridOptions, gridParams); + var quickFilterOnScope = keyOfGridInScope + '.quickFilterText'; + var quickFilterUnregisterFn = $scope.$watch(quickFilterOnScope, function (newFilter) { + gridOptions.api.setQuickFilter(newFilter); + }); + $scope.$on("$destroy", function () { + quickFilterUnregisterFn(); + if (grid) { + grid.destroy(); + } + grid = null; + }); +} + + +/***/ }), +/* 106 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Grid", function() { return Grid; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridCoreCreator", function() { return GridCoreCreator; }); +/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(107); +/* harmony import */ var _selectionService__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(109); +/* harmony import */ var _columns_columnApi__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(111); +/* harmony import */ var _columns_columnModel__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(22); +/* harmony import */ var _rendering_rowRenderer__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(112); +/* harmony import */ var _headerRendering_gridHeaderComp__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(133); +/* harmony import */ var _filter_filterManager__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(162); +/* harmony import */ var _valueService_valueService__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(163); +/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(11); +/* harmony import */ var _gridBodyComp_gridBodyComp__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(164); +/* harmony import */ var _gridApi__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(149); +/* harmony import */ var _columns_columnFactory__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(5); +/* harmony import */ var _columns_displayedGroupCreator__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(29); +/* harmony import */ var _valueService_expressionService__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(170); +/* harmony import */ var _templateService__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(171); +/* harmony import */ var _widgets_popupService__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(172); +/* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(174); +/* harmony import */ var _columns_columnUtils__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(28); +/* harmony import */ var _rendering_autoWidthCalculator__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(175); +/* harmony import */ var _headerRendering_common_horizontalResizeService__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(176); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(12); +/* harmony import */ var _gridComp_gridComp__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(177); +/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(97); +/* harmony import */ var _dragAndDrop_dragService__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(181); +/* harmony import */ var _sortController__WEBPACK_IMPORTED_MODULE_24__ = __webpack_require__(182); +/* harmony import */ var _focusService__WEBPACK_IMPORTED_MODULE_25__ = __webpack_require__(173); +/* harmony import */ var _gridBodyComp_mouseEventService__WEBPACK_IMPORTED_MODULE_26__ = __webpack_require__(183); +/* harmony import */ var _cellNavigationService__WEBPACK_IMPORTED_MODULE_27__ = __webpack_require__(184); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_28__ = __webpack_require__(23); +/* harmony import */ var _rendering_valueFormatterService__WEBPACK_IMPORTED_MODULE_29__ = __webpack_require__(185); +/* harmony import */ var _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_30__ = __webpack_require__(158); +/* harmony import */ var _widgets_agRadioButton__WEBPACK_IMPORTED_MODULE_31__ = __webpack_require__(186); +/* harmony import */ var _vanillaFrameworkOverrides__WEBPACK_IMPORTED_MODULE_32__ = __webpack_require__(187); +/* harmony import */ var _gridBodyComp_scrollVisibleService__WEBPACK_IMPORTED_MODULE_33__ = __webpack_require__(188); +/* harmony import */ var _styling_stylingService__WEBPACK_IMPORTED_MODULE_34__ = __webpack_require__(189); +/* harmony import */ var _rendering_columnHoverService__WEBPACK_IMPORTED_MODULE_35__ = __webpack_require__(190); +/* harmony import */ var _rendering_columnAnimationService__WEBPACK_IMPORTED_MODULE_36__ = __webpack_require__(191); +/* harmony import */ var _columns_autoGroupColService__WEBPACK_IMPORTED_MODULE_37__ = __webpack_require__(192); +/* harmony import */ var _pagination_paginationProxy__WEBPACK_IMPORTED_MODULE_38__ = __webpack_require__(193); +/* harmony import */ var _pagination_paginationAutoPageSizeService__WEBPACK_IMPORTED_MODULE_39__ = __webpack_require__(194); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_40__ = __webpack_require__(15); +/* harmony import */ var _valueService_valueCache__WEBPACK_IMPORTED_MODULE_41__ = __webpack_require__(195); +/* harmony import */ var _valueService_changeDetectionService__WEBPACK_IMPORTED_MODULE_42__ = __webpack_require__(196); +/* harmony import */ var _alignedGridsService__WEBPACK_IMPORTED_MODULE_43__ = __webpack_require__(197); +/* harmony import */ var _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_44__ = __webpack_require__(102); +/* harmony import */ var _components_framework_userComponentRegistry__WEBPACK_IMPORTED_MODULE_45__ = __webpack_require__(34); +/* harmony import */ var _components_framework_agComponentUtils__WEBPACK_IMPORTED_MODULE_46__ = __webpack_require__(198); +/* harmony import */ var _components_framework_componentMetadataProvider__WEBPACK_IMPORTED_MODULE_47__ = __webpack_require__(199); +/* harmony import */ var _rendering_beans__WEBPACK_IMPORTED_MODULE_48__ = __webpack_require__(121); +/* harmony import */ var _environment__WEBPACK_IMPORTED_MODULE_49__ = __webpack_require__(200); +/* harmony import */ var _misc_animationFrameService__WEBPACK_IMPORTED_MODULE_50__ = __webpack_require__(201); +/* harmony import */ var _gridBodyComp_navigationService__WEBPACK_IMPORTED_MODULE_51__ = __webpack_require__(202); +/* harmony import */ var _rendering_rowContainerHeightService__WEBPACK_IMPORTED_MODULE_52__ = __webpack_require__(203); +/* harmony import */ var _rowNodes_selectableService__WEBPACK_IMPORTED_MODULE_53__ = __webpack_require__(204); +/* harmony import */ var _pagination_paginationComp__WEBPACK_IMPORTED_MODULE_54__ = __webpack_require__(205); +/* harmony import */ var _misc_resizeObserverService__WEBPACK_IMPORTED_MODULE_55__ = __webpack_require__(206); +/* harmony import */ var _rendering_overlays_overlayWrapperComponent__WEBPACK_IMPORTED_MODULE_56__ = __webpack_require__(207); +/* harmony import */ var _widgets_agGroupComponent__WEBPACK_IMPORTED_MODULE_57__ = __webpack_require__(208); +/* harmony import */ var _widgets_agDialog__WEBPACK_IMPORTED_MODULE_58__ = __webpack_require__(209); +/* harmony import */ var _widgets_agPanel__WEBPACK_IMPORTED_MODULE_59__ = __webpack_require__(210); +/* harmony import */ var _widgets_agInputTextField__WEBPACK_IMPORTED_MODULE_60__ = __webpack_require__(212); +/* harmony import */ var _widgets_agInputTextArea__WEBPACK_IMPORTED_MODULE_61__ = __webpack_require__(213); +/* harmony import */ var _widgets_agSlider__WEBPACK_IMPORTED_MODULE_62__ = __webpack_require__(214); +/* harmony import */ var _widgets_agColorPicker__WEBPACK_IMPORTED_MODULE_63__ = __webpack_require__(215); +/* harmony import */ var _widgets_agInputNumberField__WEBPACK_IMPORTED_MODULE_64__ = __webpack_require__(217); +/* harmony import */ var _widgets_agInputRange__WEBPACK_IMPORTED_MODULE_65__ = __webpack_require__(218); +/* harmony import */ var _widgets_agSelect__WEBPACK_IMPORTED_MODULE_66__ = __webpack_require__(66); +/* harmony import */ var _widgets_agAngleSelect__WEBPACK_IMPORTED_MODULE_67__ = __webpack_require__(219); +/* harmony import */ var _widgets_agToggleButton__WEBPACK_IMPORTED_MODULE_68__ = __webpack_require__(220); +/* harmony import */ var _entities_rowPosition__WEBPACK_IMPORTED_MODULE_69__ = __webpack_require__(221); +/* harmony import */ var _entities_cellPosition__WEBPACK_IMPORTED_MODULE_70__ = __webpack_require__(222); +/* harmony import */ var _pinnedRowModel_pinnedRowModel__WEBPACK_IMPORTED_MODULE_71__ = __webpack_require__(223); +/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_72__ = __webpack_require__(17); +/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_73__ = __webpack_require__(16); +/* harmony import */ var _undoRedo_undoRedoService__WEBPACK_IMPORTED_MODULE_74__ = __webpack_require__(224); +/* harmony import */ var _components_agStackComponentsRegistry__WEBPACK_IMPORTED_MODULE_75__ = __webpack_require__(32); +/* harmony import */ var _headerRendering_common_headerPosition__WEBPACK_IMPORTED_MODULE_76__ = __webpack_require__(226); +/* harmony import */ var _headerRendering_common_headerNavigationService__WEBPACK_IMPORTED_MODULE_77__ = __webpack_require__(135); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_78__ = __webpack_require__(7); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_79__ = __webpack_require__(13); +/* harmony import */ var _columns_columnDefFactory__WEBPACK_IMPORTED_MODULE_80__ = __webpack_require__(227); +/* harmony import */ var _rendering_row_rowCssClassCalculator__WEBPACK_IMPORTED_MODULE_81__ = __webpack_require__(228); +/* harmony import */ var _rowNodeCache_rowNodeBlockLoader__WEBPACK_IMPORTED_MODULE_82__ = __webpack_require__(229); +/* harmony import */ var _rowNodes_rowNodeSorter__WEBPACK_IMPORTED_MODULE_83__ = __webpack_require__(231); +/* harmony import */ var _ctrlsService__WEBPACK_IMPORTED_MODULE_84__ = __webpack_require__(232); +/* harmony import */ var _ctrlsFactory__WEBPACK_IMPORTED_MODULE_85__ = __webpack_require__(233); +/* harmony import */ var _gridBodyComp_fakeHScrollComp__WEBPACK_IMPORTED_MODULE_86__ = __webpack_require__(234); +/* harmony import */ var _gridBodyComp_pinnedWidthService__WEBPACK_IMPORTED_MODULE_87__ = __webpack_require__(236); +/* harmony import */ var _gridBodyComp_rowContainer_rowContainerComp__WEBPACK_IMPORTED_MODULE_88__ = __webpack_require__(237); +/* harmony import */ var _entities_rowNodeEventThrottle__WEBPACK_IMPORTED_MODULE_89__ = __webpack_require__(241); +/* harmony import */ var _headerRendering_cells_column_standardMenu__WEBPACK_IMPORTED_MODULE_90__ = __webpack_require__(242); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; +}; +var __spread = (undefined && undefined.__spread) || function () { + for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); + return ar; +}; + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +// creates JavaScript vanilla Grid, including JavaScript (ag-stack) components, which can +// be wrapped by the framework wrappers +var Grid = /** @class */ (function () { + function Grid(eGridDiv, gridOptions, params) { + if (!gridOptions) { + console.error('AG Grid: no gridOptions provided to the grid'); + return; + } + this.gridOptions = gridOptions; + new GridCoreCreator().create(eGridDiv, gridOptions, function (context) { + var gridComp = new _gridComp_gridComp__WEBPACK_IMPORTED_MODULE_21__["GridComp"](eGridDiv); + context.createBean(gridComp); + }, undefined, params); + } + Grid.prototype.destroy = function () { + if (this.gridOptions && this.gridOptions.api) { + this.gridOptions.api.destroy(); + } + }; + return Grid; +}()); + +// created services of grid only, no UI, so frameworks can use this if providing +// their own UI +var GridCoreCreator = /** @class */ (function () { + function GridCoreCreator() { + } + GridCoreCreator.prototype.create = function (eGridDiv, gridOptions, createUi, acceptChanges, params) { + var _this = this; + var debug = !!gridOptions.debug; + var registeredModules = this.getRegisteredModules(params); + var beanClasses = this.createBeansList(gridOptions.rowModelType, registeredModules); + var providedBeanInstances = this.createProvidedBeans(eGridDiv, gridOptions, params); + if (!beanClasses) { + return; + } // happens when no row model found + var contextParams = { + providedBeanInstances: providedBeanInstances, + beanClasses: beanClasses, + debug: debug + }; + var logger = new _logger__WEBPACK_IMPORTED_MODULE_16__["Logger"]('AG Grid', function () { return gridOptions.debug; }); + var contextLogger = new _logger__WEBPACK_IMPORTED_MODULE_16__["Logger"]('Context', function () { return contextParams.debug; }); + var context = new _context_context__WEBPACK_IMPORTED_MODULE_20__["Context"](contextParams, contextLogger); + var beans = context.getBean('beans'); + this.registerModuleUserComponents(beans, registeredModules); + this.registerStackComponents(beans, registeredModules); + this.registerControllers(beans, registeredModules); + createUi(context); + // we wait until the UI has finished initialising before setting in columns and rows + beans.ctrlsService.whenReady(function () { + _this.setColumnsAndData(beans); + _this.dispatchGridReadyEvent(beans, gridOptions); + var isEnterprise = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_72__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_73__["ModuleNames"].EnterpriseCoreModule); + logger.log("initialised successfully, enterprise = " + isEnterprise); + }); + if (acceptChanges) { + acceptChanges(context); + } + }; + GridCoreCreator.prototype.registerControllers = function (beans, registeredModules) { + registeredModules.forEach(function (module) { + if (module.controllers) { + module.controllers.forEach(function (meta) { return beans.ctrlsFactory.register(meta); }); + } + }); + }; + GridCoreCreator.prototype.registerStackComponents = function (beans, registeredModules) { + var agStackComponents = this.createAgStackComponentsList(registeredModules); + beans.agStackComponentsRegistry.setupComponents(agStackComponents); + }; + GridCoreCreator.prototype.getRegisteredModules = function (params) { + var passedViaConstructor = params ? params.modules : null; + var registered = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_72__["ModuleRegistry"].getRegisteredModules(); + var allModules = []; + var mapNames = {}; + // adds to list and removes duplicates + function addModule(moduleBased, mod) { + function addIndividualModule(currentModule) { + if (!mapNames[currentModule.moduleName]) { + mapNames[currentModule.moduleName] = true; + allModules.push(currentModule); + _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_72__["ModuleRegistry"].register(currentModule, moduleBased); + } + } + addIndividualModule(mod); + if (mod.dependantModules) { + mod.dependantModules.forEach(addModule.bind(null, moduleBased)); + } + } + if (passedViaConstructor) { + passedViaConstructor.forEach(addModule.bind(null, true)); + } + if (registered) { + registered.forEach(addModule.bind(null, !_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_72__["ModuleRegistry"].isPackageBased())); + } + return allModules; + }; + GridCoreCreator.prototype.registerModuleUserComponents = function (beans, registeredModules) { + var moduleUserComps = this.extractModuleEntity(registeredModules, function (module) { return module.userComponents ? module.userComponents : []; }); + moduleUserComps.forEach(function (compMeta) { + beans.userComponentRegistry.registerDefaultComponent(compMeta.componentName, compMeta.componentClass); + }); + }; + GridCoreCreator.prototype.createProvidedBeans = function (eGridDiv, gridOptions, params) { + var frameworkOverrides = params ? params.frameworkOverrides : null; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_78__["missing"])(frameworkOverrides)) { + frameworkOverrides = new _vanillaFrameworkOverrides__WEBPACK_IMPORTED_MODULE_32__["VanillaFrameworkOverrides"](); + } + var seed = { + gridOptions: gridOptions, + eGridDiv: eGridDiv, + $scope: params ? params.$scope : null, + $compile: params ? params.$compile : null, + globalEventListener: params ? params.globalEventListener : null, + frameworkOverrides: frameworkOverrides + }; + if (params && params.providedBeanInstances) { + Object.assign(seed, params.providedBeanInstances); + } + return seed; + }; + GridCoreCreator.prototype.createAgStackComponentsList = function (registeredModules) { + var components = [ + { componentName: 'AgCheckbox', componentClass: _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_30__["AgCheckbox"] }, + { componentName: 'AgRadioButton', componentClass: _widgets_agRadioButton__WEBPACK_IMPORTED_MODULE_31__["AgRadioButton"] }, + { componentName: 'AgToggleButton', componentClass: _widgets_agToggleButton__WEBPACK_IMPORTED_MODULE_68__["AgToggleButton"] }, + { componentName: 'AgInputTextField', componentClass: _widgets_agInputTextField__WEBPACK_IMPORTED_MODULE_60__["AgInputTextField"] }, + { componentName: 'AgInputTextArea', componentClass: _widgets_agInputTextArea__WEBPACK_IMPORTED_MODULE_61__["AgInputTextArea"] }, + { componentName: 'AgInputNumberField', componentClass: _widgets_agInputNumberField__WEBPACK_IMPORTED_MODULE_64__["AgInputNumberField"] }, + { componentName: 'AgInputRange', componentClass: _widgets_agInputRange__WEBPACK_IMPORTED_MODULE_65__["AgInputRange"] }, + { componentName: 'AgSelect', componentClass: _widgets_agSelect__WEBPACK_IMPORTED_MODULE_66__["AgSelect"] }, + { componentName: 'AgSlider', componentClass: _widgets_agSlider__WEBPACK_IMPORTED_MODULE_62__["AgSlider"] }, + { componentName: 'AgAngleSelect', componentClass: _widgets_agAngleSelect__WEBPACK_IMPORTED_MODULE_67__["AgAngleSelect"] }, + { componentName: 'AgColorPicker', componentClass: _widgets_agColorPicker__WEBPACK_IMPORTED_MODULE_63__["AgColorPicker"] }, + { componentName: 'AgGridBody', componentClass: _gridBodyComp_gridBodyComp__WEBPACK_IMPORTED_MODULE_9__["GridBodyComp"] }, + { componentName: 'AgHeaderRoot', componentClass: _headerRendering_gridHeaderComp__WEBPACK_IMPORTED_MODULE_5__["GridHeaderComp"] }, + { componentName: 'AgPagination', componentClass: _pagination_paginationComp__WEBPACK_IMPORTED_MODULE_54__["PaginationComp"] }, + { componentName: 'AgOverlayWrapper', componentClass: _rendering_overlays_overlayWrapperComponent__WEBPACK_IMPORTED_MODULE_56__["OverlayWrapperComponent"] }, + { componentName: 'AgGroupComponent', componentClass: _widgets_agGroupComponent__WEBPACK_IMPORTED_MODULE_57__["AgGroupComponent"] }, + { componentName: 'AgPanel', componentClass: _widgets_agPanel__WEBPACK_IMPORTED_MODULE_59__["AgPanel"] }, + { componentName: 'AgDialog', componentClass: _widgets_agDialog__WEBPACK_IMPORTED_MODULE_58__["AgDialog"] }, + { componentName: 'AgRowContainer', componentClass: _gridBodyComp_rowContainer_rowContainerComp__WEBPACK_IMPORTED_MODULE_88__["RowContainerComp"] }, + { componentName: 'AgFakeHorizontalScroll', componentClass: _gridBodyComp_fakeHScrollComp__WEBPACK_IMPORTED_MODULE_86__["FakeHScrollComp"] } + ]; + var moduleAgStackComps = this.extractModuleEntity(registeredModules, function (module) { return module.agStackComponents ? module.agStackComponents : []; }); + components = components.concat(moduleAgStackComps); + return components; + }; + GridCoreCreator.prototype.createBeansList = function (rowModelType, registeredModules) { + var rowModelClass = this.getRowModelClass(rowModelType, registeredModules); + if (!rowModelClass) { + return; + } + // beans should only contain SERVICES, it should NEVER contain COMPONENTS + var beans = [ + rowModelClass, _rendering_beans__WEBPACK_IMPORTED_MODULE_48__["Beans"], _entities_rowPosition__WEBPACK_IMPORTED_MODULE_69__["RowPositionUtils"], _entities_cellPosition__WEBPACK_IMPORTED_MODULE_70__["CellPositionUtils"], _headerRendering_common_headerPosition__WEBPACK_IMPORTED_MODULE_76__["HeaderPositionUtils"], + _pagination_paginationAutoPageSizeService__WEBPACK_IMPORTED_MODULE_39__["PaginationAutoPageSizeService"], _gridApi__WEBPACK_IMPORTED_MODULE_10__["GridApi"], _components_framework_userComponentRegistry__WEBPACK_IMPORTED_MODULE_45__["UserComponentRegistry"], _components_framework_agComponentUtils__WEBPACK_IMPORTED_MODULE_46__["AgComponentUtils"], + _components_framework_componentMetadataProvider__WEBPACK_IMPORTED_MODULE_47__["ComponentMetadataProvider"], _misc_resizeObserverService__WEBPACK_IMPORTED_MODULE_55__["ResizeObserverService"], _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_44__["UserComponentFactory"], + _rendering_rowContainerHeightService__WEBPACK_IMPORTED_MODULE_52__["RowContainerHeightService"], _headerRendering_common_horizontalResizeService__WEBPACK_IMPORTED_MODULE_19__["HorizontalResizeService"], + _pinnedRowModel_pinnedRowModel__WEBPACK_IMPORTED_MODULE_71__["PinnedRowModel"], _dragAndDrop_dragService__WEBPACK_IMPORTED_MODULE_23__["DragService"], _columns_displayedGroupCreator__WEBPACK_IMPORTED_MODULE_12__["DisplayedGroupCreator"], _eventService__WEBPACK_IMPORTED_MODULE_8__["EventService"], _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"], + _widgets_popupService__WEBPACK_IMPORTED_MODULE_15__["PopupService"], _selectionService__WEBPACK_IMPORTED_MODULE_1__["SelectionService"], _filter_filterManager__WEBPACK_IMPORTED_MODULE_6__["FilterManager"], _columns_columnModel__WEBPACK_IMPORTED_MODULE_3__["ColumnModel"], _headerRendering_common_headerNavigationService__WEBPACK_IMPORTED_MODULE_77__["HeaderNavigationService"], + _pagination_paginationProxy__WEBPACK_IMPORTED_MODULE_38__["PaginationProxy"], _rendering_rowRenderer__WEBPACK_IMPORTED_MODULE_4__["RowRenderer"], _valueService_expressionService__WEBPACK_IMPORTED_MODULE_13__["ExpressionService"], _columns_columnFactory__WEBPACK_IMPORTED_MODULE_11__["ColumnFactory"], _templateService__WEBPACK_IMPORTED_MODULE_14__["TemplateService"], + _alignedGridsService__WEBPACK_IMPORTED_MODULE_43__["AlignedGridsService"], _gridBodyComp_navigationService__WEBPACK_IMPORTED_MODULE_51__["NavigationService"], _valueService_valueCache__WEBPACK_IMPORTED_MODULE_41__["ValueCache"], _valueService_valueService__WEBPACK_IMPORTED_MODULE_7__["ValueService"], _logger__WEBPACK_IMPORTED_MODULE_16__["LoggerFactory"], + _columns_columnUtils__WEBPACK_IMPORTED_MODULE_17__["ColumnUtils"], _rendering_autoWidthCalculator__WEBPACK_IMPORTED_MODULE_18__["AutoWidthCalculator"], _headerRendering_cells_column_standardMenu__WEBPACK_IMPORTED_MODULE_90__["StandardMenuFactory"], _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_22__["DragAndDropService"], _columns_columnApi__WEBPACK_IMPORTED_MODULE_2__["ColumnApi"], + _focusService__WEBPACK_IMPORTED_MODULE_25__["FocusService"], _gridBodyComp_mouseEventService__WEBPACK_IMPORTED_MODULE_26__["MouseEventService"], _environment__WEBPACK_IMPORTED_MODULE_49__["Environment"], _cellNavigationService__WEBPACK_IMPORTED_MODULE_27__["CellNavigationService"], _rendering_valueFormatterService__WEBPACK_IMPORTED_MODULE_29__["ValueFormatterService"], + _styling_stylingService__WEBPACK_IMPORTED_MODULE_34__["StylingService"], _gridBodyComp_scrollVisibleService__WEBPACK_IMPORTED_MODULE_33__["ScrollVisibleService"], _sortController__WEBPACK_IMPORTED_MODULE_24__["SortController"], _rendering_columnHoverService__WEBPACK_IMPORTED_MODULE_35__["ColumnHoverService"], _rendering_columnAnimationService__WEBPACK_IMPORTED_MODULE_36__["ColumnAnimationService"], + _rowNodes_selectableService__WEBPACK_IMPORTED_MODULE_53__["SelectableService"], _columns_autoGroupColService__WEBPACK_IMPORTED_MODULE_37__["AutoGroupColService"], _valueService_changeDetectionService__WEBPACK_IMPORTED_MODULE_42__["ChangeDetectionService"], _misc_animationFrameService__WEBPACK_IMPORTED_MODULE_50__["AnimationFrameService"], + _undoRedo_undoRedoService__WEBPACK_IMPORTED_MODULE_74__["UndoRedoService"], _components_agStackComponentsRegistry__WEBPACK_IMPORTED_MODULE_75__["AgStackComponentsRegistry"], _columns_columnDefFactory__WEBPACK_IMPORTED_MODULE_80__["ColumnDefFactory"], + _rendering_row_rowCssClassCalculator__WEBPACK_IMPORTED_MODULE_81__["RowCssClassCalculator"], _rowNodeCache_rowNodeBlockLoader__WEBPACK_IMPORTED_MODULE_82__["RowNodeBlockLoader"], _rowNodes_rowNodeSorter__WEBPACK_IMPORTED_MODULE_83__["RowNodeSorter"], _ctrlsService__WEBPACK_IMPORTED_MODULE_84__["CtrlsService"], + _gridBodyComp_pinnedWidthService__WEBPACK_IMPORTED_MODULE_87__["PinnedWidthService"], _entities_rowNodeEventThrottle__WEBPACK_IMPORTED_MODULE_89__["RowNodeEventThrottle"], _ctrlsFactory__WEBPACK_IMPORTED_MODULE_85__["CtrlsFactory"] + ]; + var moduleBeans = this.extractModuleEntity(registeredModules, function (module) { return module.beans ? module.beans : []; }); + beans.push.apply(beans, __spread(moduleBeans)); + // check for duplicates, as different modules could include the same beans that + // they depend on, eg ClientSideRowModel in enterprise, and ClientSideRowModel in community + var beansNoDuplicates = []; + beans.forEach(function (bean) { + if (beansNoDuplicates.indexOf(bean) < 0) { + beansNoDuplicates.push(bean); + } + }); + return beansNoDuplicates; + }; + GridCoreCreator.prototype.extractModuleEntity = function (moduleEntities, extractor) { + return [].concat.apply([], __spread(moduleEntities.map(extractor))); + }; + GridCoreCreator.prototype.setColumnsAndData = function (beans) { + var columnDefs = beans.gridOptionsWrapper.getColumnDefs(); + beans.columnModel.setColumnDefs(columnDefs || [], "gridInitializing"); + beans.rowModel.start(); }; - PopupComponent.prototype.setParentComponent = function (container) { - _utils__WEBPACK_IMPORTED_MODULE_1__["_"].addCssClass(container.getGui(), 'ag-has-popup'); - _super.prototype.setParentComponent.call(this, container); + GridCoreCreator.prototype.dispatchGridReadyEvent = function (beans, gridOptions) { + var readyEvent = { + type: _events__WEBPACK_IMPORTED_MODULE_28__["Events"].EVENT_GRID_READY, + api: gridOptions.api, + columnApi: gridOptions.columnApi + }; + beans.eventService.dispatchEvent(readyEvent); }; - PopupComponent.prototype.destroy = function () { - var parentComp = this.parentComponent; - var hasParent = parentComp && parentComp.isAlive(); - if (hasParent) { - _utils__WEBPACK_IMPORTED_MODULE_1__["_"].removeCssClass(parentComp.getGui(), 'ag-has-popup'); + GridCoreCreator.prototype.getRowModelClass = function (rowModelType, registeredModules) { + // default to client side + if (!rowModelType) { + rowModelType = _constants_constants__WEBPACK_IMPORTED_MODULE_40__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE; + } + var rowModelClasses = {}; + registeredModules.forEach(function (module) { + Object(_utils_object__WEBPACK_IMPORTED_MODULE_79__["iterateObject"])(module.rowModels, function (key, value) { + rowModelClasses[key] = value; + }); + }); + var rowModelClass = rowModelClasses[rowModelType]; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_78__["exists"])(rowModelClass)) { + return rowModelClass; + } + if (rowModelType === _constants_constants__WEBPACK_IMPORTED_MODULE_40__["Constants"].ROW_MODEL_TYPE_INFINITE) { + console.error("AG Grid: Row Model \"Infinite\" not found. Please ensure the " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_73__["ModuleNames"].InfiniteRowModelModule + " is registered.';"); + } + console.error('AG Grid: could not find matching row model for rowModelType ' + rowModelType); + if (rowModelType === _constants_constants__WEBPACK_IMPORTED_MODULE_40__["Constants"].ROW_MODEL_TYPE_VIEWPORT) { + console.error("AG Grid: Row Model \"Viewport\" not found. Please ensure the AG Grid Enterprise Module " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_73__["ModuleNames"].ViewportRowModelModule + " is registered.';"); + } + if (rowModelType === _constants_constants__WEBPACK_IMPORTED_MODULE_40__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE) { + console.error("AG Grid: Row Model \"Server Side\" not found. Please ensure the AG Grid Enterprise Module " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_73__["ModuleNames"].ServerSideRowModelModule + " is registered.';"); + } + if (rowModelType === _constants_constants__WEBPACK_IMPORTED_MODULE_40__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) { + console.error("AG Grid: Row Model \"Client Side\" not found. Please ensure the " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_73__["ModuleNames"].ClientSideRowModelModule + " is registered.';"); } - _super.prototype.destroy.call(this); }; - return PopupComponent; -}(_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); + return GridCoreCreator; +}()); /***/ }), -/* 56 */ +/* 107 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Component", function() { return Component; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridOptionsWrapper", function() { return GridOptionsWrapper; }); +/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(11); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(15); +/* harmony import */ var _components_componentUtil__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(30); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(12); +/* harmony import */ var _propertyKeys__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(31); +/* harmony import */ var _components_colDefUtil__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(33); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(24); +/* harmony import */ var _entities_sideBar__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(108); +/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(16); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(13); +/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(17); +/* harmony import */ var _utils_number__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(46); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(7); +/* harmony import */ var _utils_fuzzyMatch__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(47); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(14); +/* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(43); +/* harmony import */ var _utils_string__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(26); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; +var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { + return function (target, key) { decorator(target, key, paramIndex); } +}; +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; +}; +var __spread = (undefined && undefined.__spread) || function () { + for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); + return ar; +}; -var compIdSequence = new _utils__WEBPACK_IMPORTED_MODULE_2__["NumberSequence"](); -var Component = /** @class */ (function (_super) { - __extends(Component, _super); - function Component(template) { - var _this = _super.call(this) || this; - _this.annotatedGuiListeners = []; - // if false, then CSS class "ag-hidden" is applied, which sets "display: none" - _this.displayed = true; - // if false, then CSS class "ag-invisible" is applied, which sets "visibility: hidden" - _this.visible = true; - // unique id for this row component. this is used for getting a reference to the HTML dom. - // we cannot use the RowNode id as this is not unique (due to animation, old rows can be lying - // around as we create a new rowComp instance for the same row node). - _this.compId = compIdSequence.next(); - if (template) { - _this.setTemplate(template); - } - return _this; + + + + + + + + + + + + + + +var DEFAULT_ROW_HEIGHT = 25; +var DEFAULT_DETAIL_ROW_HEIGHT = 300; +var DEFAULT_VIEWPORT_ROW_MODEL_PAGE_SIZE = 5; +var DEFAULT_VIEWPORT_ROW_MODEL_BUFFER_SIZE = 5; +var DEFAULT_KEEP_DETAIL_ROW_COUNT = 10; +function isTrue(value) { + return value === true || value === 'true'; +} +function toNumber(value) { + if (typeof value == 'number') { + return value; } - Component.prototype.getCompId = function () { - return this.compId; + if (typeof value == 'string') { + return parseInt(value, 10); + } +} +function zeroOrGreater(value, defaultValue) { + if (value >= 0) { + return value; + } + // zero gets returned if number is missing or the wrong type + return defaultValue; +} +function oneOrGreater(value, defaultValue) { + var valueNumber = parseInt(value, 10); + if (Object(_utils_number__WEBPACK_IMPORTED_MODULE_11__["isNumeric"])(valueNumber) && valueNumber > 0) { + return valueNumber; + } + return defaultValue; +} +var GridOptionsWrapper = /** @class */ (function () { + function GridOptionsWrapper() { + this.propertyEventService = new _eventService__WEBPACK_IMPORTED_MODULE_0__["EventService"](); + this.domDataKey = '__AG_' + Math.random().toString(); + this.destroyed = false; + } + GridOptionsWrapper_1 = GridOptionsWrapper; + GridOptionsWrapper.prototype.agWire = function (gridApi, columnApi) { + this.gridOptions.api = gridApi; + this.gridOptions.columnApi = columnApi; + this.checkForDeprecated(); + this.checkForViolations(); }; - // for registered components only, eg creates AgCheckbox instance from ag-checkbox HTML tag - Component.prototype.createChildComponentsFromTags = function (parentNode, paramsMap) { + GridOptionsWrapper.prototype.destroy = function () { + // need to remove these, as we don't own the lifecycle of the gridOptions, we need to + // remove the references in case the user keeps the grid options, we want the rest + // of the grid to be picked up by the garbage collector + this.gridOptions.api = null; + this.gridOptions.columnApi = null; + this.destroyed = true; + }; + GridOptionsWrapper.prototype.init = function () { var _this = this; - // we MUST take a copy of the list first, as the 'swapComponentForNode' adds comments into the DOM - // which messes up the traversal order of the children. - var childNodeList = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].copyNodeList(parentNode.childNodes); - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].forEach(childNodeList, function (childNode) { - if (!(childNode instanceof HTMLElement)) { - return; + if (this.gridOptions.suppressPropertyNamesCheck !== true) { + this.checkGridOptionsProperties(); + this.checkColumnDefProperties(); + } + // parse side bar options into correct format + if (this.gridOptions.sideBar != null) { + this.gridOptions.sideBar = _entities_sideBar__WEBPACK_IMPORTED_MODULE_7__["SideBarDefParser"].parse(this.gridOptions.sideBar); + } + var async = this.useAsyncEvents(); + this.eventService.addGlobalListener(this.globalEventHandler.bind(this), async); + if (this.isGroupSelectsChildren() && this.isSuppressParentsInRowNodes()) { + console.warn("AG Grid: 'groupSelectsChildren' does not work with 'suppressParentsInRowNodes', this selection method needs the part in rowNode to work"); + } + if (this.isGroupSelectsChildren()) { + if (!this.isRowSelectionMulti()) { + console.warn("AG Grid: rowSelection must be 'multiple' for groupSelectsChildren to make sense"); } - var childComp = _this.createComponentFromElement(childNode, function (childComp) { - // copy over all attributes, including css classes, so any attributes user put on the tag - // wll be carried across - _this.copyAttributesFromNode(childNode, childComp.getGui()); - }, paramsMap); - if (childComp) { - if (childComp.addItems && childNode.children.length) { - _this.createChildComponentsFromTags(childNode); - // converting from HTMLCollection to Array - var items = Array.prototype.slice.call(childNode.children); - childComp.addItems(items); - } - // replace the tag (eg ag-checkbox) with the proper HTMLElement (eg 'div') in the dom - _this.swapComponentForNode(childComp, parentNode, childNode); + if (this.isRowModelServerSide()) { + console.warn('AG Grid: group selects children is NOT support for Server Side Row Model. ' + + 'This is because the rows are lazy loaded, so selecting a group is not possible as' + + 'the grid has no way of knowing what the children are.'); } - else if (childNode.childNodes) { - _this.createChildComponentsFromTags(childNode); + } + if (this.isGroupRemoveSingleChildren() && this.isGroupHideOpenParents()) { + console.warn("AG Grid: groupRemoveSingleChildren and groupHideOpenParents do not work with each other, you need to pick one. And don't ask us how to us these together on our support forum either you will get the same answer!"); + } + if (this.isRowModelServerSide()) { + var msg = function (prop) { return "AG Grid: '" + prop + "' is not supported on the Server-Side Row Model"; }; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["exists"])(this.gridOptions.groupDefaultExpanded)) { + console.warn(msg('groupDefaultExpanded')); + } + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["exists"])(this.gridOptions.groupDefaultExpanded)) { + console.warn(msg('groupIncludeFooter')); + } + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["exists"])(this.gridOptions.groupDefaultExpanded)) { + console.warn(msg('groupIncludeTotalFooter')); + } + } + if (this.isEnableRangeSelection()) { + _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_10__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__["ModuleNames"].RangeSelectionModule, 'enableRangeSelection'); + } + if (!this.isEnableRangeSelection() && (this.isEnableRangeHandle() || this.isEnableFillHandle())) { + console.warn("AG Grid: 'enableRangeHandle' and 'enableFillHandle' will not work unless 'enableRangeSelection' is set to true"); + } + var warnOfDeprecaredIcon = function (name) { + if (_this.gridOptions.icons && _this.gridOptions.icons[name]) { + console.warn("gridOptions.icons." + name + " is no longer supported. For information on how to style checkboxes and radio buttons, see https://www.ag-grid.com/javascript-grid-icons/"); } + }; + warnOfDeprecaredIcon('radioButtonOff'); + warnOfDeprecaredIcon('radioButtonOn'); + warnOfDeprecaredIcon('checkboxChecked'); + warnOfDeprecaredIcon('checkboxUnchecked'); + warnOfDeprecaredIcon('checkboxIndeterminate'); + // sets an initial calculation for the scrollbar width + this.getScrollbarWidth(); + }; + GridOptionsWrapper.prototype.checkColumnDefProperties = function () { + var _this = this; + if (this.gridOptions.columnDefs == null) { + return; + } + this.gridOptions.columnDefs.forEach(function (colDef) { + var userProperties = Object.getOwnPropertyNames(colDef); + var validProperties = __spread(_components_colDefUtil__WEBPACK_IMPORTED_MODULE_5__["ColDefUtil"].ALL_PROPERTIES, _components_colDefUtil__WEBPACK_IMPORTED_MODULE_5__["ColDefUtil"].FRAMEWORK_PROPERTIES); + _this.checkProperties(userProperties, validProperties, validProperties, 'colDef', 'https://www.ag-grid.com/javascript-grid-column-properties/'); }); }; - Component.prototype.createComponentFromElement = function (element, afterPreCreateCallback, paramsMap) { - var key = element.nodeName; - var componentParams = paramsMap ? paramsMap[element.getAttribute('ref')] : undefined; - var ComponentClass = this.agStackComponentsRegistry.getComponentClass(key); - if (ComponentClass) { - var newComponent = new ComponentClass(componentParams); - this.createBean(newComponent, null, afterPreCreateCallback); - return newComponent; + GridOptionsWrapper.prototype.checkGridOptionsProperties = function () { + var userProperties = Object.getOwnPropertyNames(this.gridOptions); + var validProperties = __spread(_propertyKeys__WEBPACK_IMPORTED_MODULE_4__["PropertyKeys"].ALL_PROPERTIES, _propertyKeys__WEBPACK_IMPORTED_MODULE_4__["PropertyKeys"].FRAMEWORK_PROPERTIES, Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["values"])(_eventKeys__WEBPACK_IMPORTED_MODULE_6__["Events"]).map(function (event) { return _components_componentUtil__WEBPACK_IMPORTED_MODULE_2__["ComponentUtil"].getCallbackForEvent(event); })); + var validPropertiesAndExceptions = __spread(validProperties, ['api', 'columnApi']); + this.checkProperties(userProperties, validPropertiesAndExceptions, validProperties, 'gridOptions', 'https://www.ag-grid.com/javascript-grid-properties/'); + }; + GridOptionsWrapper.prototype.checkProperties = function (userProperties, validPropertiesAndExceptions, validProperties, containerName, docsUrl) { + var invalidProperties = Object(_utils_fuzzyMatch__WEBPACK_IMPORTED_MODULE_13__["fuzzyCheckStrings"])(userProperties, validPropertiesAndExceptions, validProperties); + Object(_utils_object__WEBPACK_IMPORTED_MODULE_9__["iterateObject"])(invalidProperties, function (key, value) { + console.warn("ag-grid: invalid " + containerName + " property '" + key + "' did you mean any of these: " + value.slice(0, 8).join(", ")); + }); + if (Object.keys(invalidProperties).length > 0) { + console.warn("ag-grid: to see all the valid " + containerName + " properties please check: " + docsUrl); } - return null; }; - Component.prototype.copyAttributesFromNode = function (source, dest) { - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].iterateNamedNodeMap(source.attributes, function (name, value) { return dest.setAttribute(name, value); }); + GridOptionsWrapper.prototype.getDomDataKey = function () { + return this.domDataKey; }; - Component.prototype.swapComponentForNode = function (newComponent, parentNode, childNode) { - var eComponent = newComponent.getGui(); - parentNode.replaceChild(eComponent, childNode); - parentNode.insertBefore(document.createComment(childNode.nodeName), eComponent); - this.addDestroyFunc(this.destroyBean.bind(this, newComponent)); - this.swapInComponentForQuerySelectors(newComponent, childNode); + // returns the dom data, or undefined if not found + GridOptionsWrapper.prototype.getDomData = function (element, key) { + var domData = element[this.getDomDataKey()]; + return domData ? domData[key] : undefined; }; - Component.prototype.swapInComponentForQuerySelectors = function (newComponent, childNode) { - var thisNoType = this; - this.iterateOverQuerySelectors(function (querySelector) { - if (thisNoType[querySelector.attributeName] === childNode) { - thisNoType[querySelector.attributeName] = newComponent; - } - }); + GridOptionsWrapper.prototype.setDomData = function (element, key, value) { + var domDataKey = this.getDomDataKey(); + var domData = element[domDataKey]; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["missing"])(domData)) { + domData = {}; + element[domDataKey] = domData; + } + domData[key] = value; }; - Component.prototype.iterateOverQuerySelectors = function (action) { - var thisPrototype = Object.getPrototypeOf(this); - while (thisPrototype != null) { - var metaData = thisPrototype.__agComponentMetaData; - var currentProtoName = (thisPrototype.constructor).name; - if (metaData && metaData[currentProtoName] && metaData[currentProtoName].querySelectors) { - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].forEach(metaData[currentProtoName].querySelectors, function (querySelector) { return action(querySelector); }); - } - thisPrototype = Object.getPrototypeOf(thisPrototype); + GridOptionsWrapper.prototype.isRowSelection = function () { + return this.gridOptions.rowSelection === 'single' || this.gridOptions.rowSelection === 'multiple'; + }; + GridOptionsWrapper.prototype.isSuppressRowDeselection = function () { + return isTrue(this.gridOptions.suppressRowDeselection); + }; + GridOptionsWrapper.prototype.isRowSelectionMulti = function () { + return this.gridOptions.rowSelection === 'multiple'; + }; + GridOptionsWrapper.prototype.isRowMultiSelectWithClick = function () { + return isTrue(this.gridOptions.rowMultiSelectWithClick); + }; + GridOptionsWrapper.prototype.getContext = function () { + return this.gridOptions.context; + }; + GridOptionsWrapper.prototype.isPivotMode = function () { + return isTrue(this.gridOptions.pivotMode); + }; + GridOptionsWrapper.prototype.isSuppressExpandablePivotGroups = function () { + return isTrue(this.gridOptions.suppressExpandablePivotGroups); + }; + GridOptionsWrapper.prototype.getPivotColumnGroupTotals = function () { + return this.gridOptions.pivotColumnGroupTotals; + }; + GridOptionsWrapper.prototype.getPivotRowTotals = function () { + return this.gridOptions.pivotRowTotals; + }; + GridOptionsWrapper.prototype.isRowModelInfinite = function () { + return this.gridOptions.rowModelType === _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_INFINITE; + }; + GridOptionsWrapper.prototype.isRowModelViewport = function () { + return this.gridOptions.rowModelType === _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_VIEWPORT; + }; + GridOptionsWrapper.prototype.isRowModelServerSide = function () { + return this.gridOptions.rowModelType === _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE; + }; + GridOptionsWrapper.prototype.isRowModelDefault = function () { + return (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["missing"])(this.gridOptions.rowModelType) || + this.gridOptions.rowModelType === _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE); + }; + GridOptionsWrapper.prototype.isFullRowEdit = function () { + return this.gridOptions.editType === 'fullRow'; + }; + GridOptionsWrapper.prototype.isSuppressFocusAfterRefresh = function () { + return isTrue(this.gridOptions.suppressFocusAfterRefresh); + }; + GridOptionsWrapper.prototype.isSuppressBrowserResizeObserver = function () { + return isTrue(this.gridOptions.suppressBrowserResizeObserver); + }; + GridOptionsWrapper.prototype.isSuppressMaintainUnsortedOrder = function () { + return isTrue(this.gridOptions.suppressMaintainUnsortedOrder); + }; + GridOptionsWrapper.prototype.isSuppressClearOnFillReduction = function () { + return isTrue(this.gridOptions.suppressClearOnFillReduction); + }; + GridOptionsWrapper.prototype.isShowToolPanel = function () { + return isTrue(this.gridOptions.sideBar && Array.isArray(this.getSideBar().toolPanels)); + }; + GridOptionsWrapper.prototype.getSideBar = function () { + return this.gridOptions.sideBar; + }; + GridOptionsWrapper.prototype.isSuppressTouch = function () { + return isTrue(this.gridOptions.suppressTouch); + }; + GridOptionsWrapper.prototype.isMaintainColumnOrder = function () { + return isTrue(this.gridOptions.maintainColumnOrder); + }; + GridOptionsWrapper.prototype.isSuppressRowTransform = function () { + return isTrue(this.gridOptions.suppressRowTransform); + }; + GridOptionsWrapper.prototype.isSuppressColumnStateEvents = function () { + return isTrue(this.gridOptions.suppressColumnStateEvents); + }; + GridOptionsWrapper.prototype.isAllowDragFromColumnsToolPanel = function () { + return isTrue(this.gridOptions.allowDragFromColumnsToolPanel); + }; + GridOptionsWrapper.prototype.useAsyncEvents = function () { + return !isTrue(this.gridOptions.suppressAsyncEvents); + }; + GridOptionsWrapper.prototype.isEnableCellChangeFlash = function () { + return isTrue(this.gridOptions.enableCellChangeFlash); + }; + GridOptionsWrapper.prototype.getCellFlashDelay = function () { + return this.gridOptions.cellFlashDelay || 500; + }; + GridOptionsWrapper.prototype.getCellFadeDelay = function () { + return this.gridOptions.cellFadeDelay || 1000; + }; + GridOptionsWrapper.prototype.isGroupSelectsChildren = function () { + var result = isTrue(this.gridOptions.groupSelectsChildren); + if (result && this.isTreeData()) { + console.warn('AG Grid: groupSelectsChildren does not work with tree data'); + return false; } + return result; }; - Component.prototype.setTemplate = function (template, paramsMap) { - var eGui = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].loadTemplate(template); - this.setTemplateFromElement(eGui, paramsMap); + GridOptionsWrapper.prototype.isSuppressRowHoverHighlight = function () { + return isTrue(this.gridOptions.suppressRowHoverHighlight); }; - Component.prototype.setTemplateFromElement = function (element, paramsMap) { - this.eGui = element; - this.eGui.__agComponent = this; - this.addAnnotatedGuiEventListeners(); - this.wireQuerySelectors(); - // context will not be available when user sets template in constructor - if (!!this.getContext()) { - this.createChildComponentsFromTags(this.getGui(), paramsMap); + GridOptionsWrapper.prototype.isColumnHoverHighlight = function () { + return isTrue(this.gridOptions.columnHoverHighlight); + }; + GridOptionsWrapper.prototype.isGroupSelectsFiltered = function () { + return isTrue(this.gridOptions.groupSelectsFiltered); + }; + GridOptionsWrapper.prototype.isGroupHideOpenParents = function () { + return isTrue(this.gridOptions.groupHideOpenParents); + }; + GridOptionsWrapper.prototype.isGroupMaintainOrder = function () { + return isTrue(this.gridOptions.groupMaintainOrder); + }; + GridOptionsWrapper.prototype.getAutoGroupColumnDef = function () { + return this.gridOptions.autoGroupColumnDef; + }; + GridOptionsWrapper.prototype.isGroupMultiAutoColumn = function () { + if (this.gridOptions.groupDisplayType) { + return this.matchesGroupDisplayType('multipleColumns', this.gridOptions.groupDisplayType); } + // if we are doing hideOpenParents we also show multiple columns, otherwise hideOpenParents would not work + return isTrue(this.gridOptions.groupHideOpenParents); }; - Component.prototype.createChildComponentsPreConstruct = function () { - // ui exists if user sets template in constructor. when this happens, we have to wait for the context - // to be autoWired first before we can create child components. - if (!!this.getGui()) { - this.createChildComponentsFromTags(this.getGui()); + GridOptionsWrapper.prototype.isGroupUseEntireRow = function (pivotMode) { + // we never allow groupUseEntireRow if in pivot mode, otherwise we won't see the pivot values. + if (pivotMode) { + return false; } + return this.gridOptions.groupDisplayType ? + this.matchesGroupDisplayType('groupRows', this.gridOptions.groupDisplayType) : false; }; - Component.prototype.wireQuerySelectors = function () { - var _this = this; - if (!this.eGui) { - return; + GridOptionsWrapper.prototype.isGroupSuppressAutoColumn = function () { + var isCustomRowGroups = this.gridOptions.groupDisplayType ? + this.matchesGroupDisplayType('custom', this.gridOptions.groupDisplayType) : false; + if (isCustomRowGroups) { + return true; } - var thisNoType = this; - this.iterateOverQuerySelectors(function (querySelector) { - var resultOfQuery = _this.eGui.querySelector(querySelector.querySelector); - if (resultOfQuery) { - thisNoType[querySelector.attributeName] = resultOfQuery.__agComponent || resultOfQuery; - } - else { - // put debug msg in here if query selector fails??? - } - }); + return this.gridOptions.treeDataDisplayType ? + this.matchesTreeDataDisplayType('custom', this.gridOptions.treeDataDisplayType) : false; + }; + GridOptionsWrapper.prototype.isGroupRemoveSingleChildren = function () { + return isTrue(this.gridOptions.groupRemoveSingleChildren); + }; + GridOptionsWrapper.prototype.isGroupRemoveLowestSingleChildren = function () { + return isTrue(this.gridOptions.groupRemoveLowestSingleChildren); + }; + GridOptionsWrapper.prototype.isGroupIncludeFooter = function () { + return isTrue(this.gridOptions.groupIncludeFooter); + }; + GridOptionsWrapper.prototype.isGroupIncludeTotalFooter = function () { + return isTrue(this.gridOptions.groupIncludeTotalFooter); + }; + GridOptionsWrapper.prototype.isGroupSuppressBlankHeader = function () { + return isTrue(this.gridOptions.groupSuppressBlankHeader); + }; + GridOptionsWrapper.prototype.isSuppressRowClickSelection = function () { + return isTrue(this.gridOptions.suppressRowClickSelection); + }; + GridOptionsWrapper.prototype.isSuppressCellFocus = function () { + return isTrue(this.gridOptions.suppressCellFocus); + }; + GridOptionsWrapper.prototype.isSuppressMultiSort = function () { + return isTrue(this.gridOptions.suppressMultiSort); + }; + GridOptionsWrapper.prototype.isMultiSortKeyCtrl = function () { + return this.gridOptions.multiSortKey === 'ctrl'; + }; + GridOptionsWrapper.prototype.isPivotSuppressAutoColumn = function () { + return isTrue(this.gridOptions.pivotSuppressAutoColumn); + }; + GridOptionsWrapper.prototype.isSuppressDragLeaveHidesColumns = function () { + return isTrue(this.gridOptions.suppressDragLeaveHidesColumns); + }; + GridOptionsWrapper.prototype.isSuppressScrollOnNewData = function () { + return isTrue(this.gridOptions.suppressScrollOnNewData); + }; + GridOptionsWrapper.prototype.isSuppressScrollWhenPopupsAreOpen = function () { + return isTrue(this.gridOptions.suppressScrollWhenPopupsAreOpen); + }; + GridOptionsWrapper.prototype.isRowDragEntireRow = function () { + return isTrue(this.gridOptions.rowDragEntireRow); + }; + GridOptionsWrapper.prototype.isSuppressRowDrag = function () { + return isTrue(this.gridOptions.suppressRowDrag); + }; + GridOptionsWrapper.prototype.isRowDragManaged = function () { + return isTrue(this.gridOptions.rowDragManaged); + }; + GridOptionsWrapper.prototype.isSuppressMoveWhenRowDragging = function () { + return isTrue(this.gridOptions.suppressMoveWhenRowDragging); + }; + GridOptionsWrapper.prototype.isRowDragMultiRow = function () { + return isTrue(this.gridOptions.rowDragMultiRow); + }; + // returns either 'print', 'autoHeight' or 'normal' (normal is the default) + GridOptionsWrapper.prototype.getDomLayout = function () { + var domLayout = this.gridOptions.domLayout || _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_NORMAL; + var validLayouts = [ + _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_PRINT, + _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_AUTO_HEIGHT, + _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_NORMAL + ]; + if (validLayouts.indexOf(domLayout) === -1) { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_14__["doOnce"])(function () { + return console.warn("AG Grid: " + domLayout + " is not valid for DOM Layout, valid values are " + _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_NORMAL + ", " + _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_AUTO_HEIGHT + " and " + _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_PRINT); + }, 'warn about dom layout values'); + return _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_NORMAL; + } + return domLayout; + }; + GridOptionsWrapper.prototype.isSuppressHorizontalScroll = function () { + return isTrue(this.gridOptions.suppressHorizontalScroll); + }; + GridOptionsWrapper.prototype.isSuppressMaxRenderedRowRestriction = function () { + return isTrue(this.gridOptions.suppressMaxRenderedRowRestriction); + }; + GridOptionsWrapper.prototype.isExcludeChildrenWhenTreeDataFiltering = function () { + return isTrue(this.gridOptions.excludeChildrenWhenTreeDataFiltering); + }; + GridOptionsWrapper.prototype.isAlwaysShowHorizontalScroll = function () { + return isTrue(this.gridOptions.alwaysShowHorizontalScroll); + }; + GridOptionsWrapper.prototype.isAlwaysShowVerticalScroll = function () { + return isTrue(this.gridOptions.alwaysShowVerticalScroll); + }; + GridOptionsWrapper.prototype.isDebounceVerticalScrollbar = function () { + return isTrue(this.gridOptions.debounceVerticalScrollbar); + }; + GridOptionsWrapper.prototype.isSuppressLoadingOverlay = function () { + return isTrue(this.gridOptions.suppressLoadingOverlay); + }; + GridOptionsWrapper.prototype.isSuppressNoRowsOverlay = function () { + return isTrue(this.gridOptions.suppressNoRowsOverlay); + }; + GridOptionsWrapper.prototype.isSuppressFieldDotNotation = function () { + return isTrue(this.gridOptions.suppressFieldDotNotation); + }; + GridOptionsWrapper.prototype.getPinnedTopRowData = function () { + return this.gridOptions.pinnedTopRowData; + }; + GridOptionsWrapper.prototype.getPinnedBottomRowData = function () { + return this.gridOptions.pinnedBottomRowData; + }; + GridOptionsWrapper.prototype.isFunctionsPassive = function () { + return isTrue(this.gridOptions.functionsPassive); + }; + GridOptionsWrapper.prototype.isSuppressChangeDetection = function () { + return isTrue(this.gridOptions.suppressChangeDetection); + }; + GridOptionsWrapper.prototype.isSuppressAnimationFrame = function () { + return isTrue(this.gridOptions.suppressAnimationFrame); + }; + GridOptionsWrapper.prototype.getQuickFilterText = function () { + return this.gridOptions.quickFilterText; + }; + GridOptionsWrapper.prototype.isCacheQuickFilter = function () { + return isTrue(this.gridOptions.cacheQuickFilter); + }; + GridOptionsWrapper.prototype.isUnSortIcon = function () { + return isTrue(this.gridOptions.unSortIcon); + }; + GridOptionsWrapper.prototype.isSuppressMenuHide = function () { + return isTrue(this.gridOptions.suppressMenuHide); + }; + GridOptionsWrapper.prototype.isEnterMovesDownAfterEdit = function () { + return isTrue(this.gridOptions.enterMovesDownAfterEdit); + }; + GridOptionsWrapper.prototype.isEnterMovesDown = function () { + return isTrue(this.gridOptions.enterMovesDown); + }; + GridOptionsWrapper.prototype.isUndoRedoCellEditing = function () { + return isTrue(this.gridOptions.undoRedoCellEditing); + }; + GridOptionsWrapper.prototype.getUndoRedoCellEditingLimit = function () { + return toNumber(this.gridOptions.undoRedoCellEditingLimit); + }; + GridOptionsWrapper.prototype.getRowStyle = function () { + return this.gridOptions.rowStyle; + }; + GridOptionsWrapper.prototype.getRowClass = function () { + return this.gridOptions.rowClass; + }; + GridOptionsWrapper.prototype.getRowStyleFunc = function () { + return this.gridOptions.getRowStyle; + }; + GridOptionsWrapper.prototype.getRowClassFunc = function () { + return this.gridOptions.getRowClass; + }; + GridOptionsWrapper.prototype.rowClassRules = function () { + return this.gridOptions.rowClassRules; + }; + GridOptionsWrapper.prototype.getServerSideStoreType = function () { + return this.gridOptions.serverSideStoreType; + }; + GridOptionsWrapper.prototype.getServerSideStoreParamsFunc = function () { + return this.gridOptions.getServerSideStoreParams; + }; + GridOptionsWrapper.prototype.getCreateChartContainerFunc = function () { + return this.gridOptions.createChartContainer; + }; + GridOptionsWrapper.prototype.getPopupParent = function () { + return this.gridOptions.popupParent; + }; + GridOptionsWrapper.prototype.getBlockLoadDebounceMillis = function () { + return this.gridOptions.blockLoadDebounceMillis; + }; + GridOptionsWrapper.prototype.getPostProcessPopupFunc = function () { + return this.gridOptions.postProcessPopup; + }; + GridOptionsWrapper.prototype.getPaginationNumberFormatterFunc = function () { + return this.gridOptions.paginationNumberFormatter; + }; + GridOptionsWrapper.prototype.getChildCountFunc = function () { + return this.gridOptions.getChildCount; }; - Component.prototype.addAnnotatedGuiEventListeners = function () { - var _this = this; - this.removeAnnotatedGuiEventListeners(); - if (!this.eGui) { - return; - } - var listenerMethods = this.getAgComponentMetaData('guiListenerMethods'); - if (!listenerMethods) { - return; - } - if (!this.annotatedGuiListeners) { - this.annotatedGuiListeners = []; - } - listenerMethods.forEach(function (meta) { - var element = _this.getRefElement(meta.ref); - if (!element) { - return; - } - var listener = _this[meta.methodName].bind(_this); - element.addEventListener(meta.eventName, listener); - _this.annotatedGuiListeners.push({ eventName: meta.eventName, listener: listener, element: element }); - }); + GridOptionsWrapper.prototype.getIsApplyServerSideTransactionFunc = function () { + return this.gridOptions.isApplyServerSideTransaction; }; - Component.prototype.addAnnotatedGridEventListeners = function () { - var _this = this; - var listenerMetas = this.getAgComponentMetaData('gridListenerMethods'); - if (!listenerMetas) { - return; - } - listenerMetas.forEach(function (meta) { - var listener = _this[meta.methodName].bind(_this); - _this.addManagedListener(_this.eventService, meta.eventName, listener); - }); + GridOptionsWrapper.prototype.getDefaultGroupOrderComparator = function () { + return this.gridOptions.defaultGroupOrderComparator; }; - Component.prototype.getAgComponentMetaData = function (key) { - var res = []; - var thisProto = Object.getPrototypeOf(this); - while (thisProto != null) { - var metaData = thisProto.__agComponentMetaData; - var currentProtoName = (thisProto.constructor).name; - // IE does not support Function.prototype.name, so we need to extract - // the name using a RegEx - // from: https://matt.scharley.me/2012/03/monkey-patch-name-ie.html - if (currentProtoName === undefined) { - var funcNameRegex = /function\s([^(]{1,})\(/; - var results = funcNameRegex.exec(thisProto.constructor.toString()); - if (results && results.length > 1) { - currentProtoName = results[1].trim(); - } - } - if (metaData && metaData[currentProtoName] && metaData[currentProtoName][key]) { - res = res.concat(metaData[currentProtoName][key]); - } - thisProto = Object.getPrototypeOf(thisProto); - } - return res; + GridOptionsWrapper.prototype.getIsFullWidthCellFunc = function () { + return this.gridOptions.isFullWidthCell; }; - Component.prototype.removeAnnotatedGuiEventListeners = function () { - if (!this.annotatedGuiListeners) { - return; - } - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].forEach(this.annotatedGuiListeners, function (e) { - e.element.removeEventListener(e.eventName, e.listener); - }); - this.annotatedGuiListeners = []; + GridOptionsWrapper.prototype.getFullWidthCellRendererParams = function () { + return this.gridOptions.fullWidthCellRendererParams; }; - Component.prototype.getGui = function () { - return this.eGui; + GridOptionsWrapper.prototype.isEmbedFullWidthRows = function () { + return isTrue(this.gridOptions.embedFullWidthRows) || isTrue(this.gridOptions.deprecatedEmbedFullWidthRows); }; - Component.prototype.getFocusableElement = function () { - return this.eGui; + GridOptionsWrapper.prototype.isDetailRowAutoHeight = function () { + return isTrue(this.gridOptions.detailRowAutoHeight); }; - Component.prototype.setParentComponent = function (component) { - this.parentComponent = component; + GridOptionsWrapper.prototype.getSuppressKeyboardEventFunc = function () { + return this.gridOptions.suppressKeyboardEvent; }; - Component.prototype.getParentComponent = function () { - return this.parentComponent; + GridOptionsWrapper.prototype.getBusinessKeyForNodeFunc = function () { + return this.gridOptions.getBusinessKeyForNode; }; - // this method is for older code, that wants to provide the gui element, - // it is not intended for this to be in ag-Stack - Component.prototype.setGui = function (eGui) { - this.eGui = eGui; + GridOptionsWrapper.prototype.getApi = function () { + return this.gridOptions.api; }; - Component.prototype.queryForHtmlElement = function (cssSelector) { - return this.eGui.querySelector(cssSelector); + GridOptionsWrapper.prototype.getColumnApi = function () { + return this.gridOptions.columnApi; }; - Component.prototype.queryForHtmlInputElement = function (cssSelector) { - return this.eGui.querySelector(cssSelector); + GridOptionsWrapper.prototype.isReadOnlyEdit = function () { + return isTrue(this.gridOptions.readOnlyEdit); + ; }; - Component.prototype.appendChild = function (newChild, container) { - if (!container) { - container = this.eGui; - } - if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].isNodeOrElement(newChild)) { - container.appendChild(newChild); - } - else { - var childComponent = newChild; - container.appendChild(childComponent.getGui()); - this.addDestroyFunc(this.destroyBean.bind(this, childComponent)); - } + GridOptionsWrapper.prototype.isImmutableData = function () { + // we used to have a property immutableData for this. however this was deprecated + // in favour of having Immutable Data on by default when getRowId is provided + return this.gridOptions.getRowId != null || isTrue(this.gridOptions.immutableData); }; - Component.prototype.isDisplayed = function () { - return this.displayed; + GridOptionsWrapper.prototype.isEnsureDomOrder = function () { + return isTrue(this.gridOptions.ensureDomOrder); }; - Component.prototype.setVisible = function (visible) { - if (visible !== this.visible) { - this.visible = visible; - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].setVisible(this.eGui, visible); + GridOptionsWrapper.prototype.isEnableCharts = function () { + if (isTrue(this.gridOptions.enableCharts)) { + return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_10__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__["ModuleNames"].GridChartsModule, 'enableCharts'); } + return false; }; - Component.prototype.setDisplayed = function (displayed) { - if (displayed !== this.displayed) { - this.displayed = displayed; - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].setDisplayed(this.eGui, displayed); - var event_1 = { - type: Component.EVENT_DISPLAYED_CHANGED, - visible: this.displayed - }; - this.dispatchEvent(event_1); - } + GridOptionsWrapper.prototype.getColResizeDefault = function () { + return this.gridOptions.colResizeDefault; }; - Component.prototype.destroy = function () { - this.removeAnnotatedGuiEventListeners(); - _super.prototype.destroy.call(this); + GridOptionsWrapper.prototype.isSingleClickEdit = function () { + return isTrue(this.gridOptions.singleClickEdit); }; - Component.prototype.addGuiEventListener = function (event, listener) { - var _this = this; - this.eGui.addEventListener(event, listener); - this.addDestroyFunc(function () { return _this.eGui.removeEventListener(event, listener); }); + GridOptionsWrapper.prototype.isSuppressClickEdit = function () { + return isTrue(this.gridOptions.suppressClickEdit); }; - Component.prototype.addCssClass = function (className) { - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(this.eGui, className); + GridOptionsWrapper.prototype.isStopEditingWhenCellsLoseFocus = function () { + return isTrue(this.gridOptions.stopEditingWhenCellsLoseFocus); }; - Component.prototype.removeCssClass = function (className) { - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].removeCssClass(this.eGui, className); + GridOptionsWrapper.prototype.getGroupDefaultExpanded = function () { + return this.gridOptions.groupDefaultExpanded; }; - Component.prototype.addOrRemoveCssClass = function (className, addOrRemove) { - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(this.eGui, className, addOrRemove); + GridOptionsWrapper.prototype.getMaxConcurrentDatasourceRequests = function () { + var res = toNumber(this.gridOptions.maxConcurrentDatasourceRequests); + if (res == null) { + return 2; + } // 2 is the default + if (res <= 0) { + return; + } // negative number, eg -1, means no max restriction + return res; }; - Component.prototype.getAttribute = function (key) { - var eGui = this.eGui; - return eGui ? eGui.getAttribute(key) : null; + GridOptionsWrapper.prototype.getMaxBlocksInCache = function () { + return this.gridOptions.maxBlocksInCache; }; - Component.prototype.getRefElement = function (refName) { - return this.queryForHtmlElement("[ref=\"" + refName + "\"]"); + GridOptionsWrapper.prototype.getCacheOverflowSize = function () { + return this.gridOptions.cacheOverflowSize; }; - Component.EVENT_DISPLAYED_CHANGED = 'displayedChanged'; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('agStackComponentsRegistry') - ], Component.prototype, "agStackComponentsRegistry", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PreConstruct"] - ], Component.prototype, "createChildComponentsPreConstruct", null); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], Component.prototype, "addAnnotatedGridEventListeners", null); - return Component; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); - - - -/***/ }), -/* 57 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "QuerySelector", function() { return QuerySelector; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RefSelector", function() { return RefSelector; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridListener", function() { return GridListener; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GuiListener", function() { return GuiListener; }); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -function QuerySelector(selector) { - return querySelectorFunc.bind(this, selector); -} -function RefSelector(ref) { - return querySelectorFunc.bind(this, "[ref=" + ref + "]"); -} -function querySelectorFunc(selector, classPrototype, methodOrAttributeName, index) { - if (selector === null) { - console.error("ag-Grid: QuerySelector selector should not be null"); - return; - } - if (typeof index === "number") { - console.error("ag-Grid: QuerySelector should be on an attribute"); - return; - } - addToObjectProps(classPrototype, 'querySelectors', { - attributeName: methodOrAttributeName, - querySelector: selector - }); -} -// think we should take this out, put property bindings on the -function GridListener(eventName) { - return gridListenerFunc.bind(this, eventName); -} -function gridListenerFunc(eventName, target, methodName) { - if (eventName == null) { - console.error("ag-Grid: GridListener eventName is missing"); - return; - } - addToObjectProps(target, 'gridListenerMethods', { - methodName: methodName, - eventName: eventName - }); -} -// think we should take this out, put property bindings on the -function GuiListener(ref, eventName) { - return guiListenerFunc.bind(this, ref, eventName); -} -function guiListenerFunc(ref, eventName, target, methodName) { - if (eventName == null) { - console.error("ag-Grid: GuiListener eventName is missing"); - return; - } - addToObjectProps(target, 'guiListenerMethods', { - methodName: methodName, - eventName: eventName, - ref: ref - }); -} -// // think we should take this out, put property bindings on the -// export function Method(eventName?: string): Function { -// return methodFunc.bind(this, eventName); -// } -// -// function methodFunc(alias: string, target: Object, methodName: string) { -// if (alias === null) { -// console.error("ag-Grid: EventListener eventName should not be null"); -// return; -// } -// -// addToObjectProps(target, 'methods', { -// methodName: methodName, -// alias: alias -// }); -// } -function addToObjectProps(target, key, value) { - // it's an attribute on the class - var props = getOrCreateProps(target, target.constructor.name); - if (!props[key]) { - props[key] = []; - } - props[key].push(value); -} -function getOrCreateProps(target, instanceName) { - if (!target.__agComponentMetaData) { - target.__agComponentMetaData = {}; - } - if (!target.__agComponentMetaData[instanceName]) { - target.__agComponentMetaData[instanceName] = {}; - } - return target.__agComponentMetaData[instanceName]; -} - - -/***/ }), -/* 58 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DateFilter", function() { return DateFilter; }); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(59); -/* harmony import */ var _simpleFilter__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(60); -/* harmony import */ var _scalarFilter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(63); -/* harmony import */ var _utils_date__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(18); -/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(12); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + GridOptionsWrapper.prototype.getPaginationPageSize = function () { + return toNumber(this.gridOptions.paginationPageSize); }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + GridOptionsWrapper.prototype.isPaginateChildRows = function () { + var shouldPaginate = this.isGroupRemoveSingleChildren() || this.isGroupRemoveLowestSingleChildren(); + if (shouldPaginate) { + return true; + } + return isTrue(this.gridOptions.paginateChildRows); }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - - - - -var DateFilter = /** @class */ (function (_super) { - __extends(DateFilter, _super); - function DateFilter() { - return _super !== null && _super.apply(this, arguments) || this; - } - DateFilter.prototype.mapRangeFromModel = function (filterModel) { - // unlike the other filters, we do two things here: - // 1) allow for different attribute names (same as done for other filters) (eg the 'from' and 'to' - // are in different locations in Date and Number filter models) - // 2) convert the type (because Date filter uses Dates, however model is 'string') - // - // NOTE: The conversion of string to date also removes the timezone - i.e. when user picks - // a date from the UI, it will have timezone info in it. This is lost when creating - // the model. When we recreate the date again here, it's without a timezone. - return { - from: Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["parseDateTimeFromString"])(filterModel.dateFrom), - to: Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["parseDateTimeFromString"])(filterModel.dateTo) - }; + GridOptionsWrapper.prototype.getCacheBlockSize = function () { + return oneOrGreater(this.gridOptions.cacheBlockSize); }; - DateFilter.prototype.setValueFromFloatingFilter = function (value) { - if (value != null) { - var dateFrom = Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["parseDateTimeFromString"])(value); - this.dateCondition1FromComp.setDate(dateFrom); - } - else { - this.dateCondition1FromComp.setDate(null); - } - this.dateCondition1ToComp.setDate(null); - this.dateCondition2FromComp.setDate(null); - this.dateCondition2ToComp.setDate(null); + GridOptionsWrapper.prototype.getInfiniteInitialRowCount = function () { + return this.gridOptions.infiniteInitialRowCount; }; - DateFilter.prototype.setConditionIntoUi = function (model, position) { - var _a = model ? - [Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["parseDateTimeFromString"])(model.dateFrom), Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["parseDateTimeFromString"])(model.dateTo)] : - [null, null], dateFrom = _a[0], dateTo = _a[1]; - var _b = this.getFromToComponents(position), compFrom = _b[0], compTo = _b[1]; - compFrom.setDate(dateFrom); - compTo.setDate(dateTo); + GridOptionsWrapper.prototype.isPurgeClosedRowNodes = function () { + return isTrue(this.gridOptions.purgeClosedRowNodes); }; - DateFilter.prototype.resetUiToDefaults = function (silent) { - var _this = this; - return _super.prototype.resetUiToDefaults.call(this, silent).then(function () { - _this.dateCondition1FromComp.setDate(null); - _this.dateCondition1ToComp.setDate(null); - _this.dateCondition2FromComp.setDate(null); - _this.dateCondition2ToComp.setDate(null); - }); + GridOptionsWrapper.prototype.isSuppressPaginationPanel = function () { + return isTrue(this.gridOptions.suppressPaginationPanel); }; - DateFilter.prototype.comparator = function () { - return this.dateFilterParams.comparator ? this.dateFilterParams.comparator : this.defaultComparator.bind(this); + GridOptionsWrapper.prototype.getRowData = function () { + return this.gridOptions.rowData; }; - DateFilter.prototype.defaultComparator = function (filterDate, cellValue) { - // The default comparator assumes that the cellValue is a date - var cellAsDate = cellValue; - if (cellValue == null || cellAsDate < filterDate) { - return -1; - } - if (cellAsDate > filterDate) { - return 1; - } - return 0; + GridOptionsWrapper.prototype.isEnableRtl = function () { + return isTrue(this.gridOptions.enableRtl); }; - DateFilter.prototype.setParams = function (params) { - _super.prototype.setParams.call(this, params); - this.dateFilterParams = params; - this.createDateComponents(); + GridOptionsWrapper.prototype.getRowGroupPanelShow = function () { + return this.gridOptions.rowGroupPanelShow; }; - DateFilter.prototype.createDateComponents = function () { - var _this = this; - // params to pass to all four date comps - var dateComponentParams = { - onDateChanged: function () { return _this.onUiChanged(); }, - filterParams: this.dateFilterParams - }; - this.dateCondition1FromComp = new _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__["DateCompWrapper"](this.getContext(), this.userComponentFactory, dateComponentParams, this.eCondition1PanelFrom); - this.dateCondition1ToComp = new _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__["DateCompWrapper"](this.getContext(), this.userComponentFactory, dateComponentParams, this.eCondition1PanelTo); - this.dateCondition2FromComp = new _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__["DateCompWrapper"](this.getContext(), this.userComponentFactory, dateComponentParams, this.eCondition2PanelFrom); - this.dateCondition2ToComp = new _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__["DateCompWrapper"](this.getContext(), this.userComponentFactory, dateComponentParams, this.eCondition2PanelTo); - this.addDestroyFunc(function () { - _this.dateCondition1FromComp.destroy(); - _this.dateCondition1ToComp.destroy(); - _this.dateCondition2FromComp.destroy(); - _this.dateCondition2ToComp.destroy(); - }); + GridOptionsWrapper.prototype.getPivotPanelShow = function () { + return this.gridOptions.pivotPanelShow; }; - DateFilter.prototype.getDefaultFilterOptions = function () { - return DateFilter.DEFAULT_FILTER_OPTIONS; + GridOptionsWrapper.prototype.isAngularCompileRows = function () { + return isTrue(this.gridOptions.angularCompileRows); }; - DateFilter.prototype.createValueTemplate = function (position) { - var pos = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_3__["ConditionPosition"].One ? '1' : '2'; - return /* html */ "\n
\n
\n
\n
\n
\n
"; + GridOptionsWrapper.prototype.isAngularCompileFilters = function () { + return isTrue(this.gridOptions.angularCompileFilters); }; - DateFilter.prototype.isConditionUiComplete = function (position) { - var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_3__["ConditionPosition"].One; - var option = positionOne ? this.getCondition1Type() : this.getCondition2Type(); - if (option === _simpleFilter__WEBPACK_IMPORTED_MODULE_3__["SimpleFilter"].EMPTY) { - return false; - } - if (this.doesFilterHaveHiddenInput(option)) { - return true; - } - var _a = this.getFromToComponents(position), compFrom = _a[0], compTo = _a[1]; - return compFrom.getDate() != null && (option !== _simpleFilter__WEBPACK_IMPORTED_MODULE_3__["SimpleFilter"].IN_RANGE || compTo.getDate() != null); + GridOptionsWrapper.prototype.isDebug = function () { + return isTrue(this.gridOptions.debug); }; - DateFilter.prototype.areSimpleModelsEqual = function (aSimple, bSimple) { - return aSimple.dateFrom === bSimple.dateFrom - && aSimple.dateTo === bSimple.dateTo - && aSimple.type === bSimple.type; + GridOptionsWrapper.prototype.getColumnDefs = function () { + return this.gridOptions.columnDefs; }; - // needed for creating filter model - DateFilter.prototype.getFilterType = function () { - return DateFilter.FILTER_TYPE; + GridOptionsWrapper.prototype.getColumnTypes = function () { + return this.gridOptions.columnTypes; }; - DateFilter.prototype.createCondition = function (position) { - var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_3__["ConditionPosition"].One; - var type = positionOne ? this.getCondition1Type() : this.getCondition2Type(); - var _a = this.getFromToComponents(position), compFrom = _a[0], compTo = _a[1]; - return { - dateFrom: Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["serialiseDate"])(compFrom.getDate()), - dateTo: Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["serialiseDate"])(compTo.getDate()), - type: type, - filterType: DateFilter.FILTER_TYPE - }; + GridOptionsWrapper.prototype.getDatasource = function () { + return this.gridOptions.datasource; }; - DateFilter.prototype.resetPlaceholder = function () { - var translate = this.gridOptionsWrapper.getLocaleTextFunc(); - var placeholder = translate('dateFormatOoo', 'yyyy-mm-dd'); - this.dateCondition1FromComp.setInputPlaceholder(placeholder); - this.dateCondition1ToComp.setInputPlaceholder(placeholder); - this.dateCondition2FromComp.setInputPlaceholder(placeholder); - this.dateCondition2ToComp.setInputPlaceholder(placeholder); - }; - DateFilter.prototype.updateUiVisibility = function () { - _super.prototype.updateUiVisibility.call(this); - this.resetPlaceholder(); - var condition1Type = this.getCondition1Type(); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["setDisplayed"])(this.eCondition1PanelFrom, this.showValueFrom(condition1Type)); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["setDisplayed"])(this.eCondition1PanelTo, this.showValueTo(condition1Type)); - var condition2Type = this.getCondition2Type(); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["setDisplayed"])(this.eCondition2PanelFrom, this.showValueFrom(condition2Type)); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["setDisplayed"])(this.eCondition2PanelTo, this.showValueTo(condition2Type)); - }; - DateFilter.prototype.getFromToComponents = function (position) { - return position === _simpleFilter__WEBPACK_IMPORTED_MODULE_3__["ConditionPosition"].One ? - [this.dateCondition1FromComp, this.dateCondition1ToComp] : - [this.dateCondition2FromComp, this.dateCondition2ToComp]; - }; - DateFilter.FILTER_TYPE = 'date'; - DateFilter.DEFAULT_FILTER_OPTIONS = [ - _scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"].EQUALS, - _scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"].GREATER_THAN, - _scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"].LESS_THAN, - _scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"].NOT_EQUAL, - _scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"].IN_RANGE - ]; - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eCondition1PanelFrom') - ], DateFilter.prototype, "eCondition1PanelFrom", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eCondition1PanelTo') - ], DateFilter.prototype, "eCondition1PanelTo", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eCondition2PanelFrom') - ], DateFilter.prototype, "eCondition2PanelFrom", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eCondition2PanelTo') - ], DateFilter.prototype, "eCondition2PanelTo", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('userComponentFactory') - ], DateFilter.prototype, "userComponentFactory", void 0); - return DateFilter; -}(_scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"])); - - - -/***/ }), -/* 59 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DateCompWrapper", function() { return DateCompWrapper; }); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -/** Provides sync access to async component. Date component can be lazy created - this class encapsulates - * this by keeping value locally until DateComp has loaded, then passing DateComp the value. */ -var DateCompWrapper = /** @class */ (function () { - function DateCompWrapper(context, userComponentFactory, dateComponentParams, eParent) { - var _this = this; - this.alive = true; - this.context = context; - userComponentFactory.newDateComponent(dateComponentParams).then(function (dateComp) { - // because async, check the filter still exists after component comes back - if (!_this.alive) { - context.destroyBean(dateComp); - return; - } - _this.dateComp = dateComp; - eParent.appendChild(dateComp.getGui()); - if (dateComp.afterGuiAttached) { - dateComp.afterGuiAttached(); - } - if (_this.tempValue) { - dateComp.setDate(_this.tempValue); - } - }); - } - DateCompWrapper.prototype.destroy = function () { - this.alive = false; - this.dateComp = this.context.destroyBean(this.dateComp); + GridOptionsWrapper.prototype.getViewportDatasource = function () { + return this.gridOptions.viewportDatasource; }; - DateCompWrapper.prototype.getDate = function () { - return this.dateComp ? this.dateComp.getDate() : this.tempValue; + GridOptionsWrapper.prototype.getServerSideDatasource = function () { + return this.gridOptions.serverSideDatasource; }; - DateCompWrapper.prototype.setDate = function (value) { - if (this.dateComp) { - this.dateComp.setDate(value); - } - else { - this.tempValue = value; - } + GridOptionsWrapper.prototype.isAccentedSort = function () { + return isTrue(this.gridOptions.accentedSort); }; - DateCompWrapper.prototype.setInputPlaceholder = function (placeholder) { - if (this.dateComp && this.dateComp.setInputPlaceholder) { - this.dateComp.setInputPlaceholder(placeholder); - } + GridOptionsWrapper.prototype.isEnableBrowserTooltips = function () { + return isTrue(this.gridOptions.enableBrowserTooltips); }; - return DateCompWrapper; -}()); - - - -/***/ }), -/* 60 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ConditionPosition", function() { return ConditionPosition; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SimpleFilter", function() { return SimpleFilter; }); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57); -/* harmony import */ var _optionsFactory__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(61); -/* harmony import */ var _providedFilter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(62); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); -/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(17); -/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(12); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + GridOptionsWrapper.prototype.isEnableCellExpressions = function () { + return isTrue(this.gridOptions.enableCellExpressions); }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + GridOptionsWrapper.prototype.isEnableGroupEdit = function () { + return isTrue(this.gridOptions.enableGroupEdit); }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - - - -var ConditionPosition; -(function (ConditionPosition) { - ConditionPosition[ConditionPosition["One"] = 0] = "One"; - ConditionPosition[ConditionPosition["Two"] = 1] = "Two"; -})(ConditionPosition || (ConditionPosition = {})); -var DEFAULT_TRANSLATIONS = { - filterOoo: 'Filter...', - empty: 'Choose One', - equals: 'Equals', - notEqual: 'Not equal', - lessThan: 'Less than', - greaterThan: 'Greater than', - inRange: 'In range', - inRangeStart: 'From', - inRangeEnd: 'To', - lessThanOrEqual: 'Less than or equals', - greaterThanOrEqual: 'Greater than or equals', - contains: 'Contains', - notContains: 'Not contains', - startsWith: 'Starts with', - endsWith: 'Ends with', - andCondition: 'AND', - orCondition: 'OR', -}; -/** - * Every filter with a dropdown where the user can specify a comparing type against the filter values - */ -var SimpleFilter = /** @class */ (function (_super) { - __extends(SimpleFilter, _super); - function SimpleFilter() { - return _super !== null && _super.apply(this, arguments) || this; - } - // returns true if this type requires a 'from' field, eg any filter that requires at least one text value - SimpleFilter.prototype.showValueFrom = function (type) { - return !this.doesFilterHaveHiddenInput(type) && type !== SimpleFilter.EMPTY; + GridOptionsWrapper.prototype.isSuppressMiddleClickScrolls = function () { + return isTrue(this.gridOptions.suppressMiddleClickScrolls); + }; + GridOptionsWrapper.prototype.isPreventDefaultOnContextMenu = function () { + return isTrue(this.gridOptions.preventDefaultOnContextMenu); + }; + GridOptionsWrapper.prototype.isSuppressPreventDefaultOnMouseWheel = function () { + return isTrue(this.gridOptions.suppressPreventDefaultOnMouseWheel); + }; + GridOptionsWrapper.prototype.isSuppressColumnVirtualisation = function () { + return isTrue(this.gridOptions.suppressColumnVirtualisation); + }; + GridOptionsWrapper.prototype.isSuppressRowVirtualisation = function () { + return isTrue(this.gridOptions.suppressRowVirtualisation); + }; + GridOptionsWrapper.prototype.isSuppressContextMenu = function () { + return isTrue(this.gridOptions.suppressContextMenu); + }; + GridOptionsWrapper.prototype.isAllowContextMenuWithControlKey = function () { + return isTrue(this.gridOptions.allowContextMenuWithControlKey); + }; + GridOptionsWrapper.prototype.isSuppressCopyRowsToClipboard = function () { + return isTrue(this.gridOptions.suppressCopyRowsToClipboard); }; - // returns true if this type requires a 'to' field, currently only 'range' returns true - SimpleFilter.prototype.showValueTo = function (type) { - return type === SimpleFilter.IN_RANGE; + GridOptionsWrapper.prototype.isCopyHeadersToClipboard = function () { + return isTrue(this.gridOptions.copyHeadersToClipboard); }; - // floating filter calls this when user applies filter from floating filter - SimpleFilter.prototype.onFloatingFilterChanged = function (type, value) { - this.setTypeFromFloatingFilter(type); - this.setValueFromFloatingFilter(value); - this.onUiChanged(true); + GridOptionsWrapper.prototype.isCopyGroupHeadersToClipboard = function () { + return isTrue(this.gridOptions.copyGroupHeadersToClipboard); }; - SimpleFilter.prototype.setTypeFromFloatingFilter = function (type) { - this.eType1.setValue(type); - this.eType2.setValue(this.optionsFactory.getDefaultOption()); - this.eJoinOperatorAnd.setValue(true); + GridOptionsWrapper.prototype.isSuppressClipboardPaste = function () { + return isTrue(this.gridOptions.suppressClipboardPaste); }; - SimpleFilter.prototype.getModelFromUi = function () { - if (!this.isConditionUiComplete(ConditionPosition.One)) { - return null; - } - if (this.isAllowTwoConditions() && this.isConditionUiComplete(ConditionPosition.Two)) { - return { - filterType: this.getFilterType(), - operator: this.getJoinOperator(), - condition1: this.createCondition(ConditionPosition.One), - condition2: this.createCondition(ConditionPosition.Two) - }; - } - return this.createCondition(ConditionPosition.One); + GridOptionsWrapper.prototype.isSuppressLastEmptyLineOnPaste = function () { + return isTrue(this.gridOptions.suppressLastEmptyLineOnPaste); + }; + GridOptionsWrapper.prototype.isPagination = function () { + return isTrue(this.gridOptions.pagination); }; - SimpleFilter.prototype.getCondition1Type = function () { - return this.eType1.getValue(); + GridOptionsWrapper.prototype.isSuppressEnterpriseResetOnNewColumns = function () { + return isTrue(this.gridOptions.suppressEnterpriseResetOnNewColumns); }; - SimpleFilter.prototype.getCondition2Type = function () { - return this.eType2.getValue(); + GridOptionsWrapper.prototype.getProcessDataFromClipboardFunc = function () { + return this.gridOptions.processDataFromClipboard; }; - SimpleFilter.prototype.getJoinOperator = function () { - return this.eJoinOperatorOr.getValue() === true ? 'OR' : 'AND'; + GridOptionsWrapper.prototype.getAsyncTransactionWaitMillis = function () { + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["exists"])(this.gridOptions.asyncTransactionWaitMillis) ? this.gridOptions.asyncTransactionWaitMillis : _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].BATCH_WAIT_MILLIS; }; - SimpleFilter.prototype.areModelsEqual = function (a, b) { - // both are missing - if (!a && !b) { - return true; - } - // one is missing, other present - if ((!a && b) || (a && !b)) { - return false; - } - // one is combined, the other is not - var aIsSimple = !a.operator; - var bIsSimple = !b.operator; - var oneSimpleOneCombined = (!aIsSimple && bIsSimple) || (aIsSimple && !bIsSimple); - if (oneSimpleOneCombined) { + GridOptionsWrapper.prototype.isSuppressMovableColumns = function () { + return isTrue(this.gridOptions.suppressMovableColumns); + }; + GridOptionsWrapper.prototype.isAnimateRows = function () { + // never allow animating if enforcing the row order + if (this.isEnsureDomOrder()) { return false; } - var res; - // otherwise both present, so compare - if (aIsSimple) { - var aSimple = a; - var bSimple = b; - res = this.areSimpleModelsEqual(aSimple, bSimple); + return isTrue(this.gridOptions.animateRows); + }; + GridOptionsWrapper.prototype.isSuppressColumnMoveAnimation = function () { + return isTrue(this.gridOptions.suppressColumnMoveAnimation); + }; + GridOptionsWrapper.prototype.isSuppressAggFuncInHeader = function () { + return isTrue(this.gridOptions.suppressAggFuncInHeader); + }; + GridOptionsWrapper.prototype.isSuppressAggAtRootLevel = function () { + return isTrue(this.gridOptions.suppressAggAtRootLevel); + }; + GridOptionsWrapper.prototype.isSuppressAggFilteredOnly = function () { + return isTrue(this.gridOptions.suppressAggFilteredOnly); + }; + GridOptionsWrapper.prototype.isShowOpenedGroup = function () { + return isTrue(this.gridOptions.showOpenedGroup); + }; + GridOptionsWrapper.prototype.isReactUi = function () { + return isTrue(this.gridOptions.reactUi); + }; + GridOptionsWrapper.prototype.isSuppressReactUi = function () { + return isTrue(this.gridOptions.suppressReactUi); + }; + GridOptionsWrapper.prototype.isEnableRangeSelection = function () { + return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_10__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__["ModuleNames"].RangeSelectionModule) && isTrue(this.gridOptions.enableRangeSelection); + }; + GridOptionsWrapper.prototype.isEnableRangeHandle = function () { + return isTrue(this.gridOptions.enableRangeHandle); + }; + GridOptionsWrapper.prototype.isEnableFillHandle = function () { + return isTrue(this.gridOptions.enableFillHandle); + }; + GridOptionsWrapper.prototype.getFillHandleDirection = function () { + var direction = this.gridOptions.fillHandleDirection; + if (!direction) { + return 'xy'; } - else { - var aCombined = a; - var bCombined = b; - res = aCombined.operator === bCombined.operator - && this.areSimpleModelsEqual(aCombined.condition1, bCombined.condition1) - && this.areSimpleModelsEqual(aCombined.condition2, bCombined.condition2); + if (direction !== 'x' && direction !== 'y' && direction !== 'xy') { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_14__["doOnce"])(function () { return console.warn("AG Grid: valid values for fillHandleDirection are 'x', 'y' and 'xy'. Default to 'xy'."); }, 'warn invalid fill direction'); + return 'xy'; } - return res; + return direction; }; - SimpleFilter.prototype.setModelIntoUi = function (model) { - var isCombined = model.operator; - if (isCombined) { - var combinedModel = model; - var orChecked = combinedModel.operator === 'OR'; - this.eJoinOperatorAnd.setValue(!orChecked); - this.eJoinOperatorOr.setValue(orChecked); - this.eType1.setValue(combinedModel.condition1.type); - this.eType2.setValue(combinedModel.condition2.type); - this.setConditionIntoUi(combinedModel.condition1, ConditionPosition.One); - this.setConditionIntoUi(combinedModel.condition2, ConditionPosition.Two); + GridOptionsWrapper.prototype.getFillOperation = function () { + return this.gridOptions.fillOperation; + }; + GridOptionsWrapper.prototype.isSuppressMultiRangeSelection = function () { + return isTrue(this.gridOptions.suppressMultiRangeSelection); + }; + GridOptionsWrapper.prototype.isPaginationAutoPageSize = function () { + return isTrue(this.gridOptions.paginationAutoPageSize); + }; + GridOptionsWrapper.prototype.isRememberGroupStateWhenNewData = function () { + return isTrue(this.gridOptions.rememberGroupStateWhenNewData); + }; + GridOptionsWrapper.prototype.getIcons = function () { + return this.gridOptions.icons; + }; + GridOptionsWrapper.prototype.getAggFuncs = function () { + return this.gridOptions.aggFuncs; + }; + GridOptionsWrapper.prototype.getSortingOrder = function () { + return this.gridOptions.sortingOrder; + }; + GridOptionsWrapper.prototype.getAlignedGrids = function () { + return this.gridOptions.alignedGrids; + }; + GridOptionsWrapper.prototype.isMasterDetail = function () { + var masterDetail = isTrue(this.gridOptions.masterDetail); + if (masterDetail) { + return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_10__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__["ModuleNames"].MasterDetailModule, 'masterDetail'); } else { - var simpleModel = model; - this.eJoinOperatorAnd.setValue(true); - this.eJoinOperatorOr.setValue(false); - this.eType1.setValue(simpleModel.type); - this.eType2.setValue(this.optionsFactory.getDefaultOption()); - this.setConditionIntoUi(simpleModel, ConditionPosition.One); - this.setConditionIntoUi(null, ConditionPosition.Two); + return false; } - return _utils__WEBPACK_IMPORTED_MODULE_3__["Promise"].resolve(); }; - SimpleFilter.prototype.doesFilterPass = function (params) { - var model = this.getModel(); - var isCombined = model.operator; - if (isCombined) { - var combinedModel = model; - var firstResult = this.individualConditionPasses(params, combinedModel.condition1); - var secondResult = this.individualConditionPasses(params, combinedModel.condition2); - if (combinedModel.operator === 'AND') { - return firstResult && secondResult; - } - return firstResult || secondResult; + GridOptionsWrapper.prototype.isKeepDetailRows = function () { + return isTrue(this.gridOptions.keepDetailRows); + }; + GridOptionsWrapper.prototype.getKeepDetailRowsCount = function () { + var keepDetailRowsCount = this.gridOptions.keepDetailRowsCount; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["exists"])(keepDetailRowsCount) && keepDetailRowsCount > 0) { + return this.gridOptions.keepDetailRowsCount; } - var simpleModel = model; - var result = this.individualConditionPasses(params, simpleModel); - return result; + return DEFAULT_KEEP_DETAIL_ROW_COUNT; }; - SimpleFilter.prototype.setParams = function (params) { - _super.prototype.setParams.call(this, params); - this.optionsFactory = new _optionsFactory__WEBPACK_IMPORTED_MODULE_1__["OptionsFactory"](); - this.optionsFactory.init(params, this.getDefaultFilterOptions()); - this.allowTwoConditions = !params.suppressAndOrCondition; - this.putOptionsIntoDropdown(); - this.addChangedListeners(); + GridOptionsWrapper.prototype.getIsRowMasterFunc = function () { + return this.gridOptions.isRowMaster; }; - SimpleFilter.prototype.putOptionsIntoDropdown = function () { - var _this = this; - var filterOptions = this.optionsFactory.getFilterOptions(); - Object(_utils_array__WEBPACK_IMPORTED_MODULE_4__["forEach"])(filterOptions, function (option) { - var value; - var text; - if (typeof option === 'string') { - value = option; - text = _this.translate(value); - } - else { - value = option.displayKey; - var customOption = _this.optionsFactory.getCustomOption(value); - text = customOption ? customOption.displayName : _this.translate(value); - } - var createOption = function () { return ({ value: value, text: text }); }; - _this.eType1.addOption(createOption()); - _this.eType2.addOption(createOption()); - }); - var readOnly = filterOptions.length <= 1; - this.eType1.setDisabled(readOnly); - this.eType2.setDisabled(readOnly); + GridOptionsWrapper.prototype.getIsRowSelectableFunc = function () { + return this.gridOptions.isRowSelectable; }; - SimpleFilter.prototype.isAllowTwoConditions = function () { - return this.allowTwoConditions; + GridOptionsWrapper.prototype.getGroupRowRendererParams = function () { + return this.gridOptions.groupRowRendererParams; }; - SimpleFilter.prototype.createBodyTemplate = function () { - return /* html */ "\n \n " + this.createValueTemplate(ConditionPosition.One) + "\n
\n \n \n
\n \n " + this.createValueTemplate(ConditionPosition.Two); + GridOptionsWrapper.prototype.getOverlayLoadingTemplate = function () { + return this.gridOptions.overlayLoadingTemplate; }; - SimpleFilter.prototype.getCssIdentifier = function () { - return 'simple-filter'; + GridOptionsWrapper.prototype.getOverlayNoRowsTemplate = function () { + return this.gridOptions.overlayNoRowsTemplate; }; - SimpleFilter.prototype.updateUiVisibility = function () { - var firstConditionComplete = this.isConditionUiComplete(ConditionPosition.One); - var showSecondFilter = this.allowTwoConditions && firstConditionComplete; - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["setDisplayed"])(this.eCondition2Body, showSecondFilter); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["setDisplayed"])(this.eType2.getGui(), showSecondFilter); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["setDisplayed"])(this.eJoinOperatorPanel, showSecondFilter); + GridOptionsWrapper.prototype.isSuppressAutoSize = function () { + return isTrue(this.gridOptions.suppressAutoSize); }; - SimpleFilter.prototype.resetUiToDefaults = function (silent) { - var uniqueGroupId = 'ag-simple-filter-and-or-' + this.getCompId(); - var defaultOption = this.optionsFactory.getDefaultOption(); - this.eType1.setValue(defaultOption, silent); - this.eType2.setValue(defaultOption, silent); - this.eJoinOperatorAnd - .setValue(true, silent) - .setName(uniqueGroupId) - .setLabel(this.translate('andCondition')); - this.eJoinOperatorOr - .setValue(false, silent) - .setName(uniqueGroupId) - .setLabel(this.translate('orCondition')); - return _utils__WEBPACK_IMPORTED_MODULE_3__["Promise"].resolve(); + GridOptionsWrapper.prototype.isEnableCellTextSelection = function () { + return isTrue(this.gridOptions.enableCellTextSelection); }; - SimpleFilter.prototype.translate = function (toTranslate) { - var translate = this.gridOptionsWrapper.getLocaleTextFunc(); - return translate(toTranslate, DEFAULT_TRANSLATIONS[toTranslate]); + GridOptionsWrapper.prototype.isSuppressParentsInRowNodes = function () { + return isTrue(this.gridOptions.suppressParentsInRowNodes); }; - SimpleFilter.prototype.addChangedListeners = function () { - var _this = this; - var listener = function () { return _this.onUiChanged(); }; - this.eType1.onValueChange(listener); - this.eType2.onValueChange(listener); - this.eJoinOperatorOr.onValueChange(listener); - this.eJoinOperatorAnd.onValueChange(listener); + GridOptionsWrapper.prototype.isSuppressClipboardApi = function () { + return isTrue(this.gridOptions.suppressClipboardApi); }; - SimpleFilter.prototype.doesFilterHaveHiddenInput = function (filterType) { - var customFilterOption = this.optionsFactory.getCustomOption(filterType); - return customFilterOption && customFilterOption.hideFilterInput; + GridOptionsWrapper.prototype.isFunctionsReadOnly = function () { + return isTrue(this.gridOptions.functionsReadOnly); }; - SimpleFilter.EMPTY = 'empty'; - SimpleFilter.EQUALS = 'equals'; - SimpleFilter.NOT_EQUAL = 'notEqual'; - SimpleFilter.LESS_THAN = 'lessThan'; - SimpleFilter.LESS_THAN_OR_EQUAL = 'lessThanOrEqual'; - SimpleFilter.GREATER_THAN = 'greaterThan'; - SimpleFilter.GREATER_THAN_OR_EQUAL = 'greaterThanOrEqual'; - SimpleFilter.IN_RANGE = 'inRange'; - SimpleFilter.CONTAINS = 'contains'; - SimpleFilter.NOT_CONTAINS = 'notContains'; - SimpleFilter.STARTS_WITH = 'startsWith'; - SimpleFilter.ENDS_WITH = 'endsWith'; - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eOptions1') - ], SimpleFilter.prototype, "eType1", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eOptions2') - ], SimpleFilter.prototype, "eType2", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eJoinOperatorAnd') - ], SimpleFilter.prototype, "eJoinOperatorAnd", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eJoinOperatorOr') - ], SimpleFilter.prototype, "eJoinOperatorOr", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eCondition2Body') - ], SimpleFilter.prototype, "eCondition2Body", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eJoinOperatorPanel') - ], SimpleFilter.prototype, "eJoinOperatorPanel", void 0); - return SimpleFilter; -}(_providedFilter__WEBPACK_IMPORTED_MODULE_2__["ProvidedFilter"])); - - - -/***/ }), -/* 61 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "OptionsFactory", function() { return OptionsFactory; }); -/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(17); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ - -/* Common logic for options, used by both filters and floating filters. */ -var OptionsFactory = /** @class */ (function () { - function OptionsFactory() { - this.customFilterOptions = {}; - } - OptionsFactory.prototype.init = function (params, defaultOptions) { - this.filterOptions = params.filterOptions || defaultOptions; - this.mapCustomOptions(); - this.selectDefaultItem(params); + GridOptionsWrapper.prototype.isEnableCellTextSelect = function () { + return isTrue(this.gridOptions.enableCellTextSelection); }; - OptionsFactory.prototype.getFilterOptions = function () { - return this.filterOptions; + GridOptionsWrapper.prototype.getDefaultColDef = function () { + return this.gridOptions.defaultColDef; }; - OptionsFactory.prototype.mapCustomOptions = function () { - var _this = this; - if (!this.filterOptions) { - return; - } - this.filterOptions.forEach(function (filterOption) { - if (typeof filterOption === 'string') { - return; - } - var requiredProperties = ['displayKey', 'displayName', 'test']; - if (Object(_utils_array__WEBPACK_IMPORTED_MODULE_0__["every"])(requiredProperties, function (key) { - if (!filterOption[key]) { - console.warn("ag-Grid: ignoring FilterOptionDef as it doesn't contain a '" + key + "'"); - return false; - } - return true; - })) { - _this.customFilterOptions[filterOption.displayKey] = filterOption; - } - }); + GridOptionsWrapper.prototype.getDefaultColGroupDef = function () { + return this.gridOptions.defaultColGroupDef; }; - OptionsFactory.prototype.selectDefaultItem = function (params) { - if (params.defaultOption) { - this.defaultOption = params.defaultOption; - } - else if (this.filterOptions.length >= 1) { - var firstFilterOption = this.filterOptions[0]; - if (typeof firstFilterOption === 'string') { - this.defaultOption = firstFilterOption; - } - else if (firstFilterOption.displayKey) { - this.defaultOption = firstFilterOption.displayKey; - } - else { - console.warn("ag-Grid: invalid FilterOptionDef supplied as it doesn't contain a 'displayKey'"); + GridOptionsWrapper.prototype.getDefaultExportParams = function (type) { + if (this.gridOptions.defaultExportParams) { + console.warn("AG Grid: Since v25.2 `defaultExportParams` has been replaced by `default" + Object(_utils_string__WEBPACK_IMPORTED_MODULE_16__["capitalise"])(type) + "ExportParams`'"); + if (type === 'csv') { + return this.gridOptions.defaultExportParams; } + return this.gridOptions.defaultExportParams; } - else { - console.warn('ag-Grid: no filter options for filter'); + if (type === 'csv' && this.gridOptions.defaultCsvExportParams) { + return this.gridOptions.defaultCsvExportParams; + } + if (type === 'excel' && this.gridOptions.defaultExcelExportParams) { + return this.gridOptions.defaultExcelExportParams; } }; - OptionsFactory.prototype.getDefaultOption = function () { - return this.defaultOption; + GridOptionsWrapper.prototype.isSuppressCsvExport = function () { + return isTrue(this.gridOptions.suppressCsvExport); }; - OptionsFactory.prototype.getCustomOption = function (name) { - return this.customFilterOptions[name]; + GridOptionsWrapper.prototype.isAllowShowChangeAfterFilter = function () { + return isTrue(this.gridOptions.allowShowChangeAfterFilter); }; - return OptionsFactory; -}()); - - - -/***/ }), -/* 62 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ProvidedFilter", function() { return ProvidedFilter; }); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25); -/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(12); -/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(21); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + GridOptionsWrapper.prototype.isSuppressExcelExport = function () { + return isTrue(this.gridOptions.suppressExcelExport); }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + GridOptionsWrapper.prototype.isSuppressMakeColumnVisibleAfterUnGroup = function () { + return isTrue(this.gridOptions.suppressMakeColumnVisibleAfterUnGroup); }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - - -/** - * Contains common logic to all provided filters (apply button, clear button, etc). - * All the filters that come with ag-Grid extend this class. User filters do not - * extend this class. - */ -var ProvidedFilter = /** @class */ (function (_super) { - __extends(ProvidedFilter, _super); - function ProvidedFilter() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.applyActive = false; - _this.hidePopup = null; - // after the user hits 'apply' the model gets copied to here. this is then the model that we use for - // all filtering. so if user changes UI but doesn't hit apply, then the UI will be out of sync with this model. - // this is what we want, as the UI should only become the 'active' filter once it's applied. when apply is - // inactive, this model will be in sync (following the debounce ms). if the UI is not a valid filter - // (eg the value is missing so nothing to filter on, or for set filter all checkboxes are checked so filter - // not active) then this appliedModel will be null/undefined. - _this.appliedModel = null; - return _this; - } - /** @deprecated */ - ProvidedFilter.prototype.onFilterChanged = function () { - console.warn("ag-Grid: you should not call onFilterChanged() directly on the filter, please call\n gridApi.onFilterChanged() instead. onFilterChanged is not part of the exposed filter interface (it was\n a method that existed on an old version of the filters that was not intended for public use."); - this.providedFilterParams.filterChangedCallback(); + GridOptionsWrapper.prototype.getDataPathFunc = function () { + return this.gridOptions.getDataPath; }; - ProvidedFilter.prototype.isFilterActive = function () { - // filter is active if we have a valid applied model - return !!this.appliedModel; + GridOptionsWrapper.prototype.getIsServerSideGroupFunc = function () { + return this.gridOptions.isServerSideGroup; }; - ProvidedFilter.prototype.postConstruct = function () { - var templateString = /* html */ "\n
\n
\n " + this.createBodyTemplate() + "\n
\n
"; - this.setTemplate(templateString); + GridOptionsWrapper.prototype.getIsServerSideGroupOpenByDefaultFunc = function () { + return this.gridOptions.isServerSideGroupOpenByDefault; }; - ProvidedFilter.prototype.init = function (params) { - var _this = this; - this.setParams(params); - this.resetUiToDefaults(true).then(function () { - _this.updateUiVisibility(); - _this.setupOnBtApplyDebounce(); - }); + GridOptionsWrapper.prototype.getIsGroupOpenByDefaultFunc = function () { + return this.gridOptions.isGroupOpenByDefault; }; - ProvidedFilter.prototype.setParams = function (params) { - ProvidedFilter.checkForDeprecatedParams(params); - this.providedFilterParams = params; - if (params.newRowsAction === 'keep') { - this.newRowsActionKeep = true; - } - else if (params.newRowsAction === 'clear') { - this.newRowsActionKeep = false; - } - else { - // the default for SSRM and IRM is 'keep', for CSRM and VRM the default is 'clear' - var modelsForKeep = [_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE, _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].ROW_MODEL_TYPE_INFINITE]; - this.newRowsActionKeep = modelsForKeep.indexOf(this.rowModel.getType()) >= 0; - } - this.applyActive = ProvidedFilter.isUseApplyButton(params); - this.createButtonPanel(); + GridOptionsWrapper.prototype.getServerSideGroupKeyFunc = function () { + return this.gridOptions.getServerSideGroupKey; }; - ProvidedFilter.prototype.createButtonPanel = function () { - var _this = this; - var buttons = this.providedFilterParams.buttons; - if (!buttons || buttons.length < 1) { - return; - } - var translate = this.gridOptionsWrapper.getLocaleTextFunc(); - var eButtonsPanel = document.createElement('div'); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["addCssClass"])(eButtonsPanel, 'ag-filter-apply-panel'); - var addButton = function (type) { - var text; - var clickListener; - switch (type) { - case 'apply': - text = translate('applyFilter', 'Apply Filter'); - clickListener = function (e) { return _this.onBtApply(false, false, e); }; - break; - case 'clear': - text = translate('clearFilter', 'Clear Filter'); - clickListener = function () { return _this.onBtClear(); }; - break; - case 'reset': - text = translate('resetFilter', 'Reset Filter'); - clickListener = function () { return _this.onBtReset(); }; - break; - case 'cancel': - text = translate('cancelFilter', 'Cancel Filter'); - clickListener = function (e) { _this.onBtCancel(e); }; - break; - default: - console.warn('Unknown button type specified'); - return; - } - var button = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["loadTemplate"])(/* html */ "" + text + ""); - eButtonsPanel.appendChild(button); - _this.addManagedListener(button, 'click', clickListener); - }; - new Set(buttons).forEach(function (type) { return addButton(type); }); - this.getGui().appendChild(eButtonsPanel); + GridOptionsWrapper.prototype.getGroupRowAggNodesFunc = function () { + return this.gridOptions.groupRowAggNodes; }; - ProvidedFilter.checkForDeprecatedParams = function (params) { - var buttons = params.buttons || []; - if (buttons.length > 0) { - return; - } - var applyButton = params.applyButton, resetButton = params.resetButton, clearButton = params.clearButton; - if (clearButton) { - console.warn('ag-Grid: as of ag-Grid v23.2, filterParams.clearButton is deprecated. Please use filterParams.buttons instead'); - buttons.push('clear'); + GridOptionsWrapper.prototype.getContextMenuItemsFunc = function () { + return this.gridOptions.getContextMenuItems; + }; + GridOptionsWrapper.prototype.getMainMenuItemsFunc = function () { + return this.gridOptions.getMainMenuItems; + }; + GridOptionsWrapper.prototype.getRowIdFunc = function () { + var _a = this.gridOptions, getRowId = _a.getRowId, getRowNodeId = _a.getRowNodeId; + if (getRowId) { + return getRowId; } - if (resetButton) { - console.warn('ag-Grid: as of ag-Grid v23.2, filterParams.resetButton is deprecated. Please use filterParams.buttons instead'); - buttons.push('reset'); + // this is the deprecated way, so provide a proxy to make it compatible + if (getRowNodeId) { + return function (params) { return getRowNodeId(params.data); }; } - if (applyButton) { - console.warn('ag-Grid: as of ag-Grid v23.2, filterParams.applyButton is deprecated. Please use filterParams.buttons instead'); - buttons.push('apply'); + }; + GridOptionsWrapper.prototype.getNavigateToNextHeaderFunc = function () { + return this.gridOptions.navigateToNextHeader; + }; + GridOptionsWrapper.prototype.getTabToNextHeaderFunc = function () { + return this.gridOptions.tabToNextHeader; + }; + GridOptionsWrapper.prototype.getNavigateToNextCellFunc = function () { + return this.gridOptions.navigateToNextCell; + }; + GridOptionsWrapper.prototype.getTabToNextCellFunc = function () { + return this.gridOptions.tabToNextCell; + }; + GridOptionsWrapper.prototype.getGridTabIndex = function () { + return (this.gridOptions.tabIndex || 0).toString(); + }; + GridOptionsWrapper.prototype.isTreeData = function () { + var usingTreeData = isTrue(this.gridOptions.treeData); + if (usingTreeData) { + return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_10__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__["ModuleNames"].RowGroupingModule, 'Tree Data'); } - if (params.apply) { - console.warn('ag-Grid: as of ag-Grid v21, filterParams.apply is deprecated. Please use filterParams.buttons instead'); - buttons.push('apply'); + return false; + }; + GridOptionsWrapper.prototype.isValueCache = function () { + return isTrue(this.gridOptions.valueCache); + }; + GridOptionsWrapper.prototype.isValueCacheNeverExpires = function () { + return isTrue(this.gridOptions.valueCacheNeverExpires); + }; + GridOptionsWrapper.prototype.isDeltaSort = function () { + return isTrue(this.gridOptions.deltaSort); + }; + GridOptionsWrapper.prototype.isAggregateOnlyChangedColumns = function () { + return isTrue(this.gridOptions.aggregateOnlyChangedColumns); + }; + GridOptionsWrapper.prototype.getProcessSecondaryColDefFunc = function () { + return this.gridOptions.processSecondaryColDef; + }; + GridOptionsWrapper.prototype.getProcessSecondaryColGroupDefFunc = function () { + return this.gridOptions.processSecondaryColGroupDef; + }; + GridOptionsWrapper.prototype.getSendToClipboardFunc = function () { + return this.gridOptions.sendToClipboard; + }; + GridOptionsWrapper.prototype.getProcessRowPostCreateFunc = function () { + return this.gridOptions.processRowPostCreate; + }; + GridOptionsWrapper.prototype.getProcessCellForClipboardFunc = function () { + return this.gridOptions.processCellForClipboard; + }; + GridOptionsWrapper.prototype.getProcessHeaderForClipboardFunc = function () { + return this.gridOptions.processHeaderForClipboard; + }; + GridOptionsWrapper.prototype.getProcessGroupHeaderForClipboardFunc = function () { + return this.gridOptions.processGroupHeaderForClipboard; + }; + GridOptionsWrapper.prototype.getProcessCellFromClipboardFunc = function () { + return this.gridOptions.processCellFromClipboard; + }; + GridOptionsWrapper.prototype.getViewportRowModelPageSize = function () { + return oneOrGreater(this.gridOptions.viewportRowModelPageSize, DEFAULT_VIEWPORT_ROW_MODEL_PAGE_SIZE); + }; + GridOptionsWrapper.prototype.getViewportRowModelBufferSize = function () { + return zeroOrGreater(this.gridOptions.viewportRowModelBufferSize, DEFAULT_VIEWPORT_ROW_MODEL_BUFFER_SIZE); + }; + GridOptionsWrapper.prototype.isServerSideSortingAlwaysResets = function () { + return isTrue(this.gridOptions.serverSideSortingAlwaysResets); + }; + GridOptionsWrapper.prototype.isServerSideFilteringAlwaysResets = function () { + return isTrue(this.gridOptions.serverSideFilteringAlwaysResets); + }; + GridOptionsWrapper.prototype.getPostSortFunc = function () { + return this.gridOptions.postSort; + }; + GridOptionsWrapper.prototype.getChartToolbarItemsFunc = function () { + return this.gridOptions.getChartToolbarItems; + }; + GridOptionsWrapper.prototype.getChartThemeOverrides = function () { + return this.gridOptions.chartThemeOverrides; + }; + GridOptionsWrapper.prototype.getCustomChartThemes = function () { + return this.gridOptions.customChartThemes; + }; + GridOptionsWrapper.prototype.getChartThemes = function () { + // return default themes if user hasn't supplied any + return this.gridOptions.chartThemes || ['ag-default', 'ag-material', 'ag-pastel', 'ag-vivid', 'ag-solar']; + }; + GridOptionsWrapper.prototype.getClipboardDelimiter = function () { + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["exists"])(this.gridOptions.clipboardDelimiter) ? this.gridOptions.clipboardDelimiter : '\t'; + }; + GridOptionsWrapper.prototype.setProperty = function (key, value, force) { + if (force === void 0) { force = false; } + var gridOptionsNoType = this.gridOptions; + var previousValue = gridOptionsNoType[key]; + if (force || previousValue !== value) { + gridOptionsNoType[key] = value; + var event_1 = { + type: key, + currentValue: value, + previousValue: previousValue + }; + this.propertyEventService.dispatchEvent(event_1); } - params.buttons = buttons; - }; - // subclasses can override this to provide alternative debounce defaults - ProvidedFilter.prototype.getDefaultDebounceMs = function () { - return 0; - }; - ProvidedFilter.prototype.setupOnBtApplyDebounce = function () { - var debounceMs = ProvidedFilter.getDebounceMs(this.providedFilterParams, this.getDefaultDebounceMs()); - this.onBtApplyDebounce = Object(_utils_function__WEBPACK_IMPORTED_MODULE_4__["debounce"])(this.onBtApply.bind(this), debounceMs); }; - ProvidedFilter.prototype.getModel = function () { - return this.appliedModel; + GridOptionsWrapper.prototype.addEventListener = function (key, listener) { + this.propertyEventService.addEventListener(key, listener); }; - ProvidedFilter.prototype.setModel = function (model) { - var _this = this; - var promise = model ? this.setModelIntoUi(model) : this.resetUiToDefaults(); - return promise.then(function () { - _this.updateUiVisibility(); - // we set the model from the gui, rather than the provided model, - // so the model is consistent. eg handling of null/undefined will be the same, - // of if model is case insensitive, then casing is removed. - _this.applyModel(); - }); + GridOptionsWrapper.prototype.removeEventListener = function (key, listener) { + this.propertyEventService.removeEventListener(key, listener); }; - ProvidedFilter.prototype.onBtCancel = function (e) { - var _this = this; - this.setModelIntoUi(this.getModel()).then(function () { - _this.onUiChanged(false, 'prevent'); - if (_this.providedFilterParams.closeOnApply) { - _this.close(e); - } - }); + GridOptionsWrapper.prototype.isSkipHeaderOnAutoSize = function () { + return !!this.gridOptions.skipHeaderOnAutoSize; }; - ProvidedFilter.prototype.onBtClear = function () { - var _this = this; - this.resetUiToDefaults().then(function () { return _this.onUiChanged(); }); + GridOptionsWrapper.prototype.getAutoSizePadding = function () { + var value = this.gridOptions.autoSizePadding; + return value != null && value >= 0 ? value : 20; }; - ProvidedFilter.prototype.onBtReset = function () { - this.onBtClear(); - this.onBtApply(); + // properties + GridOptionsWrapper.prototype.getHeaderHeight = function () { + if (typeof this.gridOptions.headerHeight === 'number') { + return this.gridOptions.headerHeight; + } + return this.getFromTheme(25, 'headerHeight'); }; - /** - * Applies changes made in the UI to the filter, and returns true if the model has changed. - */ - ProvidedFilter.prototype.applyModel = function () { - var newModel = this.getModelFromUi(); - if (!this.isModelValid(newModel)) { - return false; + GridOptionsWrapper.prototype.getFloatingFiltersHeight = function () { + if (typeof this.gridOptions.floatingFiltersHeight === 'number') { + return this.gridOptions.floatingFiltersHeight; } - var previousModel = this.appliedModel; - this.appliedModel = newModel; - // models can be same if user pasted same content into text field, or maybe just changed the case - // and it's a case insensitive filter - return !this.areModelsEqual(previousModel, newModel); + return this.getFromTheme(25, 'headerHeight'); }; - ProvidedFilter.prototype.isModelValid = function (model) { - return true; + GridOptionsWrapper.prototype.getGroupHeaderHeight = function () { + if (typeof this.gridOptions.groupHeaderHeight === 'number') { + return this.gridOptions.groupHeaderHeight; + } + return this.getHeaderHeight(); }; - ProvidedFilter.prototype.onBtApply = function (afterFloatingFilter, afterDataChange, e) { - if (afterFloatingFilter === void 0) { afterFloatingFilter = false; } - if (afterDataChange === void 0) { afterDataChange = false; } - if (this.applyModel()) { - // the floating filter uses 'afterFloatingFilter' info, so it doesn't refresh after filter changed if change - // came from floating filter - this.providedFilterParams.filterChangedCallback({ afterFloatingFilter: afterFloatingFilter, afterDataChange: afterDataChange }); + GridOptionsWrapper.prototype.getPivotHeaderHeight = function () { + if (typeof this.gridOptions.pivotHeaderHeight === 'number') { + return this.gridOptions.pivotHeaderHeight; } - var closeOnApply = this.providedFilterParams.closeOnApply; - // only close if an apply button is visible, otherwise we'd be closing every time a change was made! - if (closeOnApply && !afterFloatingFilter && this.applyActive) { - this.close(e); + return this.getHeaderHeight(); + }; + GridOptionsWrapper.prototype.getPivotGroupHeaderHeight = function () { + if (typeof this.gridOptions.pivotGroupHeaderHeight === 'number') { + return this.gridOptions.pivotGroupHeaderHeight; } + return this.getGroupHeaderHeight(); }; - ProvidedFilter.prototype.onNewRowsLoaded = function () { - var _this = this; - if (!this.newRowsActionKeep) { - this.resetUiToDefaults().then(function () { return _this.appliedModel = null; }); + GridOptionsWrapper.prototype.isExternalFilterPresent = function () { + if (typeof this.gridOptions.isExternalFilterPresent === 'function') { + return this.gridOptions.isExternalFilterPresent(); } + return false; }; - ProvidedFilter.prototype.close = function (e) { - if (!this.hidePopup) { - return; + GridOptionsWrapper.prototype.doesExternalFilterPass = function (node) { + if (typeof this.gridOptions.doesExternalFilterPass === 'function') { + return this.gridOptions.doesExternalFilterPass(node); } - var keyboardEvent = e; - var key = keyboardEvent && keyboardEvent.key; - var params; - if (key === 'Enter' || key === 'Space') { - params = { keyboardEvent: keyboardEvent }; + return false; + }; + GridOptionsWrapper.prototype.getTooltipDelay = function (type) { + var _a = this.gridOptions, tooltipShowDelay = _a.tooltipShowDelay, tooltipHideDelay = _a.tooltipHideDelay; + var delay = type === 'show' ? tooltipShowDelay : tooltipHideDelay; + var capitalisedType = Object(_utils_string__WEBPACK_IMPORTED_MODULE_16__["capitalise"])(type); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["exists"])(delay)) { + if (delay < 0) { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_14__["doOnce"])(function () { return console.warn("ag-grid: tooltip" + capitalisedType + "Delay should not be lower than 0"); }, "tooltip" + capitalisedType + "DelayWarn"); + } + return Math.max(200, delay); } - this.hidePopup(params); - this.hidePopup = null; + return null; + }; + GridOptionsWrapper.prototype.isTooltipMouseTrack = function () { + return isTrue(this.gridOptions.tooltipMouseTrack); }; - // called by set filter - ProvidedFilter.prototype.isNewRowsActionKeep = function () { - return this.newRowsActionKeep; + GridOptionsWrapper.prototype.isSuppressModelUpdateAfterUpdateTransaction = function () { + return isTrue(this.gridOptions.suppressModelUpdateAfterUpdateTransaction); }; - /** - * By default, if the change came from a floating filter it will be applied immediately, otherwise if there is no - * apply button it will be applied after a debounce, otherwise it will not be applied at all. This behaviour can - * be adjusted by using the apply parameter. - */ - ProvidedFilter.prototype.onUiChanged = function (fromFloatingFilter, apply) { - if (fromFloatingFilter === void 0) { fromFloatingFilter = false; } - this.updateUiVisibility(); - this.providedFilterParams.filterModifiedCallback(); - if (this.applyActive) { - var isValid = this.isModelValid(this.getModelFromUi()); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["setDisabled"])(this.getRefElement('applyFilterButton'), !isValid); + GridOptionsWrapper.prototype.getDocument = function () { + // if user is providing document, we use the users one, + // otherwise we use the document on the global namespace. + var result = null; + if (this.gridOptions.getDocument && Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["exists"])(this.gridOptions.getDocument)) { + result = this.gridOptions.getDocument(); } - if ((fromFloatingFilter && !apply) || apply === 'immediately') { - this.onBtApply(fromFloatingFilter); + else if (this.eGridDiv) { + result = this.eGridDiv.ownerDocument; } - else if ((!this.applyActive && !apply) || apply === 'debounce') { - this.onBtApplyDebounce(); + if (result && Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["exists"])(result)) { + return result; } + return document; }; - ProvidedFilter.prototype.afterGuiAttached = function (params) { - this.hidePopup = params.hidePopup; - }; - // static, as used by floating filter also - ProvidedFilter.getDebounceMs = function (params, debounceDefault) { - if (ProvidedFilter.isUseApplyButton(params)) { - if (params.debounceMs != null) { - console.warn('ag-Grid: debounceMs is ignored when apply button is present'); - } - return 0; + GridOptionsWrapper.prototype.getMinColWidth = function () { + var minColWidth = this.gridOptions.minColWidth; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["exists"])(minColWidth) && minColWidth > GridOptionsWrapper_1.MIN_COL_WIDTH) { + return this.gridOptions.minColWidth; } - return params.debounceMs != null ? params.debounceMs : debounceDefault; - }; - // static, as used by floating filter also - ProvidedFilter.isUseApplyButton = function (params) { - ProvidedFilter.checkForDeprecatedParams(params); - return params.buttons && params.buttons.indexOf('apply') >= 0; - }; - ProvidedFilter.prototype.destroy = function () { - this.hidePopup = null; - _super.prototype.destroy.call(this); + var measuredMin = this.getFromTheme(null, 'headerCellMinWidth'); + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["exists"])(measuredMin) ? Math.max(measuredMin, GridOptionsWrapper_1.MIN_COL_WIDTH) : GridOptionsWrapper_1.MIN_COL_WIDTH; }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], ProvidedFilter.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowModel') - ], ProvidedFilter.prototype, "rowModel", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], ProvidedFilter.prototype, "postConstruct", null); - return ProvidedFilter; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); - - - -/***/ }), -/* 63 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ScalarFilter", function() { return ScalarFilter; }); -/* harmony import */ var _simpleFilter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(60); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + GridOptionsWrapper.prototype.getMaxColWidth = function () { + if (this.gridOptions.maxColWidth && this.gridOptions.maxColWidth > GridOptionsWrapper_1.MIN_COL_WIDTH) { + return this.gridOptions.maxColWidth; + } + return null; }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + GridOptionsWrapper.prototype.getColWidth = function () { + if (typeof this.gridOptions.colWidth !== 'number' || this.gridOptions.colWidth < GridOptionsWrapper_1.MIN_COL_WIDTH) { + return 200; + } + return this.gridOptions.colWidth; }; -})(); - -var ScalarFilter = /** @class */ (function (_super) { - __extends(ScalarFilter, _super); - function ScalarFilter() { - return _super !== null && _super.apply(this, arguments) || this; - } - ScalarFilter.prototype.setParams = function (params) { - _super.prototype.setParams.call(this, params); - this.scalarFilterParams = params; - this.checkDeprecatedParams(); - }; - ScalarFilter.prototype.checkDeprecatedParams = function () { - if (this.scalarFilterParams.nullComparator) { - console.warn('ag-Grid: Since v21.0, the property filterParams.nullComparator is deprecated. ' + - 'Please use filterParams.includeBlanksInEquals, filterParams.includeBlanksInLessThan and ' + - 'filterParams.includeBlanksInGreaterThan instead.'); - this.scalarFilterParams.includeBlanksInEquals = this.scalarFilterParams.nullComparator.equals; - this.scalarFilterParams.includeBlanksInLessThan = this.scalarFilterParams.nullComparator.lessThan; - this.scalarFilterParams.includeBlanksInGreaterThan = this.scalarFilterParams.nullComparator.greaterThan; - } - }; - ScalarFilter.prototype.nullComparator = function (selectedOption, filterValue, gridValue) { - if (gridValue == null) { - switch (selectedOption) { - case ScalarFilter.EMPTY: - return 0; - case ScalarFilter.EQUALS: - return this.scalarFilterParams.includeBlanksInEquals ? 0 : 1; - case ScalarFilter.NOT_EQUAL: - return this.scalarFilterParams.includeBlanksInEquals ? 1 : 0; - case ScalarFilter.GREATER_THAN: - case ScalarFilter.GREATER_THAN_OR_EQUAL: - return this.scalarFilterParams.includeBlanksInGreaterThan ? 1 : -1; - case ScalarFilter.LESS_THAN: - case ScalarFilter.LESS_THAN_OR_EQUAL: - return this.scalarFilterParams.includeBlanksInLessThan ? -1 : 1; - } - } - return this.comparator()(filterValue, gridValue); - }; - ScalarFilter.prototype.individualConditionPasses = function (params, filterModel) { - var cellValue = this.scalarFilterParams.valueGetter(params.node); - var range = this.mapRangeFromModel(filterModel); - var filterValue = range.from; - var filterValueTo = range.to; - var filterType = filterModel.type; - var customFilterOption = this.optionsFactory.getCustomOption(filterType); - if (customFilterOption) { - // only execute the custom filter if a value exists or a value isn't required, i.e. input is hidden - if (filterValue != null || customFilterOption.hideFilterInput) { - return customFilterOption.test(filterValue, cellValue); + GridOptionsWrapper.prototype.getRowBuffer = function () { + var rowBuffer = this.gridOptions.rowBuffer; + if (typeof rowBuffer === 'number') { + if (rowBuffer < 0) { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_14__["doOnce"])(function () { return console.warn("AG Grid: rowBuffer should not be negative"); }, 'warn rowBuffer negative'); + this.gridOptions.rowBuffer = rowBuffer = 0; } } - var compareResult = this.nullComparator(filterType, filterValue, cellValue); - switch (filterType) { - case ScalarFilter.EQUALS: - return compareResult === 0; - case ScalarFilter.NOT_EQUAL: - return compareResult !== 0; - case ScalarFilter.GREATER_THAN: - return compareResult > 0; - case ScalarFilter.GREATER_THAN_OR_EQUAL: - return compareResult >= 0; - case ScalarFilter.LESS_THAN: - return compareResult < 0; - case ScalarFilter.LESS_THAN_OR_EQUAL: - return compareResult <= 0; - case ScalarFilter.IN_RANGE: { - var compareToResult = this.nullComparator(filterType, filterValueTo, cellValue); - return this.scalarFilterParams.inRangeInclusive ? - compareResult >= 0 && compareToResult <= 0 : - compareResult > 0 && compareToResult < 0; - } - default: - throw new Error('Unexpected type of filter: ' + filterType); + else { + rowBuffer = _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_BUFFER_SIZE; } + return rowBuffer; }; - return ScalarFilter; -}(_simpleFilter__WEBPACK_IMPORTED_MODULE_0__["SimpleFilter"])); - - - -/***/ }), -/* 64 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderComp", function() { return HeaderComp; }); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); -/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(35); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37); -/* harmony import */ var _widgets_touchListener__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(65); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(57); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(43); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - - - - -var HeaderComp = /** @class */ (function (_super) { - __extends(HeaderComp, _super); - function HeaderComp() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.lastMovingChanged = 0; - return _this; - } - // this is a user component, and IComponent has "public destroy()" as part of the interface. - // so we need to override destroy() just to make the method public. - HeaderComp.prototype.destroy = function () { - _super.prototype.destroy.call(this); - }; - HeaderComp.prototype.init = function (params) { - var template = _utils__WEBPACK_IMPORTED_MODULE_6__["_"].firstExistingValue(params.template, HeaderComp.TEMPLATE); - // take account of any newlines & whitespace before/after the actual template - template = template && template.trim ? template.trim() : template; - this.setTemplate(template); - this.params = params; - this.setupTap(); - this.setupIcons(params.column); - this.setupMenu(); - this.setupSort(); - this.setupFilterIcon(); - this.setupText(params.displayName); + GridOptionsWrapper.prototype.getRowBufferInPixels = function () { + var rowsToBuffer = this.getRowBuffer(); + var defaultRowHeight = this.getRowHeightAsNumber(); + return rowsToBuffer * defaultRowHeight; }; - HeaderComp.prototype.setupText = function (displayName) { - var displayNameSanitised = _utils__WEBPACK_IMPORTED_MODULE_6__["_"].escape(displayName); - if (this.eText) { - this.eText.innerHTML = displayNameSanitised; + // the user might be using some non-standard scrollbar, eg a scrollbar that has zero + // width and overlays (like the Safari scrollbar, but presented in Chrome). so we + // allow the user to provide the scroll width before we work it out. + GridOptionsWrapper.prototype.getScrollbarWidth = function () { + if (this.scrollbarWidth == null) { + var useGridOptions = typeof this.gridOptions.scrollbarWidth === 'number' && this.gridOptions.scrollbarWidth >= 0; + var scrollbarWidth = useGridOptions ? this.gridOptions.scrollbarWidth : Object(_utils_browser__WEBPACK_IMPORTED_MODULE_15__["getScrollbarWidth"])(); + if (scrollbarWidth != null) { + this.scrollbarWidth = scrollbarWidth; + this.eventService.dispatchEvent({ + type: _eventKeys__WEBPACK_IMPORTED_MODULE_6__["Events"].EVENT_SCROLLBAR_WIDTH_CHANGED + }); + } } + return this.scrollbarWidth; }; - HeaderComp.prototype.setupIcons = function (column) { - this.addInIcon('sortAscending', this.eSortAsc, column); - this.addInIcon('sortDescending', this.eSortDesc, column); - this.addInIcon('sortUnSort', this.eSortNone, column); - this.addInIcon('menu', this.eMenu, column); - this.addInIcon('filter', this.eFilter, column); - }; - HeaderComp.prototype.addInIcon = function (iconName, eParent, column) { - if (eParent == null) { - return; + GridOptionsWrapper.prototype.checkForDeprecated = function () { + // casting to generic object, so typescript compiles even though + // we are looking for attributes that don't exist + var options = this.gridOptions; + if (options.deprecatedEmbedFullWidthRows) { + console.warn("AG Grid: since v21.2, deprecatedEmbedFullWidthRows has been replaced with embedFullWidthRows."); } - var eIcon = _utils__WEBPACK_IMPORTED_MODULE_6__["_"].createIconNoSpan(iconName, this.gridOptionsWrapper, column); - eParent.appendChild(eIcon); - }; - HeaderComp.prototype.setupTap = function () { - var _this = this; - var options = this.gridOptionsWrapper; - if (options.isSuppressTouch()) { - return; + if (options.rowDeselection) { + console.warn('AG Grid: since v24.x, rowDeselection is deprecated and the behaviour is true by default. Please use `suppressRowDeselection` to prevent rows from being deselected.'); } - var touchListener = new _widgets_touchListener__WEBPACK_IMPORTED_MODULE_3__["TouchListener"](this.getGui(), true); - var suppressMenuHide = options.isSuppressMenuHide(); - var tapMenuButton = suppressMenuHide && _utils__WEBPACK_IMPORTED_MODULE_6__["_"].exists(this.eMenu); - var menuTouchListener = tapMenuButton ? new _widgets_touchListener__WEBPACK_IMPORTED_MODULE_3__["TouchListener"](this.eMenu, true) : touchListener; - if (this.params.enableMenu) { - var eventType = tapMenuButton ? 'EVENT_TAP' : 'EVENT_LONG_TAP'; - var showMenuFn = function (event) { - options.getApi().showColumnMenuAfterMouseClick(_this.params.column, event.touchStart); - }; - this.addManagedListener(menuTouchListener, _widgets_touchListener__WEBPACK_IMPORTED_MODULE_3__["TouchListener"][eventType], showMenuFn); + if (options.enableMultiRowDragging) { + options.rowDragMultiRow = true; + delete options.enableMultiRowDragging; + console.warn('AG Grid: since v26.1, `enableMultiRowDragging` is deprecated. Please use `rowDragMultiRow`.'); } - if (this.params.enableSorting) { - var tapListener = function (event) { - var target = event.touchStart.target; - // When suppressMenuHide is true, a tap on the menu icon will bubble up - // to the header container, in that case we should not sort - if (suppressMenuHide && _this.eMenu.contains(target)) { - return; + var checkRenamedProperty = function (oldProp, newProp, version) { + if (options[oldProp] != null) { + console.warn("ag-grid: since version " + version + ", '" + oldProp + "' is deprecated / renamed, please use the new property name '" + newProp + "' instead."); + if (options[newProp] == null) { + options[newProp] = options[oldProp]; } - _this.sortController.progressSort(_this.params.column, false, "uiColumnSorted"); - }; - this.addManagedListener(touchListener, _widgets_touchListener__WEBPACK_IMPORTED_MODULE_3__["TouchListener"].EVENT_TAP, tapListener); + } + }; + checkRenamedProperty('batchUpdateWaitMillis', 'asyncTransactionWaitMillis', '23.1.x'); + checkRenamedProperty('deltaRowDataMode', 'immutableData', '23.1.x'); + if (options.immutableColumns || options.deltaColumnMode) { + console.warn('AG Grid: since v24.0, immutableColumns and deltaColumnMode properties are gone. The grid now works like this as default. To keep column order maintained, set grid property applyColumnDefOrder=true'); } - // if tapMenuButton is true `touchListener` and `menuTouchListener` are different - // so we need to make sure to destroy both listeners here - this.addDestroyFunc(function () { return touchListener.destroy(); }); - if (tapMenuButton) { - this.addDestroyFunc(function () { return menuTouchListener.destroy(); }); + checkRenamedProperty('suppressSetColumnStateEvents', 'suppressColumnStateEvents', '24.0.x'); + if (options.groupRowInnerRenderer || options.groupRowInnerRendererParams || options.groupRowInnerRendererFramework) { + console.warn('AG Grid: since v24.0, grid properties groupRowInnerRenderer, groupRowInnerRendererFramework and groupRowInnerRendererParams are no longer used.'); + console.warn(' Instead use the grid properties groupRowRendererParams.innerRenderer, groupRowRendererParams.innerRendererFramework and groupRowRendererParams.innerRendererParams.'); + console.warn(' For example instead of this:'); + console.warn(' groupRowInnerRenderer: "myRenderer"'); + console.warn(' groupRowInnerRendererParams: {x: a}'); + console.warn(' Replace with this:'); + console.warn(' groupRowRendererParams: {'); + console.warn(' innerRenderer: "myRenderer",'); + console.warn(' innerRendererParams: {x: a}'); + console.warn(' }'); + console.warn(' We have copied the properties over for you. However to stop this error message, please change your application code.'); + if (!options.groupRowRendererParams) { + options.groupRowRendererParams = {}; + } + var params = options.groupRowRendererParams; + if (options.groupRowInnerRenderer) { + params.innerRenderer = options.groupRowInnerRenderer; + } + if (options.groupRowInnerRendererParams) { + params.innerRendererParams = options.groupRowInnerRendererParams; + } + if (options.groupRowInnerRendererFramework) { + params.innerRendererFramework = options.groupRowInnerRendererFramework; + } } - }; - HeaderComp.prototype.setupMenu = function () { - var _this = this; - // if no menu provided in template, do nothing - if (!this.eMenu) { - return; + if (options.rememberGroupStateWhenNewData) { + console.warn('AG Grid: since v24.0, grid property rememberGroupStateWhenNewData is deprecated. This feature was provided before Transaction Updates worked (which keep group state). Now that transaction updates are possible and they keep group state, this feature is no longer needed.'); } - // we don't show the menu if on an iPad/iPhone, as the user cannot have a pointer device - // Note: If suppressMenuHide is set to true the menu will be displayed, and if suppressMenuHide - // is false (default) user will need to use longpress to display the menu. - var suppressMenuHide = this.gridOptionsWrapper.isSuppressMenuHide(); - var hideShowMenu = !this.params.enableMenu || (_utils__WEBPACK_IMPORTED_MODULE_6__["_"].isIOSUserAgent() && !suppressMenuHide); - if (hideShowMenu) { - _utils__WEBPACK_IMPORTED_MODULE_6__["_"].removeFromParent(this.eMenu); - return; + if (options.detailCellRendererParams && options.detailCellRendererParams.autoHeight) { + console.warn('AG Grid: since v24.1, grid property detailCellRendererParams.autoHeight is replaced with grid property detailRowAutoHeight. This allows this feature to work when you provide a custom DetailCellRenderer'); + options.detailRowAutoHeight = true; } - this.addManagedListener(this.eMenu, 'click', function () { return _this.showMenu(_this.eMenu); }); - if (!suppressMenuHide) { - this.eMenu.style.opacity = '0'; + if (options.suppressKeyboardEvent) { + console.warn("AG Grid: since v24.1 suppressKeyboardEvent in the gridOptions has been deprecated and will be removed in\n future versions of AG Grid. If you need this to be set for every column use the defaultColDef property."); + } + if (options.suppressEnterpriseResetOnNewColumns) { + console.warn('AG Grid: since v25, grid property suppressEnterpriseResetOnNewColumns is deprecated. This was a temporary property to allow changing columns in Server Side Row Model without triggering a reload. Now that it is possible to dynamically change columns in the grid, this is no longer needed.'); + } + if (options.suppressColumnStateEvents) { + console.warn('AG Grid: since v25, grid property suppressColumnStateEvents no longer works due to a refactor that we did. It should be possible to achieve similar using event.source, which would be "api" if the event was due to setting column state via the API'); + } + if (options.defaultExportParams) { + console.warn('AG Grid: since v25.2, the grid property `defaultExportParams` has been replaced by `defaultCsvExportParams` and `defaultExcelExportParams`.'); + } + if (options.stopEditingWhenGridLosesFocus) { + console.warn('AG Grid: since v25.2.2, the grid property `stopEditingWhenGridLosesFocus` has been replaced by `stopEditingWhenCellsLoseFocus`.'); + options.stopEditingWhenCellsLoseFocus = true; + } + if (options.applyColumnDefOrder) { + console.warn('AG Grid: since v26.0, the grid property `applyColumnDefOrder` is no longer needed, as this is the default behaviour. To turn this behaviour off, set maintainColumnOrder=true'); + } + if (options.groupMultiAutoColumn) { + console.warn("AG Grid: since v26.0, the grid property `groupMultiAutoColumn` has been replaced by `groupDisplayType = 'multipleColumns'`"); + options.groupDisplayType = 'multipleColumns'; + } + if (options.groupUseEntireRow) { + console.warn("AG Grid: since v26.0, the grid property `groupUseEntireRow` has been replaced by `groupDisplayType = 'groupRows'`"); + options.groupDisplayType = 'groupRows'; + } + if (options.groupSuppressAutoColumn) { + var propName = options.treeData ? 'treeDataDisplayType' : 'groupDisplayType'; + console.warn("AG Grid: since v26.0, the grid property `groupSuppressAutoColumn` has been replaced by `" + propName + " = 'custom'`"); + options.groupDisplayType = 'custom'; + } + if (options.defaultGroupSortComparator) { + console.warn("AG Grid: since v26.0, the grid property `defaultGroupSortComparator` has been replaced by `defaultGroupOrderComparator`"); + options.defaultGroupOrderComparator = options.defaultGroupSortComparator; + } + if (options.colWidth) { + console.warn('AG Grid: since v26.1, the grid property `colWidth` is deprecated and should be set via `defaultColDef.width`.'); + } + if (options.minColWidth) { + console.warn('AG Grid: since v26.1, the grid property `minColWidth` is deprecated and should be set via `defaultColDef.minWidth`.'); + } + if (options.maxColWidth) { + console.warn('AG Grid: since v26.1, the grid property `maxColWidth` is deprecated and should be set via `defaultColDef.maxWidth`.'); + } + if (options.reactUi) { + console.warn('AG Grid: since v27.0, React UI is on by default, so no need for reactUi=true. To turn it off, set suppressReactUi=true.'); + } + if (options.suppressReactUi) { + console.warn('AG Grid: The legacy React rendering engine is deprecated and will be removed in the next major version of the grid.'); + } + if (options.suppressCellSelection) { + console.warn('AG Grid: since v27.0, `suppressCellSelection` has been replaced by `suppressCellFocus`.'); + options.suppressCellFocus = options.suppressCellSelection; + } + if (options.getRowNodeId) { + console.warn('AG Grid: since v27.1, `getRowNodeId` is deprecate and has been replaced by `getRowId`. The difference is if getRowId() is implemented, immutable data is on by default.'); + } + if (options.immutableData) { + console.warn('AG Grid: since v27.1, `immutableData` is deprecated. To turn on, implement `getRowId` has been replaced by `getRowId`. The difference is if getRowId() is implemented, immutable data is on by default.'); + } + if (options.clipboardDeliminator) { + console.warn('AG Grid: since v27.1, `clipboardDeliminator` has been replaced by `clipboardDelimiter`.'); + options.clipboardDelimiter = options.clipboardDeliminator; } - var style = this.eMenu.style; - style.transition = 'opacity 0.2s, border 0.2s'; - style['-webkit-transition'] = 'opacity 0.2s, border 0.2s'; }; - HeaderComp.prototype.setActiveParent = function (activeParent) { - if (!this.gridOptionsWrapper.isSuppressMenuHide()) { - this.eMenu.style.opacity = activeParent ? '1' : '0'; + GridOptionsWrapper.prototype.checkForViolations = function () { + if (this.isTreeData()) { + this.treeDataViolations(); } }; - HeaderComp.prototype.showMenu = function (eventSource) { - if (!eventSource) { - eventSource = this.eMenu; + GridOptionsWrapper.prototype.treeDataViolations = function () { + if (this.isRowModelDefault()) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["missing"])(this.getDataPathFunc())) { + console.warn('AG Grid: property usingTreeData=true with rowModel=clientSide, but you did not ' + + 'provide getDataPath function, please provide getDataPath function if using tree data.'); + } + } + if (this.isRowModelServerSide()) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["missing"])(this.getIsServerSideGroupFunc())) { + console.warn('AG Grid: property usingTreeData=true with rowModel=serverSide, but you did not ' + + 'provide isServerSideGroup function, please provide isServerSideGroup function if using tree data.'); + } + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["missing"])(this.getServerSideGroupKeyFunc())) { + console.warn('AG Grid: property usingTreeData=true with rowModel=serverSide, but you did not ' + + 'provide getServerSideGroupKey function, please provide getServerSideGroupKey function if using tree data.'); + } } - this.menuFactory.showMenuAfterButtonClick(this.params.column, eventSource); }; - HeaderComp.prototype.removeSortIcons = function () { - _utils__WEBPACK_IMPORTED_MODULE_6__["_"].removeFromParent(this.eSortAsc); - _utils__WEBPACK_IMPORTED_MODULE_6__["_"].removeFromParent(this.eSortDesc); - _utils__WEBPACK_IMPORTED_MODULE_6__["_"].removeFromParent(this.eSortNone); - _utils__WEBPACK_IMPORTED_MODULE_6__["_"].removeFromParent(this.eSortOrder); + GridOptionsWrapper.prototype.getLocaleTextFunc = function () { + if (this.gridOptions.localeTextFunc) { + return this.gridOptions.localeTextFunc; + } + var localeText = this.gridOptions.localeText; + return function (key, defaultValue) { + var localisedText = localeText && localeText[key]; + return (localisedText !== null && localisedText !== void 0 ? localisedText : defaultValue); + }; }; - HeaderComp.prototype.setupSort = function () { - var _this = this; - var enableSorting = this.params.enableSorting; - if (!enableSorting) { - this.removeSortIcons(); + // responsible for calling the onXXX functions on gridOptions + GridOptionsWrapper.prototype.globalEventHandler = function (eventName, event) { + // prevent events from being fired _after_ the grid has been destroyed + if (this.destroyed) { return; } - var sortUsingCtrl = this.gridOptionsWrapper.isMultiSortKeyCtrl(); - // keep track of last time the moving changed flag was set - this.addManagedListener(this.params.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_MOVING_CHANGED, function () { - _this.lastMovingChanged = new Date().getTime(); - }); - // add the event on the header, so when clicked, we do sorting - if (this.eLabel) { - this.addManagedListener(this.eLabel, 'click', function (event) { - // sometimes when moving a column via dragging, this was also firing a clicked event. - // here is issue raised by user: https://ag-grid.zendesk.com/agent/tickets/1076 - // this check stops sort if a) column is moving or b) column moved less than 200ms ago (so caters for race condition) - var moving = _this.params.column.isMoving(); - var nowTime = new Date().getTime(); - // typically there is <2ms if moving flag was set recently, as it would be done in same VM turn - var movedRecently = (nowTime - _this.lastMovingChanged) < 50; - var columnMoving = moving || movedRecently; - if (!columnMoving) { - var multiSort = sortUsingCtrl ? (event.ctrlKey || event.metaKey) : event.shiftKey; - _this.params.progressSort(multiSort); - } - }); + var callbackMethodName = _components_componentUtil__WEBPACK_IMPORTED_MODULE_2__["ComponentUtil"].getCallbackForEvent(eventName); + if (typeof this.gridOptions[callbackMethodName] === 'function') { + this.gridOptions[callbackMethodName](event); } - this.addManagedListener(this.params.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_SORT_CHANGED, this.onSortChanged.bind(this)); - this.onSortChanged(); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_5__["Events"].EVENT_SORT_CHANGED, this.setMultiSortOrder.bind(this)); - this.setMultiSortOrder(); }; - HeaderComp.prototype.onSortChanged = function () { - _utils__WEBPACK_IMPORTED_MODULE_6__["_"].addOrRemoveCssClass(this.getGui(), 'ag-header-cell-sorted-asc', this.params.column.isSortAscending()); - _utils__WEBPACK_IMPORTED_MODULE_6__["_"].addOrRemoveCssClass(this.getGui(), 'ag-header-cell-sorted-desc', this.params.column.isSortDescending()); - _utils__WEBPACK_IMPORTED_MODULE_6__["_"].addOrRemoveCssClass(this.getGui(), 'ag-header-cell-sorted-none', this.params.column.isSortNone()); - if (this.eSortAsc) { - _utils__WEBPACK_IMPORTED_MODULE_6__["_"].addOrRemoveCssClass(this.eSortAsc, 'ag-hidden', !this.params.column.isSortAscending()); + GridOptionsWrapper.prototype.setRowHeightVariable = function (height) { + var oldRowHeight = this.eGridDiv.style.getPropertyValue('--ag-row-height').trim(); + var newRowHeight = height + "px"; + if (oldRowHeight != newRowHeight) { + this.eGridDiv.style.setProperty('--ag-row-height', newRowHeight); } - if (this.eSortDesc) { - _utils__WEBPACK_IMPORTED_MODULE_6__["_"].addOrRemoveCssClass(this.eSortDesc, 'ag-hidden', !this.params.column.isSortDescending()); + }; + // we don't allow dynamic row height for virtual paging + GridOptionsWrapper.prototype.getRowHeightAsNumber = function () { + if (!this.gridOptions.rowHeight || Object(_utils_generic__WEBPACK_IMPORTED_MODULE_12__["missing"])(this.gridOptions.rowHeight)) { + return this.getDefaultRowHeight(); } - if (this.eSortNone) { - var alwaysHideNoSort = !this.params.column.getColDef().unSortIcon && !this.gridOptionsWrapper.isUnSortIcon(); - _utils__WEBPACK_IMPORTED_MODULE_6__["_"].addOrRemoveCssClass(this.eSortNone, 'ag-hidden', alwaysHideNoSort || !this.params.column.isSortNone()); + var rowHeight = this.gridOptions.rowHeight; + if (rowHeight && this.isNumeric(rowHeight)) { + this.setRowHeightVariable(rowHeight); + return rowHeight; } + console.warn('AG Grid row height must be a number if not using standard row model'); + return this.getDefaultRowHeight(); }; - // we listen here for global sort events, NOT column sort events, as we want to do this - // when sorting has been set on all column (if we listened just for our col (where we - // set the asc / desc icons) then it's possible other cols are yet to get their sorting state. - HeaderComp.prototype.setMultiSortOrder = function () { - if (!this.eSortOrder) { - return; + GridOptionsWrapper.prototype.isGetRowHeightFunction = function () { + return typeof this.gridOptions.getRowHeight === 'function'; + }; + GridOptionsWrapper.prototype.getRowHeightForNode = function (rowNode, allowEstimate, defaultRowHeight) { + if (allowEstimate === void 0) { allowEstimate = false; } + if (defaultRowHeight == null) { + defaultRowHeight = this.getDefaultRowHeight(); } - var col = this.params.column; - var allColumnsWithSorting = this.sortController.getColumnsWithSortingOrdered(); - var indexThisCol = allColumnsWithSorting.indexOf(col); - var moreThanOneColSorting = allColumnsWithSorting.length > 1; - var showIndex = col.isSorting() && moreThanOneColSorting; - _utils__WEBPACK_IMPORTED_MODULE_6__["_"].setDisplayed(this.eSortOrder, showIndex); - if (indexThisCol >= 0) { - this.eSortOrder.innerHTML = (indexThisCol + 1).toString(); + // check the function first, in case use set both function and + // number, when using virtual pagination then function can be + // used for pinned rows and the number for the body rows. + if (this.isGetRowHeightFunction()) { + if (allowEstimate) { + return { height: defaultRowHeight, estimated: true }; + } + var params = { + node: rowNode, + data: rowNode.data, + api: this.gridOptions.api, + context: this.gridOptions.context + }; + var height = this.gridOptions.getRowHeight(params); + if (this.isNumeric(height)) { + if (height === 0) { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_14__["doOnce"])(function () { return console.warn('AG Grid: The return of `getRowHeight` cannot be zero. If the intention is to hide rows, use a filter instead.'); }, 'invalidRowHeight'); + } + return { height: Math.max(1, height), estimated: false }; + } } - else { - _utils__WEBPACK_IMPORTED_MODULE_6__["_"].clearElement(this.eSortOrder); + if (rowNode.detail && this.isMasterDetail()) { + // if autoHeight, we want the height to grow to the new height starting at 1, as otherwise a flicker would happen, + // as the detail goes to the default (eg 200px) and then immediately shrink up/down to the new measured height + // (due to auto height) which looks bad, especially if doing row animation. + if (this.isDetailRowAutoHeight()) { + return { height: 1, estimated: false }; + } + if (this.isNumeric(this.gridOptions.detailRowHeight)) { + return { height: this.gridOptions.detailRowHeight, estimated: false }; + } + return { height: DEFAULT_DETAIL_ROW_HEIGHT, estimated: false }; + } + var rowHeight = this.gridOptions.rowHeight && this.isNumeric(this.gridOptions.rowHeight) ? this.gridOptions.rowHeight : defaultRowHeight; + return { height: rowHeight, estimated: false }; + }; + GridOptionsWrapper.prototype.isDynamicRowHeight = function () { + return typeof this.gridOptions.getRowHeight === 'function'; + }; + GridOptionsWrapper.prototype.getListItemHeight = function () { + return this.getFromTheme(20, 'listItemHeight'); + }; + GridOptionsWrapper.prototype.chartMenuPanelWidth = function () { + return this.environment.chartMenuPanelWidth(); + }; + GridOptionsWrapper.prototype.isNumeric = function (value) { + return !isNaN(value) && typeof value === 'number' && isFinite(value); + }; + GridOptionsWrapper.prototype.getFromTheme = function (defaultValue, sassVariableName) { + var theme = this.environment.getTheme().theme; + if (theme && theme.indexOf('ag-theme') === 0) { + return this.environment.getSassVariable(theme, sassVariableName); } + return defaultValue; }; - HeaderComp.prototype.setupFilterIcon = function () { - if (!this.eFilter) { - return; + GridOptionsWrapper.prototype.getDefaultRowHeight = function () { + return this.getFromTheme(DEFAULT_ROW_HEIGHT, 'rowHeight'); + }; + GridOptionsWrapper.prototype.matchesGroupDisplayType = function (toMatch, supplied) { + var groupDisplayTypeValues = ['groupRows', 'multipleColumns', 'custom', 'singleColumn']; + if (groupDisplayTypeValues.indexOf(supplied) < 0) { + console.warn("AG Grid: '" + supplied + "' is not a valid groupDisplayType value - possible values are: '" + groupDisplayTypeValues.join("', '") + "'"); + return false; } - this.addManagedListener(this.params.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_FILTER_CHANGED, this.onFilterChanged.bind(this)); - this.onFilterChanged(); + return supplied === toMatch; }; - HeaderComp.prototype.onFilterChanged = function () { - var filterPresent = this.params.column.isFilterActive(); - _utils__WEBPACK_IMPORTED_MODULE_6__["_"].addOrRemoveCssClass(this.eFilter, 'ag-hidden', !filterPresent); + GridOptionsWrapper.prototype.matchesTreeDataDisplayType = function (toMatch, supplied) { + var treeDataDisplayTypeValues = ['auto', 'custom']; + if (treeDataDisplayTypeValues.indexOf(supplied) < 0) { + console.warn("AG Grid: '" + supplied + "' is not a valid treeDataDisplayType value - possible values are: '" + treeDataDisplayTypeValues.join("', '") + "'"); + return false; + } + return supplied === toMatch; }; - HeaderComp.TEMPLATE = "
\n \n
\n \n \n \n \n \n \n
\n
"; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper') - ], HeaderComp.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('sortController') - ], HeaderComp.prototype, "sortController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('menuFactory') - ], HeaderComp.prototype, "menuFactory", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eFilter') - ], HeaderComp.prototype, "eFilter", void 0); + var GridOptionsWrapper_1; + GridOptionsWrapper.MIN_COL_WIDTH = 10; + GridOptionsWrapper.PROP_HEADER_HEIGHT = 'headerHeight'; + GridOptionsWrapper.PROP_GROUP_REMOVE_SINGLE_CHILDREN = 'groupRemoveSingleChildren'; + GridOptionsWrapper.PROP_GROUP_REMOVE_LOWEST_SINGLE_CHILDREN = 'groupRemoveLowestSingleChildren'; + GridOptionsWrapper.PROP_PIVOT_HEADER_HEIGHT = 'pivotHeaderHeight'; + GridOptionsWrapper.PROP_SUPPRESS_CLIPBOARD_PASTE = 'suppressClipboardPaste'; + GridOptionsWrapper.PROP_GROUP_HEADER_HEIGHT = 'groupHeaderHeight'; + GridOptionsWrapper.PROP_PIVOT_GROUP_HEADER_HEIGHT = 'pivotGroupHeaderHeight'; + GridOptionsWrapper.PROP_NAVIGATE_TO_NEXT_CELL = 'navigateToNextCell'; + GridOptionsWrapper.PROP_TAB_TO_NEXT_CELL = 'tabToNextCell'; + GridOptionsWrapper.PROP_NAVIGATE_TO_NEXT_HEADER = 'navigateToNextHeader'; + GridOptionsWrapper.PROP_TAB_TO_NEXT_HEADER = 'tabToNextHeader'; + GridOptionsWrapper.PROP_IS_EXTERNAL_FILTER_PRESENT = 'isExternalFilterPresent'; + GridOptionsWrapper.PROP_DOES_EXTERNAL_FILTER_PASS = 'doesExternalFilterPass'; + GridOptionsWrapper.PROP_FLOATING_FILTERS_HEIGHT = 'floatingFiltersHeight'; + GridOptionsWrapper.PROP_SUPPRESS_ROW_CLICK_SELECTION = 'suppressRowClickSelection'; + GridOptionsWrapper.PROP_SUPPRESS_ROW_DRAG = 'suppressRowDrag'; + GridOptionsWrapper.PROP_SUPPRESS_MOVE_WHEN_ROW_DRAG = 'suppressMoveWhenRowDragging'; + GridOptionsWrapper.PROP_GET_ROW_CLASS = 'getRowClass'; + GridOptionsWrapper.PROP_GET_ROW_STYLE = 'getRowStyle'; + GridOptionsWrapper.PROP_GET_ROW_HEIGHT = 'getRowHeight'; + GridOptionsWrapper.PROP_POPUP_PARENT = 'popupParent'; + GridOptionsWrapper.PROP_DOM_LAYOUT = 'domLayout'; + GridOptionsWrapper.PROP_FILL_HANDLE_DIRECTION = 'fillHandleDirection'; + GridOptionsWrapper.PROP_GROUP_ROW_AGG_NODES = 'groupRowAggNodes'; + GridOptionsWrapper.PROP_GET_BUSINESS_KEY_FOR_NODE = 'getBusinessKeyForNode'; + GridOptionsWrapper.PROP_GET_CHILD_COUNT = 'getChildCount'; + GridOptionsWrapper.PROP_PROCESS_ROW_POST_CREATE = 'processRowPostCreate'; + GridOptionsWrapper.PROP_GET_ROW_NODE_ID = 'getRowNodeId'; + GridOptionsWrapper.PROP_IS_FULL_WIDTH_CELL = 'isFullWidthCell'; + GridOptionsWrapper.PROP_IS_ROW_SELECTABLE = 'isRowSelectable'; + GridOptionsWrapper.PROP_IS_ROW_MASTER = 'isRowMaster'; + GridOptionsWrapper.PROP_POST_SORT = 'postSort'; + GridOptionsWrapper.PROP_GET_DOCUMENT = 'getDocument'; + GridOptionsWrapper.PROP_POST_PROCESS_POPUP = 'postProcessPopup'; + GridOptionsWrapper.PROP_DEFAULT_GROUP_ORDER_COMPARATOR = 'defaultGroupOrderComparator'; + GridOptionsWrapper.PROP_PAGINATION_NUMBER_FORMATTER = 'paginationNumberFormatter'; + GridOptionsWrapper.PROP_GET_CONTEXT_MENU_ITEMS = 'getContextMenuItems'; + GridOptionsWrapper.PROP_GET_MAIN_MENU_ITEMS = 'getMainMenuItems'; + GridOptionsWrapper.PROP_PROCESS_CELL_FOR_CLIPBOARD = 'processCellForClipboard'; + GridOptionsWrapper.PROP_PROCESS_CELL_FROM_CLIPBOARD = 'processCellFromClipboard'; + GridOptionsWrapper.PROP_SEND_TO_CLIPBOARD = 'sendToClipboard'; + GridOptionsWrapper.PROP_PROCESS_TO_SECONDARY_COLDEF = 'processSecondaryColDef'; + GridOptionsWrapper.PROP_PROCESS_SECONDARY_COL_GROUP_DEF = 'processSecondaryColGroupDef'; + GridOptionsWrapper.PROP_GET_CHART_TOOLBAR_ITEMS = 'getChartToolbarItems'; + GridOptionsWrapper.PROP_GET_SERVER_SIDE_STORE_PARAMS = 'getServerSideStoreParams'; + GridOptionsWrapper.PROP_IS_SERVER_SIDE_GROUPS_OPEN_BY_DEFAULT = 'isServerSideGroupOpenByDefault'; + GridOptionsWrapper.PROP_IS_APPLY_SERVER_SIDE_TRANSACTION = 'isApplyServerSideTransaction'; + GridOptionsWrapper.PROP_IS_SERVER_SIDE_GROUP = 'isServerSideGroup'; + GridOptionsWrapper.PROP_GET_SERVER_SIDE_GROUP_KEY = 'getServerSideGroupKey'; __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eSortAsc') - ], HeaderComp.prototype, "eSortAsc", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('gridOptions') + ], GridOptionsWrapper.prototype, "gridOptions", void 0); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eSortDesc') - ], HeaderComp.prototype, "eSortDesc", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('eventService') + ], GridOptionsWrapper.prototype, "eventService", void 0); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eSortNone') - ], HeaderComp.prototype, "eSortNone", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('environment') + ], GridOptionsWrapper.prototype, "environment", void 0); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eSortOrder') - ], HeaderComp.prototype, "eSortOrder", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('eGridDiv') + ], GridOptionsWrapper.prototype, "eGridDiv", void 0); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eMenu') - ], HeaderComp.prototype, "eMenu", void 0); + __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Qualifier"])('gridApi')), __param(1, Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Qualifier"])('columnApi')) + ], GridOptionsWrapper.prototype, "agWire", null); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eLabel') - ], HeaderComp.prototype, "eLabel", void 0); + _context_context__WEBPACK_IMPORTED_MODULE_3__["PreDestroy"] + ], GridOptionsWrapper.prototype, "destroy", null); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eText') - ], HeaderComp.prototype, "eText", void 0); - return HeaderComp; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); + _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"] + ], GridOptionsWrapper.prototype, "init", null); + GridOptionsWrapper = GridOptionsWrapper_1 = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Bean"])('gridOptionsWrapper') + ], GridOptionsWrapper); + return GridOptionsWrapper; +}()); /***/ }), -/* 65 */ +/* 108 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TouchListener", function() { return TouchListener; }); -/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SideBarDefParser", function() { return SideBarDefParser; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ - - -var TouchListener = /** @class */ (function () { - function TouchListener(eElement, preventMouseClick) { - var _this = this; - if (preventMouseClick === void 0) { preventMouseClick = false; } - this.destroyFuncs = []; - this.touching = false; - this.eventService = new _eventService__WEBPACK_IMPORTED_MODULE_0__["EventService"](); - this.eElement = eElement; - this.preventMouseClick = preventMouseClick; - var startListener = this.onTouchStart.bind(this); - var moveListener = this.onTouchMove.bind(this); - var endListener = this.onTouchEnd.bind(this); - this.eElement.addEventListener("touchstart", startListener, { passive: true }); - this.eElement.addEventListener("touchmove", moveListener, { passive: true }); - // we set passive=false, as we want to prevent default on this event - this.eElement.addEventListener("touchend", endListener, { passive: false }); - this.destroyFuncs.push(function () { - _this.eElement.removeEventListener("touchstart", startListener, { passive: true }); - _this.eElement.removeEventListener("touchmove", moveListener, { passive: true }); - _this.eElement.removeEventListener("touchend", endListener, { passive: false }); - }); +var SideBarDefParser = /** @class */ (function () { + function SideBarDefParser() { } - TouchListener.prototype.getActiveTouch = function (touchList) { - for (var i = 0; i < touchList.length; i++) { - var matches = touchList[i].identifier === this.touchStart.identifier; - if (matches) { - return touchList[i]; - } - } - return null; - }; - TouchListener.prototype.addEventListener = function (eventType, listener) { - this.eventService.addEventListener(eventType, listener); - }; - TouchListener.prototype.removeEventListener = function (eventType, listener) { - this.eventService.removeEventListener(eventType, listener); - }; - TouchListener.prototype.onTouchStart = function (touchEvent) { - var _this = this; - // only looking at one touch point at any time - if (this.touching) { - return; - } - this.touchStart = touchEvent.touches[0]; - this.touching = true; - this.moved = false; - var touchStartCopy = this.touchStart; - window.setTimeout(function () { - var touchesMatch = _this.touchStart === touchStartCopy; - if (_this.touching && touchesMatch && !_this.moved) { - _this.moved = true; - var event_1 = { - type: TouchListener.EVENT_LONG_TAP, - touchStart: _this.touchStart, - touchEvent: touchEvent - }; - _this.eventService.dispatchEvent(event_1); - } - }, 500); - }; - TouchListener.prototype.onTouchMove = function (touchEvent) { - if (!this.touching) { - return; - } - var touch = this.getActiveTouch(touchEvent.touches); - if (!touch) { - return; + SideBarDefParser.parse = function (toParse) { + if (!toParse) { + return null; } - var eventIsFarAway = !_utils__WEBPACK_IMPORTED_MODULE_1__["_"].areEventsNear(touch, this.touchStart, 4); - if (eventIsFarAway) { - this.moved = true; + if (toParse === true) { + return { + toolPanels: [ + SideBarDefParser.DEFAULT_COLUMN_COMP, + SideBarDefParser.DEFAULT_FILTER_COMP, + ], + defaultToolPanel: 'columns' + }; } - }; - TouchListener.prototype.onTouchEnd = function (touchEvent) { - if (!this.touching) { - return; + if (typeof toParse === 'string') { + return SideBarDefParser.parse([toParse]); } - if (!this.moved) { - var event_2 = { - type: TouchListener.EVENT_TAP, - touchStart: this.touchStart + if (Array.isArray(toParse)) { + var comps_1 = []; + toParse.forEach(function (key) { + var lookupResult = SideBarDefParser.DEFAULT_BY_KEY[key]; + if (!lookupResult) { + console.warn("AG Grid: the key " + key + " is not a valid key for specifying a tool panel, valid keys are: " + Object.keys(SideBarDefParser.DEFAULT_BY_KEY).join(',')); + return; + } + comps_1.push(lookupResult); + }); + if (comps_1.length === 0) { + return null; + } + return { + toolPanels: comps_1, + defaultToolPanel: comps_1[0].id }; - this.eventService.dispatchEvent(event_2); - this.checkForDoubleTap(); - } - // stops the tap from also been processed as a mouse click - if (this.preventMouseClick) { - touchEvent.preventDefault(); } - this.touching = false; + var result = { + toolPanels: SideBarDefParser.parseComponents(toParse.toolPanels), + defaultToolPanel: toParse.defaultToolPanel, + hiddenByDefault: toParse.hiddenByDefault, + position: toParse.position + }; + return result; }; - TouchListener.prototype.checkForDoubleTap = function () { - var now = new Date().getTime(); - if (this.lastTapTime && this.lastTapTime > 0) { - // if previous tap, see if duration is short enough to be considered double tap - var interval = now - this.lastTapTime; - if (interval > TouchListener.DOUBLE_TAP_MILLIS) { - // dispatch double tap event - var event_3 = { - type: TouchListener.EVENT_DOUBLE_TAP, - touchStart: this.touchStart - }; - this.eventService.dispatchEvent(event_3); - // this stops a tripple tap ending up as two double taps - this.lastTapTime = null; + SideBarDefParser.parseComponents = function (from) { + var result = []; + if (!from) { + return result; + } + from.forEach(function (it) { + var toAdd = null; + if (typeof it === 'string') { + var lookupResult = SideBarDefParser.DEFAULT_BY_KEY[it]; + if (!lookupResult) { + console.warn("AG Grid: the key " + it + " is not a valid key for specifying a tool panel, valid keys are: " + Object.keys(SideBarDefParser.DEFAULT_BY_KEY).join(',')); + return; + } + toAdd = lookupResult; } else { - this.lastTapTime = now; + toAdd = it; } - } - else { - this.lastTapTime = now; - } + result.push(toAdd); + }); + return result; }; - TouchListener.prototype.destroy = function () { - this.destroyFuncs.forEach(function (func) { return func(); }); + SideBarDefParser.DEFAULT_COLUMN_COMP = { + id: 'columns', + labelDefault: 'Columns', + labelKey: 'columns', + iconKey: 'columns', + toolPanel: 'agColumnsToolPanel', }; - TouchListener.EVENT_TAP = "tap"; - TouchListener.EVENT_DOUBLE_TAP = "doubleTap"; - TouchListener.EVENT_LONG_TAP = "longTap"; - TouchListener.DOUBLE_TAP_MILLIS = 500; - return TouchListener; + SideBarDefParser.DEFAULT_FILTER_COMP = { + id: 'filters', + labelDefault: 'Filters', + labelKey: 'filters', + iconKey: 'filter', + toolPanel: 'agFiltersToolPanel', + }; + SideBarDefParser.DEFAULT_BY_KEY = { + columns: SideBarDefParser.DEFAULT_COLUMN_COMP, + filters: SideBarDefParser.DEFAULT_FILTER_COMP + }; + return SideBarDefParser; }()); /***/ }), -/* 66 */ +/* 109 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderGroupComp", function() { return HeaderGroupComp; }); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _widgets_touchListener__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(65); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(57); -/* harmony import */ var _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(33); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SelectionService", function() { return SelectionService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(23); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(15); +/* harmony import */ var _utils_changedPath__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(110); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(13); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -14490,1312 +22670,2002 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; +var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { + return function (target, key) { decorator(target, key, paramIndex); } +}; -var HeaderGroupComp = /** @class */ (function (_super) { - __extends(HeaderGroupComp, _super); - function HeaderGroupComp() { - return _super.call(this, HeaderGroupComp.TEMPLATE) || this; + + + + +var SelectionService = /** @class */ (function (_super) { + __extends(SelectionService, _super); + function SelectionService() { + return _super !== null && _super.apply(this, arguments) || this; } - // this is a user component, and IComponent has "public destroy()" as part of the interface. - // so we need to override destroy() just to make the method public. - HeaderGroupComp.prototype.destroy = function () { - _super.prototype.destroy.call(this); + SelectionService.prototype.setBeans = function (loggerFactory) { + this.logger = loggerFactory.create('selectionService'); + this.reset(); + if (this.gridOptionsWrapper.isRowModelDefault()) { + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DATA_CHANGED, this.reset.bind(this)); + } }; - HeaderGroupComp.prototype.init = function (params) { - this.params = params; - this.setupLabel(); - this.addGroupExpandIcon(); - this.setupExpandIcons(); + SelectionService.prototype.init = function () { + this.groupSelectsChildren = this.gridOptionsWrapper.isGroupSelectsChildren(); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_SELECTED, this.onRowSelected.bind(this)); }; - HeaderGroupComp.prototype.setupExpandIcons = function () { + SelectionService.prototype.setLastSelectedNode = function (rowNode) { + this.lastSelectedNode = rowNode; + }; + SelectionService.prototype.getLastSelectedNode = function () { + return this.lastSelectedNode; + }; + SelectionService.prototype.getSelectedNodes = function () { + var selectedNodes = []; + Object(_utils_object__WEBPACK_IMPORTED_MODULE_5__["iterateObject"])(this.selectedNodes, function (key, rowNode) { + if (rowNode) { + selectedNodes.push(rowNode); + } + }); + return selectedNodes; + }; + SelectionService.prototype.getSelectedRows = function () { + var selectedRows = []; + Object(_utils_object__WEBPACK_IMPORTED_MODULE_5__["iterateObject"])(this.selectedNodes, function (key, rowNode) { + if (rowNode && rowNode.data) { + selectedRows.push(rowNode.data); + } + }); + return selectedRows; + }; + SelectionService.prototype.removeGroupsFromSelection = function () { var _this = this; - this.addInIcon("columnGroupOpened", "agOpened"); - this.addInIcon("columnGroupClosed", "agClosed"); - var expandAction = function (event) { - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].isStopPropagationForAgGrid(event)) { - return; + Object(_utils_object__WEBPACK_IMPORTED_MODULE_5__["iterateObject"])(this.selectedNodes, function (key, rowNode) { + if (rowNode && rowNode.group) { + _this.selectedNodes[rowNode.id] = undefined; } - var newExpandedValue = !_this.params.columnGroup.isExpanded(); - _this.columnController.setColumnGroupOpened(_this.params.columnGroup.getOriginalColumnGroup(), newExpandedValue, "uiColumnExpanded"); - }; - this.addTouchAndClickListeners(this.eCloseIcon, expandAction); - this.addTouchAndClickListeners(this.eOpenIcon, expandAction); - var stopPropagationAction = function (event) { - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].stopPropagationForAgGrid(event); - }; - // adding stopPropagation to the double click for the icons prevents double click action happening - // when the icons are clicked. if the icons are double clicked, then the groups should open and - // then close again straight away. if we also listened to double click, then the group would open, - // close, then open, which is not what we want. double click should only action if the user double - // clicks outside of the icons. - this.addManagedListener(this.eCloseIcon, "dblclick", stopPropagationAction); - this.addManagedListener(this.eOpenIcon, "dblclick", stopPropagationAction); - this.addManagedListener(this.getGui(), "dblclick", expandAction); - this.updateIconVisibility(); - var originalColumnGroup = this.params.columnGroup.getOriginalColumnGroup(); - this.addManagedListener(originalColumnGroup, _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"].EVENT_EXPANDED_CHANGED, this.updateIconVisibility.bind(this)); - this.addManagedListener(originalColumnGroup, _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"].EVENT_EXPANDABLE_CHANGED, this.updateIconVisibility.bind(this)); + }); }; - HeaderGroupComp.prototype.addTouchAndClickListeners = function (eElement, action) { - var touchListener = new _widgets_touchListener__WEBPACK_IMPORTED_MODULE_2__["TouchListener"](eElement); - this.addManagedListener(touchListener, _widgets_touchListener__WEBPACK_IMPORTED_MODULE_2__["TouchListener"].EVENT_TAP, action); - this.addDestroyFunc(function () { return touchListener.destroy(); }); - this.addManagedListener(eElement, "click", action); + // should only be called if groupSelectsChildren=true + SelectionService.prototype.updateGroupsFromChildrenSelections = function (changedPath) { + // we only do this when group selection state depends on selected children + if (!this.gridOptionsWrapper.isGroupSelectsChildren()) { + return; + } + // also only do it if CSRM (code should never allow this anyway) + if (this.rowModel.getType() !== _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) { + return; + } + var clientSideRowModel = this.rowModel; + var rootNode = clientSideRowModel.getRootNode(); + if (!changedPath) { + changedPath = new _utils_changedPath__WEBPACK_IMPORTED_MODULE_4__["ChangedPath"](true, rootNode); + changedPath.setInactive(); + } + changedPath.forEachChangedNodeDepthFirst(function (rowNode) { + if (rowNode !== rootNode) { + rowNode.calculateSelectedFromChildren(); + } + }); + // clientSideRowModel.getTopLevelNodes()!.forEach((rowNode: RowNode) => { + // rowNode.depthFirstSearch((node) => { + // if (node.group) { + // } + // }); + // }); }; - HeaderGroupComp.prototype.updateIconVisibility = function () { - var columnGroup = this.params.columnGroup; - if (columnGroup.isExpandable()) { - var expanded = this.params.columnGroup.isExpanded(); - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].setDisplayed(this.eOpenIcon, expanded); - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].setDisplayed(this.eCloseIcon, !expanded); + SelectionService.prototype.getNodeForIdIfSelected = function (id) { + return this.selectedNodes[id]; + }; + SelectionService.prototype.clearOtherNodes = function (rowNodeToKeepSelected) { + var _this = this; + var groupsToRefresh = {}; + var updatedCount = 0; + Object(_utils_object__WEBPACK_IMPORTED_MODULE_5__["iterateObject"])(this.selectedNodes, function (key, otherRowNode) { + if (otherRowNode && otherRowNode.id !== rowNodeToKeepSelected.id) { + var rowNode = _this.selectedNodes[otherRowNode.id]; + updatedCount += rowNode.setSelectedParams({ + newValue: false, + clearSelection: false, + suppressFinishActions: true + }); + if (_this.groupSelectsChildren && otherRowNode.parent) { + groupsToRefresh[otherRowNode.parent.id] = otherRowNode.parent; + } + } + }); + Object(_utils_object__WEBPACK_IMPORTED_MODULE_5__["iterateObject"])(groupsToRefresh, function (key, group) { + group.calculateSelectedFromChildren(); + }); + return updatedCount; + }; + SelectionService.prototype.onRowSelected = function (event) { + var rowNode = event.node; + // we do not store the group rows when the groups select children + if (this.groupSelectsChildren && rowNode.group) { + return; + } + if (rowNode.isSelected()) { + this.selectedNodes[rowNode.id] = rowNode; } else { - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].setDisplayed(this.eOpenIcon, false); - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].setDisplayed(this.eCloseIcon, false); + this.selectedNodes[rowNode.id] = undefined; } }; - HeaderGroupComp.prototype.addInIcon = function (iconName, refName) { - var eIcon = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].createIconNoSpan(iconName, this.gridOptionsWrapper, null); - this.getRefElement(refName).appendChild(eIcon); + SelectionService.prototype.syncInRowNode = function (rowNode, oldNode) { + this.syncInOldRowNode(rowNode, oldNode); + this.syncInNewRowNode(rowNode); }; - HeaderGroupComp.prototype.addGroupExpandIcon = function () { - if (!this.params.columnGroup.isExpandable()) { - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].setDisplayed(this.eOpenIcon, false); - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].setDisplayed(this.eCloseIcon, false); + // if the id has changed for the node, then this means the rowNode + // is getting used for a different data item, which breaks + // our selectedNodes, as the node now is mapped by the old id + // which is inconsistent. so to keep the old node as selected, + // we swap in the clone (with the old id and old data). this means + // the oldNode is effectively a daemon we keep a reference to, + // so if client calls api.getSelectedNodes(), it gets the daemon + // in the result. when the client un-selects, the reference to the + // daemon is removed. the daemon, because it's an oldNode, is not + // used by the grid for rendering, it's a copy of what the node used + // to be like before the id was changed. + SelectionService.prototype.syncInOldRowNode = function (rowNode, oldNode) { + var oldNodeHasDifferentId = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_6__["exists"])(oldNode) && (rowNode.id !== oldNode.id); + if (oldNodeHasDifferentId && oldNode) { + var id = oldNode.id; + var oldNodeSelected = this.selectedNodes[id] == rowNode; + if (oldNodeSelected) { + this.selectedNodes[oldNode.id] = oldNode; + } + } + }; + SelectionService.prototype.syncInNewRowNode = function (rowNode) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_6__["exists"])(this.selectedNodes[rowNode.id])) { + rowNode.setSelectedInitialValue(true); + this.selectedNodes[rowNode.id] = rowNode; + } + else { + rowNode.setSelectedInitialValue(false); + } + }; + SelectionService.prototype.reset = function () { + this.logger.log('reset'); + this.selectedNodes = {}; + this.lastSelectedNode = null; + }; + // returns a list of all nodes at 'best cost' - a feature to be used + // with groups / trees. if a group has all it's children selected, + // then the group appears in the result, but not the children. + // Designed for use with 'children' as the group selection type, + // where groups don't actually appear in the selection normally. + SelectionService.prototype.getBestCostNodeSelection = function () { + if (this.rowModel.getType() !== _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) { + console.warn('AG Grid: `getBestCostNodeSelection` is only available when using normal row model'); + return; + } + var clientSideRowModel = this.rowModel; + var topLevelNodes = clientSideRowModel.getTopLevelNodes(); + if (topLevelNodes === null) { + console.warn('AG Grid: `selectAll` not available doing `rowModel=virtual`'); return; } + var result = []; + // recursive function, to find the selected nodes + function traverse(nodes) { + for (var i = 0, l = nodes.length; i < l; i++) { + var node = nodes[i]; + if (node.isSelected()) { + result.push(node); + } + else { + // if not selected, then if it's a group, and the group + // has children, continue to search for selections + var maybeGroup = node; + if (maybeGroup.group && maybeGroup.children) { + traverse(maybeGroup.children); + } + } + } + } + traverse(topLevelNodes); + return result; + }; + SelectionService.prototype.setRowModel = function (rowModel) { + this.rowModel = rowModel; + }; + SelectionService.prototype.isEmpty = function () { + var count = 0; + Object(_utils_object__WEBPACK_IMPORTED_MODULE_5__["iterateObject"])(this.selectedNodes, function (nodeId, rowNode) { + if (rowNode) { + count++; + } + }); + return count === 0; + }; + SelectionService.prototype.deselectAllRowNodes = function (justFiltered) { + if (justFiltered === void 0) { justFiltered = false; } + var callback = function (rowNode) { return rowNode.selectThisNode(false); }; + var rowModelClientSide = this.rowModel.getType() === _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE; + if (justFiltered) { + if (!rowModelClientSide) { + console.error('AG Grid: selecting just filtered only works with In Memory Row Model'); + return; + } + var clientSideRowModel = this.rowModel; + clientSideRowModel.forEachNodeAfterFilter(callback); + } + else { + Object(_utils_object__WEBPACK_IMPORTED_MODULE_5__["iterateObject"])(this.selectedNodes, function (id, rowNode) { + // remember the reference can be to null, as we never 'delete' from the map + if (rowNode) { + callback(rowNode); + } + }); + // this clears down the map (whereas above only sets the items in map to 'undefined') + this.reset(); + } + // the above does not clean up the parent rows if they are selected + if (rowModelClientSide && this.groupSelectsChildren) { + this.updateGroupsFromChildrenSelections(); + } + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_SELECTION_CHANGED, + api: this.gridApi, + columnApi: this.columnApi + }; + this.eventService.dispatchEvent(event); + }; + SelectionService.prototype.selectAllRowNodes = function (justFiltered) { + if (justFiltered === void 0) { justFiltered = false; } + if (this.rowModel.getType() !== _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) { + throw new Error("selectAll only available with normal row model, ie not " + this.rowModel.getType()); + } + var clientSideRowModel = this.rowModel; + var callback = function (rowNode) { return rowNode.selectThisNode(true); }; + if (justFiltered) { + clientSideRowModel.forEachNodeAfterFilter(callback); + } + else { + clientSideRowModel.forEachNode(callback); + } + // the above does not clean up the parent rows if they are selected + if (this.rowModel.getType() === _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE && this.groupSelectsChildren) { + this.updateGroupsFromChildrenSelections(); + } + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_SELECTION_CHANGED, + api: this.gridApi, + columnApi: this.columnApi + }; + this.eventService.dispatchEvent(event); + }; + /** + * @method + * @deprecated + */ + SelectionService.prototype.selectNode = function (rowNode, tryMulti) { + if (rowNode) { + rowNode.setSelectedParams({ newValue: true, clearSelection: !tryMulti }); + } }; - HeaderGroupComp.prototype.setupLabel = function () { - // no renderer, default text render - var displayName = this.params.displayName; - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(displayName)) { - var displayNameSanitised = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].escape(displayName); - this.getRefElement("agLabel").innerHTML = displayNameSanitised; + /** + * @method + * @deprecated + */ + SelectionService.prototype.deselectIndex = function (rowIndex) { + var node = this.rowModel.getRow(rowIndex); + this.deselectNode(node); + }; + /** + * @method + * @deprecated + */ + SelectionService.prototype.deselectNode = function (rowNode) { + if (rowNode) { + rowNode.setSelectedParams({ newValue: false, clearSelection: false }); } }; - HeaderGroupComp.TEMPLATE = "
\n \n \n \n
"; + /** + * @method + * @deprecated + */ + SelectionService.prototype.selectIndex = function (index, tryMulti) { + var node = this.rowModel.getRow(index); + this.selectNode(node, tryMulti); + }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])("columnController") - ], HeaderGroupComp.prototype, "columnController", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel') + ], SelectionService.prototype, "rowModel", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])("gridOptionsWrapper") - ], HeaderGroupComp.prototype, "gridOptionsWrapper", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') + ], SelectionService.prototype, "columnApi", void 0); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])("agOpened") - ], HeaderGroupComp.prototype, "eOpenIcon", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') + ], SelectionService.prototype, "gridApi", void 0); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])("agClosed") - ], HeaderGroupComp.prototype, "eCloseIcon", void 0); - return HeaderGroupComp; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); + __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('loggerFactory')) + ], SelectionService.prototype, "setBeans", null); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], SelectionService.prototype, "init", null); + SelectionService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('selectionService') + ], SelectionService); + return SelectionService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 67 */ +/* 110 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GroupCellRenderer", function() { return GroupCellRenderer; }); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(25); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(56); -/* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(68); -/* harmony import */ var _checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(69); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(57); -/* harmony import */ var _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(74); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ChangedPath", function() { return ChangedPath; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); +// when doing transactions, or change detection, and grouping is present +// in the data, there is no need for the ClientSideRowModel to update each +// group after an update, ony parts that were impacted by the change. +// this class keeps track of all groups that were impacted by a transaction. +// the the different CSRM operations (filter, sort etc) use the forEach method +// to visit each group that was changed. +var ChangedPath = /** @class */ (function () { + function ChangedPath(keepingColumns, rootNode) { + // whether changed path is active of not. it is active when a) doing + // a transaction update or b) doing change detection. if we are doing + // a CSRM refresh for other reasons (after sort or filter, or user calling + // setRowData() without delta mode) then we are not active. we are also + // marked as not active if secondary columns change in pivot (as this impacts + // aggregations) + this.active = true; + // for each node in the change path, we also store which columns need + // to be re-aggregated. + this.nodeIdsToColumns = {}; + // for quick lookup, all items in the change path are mapped by nodeId + this.mapToItems = {}; + this.keepingColumns = keepingColumns; + this.pathRoot = { + rowNode: rootNode, + children: null + }; + this.mapToItems[rootNode.id] = this.pathRoot; + } + // can be set inactive by: + // a) ClientSideRowModel, if no transactions or + // b) PivotService, if secondary columns changed + ChangedPath.prototype.setInactive = function () { + this.active = false; }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + ChangedPath.prototype.isActive = function () { + return this.active; }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - - - - - -var GroupCellRenderer = /** @class */ (function (_super) { - __extends(GroupCellRenderer, _super); - function GroupCellRenderer() { - return _super.call(this, GroupCellRenderer.TEMPLATE) || this; - } - GroupCellRenderer.prototype.init = function (params) { - this.params = params; - if (this.gridOptionsWrapper.isGroupIncludeTotalFooter()) { - this.assignBlankValueToGroupFooterCell(params); - } - var embeddedRowMismatch = this.isEmbeddedRowMismatch(); - // This allows for empty strings to appear as groups since - // it will only return for null or undefined. - var nullValue = params.value == null; - var skipCell = false; - // if the groupCellRenderer is inside of a footer and groupHideOpenParents is true - // we should only display the groupCellRenderer if the current column is the rowGroupedColumn - if (this.gridOptionsWrapper.isGroupIncludeFooter() && this.gridOptionsWrapper.isGroupHideOpenParents()) { - var node = params.node; - if (node.footer) { - var showRowGroup = params.colDef && params.colDef.showRowGroup; - var rowGroupColumnId = node.rowGroupColumn && node.rowGroupColumn.getColId(); - skipCell = showRowGroup !== rowGroupColumnId; + ChangedPath.prototype.depthFirstSearchChangedPath = function (pathItem, callback) { + if (pathItem.children) { + for (var i = 0; i < pathItem.children.length; i++) { + this.depthFirstSearchChangedPath(pathItem.children[i], callback); } } - this.cellIsBlank = embeddedRowMismatch || nullValue || skipCell; - if (this.cellIsBlank) { - return; - } - this.setupDragOpenParents(); - this.addExpandAndContract(); - this.addCheckboxIfNeeded(); - this.addValueElement(); - this.setupIndent(); - }; - GroupCellRenderer.prototype.assignBlankValueToGroupFooterCell = function (params) { - // this is not ideal, but it was the only way we could get footer working for the root node - if (!params.value && params.node.level == -1) { - params.value = ''; - } + callback(pathItem.rowNode); }; - // if we are doing embedded full width rows, we only show the renderer when - // in the body, or if pinning in the pinned section, or if pinning and RTL, - // in the right section. otherwise we would have the cell repeated in each section. - GroupCellRenderer.prototype.isEmbeddedRowMismatch = function () { - if (!this.params.fullWidth || !this.gridOptionsWrapper.isEmbedFullWidthRows()) { - return false; - } - var pinnedLeftCell = this.params.pinned === _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_LEFT; - var pinnedRightCell = this.params.pinned === _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_RIGHT; - var bodyCell = !pinnedLeftCell && !pinnedRightCell; - if (this.gridOptionsWrapper.isEnableRtl()) { - if (this.columnController.isPinningLeft()) { - return !pinnedRightCell; + ChangedPath.prototype.depthFirstSearchEverything = function (rowNode, callback, traverseEverything) { + if (rowNode.childrenAfterGroup) { + for (var i = 0; i < rowNode.childrenAfterGroup.length; i++) { + var childNode = rowNode.childrenAfterGroup[i]; + if (childNode.childrenAfterGroup) { + this.depthFirstSearchEverything(rowNode.childrenAfterGroup[i], callback, traverseEverything); + } + else if (traverseEverything) { + callback(childNode); + } } - return !bodyCell; - } - if (this.columnController.isPinningLeft()) { - return !pinnedLeftCell; } - return !bodyCell; + callback(rowNode); }; - GroupCellRenderer.prototype.setIndent = function () { - if (this.gridOptionsWrapper.isGroupHideOpenParents()) { - return; - } - var params = this.params; - var rowNode = params.node; - var paddingCount = rowNode.uiLevel; - var userProvidedPaddingPixelsTheDeprecatedWay = params.padding >= 0; - if (userProvidedPaddingPixelsTheDeprecatedWay) { - this.setPaddingDeprecatedWay(paddingCount, params.padding); - return; + // traverseLeafNodes -> used when NOT doing changed path, ie traversing everything. the callback + // will be called for child nodes in addition to parent nodes. + ChangedPath.prototype.forEachChangedNodeDepthFirst = function (callback, traverseLeafNodes) { + if (traverseLeafNodes === void 0) { traverseLeafNodes = false; } + if (this.active) { + // if we are active, then use the change path to callback + // only for updated groups + this.depthFirstSearchChangedPath(this.pathRoot, callback); } - if (this.indentClass) { - this.removeCssClass(this.indentClass); + else { + // we are not active, so callback for everything, walk the entire path + this.depthFirstSearchEverything(this.pathRoot.rowNode, callback, traverseLeafNodes); } - this.indentClass = 'ag-row-group-indent-' + paddingCount; - this.addCssClass(this.indentClass); }; - GroupCellRenderer.prototype.setPaddingDeprecatedWay = function (paddingCount, padding) { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].doOnce(function () { return console.warn('ag-Grid: since v14.2, configuring padding for groupCellRenderer should be done with Sass variables and themes. Please see the ag-Grid documentation page for Themes, in particular the property $row-group-indent-size.'); }, 'groupCellRenderer->doDeprecatedWay'); - var paddingPx = paddingCount * padding; - var eGui = this.getGui(); - var paddingSide = this.gridOptionsWrapper.isEnableRtl() ? 'paddingRight' : 'paddingLeft'; - eGui.style[paddingSide] = paddingPx + "px"; + ChangedPath.prototype.executeFromRootNode = function (callback) { + callback(this.pathRoot.rowNode); }; - GroupCellRenderer.prototype.setupIndent = function () { - // only do this if an indent - as this overwrites the padding that - // the theme set, which will make things look 'not aligned' for the - // first group level. - var node = this.params.node; - var suppressPadding = this.params.suppressPadding; - if (!suppressPadding) { - this.addManagedListener(node, _entities_rowNode__WEBPACK_IMPORTED_MODULE_3__["RowNode"].EVENT_UI_LEVEL_CHANGED, this.setIndent.bind(this)); - this.setIndent(); + ChangedPath.prototype.createPathItems = function (rowNode) { + var pointer = rowNode; + var newEntryCount = 0; + while (!this.mapToItems[pointer.id]) { + var newEntry = { + rowNode: pointer, + children: null + }; + this.mapToItems[pointer.id] = newEntry; + newEntryCount++; + pointer = pointer.parent; } + return newEntryCount; }; - GroupCellRenderer.prototype.addValueElement = function () { - var params = this.params; - var rowNode = this.displayedGroup; - if (rowNode.footer) { - this.createFooterCell(); - } - else if (rowNode.hasChildren() || - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].get(params.colDef, 'cellRendererParams.innerRenderer', null) || - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].get(params.colDef, 'cellRendererParams.innerRendererFramework', null)) { - this.createGroupCell(); - if (rowNode.hasChildren()) { - this.addChildCount(); - } + ChangedPath.prototype.populateColumnsMap = function (rowNode, columns) { + var _this = this; + if (!this.keepingColumns || !columns) { + return; } - else { - this.createLeafCell(); + var pointer = rowNode; + while (pointer) { + // if columns, add the columns in all the way to parent, merging + // in any other columns that might be there already + if (!this.nodeIdsToColumns[pointer.id]) { + this.nodeIdsToColumns[pointer.id] = {}; + } + columns.forEach(function (col) { return _this.nodeIdsToColumns[pointer.id][col.getId()] = true; }); + pointer = pointer.parent; } }; - GroupCellRenderer.prototype.createFooterCell = function () { - var footerValueGetter = this.params.footerValueGetter; - var footerValue; - if (footerValueGetter) { - // params is same as we were given, except we set the value as the item to display - var paramsClone = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].cloneObject(this.params); - paramsClone.value = this.params.value; - if (typeof footerValueGetter === 'function') { - footerValue = footerValueGetter(paramsClone); - } - else if (typeof footerValueGetter === 'string') { - footerValue = this.expressionService.evaluate(footerValueGetter, paramsClone); - } - else { - console.warn('ag-Grid: footerValueGetter should be either a function or a string (expression)'); + ChangedPath.prototype.linkPathItems = function (rowNode, newEntryCount) { + var pointer = rowNode; + for (var i = 0; i < newEntryCount; i++) { + var thisItem = this.mapToItems[pointer.id]; + var parentItem = this.mapToItems[pointer.parent.id]; + if (!parentItem.children) { + parentItem.children = []; } + parentItem.children.push(thisItem); + pointer = pointer.parent; } - else { - footerValue = 'Total ' + this.params.value; - } - this.eValue.innerHTML = footerValue; }; - GroupCellRenderer.prototype.createGroupCell = function () { - var _this = this; - var params = this.params; - var rowGroupColumn = this.displayedGroup.rowGroupColumn; - // we try and use the cellRenderer of the column used for the grouping if we can - var columnToUse = rowGroupColumn ? rowGroupColumn : params.column; - var groupName = this.params.value; - var valueFormatted = columnToUse ? - this.valueFormatterService.formatValue(columnToUse, params.node, params.scope, groupName) : null; - params.valueFormatted = valueFormatted; - var rendererPromise; - rendererPromise = params.fullWidth - ? this.useFullWidth(params) - : this.useInnerRenderer(this.params.colDef.cellRendererParams, columnToUse.getColDef(), params); - // retain a reference to the created renderer - we'll use this later for cleanup (in destroy) - if (rendererPromise) { - rendererPromise.then(function (value) { - _this.innerCellRenderer = value; - }); + // called by + // 1) change detection (provides cols) and + // 2) groupStage if doing transaction update (doesn't provide cols) + ChangedPath.prototype.addParentNode = function (rowNode, columns) { + if (!rowNode || rowNode.isRowPinned()) { + return; } + // we cannot do both steps below in the same loop as + // the second loop has a dependency on the first loop. + // ie the hierarchy cannot be stitched up yet because + // we don't have it built yet + // create the new PathItem objects. + var newEntryCount = this.createPathItems(rowNode); + // link in the node items + this.linkPathItems(rowNode, newEntryCount); + // update columns + this.populateColumnsMap(rowNode, columns); }; - GroupCellRenderer.prototype.useInnerRenderer = function (groupCellRendererParams, groupedColumnDef, // the column this group row is for, eg 'Country' - params) { - var _this = this; - // when grouping, the normal case is we use the cell renderer of the grouped column. eg if grouping by country - // and then rating, we will use the country cell renderer for each country group row and likewise the rating - // cell renderer for each rating group row. - // - // however if the user has innerCellRenderer defined, this gets preference and we don't use cell renderers - // of the grouped columns. - // - // so we check and use in the following order: - // - // 1) thisColDef.cellRendererParams.innerRenderer of the column showing the groups (eg auto group column) - // 2) groupedColDef.cellRenderer of the grouped column - // 3) groupedColDef.cellRendererParams.innerRenderer - var cellRendererPromise = null; - // we check if cell renderer provided for the group cell renderer, eg colDef.cellRendererParams.innerRenderer - var groupInnerRendererClass = this.userComponentFactory - .lookupComponentClassDef(groupCellRendererParams, "innerRenderer"); - if (groupInnerRendererClass && groupInnerRendererClass.component != null - && groupInnerRendererClass.source != _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_6__["ComponentSource"].DEFAULT) { - // use the renderer defined in cellRendererParams.innerRenderer - cellRendererPromise = this.userComponentFactory.newInnerCellRenderer(groupCellRendererParams, params); - } - else { - // otherwise see if we can use the cellRenderer of the column we are grouping by - var groupColumnRendererClass = this.userComponentFactory - .lookupComponentClassDef(groupedColumnDef, "cellRenderer"); - if (groupColumnRendererClass && - groupColumnRendererClass.source != _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_6__["ComponentSource"].DEFAULT) { - // Only if the original column is using a specific renderer, it it is a using a DEFAULT one ignore it - cellRendererPromise = this.userComponentFactory.newCellRenderer(groupedColumnDef, params); - } - else if (groupColumnRendererClass && - groupColumnRendererClass.source == _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_6__["ComponentSource"].DEFAULT && - (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].get(groupedColumnDef, 'cellRendererParams.innerRenderer', null))) { - // EDGE CASE - THIS COMES FROM A COLUMN WHICH HAS BEEN GROUPED DYNAMICALLY, THAT HAS AS RENDERER 'group' - // AND HAS A INNER CELL RENDERER - cellRendererPromise = this.userComponentFactory.newInnerCellRenderer(groupedColumnDef.cellRendererParams, params); - } - else { - // This forces the retrieval of the default plain cellRenderer that just renders the values. - cellRendererPromise = this.userComponentFactory.newCellRenderer({}, params); - } - } - if (cellRendererPromise != null) { - cellRendererPromise.then(function (rendererToUse) { - if (rendererToUse == null) { - _this.eValue.innerText = params.valueFormatted != null ? params.valueFormatted : params.value; - return; - } - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].bindCellRendererToHtmlElement(cellRendererPromise, _this.eValue); - }); + ChangedPath.prototype.canSkip = function (rowNode) { + return this.active && !this.mapToItems[rowNode.id]; + }; + ChangedPath.prototype.getValueColumnsForNode = function (rowNode, valueColumns) { + if (!this.keepingColumns) { + return valueColumns; } - else { - this.eValue.innerText = params.valueFormatted != null ? params.valueFormatted : params.value; + var colsForThisNode = this.nodeIdsToColumns[rowNode.id]; + var result = valueColumns.filter(function (col) { return colsForThisNode[col.getId()]; }); + return result; + }; + ChangedPath.prototype.getNotValueColumnsForNode = function (rowNode, valueColumns) { + if (!this.keepingColumns) { + return null; } - return cellRendererPromise; + var colsForThisNode = this.nodeIdsToColumns[rowNode.id]; + var result = valueColumns.filter(function (col) { return !colsForThisNode[col.getId()]; }); + return result; }; - GroupCellRenderer.prototype.useFullWidth = function (params) { - var cellRendererPromise = this.userComponentFactory.newFullWidthGroupRowInnerCellRenderer(params); - if (cellRendererPromise != null) { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].bindCellRendererToHtmlElement(cellRendererPromise, this.eValue); + return ChangedPath; +}()); + + + +/***/ }), +/* 111 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnApi", function() { return ColumnApi; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + +var ColumnApi = /** @class */ (function () { + function ColumnApi() { + } + /** Gets the grid to size the columns to the specified width in pixels, e.g. `sizeColumnsToFit(900)`. To have the grid fit the columns to the grid's width, use the Grid API `gridApi.sizeColumnsToFit()` instead. */ + ColumnApi.prototype.sizeColumnsToFit = function (gridWidth) { + // AG-3403 validate that gridWidth is provided because this method has the same name as + // a method on the grid API that takes no arguments, and it's easy to confuse the two + if (typeof gridWidth === "undefined") { + console.error('AG Grid: missing parameter to columnApi.sizeColumnsToFit(gridWidth)'); + } + this.columnModel.sizeColumnsToFit(gridWidth, 'api'); + }; + /** Call this if you want to open or close a column group. */ + ColumnApi.prototype.setColumnGroupOpened = function (group, newValue) { this.columnModel.setColumnGroupOpened(group, newValue, 'api'); }; + /** Returns the column group with the given name. */ + ColumnApi.prototype.getColumnGroup = function (name, instanceId) { return this.columnModel.getColumnGroup(name, instanceId); }; + /** Returns the provided column group with the given name. */ + ColumnApi.prototype.getProvidedColumnGroup = function (name) { return this.columnModel.getProvidedColumnGroup(name); }; + /** Returns the display name for a column. Useful if you are doing your own header rendering and want the grid to work out if `headerValueGetter` is used, or if you are doing your own column management GUI, to know what to show as the column name. */ + ColumnApi.prototype.getDisplayNameForColumn = function (column, location) { return this.columnModel.getDisplayNameForColumn(column, location) || ''; }; + /** Returns the display name for a column group (when grouping columns). */ + ColumnApi.prototype.getDisplayNameForColumnGroup = function (columnGroup, location) { return this.columnModel.getDisplayNameForColumnGroup(columnGroup, location) || ''; }; + /** Returns the column with the given `colKey`, which can either be the `colId` (a string) or the `colDef` (an object). */ + ColumnApi.prototype.getColumn = function (key) { return this.columnModel.getPrimaryColumn(key); }; + /** Applies the state of the columns from a previous state. Returns `false` if one or more columns could not be found. */ + ColumnApi.prototype.applyColumnState = function (params) { return this.columnModel.applyColumnState(params, 'api'); }; + /** Gets the state of the columns. Typically used when saving column state. */ + ColumnApi.prototype.getColumnState = function () { return this.columnModel.getColumnState(); }; + /** Sets the state back to match the originally provided column definitions. */ + ColumnApi.prototype.resetColumnState = function () { this.columnModel.resetColumnState('api'); }; + /** Gets the state of the column groups. Typically used when saving column group state. */ + ColumnApi.prototype.getColumnGroupState = function () { return this.columnModel.getColumnGroupState(); }; + /** Sets the state of the column group state from a previous state. */ + ColumnApi.prototype.setColumnGroupState = function (stateItems) { this.columnModel.setColumnGroupState(stateItems, 'api'); }; + /** Sets the state back to match the originally provided column definitions. */ + ColumnApi.prototype.resetColumnGroupState = function () { this.columnModel.resetColumnGroupState('api'); }; + /** Returns `true` if pinning left or right, otherwise `false`. */ + ColumnApi.prototype.isPinning = function () { return this.columnModel.isPinningLeft() || this.columnModel.isPinningRight(); }; + /** Returns `true` if pinning left, otherwise `false`. */ + ColumnApi.prototype.isPinningLeft = function () { return this.columnModel.isPinningLeft(); }; + /** Returns `true` if pinning right, otherwise `false`. */ + ColumnApi.prototype.isPinningRight = function () { return this.columnModel.isPinningRight(); }; + /** Returns the column to the right of the provided column, taking into consideration open / closed column groups and visible columns. This is useful if you need to know what column is beside yours e.g. if implementing your own cell navigation. */ + ColumnApi.prototype.getDisplayedColAfter = function (col) { return this.columnModel.getDisplayedColAfter(col); }; + /** Same as `getVisibleColAfter` except gives column to the left. */ + ColumnApi.prototype.getDisplayedColBefore = function (col) { return this.columnModel.getDisplayedColBefore(col); }; + /** Sets the visibility of a column. Key can be the column ID or `Column` object. */ + ColumnApi.prototype.setColumnVisible = function (key, visible) { this.columnModel.setColumnVisible(key, visible, 'api'); }; + /** Same as `setColumnVisible`, but provide a list of column keys. */ + ColumnApi.prototype.setColumnsVisible = function (keys, visible) { this.columnModel.setColumnsVisible(keys, visible, 'api'); }; + /** Sets the column pinned / unpinned. Key can be the column ID, field, `ColDef` object or `Column` object. */ + ColumnApi.prototype.setColumnPinned = function (key, pinned) { this.columnModel.setColumnPinned(key, pinned, 'api'); }; + /** Same as `setColumnPinned`, but provide a list of column keys. */ + ColumnApi.prototype.setColumnsPinned = function (keys, pinned) { this.columnModel.setColumnsPinned(keys, pinned, 'api'); }; + /** Returns all the columns, regardless of visible or not. */ + ColumnApi.prototype.getAllColumns = function () { return this.columnModel.getAllPrimaryColumns(); }; + /** + * Returns all the grid columns, same as `getAllColumns()`, except + * + * a) it has the order of the columns that are presented in the grid + * + * b) it's after the 'pivot' step, so if pivoting, has the value columns for the pivot. + */ + ColumnApi.prototype.getAllGridColumns = function () { return this.columnModel.getAllGridColumns(); }; + /** Same as `getAllDisplayedColumns` but just for the pinned left portion of the grid. */ + ColumnApi.prototype.getDisplayedLeftColumns = function () { return this.columnModel.getDisplayedLeftColumns(); }; + /** Same as `getAllDisplayedColumns` but just for the center portion of the grid. */ + ColumnApi.prototype.getDisplayedCenterColumns = function () { return this.columnModel.getDisplayedCenterColumns(); }; + /** Same as `getAllDisplayedColumns` but just for the pinned right portion of the grid. */ + ColumnApi.prototype.getDisplayedRightColumns = function () { return this.columnModel.getDisplayedRightColumns(); }; + /** Returns all columns currently displayed (e.g. are visible and if in a group, the group is showing the columns) for the pinned left, centre and pinned right portions of the grid. */ + ColumnApi.prototype.getAllDisplayedColumns = function () { return this.columnModel.getAllDisplayedColumns(); }; + /** Same as `getAllGridColumns()`, except only returns rendered columns, i.e. columns that are not within the viewport and therefore not rendered, due to column virtualisation, are not displayed. */ + ColumnApi.prototype.getAllDisplayedVirtualColumns = function () { return this.columnModel.getViewportColumns(); }; + /** Moves a column to `toIndex`. The column is first removed, then added at the `toIndex` location, thus index locations will change to the right of the column after the removal. */ + ColumnApi.prototype.moveColumn = function (key, toIndex) { + if (typeof key === 'number') { + // moveColumn used to take indexes, so this is advising user who hasn't moved to new method name + console.warn('AG Grid: you are using moveColumn(fromIndex, toIndex) - moveColumn takes a column key and a destination index, not two indexes, to move with indexes use moveColumnByIndex(from,to) instead'); + this.columnModel.moveColumnByIndex(key, toIndex, 'api'); } else { - this.eValue.innerText = params.valueFormatted != null ? params.valueFormatted : params.value; - } - return cellRendererPromise; + this.columnModel.moveColumn(key, toIndex, 'api'); + } + }; + /** Same as `moveColumn` but works on index locations. */ + ColumnApi.prototype.moveColumnByIndex = function (fromIndex, toIndex) { this.columnModel.moveColumnByIndex(fromIndex, toIndex, 'api'); }; + /** Same as `moveColumn` but works on list. */ + ColumnApi.prototype.moveColumns = function (columnsToMoveKeys, toIndex) { this.columnModel.moveColumns(columnsToMoveKeys, toIndex, 'api'); }; + /** Move the column to a new position in the row grouping order. */ + ColumnApi.prototype.moveRowGroupColumn = function (fromIndex, toIndex) { this.columnModel.moveRowGroupColumn(fromIndex, toIndex); }; + /** Sets the agg function for a column. `aggFunc` can be one of `'min' | 'max' | 'sum'`. */ + ColumnApi.prototype.setColumnAggFunc = function (key, aggFunc) { this.columnModel.setColumnAggFunc(key, aggFunc); }; + /** Sets the column width on a single column. The finished flag gets included in the resulting event and not used internally by the grid. The finished flag is intended for dragging, where a dragging action will produce many `columnWidth` events, so the consumer of events knows when it receives the last event in a stream. The finished parameter is optional, and defaults to `true`. */ + ColumnApi.prototype.setColumnWidth = function (key, newWidth, finished, source) { + if (finished === void 0) { finished = true; } + this.columnModel.setColumnWidths([{ key: key, newWidth: newWidth }], false, finished, source); }; - GroupCellRenderer.prototype.addChildCount = function () { - // only include the child count if it's included, eg if user doing custom aggregation, - // then this could be left out, or set to -1, ie no child count - if (this.params.suppressCount) { - return; - } - this.addManagedListener(this.displayedGroup, _entities_rowNode__WEBPACK_IMPORTED_MODULE_3__["RowNode"].EVENT_ALL_CHILDREN_COUNT_CHANGED, this.updateChildCount.bind(this)); - // filtering changes the child count, so need to cater for it - this.updateChildCount(); + /** Sets the column widths on multiple columns. This method offers better performance than calling `setColumnWidth` multiple times. The finished flag gets included in the resulting event and not used internally by the grid. The finished flag is intended for dragging, where a dragging action will produce many `columnWidth` events, so the consumer of events knows when it receives the last event in a stream. The finished parameter is optional, and defaults to `true`. */ + ColumnApi.prototype.setColumnWidths = function (columnWidths, finished, source) { + if (finished === void 0) { finished = true; } + this.columnModel.setColumnWidths(columnWidths, false, finished, source); + }; + /** Set the pivot mode. */ + ColumnApi.prototype.setPivotMode = function (pivotMode) { this.columnModel.setPivotMode(pivotMode); }; + /** Get the pivot mode. */ + ColumnApi.prototype.isPivotMode = function () { return this.columnModel.isPivotMode(); }; + /** Returns the pivot column for the given `pivotKeys` and `valueColId`. Useful to then call operations on the pivot column. */ + ColumnApi.prototype.getSecondaryPivotColumn = function (pivotKeys, valueColKey) { return this.columnModel.getSecondaryPivotColumn(pivotKeys, valueColKey); }; + /** Set the value columns. */ + ColumnApi.prototype.setValueColumns = function (colKeys) { this.columnModel.setValueColumns(colKeys, 'api'); }; + /** Get value columns. */ + ColumnApi.prototype.getValueColumns = function () { return this.columnModel.getValueColumns(); }; + /** Remove a value column. */ + ColumnApi.prototype.removeValueColumn = function (colKey) { this.columnModel.removeValueColumn(colKey, 'api'); }; + /** Same as `removeValueColumns` but provide a list. */ + ColumnApi.prototype.removeValueColumns = function (colKeys) { this.columnModel.removeValueColumns(colKeys, 'api'); }; + /** Add a value column. */ + ColumnApi.prototype.addValueColumn = function (colKey) { this.columnModel.addValueColumn(colKey, 'api'); }; + /** Same as `addValueColumn` but provide a list. */ + ColumnApi.prototype.addValueColumns = function (colKeys) { this.columnModel.addValueColumns(colKeys, 'api'); }; + /** Set the row group columns. */ + ColumnApi.prototype.setRowGroupColumns = function (colKeys) { this.columnModel.setRowGroupColumns(colKeys, 'api'); }; + /** Remove a column from the row groups. */ + ColumnApi.prototype.removeRowGroupColumn = function (colKey) { this.columnModel.removeRowGroupColumn(colKey, 'api'); }; + /** Same as `removeRowGroupColumn` but provide a list of columns. */ + ColumnApi.prototype.removeRowGroupColumns = function (colKeys) { this.columnModel.removeRowGroupColumns(colKeys, 'api'); }; + /** Add a column to the row groups. */ + ColumnApi.prototype.addRowGroupColumn = function (colKey) { this.columnModel.addRowGroupColumn(colKey, 'api'); }; + /** Same as `addRowGroupColumn` but provide a list of columns. */ + ColumnApi.prototype.addRowGroupColumns = function (colKeys) { this.columnModel.addRowGroupColumns(colKeys, 'api'); }; + /** Get row group columns. */ + ColumnApi.prototype.getRowGroupColumns = function () { return this.columnModel.getRowGroupColumns(); }; + /** Set the pivot columns. */ + ColumnApi.prototype.setPivotColumns = function (colKeys) { this.columnModel.setPivotColumns(colKeys, 'api'); }; + /** Remove a pivot column. */ + ColumnApi.prototype.removePivotColumn = function (colKey) { this.columnModel.removePivotColumn(colKey, 'api'); }; + /** Same as `removePivotColumn` but provide a list of columns. */ + ColumnApi.prototype.removePivotColumns = function (colKeys) { this.columnModel.removePivotColumns(colKeys, 'api'); }; + /** Add a pivot column. */ + ColumnApi.prototype.addPivotColumn = function (colKey) { this.columnModel.addPivotColumn(colKey, 'api'); }; + /** Same as `addPivotColumn` but provide a list of columns. */ + ColumnApi.prototype.addPivotColumns = function (colKeys) { this.columnModel.addPivotColumns(colKeys, 'api'); }; + /** Get the pivot columns. */ + ColumnApi.prototype.getPivotColumns = function () { return this.columnModel.getPivotColumns(); }; + /** Same as `getAllDisplayedColumnGroups` but just for the pinned left portion of the grid. */ + ColumnApi.prototype.getLeftDisplayedColumnGroups = function () { return this.columnModel.getDisplayedTreeLeft(); }; + /** Same as `getAllDisplayedColumnGroups` but just for the center portion of the grid. */ + ColumnApi.prototype.getCenterDisplayedColumnGroups = function () { return this.columnModel.getDisplayedTreeCentre(); }; + /** Same as `getAllDisplayedColumnGroups` but just for the pinned right portion of the grid. */ + ColumnApi.prototype.getRightDisplayedColumnGroups = function () { return this.columnModel.getDisplayedTreeRight(); }; + /** Returns all 'root' column headers. If you are not grouping columns, these return the columns. If you are grouping, these return the top level groups - you can navigate down through each one to get the other lower level headers and finally the columns at the bottom. */ + ColumnApi.prototype.getAllDisplayedColumnGroups = function () { return this.columnModel.getAllDisplayedTrees(); }; + /** Auto-sizes a column based on its contents. */ + ColumnApi.prototype.autoSizeColumn = function (key, skipHeader) { return this.columnModel.autoSizeColumn(key, skipHeader, 'api'); }; + /** Same as `autoSizeColumn`, but provide a list of column keys. */ + ColumnApi.prototype.autoSizeColumns = function (keys, skipHeader) { + this.columnModel.autoSizeColumns({ columns: keys, skipHeader: skipHeader }); + }; + /** Calls `autoSizeColumns` on all displayed columns. */ + ColumnApi.prototype.autoSizeAllColumns = function (skipHeader) { this.columnModel.autoSizeAllColumns(skipHeader, 'api'); }; + /** Set the secondary pivot columns. */ + ColumnApi.prototype.setSecondaryColumns = function (colDefs) { this.columnModel.setSecondaryColumns(colDefs, 'api'); }; + /** Returns the grid's secondary columns. */ + ColumnApi.prototype.getSecondaryColumns = function () { return this.columnModel.getSecondaryColumns(); }; + /** Returns the grid's primary columns. */ + ColumnApi.prototype.getPrimaryColumns = function () { return this.columnModel.getAllPrimaryColumns(); }; + ColumnApi.prototype.cleanDownReferencesToAvoidMemoryLeakInCaseApplicationIsKeepingReferenceToDestroyedGrid = function () { + // some users were raising support issues with regards memory leaks. the problem was the customers applications + // were keeping references to the API. trying to educate them all would be difficult, easier to just remove + // all references in the API so at least the core grid can be garbage collected. + // + // wait about 100ms before clearing down the references, in case user has some cleanup to do, + // and needs to deference the API first + setTimeout(_utils__WEBPACK_IMPORTED_MODULE_1__["_"].removeAllReferences.bind(window, this, 'Column API'), 100); }; - GroupCellRenderer.prototype.updateChildCount = function () { - var allChildrenCount = this.displayedGroup.allChildrenCount; - this.eChildCount.innerHTML = allChildrenCount >= 0 ? "(" + allChildrenCount + ")" : ""; + // below goes through deprecated items, prints message to user, then calls the new version of the same method + // public getColumnDefs(): (ColDef | ColGroupDef)[] { + // this.setColumnGroupOpened(group, newValue); + // return null; + // } + /** @deprecated columnGroupOpened no longer exists, use setColumnGroupOpened */ + ColumnApi.prototype.columnGroupOpened = function (group, newValue) { + console.error('AG Grid: columnGroupOpened no longer exists, use setColumnGroupOpened'); + this.setColumnGroupOpened(group, newValue); }; - GroupCellRenderer.prototype.createLeafCell = function () { - if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(this.params.value)) { - this.eValue.innerText = this.params.valueFormatted ? this.params.valueFormatted : this.params.value; - } + /** @deprecated hideColumns is deprecated, use setColumnsVisible */ + ColumnApi.prototype.hideColumns = function (colIds, hide) { + console.error('AG Grid: hideColumns is deprecated, use setColumnsVisible'); + this.columnModel.setColumnsVisible(colIds, !hide, 'api'); }; - GroupCellRenderer.prototype.isUserWantsSelected = function () { - var paramsCheckbox = this.params.checkbox; - if (typeof paramsCheckbox === 'function') { - return paramsCheckbox(this.params); - } - return paramsCheckbox === true; + /** @deprecated hideColumn is deprecated, use setColumnVisible */ + ColumnApi.prototype.hideColumn = function (colId, hide) { + console.error('AG Grid: hideColumn is deprecated, use setColumnVisible'); + this.columnModel.setColumnVisible(colId, !hide, 'api'); }; - GroupCellRenderer.prototype.addCheckboxIfNeeded = function () { - var _this = this; - var rowNode = this.displayedGroup; - var checkboxNeeded = this.isUserWantsSelected() && - // footers cannot be selected - !rowNode.footer && - // pinned rows cannot be selected - !rowNode.rowPinned && - // details cannot be selected - !rowNode.detail; - if (checkboxNeeded) { - var cbSelectionComponent_1 = new _checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_4__["CheckboxSelectionComponent"](); - this.getContext().createBean(cbSelectionComponent_1); - cbSelectionComponent_1.init({ rowNode: rowNode, column: this.params.column }); - this.eCheckbox.appendChild(cbSelectionComponent_1.getGui()); - this.addDestroyFunc(function () { return _this.getContext().destroyBean(cbSelectionComponent_1); }); - } - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.eCheckbox, 'ag-invisible', !checkboxNeeded); + /** @deprecated setState is deprecated, use setColumnState */ + ColumnApi.prototype.setState = function (columnState) { + console.error('AG Grid: setState is deprecated, use setColumnState'); + return this.setColumnState(columnState); }; - GroupCellRenderer.prototype.addExpandAndContract = function () { - var params = this.params; - var eGroupCell = params.eGridCell; - var eExpandedIcon = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].createIconNoSpan('groupExpanded', this.gridOptionsWrapper, null); - var eContractedIcon = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].createIconNoSpan('groupContracted', this.gridOptionsWrapper, null); - this.eExpanded.appendChild(eExpandedIcon); - this.eContracted.appendChild(eContractedIcon); - this.addManagedListener(this.eExpanded, 'click', this.onExpandClicked.bind(this)); - this.addManagedListener(this.eContracted, 'click', this.onExpandClicked.bind(this)); - // expand / contract as the user hits enter - this.addManagedListener(eGroupCell, 'keydown', this.onKeyDown.bind(this)); - this.addManagedListener(params.node, _entities_rowNode__WEBPACK_IMPORTED_MODULE_3__["RowNode"].EVENT_EXPANDED_CHANGED, this.showExpandAndContractIcons.bind(this)); - this.showExpandAndContractIcons(); - // because we don't show the expand / contract when there are no children, we need to check every time - // the number of children change. - this.addManagedListener(this.displayedGroup, _entities_rowNode__WEBPACK_IMPORTED_MODULE_3__["RowNode"].EVENT_ALL_CHILDREN_COUNT_CHANGED, this.onRowNodeIsExpandableChanged.bind(this)); - this.addManagedListener(this.displayedGroup, _entities_rowNode__WEBPACK_IMPORTED_MODULE_3__["RowNode"].EVENT_MASTER_CHANGED, this.onRowNodeIsExpandableChanged.bind(this)); - // if editing groups, then double click is to start editing - if (!this.gridOptionsWrapper.isEnableGroupEdit() && this.isExpandable() && !params.suppressDoubleClickExpand) { - this.addManagedListener(eGroupCell, 'dblclick', this.onCellDblClicked.bind(this)); - } + /** @deprecated getState is deprecated, use getColumnState */ + ColumnApi.prototype.getState = function () { + console.error('AG Grid: getState is deprecated, use getColumnState'); + return this.getColumnState(); }; - GroupCellRenderer.prototype.onRowNodeIsExpandableChanged = function () { - // maybe if no children now, we should hide the expand / contract icons - this.showExpandAndContractIcons(); - // if we have no children, this impacts the indent - this.setIndent(); + /** @deprecated resetState is deprecated, use resetColumnState */ + ColumnApi.prototype.resetState = function () { + console.error('AG Grid: resetState is deprecated, use resetColumnState'); + this.resetColumnState(); }; - GroupCellRenderer.prototype.onKeyDown = function (event) { - var enterKeyPressed = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isKeyPressed(event, _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_ENTER); - if (!enterKeyPressed || this.params.suppressEnterExpand) { - return; - } - var cellEditable = this.params.column && this.params.column.isCellEditable(this.params.node); - if (cellEditable) { - return; - } - event.preventDefault(); - this.onExpandOrContract(); + /** @deprecated getAggregationColumns is deprecated, use getValueColumns */ + ColumnApi.prototype.getAggregationColumns = function () { + console.error('AG Grid: getAggregationColumns is deprecated, use getValueColumns'); + return this.columnModel.getValueColumns(); }; - GroupCellRenderer.prototype.setupDragOpenParents = function () { - var column = this.params.column; - var rowNode = this.params.node; - if (!this.gridOptionsWrapper.isGroupHideOpenParents()) { - this.draggedFromHideOpenParents = false; - } - else if (!rowNode.hasChildren()) { - // if we are here, and we are not a group, then we must of been dragged down, - // as otherwise the cell would be blank, and if cell is blank, this method is never called. - this.draggedFromHideOpenParents = true; - } - else { - var rowGroupColumn = rowNode.rowGroupColumn; - if (rowGroupColumn) { - // if the displayGroup column for this col matches the rowGroupColumn we grouped by for this node, - // then nothing was dragged down - this.draggedFromHideOpenParents = !column.isRowGroupDisplayed(rowGroupColumn.getId()); - } - else { - // the only way we can end up here (no column, but a group) is if we are at the root node, - // which only happens when 'groupIncludeTotalFooter' is true. here, we are never dragging - this.draggedFromHideOpenParents = false; - } - } - if (this.draggedFromHideOpenParents) { - var pointer = rowNode.parent; - while (true) { - if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(pointer)) { - break; - } - if (pointer.rowGroupColumn && column.isRowGroupDisplayed(pointer.rowGroupColumn.getId())) { - this.displayedGroup = pointer; - break; - } - pointer = pointer.parent; - } - } - // if we didn't find a displayed group, set it to the row node - if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(this.displayedGroup)) { - this.displayedGroup = rowNode; - } + /** @deprecated removeAggregationColumn is deprecated, use removeValueColumn */ + ColumnApi.prototype.removeAggregationColumn = function (colKey) { + console.error('AG Grid: removeAggregationColumn is deprecated, use removeValueColumn'); + this.columnModel.removeValueColumn(colKey, 'api'); }; - GroupCellRenderer.prototype.onExpandClicked = function (mouseEvent) { - if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].isStopPropagationForAgGrid(mouseEvent)) { - return; - } - // so if we expand a node, it does not also get selected. - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].stopPropagationForAgGrid(mouseEvent); - this.onExpandOrContract(); + /** @deprecated removeAggregationColumns is deprecated, use removeValueColumns */ + ColumnApi.prototype.removeAggregationColumns = function (colKeys) { + console.error('AG Grid: removeAggregationColumns is deprecated, use removeValueColumns'); + this.columnModel.removeValueColumns(colKeys, 'api'); }; - GroupCellRenderer.prototype.onCellDblClicked = function (mouseEvent) { - if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].isStopPropagationForAgGrid(mouseEvent)) { - return; - } - // we want to avoid acting on double click events on the expand / contract icon, - // as that icons already has expand / collapse functionality on it. otherwise if - // the icon was double clicked, we would get 'click', 'click', 'dblclick' which - // is open->close->open, however double click should be open->close only. - var targetIsExpandIcon = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isElementInEventPath(this.eExpanded, mouseEvent) - || _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isElementInEventPath(this.eContracted, mouseEvent); - if (!targetIsExpandIcon) { - this.onExpandOrContract(); - } + /** @deprecated addAggregationColumn is deprecated, use addValueColumn */ + ColumnApi.prototype.addAggregationColumn = function (colKey) { + console.error('AG Grid: addAggregationColumn is deprecated, use addValueColumn'); + this.columnModel.addValueColumn(colKey, 'api'); }; - GroupCellRenderer.prototype.onExpandOrContract = function () { - // must use the displayedGroup, so if data was dragged down, we expand the parent, not this row - var rowNode = this.displayedGroup; - rowNode.setExpanded(!rowNode.expanded); + /** @deprecated addAggregationColumns is deprecated, use addValueColumns */ + ColumnApi.prototype.addAggregationColumns = function (colKeys) { + console.error('AG Grid: addAggregationColumns is deprecated, use addValueColumns'); + this.columnModel.addValueColumns(colKeys, 'api'); }; - GroupCellRenderer.prototype.isExpandable = function () { - var rowNode = this.params.node; - var reducedLeafNode = this.columnController.isPivotMode() && rowNode.leafGroup; - return this.draggedFromHideOpenParents || - (rowNode.isExpandable() && !rowNode.footer && !reducedLeafNode); + /** @deprecated setColumnAggFunction is deprecated, use setColumnAggFunc */ + ColumnApi.prototype.setColumnAggFunction = function (column, aggFunc) { + console.error('AG Grid: setColumnAggFunction is deprecated, use setColumnAggFunc'); + this.columnModel.setColumnAggFunc(column, aggFunc, 'api'); }; - GroupCellRenderer.prototype.showExpandAndContractIcons = function () { - var rowNode = this.params.node; - if (this.isExpandable()) { - // if expandable, show one based on expand state. - // if we were dragged down, means our parent is always expanded - var expanded = this.draggedFromHideOpenParents ? true : rowNode.expanded; - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].setDisplayed(this.eContracted, !expanded); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].setDisplayed(this.eExpanded, expanded); - } - else { - // it not expandable, show neither - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].setDisplayed(this.eExpanded, false); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].setDisplayed(this.eContracted, false); - } - var displayedGroup = this.displayedGroup; - // compensation padding for leaf nodes, so there is blank space instead of the expand icon - var pivotModeAndLeafGroup = this.columnController.isPivotMode() && displayedGroup.leafGroup; - var notExpandable = !displayedGroup.isExpandable(); - var addLeafIndentClass = displayedGroup.footer || notExpandable || pivotModeAndLeafGroup; - this.addOrRemoveCssClass('ag-row-group', !addLeafIndentClass); - this.addOrRemoveCssClass('ag-row-group-leaf-indent', addLeafIndentClass); + /** @deprecated getDisplayNameForCol is deprecated, use getDisplayNameForColumn */ + ColumnApi.prototype.getDisplayNameForCol = function (column) { + console.error('AG Grid: getDisplayNameForCol is deprecated, use getDisplayNameForColumn'); + return this.getDisplayNameForColumn(column, null); }; - // this is a user component, and IComponent has "public destroy()" as part of the interface. - // so we need to have public here instead of private or protected - GroupCellRenderer.prototype.destroy = function () { - this.getContext().destroyBean(this.innerCellRenderer); - _super.prototype.destroy.call(this); + /** @deprecated setColumnState is deprecated, use applyColumnState. */ + ColumnApi.prototype.setColumnState = function (columnState) { + console.error('AG Grid: setColumnState is deprecated, use applyColumnState'); + return this.columnModel.applyColumnState({ state: columnState, applyOrder: true }, 'api'); }; - GroupCellRenderer.prototype.refresh = function () { - return false; + /** @deprecated getOriginalColumnGroup is deprecated, use getProvidedColumnGroup. */ + ColumnApi.prototype.getOriginalColumnGroup = function (name) { + console.error('AG Grid: getOriginalColumnGroup is deprecated, use getProvidedColumnGroup'); + return this.columnModel.getProvidedColumnGroup(name); }; - GroupCellRenderer.TEMPLATE = '' + - '' + - '' + - '' + - '' + - '' + - ''; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], GroupCellRenderer.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('expressionService') - ], GroupCellRenderer.prototype, "expressionService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('valueFormatterService') - ], GroupCellRenderer.prototype, "valueFormatterService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController') - ], GroupCellRenderer.prototype, "columnController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('userComponentFactory') - ], GroupCellRenderer.prototype, "userComponentFactory", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_5__["RefSelector"])('eExpanded') - ], GroupCellRenderer.prototype, "eExpanded", void 0); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_5__["RefSelector"])('eContracted') - ], GroupCellRenderer.prototype, "eContracted", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_5__["RefSelector"])('eCheckbox') - ], GroupCellRenderer.prototype, "eCheckbox", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_5__["RefSelector"])('eValue') - ], GroupCellRenderer.prototype, "eValue", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], ColumnApi.prototype, "columnModel", void 0); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_5__["RefSelector"])('eChildCount') - ], GroupCellRenderer.prototype, "eChildCount", void 0); - return GroupCellRenderer; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_2__["Component"])); + _context_context__WEBPACK_IMPORTED_MODULE_0__["PreDestroy"] + ], ColumnApi.prototype, "cleanDownReferencesToAvoidMemoryLeakInCaseApplicationIsKeepingReferenceToDestroyedGrid", null); + ColumnApi = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('columnApi') + ], ColumnApi); + return ColumnApi; +}()); /***/ }), -/* 68 */ +/* 112 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowNode", function() { return RowNode; }); -/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowRenderer", function() { return RowRenderer; }); +/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(107); +/* harmony import */ var _row_rowCtrl__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(113); +/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(10); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(23); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(15); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(20); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(7); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(13); +/* harmony import */ var _utils_number__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(46); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(14); +/* harmony import */ var _cell_cellCtrl__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(114); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(18); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; +}; +var __spread = (undefined && undefined.__spread) || function () { + for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); + return ar; +}; -var RowNode = /** @class */ (function () { - function RowNode() { - /** Children mapped by the pivot columns */ - this.childrenMapped = {}; - /** True by default - can be overridden via gridOptions.isRowSelectable(rowNode) */ - this.selectable = true; - /** Used by sorting service - to give deterministic sort to groups. Previously we - * just id for this, however id is a string and had slower sorting compared to numbers. */ - this.__objectId = RowNode.OBJECT_ID_SEQUENCE++; - /** True when nodes with the same id are being removed and added as part of the same batch transaction */ - this.alreadyRendered = false; - this.highlighted = null; - this.selected = false; + + + + + + + + +var RowRenderer = /** @class */ (function (_super) { + __extends(RowRenderer, _super); + function RowRenderer() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.destroyFuncsForColumnListeners = []; + // map of row ids to row objects. keeps track of which elements + // are rendered for which rows in the dom. + _this.rowCtrlsByRowIndex = {}; + _this.zombieRowCtrls = {}; + _this.allRowCtrls = []; + _this.topRowCtrls = []; + _this.bottomRowCtrls = []; + // we only allow one refresh at a time, otherwise the internal memory structure here + // will get messed up. this can happen if the user has a cellRenderer, and inside the + // renderer they call an API method that results in another pass of the refresh, + // then it will be trying to draw rows in the middle of a refresh. + _this.refreshInProgress = false; + return _this; } - RowNode.prototype.setData = function (data) { - var oldData = this.data; - this.data = data; - this.valueCache.onDataChanged(); - this.updateDataOnDetailNode(); - this.checkRowSelectable(); - var event = this.createDataChangedEvent(data, oldData, false); - this.dispatchLocalEvent(event); + RowRenderer.prototype.postConstruct = function () { + var _this = this; + this.ctrlsService.whenReady(function () { + _this.gridBodyCtrl = _this.ctrlsService.getGridBodyCtrl(); + _this.initialise(); + }); }; - // when we are doing master / detail, the detail node is lazy created, but then kept around. - // so if we show / hide the detail, the same detail rowNode is used. so we need to keep the data - // in sync, otherwise expand/collapse of the detail would still show the old values. - RowNode.prototype.updateDataOnDetailNode = function () { - if (this.detailNode) { - this.detailNode.data = this.data; - } + RowRenderer.prototype.initialise = function () { + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_PAGINATION_CHANGED, this.onPageLoaded.bind(this)); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_PINNED_ROW_DATA_CHANGED, this.onPinnedRowDataChanged.bind(this)); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this)); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_BODY_SCROLL, this.redrawAfterScroll.bind(this)); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_BODY_HEIGHT_CHANGED, this.redrawAfterScroll.bind(this)); + this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_DOM_LAYOUT, this.onDomLayoutChanged.bind(this)); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_NEW_COLUMNS_LOADED, this.onNewColumnsLoaded.bind(this)); + this.registerCellEventListeners(); + this.initialiseCache(); + this.printLayout = this.gridOptionsWrapper.getDomLayout() === _constants_constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].DOM_LAYOUT_PRINT; + this.embedFullWidthRows = this.printLayout || this.gridOptionsWrapper.isEmbedFullWidthRows(); + this.redrawAfterModelUpdate(); }; - RowNode.prototype.createDataChangedEvent = function (newData, oldData, update) { - return { - type: RowNode.EVENT_DATA_CHANGED, - node: this, - oldData: oldData, - newData: newData, - update: update - }; + RowRenderer.prototype.initialiseCache = function () { + if (this.gridOptionsWrapper.isKeepDetailRows()) { + var countProp = this.gridOptionsWrapper.getKeepDetailRowsCount(); + var count = countProp != null ? countProp : 3; + this.cachedRowCtrls = new RowCtrlCache(count); + } }; - RowNode.prototype.createLocalRowEvent = function (type) { - return { - type: type, - node: this - }; + RowRenderer.prototype.getRowCtrls = function () { + return this.allRowCtrls; }; - // similar to setRowData, however it is expected that the data is the same data item. this - // is intended to be used with Redux type stores, where the whole data can be changed. we are - // guaranteed that the data is the same entity (so grid doesn't need to worry about the id of the - // underlying data changing, hence doesn't need to worry about selection). the grid, upon receiving - // dataChanged event, will refresh the cells rather than rip them all out (so user can show transitions). - RowNode.prototype.updateData = function (data) { - var oldData = this.data; - this.data = data; - this.updateDataOnDetailNode(); - this.checkRowSelectable(); - this.updateDataOnDetailNode(); - var event = this.createDataChangedEvent(data, oldData, true); - this.dispatchLocalEvent(event); + RowRenderer.prototype.updateAllRowCtrls = function () { + var liveList = Object(_utils_object__WEBPACK_IMPORTED_MODULE_8__["getAllValuesInObject"])(this.rowCtrlsByRowIndex); + if (this.gridOptionsWrapper.isEnsureDomOrder()) { + liveList.sort(function (a, b) { return a.getRowNode().rowIndex - b.getRowNode.rowIndex; }); + } + var zombieList = Object(_utils_object__WEBPACK_IMPORTED_MODULE_8__["getAllValuesInObject"])(this.zombieRowCtrls); + var cachedList = this.cachedRowCtrls ? this.cachedRowCtrls.getEntries() : []; + this.allRowCtrls = __spread(liveList, zombieList, cachedList); }; - RowNode.prototype.getRowIndexString = function () { - if (this.rowPinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP) { - return 't-' + this.rowIndex; + // in a clean design, each cell would register for each of these events. however when scrolling, all the cells + // registering and de-registering for events is a performance bottleneck. so we register here once and inform + // all active cells. + RowRenderer.prototype.registerCellEventListeners = function () { + var _this = this; + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_CELL_FOCUSED, function (event) { + _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.onCellFocused(event); }); + _this.getFullWidthRowCtrls().forEach(function (rowCtrl) { + rowCtrl.onFullWidthRowFocused(event); + }); + }); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_FLASH_CELLS, function (event) { + _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.onFlashCells(event); }); + }); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_HOVER_CHANGED, function () { + _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.onColumnHover(); }); + }); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, function () { + _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.onDisplayedColumnsChanged(); }); + }); + // only for printLayout - because we are rendering all the cells in the same row, regardless of pinned state, + // then changing the width of the containers will impact left position. eg the center cols all have their + // left position adjusted by the width of the left pinned column, so if the pinned left column width changes, + // all the center cols need to be shifted to accommodate this. when in normal layout, the pinned cols are + // in different containers so doesn't impact. + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, function () { + if (_this.printLayout) { + _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.onLeftChanged(); }); + } + }); + var rangeSelectionEnabled = this.gridOptionsWrapper.isEnableRangeSelection(); + if (rangeSelectionEnabled) { + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_RANGE_SELECTION_CHANGED, function () { + _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.onRangeSelectionChanged(); }); + }); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_MOVED, function () { + _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.updateRangeBordersIfRangeCount(); }); + }); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_PINNED, function () { + _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.updateRangeBordersIfRangeCount(); }); + }); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_VISIBLE, function () { + _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.updateRangeBordersIfRangeCount(); }); + }); } - else if (this.rowPinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_BOTTOM) { - return 'b-' + this.rowIndex; + // add listeners to the grid columns + this.refreshListenersToColumnsForCellComps(); + // if the grid columns change, then refresh the listeners again + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_GRID_COLUMNS_CHANGED, this.refreshListenersToColumnsForCellComps.bind(this)); + this.addDestroyFunc(this.removeGridColumnListeners.bind(this)); + }; + // executes all functions in destroyFuncsForColumnListeners and then clears the list + RowRenderer.prototype.removeGridColumnListeners = function () { + this.destroyFuncsForColumnListeners.forEach(function (func) { return func(); }); + this.destroyFuncsForColumnListeners.length = 0; + }; + // this function adds listeners onto all the grid columns, which are the column that we could have cellComps for. + // when the grid columns change, we add listeners again. in an ideal design, each CellComp would just register to + // the column it belongs to on creation, however this was a bottleneck with the number of cells, so do it here + // once instead. + RowRenderer.prototype.refreshListenersToColumnsForCellComps = function () { + var _this = this; + this.removeGridColumnListeners(); + var cols = this.columnModel.getAllGridColumns(); + if (!cols) { + return; } - return this.rowIndex.toString(); + cols.forEach(function (col) { + var forEachCellWithThisCol = function (callback) { + _this.getAllCellCtrls().forEach(function (cellCtrl) { + if (cellCtrl.getColumn() === col) { + callback(cellCtrl); + } + }); + }; + var leftChangedListener = function () { + forEachCellWithThisCol(function (cellCtrl) { return cellCtrl.onLeftChanged(); }); + }; + var widthChangedListener = function () { + forEachCellWithThisCol(function (cellCtrl) { return cellCtrl.onWidthChanged(); }); + }; + var firstRightPinnedChangedListener = function () { + forEachCellWithThisCol(function (cellCtrl) { return cellCtrl.onFirstRightPinnedChanged(); }); + }; + var lastLeftPinnedChangedListener = function () { + forEachCellWithThisCol(function (cellCtrl) { return cellCtrl.onLastLeftPinnedChanged(); }); + }; + col.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_LEFT_CHANGED, leftChangedListener); + col.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_WIDTH_CHANGED, widthChangedListener); + col.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_FIRST_RIGHT_PINNED_CHANGED, firstRightPinnedChangedListener); + col.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_LAST_LEFT_PINNED_CHANGED, lastLeftPinnedChangedListener); + _this.destroyFuncsForColumnListeners.push(function () { + col.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_LEFT_CHANGED, leftChangedListener); + col.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_WIDTH_CHANGED, widthChangedListener); + col.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_FIRST_RIGHT_PINNED_CHANGED, firstRightPinnedChangedListener); + col.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_LAST_LEFT_PINNED_CHANGED, lastLeftPinnedChangedListener); + }); + }); }; - RowNode.prototype.createDaemonNode = function () { - var oldNode = new RowNode(); - this.context.createBean(oldNode); - // just copy the id and data, this is enough for the node to be used - // in the selection controller (the selection controller is the only - // place where daemon nodes can live). - oldNode.id = this.id; - oldNode.data = this.data; - oldNode.daemon = true; - oldNode.selected = this.selected; - oldNode.level = this.level; - return oldNode; + RowRenderer.prototype.onDomLayoutChanged = function () { + var printLayout = this.gridOptionsWrapper.getDomLayout() === _constants_constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].DOM_LAYOUT_PRINT; + var embedFullWidthRows = printLayout || this.gridOptionsWrapper.isEmbedFullWidthRows(); + // if moving towards or away from print layout, means we need to destroy all rows, as rows are not laid + // out using absolute positioning when doing print layout + var destroyRows = embedFullWidthRows !== this.embedFullWidthRows || this.printLayout !== printLayout; + this.printLayout = printLayout; + this.embedFullWidthRows = embedFullWidthRows; + if (destroyRows) { + this.redrawAfterModelUpdate(); + } }; - RowNode.prototype.setDataAndId = function (data, id) { - var oldNode = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].exists(this.id) ? this.createDaemonNode() : null; - var oldData = this.data; - this.data = data; - this.updateDataOnDetailNode(); - this.setId(id); - this.selectionController.syncInRowNode(this, oldNode); - this.checkRowSelectable(); - var event = this.createDataChangedEvent(data, oldData, false); - this.dispatchLocalEvent(event); + // for row models that have datasources, when we update the datasource, we need to force the rowRenderer + // to redraw all rows. otherwise the old rows from the old datasource will stay displayed. + RowRenderer.prototype.datasourceChanged = function () { + this.firstRenderedRow = 0; + this.lastRenderedRow = -1; + var rowIndexesToRemove = Object.keys(this.rowCtrlsByRowIndex); + this.removeRowCtrls(rowIndexesToRemove); }; - RowNode.prototype.checkRowSelectable = function () { - var isRowSelectableFunc = this.gridOptionsWrapper.getIsRowSelectableFunc(); - var shouldInvokeIsRowSelectable = isRowSelectableFunc && _utils__WEBPACK_IMPORTED_MODULE_4__["_"].exists(this); - this.setRowSelectable(shouldInvokeIsRowSelectable ? isRowSelectableFunc(this) : true); + RowRenderer.prototype.onPageLoaded = function (event) { + var params = { + recycleRows: event.keepRenderedRows, + animate: event.animate, + newData: event.newData, + newPage: event.newPage, + // because this is a model updated event (not pinned rows), we + // can skip updating the pinned rows. this is needed so that if user + // is doing transaction updates, the pinned rows are not getting constantly + // trashed - or editing cells in pinned rows are not refreshed and put into read mode + onlyBody: true + }; + this.redrawAfterModelUpdate(params); }; - RowNode.prototype.setRowSelectable = function (newVal) { - if (this.selectable !== newVal) { - this.selectable = newVal; - if (this.eventService) { - this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_SELECTABLE_CHANGED)); + RowRenderer.prototype.getAllCellsForColumn = function (column) { + var res = []; + this.getAllRowCtrls().forEach(function (rowCtrl) { + var eCell = rowCtrl.getCellElement(column); + if (eCell) { + res.push(eCell); } - } + }); + return res; }; - RowNode.prototype.setId = function (id) { - // see if user is providing the id's - var getRowNodeId = this.gridOptionsWrapper.getRowNodeIdFunc(); - if (getRowNodeId) { - // if user is providing the id's, then we set the id only after the data has been set. - // this is important for virtual pagination and viewport, where empty rows exist. - if (this.data) { - this.id = getRowNodeId(this.data); - // make sure id provided doesn't start with 'row-group-' as this is reserved. also check that - // it has 'startsWith' in case the user provided a number. - if (this.id && this.id.startsWith && this.id.startsWith(RowNode.ID_PREFIX_ROW_GROUP)) { - console.error("ag-Grid: Row ID's cannot start with " + RowNode.ID_PREFIX_ROW_GROUP + ", this is a reserved prefix for ag-Grid's row grouping feature."); - } - } - else { - // this can happen if user has set blank into the rowNode after the row previously - // having data. this happens in virtual page row model, when data is delete and - // the page is refreshed. - this.id = undefined; - } - } - else { - this.id = id; - } + RowRenderer.prototype.refreshFloatingRowComps = function () { + this.refreshFloatingRows(this.topRowCtrls, this.pinnedRowModel.getPinnedTopRowData()); + this.refreshFloatingRows(this.bottomRowCtrls, this.pinnedRowModel.getPinnedBottomRowData()); }; - RowNode.prototype.isPixelInRange = function (pixel) { - return pixel >= this.rowTop && pixel < (this.rowTop + this.rowHeight); + RowRenderer.prototype.getTopRowCtrls = function () { + return this.topRowCtrls; }; - RowNode.prototype.clearRowTop = function () { - this.oldRowTop = this.rowTop; - this.setRowTop(null); + RowRenderer.prototype.getBottomRowCtrls = function () { + return this.bottomRowCtrls; }; - RowNode.prototype.setFirstChild = function (firstChild) { - if (this.firstChild === firstChild) { + RowRenderer.prototype.refreshFloatingRows = function (rowComps, rowNodes) { + var _this = this; + rowComps.forEach(function (row) { + row.destroyFirstPass(); + row.destroySecondPass(); + }); + rowComps.length = 0; + if (!rowNodes) { return; } - this.firstChild = firstChild; - if (this.eventService) { - this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_FIRST_CHILD_CHANGED)); - } + rowNodes.forEach(function (rowNode) { + var rowCon = new _row_rowCtrl__WEBPACK_IMPORTED_MODULE_1__["RowCtrl"](_this.$scope, rowNode, _this.beans, false, false, _this.printLayout); + rowComps.push(rowCon); + }); }; - RowNode.prototype.setLastChild = function (lastChild) { - if (this.lastChild === lastChild) { - return; - } - this.lastChild = lastChild; - if (this.eventService) { - this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_LAST_CHILD_CHANGED)); - } + RowRenderer.prototype.onPinnedRowDataChanged = function () { + // recycling rows in order to ensure cell editing is not cancelled + var params = { + recycleRows: true + }; + this.redrawAfterModelUpdate(params); }; - RowNode.prototype.setChildIndex = function (childIndex) { - if (this.childIndex === childIndex) { - return; - } - this.childIndex = childIndex; - if (this.eventService) { - this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_CHILD_INDEX_CHANGED)); + // if the row nodes are not rendered, no index is returned + RowRenderer.prototype.getRenderedIndexesForRowNodes = function (rowNodes) { + var result = []; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_7__["missing"])(rowNodes)) { + return result; } + Object(_utils_object__WEBPACK_IMPORTED_MODULE_8__["iterateObject"])(this.rowCtrlsByRowIndex, function (index, renderedRow) { + var rowNode = renderedRow.getRowNode(); + if (rowNodes.indexOf(rowNode) >= 0) { + result.push(index); + } + }); + return result; }; - RowNode.prototype.setRowTop = function (rowTop) { - if (this.rowTop === rowTop) { - return; - } - this.rowTop = rowTop; - if (this.eventService) { - this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_TOP_CHANGED)); + RowRenderer.prototype.redrawRows = function (rowNodes) { + // if no row nodes provided, then refresh everything + var partialRefresh = rowNodes != null && rowNodes.length > 0; + if (partialRefresh) { + var indexesToRemove = this.getRenderedIndexesForRowNodes(rowNodes); + // remove the rows + this.removeRowCtrls(indexesToRemove); } + // add draw them again + this.redrawAfterModelUpdate({ + recycleRows: partialRefresh + }); }; - RowNode.prototype.setDragging = function (dragging) { - if (this.dragging === dragging) { - return; - } - this.dragging = dragging; - if (this.eventService) { - this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_DRAGGING_CHANGED)); + RowRenderer.prototype.getCellToRestoreFocusToAfterRefresh = function (params) { + var focusedCell = params.suppressKeepFocus ? null : this.focusService.getFocusCellToUseAfterRefresh(); + if (focusedCell == null) { + return null; } - }; - RowNode.prototype.setHighlighted = function (highlighted) { - if (highlighted === this.highlighted) { - return; + // if the dom is not actually focused on a cell, then we don't try to refocus. the problem this + // solves is with editing - if the user is editing, eg focus is on a text field, and not on the + // cell itself, then the cell can be registered as having focus, however it's the text field that + // has the focus and not the cell div. therefore, when the refresh is finished, the grid will focus + // the cell, and not the textfield. that means if the user is in a text field, and the grid refreshes, + // the focus is lost from the text field. we do not want this. + var eDocument = this.gridOptionsWrapper.getDocument(); + var activeElement = eDocument.activeElement; + var cellDomData = this.gridOptionsWrapper.getDomData(activeElement, _cell_cellCtrl__WEBPACK_IMPORTED_MODULE_11__["CellCtrl"].DOM_DATA_KEY_CELL_CTRL); + var rowDomData = this.gridOptionsWrapper.getDomData(activeElement, _row_rowCtrl__WEBPACK_IMPORTED_MODULE_1__["RowCtrl"].DOM_DATA_KEY_ROW_CTRL); + var gridElementFocused = cellDomData || rowDomData; + return gridElementFocused ? focusedCell : null; + }; + // gets called from: + // +) initialisation (in registerGridComp) params = null + // +) onDomLayoutChanged, params = null + // +) onPageLoaded, recycleRows, animate, newData, newPage from event, onlyBody=true + // +) onPinnedRowDataChanged, recycleRows = true + // +) redrawRows (from Grid API), recycleRows = true/false + RowRenderer.prototype.redrawAfterModelUpdate = function (params) { + if (params === void 0) { params = {}; } + this.getLockOnRefresh(); + var focusedCell = this.getCellToRestoreFocusToAfterRefresh(params); + this.updateContainerHeights(); + this.scrollToTopIfNewData(params); + // never recycle rows when print layout, we draw each row again from scratch. this is because print layout + // uses normal dom layout to put cells into dom - it doesn't allow reordering rows. + var recycleRows = !this.printLayout && !!params.recycleRows; + var animate = params.animate && this.gridOptionsWrapper.isAnimateRows(); + // after modelUpdate, row indexes can change, so we clear out the rowsByIndex map, + // however we can reuse the rows, so we keep them but index by rowNode.id + var rowsToRecycle = recycleRows ? this.recycleRows() : null; + if (!recycleRows) { + this.removeAllRowComps(); + } + var isFocusedCellGettingRecycled = function () { + if (focusedCell == null || rowsToRecycle == null) { + return false; + } + var res = false; + Object(_utils_object__WEBPACK_IMPORTED_MODULE_8__["iterateObject"])(rowsToRecycle, function (key, rowComp) { + var rowNode = rowComp.getRowNode(); + var rowIndexEqual = rowNode.rowIndex == focusedCell.rowIndex; + var pinnedEqual = rowNode.rowPinned == focusedCell.rowPinned; + if (rowIndexEqual && pinnedEqual) { + res = true; + } + }); + return res; + }; + var focusedCellRecycled = isFocusedCellGettingRecycled(); + this.redraw(rowsToRecycle, animate); + if (!params.onlyBody) { + this.refreshFloatingRowComps(); } - this.highlighted = highlighted; - if (this.eventService) { - this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_HIGHLIGHT_CHANGED)); + this.dispatchDisplayedRowsChanged(); + // if we focus a cell that's already focused, then we get an unnecessary 'cellFocused' event fired. + // this was happening when user clicked 'expand' on a rowGroup, then cellFocused was getting fired twice. + if (!focusedCellRecycled) { + this.restoreFocusedCell(focusedCell); } + this.releaseLockOnRefresh(); }; - RowNode.prototype.setAllChildrenCount = function (allChildrenCount) { - if (this.allChildrenCount === allChildrenCount) { - return; - } - this.allChildrenCount = allChildrenCount; - if (this.eventService) { - this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_ALL_CHILDREN_COUNT_CHANGED)); + RowRenderer.prototype.scrollToTopIfNewData = function (params) { + var scrollToTop = params.newData || params.newPage; + var suppressScrollToTop = this.gridOptionsWrapper.isSuppressScrollOnNewData(); + if (scrollToTop && !suppressScrollToTop) { + this.gridBodyCtrl.getScrollFeature().scrollToTop(); } }; - RowNode.prototype.setMaster = function (master) { - if (this.master === master) { + RowRenderer.prototype.updateContainerHeights = function () { + // when doing print layout, we don't explicitly set height on the containers + if (this.printLayout) { + this.rowContainerHeightService.setModelHeight(null); return; } - // if changing AWAY from master, then unexpand, otherwise - // next time it's shown it is expanded again - if (this.master && !master) { - this.expanded = false; - } - this.master = master; - if (this.eventService) { - this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_MASTER_CHANGED)); + var containerHeight = this.paginationProxy.getCurrentPageHeight(); + // we need at least 1 pixel for the horizontal scroll to work. so if there are now rows, + // we still want the scroll to be present, otherwise there would be no way to scroll the header + // which might be needed us user wants to access columns + // on the RHS - and if that was where the filter was that cause no rows to be presented, there + // is no way to remove the filter. + if (containerHeight === 0) { + containerHeight = 1; } + this.rowContainerHeightService.setModelHeight(containerHeight); }; - RowNode.prototype.setRowHeight = function (rowHeight, estimated) { - if (estimated === void 0) { estimated = false; } - this.rowHeight = rowHeight; - this.rowHeightEstimated = estimated; - if (this.eventService) { - this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_HEIGHT_CHANGED)); + RowRenderer.prototype.getLockOnRefresh = function () { + if (this.refreshInProgress) { + throw new Error("AG Grid: cannot get grid to draw rows when it is in the middle of drawing rows. " + + "Your code probably called a grid API method while the grid was in the render stage. To overcome " + + "this, put the API call into a timeout, e.g. instead of api.redrawRows(), " + + "call setTimeout(function() { api.redrawRows(); }, 0). To see what part of your code " + + "that caused the refresh check this stacktrace."); } + this.refreshInProgress = true; }; - RowNode.prototype.setRowIndex = function (rowIndex) { - this.rowIndex = rowIndex; - if (this.eventService) { - this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_ROW_INDEX_CHANGED)); - } + RowRenderer.prototype.releaseLockOnRefresh = function () { + this.refreshInProgress = false; }; - RowNode.prototype.setUiLevel = function (uiLevel) { - if (this.uiLevel === uiLevel) { - return; - } - this.uiLevel = uiLevel; - if (this.eventService) { - this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_UI_LEVEL_CHANGED)); + // sets the focus to the provided cell, if the cell is provided. this way, the user can call refresh without + // worry about the focus been lost. this is important when the user is using keyboard navigation to do edits + // and the cellEditor is calling 'refresh' to get other cells to update (as other cells might depend on the + // edited cell). + RowRenderer.prototype.restoreFocusedCell = function (cellPosition) { + if (cellPosition) { + this.focusService.setFocusedCell(cellPosition.rowIndex, cellPosition.column, cellPosition.rowPinned, true); } }; - RowNode.prototype.setExpanded = function (expanded) { - if (this.expanded === expanded) { - return; - } - this.expanded = expanded; - if (this.eventService) { - this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_EXPANDED_CHANGED)); - } - var event = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].assign({}, this.createGlobalRowEvent(_events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_ROW_GROUP_OPENED), { - expanded: expanded + RowRenderer.prototype.stopEditing = function (cancel) { + if (cancel === void 0) { cancel = false; } + this.getAllRowCtrls().forEach(function (rowCtrl) { + rowCtrl.stopEditing(cancel); }); - this.mainEventService.dispatchEvent(event); - if (this.gridOptionsWrapper.isGroupIncludeFooter()) { - this.gridApi.redrawRows({ rowNodes: [this] }); + }; + RowRenderer.prototype.onNewColumnsLoaded = function () { + // we don't want each cellComp to register for events, as would increase rendering time. + // so for newColumnsLoaded, we register once here (in rowRenderer) and then inform + // each cell if / when event was fired. + this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.onNewColumnsLoaded(); }); + }; + RowRenderer.prototype.getAllCellCtrls = function () { + var res = []; + this.getAllRowCtrls().forEach(function (rowCtrl) { return res = res.concat(rowCtrl.getAllCellCtrls()); }); + return res; + }; + RowRenderer.prototype.getAllRowCtrls = function () { + var _this = this; + var res = __spread(this.topRowCtrls, this.bottomRowCtrls); + Object.keys(this.rowCtrlsByRowIndex).forEach(function (key) { return res.push(_this.rowCtrlsByRowIndex[key]); }); + return res; + }; + RowRenderer.prototype.addRenderedRowListener = function (eventName, rowIndex, callback) { + var rowComp = this.rowCtrlsByRowIndex[rowIndex]; + if (rowComp) { + rowComp.addEventListener(eventName, callback); } }; - RowNode.prototype.createGlobalRowEvent = function (type) { - return { - type: type, - node: this, - data: this.data, - rowIndex: this.rowIndex, - rowPinned: this.rowPinned, - context: this.gridOptionsWrapper.getContext(), - api: this.gridOptionsWrapper.getApi(), - columnApi: this.gridOptionsWrapper.getColumnApi() + RowRenderer.prototype.flashCells = function (params) { + if (params === void 0) { params = {}; } + var flashDelay = params.flashDelay, fadeDelay = params.fadeDelay; + this.getCellCtrls(params.rowNodes, params.columns) + .forEach(function (cellCtrl) { return cellCtrl.flashCell({ flashDelay: flashDelay, fadeDelay: fadeDelay }); }); + }; + RowRenderer.prototype.refreshCells = function (params) { + if (params === void 0) { params = {}; } + var refreshCellParams = { + forceRefresh: params.force, + newData: false, + suppressFlash: params.suppressFlash }; + this.getCellCtrls(params.rowNodes, params.columns) + .forEach(function (cellCtrl) { + if (cellCtrl.refreshShouldDestroy()) { + var rowCtrl = cellCtrl.getRowCtrl(); + if (rowCtrl) { + rowCtrl.refreshCell(cellCtrl); + } + } + else { + cellCtrl.refreshCell(refreshCellParams); + } + }); + this.getFullWidthRowCtrls(params.rowNodes).forEach(function (fullWidthRowCtrl) { + fullWidthRowCtrl.refreshFullWidth(); + }); }; - RowNode.prototype.dispatchLocalEvent = function (event) { - if (this.eventService) { - this.eventService.dispatchEvent(event); - } + RowRenderer.prototype.getCellRendererInstances = function (params) { + var res = this.getCellCtrls(params.rowNodes, params.columns) + .map(function (cellCtrl) { return cellCtrl.getCellRenderer(); }) + .filter(function (renderer) { return renderer != null; }); + return res; }; - // we also allow editing the value via the editors. when it is done via - // the editors, no 'cell changed' event gets fired, as it's assumed that - // the cell knows about the change given it's in charge of the editing. - // this method is for the client to call, so the cell listens for the change - // event, and also flashes the cell when the change occurs. - RowNode.prototype.setDataValue = function (colKey, newValue) { - var column = this.columnController.getPrimaryColumn(colKey); - var oldValue = this.valueService.getValue(column, this); - this.valueService.setValue(this, column, newValue); - this.dispatchCellChangedEvent(column, newValue, oldValue); + RowRenderer.prototype.getCellEditorInstances = function (params) { + var res = []; + this.getCellCtrls(params.rowNodes, params.columns).forEach(function (cellCtrl) { + var cellEditor = cellCtrl.getCellEditor(); + if (cellEditor) { + res.push(cellEditor); + } + }); + return res; }; - RowNode.prototype.setGroupValue = function (colKey, newValue) { - var column = this.columnController.getGridColumn(colKey); - if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].missing(this.groupData)) { - this.groupData = {}; - } - var columnId = column.getColId(); - var oldValue = this.groupData[columnId]; - if (oldValue === newValue) { + RowRenderer.prototype.getEditingCells = function () { + var res = []; + this.getAllCellCtrls().forEach(function (cellCtrl) { + if (cellCtrl.isEditing()) { + var cellPosition = cellCtrl.getCellPosition(); + res.push(cellPosition); + } + }); + return res; + }; + RowRenderer.prototype.mapRowNodes = function (rowNodes) { + if (!rowNodes) { return; } - this.groupData[columnId] = newValue; - this.dispatchCellChangedEvent(column, newValue, oldValue); + var res = { + top: {}, + bottom: {}, + normal: {} + }; + rowNodes.forEach(function (rowNode) { + var id = rowNode.id; + if (rowNode.rowPinned === _constants_constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_TOP) { + res.top[id] = rowNode; + } + else if (rowNode.rowPinned === _constants_constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_BOTTOM) { + res.bottom[id] = rowNode; + } + else { + res.normal[id] = rowNode; + } + }); + return res; }; - // sets the data for an aggregation - RowNode.prototype.setAggData = function (newAggData) { + RowRenderer.prototype.isRowInMap = function (rowNode, rowIdsMap) { + // skip this row if it is missing from the provided list + var id = rowNode.id; + var floating = rowNode.rowPinned; + if (floating === _constants_constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_BOTTOM) { + return rowIdsMap.bottom[id] != null; + } + else if (floating === _constants_constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_TOP) { + return rowIdsMap.top[id] != null; + } + else { + return rowIdsMap.normal[id] != null; + } + }; + // returns CellCtrl's that match the provided rowNodes and columns. eg if one row node + // and two columns provided, that identifies 4 cells, so 4 CellCtrl's returned. + RowRenderer.prototype.getCellCtrls = function (rowNodes, columns) { var _this = this; - // find out all keys that could potentially change - var colIds = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].getAllKeysInObjects([this.aggData, newAggData]); - var oldAggData = this.aggData; - this.aggData = newAggData; - // if no event service, nobody has registered for events, so no need fire event - if (this.eventService) { - colIds.forEach(function (colId) { - var column = _this.columnController.getGridColumn(colId); - var value = _this.aggData ? _this.aggData[colId] : undefined; - var oldValue = oldAggData ? oldAggData[colId] : undefined; - _this.dispatchCellChangedEvent(column, value, oldValue); + var rowIdsMap = this.mapRowNodes(rowNodes); + var res = []; + var colIdsMap; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_7__["exists"])(columns)) { + colIdsMap = {}; + columns.forEach(function (colKey) { + var column = _this.columnModel.getGridColumn(colKey); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_7__["exists"])(column)) { + colIdsMap[column.getId()] = true; + } }); } + var processRow = function (rowComp) { + var rowNode = rowComp.getRowNode(); + // skip this row if it is missing from the provided list + if (rowIdsMap != null && !_this.isRowInMap(rowNode, rowIdsMap)) { + return; + } + rowComp.getAllCellCtrls().forEach(function (cellCtrl) { + var colId = cellCtrl.getColumn().getId(); + var excludeColFromRefresh = colIdsMap && !colIdsMap[colId]; + if (excludeColFromRefresh) { + return; + } + res.push(cellCtrl); + }); + }; + Object(_utils_object__WEBPACK_IMPORTED_MODULE_8__["iterateObject"])(this.rowCtrlsByRowIndex, function (index, rowComp) { + processRow(rowComp); + }); + if (this.topRowCtrls) { + this.topRowCtrls.forEach(processRow); + } + if (this.bottomRowCtrls) { + this.bottomRowCtrls.forEach(processRow); + } + return res; }; - RowNode.prototype.hasChildren = function () { - // we need to return true when this.group=true, as this is used by server side row model - // (as children are lazy loaded and stored in a cache anyway). otherwise we return true - // if children exist. - return this.group || (this.childrenAfterGroup && this.childrenAfterGroup.length > 0); - }; - RowNode.prototype.isEmptyRowGroupNode = function () { - return this.group && _utils__WEBPACK_IMPORTED_MODULE_4__["_"].missingOrEmpty(this.childrenAfterGroup); + RowRenderer.prototype.destroy = function () { + this.removeAllRowComps(); + _super.prototype.destroy.call(this); }; - RowNode.prototype.dispatchCellChangedEvent = function (column, newValue, oldValue) { - var cellChangedEvent = { - type: RowNode.EVENT_CELL_CHANGED, - node: this, - column: column, - newValue: newValue, - oldValue: oldValue - }; - this.dispatchLocalEvent(cellChangedEvent); + RowRenderer.prototype.removeAllRowComps = function () { + var rowIndexesToRemove = Object.keys(this.rowCtrlsByRowIndex); + this.removeRowCtrls(rowIndexesToRemove); }; - RowNode.prototype.resetQuickFilterAggregateText = function () { - this.quickFilterAggregateText = null; + RowRenderer.prototype.recycleRows = function () { + // remove all stub nodes, they can't be reused, as no rowNode id + var stubNodeIndexes = []; + Object(_utils_object__WEBPACK_IMPORTED_MODULE_8__["iterateObject"])(this.rowCtrlsByRowIndex, function (index, rowComp) { + var stubNode = rowComp.getRowNode().id == null; + if (stubNode) { + stubNodeIndexes.push(index); + } + }); + this.removeRowCtrls(stubNodeIndexes); + // then clear out rowCompsByIndex, but before that take a copy, but index by id, not rowIndex + var nodesByIdMap = {}; + Object(_utils_object__WEBPACK_IMPORTED_MODULE_8__["iterateObject"])(this.rowCtrlsByRowIndex, function (index, rowComp) { + var rowNode = rowComp.getRowNode(); + nodesByIdMap[rowNode.id] = rowComp; + }); + this.rowCtrlsByRowIndex = {}; + return nodesByIdMap; }; - RowNode.prototype.isExpandable = function () { - return this.hasChildren() || this.master; + // takes array of row indexes + RowRenderer.prototype.removeRowCtrls = function (rowsToRemove) { + var _this = this; + // if no fromIndex then set to -1, which will refresh everything + // let realFromIndex = -1; + rowsToRemove.forEach(function (indexToRemove) { + var rowCtrl = _this.rowCtrlsByRowIndex[indexToRemove]; + if (rowCtrl) { + rowCtrl.destroyFirstPass(); + rowCtrl.destroySecondPass(); + } + delete _this.rowCtrlsByRowIndex[indexToRemove]; + }); }; - RowNode.prototype.isSelected = function () { - // for footers, we just return what our sibling selected state is, as cannot select a footer - if (this.footer) { - return this.sibling.isSelected(); - } - return this.selected; + // gets called when rows don't change, but viewport does, so after: + // 1) height of grid body changes, ie number of displayed rows has changed + // 2) grid scrolled to new position + // 3) ensure index visible (which is a scroll) + RowRenderer.prototype.redrawAfterScroll = function () { + this.getLockOnRefresh(); + this.redraw(null, false, true); + this.releaseLockOnRefresh(); + this.dispatchDisplayedRowsChanged(); }; - RowNode.prototype.depthFirstSearch = function (callback) { - if (this.childrenAfterGroup) { - this.childrenAfterGroup.forEach(function (child) { return child.depthFirstSearch(callback); }); - } - callback(this); + RowRenderer.prototype.removeRowCompsNotToDraw = function (indexesToDraw) { + // for speedy lookup, dump into map + var indexesToDrawMap = {}; + indexesToDraw.forEach(function (index) { return (indexesToDrawMap[index] = true); }); + var existingIndexes = Object.keys(this.rowCtrlsByRowIndex); + var indexesNotToDraw = existingIndexes.filter(function (index) { return !indexesToDrawMap[index]; }); + this.removeRowCtrls(indexesNotToDraw); }; - // + rowController.updateGroupsInSelection() - // + selectionController.calculatedSelectedForAllGroupNodes() - RowNode.prototype.calculateSelectedFromChildren = function () { - var atLeastOneSelected = false; - var atLeastOneDeSelected = false; - var atLeastOneMixed = false; - var newSelectedValue; - if (this.childrenAfterGroup) { - for (var i = 0; i < this.childrenAfterGroup.length; i++) { - var child = this.childrenAfterGroup[i]; - // skip non-selectable nodes to prevent inconsistent selection values - if (!child.selectable) { - continue; - } - var childState = child.isSelected(); - switch (childState) { - case true: - atLeastOneSelected = true; - break; - case false: - atLeastOneDeSelected = true; - break; - default: - atLeastOneMixed = true; - break; + RowRenderer.prototype.calculateIndexesToDraw = function (rowsToRecycle) { + var _this = this; + // all in all indexes in the viewport + var indexesToDraw = Object(_utils_number__WEBPACK_IMPORTED_MODULE_9__["createArrayOfNumbers"])(this.firstRenderedRow, this.lastRenderedRow); + var checkRowToDraw = function (indexStr, rowComp) { + var index = rowComp.getRowNode().rowIndex; + if (index == null) { + return; + } + if (index < _this.firstRenderedRow || index > _this.lastRenderedRow) { + if (_this.doNotUnVirtualiseRow(rowComp)) { + indexesToDraw.push(index); } } + }; + // if we are redrawing due to scrolling change, then old rows are in this.rowCompsByIndex + Object(_utils_object__WEBPACK_IMPORTED_MODULE_8__["iterateObject"])(this.rowCtrlsByRowIndex, checkRowToDraw); + // if we are redrawing due to model update, then old rows are in rowsToRecycle + Object(_utils_object__WEBPACK_IMPORTED_MODULE_8__["iterateObject"])(rowsToRecycle, checkRowToDraw); + indexesToDraw.sort(function (a, b) { return a - b; }); + return indexesToDraw; + }; + RowRenderer.prototype.redraw = function (rowsToRecycle, animate, afterScroll) { + var _this = this; + if (animate === void 0) { animate = false; } + if (afterScroll === void 0) { afterScroll = false; } + this.rowContainerHeightService.updateOffset(); + this.workOutFirstAndLastRowsToRender(); + // the row can already exist and be in the following: + // rowsToRecycle -> if model change, then the index may be different, however row may + // exist here from previous time (mapped by id). + // this.rowCompsByIndex -> if just a scroll, then this will contain what is currently in the viewport + // this is all the indexes we want, including those that already exist, so this method + // will end up going through each index and drawing only if the row doesn't already exist + var indexesToDraw = this.calculateIndexesToDraw(rowsToRecycle); + this.removeRowCompsNotToDraw(indexesToDraw); + // never animate when doing print layout - as we want to get things ready to print as quickly as possible, + // otherwise we risk the printer printing a row that's half faded (half way through fading in) + if (this.printLayout) { + animate = false; } - if (atLeastOneMixed) { - newSelectedValue = undefined; - } - else if (atLeastOneSelected && !atLeastOneDeSelected) { - newSelectedValue = true; - } - else if (!atLeastOneSelected && atLeastOneDeSelected) { - newSelectedValue = false; - } - else { - newSelectedValue = undefined; + // add in new rows + var rowCtrls = []; + indexesToDraw.forEach(function (rowIndex) { + var rowCtrl = _this.createOrUpdateRowCtrl(rowIndex, rowsToRecycle, animate, afterScroll); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_7__["exists"])(rowCtrl)) { + rowCtrls.push(rowCtrl); + } + }); + if (rowsToRecycle) { + var useAnimationFrame = afterScroll && !this.gridOptionsWrapper.isSuppressAnimationFrame() && !this.printLayout; + if (useAnimationFrame) { + this.beans.animationFrameService.addDestroyTask(function () { + _this.destroyRowCtrls(rowsToRecycle, animate); + _this.updateAllRowCtrls(); + _this.dispatchDisplayedRowsChanged(); + }); + } + else { + this.destroyRowCtrls(rowsToRecycle, animate); + } } - this.selectThisNode(newSelectedValue); + this.updateAllRowCtrls(); + this.checkAngularCompile(); + this.gridBodyCtrl.updateRowCount(); }; - RowNode.prototype.setSelectedInitialValue = function (selected) { - this.selected = selected; + RowRenderer.prototype.dispatchDisplayedRowsChanged = function () { + var event = { type: _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_ROWS_CHANGED }; + this.eventService.dispatchEvent(event); }; - RowNode.prototype.setSelected = function (newValue, clearSelection, suppressFinishActions) { - if (clearSelection === void 0) { clearSelection = false; } - if (suppressFinishActions === void 0) { suppressFinishActions = false; } - this.setSelectedParams({ - newValue: newValue, - clearSelection: clearSelection, - suppressFinishActions: suppressFinishActions, - rangeSelect: false + RowRenderer.prototype.onDisplayedColumnsChanged = function () { + var pinningLeft = this.columnModel.isPinningLeft(); + var pinningRight = this.columnModel.isPinningRight(); + var atLeastOneChanged = this.pinningLeft !== pinningLeft || pinningRight !== this.pinningRight; + if (atLeastOneChanged) { + this.pinningLeft = pinningLeft; + this.pinningRight = pinningRight; + if (this.embedFullWidthRows) { + this.redrawFullWidthEmbeddedRows(); + } + } + }; + // when embedding, what gets showed in each section depends on what is pinned. eg if embedding group expand / collapse, + // then it should go into the pinned left area if pinning left, or the center area if not pinning. + RowRenderer.prototype.redrawFullWidthEmbeddedRows = function () { + // if either of the pinned panels has shown / hidden, then need to redraw the fullWidth bits when + // embedded, as what appears in each section depends on whether we are pinned or not + var rowsToRemove = []; + this.getFullWidthRowCtrls().forEach(function (fullWidthCtrl) { + var rowIndex = fullWidthCtrl.getRowNode().rowIndex; + rowsToRemove.push(rowIndex.toString()); }); + this.refreshFloatingRowComps(); + this.removeRowCtrls(rowsToRemove); + this.redrawAfterScroll(); }; - RowNode.prototype.isRowPinned = function () { - return this.rowPinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP || this.rowPinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_BOTTOM; + RowRenderer.prototype.getFullWidthRowCtrls = function (rowNodes) { + var _this = this; + var rowNodesMap = this.mapRowNodes(rowNodes); + return Object(_utils_object__WEBPACK_IMPORTED_MODULE_8__["getAllValuesInObject"])(this.rowCtrlsByRowIndex).filter(function (rowCtrl) { + // include just full width + if (!rowCtrl.isFullWidth()) { + return false; + } + // if Row Nodes provided, we exclude where Row Node is missing + var rowNode = rowCtrl.getRowNode(); + if (rowNodesMap != null && !_this.isRowInMap(rowNode, rowNodesMap)) { + return false; + } + return true; + }); }; - // to make calling code more readable, this is the same method as setSelected except it takes names parameters - RowNode.prototype.setSelectedParams = function (params) { - var groupSelectsChildren = this.gridOptionsWrapper.isGroupSelectsChildren(); - var newValue = params.newValue === true; - var clearSelection = params.clearSelection === true; - var suppressFinishActions = params.suppressFinishActions === true; - var rangeSelect = params.rangeSelect === true; - // groupSelectsFiltered only makes sense when group selects children - var groupSelectsFiltered = groupSelectsChildren && (params.groupSelectsFiltered === true); - if (this.id === undefined) { - console.warn('ag-Grid: cannot select node until id for node is known'); - return 0; - } - if (this.rowPinned) { - console.warn('ag-Grid: cannot select pinned rows'); - return 0; - } - // if we are a footer, we don't do selection, just pass the info - // to the sibling (the parent of the group) - if (this.footer) { - var count = this.sibling.setSelectedParams(params); - return count; - } - if (rangeSelect) { - var newRowClicked = this.selectionController.getLastSelectedNode() !== this; - var allowMultiSelect = this.gridOptionsWrapper.isRowSelectionMulti(); - if (newRowClicked && allowMultiSelect) { - return this.doRowRangeSelection(); + RowRenderer.prototype.refreshFullWidthRows = function (rowNodesToRefresh) { + var rowsToRemove = []; + var selectivelyRefreshing = !!rowNodesToRefresh; + var idsToRefresh = selectivelyRefreshing ? {} : undefined; + if (selectivelyRefreshing && idsToRefresh) { + rowNodesToRefresh.forEach(function (r) { return idsToRefresh[r.id] = true; }); + } + this.getFullWidthRowCtrls().forEach(function (fullWidthRowCtrl) { + var rowNode = fullWidthRowCtrl.getRowNode(); + if (selectivelyRefreshing && idsToRefresh) { + // we refresh if a) this node is present or b) this parents nodes is present. checking parent + // node is important for master/detail, as we want detail to refresh on changes to parent node. + // it's also possible, if user is provider their own fullWidth, that details panels contain + // some info on the parent, eg if in tree data and child row shows some data from parent row also. + var parentId = (rowNode.level > 0 && rowNode.parent) ? rowNode.parent.id : undefined; + var skipThisNode = !idsToRefresh[rowNode.id] && !idsToRefresh[parentId]; + if (skipThisNode) { + return; + } } - } - var updatedCount = 0; - // when groupSelectsFiltered, then this node may end up intermediate despite - // trying to set it to true / false. this group will be calculated further on - // down when we call calculatedSelectedForAllGroupNodes(). we need to skip it - // here, otherwise the updatedCount would include it. - var skipThisNode = groupSelectsFiltered && this.group; - if (!skipThisNode) { - var thisNodeWasSelected = this.selectThisNode(newValue); - if (thisNodeWasSelected) { - updatedCount++; + var fullWidthRowsRefreshed = fullWidthRowCtrl.refreshFullWidth(); + if (!fullWidthRowsRefreshed) { + var rowIndex = fullWidthRowCtrl.getRowNode().rowIndex; + rowsToRemove.push(rowIndex.toString()); + } + }); + this.removeRowCtrls(rowsToRemove); + this.redrawAfterScroll(); + }; + RowRenderer.prototype.createOrUpdateRowCtrl = function (rowIndex, rowsToRecycle, animate, afterScroll) { + var rowNode; + var rowCon = this.rowCtrlsByRowIndex[rowIndex]; + // if no row comp, see if we can get it from the previous rowComps + if (!rowCon) { + rowNode = this.paginationProxy.getRow(rowIndex); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_7__["exists"])(rowNode) && Object(_utils_generic__WEBPACK_IMPORTED_MODULE_7__["exists"])(rowsToRecycle) && rowsToRecycle[rowNode.id] && rowNode.alreadyRendered) { + rowCon = rowsToRecycle[rowNode.id]; + rowsToRecycle[rowNode.id] = null; } } - if (groupSelectsChildren && this.group) { - updatedCount += this.selectChildNodes(newValue, groupSelectsFiltered); - } - // clear other nodes if not doing multi select - if (!suppressFinishActions) { - var clearOtherNodes = newValue && (clearSelection || !this.gridOptionsWrapper.isRowSelectionMulti()); - if (clearOtherNodes) { - updatedCount += this.selectionController.clearOtherNodes(this); + var creatingNewRowCon = !rowCon; + if (creatingNewRowCon) { + // create a new one + if (!rowNode) { + rowNode = this.paginationProxy.getRow(rowIndex); } - // only if we selected something, then update groups and fire events - if (updatedCount > 0) { - this.selectionController.updateGroupsFromChildrenSelections(); - // this is the very end of the 'action node', so we are finished all the updates, - // include any parent / child changes that this method caused - var event_1 = { - type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_SELECTION_CHANGED, - api: this.gridApi, - columnApi: this.columnApi - }; - this.mainEventService.dispatchEvent(event_1); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_7__["exists"])(rowNode)) { + rowCon = this.createRowCon(rowNode, animate, afterScroll); } - // so if user next does shift-select, we know where to start the selection from - if (newValue) { - this.selectionController.setLastSelectedNode(this); + else { + // this should never happen - if somehow we are trying to create + // a row for a rowNode that does not exist. + return; } } - return updatedCount; + if (rowNode) { + // set node as 'alreadyRendered' to ensure we only recycle rowComps that have been rendered, this ensures + // we don't reuse rowComps that have been removed and then re-added in the same batch transaction. + rowNode.alreadyRendered = true; + } + this.rowCtrlsByRowIndex[rowIndex] = rowCon; + return rowCon; }; - // selects all rows between this node and the last selected node (or the top if this is the first selection). - // not to be mixed up with 'cell range selection' where you drag the mouse, this is row range selection, by - // holding down 'shift'. - RowNode.prototype.doRowRangeSelection = function () { - var groupsSelectChildren = this.gridOptionsWrapper.isGroupSelectsChildren(); - var lastSelectedNode = this.selectionController.getLastSelectedNode(); - var nodesToSelect = this.rowModel.getNodesInRangeForSelection(this, lastSelectedNode); - var updatedCount = 0; - nodesToSelect.forEach(function (rowNode) { - if (rowNode.group && groupsSelectChildren) { + RowRenderer.prototype.destroyRowCtrls = function (rowCtrlsMap, animate) { + var _this = this; + var executeInAWhileFuncs = []; + Object(_utils_object__WEBPACK_IMPORTED_MODULE_8__["iterateObject"])(rowCtrlsMap, function (nodeId, rowCtrl) { + // if row was used, then it's null + if (!rowCtrl) { return; } - var nodeWasSelected = rowNode.selectThisNode(true); - if (nodeWasSelected) { - updatedCount++; + if (_this.cachedRowCtrls && rowCtrl.isCacheable()) { + _this.cachedRowCtrls.addRow(rowCtrl); + return; + } + rowCtrl.destroyFirstPass(); + if (animate) { + _this.zombieRowCtrls[rowCtrl.getInstanceId()] = rowCtrl; + executeInAWhileFuncs.push(function () { + rowCtrl.destroySecondPass(); + delete _this.zombieRowCtrls[rowCtrl.getInstanceId()]; + }); + } + else { + rowCtrl.destroySecondPass(); } }); - this.selectionController.updateGroupsFromChildrenSelections(); - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_SELECTION_CHANGED, - api: this.gridApi, - columnApi: this.columnApi - }; - this.mainEventService.dispatchEvent(event); - return updatedCount; + if (animate) { + // this ensures we fire displayedRowsChanged AFTER all the 'executeInAWhileFuncs' get + // executed, as we added it to the end of the list. + executeInAWhileFuncs.push(function () { + _this.updateAllRowCtrls(); + _this.dispatchDisplayedRowsChanged(); + }); + Object(_utils_function__WEBPACK_IMPORTED_MODULE_10__["executeInAWhile"])(executeInAWhileFuncs); + } }; - RowNode.prototype.isParentOfNode = function (potentialParent) { - var parentNode = this.parent; - while (parentNode) { - if (parentNode === potentialParent) { - return true; - } - parentNode = parentNode.parent; + RowRenderer.prototype.checkAngularCompile = function () { + var _this = this; + // if we are doing angular compiling, then do digest the scope here + if (this.gridOptionsWrapper.isAngularCompileRows()) { + // we do it in a timeout, in case we are already in an apply + window.setTimeout(function () { + _this.$scope.$apply(); + }, 0); } - return false; }; - RowNode.prototype.selectThisNode = function (newValue) { - // we only check selectable when newValue=true (ie selecting) to allow unselecting values, - // as selectable is dynamic, need a way to unselect rows when selectable becomes false. - var selectionNotAllowed = !this.selectable && newValue; - var selectionNotChanged = this.selected === newValue; - if (selectionNotAllowed || selectionNotChanged) { - return false; + RowRenderer.prototype.workOutFirstAndLastRowsToRender = function () { + var _this = this; + var newFirst; + var newLast; + if (!this.paginationProxy.isRowsToRender()) { + newFirst = 0; + newLast = -1; // setting to -1 means nothing in range } - this.selected = newValue; - if (this.eventService) { - this.dispatchLocalEvent(this.createLocalRowEvent(RowNode.EVENT_ROW_SELECTED)); + else if (this.printLayout) { + newFirst = this.paginationProxy.getPageFirstRow(); + newLast = this.paginationProxy.getPageLastRow(); } - var event = this.createGlobalRowEvent(_events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_ROW_SELECTED); - this.mainEventService.dispatchEvent(event); - return true; - }; - RowNode.prototype.selectChildNodes = function (newValue, groupSelectsFiltered) { - var children = groupSelectsFiltered ? this.childrenAfterFilter : this.childrenAfterGroup; - if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].missing(children)) { - return; + else { + var bufferPixels = this.gridOptionsWrapper.getRowBufferInPixels(); + var gridBodyCon = this.ctrlsService.getGridBodyCtrl(); + var suppressRowVirtualisation = this.gridOptionsWrapper.isSuppressRowVirtualisation(); + var rowHeightsChanged = false; + var firstPixel = void 0; + var lastPixel = void 0; + do { + var paginationOffset = this.paginationProxy.getPixelOffset(); + var _a = this.paginationProxy.getCurrentPagePixelRange(), pageFirstPixel = _a.pageFirstPixel, pageLastPixel = _a.pageLastPixel; + var divStretchOffset = this.rowContainerHeightService.getDivStretchOffset(); + if (suppressRowVirtualisation) { + firstPixel = pageFirstPixel + divStretchOffset; + lastPixel = pageLastPixel + divStretchOffset; + } + else { + var bodyVRange = gridBodyCon.getScrollFeature().getVScrollPosition(); + var bodyTopPixel = bodyVRange.top; + var bodyBottomPixel = bodyVRange.bottom; + firstPixel = Math.max(bodyTopPixel + paginationOffset - bufferPixels, pageFirstPixel) + divStretchOffset; + lastPixel = Math.min(bodyBottomPixel + paginationOffset + bufferPixels, pageLastPixel) + divStretchOffset; + } + // if the rows we are about to display get their heights changed, then that upsets the calcs from above. + rowHeightsChanged = this.ensureAllRowsInRangeHaveHeightsCalculated(firstPixel, lastPixel); + } while (rowHeightsChanged); + var firstRowIndex = this.paginationProxy.getRowIndexAtPixel(firstPixel); + var lastRowIndex = this.paginationProxy.getRowIndexAtPixel(lastPixel); + var pageFirstRow = this.paginationProxy.getPageFirstRow(); + var pageLastRow = this.paginationProxy.getPageLastRow(); + // adjust, in case buffer extended actual size + if (firstRowIndex < pageFirstRow) { + firstRowIndex = pageFirstRow; + } + if (lastRowIndex > pageLastRow) { + lastRowIndex = pageLastRow; + } + newFirst = firstRowIndex; + newLast = lastRowIndex; } - var updatedCount = 0; - for (var i = 0; i < children.length; i++) { - updatedCount += children[i].setSelectedParams({ - newValue: newValue, - clearSelection: false, - suppressFinishActions: true, - groupSelectsFiltered: groupSelectsFiltered - }); + // sometimes user doesn't set CSS right and ends up with grid with no height and grid ends up + // trying to render all the rows, eg 10,000+ rows. this will kill the browser. so instead of + // killing the browser, we limit the number of rows. just in case some use case we didn't think + // of, we also have a property to not do this operation. + var rowLayoutNormal = this.gridOptionsWrapper.getDomLayout() === _constants_constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].DOM_LAYOUT_NORMAL; + var suppressRowCountRestriction = this.gridOptionsWrapper.isSuppressMaxRenderedRowRestriction(); + var rowBufferMaxSize = Math.max(this.gridOptionsWrapper.getRowBuffer(), 500); + if (rowLayoutNormal && !suppressRowCountRestriction) { + if (newLast - newFirst > rowBufferMaxSize) { + newLast = newFirst + rowBufferMaxSize; + } + } + var firstDiffers = newFirst !== this.firstRenderedRow; + var lastDiffers = newLast !== this.lastRenderedRow; + if (firstDiffers || lastDiffers) { + this.firstRenderedRow = newFirst; + this.lastRenderedRow = newLast; + var event_1 = { + type: _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_VIEWPORT_CHANGED, + firstRow: newFirst, + lastRow: newLast, + api: this.gridApi, + columnApi: this.columnApi + }; + this.eventService.dispatchEvent(event_1); + } + // only dispatch firstDataRendered if we have actually rendered some data + if (this.paginationProxy.isRowsToRender()) { + var event_2 = { + type: _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_FIRST_DATA_RENDERED, + firstRow: newFirst, + lastRow: newLast, + api: this.gridApi, + columnApi: this.columnApi + }; + // added a small delay here because in some scenarios this can be fired + // before the grid is actually rendered, causing component creation + // on EVENT_FIRST_DATA_RENDERED to fail. + window.setTimeout(function () { return _this.eventService.dispatchEventOnce(event_2); }, 50); } - return updatedCount; }; - RowNode.prototype.addEventListener = function (eventType, listener) { - if (!this.eventService) { - this.eventService = new _eventService__WEBPACK_IMPORTED_MODULE_0__["EventService"](); + RowRenderer.prototype.ensureAllRowsInRangeHaveHeightsCalculated = function (topPixel, bottomPixel) { + // ensureRowHeightsVisible only works with CSRM, as it's the only row model that allows lazy row height calcs. + // all the other row models just hard code so the method just returns back false + var res = this.paginationProxy.ensureRowHeightsValid(topPixel, bottomPixel, -1, -1); + if (res) { + this.updateContainerHeights(); } - this.eventService.addEventListener(eventType, listener); + return res; }; - RowNode.prototype.removeEventListener = function (eventType, listener) { - this.eventService.removeEventListener(eventType, listener); + RowRenderer.prototype.getFirstVirtualRenderedRow = function () { + return this.firstRenderedRow; }; - RowNode.prototype.onMouseEnter = function () { - this.dispatchLocalEvent(this.createLocalRowEvent(RowNode.EVENT_MOUSE_ENTER)); + RowRenderer.prototype.getLastVirtualRenderedRow = function () { + return this.lastRenderedRow; }; - RowNode.prototype.onMouseLeave = function () { - this.dispatchLocalEvent(this.createLocalRowEvent(RowNode.EVENT_MOUSE_LEAVE)); + // check that none of the rows to remove are editing or focused as: + // a) if editing, we want to keep them, otherwise the user will loose the context of the edit, + // eg user starts editing, enters some text, then scrolls down and then up, next time row rendered + // the edit is reset - so we want to keep it rendered. + // b) if focused, we want ot keep keyboard focus, so if user ctrl+c, it goes to clipboard, + // otherwise the user can range select and drag (with focus cell going out of the viewport) + // and then ctrl+c, nothing will happen if cell is removed from dom. + // c) if detail record of master detail, as users complained that the context of detail rows + // was getting lost when detail row out of view. eg user expands to show detail row, + // then manipulates the detail panel (eg sorts the detail grid), then context is lost + // after detail panel is scrolled out of / into view. + RowRenderer.prototype.doNotUnVirtualiseRow = function (rowComp) { + var REMOVE_ROW = false; + var KEEP_ROW = true; + var rowNode = rowComp.getRowNode(); + var rowHasFocus = this.focusService.isRowNodeFocused(rowNode); + var rowIsEditing = rowComp.isEditing(); + var rowIsDetail = rowNode.detail; + var mightWantToKeepRow = rowHasFocus || rowIsEditing || rowIsDetail; + // if we deffo don't want to keep it, + if (!mightWantToKeepRow) { + return REMOVE_ROW; + } + // editing row, only remove if it is no longer rendered, eg filtered out or new data set. + // the reason we want to keep is if user is scrolling up and down, we don't want to loose + // the context of the editing in process. + var rowNodePresent = this.paginationProxy.isRowPresent(rowNode); + return rowNodePresent ? KEEP_ROW : REMOVE_ROW; }; - RowNode.prototype.getFirstChildOfFirstChild = function (rowGroupColumn) { - var currentRowNode = this; - var isCandidate = true; - var foundFirstChildPath = false; - var nodeToSwapIn; - // if we are hiding groups, then if we are the first child, of the first child, - // all the way up to the column we are interested in, then we show the group cell. - while (isCandidate && !foundFirstChildPath) { - var parentRowNode = currentRowNode.parent; - var firstChild = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].exists(parentRowNode) && currentRowNode.firstChild; - if (firstChild) { - if (parentRowNode.rowGroupColumn === rowGroupColumn) { - foundFirstChildPath = true; - nodeToSwapIn = parentRowNode; - } - } - else { - isCandidate = false; - } - currentRowNode = parentRowNode; + RowRenderer.prototype.createRowCon = function (rowNode, animate, afterScroll) { + var rowCtrlFromCache = this.cachedRowCtrls ? this.cachedRowCtrls.getRow(rowNode) : null; + if (rowCtrlFromCache) { + return rowCtrlFromCache; } - return foundFirstChildPath ? nodeToSwapIn : null; + // we don't use animations frames for printing, so the user can put the grid into print mode + // and immediately print - otherwise the user would have to wait for the rows to draw in the background + // (via the animation frames) which is awkward to do from code. + // we only do the animation frames after scrolling, as this is where we want the smooth user experience. + // having animation frames for other times makes the grid look 'jumpy'. + var suppressAnimationFrame = this.gridOptionsWrapper.isSuppressAnimationFrame(); + var useAnimationFrameForCreate = afterScroll && !suppressAnimationFrame && !this.printLayout; + var res = new _row_rowCtrl__WEBPACK_IMPORTED_MODULE_1__["RowCtrl"](this.$scope, rowNode, this.beans, animate, useAnimationFrameForCreate, this.printLayout); + return res; }; - RowNode.prototype.isFullWidthCell = function () { - var isFullWidthCellFunc = this.gridOptionsWrapper.getIsFullWidthCellFunc(); - return isFullWidthCellFunc ? isFullWidthCellFunc(this) : false; + RowRenderer.prototype.getRenderedNodes = function () { + var renderedRows = this.rowCtrlsByRowIndex; + return Object.keys(renderedRows).map(function (key) { return renderedRows[key].getRowNode(); }); }; - RowNode.ID_PREFIX_ROW_GROUP = 'row-group-'; - RowNode.ID_PREFIX_TOP_PINNED = 't-'; - RowNode.ID_PREFIX_BOTTOM_PINNED = 'b-'; - RowNode.OBJECT_ID_SEQUENCE = 0; - RowNode.EVENT_ROW_SELECTED = 'rowSelected'; - RowNode.EVENT_DATA_CHANGED = 'dataChanged'; - RowNode.EVENT_CELL_CHANGED = 'cellChanged'; - RowNode.EVENT_ALL_CHILDREN_COUNT_CHANGED = 'allChildrenCountChanged'; - RowNode.EVENT_MASTER_CHANGED = 'masterChanged'; - RowNode.EVENT_MOUSE_ENTER = 'mouseEnter'; - RowNode.EVENT_MOUSE_LEAVE = 'mouseLeave'; - RowNode.EVENT_HEIGHT_CHANGED = 'heightChanged'; - RowNode.EVENT_TOP_CHANGED = 'topChanged'; - RowNode.EVENT_FIRST_CHILD_CHANGED = 'firstChildChanged'; - RowNode.EVENT_LAST_CHILD_CHANGED = 'lastChildChanged'; - RowNode.EVENT_CHILD_INDEX_CHANGED = 'childIndexChanged'; - RowNode.EVENT_ROW_INDEX_CHANGED = 'rowIndexChanged'; - RowNode.EVENT_EXPANDED_CHANGED = 'expandedChanged'; - RowNode.EVENT_SELECTABLE_CHANGED = 'selectableChanged'; - RowNode.EVENT_UI_LEVEL_CHANGED = 'uiLevelChanged'; - RowNode.EVENT_HIGHLIGHT_CHANGED = 'rowHighlightChanged'; - RowNode.EVENT_DRAGGING_CHANGED = 'draggingChanged'; + RowRenderer.prototype.getRowByPosition = function (rowPosition) { + var rowComponent; + switch (rowPosition.rowPinned) { + case _constants_constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_TOP: + rowComponent = this.topRowCtrls[rowPosition.rowIndex]; + break; + case _constants_constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_BOTTOM: + rowComponent = this.bottomRowCtrls[rowPosition.rowIndex]; + break; + default: + rowComponent = this.rowCtrlsByRowIndex[rowPosition.rowIndex]; + break; + } + return rowComponent; + }; + RowRenderer.prototype.getRowNode = function (gridRow) { + switch (gridRow.rowPinned) { + case _constants_constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_TOP: + return this.pinnedRowModel.getPinnedTopRowData()[gridRow.rowIndex]; + case _constants_constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_BOTTOM: + return this.pinnedRowModel.getPinnedBottomRowData()[gridRow.rowIndex]; + default: + return this.rowModel.getRow(gridRow.rowIndex); + } + }; + // returns true if any row between startIndex and endIndex is rendered. used by + // SSRM or IRM, as they don't want to purge visible blocks from cache. + RowRenderer.prototype.isRangeInRenderedViewport = function (startIndex, endIndex) { + // parent closed means the parent node is not expanded, thus these blocks are not visible + var parentClosed = startIndex == null || endIndex == null; + if (parentClosed) { + return false; + } + var blockAfterViewport = startIndex > this.lastRenderedRow; + var blockBeforeViewport = endIndex < this.firstRenderedRow; + var blockInsideViewport = !blockBeforeViewport && !blockAfterViewport; + return blockInsideViewport; + }; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_5__["Autowired"])("paginationProxy") + ], RowRenderer.prototype, "paginationProxy", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('eventService') - ], RowNode.prototype, "mainEventService", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_5__["Autowired"])("columnModel") + ], RowRenderer.prototype, "columnModel", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper') - ], RowNode.prototype, "gridOptionsWrapper", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_5__["Autowired"])("$scope") + ], RowRenderer.prototype, "$scope", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('selectionController') - ], RowNode.prototype, "selectionController", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_5__["Autowired"])("pinnedRowModel") + ], RowRenderer.prototype, "pinnedRowModel", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnController') - ], RowNode.prototype, "columnController", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_5__["Autowired"])("rowModel") + ], RowRenderer.prototype, "rowModel", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('valueService') - ], RowNode.prototype, "valueService", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_5__["Autowired"])("focusService") + ], RowRenderer.prototype, "focusService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('rowModel') - ], RowNode.prototype, "rowModel", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_5__["Autowired"])("columnApi") + ], RowRenderer.prototype, "columnApi", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('context') - ], RowNode.prototype, "context", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_5__["Autowired"])("gridApi") + ], RowRenderer.prototype, "gridApi", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('valueCache') - ], RowNode.prototype, "valueCache", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_5__["Autowired"])("beans") + ], RowRenderer.prototype, "beans", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnApi') - ], RowNode.prototype, "columnApi", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_5__["Autowired"])("rowContainerHeightService") + ], RowRenderer.prototype, "rowContainerHeightService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridApi') - ], RowNode.prototype, "gridApi", void 0); - return RowNode; -}()); + Object(_context_context__WEBPACK_IMPORTED_MODULE_5__["Optional"])("ctrlsService") + ], RowRenderer.prototype, "ctrlsService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_5__["PostConstruct"] + ], RowRenderer.prototype, "postConstruct", null); + RowRenderer = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_5__["Bean"])("rowRenderer") + ], RowRenderer); + return RowRenderer; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_6__["BeanStub"])); +var RowCtrlCache = /** @class */ (function () { + function RowCtrlCache(maxCount) { + // map for fast access + this.entriesMap = {}; + // list for keeping order + this.entriesList = []; + this.maxCount = maxCount; + } + RowCtrlCache.prototype.addRow = function (rowCtrl) { + this.entriesMap[rowCtrl.getRowNode().id] = rowCtrl; + this.entriesList.push(rowCtrl); + rowCtrl.setCached(true); + if (this.entriesList.length > this.maxCount) { + var rowCtrlToDestroy = this.entriesList[0]; + rowCtrlToDestroy.destroyFirstPass(); + rowCtrlToDestroy.destroySecondPass(); + this.removeFromCache(rowCtrlToDestroy); + } + }; + RowCtrlCache.prototype.getRow = function (rowNode) { + if (rowNode == null || rowNode.id == null) { + return null; + } + var res = this.entriesMap[rowNode.id]; + if (!res) { + return null; + } + this.removeFromCache(res); + res.setCached(false); + // this can happen if user reloads data, and a new RowNode is reusing + // the same ID as the old one + var rowNodeMismatch = res.getRowNode() != rowNode; + return rowNodeMismatch ? null : res; + }; + RowCtrlCache.prototype.removeFromCache = function (rowCtrl) { + var rowNodeId = rowCtrl.getRowNode().id; + delete this.entriesMap[rowNodeId]; + Object(_utils_array__WEBPACK_IMPORTED_MODULE_12__["removeFromArray"])(this.entriesList, rowCtrl); + }; + RowCtrlCache.prototype.getEntries = function () { + return this.entriesList; + }; + return RowCtrlCache; +}()); /***/ }), -/* 69 */ +/* 113 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CheckboxSelectionComponent", function() { return CheckboxSelectionComponent; }); -/* harmony import */ var _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(70); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(56); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(57); -/* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(68); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowType", function() { return RowType; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowCtrl", function() { return RowCtrl; }); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(15); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(94); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(23); +/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(16); +/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(17); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(42); +/* harmony import */ var _utils_event__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(21); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(14); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(7); +/* harmony import */ var _utils_string__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(26); +/* harmony import */ var _cell_cellCtrl__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(114); +/* harmony import */ var _angularRowUtils__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(124); +/* harmony import */ var _rowDragComp__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(96); +/* harmony import */ var _gridBodyComp_rowContainer_rowContainerCtrl__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(125); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(44); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -15812,11 +24682,25 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; +}; +var __spread = (undefined && undefined.__spread) || function () { + for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); + return ar; }; @@ -15825,1650 +24709,1247 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var CheckboxSelectionComponent = /** @class */ (function (_super) { - __extends(CheckboxSelectionComponent, _super); - function CheckboxSelectionComponent() { - return _super.call(this, /* html*/ "\n
\n \n
") || this; - } - CheckboxSelectionComponent.prototype.onDataChanged = function () { - // when rows are loaded for the second time, this can impact the selection, as a row - // could be loaded as already selected (if user scrolls down, and then up again). - this.onSelectionChanged(); - }; - CheckboxSelectionComponent.prototype.onSelectableChanged = function () { - this.showOrHideSelect(); - }; - CheckboxSelectionComponent.prototype.onSelectionChanged = function () { - var state = this.rowNode.isSelected(); - this.eCheckbox.setValue(state, true); - }; - CheckboxSelectionComponent.prototype.onCheckedClicked = function () { - var groupSelectsFiltered = this.gridOptionsWrapper.isGroupSelectsFiltered(); - var updatedCount = this.rowNode.setSelectedParams({ newValue: false, groupSelectsFiltered: groupSelectsFiltered }); - return updatedCount; - }; - CheckboxSelectionComponent.prototype.onUncheckedClicked = function (event) { - var groupSelectsFiltered = this.gridOptionsWrapper.isGroupSelectsFiltered(); - var updatedCount = this.rowNode.setSelectedParams({ newValue: true, rangeSelect: event.shiftKey, groupSelectsFiltered: groupSelectsFiltered }); - return updatedCount; - }; - CheckboxSelectionComponent.prototype.init = function (params) { - var _this = this; - this.rowNode = params.rowNode; - this.column = params.column; - this.onSelectionChanged(); - // we don't want the row clicked event to fire when selecting the checkbox, otherwise the row - // would possibly get selected twice - this.addGuiEventListener('click', function (event) { return _utils__WEBPACK_IMPORTED_MODULE_6__["_"].stopPropagationForAgGrid(event); }); - // likewise we don't want double click on this icon to open a group - this.addGuiEventListener('dblclick', function (event) { return _utils__WEBPACK_IMPORTED_MODULE_6__["_"].stopPropagationForAgGrid(event); }); - this.addManagedListener(this.eCheckbox, _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_0__["AgCheckbox"].EVENT_CHANGED, function (params) { - if (params.selected) { - _this.onUncheckedClicked(params.event || {}); - } - else { - _this.onCheckedClicked(); - } - }); - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_5__["RowNode"].EVENT_ROW_SELECTED, this.onSelectionChanged.bind(this)); - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_5__["RowNode"].EVENT_DATA_CHANGED, this.onDataChanged.bind(this)); - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_5__["RowNode"].EVENT_SELECTABLE_CHANGED, this.onSelectableChanged.bind(this)); - this.isRowSelectableFunc = this.gridOptionsWrapper.getIsRowSelectableFunc(); - var checkboxVisibleIsDynamic = this.isRowSelectableFunc || this.checkboxCallbackExists(); - if (checkboxVisibleIsDynamic) { - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.showOrHideSelect.bind(this)); - this.showOrHideSelect(); - } - this.eCheckbox.setInputAriaLabel('Toggle Row Selection'); - }; - CheckboxSelectionComponent.prototype.showOrHideSelect = function () { - // if the isRowSelectable() is not provided the row node is selectable by default - var selectable = this.rowNode.selectable; - // checkboxSelection callback is deemed a legacy solution however we will still consider it's result. - // If selectable, then also check the colDef callback. if not selectable, this it short circuits - no need - // to call the colDef callback. - if (selectable && this.checkboxCallbackExists()) { - selectable = this.column.isCellCheckboxSelection(this.rowNode); - } - // show checkbox if both conditions are true - this.setDisplayed(selectable); - }; - CheckboxSelectionComponent.prototype.checkboxCallbackExists = function () { - // column will be missing if groupUseEntireRow=true - var colDef = this.column ? this.column.getColDef() : null; - return colDef && typeof colDef.checkboxSelection === 'function'; - }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], CheckboxSelectionComponent.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eCheckbox') - ], CheckboxSelectionComponent.prototype, "eCheckbox", void 0); - return CheckboxSelectionComponent; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_2__["Component"])); -/***/ }), -/* 70 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgCheckbox", function() { return AgCheckbox; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43); -/* harmony import */ var _agAbstractInputField__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(71); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var AgCheckbox = /** @class */ (function (_super) { - __extends(AgCheckbox, _super); - function AgCheckbox() { + +var RowType; +(function (RowType) { + RowType["Normal"] = "Normal"; + RowType["FullWidth"] = "FullWidth"; + RowType["FullWidthLoading"] = "FullWidthLoading"; + RowType["FullWidthGroup"] = "FullWidthGroup"; + RowType["FullWidthDetail"] = "FullWidthDetail"; +})(RowType || (RowType = {})); +var instanceIdSequence = 0; +var RowCtrl = /** @class */ (function (_super) { + __extends(RowCtrl, _super); + function RowCtrl(parentScope, rowNode, beans, animateIn, useAnimationFrameForCreate, printLayout) { var _this = _super.call(this) || this; - _this.className = 'ag-checkbox'; - _this.displayTag = 'input'; - _this.inputType = 'checkbox'; - _this.labelAlignment = 'right'; - _this.selected = false; - _this.readOnly = false; - _this.passive = false; - _this.setTemplate(_this.TEMPLATE.replace(/%displayField%/g, _this.displayTag)); + _this.allRowGuis = []; + _this.active = true; + _this.centerCellCtrls = { list: [], map: {} }; + _this.leftCellCtrls = { list: [], map: {} }; + _this.rightCellCtrls = { list: [], map: {} }; + _this.lastMouseDownOnDragger = false; + _this.updateColumnListsPending = false; + _this.parentScope = parentScope; + _this.beans = beans; + _this.rowNode = rowNode; + _this.paginationPage = _this.beans.paginationProxy.getCurrentPage(); + _this.useAnimationFrameForCreate = useAnimationFrameForCreate; + _this.printLayout = printLayout; + _this.instanceId = rowNode.id + '-' + instanceIdSequence++; + _this.setAnimateFlags(animateIn); + _this.rowFocused = _this.beans.focusService.isRowFocused(_this.rowNode.rowIndex, _this.rowNode.rowPinned); + _this.setupAngular1Scope(); + _this.rowLevel = _this.beans.rowCssClassCalculator.calculateRowLevel(_this.rowNode); + _this.setRowType(); + _this.addListeners(); + _this.setInitialRowTop(); return _this; } - AgCheckbox.prototype.addInputListeners = function () { - this.addManagedListener(this.eInput, 'click', this.onCheckboxClick.bind(this)); - }; - AgCheckbox.prototype.getNextValue = function () { - return this.selected === undefined ? true : !this.selected; - }; - AgCheckbox.prototype.setPassive = function (passive) { - this.passive = passive; - }; - AgCheckbox.prototype.isReadOnly = function () { - return this.readOnly; - }; - AgCheckbox.prototype.setReadOnly = function (readOnly) { - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addOrRemoveCssClass(this.eWrapper, 'ag-disabled', readOnly); - this.eInput.disabled = readOnly; - this.readOnly = readOnly; + RowCtrl.prototype.getBeans = function () { + return this.beans; }; - AgCheckbox.prototype.setDisabled = function (disabled) { - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addOrRemoveCssClass(this.eWrapper, 'ag-disabled', disabled); - return _super.prototype.setDisabled.call(this, disabled); + RowCtrl.prototype.getInstanceId = function () { + return this.instanceId; }; - AgCheckbox.prototype.toggle = function () { - var nextValue = this.getNextValue(); - if (this.passive) { - this.dispatchChange(nextValue); + RowCtrl.prototype.setComp = function (rowComp, element, containerType) { + var gui = { rowComp: rowComp, element: element, containerType: containerType }; + this.allRowGuis.push(gui); + if (containerType === _gridBodyComp_rowContainer_rowContainerCtrl__WEBPACK_IMPORTED_MODULE_14__["RowContainerType"].LEFT) { + this.leftGui = gui; + } + else if (containerType === _gridBodyComp_rowContainer_rowContainerCtrl__WEBPACK_IMPORTED_MODULE_14__["RowContainerType"].RIGHT) { + this.rightGui = gui; + } + else if (containerType === _gridBodyComp_rowContainer_rowContainerCtrl__WEBPACK_IMPORTED_MODULE_14__["RowContainerType"].FULL_WIDTH) { + this.fullWidthGui = gui; } else { - this.setValue(nextValue); + this.centerGui = gui; + } + var allNormalPresent = this.leftGui != null && this.rightGui != null && this.centerGui != null; + var fullWidthPresent = this.fullWidthGui != null; + if (allNormalPresent || fullWidthPresent) { + this.initialiseRowComps(); } }; - AgCheckbox.prototype.getValue = function () { - return this.isSelected(); + RowCtrl.prototype.isCacheable = function () { + return this.rowType === RowType.FullWidthDetail + && this.beans.gridOptionsWrapper.isKeepDetailRows(); }; - AgCheckbox.prototype.setValue = function (value, silent) { - this.refreshSelectedClass(value); - this.setSelected(value, silent); - return this; + RowCtrl.prototype.setCached = function (cached) { + var displayValue = cached ? 'none' : ''; + this.allRowGuis.forEach(function (rg) { return rg.element.style.display = displayValue; }); }; - AgCheckbox.prototype.setName = function (name) { - var input = this.getInputElement(); - input.name = name; - return this; + RowCtrl.prototype.initialiseRowComps = function () { + var _this = this; + var gow = this.beans.gridOptionsWrapper; + this.onRowHeightChanged(); + this.updateRowIndexes(); + this.setFocusedClasses(); + this.setStylesFromGridOptions(); + if (gow.isRowSelection() && this.rowNode.selectable) { + this.onRowSelected(); + } + this.updateColumnLists(!this.useAnimationFrameForCreate); + if (this.slideRowIn) { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_8__["executeNextVMTurn"])(this.onTopChanged.bind(this)); + } + if (this.fadeRowIn) { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_8__["executeNextVMTurn"])(function () { + _this.allRowGuis.forEach(function (gui) { return gui.rowComp.addOrRemoveCssClass('ag-opacity-zero', false); }); + }); + } + var businessKey = this.getRowBusinessKey(); + var rowIdSanitised = Object(_utils_string__WEBPACK_IMPORTED_MODULE_10__["escapeString"])(this.rowNode.id); + var businessKeySanitised = Object(_utils_string__WEBPACK_IMPORTED_MODULE_10__["escapeString"])(businessKey); + this.allRowGuis.forEach(function (gui) { + var comp = gui.rowComp; + comp.setRole('row'); + var initialRowClasses = _this.getInitialRowClasses(gui.containerType); + initialRowClasses.forEach(function (name) { return comp.addOrRemoveCssClass(name, true); }); + if (_this.rowNode.group) { + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_15__["setAriaExpanded"])(gui.element, _this.rowNode.expanded == true); + } + if (rowIdSanitised != null) { + comp.setRowId(rowIdSanitised); + } + if (businessKeySanitised != null) { + comp.setRowBusinessKey(businessKeySanitised); + } + if (_this.isFullWidth() && !_this.beans.gridOptionsWrapper.isSuppressCellFocus()) { + comp.setTabIndex(-1); + } + // DOM DATA + gow.setDomData(gui.element, RowCtrl.DOM_DATA_KEY_ROW_CTRL, _this); + _this.addDestroyFunc(function () { return gow.setDomData(gui.element, RowCtrl.DOM_DATA_KEY_ROW_CTRL, null); }); + // adding hover functionality adds listener to this row, so we + // do it lazily in an animation frame + if (_this.useAnimationFrameForCreate) { + _this.beans.animationFrameService.createTask(_this.addHoverFunctionality.bind(_this, gui.element), _this.rowNode.rowIndex, 'createTasksP2'); + } + else { + _this.addHoverFunctionality(gui.element); + } + if (_this.isFullWidth()) { + _this.setupFullWidth(gui); + } + if (gow.isRowDragEntireRow()) { + _this.addRowDraggerToRow(gui); + } + if (_this.useAnimationFrameForCreate) { + // the height animation we only want active after the row is alive for 1 second. + // this stops the row animation working when rows are initially crated. otherwise + // auto-height rows get inserted into the dom and resized immediately, which gives + // very bad UX (eg 10 rows get inserted, then all 10 expand, look particularly bad + // when scrolling). so this makes sure when rows are shown for the first time, they + // are resized immediately without animation. + _this.beans.animationFrameService.addDestroyTask(function () { + if (!_this.isAlive()) { + return; + } + gui.rowComp.addOrRemoveCssClass('ag-after-created', true); + }); + } + }); + this.executeProcessRowPostCreateFunc(); }; - AgCheckbox.prototype.isSelected = function () { - return this.selected; + RowCtrl.prototype.addRowDraggerToRow = function (gui) { + var gow = this.beans.gridOptionsWrapper; + if (gow.isEnableRangeSelection()) { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_8__["doOnce"])(function () { + console.warn('AG Grid: Setting `rowDragEntireRow: true` in the gridOptions doesn\'t work with `enableRangeSelection: true`'); + }, 'rowDragAndRangeSelectionEnabled'); + return; + } + var rowDragComp = new _rowDragComp__WEBPACK_IMPORTED_MODULE_13__["RowDragComp"](function () { return '1 row'; }, this.rowNode, undefined, gui.element, undefined, true); + this.createManagedBean(rowDragComp, this.beans.context); }; - AgCheckbox.prototype.setSelected = function (selected, silent) { - if (this.isSelected() === selected) { + RowCtrl.prototype.setupFullWidth = function (gui) { + var pinned = this.getPinnedForContainer(gui.containerType); + var params = this.createFullWidthParams(gui.element, pinned); + var masterDetailModuleLoaded = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].MasterDetailModule); + if (this.rowType == RowType.FullWidthDetail && !masterDetailModuleLoaded) { + if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isPackageBased()) { + console.warn("AG Grid: cell renderer 'agDetailCellRenderer' (for master detail) not found. Can only be used with ag-grid-enterprise package."); + } + else { + console.warn("AG Grid: cell renderer 'agDetailCellRenderer' (for master detail) not found. Can only be used with AG Grid Enterprise Module " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].MasterDetailModule); + } return; } - this.selected = typeof selected === 'boolean' ? selected : undefined; - this.eInput.checked = this.selected; - this.eInput.indeterminate = this.selected === undefined; - if (!silent) { - this.dispatchChange(this.selected); + var compDetails; + switch (this.rowType) { + case RowType.FullWidthDetail: + compDetails = this.beans.userComponentFactory.getFullWidthDetailCellRendererDetails(params); + break; + case RowType.FullWidthGroup: + compDetails = this.beans.userComponentFactory.getFullWidthGroupCellRendererDetails(params); + break; + case RowType.FullWidthLoading: + compDetails = this.beans.userComponentFactory.getFullWidthLoadingCellRendererDetails(params); + break; + default: + compDetails = this.beans.userComponentFactory.getFullWidthCellRendererDetails(params); + break; } + gui.rowComp.showFullWidth(compDetails); }; - AgCheckbox.prototype.dispatchChange = function (selected, event) { - this.dispatchEvent({ type: AgCheckbox.EVENT_CHANGED, selected: selected, event: event }); - var input = this.getInputElement(); - var checkboxChangedEvent = { - type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CHECKBOX_CHANGED, - id: input.id, - name: input.name, - selected: selected - }; - this.eventService.dispatchEvent(checkboxChangedEvent); + RowCtrl.prototype.getScope = function () { + return this.scope; }; - AgCheckbox.prototype.onCheckboxClick = function (e) { - this.selected = e.target.checked; - this.refreshSelectedClass(this.selected); - this.dispatchChange(this.selected, e); + RowCtrl.prototype.isPrintLayout = function () { + return this.printLayout; }; - AgCheckbox.prototype.refreshSelectedClass = function (value) { - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addOrRemoveCssClass(this.eWrapper, 'ag-checked', value === true); - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addOrRemoveCssClass(this.eWrapper, 'ag-indeterminate', value == null); + RowCtrl.prototype.setupAngular1Scope = function () { + var scopeResult = _angularRowUtils__WEBPACK_IMPORTED_MODULE_12__["AngularRowUtils"].createChildScopeOrNull(this.rowNode, this.parentScope, this.beans.gridOptionsWrapper); + if (scopeResult) { + this.scope = scopeResult.scope; + this.addDestroyFunc(scopeResult.scopeDestroyFunc); + } }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], AgCheckbox.prototype, "gridOptionsWrapper", void 0); - return AgCheckbox; -}(_agAbstractInputField__WEBPACK_IMPORTED_MODULE_2__["AgAbstractInputField"])); - - - -/***/ }), -/* 71 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgAbstractInputField", function() { return AgAbstractInputField; }); -/* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57); -/* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(72); -/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + // use by autoWidthCalculator, as it clones the elements + RowCtrl.prototype.getCellElement = function (column) { + var cellCtrl = this.getCellCtrl(column); + return cellCtrl ? cellCtrl.getGui() : null; }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + RowCtrl.prototype.executeProcessRowPostCreateFunc = function () { + var func = this.beans.gridOptionsWrapper.getProcessRowPostCreateFunc(); + if (!func) { + return; + } + var params = { + eRow: this.centerGui ? this.centerGui.element : undefined, + ePinnedLeftRow: this.leftGui ? this.leftGui.element : undefined, + ePinnedRightRow: this.rightGui ? this.rightGui.element : undefined, + node: this.rowNode, + api: this.beans.gridOptionsWrapper.getApi(), + rowIndex: this.rowNode.rowIndex, + addRenderedRowListener: this.addEventListener.bind(this), + columnApi: this.beans.gridOptionsWrapper.getColumnApi(), + context: this.beans.gridOptionsWrapper.getContext() + }; + func(params); }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - -var AgAbstractInputField = /** @class */ (function (_super) { - __extends(AgAbstractInputField, _super); - function AgAbstractInputField() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.config = {}; - _this.TEMPLATE = "\n
\n \n
\n <%displayField% ref=\"eInput\" class=\"ag-input-field-input\">\n
\n
"; - return _this; - } - AgAbstractInputField.prototype.postConstruct = function () { - _super.prototype.postConstruct.call(this); - this.setInputType(); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["addCssClass"])(this.eLabel, this.className + "-label"); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["addCssClass"])(this.eWrapper, this.className + "-input-wrapper"); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["addCssClass"])(this.eInput, this.className + "-input"); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["addCssClass"])(this.getGui(), 'ag-input-field'); - var inputId = this.eInput.id ? this.eInput.id : "ag-input-id-" + this.getCompId(); - this.eLabel.htmlFor = inputId; - this.eInput.id = inputId; - var _a = this.config, width = _a.width, value = _a.value; - if (width != null) { - this.setWidth(width); + RowCtrl.prototype.setRowType = function () { + var isStub = this.rowNode.stub; + var isFullWidthCell = this.rowNode.isFullWidthCell(); + var isDetailCell = this.beans.doingMasterDetail && this.rowNode.detail; + var pivotMode = this.beans.columnModel.isPivotMode(); + // we only use full width for groups, not footers. it wouldn't make sense to include footers if not looking + // for totals. if users complain about this, then we should introduce a new property 'footerUseEntireRow' + // so each can be set independently (as a customer complained about footers getting full width, hence + // introducing this logic) + var isGroupRow = !!this.rowNode.group && !this.rowNode.footer; + var isFullWidthGroup = isGroupRow && this.beans.gridOptionsWrapper.isGroupUseEntireRow(pivotMode); + if (isStub) { + this.rowType = RowType.FullWidthLoading; } - if (value != null) { - this.setValue(value); + else if (isDetailCell) { + this.rowType = RowType.FullWidthDetail; } - this.addInputListeners(); - }; - AgAbstractInputField.prototype.addInputListeners = function () { - var _this = this; - this.addManagedListener(this.eInput, 'input', function (e) { - var value = e.target.value; - _this.setValue(value); - }); - }; - AgAbstractInputField.prototype.setInputType = function () { - if (this.inputType) { - this.eInput.setAttribute('type', this.inputType); + else if (isFullWidthCell) { + this.rowType = RowType.FullWidth; } - }; - AgAbstractInputField.prototype.getInputElement = function () { - return this.eInput; - }; - AgAbstractInputField.prototype.setInputWidth = function (width) { - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["setElementWidth"])(this.eWrapper, width); - return this; - }; - AgAbstractInputField.prototype.setInputName = function (name) { - this.getInputElement().setAttribute('name', name); - return this; - }; - AgAbstractInputField.prototype.getFocusableElement = function () { - return this.eInput; - }; - AgAbstractInputField.prototype.setMaxLength = function (length) { - var eInput = this.eInput; - eInput.maxLength = length; - return this; - }; - AgAbstractInputField.prototype.setInputPlaceholder = function (placeholder) { - var eInput = this.eInput; - var attributeName = 'placeholder'; - if (placeholder) { - eInput.setAttribute(attributeName, placeholder); + else if (isFullWidthGroup) { + this.rowType = RowType.FullWidthGroup; } else { - eInput.removeAttribute(attributeName); + this.rowType = RowType.Normal; } - return this; - }; - AgAbstractInputField.prototype.setDisabled = function (disabled) { - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["setDisabled"])(this.eInput, disabled); - return _super.prototype.setDisabled.call(this, disabled); - }; - AgAbstractInputField.prototype.setInputAriaLabel = function (label) { - this.eInput.setAttribute('aria-label', label); - return this; - }; - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eLabel') - ], AgAbstractInputField.prototype, "eLabel", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eWrapper') - ], AgAbstractInputField.prototype, "eWrapper", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eInput') - ], AgAbstractInputField.prototype, "eInput", void 0); - return AgAbstractInputField; -}(_agAbstractField__WEBPACK_IMPORTED_MODULE_1__["AgAbstractField"])); - - - -/***/ }), -/* 72 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgAbstractField", function() { return AgAbstractField; }); -/* harmony import */ var _agAbstractLabel__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(73); -/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; -})(); - - -var AgAbstractField = /** @class */ (function (_super) { - __extends(AgAbstractField, _super); - function AgAbstractField() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.disabled = false; - return _this; - } - AgAbstractField.prototype.postConstruct = function () { - _super.prototype.postConstruct.call(this); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["addCssClass"])(this.getGui(), this.className); - }; - AgAbstractField.prototype.onValueChange = function (callbackFn) { + RowCtrl.prototype.updateColumnLists = function (suppressAnimationFrame) { var _this = this; - this.addManagedListener(this, AgAbstractField.EVENT_CHANGED, function () { return callbackFn(_this.getValue()); }); - return this; - }; - AgAbstractField.prototype.getWidth = function () { - return this.getGui().clientWidth; - }; - AgAbstractField.prototype.setWidth = function (width) { - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["setFixedWidth"])(this.getGui(), width); - return this; - }; - AgAbstractField.prototype.getValue = function () { - return this.value; - }; - AgAbstractField.prototype.setValue = function (value, silent) { - if (this.value === value) { - return this; + if (suppressAnimationFrame === void 0) { suppressAnimationFrame = false; } + if (this.isFullWidth()) { + return; } - this.value = value; - if (!silent) { - this.dispatchEvent({ type: AgAbstractField.EVENT_CHANGED }); + var noAnimation = suppressAnimationFrame + || this.beans.gridOptionsWrapper.isSuppressAnimationFrame() + || this.printLayout; + if (noAnimation) { + this.updateColumnListsImpl(); + return; } - return this; - }; - AgAbstractField.prototype.setDisabled = function (disabled) { - disabled = !!disabled; - var element = this.getGui(); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["setDisabled"])(element, disabled); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["addOrRemoveCssClass"])(element, 'ag-disabled', disabled); - this.disabled = disabled; - return this; - }; - AgAbstractField.prototype.isDisabled = function () { - return !!this.disabled; - }; - AgAbstractField.EVENT_CHANGED = 'valueChange'; - return AgAbstractField; -}(_agAbstractLabel__WEBPACK_IMPORTED_MODULE_0__["AgAbstractLabel"])); - - - -/***/ }), -/* 73 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgAbstractLabel", function() { return AgAbstractLabel; }); -/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + if (this.updateColumnListsPending) { + return; + } + this.beans.animationFrameService.createTask(function () { + if (!_this.active) { + return; + } + _this.updateColumnListsImpl(); + }, this.rowNode.rowIndex, 'createTasksP1'); + this.updateColumnListsPending = true; }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + RowCtrl.prototype.createCellCtrls = function (prev, cols, pinned) { + var _this = this; + if (pinned === void 0) { pinned = null; } + var res = { + list: [], + map: {} + }; + var addCell = function (colInstanceId, cellCtrl) { + res.list.push(cellCtrl); + res.map[colInstanceId] = cellCtrl; + }; + cols.forEach(function (col) { + // we use instanceId's rather than colId as it's possible there is a Column with same Id, + // but it's referring to a different column instance. Happens a lot with pivot, as pivot col id's are + // reused eg pivot_0, pivot_1 etc + var colInstanceId = col.getInstanceId(); + var cellCtrl = prev.map[colInstanceId]; + if (!cellCtrl) { + cellCtrl = new _cell_cellCtrl__WEBPACK_IMPORTED_MODULE_11__["CellCtrl"](col, _this.rowNode, _this.beans, _this); + } + addCell(colInstanceId, cellCtrl); + }); + prev.list.forEach(function (prevCellCtrl) { + var cellInResult = res.map[prevCellCtrl.getColumn().getInstanceId()] != null; + if (cellInResult) { + return; + } + var keepCell = !_this.isCellEligibleToBeRemoved(prevCellCtrl, pinned); + if (keepCell) { + addCell(prevCellCtrl.getColumn().getInstanceId(), prevCellCtrl); + return; + } + prevCellCtrl.destroy(); + }); + return res; }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - -var AgAbstractLabel = /** @class */ (function (_super) { - __extends(AgAbstractLabel, _super); - function AgAbstractLabel() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.labelSeparator = ''; - _this.labelAlignment = 'left'; - _this.config = {}; - _this.label = ''; - return _this; - } - AgAbstractLabel.prototype.postConstruct = function () { - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(this.getGui(), 'ag-labeled'); - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(this.eLabel, 'ag-label'); - var _a = this.config, labelSeparator = _a.labelSeparator, label = _a.label, labelWidth = _a.labelWidth, labelAlignment = _a.labelAlignment; - if (labelSeparator != null) { - this.setLabelSeparator(labelSeparator); - } - if (label != null) { - this.setLabel(label); + RowCtrl.prototype.updateColumnListsImpl = function () { + var _this = this; + this.updateColumnListsPending = false; + var columnModel = this.beans.columnModel; + if (this.printLayout) { + this.centerCellCtrls = this.createCellCtrls(this.centerCellCtrls, columnModel.getAllDisplayedColumns()); + this.leftCellCtrls = { list: [], map: {} }; + this.rightCellCtrls = { list: [], map: {} }; } - if (labelWidth != null) { - this.setLabelWidth(labelWidth); + else { + var centerCols = columnModel.getViewportCenterColumnsForRow(this.rowNode); + this.centerCellCtrls = this.createCellCtrls(this.centerCellCtrls, centerCols); + var leftCols = columnModel.getDisplayedLeftColumnsForRow(this.rowNode); + this.leftCellCtrls = this.createCellCtrls(this.leftCellCtrls, leftCols, _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_LEFT); + var rightCols = columnModel.getDisplayedRightColumnsForRow(this.rowNode); + this.rightCellCtrls = this.createCellCtrls(this.rightCellCtrls, rightCols, _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_RIGHT); } - this.setLabelAlignment(labelAlignment || this.labelAlignment); - this.refreshLabel(); - }; - AgAbstractLabel.prototype.refreshLabel = function () { - this.eLabel.innerText = this.label + this.labelSeparator; - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(this.eLabel, 'ag-hidden', this.label === ''); + this.allRowGuis.forEach(function (item) { + var cellControls = item.containerType === _gridBodyComp_rowContainer_rowContainerCtrl__WEBPACK_IMPORTED_MODULE_14__["RowContainerType"].LEFT ? _this.leftCellCtrls : + item.containerType === _gridBodyComp_rowContainer_rowContainerCtrl__WEBPACK_IMPORTED_MODULE_14__["RowContainerType"].RIGHT ? _this.rightCellCtrls : _this.centerCellCtrls; + item.rowComp.setCellCtrls(cellControls.list); + }); }; - AgAbstractLabel.prototype.setLabelSeparator = function (labelSeparator) { - if (this.labelSeparator === labelSeparator) { - return this; + RowCtrl.prototype.isCellEligibleToBeRemoved = function (cellCtrl, nextContainerPinned) { + var REMOVE_CELL = true; + var KEEP_CELL = false; + // always remove the cell if it's not rendered or if it's in the wrong pinned location + var column = cellCtrl.getColumn(); + if (column.getPinned() != nextContainerPinned) { + return REMOVE_CELL; } - this.labelSeparator = labelSeparator; - if (this.label != null) { - this.refreshLabel(); + // we want to try and keep editing and focused cells + var editing = cellCtrl.isEditing(); + var focused = this.beans.focusService.isCellFocused(cellCtrl.getCellPosition()); + var mightWantToKeepCell = editing || focused; + if (mightWantToKeepCell) { + var column_1 = cellCtrl.getColumn(); + var displayedColumns = this.beans.columnModel.getAllDisplayedColumns(); + var cellStillDisplayed = displayedColumns.indexOf(column_1) >= 0; + return cellStillDisplayed ? KEEP_CELL : REMOVE_CELL; } - return this; + return REMOVE_CELL; }; - AgAbstractLabel.prototype.setLabel = function (label) { - if (this.label === label) { - return this; + RowCtrl.prototype.setAnimateFlags = function (animateIn) { + if (animateIn) { + var oldRowTopExists = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(this.rowNode.oldRowTop); + // if the row had a previous position, we slide it in (animate row top) + this.slideRowIn = oldRowTopExists; + // if the row had no previous position, we fade it in (animate + this.fadeRowIn = !oldRowTopExists; } - this.label = label; - this.refreshLabel(); - return this; - }; - AgAbstractLabel.prototype.setLabelAlignment = function (alignment) { - var eGui = this.getGui(); - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(eGui, 'ag-label-align-left', alignment === 'left'); - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(eGui, 'ag-label-align-right', alignment === 'right'); - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(eGui, 'ag-label-align-top', alignment === 'top'); - return this; - }; - AgAbstractLabel.prototype.setLabelWidth = function (width) { - if (this.label == null) { - return this; + else { + this.slideRowIn = false; + this.fadeRowIn = false; } - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].setElementWidth(this.eLabel, width); - return this; }; - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], AgAbstractLabel.prototype, "postConstruct", null); - return AgAbstractLabel; -}(_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); - - - -/***/ }), -/* 74 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ComponentSource", function() { return ComponentSource; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UserComponentFactory", function() { return UserComponentFactory; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _userComponentRegistry__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(53); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); -/* harmony import */ var _componentTypes__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(75); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(41); -/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(16); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + RowCtrl.prototype.isEditing = function () { + return this.editingRow; }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + RowCtrl.prototype.stopRowEditing = function (cancel) { + this.stopEditing(cancel); }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - - - -var ComponentSource; -(function (ComponentSource) { - ComponentSource[ComponentSource["DEFAULT"] = 0] = "DEFAULT"; - ComponentSource[ComponentSource["REGISTERED_BY_NAME"] = 1] = "REGISTERED_BY_NAME"; - ComponentSource[ComponentSource["HARDCODED"] = 2] = "HARDCODED"; -})(ComponentSource || (ComponentSource = {})); -var UserComponentFactory = /** @class */ (function (_super) { - __extends(UserComponentFactory, _super); - function UserComponentFactory() { - return _super !== null && _super.apply(this, arguments) || this; - } - UserComponentFactory.prototype.newDateComponent = function (params) { - return this.createAndInitUserComponent(this.gridOptions, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["DateComponent"], 'agDateInput'); + RowCtrl.prototype.isFullWidth = function () { + return this.rowType !== RowType.Normal; }; - UserComponentFactory.prototype.newHeaderComponent = function (params) { - return this.createAndInitUserComponent(params.column.getColDef(), params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["HeaderComponent"], 'agColumnHeader'); + RowCtrl.prototype.getRowType = function () { + return this.rowType; }; - UserComponentFactory.prototype.newHeaderGroupComponent = function (params) { - return this.createAndInitUserComponent(params.columnGroup.getColGroupDef(), params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["HeaderGroupComponent"], 'agColumnGroupHeader'); + RowCtrl.prototype.refreshFullWidth = function () { + var _this = this; + // returns 'true' if refresh succeeded + var tryRefresh = function (gui, pinned) { + if (!gui) { + return true; + } // no refresh needed + var cellRenderer = gui.rowComp.getFullWidthCellRenderer(); + // no cell renderer, either means comp not yet ready, or comp ready but now reference + // to it (happens in react when comp is stateless). if comp not ready, we don't need to + // refresh, however we don't know which one, so we refresh to cover the case where it's + // react comp without reference so need to force a refresh + if (!cellRenderer) { + return false; + } + // no refresh method present, so can't refresh, hard refresh needed + if (!cellRenderer.refresh) { + return false; + } + var params = _this.createFullWidthParams(gui.element, pinned); + var refreshSucceeded = cellRenderer.refresh(params); + return refreshSucceeded; + }; + var fullWidthSuccess = tryRefresh(this.fullWidthGui, null); + var centerSuccess = tryRefresh(this.centerGui, null); + var leftSuccess = tryRefresh(this.leftGui, _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_LEFT); + var rightSuccess = tryRefresh(this.rightGui, _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_RIGHT); + var allFullWidthRowsRefreshed = fullWidthSuccess && centerSuccess && leftSuccess && rightSuccess; + return allFullWidthRowsRefreshed; }; - UserComponentFactory.prototype.newFullWidthGroupRowInnerCellRenderer = function (params) { - return this.createAndInitUserComponent(this.gridOptions, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["GroupRowInnerRendererComponent"], null, true); + RowCtrl.prototype.addListeners = function () { + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_HEIGHT_CHANGED, this.onRowHeightChanged.bind(this)); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_ROW_SELECTED, this.onRowSelected.bind(this)); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_ROW_INDEX_CHANGED, this.onRowIndexChanged.bind(this)); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_TOP_CHANGED, this.onTopChanged.bind(this)); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_EXPANDED_CHANGED, this.updateExpandedCss.bind(this)); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_HAS_CHILDREN_CHANGED, this.updateExpandedCss.bind(this)); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_DATA_CHANGED, this.onRowNodeDataChanged.bind(this)); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_CELL_CHANGED, this.onRowNodeCellChanged.bind(this)); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_HIGHLIGHT_CHANGED, this.onRowNodeHighlightChanged.bind(this)); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_DRAGGING_CHANGED, this.onRowNodeDraggingChanged.bind(this)); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_UI_LEVEL_CHANGED, this.onUiLevelChanged.bind(this)); + var eventService = this.beans.eventService; + this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_PAGINATION_PIXEL_OFFSET_CHANGED, this.onPaginationPixelOffsetChanged.bind(this)); + this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_HEIGHT_SCALE_CHANGED, this.onTopChanged.bind(this)); + this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this)); + this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_VIRTUAL_COLUMNS_CHANGED, this.onVirtualColumnsChanged.bind(this)); + this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_CELL_FOCUSED, this.onCellFocusChanged.bind(this)); + this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_PAGINATION_CHANGED, this.onPaginationChanged.bind(this)); + this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_MODEL_UPDATED, this.onModelUpdated.bind(this)); + this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_MOVED, this.onColumnMoved.bind(this)); + this.addListenersForCellComps(); }; - // this one is unusual, as it can be LoadingCellRenderer, DetailCellRenderer, FullWidthCellRenderer or GroupRowRenderer. - // so we have to pass the type in. - UserComponentFactory.prototype.newFullWidthCellRenderer = function (params, cellRendererType, cellRendererName) { - return this.createAndInitUserComponent(null, params, { - propertyName: cellRendererType, - isCellRenderer: function () { return true; } - }, cellRendererName); + RowCtrl.prototype.onColumnMoved = function () { + this.updateColumnLists(); }; - UserComponentFactory.prototype.newCellRenderer = function (target, params, isPinned) { - if (isPinned === void 0) { isPinned = false; } - return this.createAndInitUserComponent(target, params, isPinned ? _componentTypes__WEBPACK_IMPORTED_MODULE_3__["PinnedRowCellRendererComponent"] : _componentTypes__WEBPACK_IMPORTED_MODULE_3__["CellRendererComponent"], null, true); + RowCtrl.prototype.addListenersForCellComps = function () { + var _this = this; + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_ROW_INDEX_CHANGED, function () { + _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.onRowIndexChanged(); }); + }); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_CELL_CHANGED, function (event) { + _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.onCellChanged(event); }); + }); }; - UserComponentFactory.prototype.newCellEditor = function (colDef, params) { - return this.createAndInitUserComponent(colDef, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["CellEditorComponent"], 'agCellEditor'); + RowCtrl.prototype.onRowNodeDataChanged = function (event) { + // if this is an update, we want to refresh, as this will allow the user to put in a transition + // into the cellRenderer refresh method. otherwise this might be completely new data, in which case + // we will want to completely replace the cells + this.getAllCellCtrls().forEach(function (cellCtrl) { + return cellCtrl.refreshCell({ + suppressFlash: !event.update, + newData: !event.update + }); + }); + // check for selected also, as this could be after lazy loading of the row data, in which case + // the id might of just gotten set inside the row and the row selected state may of changed + // as a result. this is what happens when selected rows are loaded in virtual pagination. + // - niall note - since moving to the stub component, this may no longer be true, as replacing + // the stub component now replaces the entire row + this.onRowSelected(); + // as data has changed, then the style and class needs to be recomputed + this.postProcessCss(); }; - UserComponentFactory.prototype.newInnerCellRenderer = function (target, params) { - return this.createAndInitUserComponent(target, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["InnerRendererComponent"], null); + RowCtrl.prototype.onRowNodeCellChanged = function () { + // as data has changed, then the style and class needs to be recomputed + this.postProcessCss(); }; - UserComponentFactory.prototype.newLoadingOverlayComponent = function (params) { - return this.createAndInitUserComponent(this.gridOptions, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["LoadingOverlayComponent"], 'agLoadingOverlay'); + RowCtrl.prototype.postProcessCss = function () { + this.setStylesFromGridOptions(); + this.postProcessClassesFromGridOptions(); + this.postProcessRowClassRules(); + this.postProcessRowDragging(); }; - UserComponentFactory.prototype.newNoRowsOverlayComponent = function (params) { - return this.createAndInitUserComponent(this.gridOptions, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["NoRowsOverlayComponent"], 'agNoRowsOverlay'); + RowCtrl.prototype.onRowNodeHighlightChanged = function () { + var highlighted = this.rowNode.highlighted; + this.allRowGuis.forEach(function (gui) { + var aboveOn = highlighted === _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowHighlightPosition"].Above; + var belowOn = highlighted === _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowHighlightPosition"].Below; + gui.rowComp.addOrRemoveCssClass('ag-row-highlight-above', aboveOn); + gui.rowComp.addOrRemoveCssClass('ag-row-highlight-below', belowOn); + }); }; - UserComponentFactory.prototype.newTooltipComponent = function (params) { - return this.createAndInitUserComponent(params.colDef, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["TooltipComponent"], 'agTooltipComponent'); + RowCtrl.prototype.onRowNodeDraggingChanged = function () { + this.postProcessRowDragging(); }; - UserComponentFactory.prototype.newFilterComponent = function (colDef, params, defaultFilter, modifyParamsCallback) { - return this.createAndInitUserComponent(colDef, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["FilterComponent"], defaultFilter, false, modifyParamsCallback); + RowCtrl.prototype.postProcessRowDragging = function () { + var dragging = this.rowNode.dragging; + this.allRowGuis.forEach(function (gui) { return gui.rowComp.addOrRemoveCssClass('ag-row-dragging', dragging); }); }; - UserComponentFactory.prototype.newSetFilterCellRenderer = function (target, params) { - return this.createAndInitUserComponent(target, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["CellRendererComponent"], null, true); + RowCtrl.prototype.updateExpandedCss = function () { + var expandable = this.rowNode.isExpandable(); + var expanded = this.rowNode.expanded == true; + this.allRowGuis.forEach(function (gui) { + gui.rowComp.addOrRemoveCssClass('ag-row-group', expandable); + gui.rowComp.addOrRemoveCssClass('ag-row-group-expanded', expandable && expanded); + gui.rowComp.addOrRemoveCssClass('ag-row-group-contracted', expandable && !expanded); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_15__["setAriaExpanded"])(gui.element, expandable && expanded); + }); }; - UserComponentFactory.prototype.newFloatingFilterComponent = function (colDef, params, defaultFloatingFilter) { - return this.createAndInitUserComponent(colDef, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["FloatingFilterComponent"], defaultFloatingFilter, true); + RowCtrl.prototype.onDisplayedColumnsChanged = function () { + // we skip animations for onDisplayedColumnChanged, as otherwise the client could remove columns and + // then set data, and any old valueGetter's (ie from cols that were removed) would still get called. + this.updateColumnLists(true); + if (this.beans.columnModel.wasAutoRowHeightEverActive()) { + this.rowNode.checkAutoHeights(); + } }; - UserComponentFactory.prototype.newToolPanelComponent = function (toolPanelDef, params) { - return this.createAndInitUserComponent(toolPanelDef, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["ToolPanelComponent"]); + RowCtrl.prototype.onVirtualColumnsChanged = function () { + this.updateColumnLists(); }; - UserComponentFactory.prototype.newStatusPanelComponent = function (def, params) { - return this.createAndInitUserComponent(def, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["StatusPanelComponent"]); + RowCtrl.prototype.getRowPosition = function () { + return { + rowPinned: this.rowNode.rowPinned, + rowIndex: this.rowNode.rowIndex + }; }; - /** - * This method creates a component given everything needed to guess what sort of component needs to be instantiated - * It takes - * @param definitionObject: This is the context for which this component needs to be created, it can be gridOptions - * (global) or columnDef mostly. - * @param paramsFromGrid: Params to be passed to the component and passed by ag-Grid. This will get merged with any params - * specified by the user in the configuration - * @param propertyName: The name of the property used in ag-grid as a convention to refer to the component, it can be: - * 'floatingFilter', 'cellRenderer', is used to find if the user is specifying a custom component - * @param defaultComponentName: The actual name of the component to instantiate, this is usually the same as propertyName, but in - * some cases is not, like floatingFilter, if it is the same is not necessary to specify - * @param optional: Handy method to tell if this should return a component ALWAYS. if that is the case, but there is no - * component found, it throws an error, by default all components are MANDATORY - * @param modifyParamsCallback: A chance to customise the params passed to the init method. It receives what the current - * params are and the component that init is about to get called for - */ - UserComponentFactory.prototype.createAndInitUserComponent = function (definitionObject, paramsFromGrid, componentType, defaultComponentName, - // optional items are: FloatingFilter, CellComp (for cellRenderer) - optional, - // used by FilterManager only - modifyParamsCallback) { - if (optional === void 0) { optional = false; } - if (!definitionObject) { - definitionObject = this.gridOptions; + RowCtrl.prototype.onKeyboardNavigate = function (keyboardEvent) { + var currentFullWidthComp = this.allRowGuis.find(function (c) { return c.element.contains(keyboardEvent.target); }); + var currentFullWidthContainer = currentFullWidthComp ? currentFullWidthComp.element : null; + var isFullWidthContainerFocused = currentFullWidthContainer === keyboardEvent.target; + if (!isFullWidthContainerFocused) { + return; } - // Create the component instance - var componentAndParams = this.createComponentInstance(definitionObject, componentType, paramsFromGrid, defaultComponentName, optional); - if (!componentAndParams) { - return null; + var node = this.rowNode; + var lastFocusedCell = this.beans.focusService.getFocusedCell(); + var cellPosition = { + rowIndex: node.rowIndex, + rowPinned: node.rowPinned, + column: (lastFocusedCell && lastFocusedCell.column) + }; + this.beans.navigationService.navigateToNextCell(keyboardEvent, keyboardEvent.key, cellPosition, true); + keyboardEvent.preventDefault(); + }; + RowCtrl.prototype.onTabKeyDown = function (keyboardEvent) { + if (keyboardEvent.defaultPrevented || Object(_utils_event__WEBPACK_IMPORTED_MODULE_7__["isStopPropagationForAgGrid"])(keyboardEvent)) { + return; } - var componentInstance = componentAndParams.componentInstance; - // Wire the component and call the init method with the correct params - var params = this.createFinalParams(definitionObject, componentType.propertyName, paramsFromGrid, componentAndParams.paramsFromSelector); - this.addReactHacks(params); - // give caller chance to set any params that depend on the componentInstance (need here as the - // componentInstance was not available when createUserComponent was called) - var paramsAfterCallback = modifyParamsCallback ? modifyParamsCallback(params, componentInstance) : params; - var deferredInit = this.initComponent(componentInstance, paramsAfterCallback); - if (deferredInit == null) { - return _utils__WEBPACK_IMPORTED_MODULE_2__["Promise"].resolve(componentInstance); + var currentFullWidthComp = this.allRowGuis.find(function (c) { return c.element.contains(keyboardEvent.target); }); + var currentFullWidthContainer = currentFullWidthComp ? currentFullWidthComp.element : null; + var isFullWidthContainerFocused = currentFullWidthContainer === keyboardEvent.target; + var nextEl = null; + if (!isFullWidthContainerFocused) { + nextEl = this.beans.focusService.findNextFocusableElement(currentFullWidthContainer, false, keyboardEvent.shiftKey); } - else { - return deferredInit.then(function () { return componentInstance; }); + if ((this.isFullWidth() && isFullWidthContainerFocused) || !nextEl) { + this.beans.navigationService.onTabKeyDown(this, keyboardEvent); } }; - UserComponentFactory.prototype.addReactHacks = function (params) { - // a temporary fix for AG-1574 - // AG-1715 raised to do a wider ranging refactor to improve this - var agGridReact = this.context.getBean('agGridReact'); - if (agGridReact) { - params.agGridReact = Object(_utils_object__WEBPACK_IMPORTED_MODULE_5__["cloneObject"])(agGridReact); - } - // AG-1716 - directly related to AG-1574 and AG-1715 - var frameworkComponentWrapper = this.context.getBean('frameworkComponentWrapper'); - if (frameworkComponentWrapper) { - params.frameworkComponentWrapper = frameworkComponentWrapper; + RowCtrl.prototype.onFullWidthRowFocused = function (event) { + var _a; + var node = this.rowNode; + var isFocused = this.isFullWidth() && event.rowIndex === node.rowIndex && event.rowPinned == node.rowPinned; + var element = this.fullWidthGui ? this.fullWidthGui.element : (_a = this.centerGui) === null || _a === void 0 ? void 0 : _a.element; + if (!element) { + return; + } // can happen with react ui, comp not yet ready + element.classList.toggle('ag-full-width-focus', isFocused); + if (isFocused) { + // we don't scroll normal rows into view when we focus them, so we don't want + // to scroll Full Width rows either. + element.focus({ preventScroll: true }); } }; - /** - * This method creates a component given everything needed to guess what sort of component needs to be instantiated - * It takes - * @param clazz: The class to instantiate, - * @param agGridParams: Params to be passed to the component and passed by ag-Grid. This will get merged with any params - * specified by the user in the configuration - * @param modifyParamsCallback: A chance to customise the params passed to the init method. It receives what the current - * params are and the component that init is about to get called for - */ - UserComponentFactory.prototype.createUserComponentFromConcreteClass = function (clazz, agGridParams) { - var internalComponent = new clazz(); - this.initComponent(internalComponent, agGridParams); - return internalComponent; + RowCtrl.prototype.refreshCell = function (cellCtrl) { + this.centerCellCtrls = this.removeCellCtrl(this.centerCellCtrls, cellCtrl); + this.leftCellCtrls = this.removeCellCtrl(this.leftCellCtrls, cellCtrl); + this.rightCellCtrls = this.removeCellCtrl(this.rightCellCtrls, cellCtrl); + this.updateColumnLists(); }; - /** - * This method returns the underlying representation of the component to be created. ie for Javascript the - * underlying function where we should be calling new into. In case of the frameworks, the framework class - * object that represents the component to be created. - * - * This method is handy for different reasons, for example if you want to check if a component has a particular - * method implemented without having to create the component, just by inspecting the source component - * - * It takes - * @param definitionObject: This is the context for which this component needs to be created, it can be gridOptions - * (global) or columnDef mostly. - * @param propertyName: The name of the property used in ag-grid as a convention to refer to the component, it can be: - * 'floatingFilter', 'cellRenderer', is used to find if the user is specifying a custom component - * @param params: Params to be passed to the dynamic component function in case it needs to be - * invoked - * @param defaultComponentName: The name of the component to load if there is no component specified - */ - UserComponentFactory.prototype.lookupComponentClassDef = function (definitionObject, propertyName, params, defaultComponentName) { - if (params === void 0) { params = null; } - /** - * There are five things that can happen when resolving a component. - * a) HardcodedFwComponent: That holder[propertyName]Framework has associated a Framework native component - * b) HardcodedJsComponent: That holder[propertyName] has associate a JS component - * c) hardcodedJsFunction: That holder[propertyName] has associate a JS function - * d) hardcodedNameComponent: That holder[propertyName] has associate a string that represents a component to load - * e) That none of the three previous are specified, then we need to use the DefaultRegisteredComponent - */ - var hardcodedNameComponent = null; - var HardcodedJsComponent = null; - var hardcodedJsFunction = null; - var HardcodedFwComponent = null; - var componentSelectorFunc; - if (definitionObject != null) { - var componentPropertyValue = definitionObject[propertyName]; - // for filters only, we allow 'true' for the component, which means default filter to be used - var usingDefaultComponent = componentPropertyValue === true; - if (componentPropertyValue != null && !usingDefaultComponent) { - if (typeof componentPropertyValue === 'string') { - hardcodedNameComponent = componentPropertyValue; - } - else if (typeof componentPropertyValue === 'boolean') { - // never happens, as we test for usingDefaultComponent above, - // however it's needed for the next block to compile - } - else if (this.agComponentUtils.doesImplementIComponent(componentPropertyValue)) { - HardcodedJsComponent = componentPropertyValue; - } - else { - hardcodedJsFunction = componentPropertyValue; - } + RowCtrl.prototype.removeCellCtrl = function (prev, cellCtrlToRemove) { + var res = { + list: [], + map: {} + }; + prev.list.forEach(function (cellCtrl) { + if (cellCtrl === cellCtrlToRemove) { + return; } - HardcodedFwComponent = definitionObject[propertyName + "Framework"]; - componentSelectorFunc = definitionObject[propertyName + "Selector"]; - } - /** - * Since we allow many types of flavors for specifying the components, let's make sure this is not an illegal - * combination - */ - if ((HardcodedJsComponent && HardcodedFwComponent) || - (hardcodedNameComponent && HardcodedFwComponent) || - (hardcodedJsFunction && HardcodedFwComponent)) { - throw Error("ag-grid: you are trying to specify: " + propertyName + " twice as a component."); - } - if (HardcodedFwComponent && !this.frameworkComponentWrapper) { - throw Error("ag-grid: you are specifying a framework component but you are not using a framework version of ag-grid for : " + propertyName); - } - if (componentSelectorFunc && (hardcodedNameComponent || HardcodedJsComponent || hardcodedJsFunction || HardcodedFwComponent)) { - throw Error("ag-grid: you can't specify both, the selector and the component of ag-grid for : " + propertyName); - } - /** - * At this stage we are guaranteed to either have, - * DEPRECATED - * - A unique HardcodedFwComponent - * - A unique HardcodedJsComponent - * - A unique hardcodedJsFunction - * BY NAME- FAVOURED APPROACH - * - A unique hardcodedNameComponent - * - None of the previous, hence we revert to: RegisteredComponent - */ - if (HardcodedFwComponent) { - // console.warn(`ag-grid: Since version 12.1.0 specifying a component directly is deprecated, you should register the component by name`); - // console.warn(`${HardcodedFwComponent}`); - return { - componentFromFramework: true, - component: HardcodedFwComponent, - source: ComponentSource.HARDCODED, - paramsFromSelector: null - }; - } - if (HardcodedJsComponent) { - // console.warn(`ag-grid: Since version 12.1.0 specifying a component directly is deprecated, you should register the component by name`); - // console.warn(`${HardcodedJsComponent}`); - return { - componentFromFramework: false, - component: HardcodedJsComponent, - source: ComponentSource.HARDCODED, - paramsFromSelector: null - }; - } - if (hardcodedJsFunction) { - // console.warn(`ag-grid: Since version 12.1.0 specifying a function directly is deprecated, you should register the component by name`); - // console.warn(`${hardcodedJsFunction}`); - return this.agComponentUtils.adaptFunction(propertyName, hardcodedJsFunction, false, ComponentSource.HARDCODED); - } - var selectorResult = componentSelectorFunc ? componentSelectorFunc(params) : null; - var componentNameToUse; - if (selectorResult && selectorResult.component) { - componentNameToUse = selectorResult.component; - } - else if (hardcodedNameComponent) { - componentNameToUse = hardcodedNameComponent; - } - else { - componentNameToUse = defaultComponentName; - } - if (!componentNameToUse) { - return null; - } - var registeredCompClassDef = this.lookupFromRegisteredComponents(propertyName, componentNameToUse); - if (!registeredCompClassDef) { - return null; + res.list.push(cellCtrl); + res.map[cellCtrl.getInstanceId()] = cellCtrl; + }); + return res; + }; + RowCtrl.prototype.onMouseEvent = function (eventName, mouseEvent) { + switch (eventName) { + case 'dblclick': + this.onRowDblClick(mouseEvent); + break; + case 'click': + this.onRowClick(mouseEvent); + break; + case 'touchstart': + case 'mousedown': + this.onRowMouseDown(mouseEvent); + break; } + }; + RowCtrl.prototype.createRowEvent = function (type, domEvent) { return { - componentFromFramework: registeredCompClassDef.componentFromFramework, - component: registeredCompClassDef.component, - source: registeredCompClassDef.source, - paramsFromSelector: selectorResult ? selectorResult.params : null + type: type, + node: this.rowNode, + data: this.rowNode.data, + rowIndex: this.rowNode.rowIndex, + rowPinned: this.rowNode.rowPinned, + context: this.beans.gridOptionsWrapper.getContext(), + api: this.beans.gridOptionsWrapper.getApi(), + columnApi: this.beans.gridOptionsWrapper.getColumnApi(), + event: domEvent }; }; - UserComponentFactory.prototype.lookupFromRegisteredComponents = function (propertyName, componentNameOpt) { - var componentName = componentNameOpt != null ? componentNameOpt : propertyName; - var registeredComponent = this.userComponentRegistry.retrieve(componentName); - if (registeredComponent == null) { - return null; - } - //If it is a FW it has to be registered as a component - if (registeredComponent.componentFromFramework) { - return { - component: registeredComponent.component, - componentFromFramework: true, - source: ComponentSource.REGISTERED_BY_NAME, - paramsFromSelector: null - }; + RowCtrl.prototype.createRowEventWithSource = function (type, domEvent) { + var event = this.createRowEvent(type, domEvent); + // when first developing this, we included the rowComp in the event. + // this seems very weird. so when introducing the event types, i left the 'source' + // out of the type, and just include the source in the two places where this event + // was fired (rowClicked and rowDoubleClicked). it doesn't make sense for any + // users to be using this, as the rowComp isn't an object we expose, so would be + // very surprising if a user was using it. + event.source = this; + return event; + }; + RowCtrl.prototype.onRowDblClick = function (mouseEvent) { + if (Object(_utils_event__WEBPACK_IMPORTED_MODULE_7__["isStopPropagationForAgGrid"])(mouseEvent)) { + return; } - //If it is JS it may be a function or a component - if (this.agComponentUtils.doesImplementIComponent(registeredComponent.component)) { - return { - component: registeredComponent.component, - componentFromFramework: false, - source: (registeredComponent.source == _userComponentRegistry__WEBPACK_IMPORTED_MODULE_1__["RegisteredComponentSource"].REGISTERED) ? ComponentSource.REGISTERED_BY_NAME : ComponentSource.DEFAULT, - paramsFromSelector: null - }; + var agEvent = this.createRowEventWithSource(_events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_ROW_DOUBLE_CLICKED, mouseEvent); + this.beans.eventService.dispatchEvent(agEvent); + }; + RowCtrl.prototype.onRowMouseDown = function (mouseEvent) { + this.lastMouseDownOnDragger = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["isElementChildOfClass"])(mouseEvent.target, 'ag-row-drag', 3); + if (!this.isFullWidth()) { + return; } - // This is a function - return this.agComponentUtils.adaptFunction(propertyName, registeredComponent.component, registeredComponent.componentFromFramework, (registeredComponent.source == _userComponentRegistry__WEBPACK_IMPORTED_MODULE_1__["RegisteredComponentSource"].REGISTERED) ? ComponentSource.REGISTERED_BY_NAME : ComponentSource.DEFAULT); + var node = this.rowNode; + var columnModel = this.beans.columnModel; + this.beans.focusService.setFocusedCell(node.rowIndex, columnModel.getAllDisplayedColumns()[0], node.rowPinned, true); }; - /** - * Useful to check what would be the resultant params for a given object - * @param definitionObject: This is the context for which this component needs to be created, it can be gridOptions - * (global) or columnDef mostly. - * @param propertyName: The name of the property used in ag-grid as a convention to refer to the component, it can be: - * 'floatingFilter', 'cellRenderer', is used to find if the user is specifying a custom component - * @param paramsFromGrid: Params to be passed to the component and passed by ag-Grid. This will get merged with any params - * specified by the user in the configuration - * @returns {TParams} It merges the user agGridParams with the actual params specified by the user. - */ - UserComponentFactory.prototype.createFinalParams = function (definitionObject, propertyName, paramsFromGrid, paramsFromSelector) { - if (paramsFromSelector === void 0) { paramsFromSelector = null; } - var params = {}; - Object(_utils_object__WEBPACK_IMPORTED_MODULE_5__["mergeDeep"])(params, paramsFromGrid); - var userParams = definitionObject ? definitionObject[propertyName + "Params"] : null; - if (userParams != null) { - if (typeof userParams === 'function') { - Object(_utils_object__WEBPACK_IMPORTED_MODULE_5__["mergeDeep"])(params, userParams(paramsFromGrid)); + RowCtrl.prototype.onRowClick = function (mouseEvent) { + var stop = Object(_utils_event__WEBPACK_IMPORTED_MODULE_7__["isStopPropagationForAgGrid"])(mouseEvent) || this.lastMouseDownOnDragger; + if (stop) { + return; + } + var agEvent = this.createRowEventWithSource(_events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_ROW_CLICKED, mouseEvent); + this.beans.eventService.dispatchEvent(agEvent); + // ctrlKey for windows, metaKey for Apple + var multiSelectKeyPressed = mouseEvent.ctrlKey || mouseEvent.metaKey; + var shiftKeyPressed = mouseEvent.shiftKey; + // we do not allow selecting the group by clicking, when groupSelectChildren, as the logic to + // handle this is broken. to observe, change the logic below and allow groups to be selected. + // you will see the group gets selected, then all children get selected, then the grid unselects + // the children (as the default behaviour when clicking is to unselect other rows) which results + // in the group getting unselected (as all children are unselected). the correct thing would be + // to change this, so that children of the selected group are not then subsequenly un-selected. + var groupSelectsChildren = this.beans.gridOptionsWrapper.isGroupSelectsChildren(); + if ( + // we do not allow selecting groups by clicking (as the click here expands the group), or if it's a detail row, + // so return if it's a group row + (groupSelectsChildren && this.rowNode.group) || + // this is needed so we don't unselect other rows when we click this row, eg if this row is not selectable, + // and we click it, the selection should not change (ie any currently selected row should stay selected) + !this.rowNode.selectable || + // we also don't allow selection of pinned rows + this.rowNode.rowPinned || + // if no selection method enabled, do nothing + !this.beans.gridOptionsWrapper.isRowSelection() || + // if click selection suppressed, do nothing + this.beans.gridOptionsWrapper.isSuppressRowClickSelection()) { + return; + } + var multiSelectOnClick = this.beans.gridOptionsWrapper.isRowMultiSelectWithClick(); + var rowDeselectionWithCtrl = !this.beans.gridOptionsWrapper.isSuppressRowDeselection(); + if (this.rowNode.isSelected()) { + if (multiSelectOnClick) { + this.rowNode.setSelectedParams({ newValue: false }); } - else if (typeof userParams === 'object') { - Object(_utils_object__WEBPACK_IMPORTED_MODULE_5__["mergeDeep"])(params, userParams); + else if (multiSelectKeyPressed) { + if (rowDeselectionWithCtrl) { + this.rowNode.setSelectedParams({ newValue: false }); + } } - } - Object(_utils_object__WEBPACK_IMPORTED_MODULE_5__["mergeDeep"])(params, paramsFromSelector); - return params; - }; - UserComponentFactory.prototype.createComponentInstance = function (holder, componentType, paramsForSelector, defaultComponentName, optional) { - var propertyName = componentType.propertyName; - var componentToUse = this.lookupComponentClassDef(holder, propertyName, paramsForSelector, defaultComponentName); - var missing = !componentToUse || !componentToUse.component; - if (missing) { - // to help the user, we print out the name they are looking for, rather than the default name. - // i don't know why the default name was originally printed out (that doesn't help the user) - var overrideName = holder ? holder[propertyName] : defaultComponentName; - var nameToReport = overrideName ? overrideName : defaultComponentName; - if (!optional) { - console.error("Could not find component " + nameToReport + ", did you forget to configure this component?"); + else { + // selected with no multi key, must make sure anything else is unselected + this.rowNode.setSelectedParams({ newValue: !shiftKeyPressed, clearSelection: !shiftKeyPressed, rangeSelect: shiftKeyPressed }); } - return null; - } - var componentInstance; - if (componentToUse.componentFromFramework) { - // Using framework component - var FrameworkComponentRaw = componentToUse.component; - var thisComponentConfig = this.componentMetadataProvider.retrieve(propertyName); - componentInstance = this.frameworkComponentWrapper.wrap(FrameworkComponentRaw, thisComponentConfig.mandatoryMethodList, thisComponentConfig.optionalMethodList, componentType, defaultComponentName); } else { - // Using plain JavaScript component - componentInstance = new componentToUse.component(); + var clearSelection = multiSelectOnClick ? false : !multiSelectKeyPressed; + this.rowNode.setSelectedParams({ newValue: true, clearSelection: clearSelection, rangeSelect: shiftKeyPressed }); } - return { componentInstance: componentInstance, paramsFromSelector: componentToUse.paramsFromSelector }; }; - UserComponentFactory.prototype.initComponent = function (component, params) { - this.context.createBean(component); - if (component.init == null) { + RowCtrl.prototype.setupDetailRowAutoHeight = function (eDetailGui) { + var _this = this; + if (this.rowType !== RowType.FullWidthDetail) { return; } - return component.init(params); - }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("gridOptions") - ], UserComponentFactory.prototype, "gridOptions", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("agComponentUtils") - ], UserComponentFactory.prototype, "agComponentUtils", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("componentMetadataProvider") - ], UserComponentFactory.prototype, "componentMetadataProvider", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("userComponentRegistry") - ], UserComponentFactory.prototype, "userComponentRegistry", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])("frameworkComponentWrapper") - ], UserComponentFactory.prototype, "frameworkComponentWrapper", void 0); - UserComponentFactory = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('userComponentFactory') - ], UserComponentFactory); - return UserComponentFactory; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_4__["BeanStub"])); - - - -/***/ }), -/* 75 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DateComponent", function() { return DateComponent; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderComponent", function() { return HeaderComponent; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderGroupComponent", function() { return HeaderGroupComponent; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GroupRowInnerRendererComponent", function() { return GroupRowInnerRendererComponent; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellRendererComponent", function() { return CellRendererComponent; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PinnedRowCellRendererComponent", function() { return PinnedRowCellRendererComponent; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellEditorComponent", function() { return CellEditorComponent; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "InnerRendererComponent", function() { return InnerRendererComponent; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LoadingOverlayComponent", function() { return LoadingOverlayComponent; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NoRowsOverlayComponent", function() { return NoRowsOverlayComponent; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TooltipComponent", function() { return TooltipComponent; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FilterComponent", function() { return FilterComponent; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FloatingFilterComponent", function() { return FloatingFilterComponent; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ToolPanelComponent", function() { return ToolPanelComponent; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "StatusPanelComponent", function() { return StatusPanelComponent; }); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var DateComponent = { - propertyName: 'dateComponent', - isCellRenderer: function () { return false; } -}; -var HeaderComponent = { - propertyName: 'headerComponent', - isCellRenderer: function () { return false; }, -}; -var HeaderGroupComponent = { - propertyName: 'headerGroupComponent', - isCellRenderer: function () { return false; }, -}; -var GroupRowInnerRendererComponent = { - propertyName: 'groupRowInnerRenderer', - isCellRenderer: function () { return true; }, -}; -var CellRendererComponent = { - propertyName: 'cellRenderer', - isCellRenderer: function () { return true; }, -}; -var PinnedRowCellRendererComponent = { - propertyName: 'pinnedRowCellRenderer', - isCellRenderer: function () { return true; }, -}; -var CellEditorComponent = { - propertyName: 'cellEditor', - isCellRenderer: function () { return false; }, -}; -var InnerRendererComponent = { - propertyName: 'innerRenderer', - isCellRenderer: function () { return true; }, -}; -var LoadingOverlayComponent = { - propertyName: 'loadingOverlayComponent', - isCellRenderer: function () { return false; }, -}; -var NoRowsOverlayComponent = { - propertyName: 'noRowsOverlayComponent', - isCellRenderer: function () { return false; }, -}; -var TooltipComponent = { - propertyName: 'tooltipComponent', - isCellRenderer: function () { return false; }, -}; -var FilterComponent = { - propertyName: 'filter', - isCellRenderer: function () { return false; }, -}; -var FloatingFilterComponent = { - propertyName: 'floatingFilterComponent', - isCellRenderer: function () { return false; }, -}; -var ToolPanelComponent = { - propertyName: 'toolPanel', - isCellRenderer: function () { return false; }, -}; -var StatusPanelComponent = { - propertyName: 'statusPanel', - isCellRenderer: function () { return false; }, -}; - - -/***/ }), -/* 76 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AnimateShowChangeCellRenderer", function() { return AnimateShowChangeCellRenderer; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - -var ARROW_UP = '\u2191'; -var ARROW_DOWN = '\u2193'; -var AnimateShowChangeCellRenderer = /** @class */ (function (_super) { - __extends(AnimateShowChangeCellRenderer, _super); - function AnimateShowChangeCellRenderer() { - var _this = _super.call(this, AnimateShowChangeCellRenderer.TEMPLATE) || this; - _this.refreshCount = 0; - return _this; - } - AnimateShowChangeCellRenderer.prototype.init = function (params) { - // this.params = params; - this.eValue = this.queryForHtmlElement('.ag-value-change-value'); - this.eDelta = this.queryForHtmlElement('.ag-value-change-delta'); - this.refresh(params); - }; - AnimateShowChangeCellRenderer.prototype.showDelta = function (params, delta) { - var absDelta = Math.abs(delta); - var valueFormatted = params.formatValue(absDelta); - var valueToUse = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(valueFormatted) ? valueFormatted : absDelta; - var deltaUp = (delta >= 0); - if (deltaUp) { - this.eDelta.innerHTML = ARROW_UP + valueToUse; - } - else { - // because negative, use ABS to remove sign - this.eDelta.innerHTML = ARROW_DOWN + valueToUse; + if (!this.beans.gridOptionsWrapper.isDetailRowAutoHeight()) { + return; } - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(this.eDelta, 'ag-value-change-delta-up', deltaUp); - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(this.eDelta, 'ag-value-change-delta-down', !deltaUp); - }; - AnimateShowChangeCellRenderer.prototype.setTimerToRemoveDelta = function () { - var _this = this; - // the refreshCount makes sure that if the value updates again while - // the below timer is waiting, then the below timer will realise it - // is not the most recent and will not try to remove the delta value. - this.refreshCount++; - var refreshCountCopy = this.refreshCount; - window.setTimeout(function () { - if (refreshCountCopy === _this.refreshCount) { - _this.hideDeltaValue(); + var checkRowSizeFunc = function () { + var clientHeight = eDetailGui.clientHeight; + // if the UI is not ready, the height can be 0, which we ignore, as otherwise a flicker will occur + // as UI goes from the default height, to 0, then to the real height as UI becomes ready. this means + // it's not possible for have 0 as auto-height, however this is an improbable use case, as even an + // empty detail grid would still have some styling around it giving at least a few pixels. + if (clientHeight != null && clientHeight > 0) { + // we do the update in a timeout, to make sure we are not calling from inside the grid + // doing another update + var updateRowHeightFunc = function () { + _this.rowNode.setRowHeight(clientHeight); + if (_this.beans.clientSideRowModel) { + _this.beans.clientSideRowModel.onRowHeightChanged(); + } + else if (_this.beans.serverSideRowModel) { + _this.beans.serverSideRowModel.onRowHeightChanged(); + } + }; + _this.beans.frameworkOverrides.setTimeout(updateRowHeightFunc, 0); } - }, 2000); + }; + var resizeObserverDestroyFunc = this.beans.resizeObserverService.observeResize(eDetailGui, checkRowSizeFunc); + this.addDestroyFunc(resizeObserverDestroyFunc); + checkRowSizeFunc(); }; - AnimateShowChangeCellRenderer.prototype.hideDeltaValue = function () { - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].removeCssClass(this.eValue, 'ag-value-change-value-highlight'); - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].clearElement(this.eDelta); + RowCtrl.prototype.createFullWidthParams = function (eRow, pinned) { + var _this = this; + var params = { + fullWidth: true, + data: this.rowNode.data, + node: this.rowNode, + value: this.rowNode.key, + valueFormatted: this.rowNode.key, + $scope: this.scope ? this.scope : this.parentScope, + $compile: this.beans.$compile, + rowIndex: this.rowNode.rowIndex, + api: this.beans.gridOptionsWrapper.getApi(), + columnApi: this.beans.gridOptionsWrapper.getColumnApi(), + context: this.beans.gridOptionsWrapper.getContext(), + // these need to be taken out, as part of 'afterAttached' now + eGridCell: eRow, + eParentOfValue: eRow, + pinned: pinned, + addRenderedRowListener: this.addEventListener.bind(this), + registerRowDragger: function (rowDraggerElement, dragStartPixels, value, suppressVisibilityChange) { return _this.addFullWidthRowDragging(rowDraggerElement, dragStartPixels, value, suppressVisibilityChange); } + }; + return params; }; - AnimateShowChangeCellRenderer.prototype.refresh = function (params) { - var value = params.value; - if (value === this.lastValue) { - return; - } - if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(params.valueFormatted)) { - this.eValue.innerHTML = params.valueFormatted; - } - else if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(params.value)) { - this.eValue.innerHTML = value; - } - else { - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].clearElement(this.eValue); - } - // we don't show the delta if we are in the middle of a filter. see comment on FilterManager - // with regards processingFilterChange - if (this.filterManager.isSuppressFlashingCellsBecauseFiltering()) { + RowCtrl.prototype.addFullWidthRowDragging = function (rowDraggerElement, dragStartPixels, value, suppressVisibilityChange) { + if (value === void 0) { value = ''; } + if (!this.isFullWidth()) { return; } - if (typeof value === 'number' && typeof this.lastValue === 'number') { - var delta = value - this.lastValue; - this.showDelta(params, delta); - } - // highlight the current value, but only if it's not new, otherwise it - // would get highlighted first time the value is shown - if (this.lastValue) { - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(this.eValue, 'ag-value-change-value-highlight'); + var rowDragComp = new _rowDragComp__WEBPACK_IMPORTED_MODULE_13__["RowDragComp"](function () { return value; }, this.rowNode, undefined, rowDraggerElement, dragStartPixels, suppressVisibilityChange); + this.createManagedBean(rowDragComp, this.beans.context); + }; + RowCtrl.prototype.onUiLevelChanged = function () { + var newLevel = this.beans.rowCssClassCalculator.calculateRowLevel(this.rowNode); + if (this.rowLevel != newLevel) { + var classToAdd_1 = 'ag-row-level-' + newLevel; + var classToRemove_1 = 'ag-row-level-' + this.rowLevel; + this.allRowGuis.forEach(function (gui) { + gui.rowComp.addOrRemoveCssClass(classToAdd_1, true); + gui.rowComp.addOrRemoveCssClass(classToRemove_1, false); + }); } - this.setTimerToRemoveDelta(); - this.lastValue = value; - return true; + this.rowLevel = newLevel; }; - AnimateShowChangeCellRenderer.TEMPLATE = '' + - '' + - '' + - ''; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager') - ], AnimateShowChangeCellRenderer.prototype, "filterManager", void 0); - return AnimateShowChangeCellRenderer; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_1__["Component"])); - - - -/***/ }), -/* 77 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AnimateSlideCellRenderer", function() { return AnimateSlideCellRenderer; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + RowCtrl.prototype.isFirstRowOnPage = function () { + return this.rowNode.rowIndex === this.beans.paginationProxy.getPageFirstRow(); + }; + RowCtrl.prototype.isLastRowOnPage = function () { + return this.rowNode.rowIndex === this.beans.paginationProxy.getPageLastRow(); + }; + RowCtrl.prototype.onModelUpdated = function () { + this.refreshFirstAndLastRowStyles(); + }; + RowCtrl.prototype.refreshFirstAndLastRowStyles = function () { + var newFirst = this.isFirstRowOnPage(); + var newLast = this.isLastRowOnPage(); + if (this.firstRowOnPage !== newFirst) { + this.firstRowOnPage = newFirst; + this.allRowGuis.forEach(function (gui) { return gui.rowComp.addOrRemoveCssClass('ag-row-first', newFirst); }); + } + if (this.lastRowOnPage !== newLast) { + this.lastRowOnPage = newLast; + this.allRowGuis.forEach(function (gui) { return gui.rowComp.addOrRemoveCssClass('ag-row-last', newLast); }); + } }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + RowCtrl.prototype.stopEditing = function (cancel) { + if (cancel === void 0) { cancel = false; } + this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.stopEditing(cancel); }); + if (!this.editingRow) { + return; + } + if (!cancel) { + var event_1 = this.createRowEvent(_events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_ROW_VALUE_CHANGED); + this.beans.eventService.dispatchEvent(event_1); + } + this.setEditingRow(false); }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - -var AnimateSlideCellRenderer = /** @class */ (function (_super) { - __extends(AnimateSlideCellRenderer, _super); - function AnimateSlideCellRenderer() { - var _this = _super.call(this, AnimateSlideCellRenderer.TEMPLATE) || this; - _this.refreshCount = 0; - _this.eCurrent = _this.queryForHtmlElement('.ag-value-slide-current'); - return _this; - } - AnimateSlideCellRenderer.prototype.init = function (params) { - this.params = params; - this.refresh(params); + RowCtrl.prototype.setInlineEditingCss = function (editing) { + this.allRowGuis.forEach(function (gui) { + gui.rowComp.addOrRemoveCssClass("ag-row-inline-editing", editing); + gui.rowComp.addOrRemoveCssClass("ag-row-not-inline-editing", !editing); + }); }; - AnimateSlideCellRenderer.prototype.addSlideAnimation = function () { - var _this = this; - this.refreshCount++; - // below we keep checking this, and stop working on the animation - // if it no longer matches - this means another animation has started - // and this one is stale. - var refreshCountCopy = this.refreshCount; - // if old animation, remove it - if (this.ePrevious) { - this.getGui().removeChild(this.ePrevious); + RowCtrl.prototype.setEditingRow = function (value) { + this.editingRow = value; + this.allRowGuis.forEach(function (gui) { return gui.rowComp.addOrRemoveCssClass('ag-row-editing', value); }); + var event = value ? + this.createRowEvent(_events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_ROW_EDITING_STARTED) + : this.createRowEvent(_events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_ROW_EDITING_STOPPED); + this.beans.eventService.dispatchEvent(event); + }; + RowCtrl.prototype.startRowEditing = function (key, charPress, sourceRenderedCell, event) { + if (key === void 0) { key = null; } + if (charPress === void 0) { charPress = null; } + if (sourceRenderedCell === void 0) { sourceRenderedCell = null; } + if (event === void 0) { event = null; } + // don't do it if already editing + if (this.editingRow) { + return; } - this.ePrevious = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].loadTemplate(''); - this.ePrevious.innerHTML = this.eCurrent.innerHTML; - this.getGui().insertBefore(this.ePrevious, this.eCurrent); - // having timeout of 0 allows use to skip to the next css turn, - // so we know the previous css classes have been applied. so the - // complex set of setTimeout below creates the animation - window.setTimeout(function () { - if (refreshCountCopy !== _this.refreshCount) { - return; + this.getAllCellCtrls().forEach(function (cellCtrl) { + var cellStartedEdit = cellCtrl === sourceRenderedCell; + if (cellStartedEdit) { + cellCtrl.startEditing(key, charPress, cellStartedEdit, event); } - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(_this.ePrevious, 'ag-value-slide-out-end'); - }, 50); - window.setTimeout(function () { - if (refreshCountCopy !== _this.refreshCount) { - return; + else { + cellCtrl.startEditing(null, null, cellStartedEdit, event); } - _this.getGui().removeChild(_this.ePrevious); - _this.ePrevious = null; - }, 3000); + }); + this.setEditingRow(true); }; - AnimateSlideCellRenderer.prototype.refresh = function (params) { - var value = params.value; - if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].missing(value)) { - value = ''; - } - if (value === this.lastValue) { + RowCtrl.prototype.getAllCellCtrls = function () { + var res = __spread(this.centerCellCtrls.list, this.leftCellCtrls.list, this.rightCellCtrls.list); + return res; + }; + RowCtrl.prototype.postProcessClassesFromGridOptions = function () { + var _this = this; + var cssClasses = this.beans.rowCssClassCalculator.processClassesFromGridOptions(this.rowNode, this.scope); + if (!cssClasses || !cssClasses.length) { return; } - // we don't show the delta if we are in the middle of a filter. see comment on FilterManager - // with regards processingFilterChange - if (this.filterManager.isSuppressFlashingCellsBecauseFiltering()) { + cssClasses.forEach(function (classStr) { + _this.allRowGuis.forEach(function (c) { return c.rowComp.addOrRemoveCssClass(classStr, true); }); + }); + }; + RowCtrl.prototype.postProcessRowClassRules = function () { + var _this = this; + this.beans.rowCssClassCalculator.processRowClassRules(this.rowNode, this.scope, function (className) { + _this.allRowGuis.forEach(function (gui) { return gui.rowComp.addOrRemoveCssClass(className, true); }); + }, function (className) { + _this.allRowGuis.forEach(function (gui) { return gui.rowComp.addOrRemoveCssClass(className, false); }); + }); + }; + RowCtrl.prototype.setStylesFromGridOptions = function () { + var rowStyles = this.processStylesFromGridOptions(); + this.allRowGuis.forEach(function (gui) { return gui.rowComp.setUserStyles(rowStyles); }); + }; + RowCtrl.prototype.getRowBusinessKey = function () { + var businessKeyForNodeFunc = this.beans.gridOptionsWrapper.getBusinessKeyForNodeFunc(); + if (typeof businessKeyForNodeFunc !== 'function') { return; } - this.addSlideAnimation(); - this.lastValue = value; - if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(params.valueFormatted)) { - this.eCurrent.innerHTML = params.valueFormatted; - } - else if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(params.value)) { - this.eCurrent.innerHTML = value; + return businessKeyForNodeFunc(this.rowNode); + }; + RowCtrl.prototype.getPinnedForContainer = function (rowContainerType) { + var pinned = rowContainerType === _gridBodyComp_rowContainer_rowContainerCtrl__WEBPACK_IMPORTED_MODULE_14__["RowContainerType"].LEFT ? _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_LEFT : + rowContainerType === _gridBodyComp_rowContainer_rowContainerCtrl__WEBPACK_IMPORTED_MODULE_14__["RowContainerType"].RIGHT ? _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_RIGHT : null; + return pinned; + }; + RowCtrl.prototype.getInitialRowClasses = function (rowContainerType) { + var pinned = this.getPinnedForContainer(rowContainerType); + var params = { + rowNode: this.rowNode, + rowFocused: this.rowFocused, + fadeRowIn: this.fadeRowIn, + rowIsEven: this.rowNode.rowIndex % 2 === 0, + rowLevel: this.rowLevel, + fullWidthRow: this.isFullWidth(), + firstRowOnPage: this.isFirstRowOnPage(), + lastRowOnPage: this.isLastRowOnPage(), + printLayout: this.printLayout, + expandable: this.rowNode.isExpandable(), + scope: this.scope, + pinned: pinned + }; + return this.beans.rowCssClassCalculator.getInitialRowClasses(params); + }; + RowCtrl.prototype.processStylesFromGridOptions = function () { + // part 1 - rowStyle + var rowStyle = this.beans.gridOptionsWrapper.getRowStyle(); + if (rowStyle && typeof rowStyle === 'function') { + console.warn('AG Grid: rowStyle should be an object of key/value styles, not be a function, use getRowStyle() instead'); + return; } - else { - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].clearElement(this.eCurrent); + // part 1 - rowStyleFunc + var rowStyleFunc = this.beans.gridOptionsWrapper.getRowStyleFunc(); + var rowStyleFuncResult; + if (rowStyleFunc) { + var params = { + data: this.rowNode.data, + node: this.rowNode, + rowIndex: this.rowNode.rowIndex, + $scope: this.scope, + api: this.beans.gridOptionsWrapper.getApi(), + columnApi: this.beans.gridOptionsWrapper.getColumnApi(), + context: this.beans.gridOptionsWrapper.getContext() + }; + rowStyleFuncResult = rowStyleFunc(params); } - return true; + return Object.assign({}, rowStyle, rowStyleFuncResult); }; - AnimateSlideCellRenderer.TEMPLATE = '' + - '' + - ''; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager') - ], AnimateSlideCellRenderer.prototype, "filterManager", void 0); - return AnimateSlideCellRenderer; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_1__["Component"])); - - - -/***/ }), -/* 78 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LoadingCellRenderer", function() { return LoadingCellRenderer; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + RowCtrl.prototype.onRowSelected = function () { + var _this = this; + var selected = this.rowNode.isSelected(); + this.allRowGuis.forEach(function (gui) { + gui.rowComp.addOrRemoveCssClass('ag-row-selected', selected); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_15__["setAriaSelected"])(gui.element, selected ? true : undefined); + var ariaLabel = _this.createAriaLabel(); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_15__["setAriaLabel"])(gui.element, ariaLabel == null ? '' : ariaLabel); + }); }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + RowCtrl.prototype.createAriaLabel = function () { + var selected = this.rowNode.isSelected(); + if (selected && this.beans.gridOptionsWrapper.isSuppressRowDeselection()) { + return undefined; + } + var translate = this.beans.gridOptionsWrapper.getLocaleTextFunc(); + var label = translate(selected ? 'ariaRowDeselect' : 'ariaRowSelect', "Press SPACE to " + (selected ? 'deselect' : 'select') + " this row."); + return label; }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - -var LoadingCellRenderer = /** @class */ (function (_super) { - __extends(LoadingCellRenderer, _super); - function LoadingCellRenderer() { - return _super.call(this, LoadingCellRenderer.TEMPLATE) || this; - } - LoadingCellRenderer.prototype.init = function (params) { - var eLoadingIcon = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].createIconNoSpan('groupLoading', this.gridOptionsWrapper, null); - this.eLoadingIcon.appendChild(eLoadingIcon); - var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc(); - this.eLoadingText.innerText = localeTextFunc('loadingOoo', 'Loading'); + RowCtrl.prototype.isUseAnimationFrameForCreate = function () { + return this.useAnimationFrameForCreate; }; - LoadingCellRenderer.prototype.refresh = function (params) { - return false; + RowCtrl.prototype.addHoverFunctionality = function (eRow) { + var _this = this; + // because we use animation frames to do this, it's possible the row no longer exists + // by the time we get to add it + if (!this.active) { + return; + } + // because mouseenter and mouseleave do not propagate, we cannot listen on the gridPanel + // like we do for all the other mouse events. + // because of the pinning, we cannot simply add / remove the class based on the eRow. we + // have to check all eRow's (body & pinned). so the trick is if any of the rows gets a + // mouse hover, it sets such in the rowNode, and then all three reflect the change as + // all are listening for event on the row node. + // step 1 - add listener, to set flag on row node + this.addManagedListener(eRow, 'mouseenter', function () { return _this.rowNode.onMouseEnter(); }); + this.addManagedListener(eRow, 'mouseleave', function () { return _this.rowNode.onMouseLeave(); }); + // step 2 - listen for changes on row node (which any eRow can trigger) + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_MOUSE_ENTER, function () { + // if hover turned off, we don't add the class. we do this here so that if the application + // toggles this property mid way, we remove the hover form the last row, but we stop + // adding hovers from that point onwards. + if (!_this.beans.gridOptionsWrapper.isSuppressRowHoverHighlight()) { + eRow.classList.add('ag-row-hover'); + } + }); + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_MOUSE_LEAVE, function () { + eRow.classList.remove('ag-row-hover'); + }); }; - LoadingCellRenderer.TEMPLATE = "
\n \n \n
"; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], LoadingCellRenderer.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('eLoadingIcon') - ], LoadingCellRenderer.prototype, "eLoadingIcon", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('eLoadingText') - ], LoadingCellRenderer.prototype, "eLoadingText", void 0); - return LoadingCellRenderer; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_1__["Component"])); - - - -/***/ }), -/* 79 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SelectCellEditor", function() { return SelectCellEditor; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(55); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + // for animation, we don't want to animate entry or exit to a very far away pixel, + // otherwise the row would move so fast, it would appear to disappear. so this method + // moves the row closer to the viewport if it is far away, so the row slide in / out + // at a speed the user can see. + RowCtrl.prototype.roundRowTopToBounds = function (rowTop) { + var gridBodyCon = this.beans.ctrlsService.getGridBodyCtrl(); + var range = gridBodyCon.getScrollFeature().getVScrollPosition(); + var minPixel = this.applyPaginationOffset(range.top, true) - 100; + var maxPixel = this.applyPaginationOffset(range.bottom, true) + 100; + return Math.min(Math.max(minPixel, rowTop), maxPixel); }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + RowCtrl.prototype.getFrameworkOverrides = function () { + return this.beans.frameworkOverrides; }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - -var SelectCellEditor = /** @class */ (function (_super) { - __extends(SelectCellEditor, _super); - function SelectCellEditor() { - return _super.call(this, '
') || this; - } - SelectCellEditor.prototype.init = function (params) { - var _this = this; - this.focusAfterAttached = params.cellStartedEdit; - if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].missing(params.values)) { - console.warn('ag-Grid: no values found for select cellEditor'); + RowCtrl.prototype.onRowHeightChanged = function () { + // check for exists first - if the user is resetting the row height, then + // it will be null (or undefined) momentarily until the next time the flatten + // stage is called where the row will then update again with a new height + if (this.rowNode.rowHeight == null) { return; } - params.values.forEach(function (value) { - var option = { value: value }; - var valueFormatted = _this.valueFormatterService.formatValue(params.column, null, null, value); - var valueFormattedExits = valueFormatted !== null && valueFormatted !== undefined; - option.text = valueFormattedExits ? valueFormatted : value; - _this.eSelect.addOption(option); + var fromFunction = this.beans.gridOptionsWrapper.isGetRowHeightFunction(); + var rowHeight = this.rowNode.rowHeight; + var defaultRowHeight = this.beans.gridOptionsWrapper.getDefaultRowHeight(); + this.allRowGuis.forEach(function (gui) { + gui.element.style.height = rowHeight + "px"; + if (fromFunction) { + gui.element.style.setProperty('--ag-row-height', Math.min(defaultRowHeight, rowHeight) - 2 + "px"); + } }); - this.eSelect.setValue(params.value, true); - // we don't want to add this if full row editing, otherwise selecting will stop the - // full row editing. - if (!this.gridOptionsWrapper.isFullRowEdit()) { - this.eSelect.onValueChange(function () { return params.stopEditing(); }); + }; + RowCtrl.prototype.addEventListener = function (eventType, listener) { + if (eventType === 'renderedRowRemoved' || eventType === 'rowRemoved') { + eventType = _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_VIRTUAL_ROW_REMOVED; + console.warn('AG Grid: Since version 11, event renderedRowRemoved is now called ' + _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_VIRTUAL_ROW_REMOVED); } + _super.prototype.addEventListener.call(this, eventType, listener); }; - SelectCellEditor.prototype.afterGuiAttached = function () { - if (this.focusAfterAttached) { - this.eSelect.getFocusableElement().focus(); + RowCtrl.prototype.removeEventListener = function (eventType, listener) { + if (eventType === 'renderedRowRemoved' || eventType === 'rowRemoved') { + eventType = _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_VIRTUAL_ROW_REMOVED; + console.warn('AG Grid: Since version 11, event renderedRowRemoved and rowRemoved is now called ' + _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_VIRTUAL_ROW_REMOVED); } + _super.prototype.removeEventListener.call(this, eventType, listener); }; - SelectCellEditor.prototype.focusIn = function () { - this.eSelect.getFocusableElement().focus(); + // note - this is NOT called by context, as we don't wire / unwire the CellComp for performance reasons. + RowCtrl.prototype.destroyFirstPass = function () { + this.active = false; + // why do we have this method? shouldn't everything below be added as a destroy func beside + // the corresponding create logic? + this.setupRemoveAnimation(); + var event = this.createRowEvent(_events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_VIRTUAL_ROW_REMOVED); + this.dispatchEvent(event); + this.beans.eventService.dispatchEvent(event); + _super.prototype.destroy.call(this); }; - SelectCellEditor.prototype.getValue = function () { - return this.eSelect.getValue(); + RowCtrl.prototype.setupRemoveAnimation = function () { + var rowStillVisibleJustNotInViewport = this.rowNode.rowTop != null; + if (rowStillVisibleJustNotInViewport) { + // if the row is not rendered, but in viewport, it means it has moved, + // so we animate the row out. if the new location is very far away, + // the animation will be so fast the row will look like it's just disappeared, + // so instead we animate to a position just outside the viewport. + var rowTop = this.roundRowTopToBounds(this.rowNode.rowTop); + this.setRowTop(rowTop); + } + else { + this.allRowGuis.forEach(function (gui) { return gui.rowComp.addOrRemoveCssClass('ag-opacity-zero', true); }); + } }; - SelectCellEditor.prototype.isPopup = function () { - return false; + RowCtrl.prototype.destroySecondPass = function () { + this.allRowGuis.length = 0; + var destroyCellCtrls = function (ctrls) { + ctrls.list.forEach(function (c) { return c.destroy(); }); + return { list: [], map: {} }; + }; + this.centerCellCtrls = destroyCellCtrls(this.centerCellCtrls); + this.leftCellCtrls = destroyCellCtrls(this.leftCellCtrls); + this.rightCellCtrls = destroyCellCtrls(this.rightCellCtrls); }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], SelectCellEditor.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueFormatterService') - ], SelectCellEditor.prototype, "valueFormatterService", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('eSelect') - ], SelectCellEditor.prototype, "eSelect", void 0); - return SelectCellEditor; -}(_widgets_popupComponent__WEBPACK_IMPORTED_MODULE_1__["PopupComponent"])); - - - -/***/ }), -/* 80 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PopupTextCellEditor", function() { return PopupTextCellEditor; }); -/* harmony import */ var _textCellEditor__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(54); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + RowCtrl.prototype.setFocusedClasses = function () { + var _this = this; + this.allRowGuis.forEach(function (gui) { + gui.rowComp.addOrRemoveCssClass('ag-row-focus', _this.rowFocused); + gui.rowComp.addOrRemoveCssClass('ag-row-no-focus', !_this.rowFocused); + }); }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + RowCtrl.prototype.onCellFocusChanged = function () { + var rowFocused = this.beans.focusService.isRowFocused(this.rowNode.rowIndex, this.rowNode.rowPinned); + if (rowFocused !== this.rowFocused) { + this.rowFocused = rowFocused; + this.setFocusedClasses(); + } + // if we are editing, then moving the focus out of a row will stop editing + if (!rowFocused && this.editingRow) { + this.stopEditing(false); + } }; -})(); - -var PopupTextCellEditor = /** @class */ (function (_super) { - __extends(PopupTextCellEditor, _super); - function PopupTextCellEditor() { - return _super !== null && _super.apply(this, arguments) || this; - } - PopupTextCellEditor.prototype.isPopup = function () { - return true; + RowCtrl.prototype.onPaginationChanged = function () { + var currentPage = this.beans.paginationProxy.getCurrentPage(); + // it is possible this row is in the new page, but the page number has changed, which means + // it needs to reposition itself relative to the new page + if (this.paginationPage !== currentPage) { + this.paginationPage = currentPage; + this.onTopChanged(); + } + this.refreshFirstAndLastRowStyles(); }; - return PopupTextCellEditor; -}(_textCellEditor__WEBPACK_IMPORTED_MODULE_0__["TextCellEditor"])); - - - -/***/ }), -/* 81 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PopupSelectCellEditor", function() { return PopupSelectCellEditor; }); -/* harmony import */ var _selectCellEditor__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(79); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + RowCtrl.prototype.onTopChanged = function () { + this.setRowTop(this.rowNode.rowTop); }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + RowCtrl.prototype.onPaginationPixelOffsetChanged = function () { + // the pixel offset is used when calculating rowTop to set on the row DIV + this.onTopChanged(); }; -})(); - -var PopupSelectCellEditor = /** @class */ (function (_super) { - __extends(PopupSelectCellEditor, _super); - function PopupSelectCellEditor() { - return _super !== null && _super.apply(this, arguments) || this; - } - PopupSelectCellEditor.prototype.isPopup = function () { - return true; + // applies pagination offset, eg if on second page, and page height is 500px, then removes + // 500px from the top position, so a row with rowTop 600px is displayed at location 100px. + // reverse will take the offset away rather than add. + RowCtrl.prototype.applyPaginationOffset = function (topPx, reverse) { + if (reverse === void 0) { reverse = false; } + if (this.rowNode.isRowPinned()) { + return topPx; + } + var pixelOffset = this.beans.paginationProxy.getPixelOffset(); + var multiplier = reverse ? 1 : -1; + return topPx + (pixelOffset * multiplier); }; - return PopupSelectCellEditor; -}(_selectCellEditor__WEBPACK_IMPORTED_MODULE_0__["SelectCellEditor"])); - - - -/***/ }), -/* 82 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LargeTextCellEditor", function() { return LargeTextCellEditor; }); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(25); -/* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(55); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + RowCtrl.prototype.setRowTop = function (pixels) { + // print layout uses normal flow layout for row positioning + if (this.printLayout) { + return; + } + // need to make sure rowTop is not null, as this can happen if the node was once + // visible (ie parent group was expanded) but is now not visible + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(pixels)) { + var afterPaginationPixels = this.applyPaginationOffset(pixels); + var afterScalingPixels = this.rowNode.isRowPinned() ? afterPaginationPixels : this.beans.rowContainerHeightService.getRealPixelPosition(afterPaginationPixels); + var topPx = afterScalingPixels + "px"; + this.setRowTopStyle(topPx); + } }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + RowCtrl.prototype.getInitialRowTop = function () { + return this.initialTop; }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - -var LargeTextCellEditor = /** @class */ (function (_super) { - __extends(LargeTextCellEditor, _super); - function LargeTextCellEditor() { - return _super.call(this, LargeTextCellEditor.TEMPLATE) || this; - } - LargeTextCellEditor.prototype.init = function (params) { - this.params = params; - this.focusAfterAttached = params.cellStartedEdit; - this.eTextArea - .setMaxLength(params.maxLength || 200) - .setCols(params.cols || 60) - .setRows(params.rows || 10); - if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(params.value)) { - this.eTextArea.setValue(params.value.toString(), true); + RowCtrl.prototype.getInitialTransform = function () { + return this.initialTransform; + }; + RowCtrl.prototype.setInitialRowTop = function () { + // print layout uses normal flow layout for row positioning + if (this.printLayout) { + return ''; } - this.addGuiEventListener('keydown', this.onKeyDown.bind(this)); + // if sliding in, we take the old row top. otherwise we just set the current row top. + var pixels = this.slideRowIn ? this.roundRowTopToBounds(this.rowNode.oldRowTop) : this.rowNode.rowTop; + var afterPaginationPixels = this.applyPaginationOffset(pixels); + // we don't apply scaling if row is pinned + var afterScalingPixels = this.rowNode.isRowPinned() ? afterPaginationPixels : this.beans.rowContainerHeightService.getRealPixelPosition(afterPaginationPixels); + var res = afterScalingPixels + 'px'; + var suppressRowTransform = this.beans.gridOptionsWrapper.isSuppressRowTransform(); + if (suppressRowTransform) { + this.initialTop = res; + } + else { + this.initialTransform = "translateY(" + res + ")"; + } + }; + RowCtrl.prototype.setRowTopStyle = function (topPx) { + var suppressRowTransform = this.beans.gridOptionsWrapper.isSuppressRowTransform(); + this.allRowGuis.forEach(function (gui) { return suppressRowTransform ? + gui.rowComp.setTop(topPx) : + gui.rowComp.setTransform("translateY(" + topPx + ")"); }); + }; + RowCtrl.prototype.getRowNode = function () { + return this.rowNode; + }; + RowCtrl.prototype.getCellCtrl = function (column) { + // first up, check for cell directly linked to this column + var res = null; + this.getAllCellCtrls().forEach(function (cellCtrl) { + if (cellCtrl.getColumn() == column) { + res = cellCtrl; + } + }); + if (res != null) { + return res; + } + // second up, if not found, then check for spanned cols. + // we do this second (and not at the same time) as this is + // more expensive, as spanning cols is a + // infrequently used feature so we don't need to do this most + // of the time + this.getAllCellCtrls().forEach(function (cellCtrl) { + if (cellCtrl.getColSpanningList().indexOf(column) >= 0) { + res = cellCtrl; + } + }); + return res; + }; + RowCtrl.prototype.onRowIndexChanged = function () { + // we only bother updating if the rowIndex is present. if it is not present, it means this row + // is child of a group node, and the group node was closed, it's the only way to have no row index. + // when this happens, row is about to be de-rendered, so we don't care, rowComp is about to die! + if (this.rowNode.rowIndex != null) { + this.onCellFocusChanged(); + this.updateRowIndexes(); + this.postProcessCss(); + } + }; + RowCtrl.prototype.updateRowIndexes = function () { + var rowIndexStr = this.rowNode.getRowIndexString(); + var headerRowCount = this.beans.headerNavigationService.getHeaderRowCount(); + var rowIsEven = this.rowNode.rowIndex % 2 === 0; + var ariaRowIndex = headerRowCount + this.rowNode.rowIndex + 1; + this.allRowGuis.forEach(function (c) { + c.rowComp.setRowIndex(rowIndexStr); + c.rowComp.addOrRemoveCssClass('ag-row-even', rowIsEven); + c.rowComp.addOrRemoveCssClass('ag-row-odd', !rowIsEven); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_15__["setAriaRowIndex"])(c.element, ariaRowIndex); + }); + }; + // returns the pinned left container, either the normal one, or the embedded full with one if exists + RowCtrl.prototype.getPinnedLeftRowElement = function () { + return this.leftGui ? this.leftGui.element : undefined; }; - LargeTextCellEditor.prototype.onKeyDown = function (event) { - var key = event.which || event.keyCode; - if (key == _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_LEFT || - key == _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_UP || - key == _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_RIGHT || - key == _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_DOWN || - (event.shiftKey && key == _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_ENTER)) { // shift+enter allows for newlines - event.stopPropagation(); - } + // returns the pinned right container, either the normal one, or the embedded full with one if exists + RowCtrl.prototype.getPinnedRightRowElement = function () { + return this.rightGui ? this.rightGui.element : undefined; }; - LargeTextCellEditor.prototype.afterGuiAttached = function () { - if (this.focusAfterAttached) { - this.eTextArea.getFocusableElement().focus(); - } + // returns the body container, either the normal one, or the embedded full with one if exists + RowCtrl.prototype.getBodyRowElement = function () { + return this.centerGui ? this.centerGui.element : undefined; }; - LargeTextCellEditor.prototype.getValue = function () { - return this.params.parseValue(this.eTextArea.getValue()); + // returns the full width container + RowCtrl.prototype.getFullWidthRowElement = function () { + return this.fullWidthGui ? this.fullWidthGui.element : undefined; }; - LargeTextCellEditor.TEMPLATE = "
\n \n
"; - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])("eTextArea") - ], LargeTextCellEditor.prototype, "eTextArea", void 0); - return LargeTextCellEditor; -}(_widgets_popupComponent__WEBPACK_IMPORTED_MODULE_1__["PopupComponent"])); + RowCtrl.DOM_DATA_KEY_ROW_CTRL = 'renderedRow'; + return RowCtrl; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 83 */ +/* 114 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NumberFilter", function() { return NumberFilter; }); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57); -/* harmony import */ var _simpleFilter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(60); -/* harmony import */ var _scalarFilter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(63); -/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(14); -/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(12); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellCtrl", function() { return CellCtrl; }); +/* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(94); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(23); +/* harmony import */ var _cellRangeFeature__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(115); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(20); +/* harmony import */ var _cellPositionFeature__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(117); +/* harmony import */ var _utils_string__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(26); +/* harmony import */ var _cellCustomStyleFeature__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(118); +/* harmony import */ var _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(119); +/* harmony import */ var _cellMouseListenerFeature__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(120); +/* harmony import */ var _cellKeyboardListenerFeature__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(122); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(65); +/* harmony import */ var _checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(95); +/* harmony import */ var _dndSourceComp__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(123); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(14); +/* harmony import */ var _row_rowDragComp__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(96); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(13); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(42); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(44); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -17485,1008 +25966,1212 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; +var __assign = (undefined && undefined.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); }; -var NumberFilter = /** @class */ (function (_super) { - __extends(NumberFilter, _super); - function NumberFilter() { - return _super !== null && _super.apply(this, arguments) || this; + + + + + + + + + + + + + + +var CSS_CELL = 'ag-cell'; +var CSS_AUTO_HEIGHT = 'ag-cell-auto-height'; +var CSS_NORMAL_HEIGHT = 'ag-cell-normal-height'; +var CSS_CELL_FOCUS = 'ag-cell-focus'; +var CSS_CELL_FIRST_RIGHT_PINNED = 'ag-cell-first-right-pinned'; +var CSS_CELL_LAST_LEFT_PINNED = 'ag-cell-last-left-pinned'; +var CSS_CELL_NOT_INLINE_EDITING = 'ag-cell-not-inline-editing'; +var CSS_CELL_INLINE_EDITING = 'ag-cell-inline-editing'; +var CSS_CELL_POPUP_EDITING = 'ag-cell-popup-editing'; +var CSS_COLUMN_HOVER = 'ag-column-hover'; +var CSS_CELL_WRAP_TEXT = 'ag-cell-wrap-text'; +var instanceIdSequence = 0; +var CellCtrl = /** @class */ (function (_super) { + __extends(CellCtrl, _super); + function CellCtrl(column, rowNode, beans, rowCtrl) { + var _this = _super.call(this) || this; + _this.suppressRefreshCell = false; + _this.column = column; + _this.rowNode = rowNode; + _this.beans = beans; + _this.rowCtrl = rowCtrl; + // unique id to this instance, including the column ID to help with debugging in React as it's used in 'key' + _this.instanceId = column.getId() + '-' + instanceIdSequence++; + _this.createCellPosition(); + _this.addFeatures(); + return _this; } - NumberFilter.prototype.mapRangeFromModel = function (filterModel) { - return { - from: filterModel.filter, - to: filterModel.filterTo + CellCtrl.prototype.addFeatures = function () { + var _this = this; + this.cellPositionFeature = new _cellPositionFeature__WEBPACK_IMPORTED_MODULE_5__["CellPositionFeature"](this, this.beans); + this.addDestroyFunc(function () { return _this.cellPositionFeature.destroy(); }); + this.cellCustomStyleFeature = new _cellCustomStyleFeature__WEBPACK_IMPORTED_MODULE_7__["CellCustomStyleFeature"](this, this.beans); + this.addDestroyFunc(function () { return _this.cellCustomStyleFeature.destroy(); }); + this.cellMouseListenerFeature = new _cellMouseListenerFeature__WEBPACK_IMPORTED_MODULE_9__["CellMouseListenerFeature"](this, this.beans, this.column); + this.addDestroyFunc(function () { return _this.cellMouseListenerFeature.destroy(); }); + this.cellKeyboardListenerFeature = new _cellKeyboardListenerFeature__WEBPACK_IMPORTED_MODULE_10__["CellKeyboardListenerFeature"](this, this.beans, this.column, this.rowNode, this.scope, this.rowCtrl); + this.addDestroyFunc(function () { return _this.cellKeyboardListenerFeature.destroy(); }); + var rangeSelectionEnabled = this.beans.rangeService && this.beans.gridOptionsWrapper.isEnableRangeSelection(); + if (rangeSelectionEnabled) { + this.cellRangeFeature = new _cellRangeFeature__WEBPACK_IMPORTED_MODULE_2__["CellRangeFeature"](this.beans, this); + this.addDestroyFunc(function () { return _this.cellRangeFeature.destroy(); }); + } + this.addTooltipFeature(); + }; + CellCtrl.prototype.addTooltipFeature = function () { + var _this = this; + var getTooltipValue = function () { + var colDef = _this.column.getColDef(); + var data = _this.rowNode.data; + if (colDef.tooltipField && Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["exists"])(data)) { + return Object(_utils_object__WEBPACK_IMPORTED_MODULE_16__["getValueUsingField"])(data, colDef.tooltipField, _this.column.isTooltipFieldContainsDots()); + } + var valueGetter = colDef.tooltipValueGetter; + if (valueGetter) { + return valueGetter({ + location: 'cell', + api: _this.beans.gridOptionsWrapper.getApi(), + columnApi: _this.beans.gridOptionsWrapper.getColumnApi(), + context: _this.beans.gridOptionsWrapper.getContext(), + colDef: _this.column.getColDef(), + column: _this.column, + rowIndex: _this.cellPosition.rowIndex, + node: _this.rowNode, + data: _this.rowNode.data, + value: _this.value, + valueFormatted: _this.valueFormatted, + }); + } + return null; + }; + var tooltipCtrl = { + getColumn: function () { return _this.column; }, + getColDef: function () { return _this.column.getColDef(); }, + getRowIndex: function () { return _this.cellPosition.rowIndex; }, + getRowNode: function () { return _this.rowNode; }, + getGui: function () { return _this.getGui(); }, + getLocation: function () { return 'cell'; }, + getTooltipValue: getTooltipValue, + // this makes no sense, why is the cell formatted value passed to the tooltip??? + getValueFormatted: function () { return _this.valueFormatted; } }; + this.tooltipFeature = new _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_8__["TooltipFeature"](tooltipCtrl, this.beans); + this.addDestroyFunc(function () { return _this.tooltipFeature.destroy(); }); }; - NumberFilter.prototype.getDefaultDebounceMs = function () { - return 500; + CellCtrl.prototype.setComp = function (comp, scope, eGui, eCellWrapper, printLayout, startEditing) { + this.cellComp = comp; + this.gow = this.beans.gridOptionsWrapper; + this.scope = scope; + this.eGui = eGui; + this.eCellWrapper = eCellWrapper; + this.printLayout = printLayout; + // we force to make sure formatter gets called at least once, + // even if value has not changed (is is undefined) + this.updateAndFormatValue(true); + this.addDomData(); + this.onCellFocused(); + this.applyStaticCssClasses(); + this.setWrapText(); + this.onFirstRightPinnedChanged(); + this.onLastLeftPinnedChanged(); + this.onColumnHover(); + this.setupControlComps(); + this.setupAriaExpanded(); + this.setupAutoHeight(); + this.setAriaColIndex(); + if (!this.gow.isSuppressCellFocus()) { + this.cellComp.setTabIndex(-1); + } + var colIdSanitised = Object(_utils_string__WEBPACK_IMPORTED_MODULE_6__["escapeString"])(this.column.getId()); + this.cellComp.setColId(colIdSanitised); + this.cellComp.setRole('gridcell'); + this.cellPositionFeature.setComp(eGui); + this.cellCustomStyleFeature.setComp(comp, scope); + this.tooltipFeature.setComp(comp); + this.cellKeyboardListenerFeature.setComp(this.eGui); + if (this.cellRangeFeature) { + this.cellRangeFeature.setComp(comp, eGui); + } + if (startEditing && this.isCellEditable()) { + this.startEditing(); + } + else { + this.showValue(); + } }; - NumberFilter.prototype.resetUiToDefaults = function (silent) { + CellCtrl.prototype.setupAutoHeight = function () { var _this = this; - return _super.prototype.resetUiToDefaults.call(this, silent).then(function () { - var fields = [_this.eValueFrom1, _this.eValueFrom2, _this.eValueTo1, _this.eValueTo2]; - fields.forEach(function (field) { return field.setValue(null, silent); }); - _this.resetPlaceholder(); + if (!this.column.isAutoHeight()) { + return; + } + var eAutoHeightContainer = this.eCellWrapper; + var eParentCell = eAutoHeightContainer.parentElement; + var minRowHeight = this.beans.gridOptionsWrapper.getRowHeightAsNumber(); + var measureHeight = function (timesCalled) { + if (_this.editing) { + return; + } + // if not in doc yet, means framework not yet inserted, so wait for next VM turn, + // maybe it will be ready next VM turn + var doc = _this.beans.gridOptionsWrapper.getDocument(); + if ((!doc || !doc.contains(eAutoHeightContainer)) && timesCalled < 5) { + _this.beans.frameworkOverrides.setTimeout(function () { return measureHeight(timesCalled + 1); }, 0); + return; + } + var _a = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_17__["getElementSize"])(eParentCell), paddingTop = _a.paddingTop, paddingBottom = _a.paddingBottom; + var wrapperHeight = eAutoHeightContainer.offsetHeight; + var autoHeight = wrapperHeight + paddingTop + paddingBottom; + var newHeight = Math.max(autoHeight, minRowHeight); + _this.rowNode.setRowAutoHeight(newHeight, _this.column); + }; + var listener = function () { return measureHeight(0); }; + // do once to set size in case size doesn't change, common when cell is blank + listener(); + var destroyResizeObserver = this.beans.resizeObserverService.observeResize(eAutoHeightContainer, listener); + this.addDestroyFunc(function () { + destroyResizeObserver(); + _this.rowNode.setRowAutoHeight(undefined, _this.column); }); }; - NumberFilter.prototype.setConditionIntoUi = function (model, position) { - var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One; - var eValueFrom = positionOne ? this.eValueFrom1 : this.eValueFrom2; - var eValueTo = positionOne ? this.eValueTo1 : this.eValueTo2; - eValueFrom.setValue(model ? ('' + model.filter) : null); - eValueTo.setValue(model ? ('' + model.filterTo) : null); + CellCtrl.prototype.getInstanceId = function () { + return this.instanceId; }; - NumberFilter.prototype.setValueFromFloatingFilter = function (value) { - this.eValueFrom1.setValue(value); - this.eValueFrom2.setValue(null); - this.eValueTo1.setValue(null); - this.eValueTo2.setValue(null); + CellCtrl.prototype.showValue = function (forceNewCellRendererInstance) { + if (forceNewCellRendererInstance === void 0) { forceNewCellRendererInstance = false; } + var valueToDisplay = this.valueFormatted != null ? this.valueFormatted : this.value; + var params = this.createCellRendererParams(); + var compDetails = this.beans.userComponentFactory.getCellRendererDetails(this.column.getColDef(), params); + this.cellComp.setRenderDetails(compDetails, valueToDisplay, forceNewCellRendererInstance); + this.refreshHandle(); }; - NumberFilter.prototype.comparator = function () { - return function (left, right) { - if (left === right) { - return 0; - } - if (left < right) { - return 1; - } - return -1; + CellCtrl.prototype.setupControlComps = function () { + var colDef = this.column.getColDef(); + this.includeSelection = this.isIncludeControl(colDef.checkboxSelection); + this.includeRowDrag = this.isIncludeControl(colDef.rowDrag); + this.includeDndSource = this.isIncludeControl(colDef.dndSource); + this.cellComp.setIncludeSelection(this.includeSelection); + this.cellComp.setIncludeDndSource(this.includeDndSource); + this.cellComp.setIncludeRowDrag(this.includeRowDrag); + }; + CellCtrl.prototype.isForceWrapper = function () { + // text selection requires the value to be wrapped in another element + var forceWrapper = this.beans.gridOptionsWrapper.isEnableCellTextSelection() || this.column.isAutoHeight(); + return forceWrapper; + }; + CellCtrl.prototype.isIncludeControl = function (value) { + var rowNodePinned = this.rowNode.rowPinned != null; + var isFunc = typeof value === 'function'; + var res = rowNodePinned ? false : isFunc || value === true; + return res; + }; + CellCtrl.prototype.setupAriaExpanded = function () { + var _this = this; + var colDef = this.column.getColDef(); + if (!this.rowNode.isExpandable()) { + return; + } + var showRowGroup = colDef.showRowGroup; + var rowGroupColumn = this.rowNode.rowGroupColumn; + var showingAllGroups = showRowGroup === true; + var showingThisGroup = rowGroupColumn && rowGroupColumn.getColId() === showRowGroup; + var colMatches = showingAllGroups || showingThisGroup; + if (!colMatches) { + return; + } + var listener = function () { + // for react, we don't use JSX, as setting attributes via jsx is slower + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_18__["setAriaExpanded"])(_this.eGui, !!_this.rowNode.expanded); }; + this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_0__["RowNode"].EVENT_EXPANDED_CHANGED, listener); + listener(); }; - NumberFilter.prototype.setParams = function (params) { - _super.prototype.setParams.call(this, params); - this.addValueChangedListeners(); + CellCtrl.prototype.refreshShouldDestroy = function () { + var colDef = this.column.getColDef(); + var selectionChanged = this.includeSelection != this.isIncludeControl(colDef.checkboxSelection); + var rowDragChanged = this.includeRowDrag != this.isIncludeControl(colDef.rowDrag); + var dndSourceChanged = this.includeDndSource != this.isIncludeControl(colDef.dndSource); + return selectionChanged || rowDragChanged || dndSourceChanged; }; - NumberFilter.prototype.addValueChangedListeners = function () { - var _this = this; - var listener = function () { return _this.onUiChanged(); }; - this.eValueFrom1.onValueChange(listener); - this.eValueFrom2.onValueChange(listener); - this.eValueTo1.onValueChange(listener); - this.eValueTo2.onValueChange(listener); - }; - NumberFilter.prototype.resetPlaceholder = function () { - var isRange1 = this.getCondition1Type() === _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].IN_RANGE; - var isRange2 = this.getCondition2Type() === _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].IN_RANGE; - this.eValueFrom1.setInputPlaceholder(this.translate(isRange1 ? 'inRangeStart' : 'filterOoo')); - this.eValueTo1.setInputPlaceholder(this.translate(isRange1 ? 'inRangeEnd' : 'filterOoo')); - this.eValueFrom2.setInputPlaceholder(this.translate(isRange2 ? 'inRangeStart' : 'filterOoo')); - this.eValueTo2.setInputPlaceholder(this.translate(isRange2 ? 'inRangeEnd' : 'filterOoo')); - }; - NumberFilter.prototype.afterGuiAttached = function (params) { - _super.prototype.afterGuiAttached.call(this, params); - this.resetPlaceholder(); - this.eValueFrom1.getInputElement().focus(); + // either called internally if single cell editing, or called by rowRenderer if row editing + CellCtrl.prototype.startEditing = function (key, charPress, cellStartedEdit, event) { + if (key === void 0) { key = null; } + if (charPress === void 0) { charPress = null; } + if (cellStartedEdit === void 0) { cellStartedEdit = false; } + if (event === void 0) { event = null; } + var _a, _b; + if (!this.isCellEditable() || this.editing) { + return; + } + var editorParams = this.createCellEditorParams(key, charPress, cellStartedEdit); + var colDef = this.column.getColDef(); + var compDetails = this.beans.userComponentFactory.getCellEditorDetails(colDef, editorParams); + // if cellEditorSelector was used, we give preference to popup and popupPosition from the selector + var popup = ((_a = compDetails) === null || _a === void 0 ? void 0 : _a.popupFromSelector) != null ? compDetails.popupFromSelector : !!colDef.cellEditorPopup; + var position = ((_b = compDetails) === null || _b === void 0 ? void 0 : _b.popupPositionFromSelector) != null ? compDetails.popupPositionFromSelector : colDef.cellEditorPopupPosition; + this.setEditing(true, popup); + this.cellComp.setEditDetails(compDetails, popup, position); + var e = this.createEvent(event, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_EDITING_STARTED); + this.beans.eventService.dispatchEvent(e); + }; + CellCtrl.prototype.setEditing = function (editing, inPopup) { + if (inPopup === void 0) { inPopup = false; } + if (this.editing === editing) { + return; + } + this.editing = editing; + this.editingInPopup = inPopup; + this.setInlineEditingClass(); }; - NumberFilter.prototype.getDefaultFilterOptions = function () { - return NumberFilter.DEFAULT_FILTER_OPTIONS; + // pass in 'true' to cancel the editing. + CellCtrl.prototype.stopRowOrCellEdit = function (cancel) { + if (cancel === void 0) { cancel = false; } + if (this.beans.gridOptionsWrapper.isFullRowEdit()) { + this.rowCtrl.stopRowEditing(cancel); + } + else { + this.stopEditing(cancel); + } }; - NumberFilter.prototype.createValueTemplate = function (position) { - var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One; - var pos = positionOne ? '1' : '2'; - return "
\n \n \n
"; - }; - NumberFilter.prototype.isConditionUiComplete = function (position) { - var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One; - var option = positionOne ? this.getCondition1Type() : this.getCondition2Type(); - var eValue = positionOne ? this.eValueFrom1 : this.eValueFrom2; - var eValueTo = positionOne ? this.eValueTo1 : this.eValueTo2; - var value = this.stringToFloat(eValue.getValue()); - var valueTo = this.stringToFloat(eValueTo.getValue()); - if (option === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].EMPTY) { - return false; + CellCtrl.prototype.onPopupEditorClosed = function () { + if (!this.isEditing()) { + return; } - if (this.doesFilterHaveHiddenInput(option)) { - return true; + // note: this happens because of a click outside of the grid or if the popupEditor + // is closed with `Escape` key. if another cell was clicked, then the editing will + // have already stopped and returned on the conditional above. + this.stopEditingAndFocus(); + }; + CellCtrl.prototype.takeValueFromCellEditor = function (cancel) { + var noValueResult = { newValueExists: false }; + if (cancel) { + return noValueResult; + } + var cellEditor = this.cellComp.getCellEditor(); + if (!cellEditor) { + return noValueResult; } - if (option === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].IN_RANGE) { - return value != null && valueTo != null; + var userWantsToCancel = cellEditor.isCancelAfterEnd && cellEditor.isCancelAfterEnd(); + if (userWantsToCancel) { + return noValueResult; } - return value != null; + var newValue = cellEditor.getValue(); + return { + newValue: newValue, + newValueExists: true + }; }; - NumberFilter.prototype.areSimpleModelsEqual = function (aSimple, bSimple) { - return aSimple.filter === bSimple.filter - && aSimple.filterTo === bSimple.filterTo - && aSimple.type === bSimple.type; + CellCtrl.prototype.saveNewValue = function (oldValue, newValue) { + if (newValue === oldValue) { + return; + } + if (this.beans.gridOptionsWrapper.isReadOnlyEdit()) { + this.dispatchEventForSaveValueReadOnly(oldValue, newValue); + return; + } + // we suppressRefreshCell because the call to rowNode.setDataValue() results in change detection + // getting triggered, which results in all cells getting refreshed. we do not want this refresh + // to happen on this call as we want to call it explicitly below. otherwise refresh gets called twice. + // if we only did this refresh (and not the one below) then the cell would flash and not be forced. + this.suppressRefreshCell = true; + this.rowNode.setDataValue(this.column, newValue); + this.suppressRefreshCell = false; }; - // needed for creating filter model - NumberFilter.prototype.getFilterType = function () { - return NumberFilter.FILTER_TYPE; + CellCtrl.prototype.dispatchEventForSaveValueReadOnly = function (oldValue, newValue) { + var rowNode = this.rowNode; + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_EDIT_REQUEST, + event: null, + rowIndex: rowNode.rowIndex, + rowPinned: rowNode.rowPinned, + column: this.column, + api: this.beans.gridApi, + columnApi: this.beans.columnApi, + colDef: this.column.getColDef(), + context: this.beans.gridOptionsWrapper.getContext(), + data: rowNode.data, + node: rowNode, + oldValue: oldValue, + newValue: newValue, + value: newValue, + source: undefined + }; + this.beans.eventService.dispatchEvent(event); }; - NumberFilter.prototype.stringToFloat = function (value) { - if (typeof value === 'number') { - return value; + CellCtrl.prototype.stopEditing = function (cancel) { + if (cancel === void 0) { cancel = false; } + if (!this.editing) { + return; } - var filterText = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["makeNull"])(value); - if (filterText && filterText.trim() === '') { - filterText = null; + var _a = this.takeValueFromCellEditor(cancel), newValue = _a.newValue, newValueExists = _a.newValueExists; + var oldValue = this.getValueFromValueService(); + if (newValueExists) { + this.saveNewValue(oldValue, newValue); } - var newFilter; - if (filterText !== null && filterText !== undefined) { - newFilter = parseFloat(filterText); + this.setEditing(false); + this.cellComp.setEditDetails(); // passing nothing stops editing + this.updateAndFormatValue(); + this.refreshCell({ forceRefresh: true, suppressFlash: true }); + this.dispatchEditingStoppedEvent(oldValue, newValue); + }; + CellCtrl.prototype.dispatchEditingStoppedEvent = function (oldValue, newValue) { + var editingStoppedEvent = __assign(__assign({}, this.createEvent(null, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_EDITING_STOPPED)), { oldValue: oldValue, + newValue: newValue }); + this.beans.eventService.dispatchEvent(editingStoppedEvent); + }; + // if we are editing inline, then we don't have the padding in the cell (set in the themes) + // to allow the text editor full access to the entire cell + CellCtrl.prototype.setInlineEditingClass = function () { + if (!this.isAlive()) { + return; } - else { - newFilter = null; + // ag-cell-inline-editing - appears when user is inline editing + // ag-cell-not-inline-editing - appears when user is no inline editing + // ag-cell-popup-editing - appears when user is editing cell in popup (appears on the cell, not on the popup) + // note: one of {ag-cell-inline-editing, ag-cell-not-inline-editing} is always present, they toggle. + // however {ag-cell-popup-editing} shows when popup, so you have both {ag-cell-popup-editing} + // and {ag-cell-not-inline-editing} showing at the same time. + var editingInline = this.editing && !this.editingInPopup; + var popupEditorShowing = this.editing && this.editingInPopup; + this.cellComp.addOrRemoveCssClass(CSS_CELL_INLINE_EDITING, editingInline); + this.cellComp.addOrRemoveCssClass(CSS_CELL_NOT_INLINE_EDITING, !editingInline); + this.cellComp.addOrRemoveCssClass(CSS_CELL_POPUP_EDITING, popupEditorShowing); + this.rowCtrl.setInlineEditingCss(this.editing); + }; + // this is needed as the JS CellComp still allows isPopup() on the CellEditor class, so + // it's possible the editor is in a popup even though it's not configured via the colDef as so + CellCtrl.prototype.hackSayEditingInPopup = function () { + if (this.editingInPopup) { + return; } - return newFilter; + this.editingInPopup = true; + this.setInlineEditingClass(); }; - NumberFilter.prototype.createCondition = function (position) { - var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One; - var type = positionOne ? this.getCondition1Type() : this.getCondition2Type(); - var eValue = positionOne ? this.eValueFrom1 : this.eValueFrom2; - var value = this.stringToFloat(eValue.getValue()); - var eValueTo = positionOne ? this.eValueTo1 : this.eValueTo2; - var valueTo = this.stringToFloat(eValueTo.getValue()); - var model = { - filterType: NumberFilter.FILTER_TYPE, - type: type + CellCtrl.prototype.createCellEditorParams = function (key, charPress, cellStartedEdit) { + var res = { + value: this.getValueFromValueService(), + key: key, + eventKey: key, + charPress: charPress, + column: this.column, + colDef: this.column.getColDef(), + rowIndex: this.getCellPosition().rowIndex, + node: this.rowNode, + data: this.rowNode.data, + api: this.beans.gridOptionsWrapper.getApi(), + cellStartedEdit: cellStartedEdit, + columnApi: this.beans.gridOptionsWrapper.getColumnApi(), + context: this.beans.gridOptionsWrapper.getContext(), + onKeyDown: this.onKeyDown.bind(this), + stopEditing: this.stopEditingAndFocus.bind(this), + eGridCell: this.getGui(), + parseValue: this.parseValue.bind(this), + formatValue: this.formatValue.bind(this) }; - if (!this.doesFilterHaveHiddenInput(type)) { - model.filter = value; - model.filterTo = valueTo; // FIX - should only populate this when filter choice has 'to' option + if (this.scope) { + res.$scope = this.scope; } - return model; + return res; }; - NumberFilter.prototype.updateUiVisibility = function () { - _super.prototype.updateUiVisibility.call(this); - this.resetPlaceholder(); - var showFrom1 = this.showValueFrom(this.getCondition1Type()); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setDisplayed"])(this.eValueFrom1.getGui(), showFrom1); - var showTo1 = this.showValueTo(this.getCondition1Type()); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setDisplayed"])(this.eValueTo1.getGui(), showTo1); - var showFrom2 = this.showValueFrom(this.getCondition2Type()); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setDisplayed"])(this.eValueFrom2.getGui(), showFrom2); - var showTo2 = this.showValueTo(this.getCondition2Type()); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setDisplayed"])(this.eValueTo2.getGui(), showTo2); - }; - NumberFilter.FILTER_TYPE = 'number'; - NumberFilter.DEFAULT_FILTER_OPTIONS = [ - _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].EQUALS, - _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].NOT_EQUAL, - _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].LESS_THAN, - _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].LESS_THAN_OR_EQUAL, - _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].GREATER_THAN, - _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].GREATER_THAN_OR_EQUAL, - _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].IN_RANGE - ]; - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValueFrom1') - ], NumberFilter.prototype, "eValueFrom1", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValueFrom2') - ], NumberFilter.prototype, "eValueFrom2", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValueTo1') - ], NumberFilter.prototype, "eValueTo1", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValueTo2') - ], NumberFilter.prototype, "eValueTo2", void 0); - return NumberFilter; -}(_scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"])); - - - -/***/ }), -/* 84 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LoadingOverlayComponent", function() { return LoadingOverlayComponent; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + CellCtrl.prototype.createCellRendererParams = function () { + var _this = this; + var addRowCompListener = function (eventType, listener) { + console.warn('AG Grid: since AG Grid v26, params.addRowCompListener() is deprecated. If you need this functionality, please contact AG Grid support and advise why so that we can revert with an appropriate workaround, as we dont have any valid use cases for it. This method was originally provided as a work around to know when cells were destroyed in AG Grid before custom Cell Renderers could be provided.'); + _this.rowCtrl.addEventListener(eventType, listener); + }; + var res = { + value: this.value, + valueFormatted: this.valueFormatted, + getValue: this.getValueFromValueService.bind(this), + setValue: function (value) { return _this.beans.valueService.setValue(_this.rowNode, _this.column, value); }, + formatValue: this.formatValue.bind(this), + data: this.rowNode.data, + node: this.rowNode, + colDef: this.column.getColDef(), + column: this.column, + rowIndex: this.getCellPosition().rowIndex, + api: this.beans.gridOptionsWrapper.getApi(), + columnApi: this.beans.gridOptionsWrapper.getColumnApi(), + context: this.beans.gridOptionsWrapper.getContext(), + refreshCell: this.refreshCell.bind(this), + eGridCell: this.getGui(), + eParentOfValue: this.cellComp.getParentOfValue(), + registerRowDragger: function (rowDraggerElement, dragStartPixels, value, suppressVisibilityChange) { return _this.registerRowDragger(rowDraggerElement, dragStartPixels, suppressVisibilityChange); }, + // this function is not documented anywhere, so we could drop it + // it was in the olden days to allow user to register for when rendered + // row was removed (the row comp was removed), however now that the user + // can provide components for cells, the destroy method gets call when this + // happens so no longer need to fire event. + addRowCompListener: addRowCompListener + }; + if (this.scope) { + res.$scope = this.scope; + } + return res; }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + CellCtrl.prototype.parseValue = function (newValue) { + var colDef = this.column.getColDef(); + var params = { + node: this.rowNode, + data: this.rowNode.data, + oldValue: this.getValue(), + newValue: newValue, + colDef: colDef, + column: this.column, + api: this.beans.gridOptionsWrapper.getApi(), + columnApi: this.beans.gridOptionsWrapper.getColumnApi(), + context: this.beans.gridOptionsWrapper.getContext() + }; + var valueParser = colDef.valueParser; + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["exists"])(valueParser) ? this.beans.expressionService.evaluate(valueParser, params) : newValue; }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - -var LoadingOverlayComponent = /** @class */ (function (_super) { - __extends(LoadingOverlayComponent, _super); - function LoadingOverlayComponent() { - return _super.call(this) || this; - } - // this is a user component, and IComponent has "public destroy()" as part of the interface. - // so we need to override destroy() just to make the method public. - LoadingOverlayComponent.prototype.destroy = function () { - _super.prototype.destroy.call(this); + CellCtrl.prototype.setFocusOutOnEditor = function () { + if (!this.editing) { + return; + } + var cellEditor = this.cellComp.getCellEditor(); + if (cellEditor && cellEditor.focusOut) { + cellEditor.focusOut(); + } }; - LoadingOverlayComponent.prototype.init = function (params) { - var template = this.gridOptionsWrapper.getOverlayLoadingTemplate() ? - this.gridOptionsWrapper.getOverlayLoadingTemplate() : LoadingOverlayComponent.DEFAULT_LOADING_OVERLAY_TEMPLATE; - var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc(); - var localisedTemplate = template.replace('[LOADING...]', localeTextFunc('loadingOoo', 'Loading...')); - this.setTemplate(localisedTemplate); + CellCtrl.prototype.setFocusInOnEditor = function () { + if (!this.editing) { + return; + } + var cellEditor = this.cellComp.getCellEditor(); + if (cellEditor && cellEditor.focusIn) { + // if the editor is present, then we just focus it + cellEditor.focusIn(); + } + else { + // if the editor is not present, it means async cell editor (eg React fibre) + // and we are trying to set focus before the cell editor is present, so we + // focus the cell instead + this.focusCell(true); + } }; - LoadingOverlayComponent.DEFAULT_LOADING_OVERLAY_TEMPLATE = '[LOADING...]'; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], LoadingOverlayComponent.prototype, "gridOptionsWrapper", void 0); - return LoadingOverlayComponent; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_1__["Component"])); - - - -/***/ }), -/* 85 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NoRowsOverlayComponent", function() { return NoRowsOverlayComponent; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + CellCtrl.prototype.onCellChanged = function (event) { + // because of async in React, the cellComp may not be set yet, if no cellComp then we are + // yet to initialise the cell, so no need to refresh. + if (!this.cellComp) { + return; + } + var eventImpactsThisCell = event.column === this.column; + if (eventImpactsThisCell) { + this.refreshCell({}); + } }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + // + stop editing {forceRefresh: true, suppressFlash: true} + // + event cellChanged {} + // + cellRenderer.params.refresh() {} -> method passes 'as is' to the cellRenderer, so params could be anything + // + rowCtrl: event dataChanged {suppressFlash: !update, newData: !update} + // + rowCtrl: api refreshCells() {animate: true/false} + // + rowRenderer: api softRefreshView() {} + CellCtrl.prototype.refreshCell = function (params) { + // if we are in the middle of 'stopEditing', then we don't refresh here, as refresh gets called explicitly + if (this.suppressRefreshCell || this.editing) { + return; + } + var colDef = this.column.getColDef(); + var newData = params != null && !!params.newData; + var suppressFlash = (params != null && !!params.suppressFlash) || !!colDef.suppressCellFlash; + // we always refresh if cell has no value - this can happen when user provides Cell Renderer and the + // cell renderer doesn't rely on a value, instead it could be looking directly at the data, or maybe + // printing the current time (which would be silly)???. Generally speaking + // non of {field, valueGetter, showRowGroup} is bad in the users application, however for this edge case, it's + // best always refresh and take the performance hit rather than never refresh and users complaining in support + // that cells are not updating. + var noValueProvided = colDef.field == null && colDef.valueGetter == null && colDef.showRowGroup == null; + var forceRefresh = (params && params.forceRefresh) || noValueProvided || newData; + var valuesDifferent = this.updateAndFormatValue(); + var dataNeedsUpdating = forceRefresh || valuesDifferent; + if (dataNeedsUpdating) { + // if it's 'new data', then we don't refresh the cellRenderer, even if refresh method is available. + // this is because if the whole data is new (ie we are showing stock price 'BBA' now and not 'SSD') + // then we are not showing a movement in the stock price, rather we are showing different stock. + this.showValue(newData); + // we don't want to flash the cells when processing a filter change, as otherwise the UI would + // be to busy. see comment in FilterManager with regards processingFilterChange + var processingFilterChange = this.beans.filterManager.isSuppressFlashingCellsBecauseFiltering(); + var flashCell = !suppressFlash && !processingFilterChange && + (this.beans.gridOptionsWrapper.isEnableCellChangeFlash() || colDef.enableCellChangeFlash); + if (flashCell) { + this.flashCell(); + } + this.cellCustomStyleFeature.applyUserStyles(); + this.cellCustomStyleFeature.applyClassesFromColDef(); + } + // we can't readily determine if the data in an angularjs template has changed, so here we just update + // and recompile (if applicable) + this.refreshToolTip(); + // we do cellClassRules even if the value has not changed, so that users who have rules that + // look at other parts of the row (where the other part of the row might of changed) will work. + this.cellCustomStyleFeature.applyCellClassRules(); }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - -var NoRowsOverlayComponent = /** @class */ (function (_super) { - __extends(NoRowsOverlayComponent, _super); - function NoRowsOverlayComponent() { - return _super.call(this) || this; - } - // this is a user component, and IComponent has "public destroy()" as part of the interface. - // so we need to override destroy() just to make the method public. - NoRowsOverlayComponent.prototype.destroy = function () { - _super.prototype.destroy.call(this); + // cell editors call this, when they want to stop for reasons other + // than what we pick up on. eg selecting from a dropdown ends editing. + CellCtrl.prototype.stopEditingAndFocus = function (suppressNavigateAfterEdit) { + if (suppressNavigateAfterEdit === void 0) { suppressNavigateAfterEdit = false; } + this.stopRowOrCellEdit(); + this.focusCell(true); + if (!suppressNavigateAfterEdit) { + this.navigateAfterEdit(); + } }; - NoRowsOverlayComponent.prototype.init = function (params) { - var template = this.gridOptionsWrapper.getOverlayNoRowsTemplate() ? - this.gridOptionsWrapper.getOverlayNoRowsTemplate() : NoRowsOverlayComponent.DEFAULT_NO_ROWS_TEMPLATE; - var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc(); - var localisedTemplate = template.replace('[NO_ROWS_TO_SHOW]', localeTextFunc('noRowsToShow', 'No Rows To Show')); - this.setTemplate(localisedTemplate); + CellCtrl.prototype.navigateAfterEdit = function () { + var fullRowEdit = this.beans.gridOptionsWrapper.isFullRowEdit(); + if (fullRowEdit) { + return; + } + var enterMovesDownAfterEdit = this.beans.gridOptionsWrapper.isEnterMovesDownAfterEdit(); + if (enterMovesDownAfterEdit) { + this.beans.navigationService.navigateToNextCell(null, _constants_keyCode__WEBPACK_IMPORTED_MODULE_11__["KeyCode"].DOWN, this.getCellPosition(), false); + } }; - NoRowsOverlayComponent.DEFAULT_NO_ROWS_TEMPLATE = '[NO_ROWS_TO_SHOW]'; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], NoRowsOverlayComponent.prototype, "gridOptionsWrapper", void 0); - return NoRowsOverlayComponent; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_1__["Component"])); - - - -/***/ }), -/* 86 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TooltipComponent", function() { return TooltipComponent; }); -/* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(55); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + // user can also call this via API + CellCtrl.prototype.flashCell = function (delays) { + var flashDelay = delays && delays.flashDelay; + var fadeDelay = delays && delays.fadeDelay; + this.animateCell('data-changed', flashDelay, fadeDelay); }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + CellCtrl.prototype.animateCell = function (cssName, flashDelay, fadeDelay) { + var _this = this; + var fullName = "ag-cell-" + cssName; + var animationFullName = "ag-cell-" + cssName + "-animation"; + var gridOptionsWrapper = this.beans.gridOptionsWrapper; + if (!flashDelay) { + flashDelay = gridOptionsWrapper.getCellFlashDelay(); + } + if (!Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["exists"])(fadeDelay)) { + fadeDelay = gridOptionsWrapper.getCellFadeDelay(); + } + // we want to highlight the cells, without any animation + this.cellComp.addOrRemoveCssClass(fullName, true); + this.cellComp.addOrRemoveCssClass(animationFullName, false); + // then once that is applied, we remove the highlight with animation + window.setTimeout(function () { + _this.cellComp.addOrRemoveCssClass(fullName, false); + _this.cellComp.addOrRemoveCssClass(animationFullName, true); + _this.eGui.style.transition = "background-color " + fadeDelay + "ms"; + window.setTimeout(function () { + // and then to leave things as we got them, we remove the animation + _this.cellComp.addOrRemoveCssClass(animationFullName, false); + _this.eGui.style.transition = ''; + }, fadeDelay); + }, flashDelay); }; -})(); - -var TooltipComponent = /** @class */ (function (_super) { - __extends(TooltipComponent, _super); - function TooltipComponent() { - return _super.call(this, /* html */ "
") || this; - } - // will need to type params - TooltipComponent.prototype.init = function (params) { - var value = params.value; - this.getGui().innerHTML = value; + CellCtrl.prototype.onFlashCells = function (event) { + if (!this.cellComp) { + return; + } + var cellId = this.beans.cellPositionUtils.createId(this.getCellPosition()); + var shouldFlash = event.cells[cellId]; + if (shouldFlash) { + this.animateCell('highlight'); + } }; - return TooltipComponent; -}(_widgets_popupComponent__WEBPACK_IMPORTED_MODULE_0__["PopupComponent"])); - - - -/***/ }), -/* 87 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DefaultDateComponent", function() { return DefaultDateComponent; }); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); -/* harmony import */ var _utils_date__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(18); -/* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(13); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + CellCtrl.prototype.isCellEditable = function () { + return this.column.isCellEditable(this.rowNode); + }; + CellCtrl.prototype.isSuppressFillHandle = function () { + return this.column.isSuppressFillHandle(); + }; + CellCtrl.prototype.formatValue = function (value) { + var res = this.callValueFormatter(value); + return res != null ? res : value; }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + CellCtrl.prototype.callValueFormatter = function (value) { + return this.beans.valueFormatterService.formatValue(this.column, this.rowNode, this.scope, value); }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - -var DefaultDateComponent = /** @class */ (function (_super) { - __extends(DefaultDateComponent, _super); - function DefaultDateComponent() { - return _super.call(this, /* html */ "\n
\n \n
") || this; - } - // this is a user component, and IComponent has "public destroy()" as part of the interface. - // so we need to override destroy() just to make the method public. - DefaultDateComponent.prototype.destroy = function () { - _super.prototype.destroy.call(this); + CellCtrl.prototype.updateAndFormatValue = function (force) { + if (force === void 0) { force = false; } + var oldValue = this.value; + var oldValueFormatted = this.valueFormatted; + this.value = this.getValueFromValueService(); + this.valueFormatted = this.callValueFormatter(this.value); + var valuesDifferent = force ? true : + !this.valuesAreEqual(oldValue, this.value) || this.valueFormatted != oldValueFormatted; + return valuesDifferent; + }; + CellCtrl.prototype.valuesAreEqual = function (val1, val2) { + // if the user provided an equals method, use that, otherwise do simple comparison + var colDef = this.column.getColDef(); + return colDef.equals ? colDef.equals(val1, val2) : val1 === val2; }; - DefaultDateComponent.prototype.init = function (params) { + CellCtrl.prototype.getComp = function () { + return this.cellComp; + }; + CellCtrl.prototype.getValueFromValueService = function () { + // if we don't check this, then the grid will render leaf groups as open even if we are not + // allowing the user to open leaf groups. confused? remember for pivot mode we don't allow + // opening leaf groups, so we have to force leafGroups to be closed in case the user expanded + // them via the API, or user user expanded them in the UI before turning on pivot mode + var lockedClosedGroup = this.rowNode.leafGroup && this.beans.columnModel.isPivotMode(); + var isOpenGroup = this.rowNode.group && this.rowNode.expanded && !this.rowNode.footer && !lockedClosedGroup; + // are we showing group footers + var groupFootersEnabled = this.beans.gridOptionsWrapper.isGroupIncludeFooter(); + // if doing footers, we normally don't show agg data at group level when group is open + var groupAlwaysShowAggData = this.beans.gridOptionsWrapper.isGroupSuppressBlankHeader(); + // if doing grouping and footers, we don't want to include the agg value + // in the header when the group is open + var ignoreAggData = (isOpenGroup && groupFootersEnabled) && !groupAlwaysShowAggData; + var value = this.beans.valueService.getValue(this.column, this.rowNode, false, ignoreAggData); + return value; + }; + CellCtrl.prototype.getValue = function () { + return this.value; + }; + CellCtrl.prototype.getValueFormatted = function () { + return this.valueFormatted; + }; + CellCtrl.prototype.addDomData = function () { var _this = this; - if (this.shouldUseBrowserDatePicker(params)) { - if (Object(_utils_browser__WEBPACK_IMPORTED_MODULE_3__["isBrowserIE"])()) { - console.warn('ag-grid: browserDatePicker is specified to true, but it is not supported in IE 11, reverting to plain text date picker'); - } - else { - this.eDateInput.getInputElement().type = 'date'; - } + var element = this.getGui(); + this.beans.gridOptionsWrapper.setDomData(element, CellCtrl.DOM_DATA_KEY_CELL_CTRL, this); + this.addDestroyFunc(function () { return _this.beans.gridOptionsWrapper.setDomData(element, CellCtrl.DOM_DATA_KEY_CELL_CTRL, null); }); + }; + CellCtrl.prototype.createEvent = function (domEvent, eventType) { + var event = { + type: eventType, + node: this.rowNode, + data: this.rowNode.data, + value: this.value, + column: this.column, + colDef: this.column.getColDef(), + context: this.beans.gridOptionsWrapper.getContext(), + api: this.beans.gridApi, + columnApi: this.beans.columnApi, + rowPinned: this.rowNode.rowPinned, + event: domEvent, + rowIndex: this.rowNode.rowIndex + }; + // because we are hacking in $scope for angular 1, we have to de-reference + if (this.scope) { + event.$scope = this.scope; } - this.listener = params.onDateChanged; - this.addManagedListener(this.eDateInput.getInputElement(), 'input', function (e) { - if (e.target !== document.activeElement) { - return; - } - _this.listener(); - }); + return event; }; - DefaultDateComponent.prototype.getDate = function () { - return Object(_utils_date__WEBPACK_IMPORTED_MODULE_2__["parseDateTimeFromString"])(this.eDateInput.getValue()); + CellCtrl.prototype.onKeyPress = function (event) { + this.cellKeyboardListenerFeature.onKeyPress(event); }; - DefaultDateComponent.prototype.setDate = function (date) { - this.eDateInput.setValue(Object(_utils_date__WEBPACK_IMPORTED_MODULE_2__["serialiseDate"])(date, false)); + CellCtrl.prototype.onKeyDown = function (event) { + this.cellKeyboardListenerFeature.onKeyDown(event); }; - DefaultDateComponent.prototype.setInputPlaceholder = function (placeholder) { - this.eDateInput.setInputPlaceholder(placeholder); + CellCtrl.prototype.onMouseEvent = function (eventName, mouseEvent) { + this.cellMouseListenerFeature.onMouseEvent(eventName, mouseEvent); }; - DefaultDateComponent.prototype.shouldUseBrowserDatePicker = function (params) { - if (params.filterParams && params.filterParams.browserDatePicker != null) { - return params.filterParams.browserDatePicker; + CellCtrl.prototype.getGui = function () { + return this.eGui; + }; + CellCtrl.prototype.refreshToolTip = function () { + this.tooltipFeature.refreshToolTip(); + }; + CellCtrl.prototype.getColSpanningList = function () { + return this.cellPositionFeature.getColSpanningList(); + }; + CellCtrl.prototype.onLeftChanged = function () { + if (!this.cellComp) { + return; } - else { - return Object(_utils_browser__WEBPACK_IMPORTED_MODULE_3__["isBrowserChrome"])() || Object(_utils_browser__WEBPACK_IMPORTED_MODULE_3__["isBrowserFirefox"])(); + this.cellPositionFeature.onLeftChanged(); + }; + CellCtrl.prototype.onDisplayedColumnsChanged = function () { + if (!this.eGui) { + return; } + this.setAriaColIndex(); }; - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eDateInput') - ], DefaultDateComponent.prototype, "eDateInput", void 0); - return DefaultDateComponent; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); - - - -/***/ }), -/* 88 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DateFloatingFilter", function() { return DateFloatingFilter; }); -/* harmony import */ var _dateFilter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(58); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(59); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(57); -/* harmony import */ var _simpleFilter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(60); -/* harmony import */ var _floating_provided_simpleFloatingFilter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(89); -/* harmony import */ var _providedFilter__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(62); -/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(12); -/* harmony import */ var _utils_date__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(18); -/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(21); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + CellCtrl.prototype.setAriaColIndex = function () { + var colIdx = this.beans.columnModel.getAriaColumnIndex(this.column); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_18__["setAriaColIndex"])(this.getGui(), colIdx); // for react, we don't use JSX, as it slowed down column moving }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + CellCtrl.prototype.isSuppressNavigable = function () { + return this.column.isSuppressNavigable(this.rowNode); }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - - - - - - - -var DateFloatingFilter = /** @class */ (function (_super) { - __extends(DateFloatingFilter, _super); - function DateFloatingFilter() { - return _super.call(this, /* html */ "\n
\n \n
\n
") || this; - } - DateFloatingFilter.prototype.getDefaultFilterOptions = function () { - return _dateFilter__WEBPACK_IMPORTED_MODULE_0__["DateFilter"].DEFAULT_FILTER_OPTIONS; + CellCtrl.prototype.onWidthChanged = function () { + return this.cellPositionFeature.onWidthChanged(); }; - DateFloatingFilter.prototype.conditionToString = function (condition) { - if (condition.type === _simpleFilter__WEBPACK_IMPORTED_MODULE_4__["SimpleFilter"].IN_RANGE) { - return condition.dateFrom + "-" + condition.dateTo; - } - // cater for when the type doesn't need a value - if (condition.dateFrom != null) { - return "" + condition.dateFrom; - } - return "" + condition.type; + CellCtrl.prototype.getColumn = function () { + return this.column; }; - DateFloatingFilter.prototype.init = function (params) { - _super.prototype.init.call(this, params); - this.params = params; - this.createDateComponent(); - this.eReadOnlyText - .setDisabled(true) - .setInputAriaLabel('Date Filter Input'); + CellCtrl.prototype.getRowNode = function () { + return this.rowNode; }; - DateFloatingFilter.prototype.setEditable = function (editable) { - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_7__["setDisplayed"])(this.eDateWrapper, editable); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_7__["setDisplayed"])(this.eReadOnlyText.getGui(), !editable); + CellCtrl.prototype.getBeans = function () { + return this.beans; }; - DateFloatingFilter.prototype.onParentModelChanged = function (model, event) { - // We don't want to update the floating filter if the floating filter caused the change, - // because the UI is already in sync. if we didn't do this, the UI would behave strangely - // as it would be updating as the user is typing - if (this.isEventFromFloatingFilter(event)) { + CellCtrl.prototype.isPrintLayout = function () { + return this.printLayout; + }; + CellCtrl.prototype.appendChild = function (htmlElement) { + this.eGui.appendChild(htmlElement); + }; + CellCtrl.prototype.refreshHandle = function () { + if (this.editing) { return; } - _super.prototype.setLastTypeFromModel.call(this, model); - var allowEditing = this.canWeEditAfterModelFromParentFilter(model); - this.setEditable(allowEditing); - if (allowEditing) { - if (model) { - var dateModel = model; - this.dateComp.setDate(Object(_utils_date__WEBPACK_IMPORTED_MODULE_8__["parseDateTimeFromString"])(dateModel.dateFrom)); - } - else { - this.dateComp.setDate(null); - } - this.eReadOnlyText.setValue(''); + if (this.cellRangeFeature) { + this.cellRangeFeature.refreshHandle(); + } + }; + CellCtrl.prototype.getCellPosition = function () { + return this.cellPosition; + }; + CellCtrl.prototype.isEditing = function () { + return this.editing; + }; + // called by rowRenderer when user navigates via tab key + CellCtrl.prototype.startRowOrCellEdit = function (key, charPress, event) { + if (event === void 0) { event = null; } + if (this.beans.gridOptionsWrapper.isFullRowEdit()) { + this.rowCtrl.startRowEditing(key, charPress, this); } else { - this.eReadOnlyText.setValue(this.getTextFromModel(model)); - this.dateComp.setDate(null); + this.startEditing(key, charPress, true, event); } }; - DateFloatingFilter.prototype.onDateChanged = function () { - var _this = this; - var filterValueDate = this.dateComp.getDate(); - var filterValueText = Object(_utils_date__WEBPACK_IMPORTED_MODULE_8__["serialiseDate"])(filterValueDate); - this.params.parentFilterInstance(function (filterInstance) { - if (filterInstance) { - var simpleFilter = filterInstance; - simpleFilter.onFloatingFilterChanged(_this.getLastType(), filterValueText); - } - }); + CellCtrl.prototype.getRowCtrl = function () { + return this.rowCtrl; }; - DateFloatingFilter.prototype.createDateComponent = function () { - var _this = this; - var debounceMs = _providedFilter__WEBPACK_IMPORTED_MODULE_6__["ProvidedFilter"].getDebounceMs(this.params.filterParams, this.getDefaultDebounceMs()); - var dateComponentParams = { - onDateChanged: Object(_utils_function__WEBPACK_IMPORTED_MODULE_9__["debounce"])(this.onDateChanged.bind(this), debounceMs), - filterParams: this.params.column.getColDef().filterParams + CellCtrl.prototype.getRowPosition = function () { + return { + rowIndex: this.cellPosition.rowIndex, + rowPinned: this.cellPosition.rowPinned }; - this.dateComp = new _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__["DateCompWrapper"](this.getContext(), this.userComponentFactory, dateComponentParams, this.eDateWrapper); - this.addDestroyFunc(function () { return _this.dateComp.destroy(); }); }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('userComponentFactory') - ], DateFloatingFilter.prototype, "userComponentFactory", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eReadOnlyText') - ], DateFloatingFilter.prototype, "eReadOnlyText", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eDateWrapper') - ], DateFloatingFilter.prototype, "eDateWrapper", void 0); - return DateFloatingFilter; -}(_floating_provided_simpleFloatingFilter__WEBPACK_IMPORTED_MODULE_5__["SimpleFloatingFilter"])); - - - -/***/ }), -/* 89 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SimpleFloatingFilter", function() { return SimpleFloatingFilter; }); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); -/* harmony import */ var _provided_simpleFilter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(60); -/* harmony import */ var _provided_optionsFactory__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(61); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + CellCtrl.prototype.updateRangeBordersIfRangeCount = function () { + if (!this.cellComp) { + return; + } + if (this.cellRangeFeature) { + this.cellRangeFeature.updateRangeBordersIfRangeCount(); + } }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + CellCtrl.prototype.onRangeSelectionChanged = function () { + if (!this.cellComp) { + return; + } + if (this.cellRangeFeature) { + this.cellRangeFeature.onRangeSelectionChanged(); + } }; -})(); - - - -var SimpleFloatingFilter = /** @class */ (function (_super) { - __extends(SimpleFloatingFilter, _super); - function SimpleFloatingFilter() { - return _super !== null && _super.apply(this, arguments) || this; - } - SimpleFloatingFilter.prototype.getDefaultDebounceMs = function () { - return 0; + CellCtrl.prototype.isRangeSelectionEnabled = function () { + return this.cellRangeFeature != null; }; - // this is a user component, and IComponent has "public destroy()" as part of the interface. - // so we need to override destroy() just to make the method public. - SimpleFloatingFilter.prototype.destroy = function () { - _super.prototype.destroy.call(this); + CellCtrl.prototype.focusCell = function (forceBrowserFocus) { + if (forceBrowserFocus === void 0) { forceBrowserFocus = false; } + this.beans.focusService.setFocusedCell(this.getCellPosition().rowIndex, this.column, this.rowNode.rowPinned, forceBrowserFocus); }; - // used by: - // 1) NumberFloatingFilter & TextFloatingFilter: Always, for both when editable and read only. - // 2) DateFloatingFilter: Only when read only (as we show text rather than a date picker when read only) - SimpleFloatingFilter.prototype.getTextFromModel = function (model) { - if (!model) { - return null; + CellCtrl.prototype.onRowIndexChanged = function () { + // when index changes, this influences items that need the index, so we update the + // grid cell so they are working off the new index. + this.createCellPosition(); + // when the index of the row changes, ie means the cell may have lost or gained focus + this.onCellFocused(); + // check range selection + if (this.cellRangeFeature) { + this.cellRangeFeature.onRangeSelectionChanged(); } - var isCombined = model.operator; - if (isCombined) { - var combinedModel = model; - var con1Str = this.conditionToString(combinedModel.condition1); - var con2Str = this.conditionToString(combinedModel.condition2); - return con1Str + " " + combinedModel.operator + " " + con2Str; + }; + CellCtrl.prototype.onFirstRightPinnedChanged = function () { + if (!this.cellComp) { + return; } - else { - var condition = model; - return this.conditionToString(condition); + var firstRightPinned = this.column.isFirstRightPinned(); + this.cellComp.addOrRemoveCssClass(CSS_CELL_FIRST_RIGHT_PINNED, firstRightPinned); + }; + CellCtrl.prototype.onLastLeftPinnedChanged = function () { + if (!this.cellComp) { + return; } + var lastLeftPinned = this.column.isLastLeftPinned(); + this.cellComp.addOrRemoveCssClass(CSS_CELL_LAST_LEFT_PINNED, lastLeftPinned); }; - SimpleFloatingFilter.prototype.isEventFromFloatingFilter = function (event) { - return event && event.afterFloatingFilter; + CellCtrl.prototype.onCellFocused = function (event) { + if (!this.cellComp || this.gow.isSuppressCellFocus()) { + return; + } + var cellFocused = this.beans.focusService.isCellFocused(this.cellPosition); + this.cellComp.addOrRemoveCssClass(CSS_CELL_FOCUS, cellFocused); + // see if we need to force browser focus - this can happen if focus is programmatically set + if (cellFocused && event && event.forceBrowserFocus) { + var focusEl = this.cellComp.getFocusableElement(); + focusEl.focus(); + } + // if another cell was focused, and we are editing, then stop editing + var fullRowEdit = this.beans.gridOptionsWrapper.isFullRowEdit(); + if (!cellFocused && !fullRowEdit && this.editing) { + this.stopRowOrCellEdit(); + } }; - SimpleFloatingFilter.prototype.getLastType = function () { - return this.lastType; + CellCtrl.prototype.createCellPosition = function () { + this.cellPosition = { + rowIndex: this.rowNode.rowIndex, + rowPinned: this.rowNode.rowPinned, + column: this.column + }; }; - SimpleFloatingFilter.prototype.setLastTypeFromModel = function (model) { - // if no model provided by the parent filter use default - if (!model) { - this.lastType = this.optionsFactory.getDefaultOption(); + // CSS Classes that only get applied once, they never change + CellCtrl.prototype.applyStaticCssClasses = function () { + this.cellComp.addOrRemoveCssClass(CSS_CELL, true); + this.cellComp.addOrRemoveCssClass(CSS_CELL_NOT_INLINE_EDITING, true); + // normal cells fill the height of the row. autoHeight cells have no height to let them + // fit the height of content. + var autoHeight = this.column.isAutoHeight() == true; + this.cellComp.addOrRemoveCssClass(CSS_AUTO_HEIGHT, autoHeight); + this.cellComp.addOrRemoveCssClass(CSS_NORMAL_HEIGHT, !autoHeight); + }; + CellCtrl.prototype.onColumnHover = function () { + if (!this.cellComp) { return; } - var isCombined = model.operator; - var condition; - if (isCombined) { - var combinedModel = model; - condition = combinedModel.condition1; - } - else { - condition = model; + if (!this.beans.gridOptionsWrapper.isColumnHoverHighlight()) { + return; } - this.lastType = condition.type; + var isHovered = this.beans.columnHoverService.isHovered(this.column); + this.cellComp.addOrRemoveCssClass(CSS_COLUMN_HOVER, isHovered); }; - SimpleFloatingFilter.prototype.canWeEditAfterModelFromParentFilter = function (model) { - if (!model) { - // if no model, then we can edit as long as the lastType is something we can edit, as this - // is the type we will provide to the parent filter if the user decides to use the floating filter. - return this.isTypeEditable(this.lastType); + CellCtrl.prototype.onNewColumnsLoaded = function () { + if (!this.cellComp) { + return; } - // never allow editing if the filter is combined (ie has two parts) - var isCombined = model.operator; - if (isCombined) { - return false; + this.setWrapText(); + if (!this.editing) { + this.refreshCell({ forceRefresh: true, suppressFlash: true }); } - var simpleModel = model; - return this.isTypeEditable(simpleModel.type); }; - SimpleFloatingFilter.prototype.init = function (params) { - this.optionsFactory = new _provided_optionsFactory__WEBPACK_IMPORTED_MODULE_2__["OptionsFactory"](); - this.optionsFactory.init(params.filterParams, this.getDefaultFilterOptions()); - this.lastType = this.optionsFactory.getDefaultOption(); - // we are editable if: - // 1) there is a type (user has configured filter wrong if not type) - // AND - // 2) the default type is not 'in range' - var editable = this.isTypeEditable(this.lastType); - this.setEditable(editable); + CellCtrl.prototype.setWrapText = function () { + var value = this.column.getColDef().wrapText == true; + this.cellComp.addOrRemoveCssClass(CSS_CELL_WRAP_TEXT, value); }; - SimpleFloatingFilter.prototype.doesFilterHaveHiddenInput = function (filterType) { - var customFilterOption = this.optionsFactory.getCustomOption(filterType); - return customFilterOption && customFilterOption.hideFilterInput; + CellCtrl.prototype.dispatchCellContextMenuEvent = function (event) { + var colDef = this.column.getColDef(); + var cellContextMenuEvent = this.createEvent(event, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_CONTEXT_MENU); + this.beans.eventService.dispatchEvent(cellContextMenuEvent); + if (colDef.onCellContextMenu) { + // to make the callback async, do in a timeout + window.setTimeout(function () { return colDef.onCellContextMenu(cellContextMenuEvent); }, 0); + } }; - SimpleFloatingFilter.prototype.isTypeEditable = function (type) { - return !this.doesFilterHaveHiddenInput(type) && - type - && type !== _provided_simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].IN_RANGE - && type !== _provided_simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].EMPTY; + CellCtrl.prototype.getCellRenderer = function () { + return this.cellComp ? this.cellComp.getCellRenderer() : null; }; - return SimpleFloatingFilter; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); + CellCtrl.prototype.getCellEditor = function () { + return this.cellComp ? this.cellComp.getCellEditor() : null; + }; + CellCtrl.prototype.destroy = function () { + _super.prototype.destroy.call(this); + }; + CellCtrl.prototype.createSelectionCheckbox = function () { + var cbSelectionComponent = new _checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_12__["CheckboxSelectionComponent"](); + this.beans.context.createBean(cbSelectionComponent); + cbSelectionComponent.init({ rowNode: this.rowNode, column: this.column }); + // put the checkbox in before the value + return cbSelectionComponent; + }; + CellCtrl.prototype.createDndSource = function () { + var dndSourceComp = new _dndSourceComp__WEBPACK_IMPORTED_MODULE_13__["DndSourceComp"](this.rowNode, this.column, this.beans, this.eGui); + this.beans.context.createBean(dndSourceComp); + return dndSourceComp; + }; + CellCtrl.prototype.registerRowDragger = function (customElement, dragStartPixels, suppressVisibilityChange) { + var _this = this; + // if previously existed, then we are only updating + if (this.customRowDragComp) { + this.customRowDragComp.setDragElement(customElement, dragStartPixels); + return; + } + var newComp = this.createRowDragComp(customElement, dragStartPixels, suppressVisibilityChange); + if (newComp) { + this.customRowDragComp = newComp; + this.addDestroyFunc(function () { return _this.beans.context.destroyBean(newComp); }); + } + }; + CellCtrl.prototype.createRowDragComp = function (customElement, dragStartPixels, suppressVisibilityChange) { + var _this = this; + var pagination = this.beans.gridOptionsWrapper.isPagination(); + var rowDragManaged = this.beans.gridOptionsWrapper.isRowDragManaged(); + var clientSideRowModelActive = this.beans.gridOptionsWrapper.isRowModelDefault(); + if (rowDragManaged) { + // row dragging only available in default row model + if (!clientSideRowModelActive) { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_14__["doOnce"])(function () { return console.warn('AG Grid: managed row dragging is only allowed in the Client Side Row Model'); }, 'CellComp.addRowDragging'); + return; + } + if (pagination) { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_14__["doOnce"])(function () { return console.warn('AG Grid: managed row dragging is not possible when doing pagination'); }, 'CellComp.addRowDragging'); + return; + } + } + // otherwise (normal case) we are creating a RowDraggingComp for the first time + var rowDragComp = new _row_rowDragComp__WEBPACK_IMPORTED_MODULE_15__["RowDragComp"](function () { return _this.value; }, this.rowNode, this.column, customElement, dragStartPixels, suppressVisibilityChange); + this.beans.context.createBean(rowDragComp); + return rowDragComp; + }; + CellCtrl.DOM_DATA_KEY_CELL_CTRL = 'cellCtrl'; + return CellCtrl; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_4__["BeanStub"])); /***/ }), -/* 90 */ +/* 115 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TextFilter", function() { return TextFilter; }); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57); -/* harmony import */ var _simpleFilter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(60); -/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(14); -/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(12); -/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(17); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellRangeFeature", function() { return CellRangeFeature; }); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(18); +/* harmony import */ var _interfaces_IRangeService__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(116); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(44); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - -var TextFilter = /** @class */ (function (_super) { - __extends(TextFilter, _super); - function TextFilter() { - return _super !== null && _super.apply(this, arguments) || this; +var CSS_CELL_RANGE_SELECTED = 'ag-cell-range-selected'; +var CSS_CELL_RANGE_CHART = 'ag-cell-range-chart'; +var CSS_CELL_RANGE_SINGLE_CELL = 'ag-cell-range-single-cell'; +var CSS_CELL_RANGE_CHART_CATEGORY = 'ag-cell-range-chart-category'; +var CSS_CELL_RANGE_HANDLE = 'ag-cell-range-handle'; +var CSS_CELL_RANGE_TOP = 'ag-cell-range-top'; +var CSS_CELL_RANGE_RIGHT = 'ag-cell-range-right'; +var CSS_CELL_RANGE_BOTTOM = 'ag-cell-range-bottom'; +var CSS_CELL_RANGE_LEFT = 'ag-cell-range-left'; +var CellRangeFeature = /** @class */ (function () { + function CellRangeFeature(beans, ctrl) { + this.beans = beans; + this.cellCtrl = ctrl; } - TextFilter.prototype.getDefaultDebounceMs = function () { - return 500; - }; - TextFilter.prototype.getValue = function (inputField) { - var val = inputField.getValue(); - val = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["makeNull"])(val); - if (val && val.trim() === '') { - val = null; - } - return val; - }; - TextFilter.prototype.addValueChangedListeners = function () { - var _this = this; - var listener = function () { return _this.onUiChanged(); }; - this.eValue1.onValueChange(listener); - this.eValue2.onValueChange(listener); - }; - TextFilter.prototype.setParams = function (params) { - _super.prototype.setParams.call(this, params); - this.textFilterParams = params; - this.comparator = this.textFilterParams.textCustomComparator || TextFilter.DEFAULT_COMPARATOR; - this.formatter = this.textFilterParams.textFormatter || - (this.textFilterParams.caseSensitive == true - ? TextFilter.DEFAULT_FORMATTER - : TextFilter.DEFAULT_LOWERCASE_FORMATTER); - this.addValueChangedListeners(); + CellRangeFeature.prototype.setComp = function (cellComp, eGui) { + this.cellComp = cellComp; + this.eGui = eGui; + this.onRangeSelectionChanged(); }; - TextFilter.prototype.setConditionIntoUi = function (model, position) { - var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One; - var eValue = positionOne ? this.eValue1 : this.eValue2; - eValue.setValue(model ? model.filter : null); + CellRangeFeature.prototype.onRangeSelectionChanged = function () { + // when using reactUi, given UI is async, it's possible this method is called before the comp is registered + if (!this.cellComp) { + return; + } + this.rangeCount = this.beans.rangeService.getCellRangeCount(this.cellCtrl.getCellPosition()); + this.hasChartRange = this.getHasChartRange(); + this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_SELECTED, this.rangeCount !== 0); + this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_SELECTED + "-1", this.rangeCount === 1); + this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_SELECTED + "-2", this.rangeCount === 2); + this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_SELECTED + "-3", this.rangeCount === 3); + this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_SELECTED + "-4", this.rangeCount >= 4); + this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_CHART, this.hasChartRange); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_3__["setAriaSelected"])(this.eGui, this.rangeCount > 0 ? true : undefined); + this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_SINGLE_CELL, this.isSingleCell()); + this.updateRangeBorders(); + this.refreshHandle(); }; - TextFilter.prototype.createCondition = function (position) { - var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One; - var type = positionOne ? this.getCondition1Type() : this.getCondition2Type(); - var eValue = positionOne ? this.eValue1 : this.eValue2; - var value = this.getValue(eValue); - var model = { - filterType: TextFilter.FILTER_TYPE, - type: type - }; - if (!this.doesFilterHaveHiddenInput(type)) { - model.filter = value; + CellRangeFeature.prototype.updateRangeBorders = function () { + var rangeBorders = this.getRangeBorders(); + var isSingleCell = this.isSingleCell(); + var isTop = !isSingleCell && rangeBorders.top; + var isRight = !isSingleCell && rangeBorders.right; + var isBottom = !isSingleCell && rangeBorders.bottom; + var isLeft = !isSingleCell && rangeBorders.left; + this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_TOP, isTop); + this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_RIGHT, isRight); + this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_BOTTOM, isBottom); + this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_LEFT, isLeft); + }; + CellRangeFeature.prototype.isSingleCell = function () { + var rangeService = this.beans.rangeService; + return this.rangeCount === 1 && rangeService && !rangeService.isMoreThanOneCell(); + }; + CellRangeFeature.prototype.getHasChartRange = function () { + var rangeService = this.beans.rangeService; + if (!this.rangeCount || !rangeService) { + return false; } - return model; + var cellRanges = rangeService.getCellRanges(); + return cellRanges.length > 0 && cellRanges.every(function (range) { return Object(_utils_array__WEBPACK_IMPORTED_MODULE_0__["includes"])([_interfaces_IRangeService__WEBPACK_IMPORTED_MODULE_1__["CellRangeType"].DIMENSION, _interfaces_IRangeService__WEBPACK_IMPORTED_MODULE_1__["CellRangeType"].VALUE], range.type); }); }; - TextFilter.prototype.getFilterType = function () { - return TextFilter.FILTER_TYPE; - }; - TextFilter.prototype.areSimpleModelsEqual = function (aSimple, bSimple) { - return aSimple.filter === bSimple.filter && aSimple.type === bSimple.type; + CellRangeFeature.prototype.updateRangeBordersIfRangeCount = function () { + // we only need to update range borders if we are in a range + if (this.rangeCount > 0) { + this.updateRangeBorders(); + this.refreshHandle(); + } }; - TextFilter.prototype.resetUiToDefaults = function (silent) { + CellRangeFeature.prototype.getRangeBorders = function () { var _this = this; - return _super.prototype.resetUiToDefaults.call(this, silent).then(function () { - _this.forEachInput(function (field) { return field.setValue(null, silent); }); - _this.resetPlaceholder(); - }); - }; - TextFilter.prototype.resetPlaceholder = function () { - var placeholder = this.translate('filterOoo'); - this.forEachInput(function (field) { return field.setInputPlaceholder(placeholder); }); - }; - TextFilter.prototype.forEachInput = function (action) { - Object(_utils_array__WEBPACK_IMPORTED_MODULE_4__["forEach"])([this.eValue1, this.eValue2], action); - }; - TextFilter.prototype.setValueFromFloatingFilter = function (value) { - this.eValue1.setValue(value); - this.eValue2.setValue(null); - }; - TextFilter.prototype.getDefaultFilterOptions = function () { - return TextFilter.DEFAULT_FILTER_OPTIONS; - }; - TextFilter.prototype.createValueTemplate = function (position) { - var pos = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One ? '1' : '2'; - return /* html */ "\n
\n \n
"; - }; - TextFilter.prototype.updateUiVisibility = function () { - _super.prototype.updateUiVisibility.call(this); - var showValue1 = this.showValueFrom(this.getCondition1Type()); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["setDisplayed"])(this.eValue1.getGui(), showValue1); - var showValue2 = this.showValueFrom(this.getCondition2Type()); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["setDisplayed"])(this.eValue2.getGui(), showValue2); + var isRtl = this.beans.gridOptionsWrapper.isEnableRtl(); + var top = false; + var right = false; + var bottom = false; + var left = false; + var thisCol = this.cellCtrl.getCellPosition().column; + var _a = this.beans, rangeService = _a.rangeService, columnModel = _a.columnModel; + var leftCol; + var rightCol; + if (isRtl) { + leftCol = columnModel.getDisplayedColAfter(thisCol); + rightCol = columnModel.getDisplayedColBefore(thisCol); + } + else { + leftCol = columnModel.getDisplayedColBefore(thisCol); + rightCol = columnModel.getDisplayedColAfter(thisCol); + } + var ranges = rangeService.getCellRanges().filter(function (range) { return rangeService.isCellInSpecificRange(_this.cellCtrl.getCellPosition(), range); }); + // this means we are the first column in the grid + if (!leftCol) { + left = true; + } + // this means we are the last column in the grid + if (!rightCol) { + right = true; + } + for (var i = 0; i < ranges.length; i++) { + if (top && right && bottom && left) { + break; + } + var range = ranges[i]; + var startRow = rangeService.getRangeStartRow(range); + var endRow = rangeService.getRangeEndRow(range); + if (!top && this.beans.rowPositionUtils.sameRow(startRow, this.cellCtrl.getCellPosition())) { + top = true; + } + if (!bottom && this.beans.rowPositionUtils.sameRow(endRow, this.cellCtrl.getCellPosition())) { + bottom = true; + } + if (!left && leftCol && range.columns.indexOf(leftCol) < 0) { + left = true; + } + if (!right && rightCol && range.columns.indexOf(rightCol) < 0) { + right = true; + } + } + return { top: top, right: right, bottom: bottom, left: left }; }; - TextFilter.prototype.afterGuiAttached = function (params) { - _super.prototype.afterGuiAttached.call(this, params); - this.resetPlaceholder(); - this.eValue1.getInputElement().focus(); + CellRangeFeature.prototype.refreshHandle = function () { + if (!this.beans.rangeService) { + return; + } + var shouldHaveSelectionHandle = this.shouldHaveSelectionHandle(); + if (this.selectionHandle && !shouldHaveSelectionHandle) { + this.selectionHandle = this.beans.context.destroyBean(this.selectionHandle); + } + if (shouldHaveSelectionHandle) { + this.addSelectionHandle(); + } + this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_HANDLE, !!this.selectionHandle); }; - TextFilter.prototype.isConditionUiComplete = function (position) { - var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One; - var option = positionOne ? this.getCondition1Type() : this.getCondition2Type(); - if (option === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].EMPTY) { + CellRangeFeature.prototype.shouldHaveSelectionHandle = function () { + var _a = this.beans, gridOptionsWrapper = _a.gridOptionsWrapper, rangeService = _a.rangeService; + var cellRanges = rangeService.getCellRanges(); + var rangesLen = cellRanges.length; + if (this.rangeCount < 1 || rangesLen < 1) { return false; } - if (this.doesFilterHaveHiddenInput(option)) { - return true; + var cellRange = Object(_utils_array__WEBPACK_IMPORTED_MODULE_0__["last"])(cellRanges); + var cellPosition = this.cellCtrl.getCellPosition(); + var isFillHandleAvailable = gridOptionsWrapper.isEnableFillHandle() && !this.cellCtrl.isSuppressFillHandle(); + var isRangeHandleAvailable = gridOptionsWrapper.isEnableRangeHandle(); + var handleIsAvailable = rangesLen === 1 && !this.cellCtrl.isEditing() && (isFillHandleAvailable || isRangeHandleAvailable); + if (this.hasChartRange) { + var hasCategoryRange = cellRanges[0].type === _interfaces_IRangeService__WEBPACK_IMPORTED_MODULE_1__["CellRangeType"].DIMENSION; + var isCategoryCell = hasCategoryRange && rangeService.isCellInSpecificRange(cellPosition, cellRanges[0]); + this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_CHART_CATEGORY, isCategoryCell); + handleIsAvailable = cellRange.type === _interfaces_IRangeService__WEBPACK_IMPORTED_MODULE_1__["CellRangeType"].VALUE; } - return this.getValue(positionOne ? this.eValue1 : this.eValue2) != null; - }; - TextFilter.prototype.individualConditionPasses = function (params, filterModel) { - var filterText = filterModel.filter; - var filterOption = filterModel.type; - var cellValue = this.textFilterParams.valueGetter(params.node); - var cellValueFormatted = this.formatter(cellValue); - var customFilterOption = this.optionsFactory.getCustomOption(filterOption); - if (customFilterOption) { - // only execute the custom filter if a value exists or a value isn't required, i.e. input is hidden - if (filterText != null || customFilterOption.hideFilterInput) { - return customFilterOption.test(filterText, cellValueFormatted); - } + return handleIsAvailable && + cellRange.endRow != null && + rangeService.isContiguousRange(cellRange) && + rangeService.isBottomRightCell(cellRange, cellPosition); + }; + CellRangeFeature.prototype.addSelectionHandle = function () { + var _a = this.beans, gridOptionsWrapper = _a.gridOptionsWrapper, rangeService = _a.rangeService; + var cellRangeType = Object(_utils_array__WEBPACK_IMPORTED_MODULE_0__["last"])(rangeService.getCellRanges()).type; + var selectionHandleFill = gridOptionsWrapper.isEnableFillHandle() && Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["missing"])(cellRangeType); + var type = selectionHandleFill ? _interfaces_IRangeService__WEBPACK_IMPORTED_MODULE_1__["SelectionHandleType"].FILL : _interfaces_IRangeService__WEBPACK_IMPORTED_MODULE_1__["SelectionHandleType"].RANGE; + if (this.selectionHandle && this.selectionHandle.getType() !== type) { + this.selectionHandle = this.beans.context.destroyBean(this.selectionHandle); } - if (cellValue == null) { - return filterOption === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].NOT_EQUAL || filterOption === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].NOT_CONTAINS; + if (!this.selectionHandle) { + this.selectionHandle = this.beans.selectionHandleFactory.createSelectionHandle(type); } - var filterTextFormatted = this.formatter(filterText); - return this.comparator(filterOption, cellValueFormatted, filterTextFormatted); - }; - TextFilter.FILTER_TYPE = 'text'; - TextFilter.DEFAULT_FILTER_OPTIONS = [ - _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].CONTAINS, - _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].NOT_CONTAINS, - _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].EQUALS, - _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].NOT_EQUAL, - _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].STARTS_WITH, - _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].ENDS_WITH - ]; - TextFilter.DEFAULT_FORMATTER = function (from) { return from; }; - TextFilter.DEFAULT_LOWERCASE_FORMATTER = function (from) { - return from == null ? null : from.toString().toLowerCase(); + this.selectionHandle.refresh(this.cellCtrl); }; - TextFilter.DEFAULT_COMPARATOR = function (filter, value, filterText) { - switch (filter) { - case TextFilter.CONTAINS: - return value.indexOf(filterText) >= 0; - case TextFilter.NOT_CONTAINS: - return value.indexOf(filterText) === -1; - case TextFilter.EQUALS: - return value === filterText; - case TextFilter.NOT_EQUAL: - return value != filterText; - case TextFilter.STARTS_WITH: - return value.indexOf(filterText) === 0; - case TextFilter.ENDS_WITH: - var index = value.lastIndexOf(filterText); - return index >= 0 && index === (value.length - filterText.length); - default: - // should never happen - console.warn('invalid filter type ' + filter); - return false; - } + CellRangeFeature.prototype.destroy = function () { + this.beans.context.destroyBean(this.selectionHandle); }; - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValue1') - ], TextFilter.prototype, "eValue1", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValue2') - ], TextFilter.prototype, "eValue2", void 0); - return TextFilter; -}(_simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"])); + return CellRangeFeature; +}()); /***/ }), -/* 91 */ +/* 116 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NumberFloatingFilter", function() { return NumberFloatingFilter; }); -/* harmony import */ var _numberFilter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(83); -/* harmony import */ var _simpleFilter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(60); -/* harmony import */ var _floating_provided_textInputFloatingFilter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(92); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SelectionHandleType", function() { return SelectionHandleType; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellRangeType", function() { return CellRangeType; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); - - - -var NumberFloatingFilter = /** @class */ (function (_super) { - __extends(NumberFloatingFilter, _super); - function NumberFloatingFilter() { - return _super !== null && _super.apply(this, arguments) || this; - } - NumberFloatingFilter.prototype.getDefaultFilterOptions = function () { - return _numberFilter__WEBPACK_IMPORTED_MODULE_0__["NumberFilter"].DEFAULT_FILTER_OPTIONS; - }; - NumberFloatingFilter.prototype.conditionToString = function (condition) { - var isRange = condition.type == _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].IN_RANGE; - if (isRange) { - return condition.filter + "-" + condition.filterTo; - } - // cater for when the type doesn't need a value - if (condition.filter != null) { - return "" + condition.filter; - } - return "" + condition.type; - }; - return NumberFloatingFilter; -}(_floating_provided_textInputFloatingFilter__WEBPACK_IMPORTED_MODULE_2__["TextInputFloatingFilter"])); - +var SelectionHandleType; +(function (SelectionHandleType) { + SelectionHandleType[SelectionHandleType["FILL"] = 0] = "FILL"; + SelectionHandleType[SelectionHandleType["RANGE"] = 1] = "RANGE"; +})(SelectionHandleType || (SelectionHandleType = {})); +var CellRangeType; +(function (CellRangeType) { + CellRangeType[CellRangeType["VALUE"] = 0] = "VALUE"; + CellRangeType[CellRangeType["DIMENSION"] = 1] = "DIMENSION"; +})(CellRangeType || (CellRangeType = {})); /***/ }), -/* 92 */ +/* 117 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TextInputFloatingFilter", function() { return TextInputFloatingFilter; }); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57); -/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(21); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25); -/* harmony import */ var _provided_providedFilter__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(62); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(37); -/* harmony import */ var _simpleFloatingFilter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(89); -/* harmony import */ var _utils_keyboard__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(24); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellPositionFeature", function() { return CellPositionFeature; }); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(18); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(24); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(15); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(20); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -18503,106 +27188,155 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - -var TextInputFloatingFilter = /** @class */ (function (_super) { - __extends(TextInputFloatingFilter, _super); - function TextInputFloatingFilter() { - return _super !== null && _super.apply(this, arguments) || this; +/** + * Takes care of: + * #) Cell Width (including when doing cell spanning, which makes width cover many columns) + * #) Cell Height (when doing row span, otherwise we don't touch the height as it's just row height) + * #) Cell Left (the horizontal positioning of the cell, the vertical positioning is on the row) + */ +var CellPositionFeature = /** @class */ (function (_super) { + __extends(CellPositionFeature, _super); + function CellPositionFeature(ctrl, beans) { + var _this = _super.call(this) || this; + _this.cellCtrl = ctrl; + _this.beans = beans; + _this.column = ctrl.getColumn(); + _this.rowNode = ctrl.getRowNode(); + _this.setupColSpan(); + _this.setupRowSpan(); + return _this; } - TextInputFloatingFilter.prototype.postConstruct = function () { - this.setTemplate(/* html */ "\n
\n \n
"); + CellPositionFeature.prototype.setupRowSpan = function () { + this.rowSpan = this.column.getRowSpan(this.rowNode); }; - TextInputFloatingFilter.prototype.getDefaultDebounceMs = function () { - return 500; + CellPositionFeature.prototype.setComp = function (eGui) { + this.eGui = eGui; + this.onLeftChanged(); + this.onWidthChanged(); + this.applyRowSpan(); }; - TextInputFloatingFilter.prototype.onParentModelChanged = function (model, event) { - // we don't want to update the floating filter if the floating filter caused the change. - // as if it caused the change, the ui is already in sync. if we didn't do this, the UI - // would behave strange as it would be updating as the user is typing - if (this.isEventFromFloatingFilter(event)) { - return; + CellPositionFeature.prototype.onDisplayColumnsChanged = function () { + var colsSpanning = this.getColSpanningList(); + if (!Object(_utils_array__WEBPACK_IMPORTED_MODULE_0__["areEqual"])(this.colsSpanning, colsSpanning)) { + this.colsSpanning = colsSpanning; + this.onWidthChanged(); + this.onLeftChanged(); // left changes when doing RTL } - this.setLastTypeFromModel(model); - var modelString = this.getTextFromModel(model); - this.eFloatingFilterInput.setValue(modelString); - var editable = this.canWeEditAfterModelFromParentFilter(model); - this.setEditable(editable); }; - TextInputFloatingFilter.prototype.init = function (params) { - _super.prototype.init.call(this, params); - this.params = params; - this.applyActive = _provided_providedFilter__WEBPACK_IMPORTED_MODULE_3__["ProvidedFilter"].isUseApplyButton(this.params.filterParams); - var debounceMs = _provided_providedFilter__WEBPACK_IMPORTED_MODULE_3__["ProvidedFilter"].getDebounceMs(this.params.filterParams, this.getDefaultDebounceMs()); - var toDebounce = Object(_utils_function__WEBPACK_IMPORTED_MODULE_1__["debounce"])(this.syncUpWithParentFilter.bind(this), debounceMs); - var filterGui = this.eFloatingFilterInput.getGui(); - this.addManagedListener(filterGui, 'input', toDebounce); - this.addManagedListener(filterGui, 'keypress', toDebounce); - this.addManagedListener(filterGui, 'keydown', toDebounce); - var columnDef = params.column.getDefinition(); - if (columnDef.filterParams && - columnDef.filterParams.filterOptions && - columnDef.filterParams.filterOptions.length === 1 && - columnDef.filterParams.filterOptions[0] === 'inRange') { - this.eFloatingFilterInput.setDisabled(true); + CellPositionFeature.prototype.setupColSpan = function () { + // if no col span is active, then we don't set it up, as it would be wasteful of CPU + if (this.column.getColDef().colSpan == null) { + return; } - var displayName = this.columnController.getDisplayNameForColumn(params.column, 'header', true); - this.eFloatingFilterInput.setInputAriaLabel(displayName + " Filter Input"); + this.colsSpanning = this.getColSpanningList(); + // because we are col spanning, a reorder of the cols can change what cols we are spanning over + this.addManagedListener(this.beans.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayColumnsChanged.bind(this)); + // because we are spanning over multiple cols, we check for width any time any cols width changes. + // this is expensive - really we should be explicitly checking only the cols we are spanning over + // instead of every col, however it would be tricky code to track the cols we are spanning over, so + // because hardly anyone will be using colSpan, am favouring this easier way for more maintainable code. + this.addManagedListener(this.beans.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, this.onWidthChanged.bind(this)); }; - TextInputFloatingFilter.prototype.syncUpWithParentFilter = function (e) { - var _this = this; - var value = this.eFloatingFilterInput.getValue(); - var enterKeyPressed = Object(_utils_keyboard__WEBPACK_IMPORTED_MODULE_6__["isKeyPressed"])(e, _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_ENTER); - if (this.applyActive && !enterKeyPressed) { + CellPositionFeature.prototype.onWidthChanged = function () { + if (!this.eGui) { return; } - this.params.parentFilterInstance(function (filterInstance) { - if (filterInstance) { - var simpleFilter = filterInstance; - simpleFilter.onFloatingFilterChanged(_this.getLastType(), value); + var width = this.getCellWidth(); + this.eGui.style.width = width + "px"; + }; + CellPositionFeature.prototype.getCellWidth = function () { + if (!this.colsSpanning) { + return this.column.getActualWidth(); + } + return this.colsSpanning.reduce(function (width, col) { return width + col.getActualWidth(); }, 0); + }; + CellPositionFeature.prototype.getColSpanningList = function () { + var colSpan = this.column.getColSpan(this.rowNode); + var colsSpanning = []; + // if just one col, the col span is just the column we are in + if (colSpan === 1) { + colsSpanning.push(this.column); + } + else { + var pointer = this.column; + var pinned = this.column.getPinned(); + for (var i = 0; pointer && i < colSpan; i++) { + colsSpanning.push(pointer); + pointer = this.beans.columnModel.getDisplayedColAfter(pointer); + if (!pointer || Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["missing"])(pointer)) { + break; + } + // we do not allow col spanning to span outside of pinned areas + if (pinned !== pointer.getPinned()) { + break; + } } - }); + } + return colsSpanning; }; - TextInputFloatingFilter.prototype.setEditable = function (editable) { - this.eFloatingFilterInput.setDisabled(!editable); + CellPositionFeature.prototype.onLeftChanged = function () { + if (!this.eGui) { + return; + } + var left = this.modifyLeftForPrintLayout(this.getCellLeft()); + this.eGui.style.left = left + 'px'; }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_4__["Autowired"])('columnController') - ], TextInputFloatingFilter.prototype, "columnController", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eFloatingFilterInput') - ], TextInputFloatingFilter.prototype, "eFloatingFilterInput", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_4__["PostConstruct"] - ], TextInputFloatingFilter.prototype, "postConstruct", null); - return TextInputFloatingFilter; -}(_simpleFloatingFilter__WEBPACK_IMPORTED_MODULE_5__["SimpleFloatingFilter"])); + CellPositionFeature.prototype.getCellLeft = function () { + var mostLeftCol; + if (this.beans.gridOptionsWrapper.isEnableRtl() && this.colsSpanning) { + mostLeftCol = Object(_utils_array__WEBPACK_IMPORTED_MODULE_0__["last"])(this.colsSpanning); + } + else { + mostLeftCol = this.column; + } + return mostLeftCol.getLeft(); + }; + CellPositionFeature.prototype.modifyLeftForPrintLayout = function (leftPosition) { + if (!this.cellCtrl.isPrintLayout() || this.column.getPinned() === _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_LEFT) { + return leftPosition; + } + var leftWidth = this.beans.columnModel.getDisplayedColumnsLeftWidth(); + if (this.column.getPinned() === _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_RIGHT) { + var bodyWidth = this.beans.columnModel.getBodyContainerWidth(); + return leftWidth + bodyWidth + (leftPosition || 0); + } + // is in body + return leftWidth + (leftPosition || 0); + }; + CellPositionFeature.prototype.applyRowSpan = function () { + if (this.rowSpan === 1) { + return; + } + var singleRowHeight = this.beans.gridOptionsWrapper.getRowHeightAsNumber(); + var totalRowHeight = singleRowHeight * this.rowSpan; + this.eGui.style.height = totalRowHeight + "px"; + this.eGui.style.zIndex = '1'; + }; + // overriding to make public, as we don't dispose this bean via context + CellPositionFeature.prototype.destroy = function () { + _super.prototype.destroy.call(this); + }; + return CellPositionFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_4__["BeanStub"])); /***/ }), -/* 93 */ +/* 118 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TextFloatingFilter", function() { return TextFloatingFilter; }); -/* harmony import */ var _textFilter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(90); -/* harmony import */ var _floating_provided_textInputFloatingFilter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(92); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellCustomStyleFeature", function() { return CellCustomStyleFeature; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -18620,498 +27354,213 @@ var __extends = (undefined && undefined.__extends) || (function () { }; })(); - -var TextFloatingFilter = /** @class */ (function (_super) { - __extends(TextFloatingFilter, _super); - function TextFloatingFilter() { - return _super !== null && _super.apply(this, arguments) || this; +var CellCustomStyleFeature = /** @class */ (function (_super) { + __extends(CellCustomStyleFeature, _super); + function CellCustomStyleFeature(ctrl, beans) { + var _this = _super.call(this) || this; + _this.staticClasses = []; + _this.cellCtrl = ctrl; + _this.beans = beans; + _this.column = ctrl.getColumn(); + _this.rowNode = ctrl.getRowNode(); + return _this; } - TextFloatingFilter.prototype.conditionToString = function (condition) { - // it's not possible to have 'in range' for string, so no need to check for it. - // also cater for when the type doesn't need a value - if (condition.filter != null) { - return "" + condition.filter; + CellCustomStyleFeature.prototype.setComp = function (comp, scope) { + this.cellComp = comp; + this.scope = scope; + this.applyUserStyles(); + this.applyCellClassRules(); + this.applyClassesFromColDef(); + }; + CellCustomStyleFeature.prototype.applyCellClassRules = function () { + var _this = this; + var colDef = this.column.getColDef(); + var cellClassParams = { + value: this.cellCtrl.getValue(), + data: this.rowNode.data, + node: this.rowNode, + colDef: colDef, + rowIndex: this.rowNode.rowIndex, + api: this.beans.gridOptionsWrapper.getApi(), + columnApi: this.beans.gridOptionsWrapper.getColumnApi(), + $scope: this.scope, + context: this.beans.gridOptionsWrapper.getContext() + }; + this.beans.stylingService.processClassRules(colDef.cellClassRules, cellClassParams, function (className) { return _this.cellComp.addOrRemoveCssClass(className, true); }, function (className) { return _this.cellComp.addOrRemoveCssClass(className, false); }); + }; + CellCustomStyleFeature.prototype.applyUserStyles = function () { + var colDef = this.column.getColDef(); + if (!colDef.cellStyle) { + return; + } + var styles; + if (typeof colDef.cellStyle === 'function') { + var cellStyleParams = { + column: this.column, + value: this.cellCtrl.getValue(), + colDef: colDef, + data: this.rowNode.data, + node: this.rowNode, + rowIndex: this.rowNode.rowIndex, + $scope: this.scope, + api: this.beans.gridOptionsWrapper.getApi(), + columnApi: this.beans.gridOptionsWrapper.getColumnApi(), + context: this.beans.gridOptionsWrapper.getContext(), + }; + var cellStyleFunc = colDef.cellStyle; + styles = cellStyleFunc(cellStyleParams); } else { - return "" + condition.type; + styles = colDef.cellStyle; } + this.cellComp.setUserStyles(styles); }; - TextFloatingFilter.prototype.getDefaultFilterOptions = function () { - return _textFilter__WEBPACK_IMPORTED_MODULE_0__["TextFilter"].DEFAULT_FILTER_OPTIONS; + CellCustomStyleFeature.prototype.applyClassesFromColDef = function () { + var _this = this; + var colDef = this.column.getColDef(); + var cellClassParams = { + value: this.cellCtrl.getValue(), + data: this.rowNode.data, + node: this.rowNode, + colDef: colDef, + rowIndex: this.rowNode.rowIndex, + $scope: this.scope, + api: this.beans.gridOptionsWrapper.getApi(), + columnApi: this.beans.gridOptionsWrapper.getColumnApi(), + context: this.beans.gridOptionsWrapper.getContext() + }; + if (this.staticClasses.length) { + this.staticClasses.forEach(function (className) { return _this.cellComp.addOrRemoveCssClass(className, false); }); + } + this.staticClasses = this.beans.stylingService.getStaticCellClasses(colDef, cellClassParams); + if (this.staticClasses.length) { + this.staticClasses.forEach(function (className) { return _this.cellComp.addOrRemoveCssClass(className, true); }); + } }; - return TextFloatingFilter; -}(_floating_provided_textInputFloatingFilter__WEBPACK_IMPORTED_MODULE_1__["TextInputFloatingFilter"])); + // overriding to make public, as we don't dispose this bean via context + CellCustomStyleFeature.prototype.destroy = function () { + _super.prototype.destroy.call(this); + }; + return CellCustomStyleFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 94 */ +/* 119 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "initialiseAgGridWithAngular1", function() { return initialiseAgGridWithAngular1; }); -/* harmony import */ var _grid__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(95); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TooltipFeature", function() { return TooltipFeature; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _customTooltipFeature__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ - -function initialiseAgGridWithAngular1(angular) { - var angularModule = angular.module("agGrid", []); - angularModule.directive("agGrid", function () { - return { - restrict: "A", - controller: ['$element', '$scope', '$compile', '$attrs', AngularDirectiveController], - scope: true - }; - }); -} -function AngularDirectiveController($element, $scope, $compile, $attrs) { - var gridOptions; - var quickFilterOnScope; - var keyOfGridInScope = $attrs.agGrid; - quickFilterOnScope = keyOfGridInScope + '.quickFilterText'; - gridOptions = $scope.$eval(keyOfGridInScope); - if (!gridOptions) { - console.warn("WARNING - grid options for ag-Grid not found. Please ensure the attribute ag-grid points to a valid object on the scope"); - return; - } - var eGridDiv = $element[0]; - var gridParams = { - $scope: $scope, - $compile: $compile, - quickFilterOnScope: quickFilterOnScope +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - var grid = new _grid__WEBPACK_IMPORTED_MODULE_0__["Grid"](eGridDiv, gridOptions, gridParams); - $scope.$on("$destroy", function () { - grid.destroy(); - grid = null; - }); -} - - -/***/ }), -/* 95 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Grid", function() { return Grid; }); -/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(50); -/* harmony import */ var _selectionController__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(96); -/* harmony import */ var _columnController_columnApi__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(98); -/* harmony import */ var _columnController_columnController__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(42); -/* harmony import */ var _rendering_rowRenderer__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(99); -/* harmony import */ var _headerRendering_headerRootComp__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(108); -/* harmony import */ var _filter_filterManager__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(125); -/* harmony import */ var _valueService_valueService__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(126); -/* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(36); -/* harmony import */ var _gridPanel_gridPanel__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(127); -/* harmony import */ var _gridApi__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(130); -/* harmony import */ var _columnController_columnFactory__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(5); -/* harmony import */ var _columnController_displayedGroupCreator__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(47); -/* harmony import */ var _valueService_expressionService__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(131); -/* harmony import */ var _templateService__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(132); -/* harmony import */ var _widgets_popupService__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(133); -/* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(134); -/* harmony import */ var _columnController_columnUtils__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(46); -/* harmony import */ var _rendering_autoWidthCalculator__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(135); -/* harmony import */ var _headerRendering_horizontalResizeService__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(136); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(37); -/* harmony import */ var _gridCore__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(137); -/* harmony import */ var _headerRendering_standardMenu__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(138); -/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(104); -/* harmony import */ var _dragAndDrop_dragService__WEBPACK_IMPORTED_MODULE_24__ = __webpack_require__(139); -/* harmony import */ var _sortController__WEBPACK_IMPORTED_MODULE_25__ = __webpack_require__(140); -/* harmony import */ var _focusController__WEBPACK_IMPORTED_MODULE_26__ = __webpack_require__(141); -/* harmony import */ var _gridPanel_mouseEventService__WEBPACK_IMPORTED_MODULE_27__ = __webpack_require__(142); -/* harmony import */ var _cellNavigationService__WEBPACK_IMPORTED_MODULE_28__ = __webpack_require__(143); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_29__ = __webpack_require__(43); -/* harmony import */ var _rendering_cellRendererFactory__WEBPACK_IMPORTED_MODULE_30__ = __webpack_require__(144); -/* harmony import */ var _rendering_valueFormatterService__WEBPACK_IMPORTED_MODULE_31__ = __webpack_require__(145); -/* harmony import */ var _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_32__ = __webpack_require__(70); -/* harmony import */ var _widgets_agRadioButton__WEBPACK_IMPORTED_MODULE_33__ = __webpack_require__(146); -/* harmony import */ var _vanillaFrameworkOverrides__WEBPACK_IMPORTED_MODULE_34__ = __webpack_require__(147); -/* harmony import */ var _gridPanel_scrollVisibleService__WEBPACK_IMPORTED_MODULE_35__ = __webpack_require__(148); -/* harmony import */ var _styling_stylingService__WEBPACK_IMPORTED_MODULE_36__ = __webpack_require__(149); -/* harmony import */ var _rendering_columnHoverService__WEBPACK_IMPORTED_MODULE_37__ = __webpack_require__(150); -/* harmony import */ var _rendering_columnAnimationService__WEBPACK_IMPORTED_MODULE_38__ = __webpack_require__(151); -/* harmony import */ var _columnController_autoGroupColService__WEBPACK_IMPORTED_MODULE_39__ = __webpack_require__(152); -/* harmony import */ var _pagination_paginationProxy__WEBPACK_IMPORTED_MODULE_40__ = __webpack_require__(153); -/* harmony import */ var _pagination_paginationAutoPageSizeService__WEBPACK_IMPORTED_MODULE_41__ = __webpack_require__(154); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_42__ = __webpack_require__(25); -/* harmony import */ var _valueService_valueCache__WEBPACK_IMPORTED_MODULE_43__ = __webpack_require__(155); -/* harmony import */ var _valueService_changeDetectionService__WEBPACK_IMPORTED_MODULE_44__ = __webpack_require__(156); -/* harmony import */ var _alignedGridsService__WEBPACK_IMPORTED_MODULE_45__ = __webpack_require__(157); -/* harmony import */ var _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_46__ = __webpack_require__(74); -/* harmony import */ var _components_framework_userComponentRegistry__WEBPACK_IMPORTED_MODULE_47__ = __webpack_require__(53); -/* harmony import */ var _components_framework_agComponentUtils__WEBPACK_IMPORTED_MODULE_48__ = __webpack_require__(158); -/* harmony import */ var _components_framework_componentMetadataProvider__WEBPACK_IMPORTED_MODULE_49__ = __webpack_require__(159); -/* harmony import */ var _rendering_beans__WEBPACK_IMPORTED_MODULE_50__ = __webpack_require__(160); -/* harmony import */ var _environment__WEBPACK_IMPORTED_MODULE_51__ = __webpack_require__(161); -/* harmony import */ var _misc_animationFrameService__WEBPACK_IMPORTED_MODULE_52__ = __webpack_require__(162); -/* harmony import */ var _gridPanel_navigationService__WEBPACK_IMPORTED_MODULE_53__ = __webpack_require__(163); -/* harmony import */ var _rendering_maxDivHeightScaler__WEBPACK_IMPORTED_MODULE_54__ = __webpack_require__(164); -/* harmony import */ var _rowNodes_selectableService__WEBPACK_IMPORTED_MODULE_55__ = __webpack_require__(165); -/* harmony import */ var _rendering_autoHeightCalculator__WEBPACK_IMPORTED_MODULE_56__ = __webpack_require__(166); -/* harmony import */ var _pagination_paginationComp__WEBPACK_IMPORTED_MODULE_57__ = __webpack_require__(167); -/* harmony import */ var _misc_resizeObserverService__WEBPACK_IMPORTED_MODULE_58__ = __webpack_require__(168); -/* harmony import */ var _rendering_overlays_overlayWrapperComponent__WEBPACK_IMPORTED_MODULE_59__ = __webpack_require__(169); -/* harmony import */ var _widgets_agGroupComponent__WEBPACK_IMPORTED_MODULE_60__ = __webpack_require__(170); -/* harmony import */ var _widgets_agDialog__WEBPACK_IMPORTED_MODULE_61__ = __webpack_require__(171); -/* harmony import */ var _widgets_agPanel__WEBPACK_IMPORTED_MODULE_62__ = __webpack_require__(172); -/* harmony import */ var _widgets_agInputTextField__WEBPACK_IMPORTED_MODULE_63__ = __webpack_require__(173); -/* harmony import */ var _widgets_agInputTextArea__WEBPACK_IMPORTED_MODULE_64__ = __webpack_require__(174); -/* harmony import */ var _widgets_agSlider__WEBPACK_IMPORTED_MODULE_65__ = __webpack_require__(175); -/* harmony import */ var _widgets_agColorPicker__WEBPACK_IMPORTED_MODULE_66__ = __webpack_require__(176); -/* harmony import */ var _widgets_agInputNumberField__WEBPACK_IMPORTED_MODULE_67__ = __webpack_require__(179); -/* harmony import */ var _widgets_agInputRange__WEBPACK_IMPORTED_MODULE_68__ = __webpack_require__(180); -/* harmony import */ var _widgets_agSelect__WEBPACK_IMPORTED_MODULE_69__ = __webpack_require__(181); -/* harmony import */ var _widgets_agAngleSelect__WEBPACK_IMPORTED_MODULE_70__ = __webpack_require__(183); -/* harmony import */ var _widgets_agToggleButton__WEBPACK_IMPORTED_MODULE_71__ = __webpack_require__(184); -/* harmony import */ var _rendering_detailRowCompCache__WEBPACK_IMPORTED_MODULE_72__ = __webpack_require__(185); -/* harmony import */ var _entities_rowPosition__WEBPACK_IMPORTED_MODULE_73__ = __webpack_require__(186); -/* harmony import */ var _entities_cellPosition__WEBPACK_IMPORTED_MODULE_74__ = __webpack_require__(187); -/* harmony import */ var _pinnedRowModel_pinnedRowModel__WEBPACK_IMPORTED_MODULE_75__ = __webpack_require__(188); -/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_76__ = __webpack_require__(39); -/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_77__ = __webpack_require__(38); -/* harmony import */ var _undoRedo_undoRedoService__WEBPACK_IMPORTED_MODULE_78__ = __webpack_require__(189); -/* harmony import */ var _components_agStackComponentsRegistry__WEBPACK_IMPORTED_MODULE_79__ = __webpack_require__(191); -/* harmony import */ var _headerRendering_header_headerPosition__WEBPACK_IMPORTED_MODULE_80__ = __webpack_require__(192); -/* harmony import */ var _headerRendering_header_headerNavigationService__WEBPACK_IMPORTED_MODULE_81__ = __webpack_require__(124); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_82__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); -var Grid = /** @class */ (function () { - function Grid(eGridDiv, gridOptions, params) { - if (!eGridDiv) { - console.error('ag-Grid: no div element provided to the grid'); - return; - } - if (!gridOptions) { - console.error('ag-Grid: no gridOptions provided to the grid'); - return; - } - var debug = !!gridOptions.debug; - this.gridOptions = gridOptions; - var registeredModules = this.getRegisteredModules(params); - var beanClasses = this.createBeansList(registeredModules); - var providedBeanInstances = this.createProvidedBeans(eGridDiv, params); - if (!beanClasses) { - return; - } // happens when no row model found - var contextParams = { - providedBeanInstances: providedBeanInstances, - beanClasses: beanClasses, - debug: debug - }; - this.logger = new _logger__WEBPACK_IMPORTED_MODULE_16__["Logger"]('ag-Grid', function () { return gridOptions.debug; }); - var contextLogger = new _logger__WEBPACK_IMPORTED_MODULE_16__["Logger"]('Context', function () { return contextParams.debug; }); - this.context = new _context_context__WEBPACK_IMPORTED_MODULE_20__["Context"](contextParams, contextLogger); - this.registerModuleUserComponents(registeredModules); - this.registerStackComponents(registeredModules); - var gridCoreClass = (params && params.rootComponent) || _gridCore__WEBPACK_IMPORTED_MODULE_21__["GridCore"]; - var gridCore = new gridCoreClass(); - this.context.createBean(gridCore); - this.setColumnsAndData(); - this.dispatchGridReadyEvent(gridOptions); - var isEnterprise = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_76__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_77__["ModuleNames"].EnterpriseCoreModule); - this.logger.log("initialised successfully, enterprise = " + isEnterprise); - } - Grid.prototype.registerStackComponents = function (registeredModules) { - var agStackComponents = this.createAgStackComponentsList(registeredModules); - var agStackComponentsRegistry = this.context.getBean('agStackComponentsRegistry'); - agStackComponentsRegistry.setupComponents(agStackComponents); - }; - Grid.prototype.getRegisteredModules = function (params) { - var passedViaConstructor = params ? params.modules : null; - var registered = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_76__["ModuleRegistry"].getRegisteredModules(); - var allModules = []; - var mapNames = {}; - // adds to list and removes duplicates - function addModule(moduleBased, module) { - function addIndividualModule(module) { - if (!mapNames[module.moduleName]) { - mapNames[module.moduleName] = true; - allModules.push(module); - _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_76__["ModuleRegistry"].register(module, moduleBased); - } - } - addIndividualModule(module); - if (module.dependantModules) { - module.dependantModules.forEach(addModule.bind(null, moduleBased)); - } - } - if (passedViaConstructor) { - passedViaConstructor.forEach(addModule.bind(null, true)); - } - if (registered) { - registered.forEach(addModule.bind(null, !_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_76__["ModuleRegistry"].isPackageBased())); - } - return allModules; - }; - Grid.prototype.registerModuleUserComponents = function (registeredModules) { - var userComponentRegistry = this.context.getBean('userComponentRegistry'); - var moduleUserComps = this.extractModuleEntity(registeredModules, function (module) { return module.userComponents ? module.userComponents : []; }); - moduleUserComps.forEach(function (compMeta) { - userComponentRegistry.registerDefaultComponent(compMeta.componentName, compMeta.componentClass); - }); - }; - Grid.prototype.createProvidedBeans = function (eGridDiv, params) { - var frameworkOverrides = params ? params.frameworkOverrides : null; - if (_utils__WEBPACK_IMPORTED_MODULE_82__["_"].missing(frameworkOverrides)) { - frameworkOverrides = new _vanillaFrameworkOverrides__WEBPACK_IMPORTED_MODULE_34__["VanillaFrameworkOverrides"](); - } - var seed = { - gridOptions: this.gridOptions, - eGridDiv: eGridDiv, - $scope: params ? params.$scope : null, - $compile: params ? params.$compile : null, - quickFilterOnScope: params ? params.quickFilterOnScope : null, - globalEventListener: params ? params.globalEventListener : null, - frameworkOverrides: frameworkOverrides - }; - if (params && params.providedBeanInstances) { - _utils__WEBPACK_IMPORTED_MODULE_82__["_"].assign(seed, params.providedBeanInstances); - } - return seed; - }; - Grid.prototype.createAgStackComponentsList = function (registeredModules) { - var components = [ - { componentName: 'AgCheckbox', componentClass: _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_32__["AgCheckbox"] }, - { componentName: 'AgRadioButton', componentClass: _widgets_agRadioButton__WEBPACK_IMPORTED_MODULE_33__["AgRadioButton"] }, - { componentName: 'AgToggleButton', componentClass: _widgets_agToggleButton__WEBPACK_IMPORTED_MODULE_71__["AgToggleButton"] }, - { componentName: 'AgInputTextField', componentClass: _widgets_agInputTextField__WEBPACK_IMPORTED_MODULE_63__["AgInputTextField"] }, - { componentName: 'AgInputTextArea', componentClass: _widgets_agInputTextArea__WEBPACK_IMPORTED_MODULE_64__["AgInputTextArea"] }, - { componentName: 'AgInputNumberField', componentClass: _widgets_agInputNumberField__WEBPACK_IMPORTED_MODULE_67__["AgInputNumberField"] }, - { componentName: 'AgInputRange', componentClass: _widgets_agInputRange__WEBPACK_IMPORTED_MODULE_68__["AgInputRange"] }, - { componentName: 'AgSelect', componentClass: _widgets_agSelect__WEBPACK_IMPORTED_MODULE_69__["AgSelect"] }, - { componentName: 'AgSlider', componentClass: _widgets_agSlider__WEBPACK_IMPORTED_MODULE_65__["AgSlider"] }, - { componentName: 'AgAngleSelect', componentClass: _widgets_agAngleSelect__WEBPACK_IMPORTED_MODULE_70__["AgAngleSelect"] }, - { componentName: 'AgColorPicker', componentClass: _widgets_agColorPicker__WEBPACK_IMPORTED_MODULE_66__["AgColorPicker"] }, - { componentName: 'AgGridComp', componentClass: _gridPanel_gridPanel__WEBPACK_IMPORTED_MODULE_9__["GridPanel"] }, - { componentName: 'AgHeaderRoot', componentClass: _headerRendering_headerRootComp__WEBPACK_IMPORTED_MODULE_5__["HeaderRootComp"] }, - { componentName: 'AgPagination', componentClass: _pagination_paginationComp__WEBPACK_IMPORTED_MODULE_57__["PaginationComp"] }, - { componentName: 'AgOverlayWrapper', componentClass: _rendering_overlays_overlayWrapperComponent__WEBPACK_IMPORTED_MODULE_59__["OverlayWrapperComponent"] }, - { componentName: 'AgGroupComponent', componentClass: _widgets_agGroupComponent__WEBPACK_IMPORTED_MODULE_60__["AgGroupComponent"] }, - { componentName: 'AgPanel', componentClass: _widgets_agPanel__WEBPACK_IMPORTED_MODULE_62__["AgPanel"] }, - { componentName: 'AgDialog', componentClass: _widgets_agDialog__WEBPACK_IMPORTED_MODULE_61__["AgDialog"] } - ]; - var moduleAgStackComps = this.extractModuleEntity(registeredModules, function (module) { return module.agStackComponents ? module.agStackComponents : []; }); - components = components.concat(moduleAgStackComps); - return components; +var TooltipFeature = /** @class */ (function (_super) { + __extends(TooltipFeature, _super); + function TooltipFeature(ctrl, beans) { + var _this = _super.call(this) || this; + _this.ctrl = ctrl; + _this.beans = beans; + return _this; + } + TooltipFeature.prototype.setComp = function (comp) { + this.comp = comp; + this.setupTooltip(); }; - Grid.prototype.createBeansList = function (registeredModules) { - var rowModelClass = this.getRowModelClass(registeredModules); - if (!rowModelClass) { - return undefined; + TooltipFeature.prototype.setupTooltip = function () { + this.browserTooltips = this.beans.gridOptionsWrapper.isEnableBrowserTooltips(); + this.updateTooltipText(); + if (this.browserTooltips) { + this.comp.setTitle(this.tooltip != null ? this.tooltip : undefined); } - // beans should only contain SERVICES, it should NEVER contain COMPONENTS - var beans = [ - rowModelClass, _rendering_beans__WEBPACK_IMPORTED_MODULE_50__["Beans"], _entities_rowPosition__WEBPACK_IMPORTED_MODULE_73__["RowPositionUtils"], _entities_cellPosition__WEBPACK_IMPORTED_MODULE_74__["CellPositionUtils"], _headerRendering_header_headerPosition__WEBPACK_IMPORTED_MODULE_80__["HeaderPositionUtils"], - _pagination_paginationAutoPageSizeService__WEBPACK_IMPORTED_MODULE_41__["PaginationAutoPageSizeService"], _gridApi__WEBPACK_IMPORTED_MODULE_10__["GridApi"], _components_framework_userComponentRegistry__WEBPACK_IMPORTED_MODULE_47__["UserComponentRegistry"], _components_framework_agComponentUtils__WEBPACK_IMPORTED_MODULE_48__["AgComponentUtils"], - _components_framework_componentMetadataProvider__WEBPACK_IMPORTED_MODULE_49__["ComponentMetadataProvider"], _misc_resizeObserverService__WEBPACK_IMPORTED_MODULE_58__["ResizeObserverService"], _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_46__["UserComponentFactory"], - _rendering_maxDivHeightScaler__WEBPACK_IMPORTED_MODULE_54__["MaxDivHeightScaler"], _rendering_autoHeightCalculator__WEBPACK_IMPORTED_MODULE_56__["AutoHeightCalculator"], _rendering_cellRendererFactory__WEBPACK_IMPORTED_MODULE_30__["CellRendererFactory"], _headerRendering_horizontalResizeService__WEBPACK_IMPORTED_MODULE_19__["HorizontalResizeService"], - _pinnedRowModel_pinnedRowModel__WEBPACK_IMPORTED_MODULE_75__["PinnedRowModel"], _dragAndDrop_dragService__WEBPACK_IMPORTED_MODULE_24__["DragService"], _columnController_displayedGroupCreator__WEBPACK_IMPORTED_MODULE_12__["DisplayedGroupCreator"], _eventService__WEBPACK_IMPORTED_MODULE_8__["EventService"], _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"], - _widgets_popupService__WEBPACK_IMPORTED_MODULE_15__["PopupService"], _selectionController__WEBPACK_IMPORTED_MODULE_1__["SelectionController"], _filter_filterManager__WEBPACK_IMPORTED_MODULE_6__["FilterManager"], _columnController_columnController__WEBPACK_IMPORTED_MODULE_3__["ColumnController"], _headerRendering_header_headerNavigationService__WEBPACK_IMPORTED_MODULE_81__["HeaderNavigationService"], - _pagination_paginationProxy__WEBPACK_IMPORTED_MODULE_40__["PaginationProxy"], _rendering_rowRenderer__WEBPACK_IMPORTED_MODULE_4__["RowRenderer"], _valueService_expressionService__WEBPACK_IMPORTED_MODULE_13__["ExpressionService"], _columnController_columnFactory__WEBPACK_IMPORTED_MODULE_11__["ColumnFactory"], _templateService__WEBPACK_IMPORTED_MODULE_14__["TemplateService"], - _alignedGridsService__WEBPACK_IMPORTED_MODULE_45__["AlignedGridsService"], _gridPanel_navigationService__WEBPACK_IMPORTED_MODULE_53__["NavigationService"], _valueService_valueCache__WEBPACK_IMPORTED_MODULE_43__["ValueCache"], _valueService_valueService__WEBPACK_IMPORTED_MODULE_7__["ValueService"], _logger__WEBPACK_IMPORTED_MODULE_16__["LoggerFactory"], - _columnController_columnUtils__WEBPACK_IMPORTED_MODULE_17__["ColumnUtils"], _rendering_autoWidthCalculator__WEBPACK_IMPORTED_MODULE_18__["AutoWidthCalculator"], _headerRendering_standardMenu__WEBPACK_IMPORTED_MODULE_22__["StandardMenuFactory"], _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_23__["DragAndDropService"], _columnController_columnApi__WEBPACK_IMPORTED_MODULE_2__["ColumnApi"], - _focusController__WEBPACK_IMPORTED_MODULE_26__["FocusController"], _gridPanel_mouseEventService__WEBPACK_IMPORTED_MODULE_27__["MouseEventService"], _environment__WEBPACK_IMPORTED_MODULE_51__["Environment"], _cellNavigationService__WEBPACK_IMPORTED_MODULE_28__["CellNavigationService"], _rendering_valueFormatterService__WEBPACK_IMPORTED_MODULE_31__["ValueFormatterService"], - _styling_stylingService__WEBPACK_IMPORTED_MODULE_36__["StylingService"], _gridPanel_scrollVisibleService__WEBPACK_IMPORTED_MODULE_35__["ScrollVisibleService"], _sortController__WEBPACK_IMPORTED_MODULE_25__["SortController"], _rendering_columnHoverService__WEBPACK_IMPORTED_MODULE_37__["ColumnHoverService"], _rendering_columnAnimationService__WEBPACK_IMPORTED_MODULE_38__["ColumnAnimationService"], - _rowNodes_selectableService__WEBPACK_IMPORTED_MODULE_55__["SelectableService"], _columnController_autoGroupColService__WEBPACK_IMPORTED_MODULE_39__["AutoGroupColService"], _valueService_changeDetectionService__WEBPACK_IMPORTED_MODULE_44__["ChangeDetectionService"], _misc_animationFrameService__WEBPACK_IMPORTED_MODULE_52__["AnimationFrameService"], - _rendering_detailRowCompCache__WEBPACK_IMPORTED_MODULE_72__["DetailRowCompCache"], _undoRedo_undoRedoService__WEBPACK_IMPORTED_MODULE_78__["UndoRedoService"], _components_agStackComponentsRegistry__WEBPACK_IMPORTED_MODULE_79__["AgStackComponentsRegistry"] - ]; - var moduleBeans = this.extractModuleEntity(registeredModules, function (module) { return module.beans ? module.beans : []; }); - beans.push.apply(beans, moduleBeans); - // check for duplicates, as different modules could include the same beans that - // they depend on, eg ClientSideRowModel in enterprise, and ClientSideRowModel in community - var beansNoDuplicates = []; - beans.forEach(function (bean) { - if (beansNoDuplicates.indexOf(bean) < 0) { - beansNoDuplicates.push(bean); - } - }); - return beansNoDuplicates; - }; - Grid.prototype.extractModuleEntity = function (moduleEntities, extractor) { - return [].concat.apply([], moduleEntities.map(extractor)); - }; - Grid.prototype.setColumnsAndData = function () { - var gridOptionsWrapper = this.context.getBean('gridOptionsWrapper'); - var columnController = this.context.getBean('columnController'); - var columnDefs = gridOptionsWrapper.getColumnDefs(); - if (_utils__WEBPACK_IMPORTED_MODULE_82__["_"].exists(columnDefs)) { - columnController.setColumnDefs(columnDefs, "gridInitializing"); + else { + this.createTooltipFeatureIfNeeded(); } - var rowModel = this.context.getBean('rowModel'); - rowModel.start(); }; - Grid.prototype.dispatchGridReadyEvent = function (gridOptions) { - var eventService = this.context.getBean('eventService'); - var readyEvent = { - type: _events__WEBPACK_IMPORTED_MODULE_29__["Events"].EVENT_GRID_READY, - api: gridOptions.api, - columnApi: gridOptions.columnApi - }; - eventService.dispatchEvent(readyEvent); + TooltipFeature.prototype.updateTooltipText = function () { + this.tooltip = this.ctrl.getTooltipValue(); }; - Grid.prototype.getRowModelClass = function (registeredModules) { - var rowModelType = this.gridOptions.rowModelType; - //TODO: temporary measure before 'enterprise' is completely removed (similar handling in gridOptionsWrapper is also required) - if (rowModelType === 'enterprise') { - console.warn("ag-Grid: enterprise rowModel deprecated. Should now be called server side row model instead."); - rowModelType = _constants__WEBPACK_IMPORTED_MODULE_42__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE; - } - if (rowModelType === 'normal') { - console.warn("ag-Grid: normal rowModel deprecated. Should now be called client side row model instead."); - rowModelType = _constants__WEBPACK_IMPORTED_MODULE_42__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE; - } - // default to client side - if (!rowModelType) { - rowModelType = _constants__WEBPACK_IMPORTED_MODULE_42__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE; - } - var rowModelClasses = {}; - registeredModules.forEach(function (module) { - _utils__WEBPACK_IMPORTED_MODULE_82__["_"].iterateObject(module.rowModels, function (key, value) { - rowModelClasses[key] = value; - }); - }); - var rowModelClass = rowModelClasses[rowModelType]; - if (_utils__WEBPACK_IMPORTED_MODULE_82__["_"].exists(rowModelClass)) { - return rowModelClass; + TooltipFeature.prototype.createTooltipFeatureIfNeeded = function () { + var _this = this; + if (this.genericTooltipFeature != null) { + return; } - else { - if (rowModelType === _constants__WEBPACK_IMPORTED_MODULE_42__["Constants"].ROW_MODEL_TYPE_INFINITE) { - console.error("ag-Grid: Row Model \"Infinite\" not found. Please ensure the " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_77__["ModuleNames"].InfiniteRowModelModule + " is registered.';"); - } - console.error('ag-Grid: could not find matching row model for rowModelType ' + rowModelType); - if (rowModelType === _constants__WEBPACK_IMPORTED_MODULE_42__["Constants"].ROW_MODEL_TYPE_VIEWPORT) { - console.error("ag-Grid: Row Model \"Viewport\" not found. Please ensure the ag-Grid Enterprise Module " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_77__["ModuleNames"].ViewportRowModelModule + " is registered.';"); - } - if (rowModelType === _constants__WEBPACK_IMPORTED_MODULE_42__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE) { - console.error("ag-Grid: Row Model \"Server Side\" not found. Please ensure the ag-Grid Enterprise Module " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_77__["ModuleNames"].ServerSideRowModelModule + " is registered.';"); - } - if (rowModelType === _constants__WEBPACK_IMPORTED_MODULE_42__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) { - console.error("ag-Grid: Row Model \"Client Side\" not found. Please ensure the " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_77__["ModuleNames"].ClientSideRowModelModule + " is registered.';"); - } - return undefined; + var parent = { + getTooltipParams: function () { return _this.getTooltipParams(); }, + getGui: function () { return _this.ctrl.getGui(); } + }; + this.genericTooltipFeature = this.createManagedBean(new _customTooltipFeature__WEBPACK_IMPORTED_MODULE_1__["CustomTooltipFeature"](parent), this.beans.context); + }; + TooltipFeature.prototype.refreshToolTip = function () { + this.updateTooltipText(); + if (this.browserTooltips) { + this.comp.setTitle(this.tooltip != null ? this.tooltip : undefined); } }; - Grid.prototype.destroy = function () { - this.gridOptions.api.destroy(); + TooltipFeature.prototype.getTooltipParams = function () { + var ctrl = this.ctrl; + var column = ctrl.getColumn ? ctrl.getColumn() : undefined; + var colDef = ctrl.getColDef ? ctrl.getColDef() : undefined; + var rowNode = ctrl.getRowNode ? ctrl.getRowNode() : undefined; + return { + location: ctrl.getLocation(), + colDef: colDef, + column: column, + rowIndex: ctrl.getRowIndex ? ctrl.getRowIndex() : undefined, + node: rowNode, + data: rowNode ? rowNode.data : undefined, + value: this.getTooltipText(), + valueFormatted: ctrl.getValueFormatted ? ctrl.getValueFormatted() : undefined + }; }; - return Grid; -}()); + TooltipFeature.prototype.getTooltipText = function () { + return this.tooltip; + }; + // overriding to make public, as we don't dispose this bean via context + TooltipFeature.prototype.destroy = function () { + _super.prototype.destroy.call(this); + }; + return TooltipFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 96 */ +/* 120 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SelectionController", function() { return SelectionController; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25); -/* harmony import */ var _utils_changedPath__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(97); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellMouseListenerFeature", function() { return CellMouseListenerFeature; }); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(23); +/* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(42); +/* harmony import */ var _utils_event__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(21); +/* harmony import */ var _beans__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(121); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -19128,709 +27577,548 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { - return function (target, key) { decorator(target, key, paramIndex); } -}; - - - - -var SelectionController = /** @class */ (function (_super) { - __extends(SelectionController, _super); - function SelectionController() { - return _super !== null && _super.apply(this, arguments) || this; +var CellMouseListenerFeature = /** @class */ (function (_super) { + __extends(CellMouseListenerFeature, _super); + function CellMouseListenerFeature(ctrl, beans, column) { + var _this = _super.call(this) || this; + _this.cellCtrl = ctrl; + _this.beans = beans; + _this.column = column; + return _this; } - SelectionController.prototype.setBeans = function (loggerFactory) { - this.logger = loggerFactory.create('SelectionController'); - this.reset(); - if (this.gridOptionsWrapper.isRowModelDefault()) { - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DATA_CHANGED, this.reset.bind(this)); - } - }; - SelectionController.prototype.init = function () { - this.groupSelectsChildren = this.gridOptionsWrapper.isGroupSelectsChildren(); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_SELECTED, this.onRowSelected.bind(this)); - }; - SelectionController.prototype.setLastSelectedNode = function (rowNode) { - this.lastSelectedNode = rowNode; - }; - SelectionController.prototype.getLastSelectedNode = function () { - return this.lastSelectedNode; - }; - SelectionController.prototype.getSelectedNodes = function () { - var selectedNodes = []; - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(this.selectedNodes, function (key, rowNode) { - if (rowNode) { - selectedNodes.push(rowNode); - } - }); - return selectedNodes; - }; - SelectionController.prototype.getSelectedRows = function () { - var selectedRows = []; - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(this.selectedNodes, function (key, rowNode) { - if (rowNode && rowNode.data) { - selectedRows.push(rowNode.data); - } - }); - return selectedRows; - }; - SelectionController.prototype.removeGroupsFromSelection = function () { - var _this = this; - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(this.selectedNodes, function (key, rowNode) { - if (rowNode && rowNode.group) { - _this.selectedNodes[rowNode.id] = undefined; - } - }); - }; - // should only be called if groupSelectsChildren=true - SelectionController.prototype.updateGroupsFromChildrenSelections = function (changedPath) { - // we only do this when group selection state depends on selected children - if (!this.gridOptionsWrapper.isGroupSelectsChildren()) { - return; - } - // also only do it if CSRM (code should never allow this anyway) - if (this.rowModel.getType() !== _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) { + CellMouseListenerFeature.prototype.onMouseEvent = function (eventName, mouseEvent) { + if (Object(_utils_event__WEBPACK_IMPORTED_MODULE_3__["isStopPropagationForAgGrid"])(mouseEvent)) { return; } - var clientSideRowModel = this.rowModel; - var rootNode = clientSideRowModel.getRootNode(); - if (!changedPath) { - changedPath = new _utils_changedPath__WEBPACK_IMPORTED_MODULE_4__["ChangedPath"](true, rootNode); - changedPath.setInactive(); + switch (eventName) { + case 'click': + this.onCellClicked(mouseEvent); + break; + case 'mousedown': + case 'touchstart': + this.onMouseDown(mouseEvent); + break; + case 'dblclick': + this.onCellDoubleClicked(mouseEvent); + break; + case 'mouseout': + this.onMouseOut(mouseEvent); + break; + case 'mouseover': + this.onMouseOver(mouseEvent); + break; } - changedPath.forEachChangedNodeDepthFirst(function (rowNode) { - if (rowNode !== rootNode) { - rowNode.calculateSelectedFromChildren(); - } - }); - // clientSideRowModel.getTopLevelNodes()!.forEach((rowNode: RowNode) => { - // rowNode.depthFirstSearch((node) => { - // if (node.group) { - // } - // }); - // }); - }; - SelectionController.prototype.getNodeForIdIfSelected = function (id) { - return this.selectedNodes[id]; - }; - SelectionController.prototype.clearOtherNodes = function (rowNodeToKeepSelected) { - var _this = this; - var groupsToRefresh = {}; - var updatedCount = 0; - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(this.selectedNodes, function (key, otherRowNode) { - if (otherRowNode && otherRowNode.id !== rowNodeToKeepSelected.id) { - var rowNode = _this.selectedNodes[otherRowNode.id]; - updatedCount += rowNode.setSelectedParams({ - newValue: false, - clearSelection: false, - suppressFinishActions: true - }); - if (_this.groupSelectsChildren && otherRowNode.parent) { - groupsToRefresh[otherRowNode.parent.id] = otherRowNode.parent; - } - } - }); - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(groupsToRefresh, function (key, group) { - group.calculateSelectedFromChildren(); - }); - return updatedCount; }; - SelectionController.prototype.onRowSelected = function (event) { - var rowNode = event.node; - // we do not store the group rows when the groups select children - if (this.groupSelectsChildren && rowNode.group) { + CellMouseListenerFeature.prototype.onCellClicked = function (mouseEvent) { + // iPad doesn't have double click - so we need to mimic it to enable editing for iPad. + if (this.isDoubleClickOnIPad()) { + this.onCellDoubleClicked(mouseEvent); + mouseEvent.preventDefault(); // if we don't do this, then iPad zooms in return; } - if (rowNode.isSelected()) { - this.selectedNodes[rowNode.id] = rowNode; + var _a = this.beans, eventService = _a.eventService, gridOptionsWrapper = _a.gridOptionsWrapper; + var cellClickedEvent = this.cellCtrl.createEvent(mouseEvent, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_CELL_CLICKED); + eventService.dispatchEvent(cellClickedEvent); + var colDef = this.column.getColDef(); + if (colDef.onCellClicked) { + // to make callback async, do in a timeout + window.setTimeout(function () { return colDef.onCellClicked(cellClickedEvent); }, 0); } - else { - this.selectedNodes[rowNode.id] = undefined; + var editOnSingleClick = (gridOptionsWrapper.isSingleClickEdit() || colDef.singleClickEdit) + && !gridOptionsWrapper.isSuppressClickEdit(); + if (editOnSingleClick) { + this.cellCtrl.startRowOrCellEdit(); } }; - SelectionController.prototype.syncInRowNode = function (rowNode, oldNode) { - this.syncInOldRowNode(rowNode, oldNode); - this.syncInNewRowNode(rowNode); - }; - // if the id has changed for the node, then this means the rowNode - // is getting used for a different data item, which breaks - // our selectedNodes, as the node now is mapped by the old id - // which is inconsistent. so to keep the old node as selected, - // we swap in the clone (with the old id and old data). this means - // the oldNode is effectively a daemon we keep a reference to, - // so if client calls api.getSelectedNodes(), it gets the daemon - // in the result. when the client un-selects, the reference to the - // daemon is removed. the daemon, because it's an oldNode, is not - // used by the grid for rendering, it's a copy of what the node used - // to be like before the id was changed. - SelectionController.prototype.syncInOldRowNode = function (rowNode, oldNode) { - var oldNodeHasDifferentId = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(oldNode) && (rowNode.id !== oldNode.id); - if (oldNodeHasDifferentId) { - var oldNodeSelected = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(this.selectedNodes[oldNode.id]); - if (oldNodeSelected) { - this.selectedNodes[oldNode.id] = oldNode; - } + // returns true if on iPad and this is second 'click' event in 200ms + CellMouseListenerFeature.prototype.isDoubleClickOnIPad = function () { + if (!Object(_utils_browser__WEBPACK_IMPORTED_MODULE_1__["isIOSUserAgent"])() || Object(_utils_event__WEBPACK_IMPORTED_MODULE_3__["isEventSupported"])('dblclick')) { + return false; } + var nowMillis = new Date().getTime(); + var res = nowMillis - this.lastIPadMouseClickEvent < 200; + this.lastIPadMouseClickEvent = nowMillis; + return res; }; - SelectionController.prototype.syncInNewRowNode = function (rowNode) { - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(this.selectedNodes[rowNode.id])) { - rowNode.setSelectedInitialValue(true); - this.selectedNodes[rowNode.id] = rowNode; + CellMouseListenerFeature.prototype.onCellDoubleClicked = function (mouseEvent) { + var colDef = this.column.getColDef(); + // always dispatch event to eventService + var cellDoubleClickedEvent = this.cellCtrl.createEvent(mouseEvent, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_CELL_DOUBLE_CLICKED); + this.beans.eventService.dispatchEvent(cellDoubleClickedEvent); + // check if colDef also wants to handle event + if (typeof colDef.onCellDoubleClicked === 'function') { + // to make the callback async, do in a timeout + window.setTimeout(function () { return colDef.onCellDoubleClicked(cellDoubleClickedEvent); }, 0); } - else { - rowNode.setSelectedInitialValue(false); + var editOnDoubleClick = !this.beans.gridOptionsWrapper.isSingleClickEdit() + && !this.beans.gridOptionsWrapper.isSuppressClickEdit(); + if (editOnDoubleClick) { + this.cellCtrl.startRowOrCellEdit(null, null, mouseEvent); } }; - SelectionController.prototype.reset = function () { - this.logger.log('reset'); - this.selectedNodes = {}; - this.lastSelectedNode = null; - }; - // returns a list of all nodes at 'best cost' - a feature to be used - // with groups / trees. if a group has all it's children selected, - // then the group appears in the result, but not the children. - // Designed for use with 'children' as the group selection type, - // where groups don't actually appear in the selection normally. - SelectionController.prototype.getBestCostNodeSelection = function () { - if (this.rowModel.getType() !== _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) { - console.warn('getBestCostNodeSelection is only available when using normal row model'); + CellMouseListenerFeature.prototype.onMouseDown = function (mouseEvent) { + var ctrlKey = mouseEvent.ctrlKey, metaKey = mouseEvent.metaKey, shiftKey = mouseEvent.shiftKey; + var target = mouseEvent.target; + var _a = this.beans, eventService = _a.eventService, rangeService = _a.rangeService; + // do not change the range for right-clicks inside an existing range + if (this.isRightClickInExistingRange(mouseEvent)) { return; } - var clientSideRowModel = this.rowModel; - var topLevelNodes = clientSideRowModel.getTopLevelNodes(); - if (topLevelNodes === null) { - console.warn('selectAll not available doing rowModel=virtual'); + var ranges = rangeService && rangeService.getCellRanges().length != 0; + if (!shiftKey || !ranges) { + // We only need to pass true to focusCell when the browser is IE/Edge and we are trying + // to focus the cell itself. This should never be true if the mousedown was triggered + // due to a click on a cell editor for example. + var forceBrowserFocus = (Object(_utils_browser__WEBPACK_IMPORTED_MODULE_1__["isBrowserEdge"])()) && !this.cellCtrl.isEditing() && !Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["isFocusableFormField"])(target); + this.cellCtrl.focusCell(forceBrowserFocus); + } + // if shift clicking, and a range exists, we keep the focus on the cell that started the + // range as the user then changes the range selection. + if (shiftKey && ranges) { + // this stops the cell from getting focused + mouseEvent.preventDefault(); + } + // if we are clicking on a checkbox, we need to make sure the cell wrapping that checkbox + // is focused but we don't want to change the range selection, so return here. + if (this.containsWidget(target)) { return; } - var result = []; - // recursive function, to find the selected nodes - function traverse(nodes) { - for (var i = 0, l = nodes.length; i < l; i++) { - var node = nodes[i]; - if (node.isSelected()) { - result.push(node); - } - else { - // if not selected, then if it's a group, and the group - // has children, continue to search for selections - if (node.group && node.children) { - traverse(node.children); - } - } + if (rangeService) { + var thisCell = this.cellCtrl.getCellPosition(); + if (shiftKey) { + rangeService.extendLatestRangeToCell(thisCell); } - } - traverse(topLevelNodes); - return result; - }; - SelectionController.prototype.setRowModel = function (rowModel) { - this.rowModel = rowModel; - }; - SelectionController.prototype.isEmpty = function () { - var count = 0; - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(this.selectedNodes, function (nodeId, rowNode) { - if (rowNode) { - count++; + else { + var ctrlKeyPressed = ctrlKey || metaKey; + rangeService.setRangeToCell(thisCell, ctrlKeyPressed); } - }); - return count === 0; + } + eventService.dispatchEvent(this.cellCtrl.createEvent(mouseEvent, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_CELL_MOUSE_DOWN)); }; - SelectionController.prototype.deselectAllRowNodes = function (justFiltered) { - if (justFiltered === void 0) { justFiltered = false; } - var callback = function (rowNode) { return rowNode.selectThisNode(false); }; - var rowModelClientSide = this.rowModel.getType() === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE; - if (justFiltered) { - if (!rowModelClientSide) { - console.error('ag-Grid: selecting just filtered only works with In Memory Row Model'); - return; + CellMouseListenerFeature.prototype.isRightClickInExistingRange = function (mouseEvent) { + var rangeService = this.beans.rangeService; + if (rangeService) { + var cellInRange = rangeService.isCellInAnyRange(this.cellCtrl.getCellPosition()); + if (cellInRange && mouseEvent.button === 2) { + return true; } - var clientSideRowModel = this.rowModel; - clientSideRowModel.forEachNodeAfterFilter(callback); - } - else { - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(this.selectedNodes, function (id, rowNode) { - // remember the reference can be to null, as we never 'delete' from the map - if (rowNode) { - callback(rowNode); - } - }); - // this clears down the map (whereas above only sets the items in map to 'undefined') - this.reset(); - } - // the above does not clean up the parent rows if they are selected - if (rowModelClientSide && this.groupSelectsChildren) { - this.updateGroupsFromChildrenSelections(); } - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_SELECTION_CHANGED, - api: this.gridApi, - columnApi: this.columnApi - }; - this.eventService.dispatchEvent(event); + return false; }; - SelectionController.prototype.selectAllRowNodes = function (justFiltered) { - if (justFiltered === void 0) { justFiltered = false; } - if (this.rowModel.getType() !== _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) { - throw new Error("selectAll only available with normal row model, ie not " + this.rowModel.getType()); - } - var clientSideRowModel = this.rowModel; - var callback = function (rowNode) { return rowNode.selectThisNode(true); }; - if (justFiltered) { - clientSideRowModel.forEachNodeAfterFilter(callback); - } - else { - clientSideRowModel.forEachNode(callback); - } - // the above does not clean up the parent rows if they are selected - if (this.rowModel.getType() === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE && this.groupSelectsChildren) { - this.updateGroupsFromChildrenSelections(); - } - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_SELECTION_CHANGED, - api: this.gridApi, - columnApi: this.columnApi - }; - this.eventService.dispatchEvent(event); + CellMouseListenerFeature.prototype.containsWidget = function (target) { + return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["isElementChildOfClass"])(target, 'ag-selection-checkbox', 3); }; - /** - * @method - * @deprecated - */ - SelectionController.prototype.selectNode = function (rowNode, tryMulti) { - if (rowNode) { - rowNode.setSelectedParams({ newValue: true, clearSelection: !tryMulti }); + CellMouseListenerFeature.prototype.onMouseOut = function (mouseEvent) { + if (this.mouseStayingInsideCell(mouseEvent)) { + return; } + var cellMouseOutEvent = this.cellCtrl.createEvent(mouseEvent, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_CELL_MOUSE_OUT); + this.beans.eventService.dispatchEvent(cellMouseOutEvent); + this.beans.columnHoverService.clearMouseOver(); }; - /** - * @method - * @deprecated - */ - SelectionController.prototype.deselectIndex = function (rowIndex) { - var node = this.rowModel.getRow(rowIndex); - this.deselectNode(node); + CellMouseListenerFeature.prototype.onMouseOver = function (mouseEvent) { + if (this.mouseStayingInsideCell(mouseEvent)) { + return; + } + var cellMouseOverEvent = this.cellCtrl.createEvent(mouseEvent, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_CELL_MOUSE_OVER); + this.beans.eventService.dispatchEvent(cellMouseOverEvent); + this.beans.columnHoverService.setMouseOver([this.column]); }; - /** - * @method - * @deprecated - */ - SelectionController.prototype.deselectNode = function (rowNode) { - if (rowNode) { - rowNode.setSelectedParams({ newValue: false, clearSelection: false }); + CellMouseListenerFeature.prototype.mouseStayingInsideCell = function (e) { + if (!e.target || !e.relatedTarget) { + return false; } + var eGui = this.cellCtrl.getGui(); + var cellContainsTarget = eGui.contains(e.target); + var cellContainsRelatedTarget = eGui.contains(e.relatedTarget); + return cellContainsTarget && cellContainsRelatedTarget; }; - /** - * @method - * @deprecated - */ - SelectionController.prototype.selectIndex = function (index, tryMulti) { - var node = this.rowModel.getRow(index); - this.selectNode(node, tryMulti); + CellMouseListenerFeature.prototype.destroy = function () { }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel') - ], SelectionController.prototype, "rowModel", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], SelectionController.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') - ], SelectionController.prototype, "columnApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') - ], SelectionController.prototype, "gridApi", void 0); - __decorate([ - __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('loggerFactory')) - ], SelectionController.prototype, "setBeans", null); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], SelectionController.prototype, "init", null); - SelectionController = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('selectionController') - ], SelectionController); - return SelectionController; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + return CellMouseListenerFeature; +}(_beans__WEBPACK_IMPORTED_MODULE_4__["Beans"])); /***/ }), -/* 97 */ +/* 121 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ChangedPath", function() { return ChangedPath; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Beans", function() { return Beans; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -// when doing transactions, or change detection, and grouping is present -// in the data, there is no need for the ClientSideRowModel to update each -// group after an update, ony parts that were impacted by the change. -// this class keeps track of all groups that were impacted by a transaction. -// the the different CSRM operations (filter, sort etc) use the forEach method -// to visit each group that was changed. -var ChangedPath = /** @class */ (function () { - function ChangedPath(keepingColumns, rootNode) { - // whether changed path is active of not. it is active when a) doing - // a transaction update or b) doing change detection. if we are doing - // a CSRM refresh for other reasons (after sort or filter, or user calling - // setRowData() without delta mode) then we are not active. we are also - // marked as not active if secondary columns change in pivot (as this impacts - // aggregations) - this.active = true; - // for each node in the change path, we also store which columns need - // to be re-aggregated. - this.nodeIdsToColumns = {}; - // for quick lookup, all items in the change path are mapped by nodeId - this.mapToItems = {}; - this.keepingColumns = keepingColumns; - this.pathRoot = { - rowNode: rootNode, - children: null - }; - this.mapToItems[rootNode.id] = this.pathRoot; +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + +/** Using the IoC has a slight performance consideration, which is no problem most of the + * time, unless we are trashing objects - which is the case when scrolling and rowComp + * and cellComp. So for performance reasons, RowComp and CellComp do not get autowired + * with the IoC. Instead they get passed this object which is all the beans the RowComp + * and CellComp need. Not autowiring all the cells gives performance improvement. */ +var Beans = /** @class */ (function () { + function Beans() { } - // can be set inactive by: - // a) ClientSideRowModel, if no transactions or - // b) PivotService, if secondary columns changed - ChangedPath.prototype.setInactive = function () { - this.active = false; - }; - ChangedPath.prototype.isActive = function () { - return this.active; - }; - ChangedPath.prototype.depthFirstSearchChangedPath = function (pathItem, callback) { - if (pathItem.children) { - for (var i = 0; i < pathItem.children.length; i++) { - this.depthFirstSearchChangedPath(pathItem.children[i], callback); - } - } - callback(pathItem.rowNode); - }; - ChangedPath.prototype.depthFirstSearchEverything = function (rowNode, callback, traverseEverything) { - if (rowNode.childrenAfterGroup) { - for (var i = 0; i < rowNode.childrenAfterGroup.length; i++) { - var childNode = rowNode.childrenAfterGroup[i]; - if (childNode.childrenAfterGroup) { - this.depthFirstSearchEverything(rowNode.childrenAfterGroup[i], callback, traverseEverything); - } - else if (traverseEverything) { - callback(childNode); - } - } - } - callback(rowNode); - }; - // traverseLeafNodes -> used when NOT doing changed path, ie traversing everything. the callback - // will be called for child nodes in addition to parent nodes. - ChangedPath.prototype.forEachChangedNodeDepthFirst = function (callback, traverseLeafNodes) { - if (traverseLeafNodes === void 0) { traverseLeafNodes = false; } - if (this.active) { - // if we are active, then use the change path to callback - // only for updated groups - this.depthFirstSearchChangedPath(this.pathRoot, callback); - } - else { - // we are not active, so callback for everything, walk the entire path - this.depthFirstSearchEverything(this.pathRoot.rowNode, callback, traverseLeafNodes); - } - }; - ChangedPath.prototype.executeFromRootNode = function (callback) { - callback(this.pathRoot.rowNode); - }; - ChangedPath.prototype.createPathItems = function (rowNode) { - var pointer = rowNode; - var newEntryCount = 0; - while (!this.mapToItems[pointer.id]) { - var newEntry = { - rowNode: pointer, - children: null - }; - this.mapToItems[pointer.id] = newEntry; - newEntryCount++; - pointer = pointer.parent; - } - return newEntryCount; - }; - ChangedPath.prototype.populateColumnsMap = function (rowNode, columns) { - var _this = this; - if (!this.keepingColumns || !columns) { - return; - } - var pointer = rowNode; - while (pointer) { - // if columns, add the columns in all the way to parent, merging - // in any other columns that might be there already - if (!this.nodeIdsToColumns[pointer.id]) { - this.nodeIdsToColumns[pointer.id] = {}; - } - columns.forEach(function (col) { return _this.nodeIdsToColumns[pointer.id][col.getId()] = true; }); - pointer = pointer.parent; - } - }; - ChangedPath.prototype.linkPathItems = function (rowNode, newEntryCount) { - var pointer = rowNode; - for (var i = 0; i < newEntryCount; i++) { - var thisItem = this.mapToItems[pointer.id]; - var parentItem = this.mapToItems[pointer.parent.id]; - if (!parentItem.children) { - parentItem.children = []; - } - parentItem.children.push(thisItem); - pointer = pointer.parent; - } - }; - // called by - // 1) change detection (provides cols) and - // 2) groupStage if doing transaction update (doesn't provide cols) - ChangedPath.prototype.addParentNode = function (rowNode, columns) { - if (!rowNode || rowNode.isRowPinned()) { - return; - } - // we cannot do both steps below in the same loop as - // the second loop has a dependency on the first loop. - // ie the hierarchy cannot be stitched up yet because - // we don't have it built yet - // create the new PathItem objects. - var newEntryCount = this.createPathItems(rowNode); - // link in the node items - this.linkPathItems(rowNode, newEntryCount); - // update columns - this.populateColumnsMap(rowNode, columns); - }; - ChangedPath.prototype.canSkip = function (rowNode) { - return this.active && !this.mapToItems[rowNode.id]; - }; - ChangedPath.prototype.getValueColumnsForNode = function (rowNode, valueColumns) { - if (!this.keepingColumns) { - return valueColumns; + Beans.prototype.postConstruct = function () { + this.doingMasterDetail = this.gridOptionsWrapper.isMasterDetail(); + if (this.gridOptionsWrapper.isRowModelDefault()) { + this.clientSideRowModel = this.rowModel; } - var colsForThisNode = this.nodeIdsToColumns[rowNode.id]; - var result = valueColumns.filter(function (col) { return colsForThisNode[col.getId()]; }); - return result; - }; - ChangedPath.prototype.getNotValueColumnsForNode = function (rowNode, valueColumns) { - if (!this.keepingColumns) { - return null; + if (this.gridOptionsWrapper.isRowModelServerSide()) { + this.serverSideRowModel = this.rowModel; } - var colsForThisNode = this.nodeIdsToColumns[rowNode.id]; - var result = valueColumns.filter(function (col) { return !colsForThisNode[col.getId()]; }); - return result; }; - return ChangedPath; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('resizeObserverService') + ], Beans.prototype, "resizeObserverService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('paginationProxy') + ], Beans.prototype, "paginationProxy", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('context') + ], Beans.prototype, "context", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') + ], Beans.prototype, "columnApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') + ], Beans.prototype, "gridApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') + ], Beans.prototype, "gridOptionsWrapper", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('expressionService') + ], Beans.prototype, "expressionService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer') + ], Beans.prototype, "rowRenderer", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('$compile') + ], Beans.prototype, "$compile", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('templateService') + ], Beans.prototype, "templateService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueService') + ], Beans.prototype, "valueService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('eventService') + ], Beans.prototype, "eventService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], Beans.prototype, "columnModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('headerNavigationService') + ], Beans.prototype, "headerNavigationService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('navigationService') + ], Beans.prototype, "navigationService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnAnimationService') + ], Beans.prototype, "columnAnimationService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('rangeService') + ], Beans.prototype, "rangeService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusService') + ], Beans.prototype, "focusService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('contextMenuFactory') + ], Beans.prototype, "contextMenuFactory", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('popupService') + ], Beans.prototype, "popupService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueFormatterService') + ], Beans.prototype, "valueFormatterService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('stylingService') + ], Beans.prototype, "stylingService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnHoverService') + ], Beans.prototype, "columnHoverService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('userComponentFactory') + ], Beans.prototype, "userComponentFactory", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('userComponentRegistry') + ], Beans.prototype, "userComponentRegistry", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('animationFrameService') + ], Beans.prototype, "animationFrameService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('dragAndDropService') + ], Beans.prototype, "dragAndDropService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('sortController') + ], Beans.prototype, "sortController", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager') + ], Beans.prototype, "filterManager", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowContainerHeightService') + ], Beans.prototype, "rowContainerHeightService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('frameworkOverrides') + ], Beans.prototype, "frameworkOverrides", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('cellPositionUtils') + ], Beans.prototype, "cellPositionUtils", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowPositionUtils') + ], Beans.prototype, "rowPositionUtils", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('selectionService') + ], Beans.prototype, "selectionService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('selectionHandleFactory') + ], Beans.prototype, "selectionHandleFactory", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowCssClassCalculator') + ], Beans.prototype, "rowCssClassCalculator", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel') + ], Beans.prototype, "rowModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('ctrlsService') + ], Beans.prototype, "ctrlsService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('ctrlsFactory') + ], Beans.prototype, "ctrlsFactory", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('agStackComponentsRegistry') + ], Beans.prototype, "agStackComponentsRegistry", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueCache') + ], Beans.prototype, "valueCache", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowNodeEventThrottle') + ], Beans.prototype, "rowNodeEventThrottle", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], Beans.prototype, "postConstruct", null); + Beans = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('beans') + ], Beans); + return Beans; }()); /***/ }), -/* 98 */ +/* 122 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnApi", function() { return ColumnApi; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellKeyboardListenerFeature", function() { return CellKeyboardListenerFeature; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(65); +/* harmony import */ var _utils_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(49); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); -var ColumnApi = /** @class */ (function () { - function ColumnApi() { + + +var CellKeyboardListenerFeature = /** @class */ (function (_super) { + __extends(CellKeyboardListenerFeature, _super); + function CellKeyboardListenerFeature(ctrl, beans, column, rowNode, scope, rowCtrl) { + var _this = _super.call(this) || this; + _this.cellCtrl = ctrl; + _this.beans = beans; + _this.rowNode = rowNode; + _this.rowCtrl = rowCtrl; + return _this; } - ColumnApi.prototype.sizeColumnsToFit = function (gridWidth) { - // AG-3403 validate that gridWidth is provided because this method has the same name as - // a method on the grid API that takes no arguments, and it's easy to confuse the two - if (typeof gridWidth === "undefined") { - console.error('ag-Grid: missing parameter to columnApi.sizeColumnsToFit(gridWidth)'); - } - this.columnController.sizeColumnsToFit(gridWidth, 'api'); - }; - ColumnApi.prototype.setColumnGroupOpened = function (group, newValue) { this.columnController.setColumnGroupOpened(group, newValue, 'api'); }; - ColumnApi.prototype.getColumnGroup = function (name, instanceId) { return this.columnController.getColumnGroup(name, instanceId); }; - ColumnApi.prototype.getOriginalColumnGroup = function (name) { return this.columnController.getOriginalColumnGroup(name); }; - ColumnApi.prototype.getDisplayNameForColumn = function (column, location) { return this.columnController.getDisplayNameForColumn(column, location) || ''; }; - ColumnApi.prototype.getDisplayNameForColumnGroup = function (columnGroup, location) { return this.columnController.getDisplayNameForColumnGroup(columnGroup, location) || ''; }; - ColumnApi.prototype.getColumn = function (key) { return this.columnController.getPrimaryColumn(key); }; - ColumnApi.prototype.setColumnState = function (columnState) { return this.columnController.setColumnState(columnState, false, 'api'); }; - ColumnApi.prototype.getColumnState = function () { return this.columnController.getColumnState(); }; - ColumnApi.prototype.resetColumnState = function () { this.columnController.resetColumnState(false, 'api'); }; - ColumnApi.prototype.getColumnGroupState = function () { return this.columnController.getColumnGroupState(); }; - ColumnApi.prototype.setColumnGroupState = function (stateItems) { this.columnController.setColumnGroupState(stateItems, 'api'); }; - ColumnApi.prototype.resetColumnGroupState = function () { this.columnController.resetColumnGroupState('api'); }; - ColumnApi.prototype.isPinning = function () { return this.columnController.isPinningLeft() || this.columnController.isPinningRight(); }; - ColumnApi.prototype.isPinningLeft = function () { return this.columnController.isPinningLeft(); }; - ColumnApi.prototype.isPinningRight = function () { return this.columnController.isPinningRight(); }; - ColumnApi.prototype.getDisplayedColAfter = function (col) { return this.columnController.getDisplayedColAfter(col); }; - ColumnApi.prototype.getDisplayedColBefore = function (col) { return this.columnController.getDisplayedColBefore(col); }; - ColumnApi.prototype.setColumnVisible = function (key, visible) { this.columnController.setColumnVisible(key, visible, 'api'); }; - ColumnApi.prototype.setColumnsVisible = function (keys, visible) { this.columnController.setColumnsVisible(keys, visible, 'api'); }; - ColumnApi.prototype.setColumnPinned = function (key, pinned) { this.columnController.setColumnPinned(key, pinned, 'api'); }; - ColumnApi.prototype.setColumnsPinned = function (keys, pinned) { this.columnController.setColumnsPinned(keys, pinned, 'api'); }; - ColumnApi.prototype.getAllColumns = function () { return this.columnController.getAllPrimaryColumns(); }; - ColumnApi.prototype.getAllGridColumns = function () { return this.columnController.getAllGridColumns(); }; - ColumnApi.prototype.getDisplayedLeftColumns = function () { return this.columnController.getDisplayedLeftColumns(); }; - ColumnApi.prototype.getDisplayedCenterColumns = function () { return this.columnController.getDisplayedCenterColumns(); }; - ColumnApi.prototype.getDisplayedRightColumns = function () { return this.columnController.getDisplayedRightColumns(); }; - ColumnApi.prototype.getAllDisplayedColumns = function () { return this.columnController.getAllDisplayedColumns(); }; - ColumnApi.prototype.getAllDisplayedVirtualColumns = function () { return this.columnController.getAllDisplayedVirtualColumns(); }; - ColumnApi.prototype.moveColumn = function (key, toIndex) { - if (typeof key === 'number') { - // moveColumn used to take indexes, so this is advising user who hasn't moved to new method name - console.warn('ag-Grid: you are using moveColumn(fromIndex, toIndex) - moveColumn takes a column key and a destination index, not two indexes, to move with indexes use moveColumnByIndex(from,to) instead'); - this.columnController.moveColumnByIndex(key, toIndex, 'api'); + CellKeyboardListenerFeature.prototype.setComp = function (eGui) { + this.eGui = eGui; + }; + CellKeyboardListenerFeature.prototype.onKeyDown = function (event) { + var key = event.key; + switch (key) { + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].ENTER: + this.onEnterKeyDown(event); + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].F2: + this.onF2KeyDown(event); + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].ESCAPE: + this.onEscapeKeyDown(event); + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].TAB: + this.onTabKeyDown(event); + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].BACKSPACE: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].DELETE: + this.onBackspaceOrDeleteKeyPressed(key, event); + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].DOWN: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].UP: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].RIGHT: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].LEFT: + this.onNavigationKeyPressed(event, key); + break; + } + }; + CellKeyboardListenerFeature.prototype.onNavigationKeyPressed = function (event, key) { + if (this.cellCtrl.isEditing()) { + return; + } + if (event.shiftKey && this.cellCtrl.isRangeSelectionEnabled()) { + this.onShiftRangeSelect(key); } else { - this.columnController.moveColumn(key, toIndex, 'api'); + this.beans.navigationService.navigateToNextCell(event, key, this.cellCtrl.getCellPosition(), true); } + // if we don't prevent default, the grid will scroll with the navigation keys + event.preventDefault(); }; - ColumnApi.prototype.moveColumnByIndex = function (fromIndex, toIndex) { this.columnController.moveColumnByIndex(fromIndex, toIndex, 'api'); }; - ColumnApi.prototype.moveColumns = function (columnsToMoveKeys, toIndex) { this.columnController.moveColumns(columnsToMoveKeys, toIndex, 'api'); }; - ColumnApi.prototype.moveRowGroupColumn = function (fromIndex, toIndex) { this.columnController.moveRowGroupColumn(fromIndex, toIndex); }; - ColumnApi.prototype.setColumnAggFunc = function (column, aggFunc) { this.columnController.setColumnAggFunc(column, aggFunc); }; - ColumnApi.prototype.setColumnWidth = function (key, newWidth, finished) { - if (finished === void 0) { finished = true; } - this.columnController.setColumnWidths([{ key: key, newWidth: newWidth }], false, finished); - }; - ColumnApi.prototype.setColumnWidths = function (columnWidths, finished) { - if (finished === void 0) { finished = true; } - this.columnController.setColumnWidths(columnWidths, false, finished); - }; - ColumnApi.prototype.setPivotMode = function (pivotMode) { this.columnController.setPivotMode(pivotMode); }; - ColumnApi.prototype.isPivotMode = function () { return this.columnController.isPivotMode(); }; - ColumnApi.prototype.getSecondaryPivotColumn = function (pivotKeys, valueColKey) { return this.columnController.getSecondaryPivotColumn(pivotKeys, valueColKey); }; - ColumnApi.prototype.setValueColumns = function (colKeys) { this.columnController.setValueColumns(colKeys, 'api'); }; - ColumnApi.prototype.getValueColumns = function () { return this.columnController.getValueColumns(); }; - ColumnApi.prototype.removeValueColumn = function (colKey) { this.columnController.removeValueColumn(colKey, 'api'); }; - ColumnApi.prototype.removeValueColumns = function (colKeys) { this.columnController.removeValueColumns(colKeys, 'api'); }; - ColumnApi.prototype.addValueColumn = function (colKey) { this.columnController.addValueColumn(colKey, 'api'); }; - ColumnApi.prototype.addValueColumns = function (colKeys) { this.columnController.addValueColumns(colKeys, 'api'); }; - ColumnApi.prototype.setRowGroupColumns = function (colKeys) { this.columnController.setRowGroupColumns(colKeys, 'api'); }; - ColumnApi.prototype.removeRowGroupColumn = function (colKey) { this.columnController.removeRowGroupColumn(colKey, 'api'); }; - ColumnApi.prototype.removeRowGroupColumns = function (colKeys) { this.columnController.removeRowGroupColumns(colKeys, 'api'); }; - ColumnApi.prototype.addRowGroupColumn = function (colKey) { this.columnController.addRowGroupColumn(colKey, 'api'); }; - ColumnApi.prototype.addRowGroupColumns = function (colKeys) { this.columnController.addRowGroupColumns(colKeys, 'api'); }; - ColumnApi.prototype.getRowGroupColumns = function () { return this.columnController.getRowGroupColumns(); }; - ColumnApi.prototype.setPivotColumns = function (colKeys) { this.columnController.setPivotColumns(colKeys, 'api'); }; - ColumnApi.prototype.removePivotColumn = function (colKey) { this.columnController.removePivotColumn(colKey, 'api'); }; - ColumnApi.prototype.removePivotColumns = function (colKeys) { this.columnController.removePivotColumns(colKeys, 'api'); }; - ColumnApi.prototype.addPivotColumn = function (colKey) { this.columnController.addPivotColumn(colKey, 'api'); }; - ColumnApi.prototype.addPivotColumns = function (colKeys) { this.columnController.addPivotColumns(colKeys, 'api'); }; - ColumnApi.prototype.getPivotColumns = function () { return this.columnController.getPivotColumns(); }; - ColumnApi.prototype.getLeftDisplayedColumnGroups = function () { return this.columnController.getLeftDisplayedColumnGroups(); }; - ColumnApi.prototype.getCenterDisplayedColumnGroups = function () { return this.columnController.getCenterDisplayedColumnGroups(); }; - ColumnApi.prototype.getRightDisplayedColumnGroups = function () { return this.columnController.getRightDisplayedColumnGroups(); }; - ColumnApi.prototype.getAllDisplayedColumnGroups = function () { return this.columnController.getAllDisplayedColumnGroups(); }; - ColumnApi.prototype.autoSizeColumn = function (key, skipHeader) { return this.columnController.autoSizeColumn(key, skipHeader, 'api'); }; - ColumnApi.prototype.autoSizeColumns = function (keys, skipHeader) { return this.columnController.autoSizeColumns(keys, skipHeader, 'api'); }; - ColumnApi.prototype.autoSizeAllColumns = function (skipHeader) { this.columnController.autoSizeAllColumns(skipHeader, 'api'); }; - ColumnApi.prototype.setSecondaryColumns = function (colDefs) { this.columnController.setSecondaryColumns(colDefs, 'api'); }; - ColumnApi.prototype.getSecondaryColumns = function () { return this.columnController.getSecondaryColumns(); }; - ColumnApi.prototype.getPrimaryColumns = function () { return this.columnController.getAllPrimaryColumns(); }; - // below goes through deprecated items, prints message to user, then calls the new version of the same method - ColumnApi.prototype.columnGroupOpened = function (group, newValue) { - console.error('ag-Grid: columnGroupOpened no longer exists, use setColumnGroupOpened'); - this.setColumnGroupOpened(group, newValue); - }; - ColumnApi.prototype.hideColumns = function (colIds, hide) { - console.error('ag-Grid: hideColumns is deprecated, use setColumnsVisible'); - this.columnController.setColumnsVisible(colIds, !hide, 'api'); - }; - ColumnApi.prototype.hideColumn = function (colId, hide) { - console.error('ag-Grid: hideColumn is deprecated, use setColumnVisible'); - this.columnController.setColumnVisible(colId, !hide, 'api'); - }; - ColumnApi.prototype.setState = function (columnState) { - console.error('ag-Grid: setState is deprecated, use setColumnState'); - return this.setColumnState(columnState); - }; - ColumnApi.prototype.getState = function () { - console.error('ag-Grid: getState is deprecated, use getColumnState'); - return this.getColumnState(); + CellKeyboardListenerFeature.prototype.onShiftRangeSelect = function (key) { + if (!this.beans.rangeService) { + return; + } + var endCell = this.beans.rangeService.extendLatestRangeInDirection(key); + if (endCell) { + this.beans.navigationService.ensureCellVisible(endCell); + } }; - ColumnApi.prototype.resetState = function () { - console.error('ag-Grid: resetState is deprecated, use resetColumnState'); - this.resetColumnState(); + CellKeyboardListenerFeature.prototype.onTabKeyDown = function (event) { + this.beans.navigationService.onTabKeyDown(this.cellCtrl, event); }; - ColumnApi.prototype.getAggregationColumns = function () { - console.error('ag-Grid: getAggregationColumns is deprecated, use getValueColumns'); - return this.columnController.getValueColumns(); + CellKeyboardListenerFeature.prototype.onBackspaceOrDeleteKeyPressed = function (key, event) { + if (!this.cellCtrl.isEditing()) { + this.cellCtrl.startRowOrCellEdit(key, undefined, event); + } }; - ColumnApi.prototype.removeAggregationColumn = function (colKey) { - console.error('ag-Grid: removeAggregationColumn is deprecated, use removeValueColumn'); - this.columnController.removeValueColumn(colKey, 'api'); + CellKeyboardListenerFeature.prototype.onEnterKeyDown = function (e) { + if (this.cellCtrl.isEditing() || this.rowCtrl.isEditing()) { + this.cellCtrl.stopEditingAndFocus(); + } + else { + if (this.beans.gridOptionsWrapper.isEnterMovesDown()) { + this.beans.navigationService.navigateToNextCell(null, _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].DOWN, this.cellCtrl.getCellPosition(), false); + } + else { + this.cellCtrl.startRowOrCellEdit(_constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].ENTER, undefined, e); + if (this.cellCtrl.isEditing()) { + // if we started editing, then we need to prevent default, otherwise the Enter action can get + // applied to the cell editor. this happened, for example, with largeTextCellEditor where not + // preventing default results in a 'new line' character getting inserted in the text area + // when the editing was started + e.preventDefault(); + } + } + } }; - ColumnApi.prototype.removeAggregationColumns = function (colKeys) { - console.error('ag-Grid: removeAggregationColumns is deprecated, use removeValueColumns'); - this.columnController.removeValueColumns(colKeys, 'api'); + CellKeyboardListenerFeature.prototype.onF2KeyDown = function (event) { + if (!this.cellCtrl.isEditing()) { + this.cellCtrl.startRowOrCellEdit(_constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].F2, undefined, event); + } }; - ColumnApi.prototype.addAggregationColumn = function (colKey) { - console.error('ag-Grid: addAggregationColumn is deprecated, use addValueColumn'); - this.columnController.addValueColumn(colKey, 'api'); + CellKeyboardListenerFeature.prototype.onEscapeKeyDown = function (event) { + if (this.cellCtrl.isEditing()) { + this.cellCtrl.stopRowOrCellEdit(true); + this.cellCtrl.focusCell(true); + } }; - ColumnApi.prototype.addAggregationColumns = function (colKeys) { - console.error('ag-Grid: addAggregationColumns is deprecated, use addValueColumns'); - this.columnController.addValueColumns(colKeys, 'api'); + CellKeyboardListenerFeature.prototype.onKeyPress = function (event) { + // check this, in case focus is on a (for example) a text field inside the cell, + // in which cse we should not be listening for these key pressed + var eventTarget = event.target; + var eventOnChildComponent = eventTarget !== this.eGui; + if (eventOnChildComponent || this.cellCtrl.isEditing()) { + return; + } + var pressedChar = String.fromCharCode(event.charCode); + if (pressedChar === ' ') { + this.onSpaceKeyPressed(event); + } + else if (Object(_utils_keyboard__WEBPACK_IMPORTED_MODULE_2__["isEventFromPrintableCharacter"])(event)) { + this.cellCtrl.startRowOrCellEdit(null, pressedChar, event); + // if we don't prevent default, then the keypress also gets applied to the text field + // (at least when doing the default editor), but we need to allow the editor to decide + // what it wants to do. we only do this IF editing was started - otherwise it messes + // up when the use is not doing editing, but using rendering with text fields in cellRenderer + // (as it would block the the user from typing into text fields). + event.preventDefault(); + } }; - ColumnApi.prototype.setColumnAggFunction = function (column, aggFunc) { - console.error('ag-Grid: setColumnAggFunction is deprecated, use setColumnAggFunc'); - this.columnController.setColumnAggFunc(column, aggFunc, 'api'); + CellKeyboardListenerFeature.prototype.onSpaceKeyPressed = function (event) { + var gridOptionsWrapper = this.beans.gridOptionsWrapper; + if (!this.cellCtrl.isEditing() && gridOptionsWrapper.isRowSelection()) { + var currentSelection = this.rowNode.isSelected(); + var newSelection = !currentSelection; + if (newSelection || !gridOptionsWrapper.isSuppressRowDeselection()) { + var groupSelectsFiltered = this.beans.gridOptionsWrapper.isGroupSelectsFiltered(); + var updatedCount = this.rowNode.setSelectedParams({ + newValue: newSelection, + rangeSelect: event.shiftKey, + groupSelectsFiltered: groupSelectsFiltered + }); + if (currentSelection === undefined && updatedCount === 0) { + this.rowNode.setSelectedParams({ + newValue: false, + rangeSelect: event.shiftKey, + groupSelectsFiltered: groupSelectsFiltered + }); + } + } + } + // prevent default as space key, by default, moves browser scroll down + event.preventDefault(); }; - ColumnApi.prototype.getDisplayNameForCol = function (column) { - console.error('ag-Grid: getDisplayNameForCol is deprecated, use getDisplayNameForColumn'); - return this.getDisplayNameForColumn(column, null); + CellKeyboardListenerFeature.prototype.destroy = function () { }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], ColumnApi.prototype, "columnController", void 0); - ColumnApi = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('columnApi') - ], ColumnApi); - return ColumnApi; -}()); + return CellKeyboardListenerFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 99 */ +/* 123 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowRenderer", function() { return RowRenderer; }); -/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(50); -/* harmony import */ var _rowComp__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(100); -/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(35); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(25); -/* harmony import */ var _cellComp__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(101); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(41); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DndSourceComp", function() { return DndSourceComp; }); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _utils_icon__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(48); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -19853,1308 +28141,1277 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; -var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { - return function (target, key) { decorator(target, key, paramIndex); } -}; - - - - - - -var RowRenderer = /** @class */ (function (_super) { - __extends(RowRenderer, _super); - function RowRenderer() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.destroyFuncsForColumnListeners = []; - // map of row ids to row objects. keeps track of which elements - // are rendered for which rows in the dom. - _this.rowCompsByIndex = {}; - _this.floatingTopRowComps = []; - _this.floatingBottomRowComps = []; - // we only allow one refresh at a time, otherwise the internal memory structure here - // will get messed up. this can happen if the user has a cellRenderer, and inside the - // renderer they call an API method that results in another pass of the refresh, - // then it will be trying to draw rows in the middle of a refresh. - _this.refreshInProgress = false; +var DndSourceComp = /** @class */ (function (_super) { + __extends(DndSourceComp, _super); + function DndSourceComp(rowNode, column, beans, eCell) { + var _this = _super.call(this, "
") || this; + _this.rowNode = rowNode; + _this.column = column; + _this.beans = beans; + _this.eCell = eCell; return _this; } - RowRenderer.prototype.registerGridCore = function (gridCore) { - this.gridCore = gridCore; - }; - RowRenderer.prototype.getGridCore = function () { - return this.gridCore; - }; - RowRenderer.prototype.agWire = function (loggerFactory) { - this.logger = loggerFactory.create("RowRenderer"); - }; - RowRenderer.prototype.registerGridComp = function (gridPanel) { - this.gridPanel = gridPanel; - this.rowContainers = this.gridPanel.getRowContainers(); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_PAGINATION_CHANGED, this.onPageLoaded.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_PINNED_ROW_DATA_CHANGED, this.onPinnedRowDataChanged.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_BODY_SCROLL, this.redrawAfterScroll.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_BODY_HEIGHT_CHANGED, this.redrawAfterScroll.bind(this)); - this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_DOM_LAYOUT, this.onDomLayoutChanged.bind(this)); - this.registerCellEventListeners(); - this.printLayout = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].DOM_LAYOUT_PRINT; - this.embedFullWidthRows = this.printLayout || this.gridOptionsWrapper.isEmbedFullWidthRows(); - this.redrawAfterModelUpdate(); - }; - // in a clean design, each cell would register for each of these events. however when scrolling, all the cells - // registering and de-registering for events is a performance bottleneck. so we register here once and inform - // all active cells. - RowRenderer.prototype.registerCellEventListeners = function () { - var _this = this; - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_CELL_FOCUSED, function (event) { - _this.forEachCellComp(function (cellComp) { return cellComp.onCellFocused(event); }); - }); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_FLASH_CELLS, function (event) { - _this.forEachCellComp(function (cellComp) { return cellComp.onFlashCells(event); }); - }); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_HOVER_CHANGED, function () { - _this.forEachCellComp(function (cellComp) { return cellComp.onColumnHover(); }); - }); - // only for printLayout - because we are rendering all the cells in the same row, regardless of pinned state, - // then changing the width of the containers will impact left position. eg the center cols all have their - // left position adjusted by the width of the left pinned column, so if the pinned left column width changes, - // all the center cols need to be shifted to accommodate this. when in normal layout, the pinned cols are - // in different containers so doesn't impact. - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, function () { - if (_this.printLayout) { - _this.forEachCellComp(function (cellComp) { return cellComp.onLeftChanged(); }); - } + DndSourceComp.prototype.postConstruct = function () { + var eGui = this.getGui(); + eGui.appendChild(Object(_utils_icon__WEBPACK_IMPORTED_MODULE_2__["createIconNoSpan"])('rowDrag', this.beans.gridOptionsWrapper, null)); + // we need to stop the event propagation here to avoid starting a range selection while dragging + this.addGuiEventListener('mousedown', function (e) { + e.stopPropagation(); }); - var rangeSelectionEnabled = this.gridOptionsWrapper.isEnableRangeSelection(); - if (rangeSelectionEnabled) { - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_RANGE_SELECTION_CHANGED, function () { - _this.forEachCellComp(function (cellComp) { return cellComp.onRangeSelectionChanged(); }); - }); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_MOVED, function () { - _this.forEachCellComp(function (cellComp) { return cellComp.updateRangeBordersIfRangeCount(); }); - }); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_PINNED, function () { - _this.forEachCellComp(function (cellComp) { return cellComp.updateRangeBordersIfRangeCount(); }); - }); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_VISIBLE, function () { - _this.forEachCellComp(function (cellComp) { return cellComp.updateRangeBordersIfRangeCount(); }); - }); - } - // add listeners to the grid columns - this.refreshListenersToColumnsForCellComps(); - // if the grid columns change, then refresh the listeners again - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_GRID_COLUMNS_CHANGED, this.refreshListenersToColumnsForCellComps.bind(this)); - this.addDestroyFunc(this.removeGridColumnListeners.bind(this)); + this.addDragSource(); + this.checkVisibility(); }; - // executes all functions in destroyFuncsForColumnListeners and then clears the list - RowRenderer.prototype.removeGridColumnListeners = function () { - this.destroyFuncsForColumnListeners.forEach(function (func) { return func(); }); - this.destroyFuncsForColumnListeners.length = 0; + DndSourceComp.prototype.addDragSource = function () { + this.addGuiEventListener('dragstart', this.onDragStart.bind(this)); }; - // this function adds listeners onto all the grid columns, which are the column that we could have cellComps for. - // when the grid columns change, we add listeners again. in an ideal design, each CellComp would just register to - // the column it belongs to on creation, however this was a bottleneck with the number of cells, so do it here - // once instead. - RowRenderer.prototype.refreshListenersToColumnsForCellComps = function () { + DndSourceComp.prototype.onDragStart = function (dragEvent) { var _this = this; - this.removeGridColumnListeners(); - var cols = this.columnController.getAllGridColumns(); - if (!cols) { - return; - } - cols.forEach(function (col) { - var forEachCellWithThisCol = function (callback) { - _this.forEachCellComp(function (cellComp) { - if (cellComp.getColumn() === col) { - callback(cellComp); - } - }); - }; - var leftChangedListener = function () { - forEachCellWithThisCol(function (cellComp) { return cellComp.onLeftChanged(); }); - }; - var widthChangedListener = function () { - forEachCellWithThisCol(function (cellComp) { return cellComp.onWidthChanged(); }); - }; - var firstRightPinnedChangedListener = function () { - forEachCellWithThisCol(function (cellComp) { return cellComp.onFirstRightPinnedChanged(); }); - }; - var lastLeftPinnedChangedListener = function () { - forEachCellWithThisCol(function (cellComp) { return cellComp.onLastLeftPinnedChanged(); }); - }; - col.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_LEFT_CHANGED, leftChangedListener); - col.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_WIDTH_CHANGED, widthChangedListener); - col.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_FIRST_RIGHT_PINNED_CHANGED, firstRightPinnedChangedListener); - col.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_LAST_LEFT_PINNED_CHANGED, lastLeftPinnedChangedListener); - _this.destroyFuncsForColumnListeners.push(function () { - col.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_LEFT_CHANGED, leftChangedListener); - col.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_WIDTH_CHANGED, widthChangedListener); - col.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_FIRST_RIGHT_PINNED_CHANGED, firstRightPinnedChangedListener); - col.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_LAST_LEFT_PINNED_CHANGED, lastLeftPinnedChangedListener); - }); - }); - }; - RowRenderer.prototype.onDomLayoutChanged = function () { - var printLayout = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].DOM_LAYOUT_PRINT; - var embedFullWidthRows = printLayout || this.gridOptionsWrapper.isEmbedFullWidthRows(); - // if moving towards or away from print layout, means we need to destroy all rows, as rows are not laid - // out using absolute positioning when doing print layout - var destroyRows = embedFullWidthRows !== this.embedFullWidthRows || this.printLayout !== printLayout; - this.printLayout = printLayout; - this.embedFullWidthRows = embedFullWidthRows; - if (destroyRows) { - this.redrawAfterModelUpdate(); - } - }; - // for row models that have datasources, when we update the datasource, we need to force the rowRenderer - // to redraw all rows. otherwise the old rows from the old datasource will stay displayed. - RowRenderer.prototype.datasourceChanged = function () { - this.firstRenderedRow = 0; - this.lastRenderedRow = -1; - var rowIndexesToRemove = Object.keys(this.rowCompsByIndex); - this.removeRowComps(rowIndexesToRemove); - }; - RowRenderer.prototype.onPageLoaded = function (refreshEvent) { - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(refreshEvent)) { - refreshEvent = { - type: _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_MODEL_UPDATED, - api: this.gridApi, - columnApi: this.columnApi, - animate: false, - keepRenderedRows: false, - newData: false, - newPage: false - }; - } - this.onModelUpdated(refreshEvent); - }; - RowRenderer.prototype.getAllCellsForColumn = function (column) { - var eCells = []; - function callback(key, rowComp) { - var eCell = rowComp.getCellForCol(column); - if (eCell) { - eCells.push(eCell); + var providedOnRowDrag = this.column.getColDef().dndSourceOnRowDrag; + dragEvent.dataTransfer.setDragImage(this.eCell, 0, 0); + // default behaviour is to convert data to json and set into drag component + var defaultOnRowDrag = function () { + try { + var jsonData = JSON.stringify(_this.rowNode.data); + dragEvent.dataTransfer.setData('application/json', jsonData); + dragEvent.dataTransfer.setData('text/plain', jsonData); + } + catch (e) { + // if we cannot convert the data to json, then we do not set the type } + }; + if (providedOnRowDrag) { + providedOnRowDrag({ rowNode: this.rowNode, dragEvent: dragEvent }); } - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowCompsByIndex, callback); - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.floatingBottomRowComps, callback); - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.floatingTopRowComps, callback); - return eCells; - }; - RowRenderer.prototype.refreshFloatingRowComps = function () { - this.refreshFloatingRows(this.floatingTopRowComps, this.pinnedRowModel.getPinnedTopRowData(), this.rowContainers.floatingTopPinnedLeft, this.rowContainers.floatingTopPinnedRight, this.rowContainers.floatingTop, this.rowContainers.floatingTopFullWidth); - this.refreshFloatingRows(this.floatingBottomRowComps, this.pinnedRowModel.getPinnedBottomRowData(), this.rowContainers.floatingBottomPinnedLeft, this.rowContainers.floatingBottomPinnedRight, this.rowContainers.floatingBottom, this.rowContainers.floatingBottomFullWidth); - }; - RowRenderer.prototype.refreshFloatingRows = function (rowComps, rowNodes, pinnedLeftContainerComp, pinnedRightContainerComp, bodyContainerComp, fullWidthContainerComp) { - var _this = this; - rowComps.forEach(function (row) { - row.destroy(); - }); - rowComps.length = 0; - if (rowNodes) { - rowNodes.forEach(function (node) { - var rowComp = new _rowComp__WEBPACK_IMPORTED_MODULE_1__["RowComp"](_this.$scope, bodyContainerComp, pinnedLeftContainerComp, pinnedRightContainerComp, fullWidthContainerComp, node, _this.beans, false, false, _this.printLayout, _this.embedFullWidthRows); - rowComp.init(); - rowComps.push(rowComp); - }); + else { + defaultOnRowDrag(); } - this.flushContainers(rowComps); - }; - RowRenderer.prototype.onPinnedRowDataChanged = function () { - // recycling rows in order to ensure cell editing is not cancelled - var params = { - recycleRows: true - }; - this.redrawAfterModelUpdate(params); - }; - RowRenderer.prototype.onModelUpdated = function (refreshEvent) { - var params = { - recycleRows: refreshEvent.keepRenderedRows, - animate: refreshEvent.animate, - newData: refreshEvent.newData, - newPage: refreshEvent.newPage, - // because this is a model updated event (not pinned rows), we - // can skip updating the pinned rows. this is needed so that if user - // is doing transaction updates, the pinned rows are not getting constantly - // trashed - or editing cells in pinned rows are not refreshed and put into read mode - onlyBody: true - }; - this.redrawAfterModelUpdate(params); }; - // if the row nodes are not rendered, no index is returned - RowRenderer.prototype.getRenderedIndexesForRowNodes = function (rowNodes) { - var result = []; - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(rowNodes)) { - return result; - } - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowCompsByIndex, function (index, renderedRow) { - var rowNode = renderedRow.getRowNode(); - if (rowNodes.indexOf(rowNode) >= 0) { - result.push(index); - } - }); - return result; + DndSourceComp.prototype.checkVisibility = function () { + var visible = this.column.isDndSource(this.rowNode); + this.setDisplayed(visible); }; - RowRenderer.prototype.redrawRows = function (rowNodes) { - if (!rowNodes || rowNodes.length == 0) { - return; + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], DndSourceComp.prototype, "postConstruct", null); + return DndSourceComp; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); + + + +/***/ }), +/* 124 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AngularRowUtils", function() { return AngularRowUtils; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __assign = (undefined && undefined.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; } - // we only need to be worried about rendered rows, as this method is - // called to what's rendered. if the row isn't rendered, we don't care - var indexesToRemove = this.getRenderedIndexesForRowNodes(rowNodes); - // remove the rows - this.removeRowComps(indexesToRemove); - // add draw them again - this.redrawAfterModelUpdate({ - recycleRows: true - }); + return t; }; - RowRenderer.prototype.getCellToRestoreFocusToAfterRefresh = function (params) { - var focusedCell = params.suppressKeepFocus ? null : this.focusController.getFocusCellToUseAfterRefresh(); - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(focusedCell)) { + return __assign.apply(this, arguments); +}; +var AngularRowUtils = /** @class */ (function () { + function AngularRowUtils() { + } + AngularRowUtils.createChildScopeOrNull = function (rowNode, parentScope, gridOptionsWrapper) { + var isAngularCompileRows = gridOptionsWrapper.isAngularCompileRows(); + if (!isAngularCompileRows) { return null; } - // if the dom is not actually focused on a cell, then we don't try to refocus. the problem this - // solves is with editing - if the user is editing, eg focus is on a text field, and not on the - // cell itself, then the cell can be registered as having focus, however it's the text field that - // has the focus and not the cell div. therefore, when the refresh is finished, the grid will focus - // the cell, and not the textfield. that means if the user is in a text field, and the grid refreshes, - // the focus is lost from the text field. we do not want this. - var activeElement = document.activeElement; - var domData = this.gridOptionsWrapper.getDomData(activeElement, _cellComp__WEBPACK_IMPORTED_MODULE_5__["CellComp"].DOM_DATA_KEY_CELL_COMP); - var elementIsNotACellDev = _utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(domData); - return elementIsNotACellDev ? null : focusedCell; + var newChildScope = parentScope.$new(); + newChildScope.data = __assign({}, rowNode.data); + newChildScope.rowNode = rowNode; + newChildScope.context = gridOptionsWrapper.getContext(); + var destroyFunc = function () { + newChildScope.$destroy(); + newChildScope.data = null; + newChildScope.rowNode = null; + newChildScope.context = null; + }; + return { + scope: newChildScope, + scopeDestroyFunc: destroyFunc + }; }; - // gets called after changes to the model. - RowRenderer.prototype.redrawAfterModelUpdate = function (params) { - if (params === void 0) { params = {}; } - this.getLockOnRefresh(); - var focusedCell = this.getCellToRestoreFocusToAfterRefresh(params); - this.sizeContainerToPageHeight(); - this.scrollToTopIfNewData(params); - // never recycle rows when print layout, we draw each row again from scratch. this is because print layout - // uses normal dom layout to put cells into dom - it doesn't allow reordering rows. - var recycleRows = !this.printLayout && params.recycleRows; - var animate = params.animate && this.gridOptionsWrapper.isAnimateRows(); - var rowsToRecycle = this.binRowComps(recycleRows); - this.redraw(rowsToRecycle, animate); - if (!params.onlyBody) { - this.refreshFloatingRowComps(); - } - this.restoreFocusedCell(focusedCell); - this.releaseLockOnRefresh(); + return AngularRowUtils; +}()); + + + +/***/ }), +/* 125 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowContainerName", function() { return RowContainerName; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowContainerType", function() { return RowContainerType; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getRowContainerTypeForName", function() { return getRowContainerTypeForName; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowContainerCtrl", function() { return RowContainerCtrl; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(24); +/* harmony import */ var _rowContainerEventsFeature__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(126); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(42); +/* harmony import */ var _viewportSizeFeature__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(127); +/* harmony import */ var _utils_map__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(27); +/* harmony import */ var _setPinnedLeftWidthFeature__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(128); +/* harmony import */ var _setPinnedRightWidthFeature__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(129); +/* harmony import */ var _setHeightFeature__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(130); +/* harmony import */ var _dragListenerFeature__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(131); +/* harmony import */ var _centerWidthFeature__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(132); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(15); +/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(107); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - RowRenderer.prototype.scrollToTopIfNewData = function (params) { - var scrollToTop = params.newData || params.newPage; - var suppressScrollToTop = this.gridOptionsWrapper.isSuppressScrollOnNewData(); - if (scrollToTop && !suppressScrollToTop) { - this.gridPanel.scrollToTop(); - } + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - RowRenderer.prototype.sizeContainerToPageHeight = function () { - var containers = [ - this.rowContainers.body, - this.rowContainers.fullWidth, - this.rowContainers.pinnedLeft, - this.rowContainers.pinnedRight - ]; - if (this.printLayout) { - containers.forEach(function (container) { return container.setHeight(null); }); - return; - } - var containerHeight = this.paginationProxy.getCurrentPageHeight(); - // we need at least 1 pixel for the horizontal scroll to work. so if there are now rows, - // we still want the scroll to be present, otherwise there would be no way to scroll the header - // which might be needed us user wants to access columns - // on the RHS - and if that was where the filter was that cause no rows to be presented, there - // is no way to remove the filter. - if (containerHeight === 0) { - containerHeight = 1; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); } - this.maxDivHeightScaler.setModelHeight(containerHeight); - var realHeight = this.maxDivHeightScaler.getUiContainerHeight(); - containers.forEach(function (container) { return container.setHeight(realHeight); }); - }; - RowRenderer.prototype.getLockOnRefresh = function () { - if (this.refreshInProgress) { - throw new Error("ag-Grid: cannot get grid to draw rows when it is in the middle of drawing rows. " + - "Your code probably called a grid API method while the grid was in the render stage. To overcome " + - "this, put the API call into a timeout, eg instead of api.refreshView(), " + - "call setTimeout(function(){api.refreshView(),0}). To see what part of your code " + - "that caused the refresh check this stacktrace."); + finally { if (e) throw e.error; } + } + return ar; +}; +var __spread = (undefined && undefined.__spread) || function () { + for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); + return ar; +}; + + + + + + + + + + + + + + +var RowContainerName; +(function (RowContainerName) { + RowContainerName["LEFT"] = "left"; + RowContainerName["RIGHT"] = "right"; + RowContainerName["CENTER"] = "center"; + RowContainerName["FULL_WIDTH"] = "fullWidth"; + RowContainerName["TOP_LEFT"] = "topLeft"; + RowContainerName["TOP_RIGHT"] = "topRight"; + RowContainerName["TOP_CENTER"] = "topCenter"; + RowContainerName["TOP_FULL_WIDTH"] = "topFullWidth"; + RowContainerName["BOTTOM_LEFT"] = "bottomLeft"; + RowContainerName["BOTTOM_RIGHT"] = "bottomRight"; + RowContainerName["BOTTOM_CENTER"] = "bottomCenter"; + RowContainerName["BOTTOM_FULL_WIDTH"] = "bottomFullWidth"; +})(RowContainerName || (RowContainerName = {})); +var RowContainerType; +(function (RowContainerType) { + RowContainerType["LEFT"] = "left"; + RowContainerType["RIGHT"] = "right"; + RowContainerType["CENTER"] = "center"; + RowContainerType["FULL_WIDTH"] = "fullWidth"; +})(RowContainerType || (RowContainerType = {})); +function getRowContainerTypeForName(name) { + switch (name) { + case RowContainerName.CENTER: + case RowContainerName.TOP_CENTER: + case RowContainerName.BOTTOM_CENTER: + return RowContainerType.CENTER; + case RowContainerName.LEFT: + case RowContainerName.TOP_LEFT: + case RowContainerName.BOTTOM_LEFT: + return RowContainerType.LEFT; + case RowContainerName.RIGHT: + case RowContainerName.TOP_RIGHT: + case RowContainerName.BOTTOM_RIGHT: + return RowContainerType.RIGHT; + case RowContainerName.FULL_WIDTH: + case RowContainerName.TOP_FULL_WIDTH: + case RowContainerName.BOTTOM_FULL_WIDTH: + return RowContainerType.FULL_WIDTH; + default: + throw Error('Invalid Row Container Type'); + } +} +var ContainerCssClasses = Object(_utils_map__WEBPACK_IMPORTED_MODULE_6__["convertToMap"])([ + [RowContainerName.CENTER, 'ag-center-cols-container'], + [RowContainerName.LEFT, 'ag-pinned-left-cols-container'], + [RowContainerName.RIGHT, 'ag-pinned-right-cols-container'], + [RowContainerName.FULL_WIDTH, 'ag-full-width-container'], + [RowContainerName.TOP_CENTER, 'ag-floating-top-container'], + [RowContainerName.TOP_LEFT, 'ag-pinned-left-floating-top'], + [RowContainerName.TOP_RIGHT, 'ag-pinned-right-floating-top'], + [RowContainerName.TOP_FULL_WIDTH, 'ag-floating-top-full-width-container'], + [RowContainerName.BOTTOM_CENTER, 'ag-floating-bottom-container'], + [RowContainerName.BOTTOM_LEFT, 'ag-pinned-left-floating-bottom'], + [RowContainerName.BOTTOM_RIGHT, 'ag-pinned-right-floating-bottom'], + [RowContainerName.BOTTOM_FULL_WIDTH, 'ag-floating-bottom-full-width-container'], +]); +var ViewportCssClasses = Object(_utils_map__WEBPACK_IMPORTED_MODULE_6__["convertToMap"])([ + [RowContainerName.CENTER, 'ag-center-cols-viewport'], + [RowContainerName.TOP_CENTER, 'ag-floating-top-viewport'], + [RowContainerName.BOTTOM_CENTER, 'ag-floating-bottom-viewport'], +]); +var WrapperCssClasses = Object(_utils_map__WEBPACK_IMPORTED_MODULE_6__["convertToMap"])([ + [RowContainerName.CENTER, 'ag-center-cols-clipper'], +]); +var RowContainerCtrl = /** @class */ (function (_super) { + __extends(RowContainerCtrl, _super); + function RowContainerCtrl(name) { + var _this = _super.call(this) || this; + _this.name = name; + return _this; + } + RowContainerCtrl.getRowContainerCssClasses = function (name) { + var containerClass = ContainerCssClasses.get(name); + var viewportClass = ViewportCssClasses.get(name); + var wrapperClass = WrapperCssClasses.get(name); + return { container: containerClass, viewport: viewportClass, wrapper: wrapperClass }; + }; + RowContainerCtrl.getPinned = function (name) { + switch (name) { + case RowContainerName.BOTTOM_LEFT: + case RowContainerName.TOP_LEFT: + case RowContainerName.LEFT: + return _constants_constants__WEBPACK_IMPORTED_MODULE_12__["Constants"].PINNED_LEFT; + case RowContainerName.BOTTOM_RIGHT: + case RowContainerName.TOP_RIGHT: + case RowContainerName.RIGHT: + return _constants_constants__WEBPACK_IMPORTED_MODULE_12__["Constants"].PINNED_RIGHT; + default: + return null; } - this.refreshInProgress = true; - }; - RowRenderer.prototype.releaseLockOnRefresh = function () { - this.refreshInProgress = false; }; - // sets the focus to the provided cell, if the cell is provided. this way, the user can call refresh without - // worry about the focus been lost. this is important when the user is using keyboard navigation to do edits - // and the cellEditor is calling 'refresh' to get other cells to update (as other cells might depend on the - // edited cell). - RowRenderer.prototype.restoreFocusedCell = function (cellPosition) { - if (cellPosition) { - this.focusController.setFocusedCell(cellPosition.rowIndex, cellPosition.column, cellPosition.rowPinned, true); + RowContainerCtrl.prototype.postConstruct = function () { + var _this = this; + this.enableRtl = this.gridOptionsWrapper.isEnableRtl(); + this.embedFullWidthRows = this.gridOptionsWrapper.isEmbedFullWidthRows(); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_SCROLL_VISIBILITY_CHANGED, this.onScrollVisibilityChanged.bind(this)); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this)); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, this.onDisplayedColumnsWidthChanged.bind(this)); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_ROWS_CHANGED, this.onDisplayedRowsChanged.bind(this)); + this.forContainers([RowContainerName.CENTER], function () { return _this.viewportSizeFeature = _this.createManagedBean(new _viewportSizeFeature__WEBPACK_IMPORTED_MODULE_5__["ViewportSizeFeature"](_this)); }); + this.registerWithCtrlsService(); + }; + RowContainerCtrl.prototype.registerWithCtrlsService = function () { + switch (this.name) { + case RowContainerName.CENTER: + this.ctrlsService.registerCenterRowContainerCtrl(this); + break; + case RowContainerName.LEFT: + this.ctrlsService.registerLeftRowContainerCtrl(this); + break; + case RowContainerName.RIGHT: + this.ctrlsService.registerRightRowContainerCtrl(this); + break; + case RowContainerName.TOP_CENTER: + this.ctrlsService.registerTopCenterRowContainerCtrl(this); + break; + case RowContainerName.TOP_LEFT: + this.ctrlsService.registerTopLeftRowContainerCon(this); + break; + case RowContainerName.TOP_RIGHT: + this.ctrlsService.registerTopRightRowContainerCtrl(this); + break; + case RowContainerName.BOTTOM_CENTER: + this.ctrlsService.registerBottomCenterRowContainerCtrl(this); + break; + case RowContainerName.BOTTOM_LEFT: + this.ctrlsService.registerBottomLeftRowContainerCtrl(this); + break; + case RowContainerName.BOTTOM_RIGHT: + this.ctrlsService.registerBottomRightRowContainerCtrl(this); + break; } }; - RowRenderer.prototype.stopEditing = function (cancel) { - if (cancel === void 0) { cancel = false; } - this.forEachRowComp(function (key, rowComp) { - rowComp.stopEditing(cancel); - }); - }; - RowRenderer.prototype.forEachCellComp = function (callback) { - this.forEachRowComp(function (key, rowComp) { return rowComp.forEachCellComp(callback); }); - }; - RowRenderer.prototype.forEachRowComp = function (callback) { - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowCompsByIndex, callback); - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.floatingTopRowComps, callback); - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.floatingBottomRowComps, callback); - }; - RowRenderer.prototype.addRenderedRowListener = function (eventName, rowIndex, callback) { - var rowComp = this.rowCompsByIndex[rowIndex]; - if (rowComp) { - rowComp.addEventListener(eventName, callback); + RowContainerCtrl.prototype.forContainers = function (names, callback) { + if (names.indexOf(this.name) >= 0) { + callback(); } }; - RowRenderer.prototype.flashCells = function (params) { - if (params === void 0) { params = {}; } - var flashDelay = params.flashDelay, fadeDelay = params.fadeDelay; - this.forEachCellCompFiltered(params.rowNodes, params.columns, function (cellComp) { return cellComp.flashCell({ flashDelay: flashDelay, fadeDelay: fadeDelay }); }); - }; - RowRenderer.prototype.refreshCells = function (params) { - if (params === void 0) { params = {}; } - var refreshCellParams = { - forceRefresh: params.force, - newData: false, - suppressFlash: params.suppressFlash - }; - this.forEachCellCompFiltered(params.rowNodes, params.columns, function (cellComp) { return cellComp.refreshCell(refreshCellParams); }); - }; - RowRenderer.prototype.getCellRendererInstances = function (params) { - var res = []; - this.forEachCellCompFiltered(params.rowNodes, params.columns, function (cellComp) { - var cellRenderer = cellComp.getCellRenderer(); - if (cellRenderer) { - res.push(cellRenderer); - } - }); - return res; + RowContainerCtrl.prototype.getContainerElement = function () { + return this.eContainer; }; - RowRenderer.prototype.getCellEditorInstances = function (params) { - var res = []; - this.forEachCellCompFiltered(params.rowNodes, params.columns, function (cellComp) { - var cellEditor = cellComp.getCellEditor(); - if (cellEditor) { - res.push(cellEditor); - } - }); - return res; + RowContainerCtrl.prototype.getViewportSizeFeature = function () { + return this.viewportSizeFeature; }; - RowRenderer.prototype.getEditingCells = function () { - var res = []; - this.forEachCellComp(function (cellComp) { - if (cellComp.isEditing()) { - var cellPosition = cellComp.getCellPosition(); - res.push(cellPosition); - } - }); - return res; + RowContainerCtrl.prototype.setComp = function (view, eContainer, eViewport, eWrapper) { + var _this = this; + this.comp = view; + this.eContainer = eContainer; + this.eViewport = eViewport; + this.eWrapper = eWrapper; + this.createManagedBean(new _rowContainerEventsFeature__WEBPACK_IMPORTED_MODULE_3__["RowContainerEventsFeature"](this.eContainer)); + this.addPreventScrollWhileDragging(); + this.listenOnDomOrder(); + this.stopHScrollOnPinnedRows(); + var allTopNoFW = [RowContainerName.TOP_CENTER, RowContainerName.TOP_LEFT, RowContainerName.TOP_RIGHT]; + var allBottomNoFW = [RowContainerName.BOTTOM_CENTER, RowContainerName.BOTTOM_LEFT, RowContainerName.BOTTOM_RIGHT]; + var allMiddleNoFW = [RowContainerName.CENTER, RowContainerName.LEFT, RowContainerName.RIGHT]; + var allNoFW = __spread(allTopNoFW, allBottomNoFW, allMiddleNoFW); + var allMiddle = [RowContainerName.CENTER, RowContainerName.LEFT, RowContainerName.RIGHT, RowContainerName.FULL_WIDTH]; + var allCenter = [RowContainerName.CENTER, RowContainerName.TOP_CENTER, RowContainerName.BOTTOM_CENTER]; + var allLeft = [RowContainerName.LEFT, RowContainerName.BOTTOM_LEFT, RowContainerName.TOP_LEFT]; + var allRight = [RowContainerName.RIGHT, RowContainerName.BOTTOM_RIGHT, RowContainerName.TOP_RIGHT]; + this.forContainers(allLeft, function () { return _this.createManagedBean(new _setPinnedLeftWidthFeature__WEBPACK_IMPORTED_MODULE_7__["SetPinnedLeftWidthFeature"](_this.eContainer)); }); + this.forContainers(allRight, function () { return _this.createManagedBean(new _setPinnedRightWidthFeature__WEBPACK_IMPORTED_MODULE_8__["SetPinnedRightWidthFeature"](_this.eContainer)); }); + this.forContainers(allMiddle, function () { return _this.createManagedBean(new _setHeightFeature__WEBPACK_IMPORTED_MODULE_9__["SetHeightFeature"](_this.eContainer, _this.eWrapper)); }); + this.forContainers(allNoFW, function () { return _this.createManagedBean(new _dragListenerFeature__WEBPACK_IMPORTED_MODULE_10__["DragListenerFeature"](_this.eContainer)); }); + this.forContainers(allCenter, function () { return _this.createManagedBean(new _centerWidthFeature__WEBPACK_IMPORTED_MODULE_11__["CenterWidthFeature"](function (width) { return _this.comp.setContainerWidth(width + "px"); })); }); + }; + RowContainerCtrl.prototype.listenOnDomOrder = function () { + var _this = this; + var listener = function () { return _this.comp.setDomOrder(_this.gridOptionsWrapper.isEnsureDomOrder()); }; + this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_13__["GridOptionsWrapper"].PROP_DOM_LAYOUT, listener); + listener(); }; - // calls the callback for each cellComp that match the provided rowNodes and columns. eg if one row node - // and two columns provided, that identifies 4 cells, so callback gets called 4 times, once for each cell. - RowRenderer.prototype.forEachCellCompFiltered = function (rowNodes, columns, callback) { + // when editing a pinned row, if the cell is half outside the scrollable area, the browser can + // scroll the column into view. we do not want this, the pinned sections should never scroll. + // so we listen to scrolls on these containers and reset the scroll if we find one. + RowContainerCtrl.prototype.stopHScrollOnPinnedRows = function () { var _this = this; - var rowIdsMap; - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(rowNodes)) { - rowIdsMap = { - top: {}, - bottom: {}, - normal: {} - }; - rowNodes.forEach(function (rowNode) { - if (rowNode.rowPinned === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_TOP) { - rowIdsMap.top[rowNode.id] = true; - } - else if (rowNode.rowPinned === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_BOTTOM) { - rowIdsMap.bottom[rowNode.id] = true; - } - else { - rowIdsMap.normal[rowNode.id] = true; - } - }); - } - var colIdsMap; - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(columns)) { - colIdsMap = {}; - columns.forEach(function (colKey) { - var column = _this.columnController.getGridColumn(colKey); - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(column)) { - colIdsMap[column.getId()] = true; - } - }); - } - var processRow = function (rowComp) { - var rowNode = rowComp.getRowNode(); - var id = rowNode.id; - var floating = rowNode.rowPinned; - // skip this row if it is missing from the provided list - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(rowIdsMap)) { - if (floating === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_BOTTOM) { - if (!rowIdsMap.bottom[id]) { - return; - } - } - else if (floating === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_TOP) { - if (!rowIdsMap.top[id]) { - return; - } - } - else { - if (!rowIdsMap.normal[id]) { - return; - } - } - } - rowComp.forEachCellComp(function (cellComp) { - var colId = cellComp.getColumn().getId(); - var excludeColFromRefresh = colIdsMap && !colIdsMap[colId]; - if (excludeColFromRefresh) { - return; - } - callback(cellComp); - }); - }; - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowCompsByIndex, function (index, rowComp) { - processRow(rowComp); + this.forContainers([RowContainerName.TOP_CENTER, RowContainerName.BOTTOM_CENTER], function () { + var resetScrollLeft = function () { return _this.eViewport.scrollLeft = 0; }; + _this.addManagedListener(_this.eViewport, 'scroll', resetScrollLeft); }); - if (this.floatingTopRowComps) { - this.floatingTopRowComps.forEach(processRow); - } - if (this.floatingBottomRowComps) { - this.floatingBottomRowComps.forEach(processRow); - } - }; - RowRenderer.prototype.destroy = function () { - var rowIndexesToRemove = Object.keys(this.rowCompsByIndex); - this.removeRowComps(rowIndexesToRemove); - _super.prototype.destroy.call(this); }; - RowRenderer.prototype.binRowComps = function (recycleRows) { + RowContainerCtrl.prototype.onDisplayedColumnsChanged = function () { var _this = this; - var rowsToRecycle = {}; - var indexesToRemove; - if (recycleRows) { - indexesToRemove = []; - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowCompsByIndex, function (index, rowComp) { - var rowNode = rowComp.getRowNode(); - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(rowNode.id)) { - rowsToRecycle[rowNode.id] = rowComp; - delete _this.rowCompsByIndex[index]; - } - else { - indexesToRemove.push(index); - } - }); - } - else { - indexesToRemove = Object.keys(this.rowCompsByIndex); - } - this.removeRowComps(indexesToRemove); - return rowsToRecycle; + this.forContainers([RowContainerName.CENTER], function () { return _this.onHorizontalViewportChanged(); }); }; - // takes array of row indexes - RowRenderer.prototype.removeRowComps = function (rowsToRemove) { + RowContainerCtrl.prototype.onDisplayedColumnsWidthChanged = function () { var _this = this; - // if no fromIndex then set to -1, which will refresh everything - // let realFromIndex = -1; - rowsToRemove.forEach(function (indexToRemove) { - var renderedRow = _this.rowCompsByIndex[indexToRemove]; - renderedRow.destroy(); - delete _this.rowCompsByIndex[indexToRemove]; - }); - }; - // gets called when rows don't change, but viewport does, so after: - // 1) height of grid body changes, ie number of displayed rows has changed - // 2) grid scrolled to new position - // 3) ensure index visible (which is a scroll) - RowRenderer.prototype.redrawAfterScroll = function () { - this.getLockOnRefresh(); - this.redraw(null, false, true); - this.releaseLockOnRefresh(); + this.forContainers([RowContainerName.CENTER], function () { return _this.onHorizontalViewportChanged(); }); }; - RowRenderer.prototype.removeRowCompsNotToDraw = function (indexesToDraw) { - // for speedy lookup, dump into map - var indexesToDrawMap = {}; - indexesToDraw.forEach(function (index) { return (indexesToDrawMap[index] = true); }); - var existingIndexes = Object.keys(this.rowCompsByIndex); - var indexesNotToDraw = existingIndexes.filter(function (index) { return !indexesToDrawMap[index]; }); - this.removeRowComps(indexesNotToDraw); + RowContainerCtrl.prototype.onScrollVisibilityChanged = function () { + if (this.name !== RowContainerName.CENTER) { + return; + } + var visible = this.scrollVisibleService.isHorizontalScrollShowing(); + var scrollbarWidth = visible ? (this.gridOptionsWrapper.getScrollbarWidth() || 0) : 0; + var height = scrollbarWidth == 0 ? '100%' : "calc(100% + " + scrollbarWidth + "px)"; + this.comp.setViewportHeight(height); }; - RowRenderer.prototype.calculateIndexesToDraw = function (rowsToRecycle) { + // this methods prevents the grid views from being scrolled while the dragService is being used + // eg. the view should not scroll up and down while dragging rows using the rowDragComp. + RowContainerCtrl.prototype.addPreventScrollWhileDragging = function () { var _this = this; - // all in all indexes in the viewport - var indexesToDraw = _utils__WEBPACK_IMPORTED_MODULE_8__["_"].createArrayOfNumbers(this.firstRenderedRow, this.lastRenderedRow); - var checkRowToDraw = function (indexStr, rowComp) { - var index = Number(indexStr); - if (index < _this.firstRenderedRow || index > _this.lastRenderedRow) { - if (_this.doNotUnVirtualiseRow(rowComp)) { - indexesToDraw.push(index); + var preventScroll = function (e) { + if (_this.dragService.isDragging()) { + if (e.cancelable) { + e.preventDefault(); } } }; - // if we are redrawing due to scrolling change, then old rows are in this.rowCompsByIndex - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowCompsByIndex, checkRowToDraw); - // if we are redrawing due to model update, then old rows are in rowsToRecycle - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(rowsToRecycle, checkRowToDraw); - indexesToDraw.sort(function (a, b) { return a - b; }); - return indexesToDraw; - }; - RowRenderer.prototype.redraw = function (rowsToRecycle, animate, afterScroll) { - var _this = this; - if (animate === void 0) { animate = false; } - if (afterScroll === void 0) { afterScroll = false; } - this.maxDivHeightScaler.updateOffset(); - this.workOutFirstAndLastRowsToRender(); - // the row can already exist and be in the following: - // rowsToRecycle -> if model change, then the index may be different, however row may - // exist here from previous time (mapped by id). - // this.rowCompsByIndex -> if just a scroll, then this will contain what is currently in the viewport - // this is all the indexes we want, including those that already exist, so this method - // will end up going through each index and drawing only if the row doesn't already exist - var indexesToDraw = this.calculateIndexesToDraw(rowsToRecycle); - this.removeRowCompsNotToDraw(indexesToDraw); - // never animate when doing print layout - as we want to get things ready to print as quickly as possible, - // otherwise we risk the printer printing a row that's half faded (half way through fading in) - if (this.printLayout) { - animate = false; - } - // add in new rows - var nextVmTurnFunctions = []; - var rowComps = []; - indexesToDraw.forEach(function (rowIndex) { - var rowComp = _this.createOrUpdateRowComp(rowIndex, rowsToRecycle, animate, afterScroll); - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(rowComp)) { - rowComps.push(rowComp); - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].pushAll(nextVmTurnFunctions, rowComp.getAndClearNextVMTurnFunctions()); - } - }); - this.flushContainers(rowComps); - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].executeNextVMTurn(nextVmTurnFunctions); - var useAnimationFrame = afterScroll && !this.gridOptionsWrapper.isSuppressAnimationFrame() && !this.printLayout; - if (useAnimationFrame) { - this.beans.taskQueue.addDestroyTask(this.destroyRowComps.bind(this, rowsToRecycle, animate)); - } - else { - this.destroyRowComps(rowsToRecycle, animate); - } - this.checkAngularCompile(); - this.gridPanel.updateRowCount(); + this.eContainer.addEventListener('touchmove', preventScroll, { passive: false }); + this.addDestroyFunc(function () { return _this.eContainer.removeEventListener('touchmove', preventScroll); }); }; - RowRenderer.prototype.flushContainers = function (rowComps) { - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowContainers, function (key, rowContainerComp) { - if (rowContainerComp) { - rowContainerComp.flushRowTemplates(); - } - }); - rowComps.forEach(function (rowComp) { return rowComp.afterFlush(); }); + // this gets called whenever a change in the viewport, so we can inform column controller it has to work + // out the virtual columns again. gets called from following locations: + // + ensureColVisible, scroll, init, layoutChanged, displayedColumnsChanged, API (doLayout) + RowContainerCtrl.prototype.onHorizontalViewportChanged = function () { + var scrollWidth = this.getCenterWidth(); + var scrollPosition = this.getCenterViewportScrollLeft(); + this.columnModel.setViewportPosition(scrollWidth, scrollPosition); }; - RowRenderer.prototype.onDisplayedColumnsChanged = function () { - var pinningLeft = this.columnController.isPinningLeft(); - var pinningRight = this.columnController.isPinningRight(); - var atLeastOneChanged = this.pinningLeft !== pinningLeft || pinningRight !== this.pinningRight; - if (atLeastOneChanged) { - this.pinningLeft = pinningLeft; - this.pinningRight = pinningRight; - if (this.embedFullWidthRows) { - this.redrawFullWidthEmbeddedRows(); - } - } + RowContainerCtrl.prototype.getCenterWidth = function () { + return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["getInnerWidth"])(this.eViewport); }; - // when embedding, what gets showed in each section depends on what is pinned. eg if embedding group expand / collapse, - // then it should go into the pinned left area if pinning left, or the center area if not pinning. - RowRenderer.prototype.redrawFullWidthEmbeddedRows = function () { - // if either of the pinned panels has shown / hidden, then need to redraw the fullWidth bits when - // embedded, as what appears in each section depends on whether we are pinned or not - var rowsToRemove = []; - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowCompsByIndex, function (id, rowComp) { - if (rowComp.isFullWidth()) { - var rowIndex = rowComp.getRowNode().rowIndex; - rowsToRemove.push(rowIndex.toString()); - } - }); - this.refreshFloatingRowComps(); - this.removeRowComps(rowsToRemove); - this.redrawAfterScroll(); + RowContainerCtrl.prototype.getCenterViewportScrollLeft = function () { + // we defer to a util, as how you calculated scrollLeft when doing RTL depends on the browser + return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["getScrollLeft"])(this.eViewport, this.enableRtl); }; - RowRenderer.prototype.refreshFullWidthRows = function () { - var rowsToRemove = []; - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowCompsByIndex, function (id, rowComp) { - if (rowComp.isFullWidth()) { - var fullWidthRowsRefreshed = rowComp.refreshFullWidth(); - if (!fullWidthRowsRefreshed) { - var rowIndex = rowComp.getRowNode().rowIndex; - rowsToRemove.push(rowIndex.toString()); - } - } - }); - this.removeRowComps(rowsToRemove); - this.redrawAfterScroll(); + RowContainerCtrl.prototype.registerViewportResizeListener = function (listener) { + var unsubscribeFromResize = this.resizeObserverService.observeResize(this.eViewport, listener); + this.addDestroyFunc(function () { return unsubscribeFromResize(); }); }; - RowRenderer.prototype.createOrUpdateRowComp = function (rowIndex, rowsToRecycle, animate, afterScroll) { - var rowNode; - var rowComp = this.rowCompsByIndex[rowIndex]; - // if no row comp, see if we can get it from the previous rowComps - if (!rowComp) { - rowNode = this.paginationProxy.getRow(rowIndex); - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(rowNode) && _utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(rowsToRecycle) && rowsToRecycle[rowNode.id] && rowNode.alreadyRendered) { - rowComp = rowsToRecycle[rowNode.id]; - rowsToRecycle[rowNode.id] = null; - } - } - var creatingNewRowComp = !rowComp; - if (creatingNewRowComp) { - // create a new one - if (!rowNode) { - rowNode = this.paginationProxy.getRow(rowIndex); - } - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(rowNode)) { - rowComp = this.createRowComp(rowNode, animate, afterScroll); - } - else { - // this should never happen - if somehow we are trying to create - // a row for a rowNode that does not exist. - return; - } - } - else { - // ensure row comp is in right position in DOM - rowComp.ensureDomOrder(); - } - if (rowNode) { - // set node as 'alreadyRendered' to ensure we only recycle rowComps that have been rendered, this ensures - // we don't reuse rowComps that have been removed and then re-added in the same batch transaction. - rowNode.alreadyRendered = true; - } - this.rowCompsByIndex[rowIndex] = rowComp; - return rowComp; + RowContainerCtrl.prototype.isViewportVisible = function () { + return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["isVisible"])(this.eViewport); }; - RowRenderer.prototype.destroyRowComps = function (rowCompsMap, animate) { - var delayedFuncs = []; - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(rowCompsMap, function (nodeId, rowComp) { - // if row was used, then it's null - if (!rowComp) { - return; - } - rowComp.destroy(animate); - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].pushAll(delayedFuncs, rowComp.getAndClearDelayedDestroyFunctions()); - }); - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].executeInAWhile(delayedFuncs); + RowContainerCtrl.prototype.isViewportHScrollShowing = function () { + return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["isHorizontalScrollShowing"])(this.eViewport); }; - RowRenderer.prototype.checkAngularCompile = function () { - var _this = this; - // if we are doing angular compiling, then do digest the scope here - if (this.gridOptionsWrapper.isAngularCompileRows()) { - // we do it in a timeout, in case we are already in an apply - window.setTimeout(function () { - _this.$scope.$apply(); - }, 0); - } + RowContainerCtrl.prototype.getViewportScrollLeft = function () { + return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["getScrollLeft"])(this.eViewport, this.enableRtl); }; - RowRenderer.prototype.workOutFirstAndLastRowsToRender = function () { - var _this = this; - var newFirst; - var newLast; - if (!this.paginationProxy.isRowsToRender()) { - newFirst = 0; - newLast = -1; // setting to -1 means nothing in range - } - else if (this.printLayout) { - newFirst = this.paginationProxy.getPageFirstRow(); - newLast = this.paginationProxy.getPageLastRow(); - } - else { - var paginationOffset = this.paginationProxy.getPixelOffset(); - var maxDivHeightScaler = this.maxDivHeightScaler.getOffset(); - var bodyVRange = this.gridPanel.getVScrollPosition(); - var bodyTopPixel = bodyVRange.top; - var bodyBottomPixel = bodyVRange.bottom; - var bufferPixels = this.gridOptionsWrapper.getRowBufferInPixels(); - var firstPixel = bodyTopPixel + paginationOffset + maxDivHeightScaler - bufferPixels; - var lastPixel = bodyBottomPixel + paginationOffset + maxDivHeightScaler + bufferPixels; - this.ensureAllRowsInRangeHaveHeightsCalculated(firstPixel, lastPixel); - var firstRowIndex = this.paginationProxy.getRowIndexAtPixel(firstPixel); - var lastRowIndex = this.paginationProxy.getRowIndexAtPixel(lastPixel); - var pageFirstRow = this.paginationProxy.getPageFirstRow(); - var pageLastRow = this.paginationProxy.getPageLastRow(); - // adjust, in case buffer extended actual size - if (firstRowIndex < pageFirstRow) { - firstRowIndex = pageFirstRow; - } - if (lastRowIndex > pageLastRow) { - lastRowIndex = pageLastRow; - } - newFirst = firstRowIndex; - newLast = lastRowIndex; - } - // sometimes user doesn't set CSS right and ends up with grid with no height and grid ends up - // trying to render all the rows, eg 10,000+ rows. this will kill the browser. so instead of - // killing the browser, we limit the number of rows. just in case some use case we didn't think - // of, we also have a property to not do this operation. - var rowLayoutNormal = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].DOM_LAYOUT_NORMAL; - var suppressRowCountRestriction = this.gridOptionsWrapper.isSuppressMaxRenderedRowRestriction(); - var rowBufferMaxSize = Math.max(this.gridOptionsWrapper.getRowBuffer(), 500); - if (rowLayoutNormal && !suppressRowCountRestriction) { - if (newLast - newFirst > rowBufferMaxSize) { - newLast = newFirst + rowBufferMaxSize; - } - } - var firstDiffers = newFirst !== this.firstRenderedRow; - var lastDiffers = newLast !== this.lastRenderedRow; - if (firstDiffers || lastDiffers) { - this.firstRenderedRow = newFirst; - this.lastRenderedRow = newLast; - var event_1 = { - type: _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_VIEWPORT_CHANGED, - firstRow: newFirst, - lastRow: newLast, - api: this.gridApi, - columnApi: this.columnApi - }; - this.eventService.dispatchEvent(event_1); - } - // only dispatch firstDataRendered if we have actually rendered some data - if (this.paginationProxy.isRowsToRender()) { - var event_2 = { - type: _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_FIRST_DATA_RENDERED, - firstRow: newFirst, - lastRow: newLast, - api: this.gridApi, - columnApi: this.columnApi - }; - // added a small delay here because in some scenarios this can be fired - // before the grid is actually rendered, causing component creation - // on EVENT_FIRST_DATA_RENDERED to fail. - window.setTimeout(function () { return _this.eventService.dispatchEventOnce(event_2); }, 50); - } + RowContainerCtrl.prototype.isHorizontalScrollShowing = function () { + var isAlwaysShowHorizontalScroll = this.gridOptionsWrapper.isAlwaysShowHorizontalScroll(); + return isAlwaysShowHorizontalScroll || Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["isHorizontalScrollShowing"])(this.eViewport); }; - RowRenderer.prototype.ensureAllRowsInRangeHaveHeightsCalculated = function (topPixel, bottomPixel) { - // ensureRowHeightsVisible only works with CSRM, as it's the only row model that allows lazy row height calcs. - // all the other row models just hard code so the method just returns back false - var rowHeightsChanged = this.paginationProxy.ensureRowHeightsValid(topPixel, bottomPixel, -1, -1); - if (rowHeightsChanged) { - // if row heights have changed, we need to resize the containers the rows sit it - this.sizeContainerToPageHeight(); - // we also need to update heightScaler as this has dependency of row container height - this.maxDivHeightScaler.updateOffset(); - } + RowContainerCtrl.prototype.getViewportElement = function () { + return this.eViewport; }; - RowRenderer.prototype.getFirstVirtualRenderedRow = function () { - return this.firstRenderedRow; + RowContainerCtrl.prototype.setContainerTranslateX = function (amount) { + this.eContainer.style.transform = "translateX(" + amount + "px)"; }; - RowRenderer.prototype.getLastVirtualRenderedRow = function () { - return this.lastRenderedRow; + RowContainerCtrl.prototype.getHScrollPosition = function () { + var res = { + left: this.eViewport.scrollLeft, + right: this.eViewport.scrollLeft + this.eViewport.offsetWidth + }; + return res; }; - // check that none of the rows to remove are editing or focused as: - // a) if editing, we want to keep them, otherwise the user will loose the context of the edit, - // eg user starts editing, enters some text, then scrolls down and then up, next time row rendered - // the edit is reset - so we want to keep it rendered. - // b) if focused, we want ot keep keyboard focus, so if user ctrl+c, it goes to clipboard, - // otherwise the user can range select and drag (with focus cell going out of the viewport) - // and then ctrl+c, nothing will happen if cell is removed from dom. - // c) if detail record of master detail, as users complained that the context of detail rows - // was getting lost when detail row out of view. eg user expands to show detail row, - // then manipulates the detail panel (eg sorts the detail grid), then context is lost - // after detail panel is scrolled out of / into view. - RowRenderer.prototype.doNotUnVirtualiseRow = function (rowComp) { - var REMOVE_ROW = false; - var KEEP_ROW = true; - var rowNode = rowComp.getRowNode(); - var rowHasFocus = this.focusController.isRowNodeFocused(rowNode); - var rowIsEditing = rowComp.isEditing(); - var rowIsDetail = rowNode.detail; - var mightWantToKeepRow = rowHasFocus || rowIsEditing || rowIsDetail; - // if we deffo don't want to keep it, - if (!mightWantToKeepRow) { - return REMOVE_ROW; + RowContainerCtrl.prototype.setCenterViewportScrollLeft = function (value) { + // we defer to a util, as how you calculated scrollLeft when doing RTL depends on the browser + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setScrollLeft"])(this.eViewport, value, this.enableRtl); + }; + RowContainerCtrl.prototype.onDisplayedRowsChanged = function () { + var _this = this; + var fullWithContainer = this.name === RowContainerName.TOP_FULL_WIDTH + || this.name === RowContainerName.BOTTOM_FULL_WIDTH + || this.name === RowContainerName.FULL_WIDTH; + var doesRowMatch = function (rowCtrl) { + var fullWidthRow = rowCtrl.isFullWidth(); + var printLayout = _this.gridOptionsWrapper.getDomLayout() === _constants_constants__WEBPACK_IMPORTED_MODULE_12__["Constants"].DOM_LAYOUT_PRINT; + var embedFW = _this.embedFullWidthRows || printLayout; + var match = fullWithContainer ? + !embedFW && fullWidthRow + : embedFW || !fullWidthRow; + return match; + }; + // this list contains either all pinned top, center or pinned bottom rows + var allRowsRegardlessOfFullWidth = this.getRowCtrls(); + // this filters out rows not for this container, eg if it's a full with row, but we are not full with container + var rowsThisContainer = allRowsRegardlessOfFullWidth.filter(doesRowMatch); + this.comp.setRowCtrls(rowsThisContainer); + }; + RowContainerCtrl.prototype.getRowCtrls = function () { + switch (this.name) { + case RowContainerName.TOP_CENTER: + case RowContainerName.TOP_LEFT: + case RowContainerName.TOP_RIGHT: + case RowContainerName.TOP_FULL_WIDTH: + return this.rowRenderer.getTopRowCtrls(); + case RowContainerName.BOTTOM_CENTER: + case RowContainerName.BOTTOM_LEFT: + case RowContainerName.BOTTOM_RIGHT: + case RowContainerName.BOTTOM_FULL_WIDTH: + return this.rowRenderer.getBottomRowCtrls(); + default: + return this.rowRenderer.getRowCtrls(); } - // editing row, only remove if it is no longer rendered, eg filtered out or new data set. - // the reason we want to keep is if user is scrolling up and down, we don't want to loose - // the context of the editing in process. - var rowNodePresent = this.paginationProxy.isRowPresent(rowNode); - return rowNodePresent ? KEEP_ROW : REMOVE_ROW; }; - RowRenderer.prototype.createRowComp = function (rowNode, animate, afterScroll) { - var suppressAnimationFrame = this.gridOptionsWrapper.isSuppressAnimationFrame(); - // we don't use animations frames for printing, so the user can put the grid into print mode - // and immediately print - otherwise the user would have to wait for the rows to draw in the background - // (via the animation frames) which is awkward to do from code. - // we only do the animation frames after scrolling, as this is where we want the smooth user experience. - // having animation frames for other times makes the grid look 'jumpy'. - var useAnimationFrameForCreate = afterScroll && !suppressAnimationFrame && !this.printLayout; - var rowComp = new _rowComp__WEBPACK_IMPORTED_MODULE_1__["RowComp"](this.$scope, this.rowContainers.body, this.rowContainers.pinnedLeft, this.rowContainers.pinnedRight, this.rowContainers.fullWidth, rowNode, this.beans, animate, useAnimationFrameForCreate, this.printLayout, this.embedFullWidthRows); - rowComp.init(); - return rowComp; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('scrollVisibleService') + ], RowContainerCtrl.prototype, "scrollVisibleService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('dragService') + ], RowContainerCtrl.prototype, "dragService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('ctrlsService') + ], RowContainerCtrl.prototype, "ctrlsService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnModel') + ], RowContainerCtrl.prototype, "columnModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('resizeObserverService') + ], RowContainerCtrl.prototype, "resizeObserverService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowRenderer') + ], RowContainerCtrl.prototype, "rowRenderer", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], RowContainerCtrl.prototype, "postConstruct", null); + return RowContainerCtrl; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); + + + +/***/ }), +/* 126 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowContainerEventsFeature", function() { return RowContainerEventsFeature; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _utils_event__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(21); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _rendering_row_rowCtrl__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(113); +/* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(43); +/* harmony import */ var _widgets_touchListener__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(82); +/* harmony import */ var _utils_keyboard__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(49); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(23); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(65); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(15); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(7); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(18); +/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(17); +/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(16); +/* harmony import */ var _rendering_cell_cellCtrl__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(114); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - RowRenderer.prototype.getRenderedNodes = function () { - var renderedRows = this.rowCompsByIndex; - return Object.keys(renderedRows).map(function (key) { return renderedRows[key].getRowNode(); }); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - // we use index for rows, but column object for columns, as the next column (by index) might not - // be visible (header grouping) so it's not reliable, so using the column object instead. - RowRenderer.prototype.navigateToNextCell = function (event, key, currentCell, allowUserOverride) { - // we keep searching for a next cell until we find one. this is how the group rows get skipped - var nextCell = currentCell; - var hitEdgeOfGrid = false; - while (nextCell && (nextCell === currentCell || !this.isValidNavigateCell(nextCell))) { - // if the current cell is spanning across multiple columns, we need to move - // our current position to be the last cell on the right before finding the - // the next target. - if (this.gridOptionsWrapper.isEnableRtl()) { - if (key === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].KEY_LEFT) { - nextCell = this.getLastCellOfColSpan(nextCell); - } - } - else if (key === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].KEY_RIGHT) { - nextCell = this.getLastCellOfColSpan(nextCell); - } - nextCell = this.cellNavigationService.getNextCellToFocus(key, nextCell); - // eg if going down, and nextCell=undefined, means we are gone past the last row - hitEdgeOfGrid = _utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(nextCell); - } - if (hitEdgeOfGrid && event.keyCode === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].KEY_UP) { - nextCell = { - rowIndex: -1, - rowPinned: null, - column: currentCell.column - }; - } - // allow user to override what cell to go to next. when doing normal cell navigation (with keys) - // we allow this, however if processing 'enter after edit' we don't allow override - if (allowUserOverride) { - var userFunc = this.gridOptionsWrapper.getNavigateToNextCellFunc(); - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(userFunc)) { - var params = { - key: key, - previousCellPosition: currentCell, - nextCellPosition: nextCell ? nextCell : null, - event: event - }; - var userCell = userFunc(params); - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(userCell)) { - if (userCell.floating) { - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].doOnce(function () { console.warn("ag-Grid: tabToNextCellFunc return type should have attributes: rowIndex, rowPinned, column. However you had 'floating', maybe you meant 'rowPinned'?"); }, 'no floating in userCell'); - userCell.rowPinned = userCell.floating; - } - nextCell = { - rowPinned: userCell.rowPinned, - rowIndex: userCell.rowIndex, - column: userCell.column - }; - } - else { - nextCell = null; - } - } +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); } - // no next cell means we have reached a grid boundary, eg left, right, top or bottom of grid - if (!nextCell) { + finally { if (e) throw e.error; } + } + return ar; +}; + + + + + + + + + + + + + + + +var RowContainerEventsFeature = /** @class */ (function (_super) { + __extends(RowContainerEventsFeature, _super); + function RowContainerEventsFeature(element) { + var _this = _super.call(this) || this; + _this.element = element; + return _this; + } + RowContainerEventsFeature.prototype.postConstruct = function () { + this.addMouseListeners(); + this.mockContextMenuForIPad(); + this.addKeyboardEvents(); + }; + RowContainerEventsFeature.prototype.addKeyboardEvents = function () { + var _this = this; + var eventNames = ['keydown', 'keypress']; + eventNames.forEach(function (eventName) { + var listener = _this.processKeyboardEvent.bind(_this, eventName); + _this.addManagedListener(_this.element, eventName, listener); + }); + }; + RowContainerEventsFeature.prototype.addMouseListeners = function () { + var _this = this; + var mouseDownEvent = Object(_utils_event__WEBPACK_IMPORTED_MODULE_1__["isEventSupported"])('touchstart') ? 'touchstart' : 'mousedown'; + var eventNames = ['dblclick', 'contextmenu', 'mouseover', 'mouseout', 'click', mouseDownEvent]; + eventNames.forEach(function (eventName) { + var listener = _this.processMouseEvent.bind(_this, eventName); + _this.addManagedListener(_this.element, eventName, listener); + }); + }; + RowContainerEventsFeature.prototype.processMouseEvent = function (eventName, mouseEvent) { + if (!this.mouseEventService.isEventFromThisGrid(mouseEvent) || + Object(_utils_event__WEBPACK_IMPORTED_MODULE_1__["isStopPropagationForAgGrid"])(mouseEvent)) { return; } - if (nextCell.rowIndex < 0) { - var headerLen = this.beans.headerNavigationService.getHeaderRowCount(); - this.focusController.focusHeaderPosition({ - headerRowIndex: headerLen + (nextCell.rowIndex), column: currentCell.column - }); - return; + var rowComp = this.getRowForEvent(mouseEvent); + var cellCtrl = this.mouseEventService.getRenderedCellForEvent(mouseEvent); + if (eventName === "contextmenu") { + this.handleContextMenuMouseEvent(mouseEvent, null, rowComp, cellCtrl); } - // in case we have col spanning we get the cellComp and use it to - // get the position. This was we always focus the first cell inside - // the spanning. - this.ensureCellVisible(nextCell); // ensureCellVisible first, to make sure nextCell is rendered - var cellComp = this.getComponentForCell(nextCell); - // not guaranteed to have a cellComp when using the SSRM as blocks are loading. - if (!cellComp) { - return; + else { + if (cellCtrl) { + cellCtrl.onMouseEvent(eventName, mouseEvent); + } + if (rowComp) { + rowComp.onMouseEvent(eventName, mouseEvent); + } } - nextCell = cellComp.getCellPosition(); - // we call this again, as nextCell can be different to it's previous value due to Column Spanning - // (ie if cursor moving from right to left, and cell is spanning columns, then nextCell was the - // last column in the group, however now it's the first column in the group). if we didn't do - // ensureCellVisible again, then we could only be showing the last portion (last column) of the - // merged cells. - this.ensureCellVisible(nextCell); - this.focusController.setFocusedCell(nextCell.rowIndex, nextCell.column, nextCell.rowPinned, true); - if (this.rangeController) { - this.rangeController.setRangeToCell(nextCell); + }; + RowContainerEventsFeature.prototype.mockContextMenuForIPad = function () { + var _this = this; + // we do NOT want this when not in iPad, otherwise we will be doing + if (!Object(_utils_browser__WEBPACK_IMPORTED_MODULE_4__["isIOSUserAgent"])()) { + return; } + var touchListener = new _widgets_touchListener__WEBPACK_IMPORTED_MODULE_5__["TouchListener"](this.element); + var longTapListener = function (event) { + var rowComp = _this.getRowForEvent(event.touchEvent); + var cellComp = _this.mouseEventService.getRenderedCellForEvent(event.touchEvent); + _this.handleContextMenuMouseEvent(null, event.touchEvent, rowComp, cellComp); + }; + this.addManagedListener(touchListener, _widgets_touchListener__WEBPACK_IMPORTED_MODULE_5__["TouchListener"].EVENT_LONG_TAP, longTapListener); + this.addDestroyFunc(function () { return touchListener.destroy(); }); }; - RowRenderer.prototype.isValidNavigateCell = function (cell) { - var rowNode = this.rowPositionUtils.getRowNode(cell); - // we do not allow focusing on detail rows and full width rows - if (rowNode.detail || rowNode.isFullWidthCell()) { - return false; + RowContainerEventsFeature.prototype.getRowForEvent = function (event) { + var sourceElement = event.target; + while (sourceElement) { + var rowCon = this.gridOptionsWrapper.getDomData(sourceElement, _rendering_row_rowCtrl__WEBPACK_IMPORTED_MODULE_3__["RowCtrl"].DOM_DATA_KEY_ROW_CTRL); + if (rowCon) { + return rowCon; + } + sourceElement = sourceElement.parentElement; } - // if not a group, then we have a valid row, so quit the search - if (!rowNode.group) { - return true; + return null; + }; + RowContainerEventsFeature.prototype.handleContextMenuMouseEvent = function (mouseEvent, touchEvent, rowComp, cellCtrl) { + var rowNode = rowComp ? rowComp.getRowNode() : null; + var column = cellCtrl ? cellCtrl.getColumn() : null; + var value = null; + if (column) { + var event_1 = mouseEvent ? mouseEvent : touchEvent; + cellCtrl.dispatchCellContextMenuEvent(event_1); + value = this.valueService.getValue(column, rowNode); } - // full width rows cannot be focused, so if it's a group and using full width rows, - // we need to skip over the row - var pivotMode = this.columnController.isPivotMode(); - var usingFullWidthRows = this.gridOptionsWrapper.isGroupUseEntireRow(pivotMode); - if (!usingFullWidthRows) { - return true; + // if user clicked on a cell, anchor to that cell, otherwise anchor to the grid panel + var gridBodyCon = this.ctrlsService.getGridBodyCtrl(); + var anchorToElement = cellCtrl ? cellCtrl.getGui() : gridBodyCon.getGridBodyElement(); + if (this.contextMenuFactory) { + this.contextMenuFactory.onContextMenu(mouseEvent, touchEvent, rowNode, column, value, anchorToElement); } - return false; }; - RowRenderer.prototype.getLastCellOfColSpan = function (cell) { - var cellComp = this.getComponentForCell(cell); - if (!cellComp) { - return cell; + RowContainerEventsFeature.prototype.processKeyboardEvent = function (eventName, keyboardEvent) { + var cellComp = Object(_utils_event__WEBPACK_IMPORTED_MODULE_1__["getCtrlForEvent"])(this.gridOptionsWrapper, keyboardEvent, _rendering_cell_cellCtrl__WEBPACK_IMPORTED_MODULE_14__["CellCtrl"].DOM_DATA_KEY_CELL_CTRL); + var rowComp = Object(_utils_event__WEBPACK_IMPORTED_MODULE_1__["getCtrlForEvent"])(this.gridOptionsWrapper, keyboardEvent, _rendering_row_rowCtrl__WEBPACK_IMPORTED_MODULE_3__["RowCtrl"].DOM_DATA_KEY_ROW_CTRL); + if (keyboardEvent.defaultPrevented) { + return; } - var colSpanningList = cellComp.getColSpanningList(); - if (colSpanningList.length === 1) { - return cell; + if (cellComp) { + this.processCellKeyboardEvent(cellComp, eventName, keyboardEvent); + } + else if (rowComp && rowComp.isFullWidth()) { + this.processFullWidthRowKeyboardEvent(rowComp, eventName, keyboardEvent); } - return { - rowIndex: cell.rowIndex, - column: _utils__WEBPACK_IMPORTED_MODULE_8__["_"].last(colSpanningList), - rowPinned: cell.rowPinned - }; }; - RowRenderer.prototype.ensureCellVisible = function (gridCell) { - // this scrolls the row into view - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(gridCell.rowPinned)) { - this.gridPanel.ensureIndexVisible(gridCell.rowIndex); + RowContainerEventsFeature.prototype.processCellKeyboardEvent = function (cellCtrl, eventName, keyboardEvent) { + var rowNode = cellCtrl.getRowNode(); + var column = cellCtrl.getColumn(); + var editing = cellCtrl.isEditing(); + var gridProcessingAllowed = !Object(_utils_keyboard__WEBPACK_IMPORTED_MODULE_6__["isUserSuppressingKeyboardEvent"])(this.gridOptionsWrapper, keyboardEvent, rowNode, column, editing); + if (gridProcessingAllowed) { + switch (eventName) { + case 'keydown': + // first see if it's a scroll key, page up / down, home / end etc + var wasScrollKey = !editing && this.navigationService.handlePageScrollingKey(keyboardEvent); + // if not a scroll key, then we pass onto cell + if (!wasScrollKey) { + cellCtrl.onKeyDown(keyboardEvent); + } + // perform clipboard and undo / redo operations + this.doGridOperations(keyboardEvent, cellCtrl.isEditing()); + break; + case 'keypress': + cellCtrl.onKeyPress(keyboardEvent); + break; + } } - if (!gridCell.column.isPinned()) { - this.gridPanel.ensureColumnVisible(gridCell.column); + if (eventName === 'keydown') { + var cellKeyDownEvent = cellCtrl.createEvent(keyboardEvent, _events__WEBPACK_IMPORTED_MODULE_7__["Events"].EVENT_CELL_KEY_DOWN); + this.eventService.dispatchEvent(cellKeyDownEvent); } - // need to nudge the scrolls for the floating items. otherwise when we set focus on a non-visible - // floating cell, the scrolls get out of sync - this.gridPanel.horizontallyScrollHeaderCenterAndFloatingCenter(); - // need to flush frames, to make sure the correct cells are rendered - this.animationFrameService.flushAllFrames(); - }; - RowRenderer.prototype.startEditingCell = function (gridCell, keyPress, charPress) { - var cell = this.getComponentForCell(gridCell); - if (cell) { - cell.startRowOrCellEdit(keyPress, charPress); + if (eventName === 'keypress') { + var cellKeyPressEvent = cellCtrl.createEvent(keyboardEvent, _events__WEBPACK_IMPORTED_MODULE_7__["Events"].EVENT_CELL_KEY_PRESS); + this.eventService.dispatchEvent(cellKeyPressEvent); } }; - RowRenderer.prototype.getComponentForCell = function (cellPosition) { - var rowComponent; - switch (cellPosition.rowPinned) { - case _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_TOP: - rowComponent = this.floatingTopRowComps[cellPosition.rowIndex]; - break; - case _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_BOTTOM: - rowComponent = this.floatingBottomRowComps[cellPosition.rowIndex]; - break; - default: - rowComponent = this.rowCompsByIndex[cellPosition.rowIndex]; - break; + RowContainerEventsFeature.prototype.processFullWidthRowKeyboardEvent = function (rowComp, eventName, keyboardEvent) { + var rowNode = rowComp.getRowNode(); + var focusedCell = this.focusService.getFocusedCell(); + var column = (focusedCell && focusedCell.column); + var gridProcessingAllowed = !Object(_utils_keyboard__WEBPACK_IMPORTED_MODULE_6__["isUserSuppressingKeyboardEvent"])(this.gridOptionsWrapper, keyboardEvent, rowNode, column, false); + if (gridProcessingAllowed) { + var key = keyboardEvent.key; + if (eventName === 'keydown') { + switch (key) { + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_8__["KeyCode"].UP: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_8__["KeyCode"].DOWN: + rowComp.onKeyboardNavigate(keyboardEvent); + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_8__["KeyCode"].TAB: + rowComp.onTabKeyDown(keyboardEvent); + default: + } + } } - if (!rowComponent) { - return null; + if (eventName === 'keydown') { + var cellKeyDownEvent = rowComp.createRowEvent(_events__WEBPACK_IMPORTED_MODULE_7__["Events"].EVENT_CELL_KEY_DOWN, keyboardEvent); + this.eventService.dispatchEvent(cellKeyDownEvent); } - var cellComponent = rowComponent.getRenderedCellForColumn(cellPosition.column); - return cellComponent; - }; - RowRenderer.prototype.getRowNode = function (gridRow) { - switch (gridRow.rowPinned) { - case _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_TOP: - return this.pinnedRowModel.getPinnedTopRowData()[gridRow.rowIndex]; - case _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_BOTTOM: - return this.pinnedRowModel.getPinnedBottomRowData()[gridRow.rowIndex]; - default: - return this.rowModel.getRow(gridRow.rowIndex); + if (eventName === 'keypress') { + var cellKeyPressEvent = rowComp.createRowEvent(_events__WEBPACK_IMPORTED_MODULE_7__["Events"].EVENT_CELL_KEY_PRESS, keyboardEvent); + this.eventService.dispatchEvent(cellKeyPressEvent); } }; - RowRenderer.prototype.onTabKeyDown = function (previousRenderedCell, keyboardEvent) { - var backwards = keyboardEvent.shiftKey; - var success = this.moveToCellAfter(previousRenderedCell, backwards); - if (success) { - keyboardEvent.preventDefault(); + RowContainerEventsFeature.prototype.doGridOperations = function (keyboardEvent, editing) { + // check if ctrl or meta key pressed + if (!keyboardEvent.ctrlKey && !keyboardEvent.metaKey) { + return; } - else if (keyboardEvent.shiftKey) { - var cellPosition = previousRenderedCell.getCellPosition(); - if (cellPosition.rowIndex === 0) { - keyboardEvent.preventDefault(); - this.focusController.focusHeaderPosition({ - headerRowIndex: this.beans.headerNavigationService.getHeaderRowCount() - 1, - column: _utils__WEBPACK_IMPORTED_MODULE_8__["_"].last(this.columnController.getAllDisplayedColumns()) - }); - } + // if the cell the event came from is editing, then we do not + // want to do the default shortcut keys, otherwise the editor + // (eg a text field) would not be able to do the normal cut/copy/paste + if (editing) { + return; } - }; - RowRenderer.prototype.tabToNextCell = function (backwards) { - var focusedCell = this.focusController.getFocusedCell(); - // if no focus, then cannot navigate - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(focusedCell)) { - return false; + // for copy / paste, we don't want to execute when the event + // was from a child grid (happens in master detail) + if (!this.mouseEventService.isEventFromThisGrid(keyboardEvent)) { + return; } - var renderedCell = this.getComponentForCell(focusedCell); - // if cell is not rendered, means user has scrolled away from the cell - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(renderedCell)) { - return false; + switch (keyboardEvent.key.toUpperCase()) { + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_8__["KeyCode"].A: + return this.onCtrlAndA(keyboardEvent); + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_8__["KeyCode"].C: + return this.onCtrlAndC(keyboardEvent); + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_8__["KeyCode"].V: + return this.onCtrlAndV(); + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_8__["KeyCode"].D: + return this.onCtrlAndD(keyboardEvent); + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_8__["KeyCode"].Z: + return keyboardEvent.shiftKey ? this.undoRedoService.redo() : this.undoRedoService.undo(); + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_8__["KeyCode"].Y: + return this.undoRedoService.redo(); } - var result = this.moveToCellAfter(renderedCell, backwards); - return result; }; - RowRenderer.prototype.moveToCellAfter = function (previousRenderedCell, backwards) { - var editing = previousRenderedCell.isEditing(); - var res; - if (editing) { - if (this.gridOptionsWrapper.isFullRowEdit()) { - res = this.moveToNextEditingRow(previousRenderedCell, backwards); + RowContainerEventsFeature.prototype.onCtrlAndA = function (event) { + var _a = this, pinnedRowModel = _a.pinnedRowModel, paginationProxy = _a.paginationProxy, rangeService = _a.rangeService; + var PINNED_BOTTOM = _constants_constants__WEBPACK_IMPORTED_MODULE_9__["Constants"].PINNED_BOTTOM, PINNED_TOP = _constants_constants__WEBPACK_IMPORTED_MODULE_9__["Constants"].PINNED_TOP; + if (rangeService && paginationProxy.isRowsToRender()) { + var _b = __read([ + pinnedRowModel.isEmpty(PINNED_TOP), + pinnedRowModel.isEmpty(PINNED_BOTTOM) + ], 2), isEmptyPinnedTop = _b[0], isEmptyPinnedBottom = _b[1]; + var floatingStart = isEmptyPinnedTop ? null : PINNED_TOP; + var floatingEnd = void 0; + var rowEnd = void 0; + if (isEmptyPinnedBottom) { + floatingEnd = null; + rowEnd = this.paginationProxy.getRowCount() - 1; } else { - res = this.moveToNextEditingCell(previousRenderedCell, backwards); + floatingEnd = PINNED_BOTTOM; + rowEnd = pinnedRowModel.getPinnedBottomRowData().length - 1; } + var allDisplayedColumns = this.columnModel.getAllDisplayedColumns(); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_10__["missingOrEmpty"])(allDisplayedColumns)) { + return; + } + rangeService.setCellRange({ + rowStartIndex: 0, + rowStartPinned: floatingStart, + rowEndIndex: rowEnd, + rowEndPinned: floatingEnd, + columnStart: allDisplayedColumns[0], + columnEnd: Object(_utils_array__WEBPACK_IMPORTED_MODULE_11__["last"])(allDisplayedColumns) + }); } - else { - res = this.moveToNextCellNotEditing(previousRenderedCell, backwards); - } - return res; + event.preventDefault(); }; - RowRenderer.prototype.moveToNextEditingCell = function (previousRenderedCell, backwards) { - var gridCell = previousRenderedCell.getCellPosition(); - // need to do this before getting next cell to edit, in case the next cell - // has editable function (eg colDef.editable=func() ) and it depends on the - // result of this cell, so need to save updates from the first edit, in case - // the value is referenced in the function. - previousRenderedCell.stopEditing(); - // find the next cell to start editing - var nextRenderedCell = this.findNextCellToFocusOn(gridCell, backwards, true); - var foundCell = _utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(nextRenderedCell); - // only prevent default if we found a cell. so if user is on last cell and hits tab, then we default - // to the normal tabbing so user can exit the grid. - if (foundCell) { - nextRenderedCell.startEditingIfEnabled(null, null, true); - nextRenderedCell.focusCell(false); + RowContainerEventsFeature.prototype.onCtrlAndC = function (event) { + if (!this.clipboardService || this.gridOptionsWrapper.isEnableCellTextSelection()) { + return; } - return foundCell; + this.clipboardService.copyToClipboard(); + event.preventDefault(); }; - RowRenderer.prototype.moveToNextEditingRow = function (previousRenderedCell, backwards) { - var gridCell = previousRenderedCell.getCellPosition(); - // find the next cell to start editing - var nextRenderedCell = this.findNextCellToFocusOn(gridCell, backwards, true); - var foundCell = _utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(nextRenderedCell); - // only prevent default if we found a cell. so if user is on last cell and hits tab, then we default - // to the normal tabbing so user can exit the grid. - if (foundCell) { - this.moveEditToNextCellOrRow(previousRenderedCell, nextRenderedCell); + RowContainerEventsFeature.prototype.onCtrlAndV = function () { + if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_12__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_13__["ModuleNames"].ClipboardModule) && !this.gridOptionsWrapper.isSuppressClipboardPaste()) { + this.clipboardService.pasteFromClipboard(); } - return foundCell; }; - RowRenderer.prototype.moveToNextCellNotEditing = function (previousRenderedCell, backwards) { - var gridCell = previousRenderedCell.getCellPosition(); - // find the next cell to start editing - var nextRenderedCell = this.findNextCellToFocusOn(gridCell, backwards, false); - var foundCell = _utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(nextRenderedCell); - // only prevent default if we found a cell. so if user is on last cell and hits tab, then we default - // to the normal tabbing so user can exit the grid. - if (foundCell) { - nextRenderedCell.focusCell(true); + RowContainerEventsFeature.prototype.onCtrlAndD = function (event) { + if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_12__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_13__["ModuleNames"].ClipboardModule) && !this.gridOptionsWrapper.isSuppressClipboardPaste()) { + this.clipboardService.copyRangeDown(); } - return foundCell; + event.preventDefault(); + }; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('mouseEventService') + ], RowContainerEventsFeature.prototype, "mouseEventService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('valueService') + ], RowContainerEventsFeature.prototype, "valueService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('contextMenuFactory') + ], RowContainerEventsFeature.prototype, "contextMenuFactory", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('ctrlsService') + ], RowContainerEventsFeature.prototype, "ctrlsService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('navigationService') + ], RowContainerEventsFeature.prototype, "navigationService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('focusService') + ], RowContainerEventsFeature.prototype, "focusService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('undoRedoService') + ], RowContainerEventsFeature.prototype, "undoRedoService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnModel') + ], RowContainerEventsFeature.prototype, "columnModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('paginationProxy') + ], RowContainerEventsFeature.prototype, "paginationProxy", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('pinnedRowModel') + ], RowContainerEventsFeature.prototype, "pinnedRowModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('rangeService') + ], RowContainerEventsFeature.prototype, "rangeService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('clipboardService') + ], RowContainerEventsFeature.prototype, "clipboardService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] + ], RowContainerEventsFeature.prototype, "postConstruct", null); + return RowContainerEventsFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); + + + +/***/ }), +/* 127 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ViewportSizeFeature", function() { return ViewportSizeFeature; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(23); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(42); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + +// listens to changes in the center viewport size, for column and row virtualisation, +// and adjusts grid as necessary. there are two viewports, one for horizontal and one for +// vertical scrolling. +var ViewportSizeFeature = /** @class */ (function (_super) { + __extends(ViewportSizeFeature, _super); + function ViewportSizeFeature(centerContainer) { + var _this = _super.call(this) || this; + _this.centerContainerCon = centerContainer; + return _this; + } + ViewportSizeFeature.prototype.postConstruct = function () { + var _this = this; + this.ctrlsService.whenReady(function () { + _this.gridBodyCon = _this.ctrlsService.getGridBodyCtrl(); + _this.listenForResize(); + }); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_SCROLLBAR_WIDTH_CHANGED, this.onScrollbarWidthChanged.bind(this)); + }; + ViewportSizeFeature.prototype.listenForResize = function () { + var listener = this.onCenterViewportResized.bind(this); + // centerContainer gets horizontal resizes + this.centerContainerCon.registerViewportResizeListener(listener); + // eBodyViewport gets vertical resizes + this.gridBodyCon.registerBodyViewportResizeListener(listener); + }; + ViewportSizeFeature.prototype.onScrollbarWidthChanged = function () { + this.checkViewportAndScrolls(); }; - RowRenderer.prototype.moveEditToNextCellOrRow = function (previousRenderedCell, nextRenderedCell) { - var pGridCell = previousRenderedCell.getCellPosition(); - var nGridCell = nextRenderedCell.getCellPosition(); - var rowsMatch = pGridCell.rowIndex === nGridCell.rowIndex && pGridCell.rowPinned === nGridCell.rowPinned; - if (rowsMatch) { - // same row, so we don't start / stop editing, we just move the focus along - previousRenderedCell.setFocusOutOnEditor(); - nextRenderedCell.setFocusInOnEditor(); + ViewportSizeFeature.prototype.onCenterViewportResized = function () { + if (this.centerContainerCon.isViewportVisible()) { + this.checkViewportAndScrolls(); + var newWidth = this.centerContainerCon.getCenterWidth(); + if (newWidth !== this.centerWidth) { + this.centerWidth = newWidth; + this.columnModel.refreshFlexedColumns({ viewportWidth: this.centerWidth, updateBodyWidths: true, fireResizedEvent: true }); + } } else { - var pRow = previousRenderedCell.getRenderedRow(); - var nRow = nextRenderedCell.getRenderedRow(); - previousRenderedCell.setFocusOutOnEditor(); - pRow.stopEditing(); - nRow.startRowEditing(); - nextRenderedCell.setFocusInOnEditor(); + this.bodyHeight = 0; } - nextRenderedCell.focusCell(); }; - // called by the cell, when tab is pressed while editing. - // @return: RenderedCell when navigation successful, otherwise null - RowRenderer.prototype.findNextCellToFocusOn = function (gridCell, backwards, startEditing) { - var nextCell = gridCell; - while (true) { - if (!backwards) { - nextCell = this.getLastCellOfColSpan(nextCell); - } - nextCell = this.cellNavigationService.getNextTabbedCell(nextCell, backwards); - // allow user to override what cell to go to next - var userFunc = this.gridOptionsWrapper.getTabToNextCellFunc(); - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(userFunc)) { - var params = { - backwards: backwards, - editing: startEditing, - previousCellPosition: gridCell, - nextCellPosition: nextCell ? nextCell : null - }; - var userCell = userFunc(params); - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(userCell)) { - if (userCell.floating) { - _utils__WEBPACK_IMPORTED_MODULE_8__["_"].doOnce(function () { console.warn("ag-Grid: tabToNextCellFunc return type should have attributes: rowIndex, rowPinned, column. However you had 'floating', maybe you meant 'rowPinned'?"); }, 'no floating in userCell'); - userCell.rowPinned = userCell.floating; - } - nextCell = { - rowIndex: userCell.rowIndex, - column: userCell.column, - rowPinned: userCell.rowPinned - }; - } - else { - nextCell = null; - } - } - // if no 'next cell', means we have got to last cell of grid, so nothing to move to, - // so bottom right cell going forwards, or top left going backwards - if (!nextCell) { - return null; - } - // if editing, but cell not editable, skip cell. we do this before we do all of - // the 'ensure index visible' and 'flush all frames', otherwise if we are skipping - // a bunch of cells (eg 10 rows) then all the work on ensuring cell visible is useless - // (except for the last one) which causes grid to stall for a while. - if (startEditing) { - var rowNode = this.lookupRowNodeForCell(nextCell); - var cellIsEditable = nextCell.column.isCellEditable(rowNode); - if (!cellIsEditable) { - continue; - } - } - // this scrolls the row into view - var cellIsNotFloating = _utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(nextCell.rowPinned); - if (cellIsNotFloating) { - this.gridPanel.ensureIndexVisible(nextCell.rowIndex); - } - // pinned columns don't scroll, so no need to ensure index visible - if (!nextCell.column.isPinned()) { - this.gridPanel.ensureColumnVisible(nextCell.column); - } - // need to nudge the scrolls for the floating items. otherwise when we set focus on a non-visible - // floating cell, the scrolls get out of sync - this.gridPanel.horizontallyScrollHeaderCenterAndFloatingCenter(); - // get the grid panel to flush all animation frames - otherwise the call below to get the cellComp - // could fail, if we just scrolled the grid (to make a cell visible) and the rendering hasn't finished. - this.animationFrameService.flushAllFrames(); - // we have to call this after ensureColumnVisible - otherwise it could be a virtual column - // or row that is not currently in view, hence the renderedCell would not exist - var nextCellComp = this.getComponentForCell(nextCell); - // if next cell is fullWidth row, then no rendered cell, - // as fullWidth rows have no cells, so we skip it - if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(nextCellComp)) { - continue; - } - if (nextCellComp.isSuppressNavigable()) { - continue; - } - // by default, when we click a cell, it gets selected into a range, so to keep keyboard navigation - // consistent, we set into range here also. - if (this.rangeController) { - this.rangeController.setRangeToCell(nextCell); - } - // we successfully tabbed onto a grid cell, so return true - return nextCellComp; + // gets called every time the viewport size changes. we use this to check visibility of scrollbars + // in the grid panel, and also to check size and position of viewport for row and column virtualisation. + ViewportSizeFeature.prototype.checkViewportAndScrolls = function () { + // results in updating anything that depends on scroll showing + this.updateScrollVisibleService(); + // fires event if height changes, used by PaginationService, HeightScalerService, RowRenderer + this.checkBodyHeight(); + // check for virtual columns for ColumnController + this.onHorizontalViewportChanged(); + this.gridBodyCon.getScrollFeature().checkScrollLeft(); + }; + ViewportSizeFeature.prototype.getBodyHeight = function () { + return this.bodyHeight; + }; + ViewportSizeFeature.prototype.checkBodyHeight = function () { + var eBodyViewport = this.gridBodyCon.getBodyViewportElement(); + var bodyHeight = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["getInnerHeight"])(eBodyViewport); + if (this.bodyHeight !== bodyHeight) { + this.bodyHeight = bodyHeight; + var event_1 = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_BODY_HEIGHT_CHANGED, + api: this.gridApi, + columnApi: this.columnApi + }; + this.eventService.dispatchEvent(event_1); } }; - RowRenderer.prototype.lookupRowNodeForCell = function (cell) { - if (cell.rowPinned === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_TOP) { - return this.pinnedRowModel.getPinnedTopRow(cell.rowIndex); + ViewportSizeFeature.prototype.updateScrollVisibleService = function () { + // because of column animation (which takes 200ms), we have to do this twice. + // eg if user removes cols anywhere except at the RHS, then the cols on the RHS + // will animate to the left to fill the gap. this animation means just after + // the cols are removed, the remaining cols are still in the original location + // at the start of the animation, so pre animation the H scrollbar is still needed, + // but post animation it is not. + this.updateScrollVisibleServiceImpl(); + setTimeout(this.updateScrollVisibleServiceImpl.bind(this), 500); + }; + ViewportSizeFeature.prototype.updateScrollVisibleServiceImpl = function () { + var params = { + horizontalScrollShowing: this.isHorizontalScrollShowing(), + verticalScrollShowing: this.gridBodyCon.isVerticalScrollShowing() + }; + this.scrollVisibleService.setScrollsVisible(params); + // fix - gridComp should just listen to event from above + this.gridBodyCon.setVerticalScrollPaddingVisible(params.verticalScrollShowing); + }; + ViewportSizeFeature.prototype.isHorizontalScrollShowing = function () { + var isAlwaysShowHorizontalScroll = this.gridOptionsWrapper.isAlwaysShowHorizontalScroll(); + return isAlwaysShowHorizontalScroll || this.centerContainerCon.isViewportHScrollShowing(); + }; + // this gets called whenever a change in the viewport, so we can inform column controller it has to work + // out the virtual columns again. gets called from following locations: + // + ensureColVisible, scroll, init, layoutChanged, displayedColumnsChanged, API (doLayout) + ViewportSizeFeature.prototype.onHorizontalViewportChanged = function () { + var scrollWidth = this.centerContainerCon.getCenterWidth(); + var scrollPosition = this.centerContainerCon.getViewportScrollLeft(); + this.columnModel.setViewportPosition(scrollWidth, scrollPosition); + }; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('ctrlsService') + ], ViewportSizeFeature.prototype, "ctrlsService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnModel') + ], ViewportSizeFeature.prototype, "columnModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('scrollVisibleService') + ], ViewportSizeFeature.prototype, "scrollVisibleService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnApi') + ], ViewportSizeFeature.prototype, "columnApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridApi') + ], ViewportSizeFeature.prototype, "gridApi", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], ViewportSizeFeature.prototype, "postConstruct", null); + return ViewportSizeFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); + + + +/***/ }), +/* 128 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SetPinnedLeftWidthFeature", function() { return SetPinnedLeftWidthFeature; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(24); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(42); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + +var SetPinnedLeftWidthFeature = /** @class */ (function (_super) { + __extends(SetPinnedLeftWidthFeature, _super); + function SetPinnedLeftWidthFeature(element) { + var _this = _super.call(this) || this; + _this.element = element; + return _this; + } + SetPinnedLeftWidthFeature.prototype.postConstruct = function () { + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_LEFT_PINNED_WIDTH_CHANGED, this.onPinnedLeftWidthChanged.bind(this)); + }; + SetPinnedLeftWidthFeature.prototype.onPinnedLeftWidthChanged = function () { + var leftWidth = this.pinnedWidthService.getPinnedLeftWidth(); + var displayed = leftWidth > 0; + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["setDisplayed"])(this.element, displayed); + if (displayed) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["setFixedWidth"])(this.element, leftWidth); } - if (cell.rowPinned === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_BOTTOM) { - return this.pinnedRowModel.getPinnedBottomRow(cell.rowIndex); + }; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('pinnedWidthService') + ], SetPinnedLeftWidthFeature.prototype, "pinnedWidthService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], SetPinnedLeftWidthFeature.prototype, "postConstruct", null); + return SetPinnedLeftWidthFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); + + + +/***/ }), +/* 129 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SetPinnedRightWidthFeature", function() { return SetPinnedRightWidthFeature; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(24); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(42); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(20); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + +var SetPinnedRightWidthFeature = /** @class */ (function (_super) { + __extends(SetPinnedRightWidthFeature, _super); + function SetPinnedRightWidthFeature(element) { + var _this = _super.call(this) || this; + _this.element = element; + return _this; + } + SetPinnedRightWidthFeature.prototype.postConstruct = function () { + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_RIGHT_PINNED_WIDTH_CHANGED, this.onPinnedRightWidthChanged.bind(this)); + }; + SetPinnedRightWidthFeature.prototype.onPinnedRightWidthChanged = function () { + var rightWidth = this.pinnedWidthService.getPinnedRightWidth(); + var displayed = rightWidth > 0; + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["setDisplayed"])(this.element, displayed); + if (displayed) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["setFixedWidth"])(this.element, rightWidth); + } + }; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('pinnedWidthService') + ], SetPinnedRightWidthFeature.prototype, "pinnedWidthService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], SetPinnedRightWidthFeature.prototype, "postConstruct", null); + return SetPinnedRightWidthFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"])); + + + +/***/ }), +/* 130 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SetHeightFeature", function() { return SetHeightFeature; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(24); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + +var SetHeightFeature = /** @class */ (function (_super) { + __extends(SetHeightFeature, _super); + function SetHeightFeature(eContainer, eWrapper) { + var _this = _super.call(this) || this; + _this.eContainer = eContainer; + _this.eWrapper = eWrapper; + return _this; + } + SetHeightFeature.prototype.postConstruct = function () { + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_CONTAINER_HEIGHT_CHANGED, this.onHeightChanged.bind(this)); + }; + SetHeightFeature.prototype.onHeightChanged = function () { + var height = this.maxDivHeightScaler.getUiContainerHeight(); + var heightString = height != null ? height + "px" : ""; + this.eContainer.style.height = heightString; + if (this.eWrapper) { + this.eWrapper.style.height = heightString; } - return this.paginationProxy.getRow(cell.rowIndex); }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("paginationProxy") - ], RowRenderer.prototype, "paginationProxy", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("columnController") - ], RowRenderer.prototype, "columnController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("gridOptionsWrapper") - ], RowRenderer.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("$scope") - ], RowRenderer.prototype, "$scope", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("pinnedRowModel") - ], RowRenderer.prototype, "pinnedRowModel", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("rowModel") - ], RowRenderer.prototype, "rowModel", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("loggerFactory") - ], RowRenderer.prototype, "loggerFactory", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("focusController") - ], RowRenderer.prototype, "focusController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("cellNavigationService") - ], RowRenderer.prototype, "cellNavigationService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("columnApi") - ], RowRenderer.prototype, "columnApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("gridApi") - ], RowRenderer.prototype, "gridApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("beans") - ], RowRenderer.prototype, "beans", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("maxDivHeightScaler") - ], RowRenderer.prototype, "maxDivHeightScaler", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("animationFrameService") - ], RowRenderer.prototype, "animationFrameService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("rowPositionUtils") - ], RowRenderer.prototype, "rowPositionUtils", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Optional"])("rangeController") - ], RowRenderer.prototype, "rangeController", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])("rowContainerHeightService") + ], SetHeightFeature.prototype, "maxDivHeightScaler", void 0); __decorate([ - __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Qualifier"])("loggerFactory")) - ], RowRenderer.prototype, "agWire", null); - RowRenderer = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Bean"])("rowRenderer") - ], RowRenderer); - return RowRenderer; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_7__["BeanStub"])); + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], SetHeightFeature.prototype, "postConstruct", null); + return SetHeightFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 100 */ +/* 131 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowComp", function() { return RowComp; }); -/* harmony import */ var _cellComp__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(101); -/* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(68); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(56); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(25); -/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(38); -/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(39); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DragListenerFeature", function() { return DragListenerFeature; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -21171,1340 +29428,1241 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var __assign = (undefined && undefined.__assign) || function () { - __assign = Object.assign || function(t) { - for (var s, i = 1, n = arguments.length; i < n; i++) { - s = arguments[i]; - for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) - t[p] = s[p]; - } - return t; - }; - return __assign.apply(this, arguments); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; }; - - - - - -var RowComp = /** @class */ (function (_super) { - __extends(RowComp, _super); - function RowComp(parentScope, bodyContainerComp, pinnedLeftContainerComp, pinnedRightContainerComp, fullWidthContainerComp, rowNode, beans, animateIn, useAnimationFrameForCreate, printLayout, embedFullWidth) { +var DragListenerFeature = /** @class */ (function (_super) { + __extends(DragListenerFeature, _super); + function DragListenerFeature(eContainer) { var _this = _super.call(this) || this; - _this.eAllRowContainers = []; - _this.active = true; - _this.rowContainerReadyCount = 0; - _this.refreshNeeded = false; - _this.columnRefreshPending = false; - _this.cellComps = {}; - // for animations, there are bits we want done in the next VM turn, to all DOM to update first. - // instead of each row doing a setTimeout(func,0), we put the functions here and the rowRenderer - // executes them all in one timeout - _this.createSecondPassFuncs = []; - // these get called before the row is destroyed - they set up the DOM for the remove animation (ie they - // set the DOM up for the animation), then the delayedDestroyFunctions get called when the animation is - // complete (ie removes from the dom). - _this.removeFirstPassFuncs = []; - // for animations, these functions get called 400ms after the row is cleared, called by the rowRenderer - // so each row isn't setting up it's own timeout - _this.removeSecondPassFuncs = []; - _this.initialised = false; - _this.elementOrderChanged = false; - _this.lastMouseDownOnDragger = false; - _this.parentScope = parentScope; - _this.beans = beans; - _this.bodyContainerComp = bodyContainerComp; - _this.pinnedLeftContainerComp = pinnedLeftContainerComp; - _this.pinnedRightContainerComp = pinnedRightContainerComp; - _this.fullWidthContainerComp = fullWidthContainerComp; - _this.rowNode = rowNode; - _this.rowIsEven = _this.rowNode.rowIndex % 2 === 0; - _this.paginationPage = _this.beans.paginationProxy.getCurrentPage(); - _this.useAnimationFrameForCreate = useAnimationFrameForCreate; - _this.printLayout = printLayout; - _this.embedFullWidth = embedFullWidth; - _this.setAnimateFlags(animateIn); + _this.eContainer = eContainer; return _this; } - RowComp.prototype.init = function () { + DragListenerFeature.prototype.postConstruct = function () { var _this = this; - this.rowFocused = this.beans.focusController.isRowFocused(this.rowNode.rowIndex, this.rowNode.rowPinned); - this.scope = this.createChildScopeOrNull(this.rowNode.data); - this.setupRowContainers(); - this.addListeners(); - if (this.slideRowIn) { - this.createSecondPassFuncs.push(function () { - _this.onTopChanged(); - }); - } - if (this.fadeRowIn) { - this.createSecondPassFuncs.push(function () { - _this.eAllRowContainers.forEach(function (eRow) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(eRow, 'ag-opacity-zero'); }); - }); - } - }; - RowComp.prototype.createTemplate = function (contents, extraCssClass) { - if (extraCssClass === void 0) { extraCssClass = null; } - var templateParts = []; - var rowHeight = this.rowNode.rowHeight; - var rowClasses = this.getInitialRowClasses(extraCssClass).join(' '); - var rowIdSanitised = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(this.rowNode.id); - var userRowStyles = this.preProcessStylesFromGridOptions(); - var businessKey = this.getRowBusinessKey(); - var businessKeySanitised = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(businessKey); - var rowTopStyle = this.getInitialRowTopStyle(); - var rowIdx = this.rowNode.getRowIndexString(); - var headerRowCount = this.beans.headerNavigationService.getHeaderRowCount(); - templateParts.push(""); - // add in the template for the cells - templateParts.push(contents); - templateParts.push(""); - return templateParts.join(''); - }; - RowComp.prototype.getCellForCol = function (column) { - var cellComp = this.cellComps[column.getColId()]; - return cellComp ? cellComp.getGui() : null; - }; - RowComp.prototype.afterFlush = function () { - if (this.initialised) { - return; - } - this.initialised = true; - this.executeProcessRowPostCreateFunc(); - }; - RowComp.prototype.executeProcessRowPostCreateFunc = function () { - var func = this.beans.gridOptionsWrapper.getProcessRowPostCreateFunc(); - if (!func) { + if (!this.gridOptionsWrapper.isEnableRangeSelection() || // no range selection if no property + Object(_utils_generic__WEBPACK_IMPORTED_MODULE_1__["missing"])(this.rangeService) // no range selection if not enterprise version + ) { return; } var params = { - eRow: this.eBodyRow, - ePinnedLeftRow: this.ePinnedLeftRow, - ePinnedRightRow: this.ePinnedRightRow, - node: this.rowNode, - api: this.beans.gridOptionsWrapper.getApi(), - rowIndex: this.rowNode.rowIndex, - addRenderedRowListener: this.addEventListener.bind(this), - columnApi: this.beans.gridOptionsWrapper.getColumnApi(), - context: this.beans.gridOptionsWrapper.getContext() + dragStartPixels: 0, + eElement: this.eContainer, + onDragStart: this.rangeService.onDragStart.bind(this.rangeService), + onDragStop: this.rangeService.onDragStop.bind(this.rangeService), + onDragging: this.rangeService.onDragging.bind(this.rangeService) }; - func(params); - }; - RowComp.prototype.getInitialRowTopStyle = function () { - // print layout uses normal flow layout for row positioning - if (this.printLayout) { - return ''; - } - // if sliding in, we take the old row top. otherwise we just set the current row top. - var pixels = this.slideRowIn ? this.roundRowTopToBounds(this.rowNode.oldRowTop) : this.rowNode.rowTop; - var afterPaginationPixels = this.applyPaginationOffset(pixels); - var afterScalingPixels = this.beans.maxDivHeightScaler.getRealPixelPosition(afterPaginationPixels); - var isSuppressRowTransform = this.beans.gridOptionsWrapper.isSuppressRowTransform(); - return isSuppressRowTransform ? "top: " + afterScalingPixels + "px; " : "transform: translateY(" + afterScalingPixels + "px);"; - }; - RowComp.prototype.getRowBusinessKey = function () { - var businessKeyForNodeFunc = this.beans.gridOptionsWrapper.getBusinessKeyForNodeFunc(); - if (typeof businessKeyForNodeFunc !== 'function') { - return; - } - return businessKeyForNodeFunc(this.rowNode); - }; - RowComp.prototype.areAllContainersReady = function () { - return this.rowContainerReadyCount === 3; - }; - RowComp.prototype.lazyCreateCells = function (cols, eRow) { - if (!this.active) { - return; - } - var cellTemplatesAndComps = this.createCells(cols); - eRow.innerHTML = cellTemplatesAndComps.template; - this.callAfterRowAttachedOnCells(cellTemplatesAndComps.cellComps, eRow); - this.rowContainerReadyCount++; - if (this.areAllContainersReady() && this.refreshNeeded) { - this.refreshCells(); - } - }; - RowComp.prototype.createRowContainer = function (rowContainerComp, cols, callback) { - var _this = this; - var useAnimationsFrameForCreate = this.useAnimationFrameForCreate; - var cellTemplatesAndComps = useAnimationsFrameForCreate ? { cellComps: [], template: '' } : this.createCells(cols); - var rowTemplate = this.createTemplate(cellTemplatesAndComps.template); - // the RowRenderer is probably inserting many rows. rather than inserting each template one - // at a time, the grid inserts all rows together - so the callback here is called by the - // rowRenderer when all RowComps are created, then all the HTML is inserted in one go, - // and then all the callbacks are called. this is NOT done in an animation frame. - rowContainerComp.appendRowTemplate(rowTemplate, function () { - var eRow = rowContainerComp.getRowElement(_this.getCompId()); - _this.afterRowAttached(rowContainerComp, eRow); - callback(eRow); - if (useAnimationsFrameForCreate) { - _this.beans.taskQueue.createTask(_this.lazyCreateCells.bind(_this, cols, eRow), _this.rowNode.rowIndex, 'createTasksP1'); - } - else { - _this.callAfterRowAttachedOnCells(cellTemplatesAndComps.cellComps, eRow); - _this.rowContainerReadyCount = 3; - } - }); - }; - RowComp.prototype.createChildScopeOrNull = function (data) { - var isAngularCompileRows = this.beans.gridOptionsWrapper.isAngularCompileRows(); - if (!isAngularCompileRows) { - return null; - } - var newChildScope = this.parentScope.$new(); - newChildScope.data = __assign({}, data); - newChildScope.rowNode = this.rowNode; - newChildScope.context = this.beans.gridOptionsWrapper.getContext(); - this.addDestroyFunc(function () { - newChildScope.$destroy(); - newChildScope.data = null; - newChildScope.rowNode = null; - newChildScope.context = null; - }); - return newChildScope; + this.dragService.addDragSource(params); + this.addDestroyFunc(function () { return _this.dragService.removeDragSource(params); }); }; - RowComp.prototype.setupRowContainers = function () { - var isFullWidthCell = this.rowNode.isFullWidthCell(); - var isDetailCell = this.beans.doingMasterDetail && this.rowNode.detail; - var pivotMode = this.beans.columnController.isPivotMode(); - // we only use full width for groups, not footers. it wouldn't make sense to include footers if not looking - // for totals. if users complain about this, then we should introduce a new property 'footerUseEntireRow' - // so each can be set independently (as a customer complained about footers getting full width, hence - // introducing this logic) - var isGroupRow = this.rowNode.group && !this.rowNode.footer; - var isFullWidthGroup = isGroupRow && this.beans.gridOptionsWrapper.isGroupUseEntireRow(pivotMode); - if (this.rowNode.stub) { - this.createFullWidthRows(RowComp.LOADING_CELL_RENDERER, RowComp.LOADING_CELL_RENDERER_COMP_NAME); - } - else if (isDetailCell) { - this.createFullWidthRows(RowComp.DETAIL_CELL_RENDERER, RowComp.DETAIL_CELL_RENDERER_COMP_NAME); - } - else if (isFullWidthCell) { - this.createFullWidthRows(RowComp.FULL_WIDTH_CELL_RENDERER, null); - } - else if (isFullWidthGroup) { - this.createFullWidthRows(RowComp.GROUP_ROW_RENDERER, RowComp.GROUP_ROW_RENDERER_COMP_NAME); - } - else { - this.setupNormalRowContainers(); - } + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('rangeService') + ], DragListenerFeature.prototype, "rangeService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('dragService') + ], DragListenerFeature.prototype, "dragService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] + ], DragListenerFeature.prototype, "postConstruct", null); + return DragListenerFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); + + + +/***/ }), +/* 132 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CenterWidthFeature", function() { return CenterWidthFeature; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(107); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(15); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(24); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - RowComp.prototype.setupNormalRowContainers = function () { - var _this = this; - var centerCols; - var leftCols = []; - var rightCols = []; - if (this.printLayout) { - centerCols = this.beans.columnController.getAllDisplayedColumns(); - } - else { - centerCols = this.beans.columnController.getAllDisplayedCenterVirtualColumnsForRow(this.rowNode); - leftCols = this.beans.columnController.getDisplayedLeftColumnsForRow(this.rowNode); - rightCols = this.beans.columnController.getDisplayedRightColumnsForRow(this.rowNode); - } - this.createRowContainer(this.bodyContainerComp, centerCols, function (eRow) { return _this.eBodyRow = eRow; }); - this.createRowContainer(this.pinnedRightContainerComp, rightCols, function (eRow) { return _this.ePinnedRightRow = eRow; }); - this.createRowContainer(this.pinnedLeftContainerComp, leftCols, function (eRow) { return _this.ePinnedLeftRow = eRow; }); - }; - RowComp.prototype.createFullWidthRows = function (type, name) { - var _this = this; - this.fullWidthRow = true; - if (this.embedFullWidth) { - this.createFullWidthRowContainer(this.bodyContainerComp, null, null, type, name, function (eRow) { - _this.eFullWidthRowBody = eRow; - }, function (cellRenderer) { - _this.fullWidthRowComponentBody = cellRenderer; - }); - // printLayout doesn't put components into the pinned sections - if (this.printLayout) { - return; - } - this.createFullWidthRowContainer(this.pinnedLeftContainerComp, _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_LEFT, 'ag-cell-last-left-pinned', type, name, function (eRow) { - _this.eFullWidthRowLeft = eRow; - }, function (cellRenderer) { - _this.fullWidthRowComponentLeft = cellRenderer; - }); - this.createFullWidthRowContainer(this.pinnedRightContainerComp, _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_RIGHT, 'ag-cell-first-right-pinned', type, name, function (eRow) { - _this.eFullWidthRowRight = eRow; - }, function (cellRenderer) { - _this.fullWidthRowComponentRight = cellRenderer; - }); - } - else { - // otherwise we add to the fullWidth container as normal - // let previousFullWidth = ensureDomOrder ? this.lastPlacedElements.eFullWidth : null; - this.createFullWidthRowContainer(this.fullWidthContainerComp, null, null, type, name, function (eRow) { - _this.eFullWidthRow = eRow; - }, function (cellRenderer) { - _this.fullWidthRowComponent = cellRenderer; - }); - } + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - RowComp.prototype.setAnimateFlags = function (animateIn) { - if (animateIn) { - var oldRowTopExists = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(this.rowNode.oldRowTop); - // if the row had a previous position, we slide it in (animate row top) - this.slideRowIn = oldRowTopExists; - // if the row had no previous position, we fade it in (animate - this.fadeRowIn = !oldRowTopExists; - } - else { - this.slideRowIn = false; - this.fadeRowIn = false; - } +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + +var CenterWidthFeature = /** @class */ (function (_super) { + __extends(CenterWidthFeature, _super); + function CenterWidthFeature(callback) { + var _this = _super.call(this) || this; + _this.callback = callback; + return _this; + } + CenterWidthFeature.prototype.postConstruct = function () { + var listener = this.setWidth.bind(this); + this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__["GridOptionsWrapper"].PROP_DOM_LAYOUT, listener); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, listener); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, listener); + this.setWidth(); }; - RowComp.prototype.isEditing = function () { - return this.editingRow; + CenterWidthFeature.prototype.setWidth = function () { + var columnModel = this.columnModel; + var printLayout = this.gridOptionsWrapper.getDomLayout() === _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].DOM_LAYOUT_PRINT; + var centerWidth = columnModel.getBodyContainerWidth(); + var leftWidth = columnModel.getDisplayedColumnsLeftWidth(); + var rightWidth = columnModel.getDisplayedColumnsRightWidth(); + var totalWidth = printLayout ? centerWidth + leftWidth + rightWidth : centerWidth; + this.callback(totalWidth); }; - RowComp.prototype.stopRowEditing = function (cancel) { - this.stopEditing(cancel); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnModel') + ], CenterWidthFeature.prototype, "columnModel", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], CenterWidthFeature.prototype, "postConstruct", null); + return CenterWidthFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); + + + +/***/ }), +/* 133 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridHeaderComp", function() { return GridHeaderComp; }); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(15); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(36); +/* harmony import */ var _gridHeaderCtrl__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(134); +/* harmony import */ var _rowContainer_headerRowContainerComp__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(141); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - RowComp.prototype.isFullWidth = function () { - return this.fullWidthRow; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - RowComp.prototype.refreshFullWidth = function () { +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + +var GridHeaderComp = /** @class */ (function (_super) { + __extends(GridHeaderComp, _super); + function GridHeaderComp() { + return _super.call(this, GridHeaderComp.TEMPLATE) || this; + } + GridHeaderComp.prototype.postConstruct = function () { var _this = this; - // returns 'true' if refresh succeeded - var tryRefresh = function (eRow, eCellComp, pinned) { - if (!eRow || !eCellComp) { - return true; - } // no refresh needed - // no refresh method present, so can't refresh, hard refresh needed - if (!eCellComp.refresh) { - return false; + var compProxy = { + addOrRemoveCssClass: function (cssClassName, on) { return _this.addOrRemoveCssClass(cssClassName, on); }, + setHeightAndMinHeight: function (height) { + _this.getGui().style.height = height; + _this.getGui().style.minHeight = height; } - var params = _this.createFullWidthParams(eRow, pinned); - var refreshSucceeded = eCellComp.refresh(params); - return refreshSucceeded; }; - var normalSuccess = tryRefresh(this.eFullWidthRow, this.fullWidthRowComponent, null); - var bodySuccess = tryRefresh(this.eFullWidthRowBody, this.fullWidthRowComponentBody, null); - var leftSuccess = tryRefresh(this.eFullWidthRowLeft, this.fullWidthRowComponentLeft, _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_LEFT); - var rightSuccess = tryRefresh(this.eFullWidthRowRight, this.fullWidthRowComponentRight, _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_RIGHT); - var allFullWidthRowsRefreshed = normalSuccess && bodySuccess && leftSuccess && rightSuccess; - return allFullWidthRowsRefreshed; - }; - RowComp.prototype.addListeners = function () { - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_HEIGHT_CHANGED, this.onRowHeightChanged.bind(this)); - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_ROW_SELECTED, this.onRowSelected.bind(this)); - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_ROW_INDEX_CHANGED, this.onRowIndexChanged.bind(this)); - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_TOP_CHANGED, this.onTopChanged.bind(this)); - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_EXPANDED_CHANGED, this.onExpandedChanged.bind(this)); - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_DATA_CHANGED, this.onRowNodeDataChanged.bind(this)); - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_CELL_CHANGED, this.onRowNodeCellChanged.bind(this)); - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_HIGHLIGHT_CHANGED, this.onRowNodeHighlightChanged.bind(this)); - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_DRAGGING_CHANGED, this.onRowNodeDraggingChanged.bind(this)); - var eventService = this.beans.eventService; - this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_HEIGHT_SCALE_CHANGED, this.onTopChanged.bind(this)); - this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this)); - this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_VIRTUAL_COLUMNS_CHANGED, this.onVirtualColumnsChanged.bind(this)); - this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_RESIZED, this.onColumnResized.bind(this)); - this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_CELL_FOCUSED, this.onCellFocusChanged.bind(this)); - this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_PAGINATION_CHANGED, this.onPaginationChanged.bind(this)); - this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_MODEL_UPDATED, this.onModelUpdated.bind(this)); - this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_MOVED, this.onColumnMoved.bind(this)); - this.addListenersForCellComps(); - }; - RowComp.prototype.addListenersForCellComps = function () { - var _this = this; - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_ROW_INDEX_CHANGED, function () { - _this.forEachCellComp(function (cellComp) { return cellComp.onRowIndexChanged(); }); - }); - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_CELL_CHANGED, function (event) { - _this.forEachCellComp(function (cellComp) { return cellComp.onCellChanged(event); }); - }); - }; - RowComp.prototype.onRowNodeDataChanged = function (event) { - // if this is an update, we want to refresh, as this will allow the user to put in a transition - // into the cellRenderer refresh method. otherwise this might be completely new data, in which case - // we will want to completely replace the cells - this.forEachCellComp(function (cellComp) { - return cellComp.refreshCell({ - suppressFlash: !event.update, - newData: !event.update - }); - }); - // check for selected also, as this could be after lazy loading of the row data, in which case - // the id might of just gotten set inside the row and the row selected state may of changed - // as a result. this is what happens when selected rows are loaded in virtual pagination. - // - niall note - since moving to the stub component, this may no longer be true, as replacing - // the stub component now replaces the entire row - this.onRowSelected(); - // as data has changed, then the style and class needs to be recomputed - this.postProcessCss(); - }; - RowComp.prototype.onRowNodeCellChanged = function () { - // as data has changed, then the style and class needs to be recomputed - this.postProcessCss(); - }; - RowComp.prototype.postProcessCss = function () { - this.postProcessStylesFromGridOptions(); - this.postProcessClassesFromGridOptions(); - this.postProcessRowClassRules(); - this.postProcessRowDragging(); - }; - RowComp.prototype.onRowNodeHighlightChanged = function () { - var highlighted = this.rowNode.highlighted; - this.eAllRowContainers.forEach(function (row) { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(row, 'ag-row-highlight-above'); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(row, 'ag-row-highlight-below'); - if (highlighted) { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(row, 'ag-row-highlight-' + highlighted); - } - }); - }; - RowComp.prototype.onRowNodeDraggingChanged = function () { - this.postProcessRowDragging(); - }; - RowComp.prototype.postProcessRowDragging = function () { - var dragging = this.rowNode.dragging; - this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-dragging', dragging); }); - }; - RowComp.prototype.onExpandedChanged = function () { - var rowNode = this.rowNode; - this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-group-expanded', rowNode.expanded); }); - this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-group-contracted', !rowNode.expanded); }); - }; - RowComp.prototype.onDisplayedColumnsChanged = function () { - if (this.fullWidthRow) { - return; - } - this.refreshCells(); - }; - RowComp.prototype.destroyFullWidthComponents = function () { - if (this.fullWidthRowComponent) { - this.beans.detailRowCompCache.addOrDestroy(this.rowNode, null, this.fullWidthRowComponent); - this.fullWidthRowComponent = null; - } - if (this.fullWidthRowComponentBody) { - this.beans.detailRowCompCache.addOrDestroy(this.rowNode, null, this.fullWidthRowComponentBody); - this.fullWidthRowComponent = null; - } - if (this.fullWidthRowComponentLeft) { - this.beans.detailRowCompCache.addOrDestroy(this.rowNode, _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_LEFT, this.fullWidthRowComponentLeft); - this.fullWidthRowComponentLeft = null; - } - if (this.fullWidthRowComponentRight) { - this.beans.detailRowCompCache.addOrDestroy(this.rowNode, _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_RIGHT, this.fullWidthRowComponentRight); - this.fullWidthRowComponent = null; - } + var ctrl = this.createManagedBean(new _gridHeaderCtrl__WEBPACK_IMPORTED_MODULE_3__["GridHeaderCtrl"]()); + ctrl.setComp(compProxy, this.getGui(), this.getFocusableElement()); + var addContainer = function (container) { + _this.createManagedBean(container); + _this.appendChild(container); + }; + addContainer(new _rowContainer_headerRowContainerComp__WEBPACK_IMPORTED_MODULE_4__["HeaderRowContainerComp"](_constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_LEFT)); + addContainer(new _rowContainer_headerRowContainerComp__WEBPACK_IMPORTED_MODULE_4__["HeaderRowContainerComp"](null)); + addContainer(new _rowContainer_headerRowContainerComp__WEBPACK_IMPORTED_MODULE_4__["HeaderRowContainerComp"](_constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_RIGHT)); }; - RowComp.prototype.getContainerForCell = function (pinnedType) { - switch (pinnedType) { - case _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_LEFT: return this.ePinnedLeftRow; - case _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_RIGHT: return this.ePinnedRightRow; - default: return this.eBodyRow; - } + GridHeaderComp.TEMPLATE = "
"; + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], GridHeaderComp.prototype, "postConstruct", null); + return GridHeaderComp; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_2__["Component"])); + + + +/***/ }), +/* 134 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridHeaderCtrl", function() { return GridHeaderCtrl; }); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(65); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(24); +/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(107); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7); +/* harmony import */ var _widgets_managedFocusFeature__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(64); +/* harmony import */ var _common_headerNavigationService__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(135); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - RowComp.prototype.onVirtualColumnsChanged = function () { - if (this.fullWidthRow) { - return; - } - this.refreshCells(); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - RowComp.prototype.onColumnResized = function () { - if (this.fullWidthRow) { - return; - } - this.refreshCells(); +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + + +var GridHeaderCtrl = /** @class */ (function (_super) { + __extends(GridHeaderCtrl, _super); + function GridHeaderCtrl() { + return _super !== null && _super.apply(this, arguments) || this; + } + GridHeaderCtrl.prototype.setComp = function (comp, eGui, eFocusableElement) { + this.comp = comp; + this.eGui = eGui; + this.createManagedBean(new _widgets_managedFocusFeature__WEBPACK_IMPORTED_MODULE_6__["ManagedFocusFeature"](eFocusableElement, { + onTabKeyDown: this.onTabKeyDown.bind(this), + handleKeyDown: this.handleKeyDown.bind(this), + onFocusOut: this.onFocusOut.bind(this) + })); + // for setting ag-pivot-on / ag-pivot-off CSS classes + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_PIVOT_MODE_CHANGED, this.onPivotModeChanged.bind(this)); + this.onPivotModeChanged(); + this.setupHeaderHeight(); + this.ctrlsService.registerGridHeaderCtrl(this); }; - RowComp.prototype.refreshCells = function () { - if (!this.areAllContainersReady()) { - this.refreshNeeded = true; - return; - } - var suppressAnimationFrame = this.beans.gridOptionsWrapper.isSuppressAnimationFrame(); - var skipAnimationFrame = suppressAnimationFrame || this.printLayout; - if (skipAnimationFrame) { - this.refreshCellsInAnimationFrame(); + GridHeaderCtrl.prototype.setupHeaderHeight = function () { + var listener = this.setHeaderHeight.bind(this); + listener(); + this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_4__["GridOptionsWrapper"].PROP_HEADER_HEIGHT, listener); + this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_4__["GridOptionsWrapper"].PROP_PIVOT_HEADER_HEIGHT, listener); + this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_4__["GridOptionsWrapper"].PROP_GROUP_HEADER_HEIGHT, listener); + this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_4__["GridOptionsWrapper"].PROP_PIVOT_GROUP_HEADER_HEIGHT, listener); + this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_4__["GridOptionsWrapper"].PROP_FLOATING_FILTERS_HEIGHT, listener); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, listener); + }; + GridHeaderCtrl.prototype.setHeaderHeight = function () { + var _a = this, columnModel = _a.columnModel, gridOptionsWrapper = _a.gridOptionsWrapper; + var numberOfFloating = 0; + var headerRowCount = columnModel.getHeaderRowCount(); + var totalHeaderHeight; + var groupHeight; + var headerHeight; + if (columnModel.isPivotMode()) { + groupHeight = gridOptionsWrapper.getPivotGroupHeaderHeight(); + headerHeight = gridOptionsWrapper.getPivotHeaderHeight(); } else { - if (this.columnRefreshPending) { - return; + var hasFloatingFilters = columnModel.hasFloatingFilters(); + if (hasFloatingFilters) { + headerRowCount++; + numberOfFloating = 1; } - this.beans.taskQueue.createTask(this.refreshCellsInAnimationFrame.bind(this), this.rowNode.rowIndex, 'createTasksP1'); + groupHeight = gridOptionsWrapper.getGroupHeaderHeight(); + headerHeight = gridOptionsWrapper.getHeaderHeight(); } + var numberOfNonGroups = 1 + numberOfFloating; + var numberOfGroups = headerRowCount - numberOfNonGroups; + totalHeaderHeight = numberOfFloating * gridOptionsWrapper.getFloatingFiltersHeight(); + totalHeaderHeight += numberOfGroups * groupHeight; + totalHeaderHeight += headerHeight; + // one extra pixel is needed here to account for the + // height of the border + var px = totalHeaderHeight + 1 + "px"; + this.comp.setHeightAndMinHeight(px); }; - RowComp.prototype.refreshCellsInAnimationFrame = function () { - if (!this.active) { - return; - } - this.columnRefreshPending = false; - var centerCols; - var leftCols; - var rightCols; - if (this.printLayout) { - centerCols = this.beans.columnController.getAllDisplayedColumns(); - leftCols = []; - rightCols = []; - } - else { - centerCols = this.beans.columnController.getAllDisplayedCenterVirtualColumnsForRow(this.rowNode); - leftCols = this.beans.columnController.getDisplayedLeftColumnsForRow(this.rowNode); - rightCols = this.beans.columnController.getDisplayedRightColumnsForRow(this.rowNode); - } - this.insertCellsIntoContainer(this.eBodyRow, centerCols); - this.insertCellsIntoContainer(this.ePinnedLeftRow, leftCols); - this.insertCellsIntoContainer(this.ePinnedRightRow, rightCols); - this.elementOrderChanged = false; - var colIdsToRemove = Object.keys(this.cellComps); - centerCols.forEach(function (col) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeFromArray(colIdsToRemove, col.getId()); }); - leftCols.forEach(function (col) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeFromArray(colIdsToRemove, col.getId()); }); - rightCols.forEach(function (col) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeFromArray(colIdsToRemove, col.getId()); }); - // we never remove editing cells, as this would cause the cells to loose their values while editing - // as the grid is scrolling horizontally. - var eligibleToBeRemoved = colIdsToRemove.filter(this.isCellEligibleToBeRemoved.bind(this)); - // remove old cells from gui, but we don't destroy them, we might use them again - this.removeRenderedCells(eligibleToBeRemoved); - }; - RowComp.prototype.onColumnMoved = function () { - this.elementOrderChanged = true; - }; - RowComp.prototype.removeRenderedCells = function (colIds) { - var _this = this; - colIds.forEach(function (key) { - var cellComp = _this.cellComps[key]; - // could be old reference, ie removed cell - if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(cellComp)) { - return; - } - cellComp.detach(); - cellComp.destroy(); - _this.cellComps[key] = null; - }); + GridHeaderCtrl.prototype.onPivotModeChanged = function () { + var pivotMode = this.columnModel.isPivotMode(); + this.comp.addOrRemoveCssClass('ag-pivot-on', pivotMode); + this.comp.addOrRemoveCssClass('ag-pivot-off', !pivotMode); }; - RowComp.prototype.isCellEligibleToBeRemoved = function (indexStr) { - var displayedColumns = this.beans.columnController.getAllDisplayedColumns(); - var REMOVE_CELL = true; - var KEEP_CELL = false; - var renderedCell = this.cellComps[indexStr]; - // always remove the cell if it's not rendered or if it's in the wrong pinned location - if (!renderedCell || this.isCellInWrongRow(renderedCell)) { - return REMOVE_CELL; - } - // we want to try and keep editing and focused cells - var editing = renderedCell.isEditing(); - var focused = this.beans.focusController.isCellFocused(renderedCell.getCellPosition()); - var mightWantToKeepCell = editing || focused; - if (mightWantToKeepCell) { - var column = renderedCell.getColumn(); - var cellStillDisplayed = displayedColumns.indexOf(column) >= 0; - return cellStillDisplayed ? KEEP_CELL : REMOVE_CELL; + GridHeaderCtrl.prototype.onTabKeyDown = function (e) { + var isRtl = this.gridOptionsWrapper.isEnableRtl(); + var direction = e.shiftKey !== isRtl + ? _common_headerNavigationService__WEBPACK_IMPORTED_MODULE_7__["HeaderNavigationDirection"].LEFT + : _common_headerNavigationService__WEBPACK_IMPORTED_MODULE_7__["HeaderNavigationDirection"].RIGHT; + if (this.headerNavigationService.navigateHorizontally(direction, true, e) || + this.focusService.focusNextGridCoreContainer(e.shiftKey)) { + e.preventDefault(); } - return REMOVE_CELL; }; - RowComp.prototype.ensureCellInCorrectContainer = function (cellComp) { - // for print layout, we always put cells into centre, otherwise we put in correct pinned section - if (this.printLayout) { - return; - } - var element = cellComp.getGui(); - var column = cellComp.getColumn(); - var pinnedType = column.getPinned(); - var eContainer = this.getContainerForCell(pinnedType); - // if in wrong container, remove it - var eOldContainer = cellComp.getParentRow(); - var inWrongRow = eOldContainer !== eContainer; - if (inWrongRow) { - // take out from old row - if (eOldContainer) { - eOldContainer.removeChild(element); - } - eContainer.appendChild(element); - cellComp.setParentRow(eContainer); - this.elementOrderChanged = true; + GridHeaderCtrl.prototype.handleKeyDown = function (e) { + var direction = null; + switch (e.key) { + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_0__["KeyCode"].LEFT: + direction = _common_headerNavigationService__WEBPACK_IMPORTED_MODULE_7__["HeaderNavigationDirection"].LEFT; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_0__["KeyCode"].RIGHT: + if (!Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["exists"])(direction)) { + direction = _common_headerNavigationService__WEBPACK_IMPORTED_MODULE_7__["HeaderNavigationDirection"].RIGHT; + } + this.headerNavigationService.navigateHorizontally(direction, false, e); + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_0__["KeyCode"].UP: + direction = _common_headerNavigationService__WEBPACK_IMPORTED_MODULE_7__["HeaderNavigationDirection"].UP; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_0__["KeyCode"].DOWN: + if (!Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["exists"])(direction)) { + direction = _common_headerNavigationService__WEBPACK_IMPORTED_MODULE_7__["HeaderNavigationDirection"].DOWN; + } + if (this.headerNavigationService.navigateVertically(direction, null, e)) { + e.preventDefault(); + } + break; + default: + return; } }; - RowComp.prototype.isCellInWrongRow = function (cellComp) { - var column = cellComp.getColumn(); - var rowWeWant = this.getContainerForCell(column.getPinned()); - var oldRow = cellComp.getParentRow(); // if in wrong container, remove it - return oldRow !== rowWeWant; - }; - RowComp.prototype.insertCellsIntoContainer = function (eRow, cols) { - var _this = this; - if (!eRow) { + GridHeaderCtrl.prototype.onFocusOut = function (e) { + var eDocument = this.gridOptionsWrapper.getDocument(); + var relatedTarget = e.relatedTarget; + if (!relatedTarget && this.eGui.contains(eDocument.activeElement)) { return; } - var cellTemplates = []; - var newCellComps = []; - cols.forEach(function (col) { - var colId = col.getId(); - var existingCell = _this.cellComps[colId]; - if (existingCell) { - _this.ensureCellInCorrectContainer(existingCell); - } - else { - _this.createNewCell(col, eRow, cellTemplates, newCellComps); - } - }); - if (cellTemplates.length > 0) { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].appendHtml(eRow, cellTemplates.join('')); - this.callAfterRowAttachedOnCells(newCellComps, eRow); - } - if (this.elementOrderChanged && this.beans.gridOptionsWrapper.isEnsureDomOrder()) { - var correctChildOrder = cols.map(function (col) { return _this.getCellForCol(col); }); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].setDomChildOrder(eRow, correctChildOrder); + if (!this.eGui.contains(relatedTarget)) { + this.focusService.clearFocusedHeader(); } }; - RowComp.prototype.addDomData = function (eRowContainer) { - var gow = this.beans.gridOptionsWrapper; - gow.setDomData(eRowContainer, RowComp.DOM_DATA_KEY_RENDERED_ROW, this); - this.addDestroyFunc(function () { - gow.setDomData(eRowContainer, RowComp.DOM_DATA_KEY_RENDERED_ROW, null); - }); - }; - RowComp.prototype.createNewCell = function (col, eContainer, cellTemplates, newCellComps) { - var newCellComp = new _cellComp__WEBPACK_IMPORTED_MODULE_0__["CellComp"](this.scope, this.beans, col, this.rowNode, this, false, this.printLayout); - var cellTemplate = newCellComp.getCreateTemplate(); - cellTemplates.push(cellTemplate); - newCellComps.push(newCellComp); - this.cellComps[col.getId()] = newCellComp; - newCellComp.setParentRow(eContainer); - this.elementOrderChanged = true; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('headerNavigationService') + ], GridHeaderCtrl.prototype, "headerNavigationService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('focusService') + ], GridHeaderCtrl.prototype, "focusService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnModel') + ], GridHeaderCtrl.prototype, "columnModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('ctrlsService') + ], GridHeaderCtrl.prototype, "ctrlsService", void 0); + return GridHeaderCtrl; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + + + +/***/ }), +/* 135 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderNavigationDirection", function() { return HeaderNavigationDirection; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderNavigationService", function() { return HeaderNavigationService; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(9); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(18); +/* harmony import */ var _row_headerRowComp__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(136); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - RowComp.prototype.onMouseEvent = function (eventName, mouseEvent) { - switch (eventName) { - case 'dblclick': - this.onRowDblClick(mouseEvent); - break; - case 'click': - this.onRowClick(mouseEvent); - break; - case 'mousedown': - this.onRowMouseDown(mouseEvent); - break; - } + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - RowComp.prototype.createRowEvent = function (type, domEvent) { - return { - type: type, - node: this.rowNode, - data: this.rowNode.data, - rowIndex: this.rowNode.rowIndex, - rowPinned: this.rowNode.rowPinned, - context: this.beans.gridOptionsWrapper.getContext(), - api: this.beans.gridOptionsWrapper.getApi(), - columnApi: this.beans.gridOptionsWrapper.getColumnApi(), - event: domEvent - }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + +var HeaderNavigationDirection; +(function (HeaderNavigationDirection) { + HeaderNavigationDirection[HeaderNavigationDirection["UP"] = 0] = "UP"; + HeaderNavigationDirection[HeaderNavigationDirection["DOWN"] = 1] = "DOWN"; + HeaderNavigationDirection[HeaderNavigationDirection["LEFT"] = 2] = "LEFT"; + HeaderNavigationDirection[HeaderNavigationDirection["RIGHT"] = 3] = "RIGHT"; +})(HeaderNavigationDirection || (HeaderNavigationDirection = {})); +var HeaderNavigationService = /** @class */ (function (_super) { + __extends(HeaderNavigationService, _super); + function HeaderNavigationService() { + return _super !== null && _super.apply(this, arguments) || this; + } + HeaderNavigationService.prototype.postConstruct = function () { + var _this = this; + this.ctrlsService.whenReady(function (p) { + _this.gridBodyCon = p.gridBodyCtrl; + }); }; - RowComp.prototype.createRowEventWithSource = function (type, domEvent) { - var event = this.createRowEvent(type, domEvent); - // when first developing this, we included the rowComp in the event. - // this seems very weird. so when introducing the event types, i left the 'source' - // out of the type, and just include the source in the two places where this event - // was fired (rowClicked and rowDoubleClicked). it doesn't make sense for any - // users to be using this, as the rowComp isn't an object we expose, so would be - // very surprising if a user was using it. - event.source = this; - return event; + HeaderNavigationService.prototype.getHeaderRowCount = function () { + var centerHeaderContainer = this.ctrlsService.getHeaderRowContainerCtrl(); + return centerHeaderContainer ? centerHeaderContainer.getRowCount() : 0; }; - RowComp.prototype.onRowDblClick = function (mouseEvent) { - if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].isStopPropagationForAgGrid(mouseEvent)) { - return; + HeaderNavigationService.prototype.getHeaderRowType = function (rowIndex) { + var centerHeaderContainer = this.ctrlsService.getHeaderRowContainerCtrl(); + if (centerHeaderContainer) { + return centerHeaderContainer.getRowType(rowIndex); } - var agEvent = this.createRowEventWithSource(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DOUBLE_CLICKED, mouseEvent); - this.beans.eventService.dispatchEvent(agEvent); - }; - RowComp.prototype.onRowMouseDown = function (mouseEvent) { - this.lastMouseDownOnDragger = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isElementChildOfClass(mouseEvent.target, 'ag-row-drag', 3); }; - RowComp.prototype.onRowClick = function (mouseEvent) { - var stop = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isStopPropagationForAgGrid(mouseEvent) || this.lastMouseDownOnDragger; - if (stop) { - return; + /* + * This method navigates grid header vertically + * @return {boolean} true to preventDefault on the event that caused this navigation. + */ + HeaderNavigationService.prototype.navigateVertically = function (direction, fromHeader, event) { + if (!fromHeader) { + fromHeader = this.focusService.getFocusedHeader(); } - var agEvent = this.createRowEventWithSource(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_CLICKED, mouseEvent); - this.beans.eventService.dispatchEvent(agEvent); - // ctrlKey for windows, metaKey for Apple - var multiSelectKeyPressed = mouseEvent.ctrlKey || mouseEvent.metaKey; - var shiftKeyPressed = mouseEvent.shiftKey; - if ( - // we do not allow selecting groups by clicking (as the click here expands the group), or if it's a detail row, - // so return if it's a group row - this.rowNode.group || - // this is needed so we don't unselect other rows when we click this row, eg if this row is not selectable, - // and we click it, the selection should not change (ie any currently selected row should stay selected) - !this.rowNode.selectable || - // we also don't allow selection of pinned rows - this.rowNode.rowPinned || - // if no selection method enabled, do nothing - !this.beans.gridOptionsWrapper.isRowSelection() || - // if click selection suppressed, do nothing - this.beans.gridOptionsWrapper.isSuppressRowClickSelection()) { - return; + if (!fromHeader) { + return false; } - var multiSelectOnClick = this.beans.gridOptionsWrapper.isRowMultiSelectWithClick(); - var rowDeselectionWithCtrl = this.beans.gridOptionsWrapper.isRowDeselection(); - if (this.rowNode.isSelected()) { - if (multiSelectOnClick) { - this.rowNode.setSelectedParams({ newValue: false }); - } - else if (multiSelectKeyPressed) { - if (rowDeselectionWithCtrl) { - this.rowNode.setSelectedParams({ newValue: false }); - } - } - else { - // selected with no multi key, must make sure anything else is unselected - this.rowNode.setSelectedParams({ newValue: true, clearSelection: true }); - } + var headerRowIndex = fromHeader.headerRowIndex, column = fromHeader.column; + var rowLen = this.getHeaderRowCount(); + var isUp = direction === HeaderNavigationDirection.UP; + var nextRow = isUp ? headerRowIndex - 1 : headerRowIndex + 1; + var nextFocusColumn = null; + var skipColumn = false; + if (nextRow < 0) { + nextRow = 0; + nextFocusColumn = column; + skipColumn = true; } - else { - var clearSelection = multiSelectOnClick ? false : !multiSelectKeyPressed; - this.rowNode.setSelectedParams({ newValue: true, clearSelection: clearSelection, rangeSelect: shiftKeyPressed }); + if (nextRow >= rowLen) { + nextRow = -1; // -1 indicates the focus should move to grid rows. } - }; - RowComp.prototype.createFullWidthRowContainer = function (rowContainerComp, pinned, extraCssClass, cellRendererType, cellRendererName, eRowCallback, cellRendererCallback) { - var _this = this; - var rowTemplate = this.createTemplate('', extraCssClass); - rowContainerComp.appendRowTemplate(rowTemplate, function () { - var eRow = rowContainerComp.getRowElement(_this.getCompId()); - var params = _this.createFullWidthParams(eRow, pinned); - var callback = function (cellRenderer) { - if (_this.isAlive()) { - var gui = cellRenderer.getGui(); - eRow.appendChild(gui); - cellRendererCallback(cellRenderer); - } - else { - _this.beans.context.destroyBean(cellRenderer); - } - }; - // if doing master detail, it's possible we have a cached row comp from last time detail was displayed - var cachedRowComp = _this.beans.detailRowCompCache.get(_this.rowNode, pinned); - if (cachedRowComp) { - callback(cachedRowComp); + var currentRowType = this.getHeaderRowType(headerRowIndex); + if (!skipColumn) { + if (currentRowType === _row_headerRowComp__WEBPACK_IMPORTED_MODULE_4__["HeaderRowType"].COLUMN_GROUP) { + var currentColumn = column; + nextFocusColumn = isUp ? column.getParent() : currentColumn.getDisplayedChildren()[0]; + } + else if (currentRowType === _row_headerRowComp__WEBPACK_IMPORTED_MODULE_4__["HeaderRowType"].FLOATING_FILTER) { + nextFocusColumn = column; } else { - var res = _this.beans.userComponentFactory.newFullWidthCellRenderer(params, cellRendererType, cellRendererName); - if (!res) { - var masterDetailModuleLoaded = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_6__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].MasterDetailModule); - if (cellRendererName === 'agDetailCellRenderer' && !masterDetailModuleLoaded) { - console.warn("ag-Grid: cell renderer agDetailCellRenderer (for master detail) not found. Did you forget to include the master detail module?"); - } - else { - console.error("ag-Grid: fullWidthCellRenderer " + cellRendererName + " not found"); - } - return; - } - res.then(callback); + var currentColumn = column; + nextFocusColumn = isUp ? currentColumn.getParent() : currentColumn; + } + if (!nextFocusColumn) { + return false; } - _this.afterRowAttached(rowContainerComp, eRow); - eRowCallback(eRow); - _this.angular1Compile(eRow); - }); - }; - RowComp.prototype.angular1Compile = function (element) { - if (!this.scope) { - return; } - this.beans.$compile(element)(this.scope); - }; - RowComp.prototype.createFullWidthParams = function (eRow, pinned) { - var params = { - fullWidth: true, - data: this.rowNode.data, - node: this.rowNode, - value: this.rowNode.key, - $scope: this.scope ? this.scope : this.parentScope, - $compile: this.beans.$compile, - rowIndex: this.rowNode.rowIndex, - api: this.beans.gridOptionsWrapper.getApi(), - columnApi: this.beans.gridOptionsWrapper.getColumnApi(), - context: this.beans.gridOptionsWrapper.getContext(), - // these need to be taken out, as part of 'afterAttached' now - eGridCell: eRow, - eParentOfValue: eRow, - pinned: pinned, - addRenderedRowListener: this.addEventListener.bind(this) - }; - return params; + return this.focusService.focusHeaderPosition({ + headerPosition: { headerRowIndex: nextRow, column: nextFocusColumn }, + allowUserOverride: true, + event: event + }); }; - RowComp.prototype.getInitialRowClasses = function (extraCssClass) { - var classes = []; - var isTreeData = this.beans.gridOptionsWrapper.isTreeData(); - var rowNode = this.rowNode; - if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(extraCssClass)) { - classes.push(extraCssClass); - } - classes.push('ag-row'); - classes.push(this.rowFocused ? 'ag-row-focus' : 'ag-row-no-focus'); - if (this.fadeRowIn) { - classes.push('ag-opacity-zero'); - } - classes.push(this.rowIsEven ? 'ag-row-even' : 'ag-row-odd'); - if (rowNode.isRowPinned()) { - classes.push('ag-row-pinned'); - } - if (rowNode.isSelected()) { - classes.push('ag-row-selected'); - } - if (rowNode.group) { - classes.push('ag-row-group'); - // if a group, put the level of the group in - classes.push('ag-row-level-' + rowNode.level); - if (rowNode.footer) { - classes.push('ag-row-footer'); - } + /* + * This method navigates grid header horizontally + * @return {boolean} true to preventDefault on the event that caused this navigation. + */ + HeaderNavigationService.prototype.navigateHorizontally = function (direction, fromTab, event) { + if (fromTab === void 0) { fromTab = false; } + var focusedHeader = this.focusService.getFocusedHeader(); + var isLeft = direction === HeaderNavigationDirection.LEFT; + var isRtl = this.gridOptionsWrapper.isEnableRtl(); + var nextHeader; + var normalisedDirection; + // either navigating to the left or isRtl (cannot be both) + if (isLeft !== isRtl) { + normalisedDirection = 'Before'; + nextHeader = this.headerPositionUtils.findHeader(focusedHeader, normalisedDirection); } else { - // if a leaf, and a parent exists, put a level of the parent, else put level of 0 for top level item - classes.push('ag-row-level-' + (rowNode.parent ? (rowNode.parent.level + 1) : '0')); - } - if (rowNode.stub) { - classes.push('ag-row-loading'); - } - if (this.fullWidthRow) { - classes.push('ag-full-width-row'); - } - var addExpandedClass = isTreeData ? - // if doing tree data, we add the expanded classes if any children, as any node can be a parent - rowNode.allChildrenCount : - // if normal row grouping, we add expanded classes to groups only - rowNode.group && !rowNode.footer; - if (addExpandedClass) { - classes.push(rowNode.expanded ? 'ag-row-group-expanded' : 'ag-row-group-contracted'); - } - if (rowNode.dragging) { - classes.push('ag-row-dragging'); + normalisedDirection = 'After'; + nextHeader = this.headerPositionUtils.findHeader(focusedHeader, normalisedDirection); } - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].pushAll(classes, this.processClassesFromGridOptions()); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].pushAll(classes, this.preProcessRowClassRules()); - // we use absolute position unless we are doing print layout - classes.push(this.printLayout ? 'ag-row-position-relative' : 'ag-row-position-absolute'); - this.firstRowOnPage = this.isFirstRowOnPage(); - this.lastRowOnPage = this.isLastRowOnPage(); - if (this.firstRowOnPage) { - classes.push('ag-row-first'); + if (nextHeader) { + return this.focusService.focusHeaderPosition({ + headerPosition: nextHeader, + direction: normalisedDirection, + fromTab: fromTab, + allowUserOverride: true, + event: event + }); } - if (this.lastRowOnPage) { - classes.push('ag-row-last'); + if (!fromTab) { + return true; } - return classes; - }; - RowComp.prototype.isFirstRowOnPage = function () { - return this.rowNode.rowIndex === this.beans.paginationProxy.getPageFirstRow(); - }; - RowComp.prototype.isLastRowOnPage = function () { - return this.rowNode.rowIndex === this.beans.paginationProxy.getPageLastRow(); + return this.focusNextHeaderRow(focusedHeader, normalisedDirection, event); }; - RowComp.prototype.onModelUpdated = function () { - var newFirst = this.isFirstRowOnPage(); - var newLast = this.isLastRowOnPage(); - if (this.firstRowOnPage !== newFirst) { - this.firstRowOnPage = newFirst; - this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-first', newFirst); }); + HeaderNavigationService.prototype.focusNextHeaderRow = function (focusedHeader, direction, event) { + var currentIndex = focusedHeader.headerRowIndex; + var nextPosition = null; + var nextRowIndex; + if (direction === 'Before') { + if (currentIndex > 0) { + nextRowIndex = currentIndex - 1; + nextPosition = this.headerPositionUtils.findColAtEdgeForHeaderRow(nextRowIndex, 'end'); + } } - if (this.lastRowOnPage !== newLast) { - this.lastRowOnPage = newLast; - this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-last', newLast); }); + else { + nextRowIndex = currentIndex + 1; + nextPosition = this.headerPositionUtils.findColAtEdgeForHeaderRow(nextRowIndex, 'start'); } - }; - RowComp.prototype.preProcessRowClassRules = function () { - var res = []; - this.processRowClassRules(function (className) { - res.push(className); - }, function (className) { - // not catered for, if creating, no need - // to remove class as it was never there + return this.focusService.focusHeaderPosition({ + headerPosition: nextPosition, + direction: direction, + fromTab: true, + allowUserOverride: true, + event: event }); - return res; - }; - RowComp.prototype.processRowClassRules = function (onApplicableClass, onNotApplicableClass) { - this.beans.stylingService.processClassRules(this.beans.gridOptionsWrapper.rowClassRules(), { - value: undefined, - colDef: undefined, - data: this.rowNode.data, - node: this.rowNode, - rowIndex: this.rowNode.rowIndex, - api: this.beans.gridOptionsWrapper.getApi(), - columnApi: this.beans.gridOptionsWrapper.getColumnApi(), - $scope: this.scope, - context: this.beans.gridOptionsWrapper.getContext() - }, onApplicableClass, onNotApplicableClass); }; - RowComp.prototype.stopEditing = function (cancel) { - if (cancel === void 0) { cancel = false; } - this.forEachCellComp(function (renderedCell) { - renderedCell.stopEditing(cancel); - }); - if (!this.editingRow) { + HeaderNavigationService.prototype.scrollToColumn = function (column, direction) { + if (direction === void 0) { direction = 'After'; } + if (column.getPinned()) { return; } - if (!cancel) { - var event_1 = this.createRowEvent(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_VALUE_CHANGED); - this.beans.eventService.dispatchEvent(event_1); + var columnToScrollTo; + if (column instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_2__["ColumnGroup"]) { + var columns = column.getDisplayedLeafColumns(); + columnToScrollTo = direction === 'Before' ? Object(_utils_array__WEBPACK_IMPORTED_MODULE_3__["last"])(columns) : columns[0]; } - this.setEditingRow(false); - }; - RowComp.prototype.setEditingRow = function (value) { - this.editingRow = value; - this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-editing', value); }); - var event = value ? - this.createRowEvent(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_EDITING_STARTED) - : this.createRowEvent(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_EDITING_STOPPED); - this.beans.eventService.dispatchEvent(event); - }; - RowComp.prototype.startRowEditing = function (keyPress, charPress, sourceRenderedCell) { - if (keyPress === void 0) { keyPress = null; } - if (charPress === void 0) { charPress = null; } - if (sourceRenderedCell === void 0) { sourceRenderedCell = null; } - // don't do it if already editing - if (this.editingRow) { - return; + else { + columnToScrollTo = column; } - this.forEachCellComp(function (renderedCell) { - var cellStartedEdit = renderedCell === sourceRenderedCell; - if (cellStartedEdit) { - renderedCell.startEditingIfEnabled(keyPress, charPress, cellStartedEdit); - } - else { - renderedCell.startEditingIfEnabled(null, null, cellStartedEdit); - } - }); - this.setEditingRow(true); + this.gridBodyCon.getScrollFeature().ensureColumnVisible(columnToScrollTo); + // need to nudge the scrolls for the floating items. otherwise when we set focus on a non-visible + // floating cell, the scrolls get out of sync + this.gridBodyCon.getScrollFeature().horizontallyScrollHeaderCenterAndFloatingCenter(); + // need to flush frames, to make sure the correct cells are rendered + this.animationFrameService.flushAllFrames(); }; - RowComp.prototype.forEachCellComp = function (callback) { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].iterateObject(this.cellComps, function (key, cellComp) { - if (!cellComp) { - return; - } - callback(cellComp); - }); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('focusService') + ], HeaderNavigationService.prototype, "focusService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('headerPositionUtils') + ], HeaderNavigationService.prototype, "headerPositionUtils", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('animationFrameService') + ], HeaderNavigationService.prototype, "animationFrameService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('ctrlsService') + ], HeaderNavigationService.prototype, "ctrlsService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], HeaderNavigationService.prototype, "postConstruct", null); + HeaderNavigationService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('headerNavigationService') + ], HeaderNavigationService); + return HeaderNavigationService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); + + + +/***/ }), +/* 136 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderRowType", function() { return HeaderRowType; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderRowComp", function() { return HeaderRowComp; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(44); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(42); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(13); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(36); +/* harmony import */ var _cells_column_headerCellComp__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(137); +/* harmony import */ var _cells_columnGroup_headerGroupCellComp__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(139); +/* harmony import */ var _cells_floatingFilter_headerFilterCellComp__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(140); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - RowComp.prototype.postProcessClassesFromGridOptions = function () { - var _this = this; - var cssClasses = this.processClassesFromGridOptions(); - if (!cssClasses || !cssClasses.length) { - return; - } - cssClasses.forEach(function (classStr) { - _this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(row, classStr); }); - }); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - RowComp.prototype.postProcessRowClassRules = function () { +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + + +var HeaderRowType; +(function (HeaderRowType) { + HeaderRowType["COLUMN_GROUP"] = "group"; + HeaderRowType["COLUMN"] = "column"; + HeaderRowType["FLOATING_FILTER"] = "filter"; +})(HeaderRowType || (HeaderRowType = {})); +var HeaderRowComp = /** @class */ (function (_super) { + __extends(HeaderRowComp, _super); + function HeaderRowComp(ctrl) { + var _this = _super.call(this) || this; + _this.headerComps = {}; + var extraClass = ctrl.getType() == HeaderRowType.COLUMN_GROUP ? "ag-header-row-column-group" : + ctrl.getType() == HeaderRowType.FLOATING_FILTER ? "ag-header-row-column-filter" : "ag-header-row-column"; + _this.setTemplate(/* html */ "
"); + _this.ctrl = ctrl; + return _this; + } + //noinspection JSUnusedLocalSymbols + HeaderRowComp.prototype.init = function () { var _this = this; - this.processRowClassRules(function (className) { - _this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(row, className); }); - }, function (className) { - _this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(row, className); }); - }); - }; - RowComp.prototype.processClassesFromGridOptions = function () { - var res = []; - var process = function (rowCls) { - if (typeof rowCls === 'string') { - res.push(rowCls); - } - else if (Array.isArray(rowCls)) { - rowCls.forEach(function (e) { return res.push(e); }); - } + var compProxy = { + setTransform: function (transform) { return _this.getGui().style.transform = transform; }, + setHeight: function (height) { return _this.getGui().style.height = height; }, + setTop: function (top) { return _this.getGui().style.top = top; }, + setHeaderCtrls: function (ctrls) { return _this.setHeaderCtrls(ctrls); }, + setWidth: function (width) { return _this.getGui().style.width = width; }, + setAriaRowIndex: function (rowIndex) { return Object(_utils_aria__WEBPACK_IMPORTED_MODULE_1__["setAriaRowIndex"])(_this.getGui(), rowIndex); } }; - // part 1 - rowClass - var rowClass = this.beans.gridOptionsWrapper.getRowClass(); - if (rowClass) { - if (typeof rowClass === 'function') { - console.warn('ag-Grid: rowClass should not be a function, please use getRowClass instead'); - return; - } - process(rowClass); - } - // part 2 - rowClassFunc - var rowClassFunc = this.beans.gridOptionsWrapper.getRowClassFunc(); - if (rowClassFunc) { - var params = { - node: this.rowNode, - data: this.rowNode.data, - rowIndex: this.rowNode.rowIndex, - context: this.beans.gridOptionsWrapper.getContext(), - api: this.beans.gridOptionsWrapper.getApi() - }; - var rowClassFuncResult = rowClassFunc(params); - process(rowClassFuncResult); - } - return res; - }; - RowComp.prototype.preProcessStylesFromGridOptions = function () { - var rowStyles = this.processStylesFromGridOptions(); - return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].cssStyleObjectToMarkup(rowStyles); + this.ctrl.setComp(compProxy); }; - RowComp.prototype.postProcessStylesFromGridOptions = function () { - var rowStyles = this.processStylesFromGridOptions(); - this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addStylesToElement(row, rowStyles); }); + HeaderRowComp.prototype.destroyHeaderCtrls = function () { + this.setHeaderCtrls([]); }; - RowComp.prototype.processStylesFromGridOptions = function () { - // part 1 - rowStyle - var rowStyle = this.beans.gridOptionsWrapper.getRowStyle(); - if (rowStyle && typeof rowStyle === 'function') { - console.warn('ag-Grid: rowStyle should be an object of key/value styles, not be a function, use getRowStyle() instead'); + HeaderRowComp.prototype.setHeaderCtrls = function (ctrls) { + var _this = this; + if (!this.isAlive()) { return; } - // part 1 - rowStyleFunc - var rowStyleFunc = this.beans.gridOptionsWrapper.getRowStyleFunc(); - var rowStyleFuncResult; - if (rowStyleFunc) { - var params = { - data: this.rowNode.data, - node: this.rowNode, - api: this.beans.gridOptionsWrapper.getApi(), - context: this.beans.gridOptionsWrapper.getContext(), - $scope: this.scope - }; - rowStyleFuncResult = rowStyleFunc(params); + var oldComps = this.headerComps; + this.headerComps = {}; + ctrls.forEach(function (ctrl) { + var id = ctrl.getInstanceId(); + var comp = oldComps[id]; + delete oldComps[id]; + if (comp == null) { + comp = _this.createHeaderComp(ctrl); + _this.getGui().appendChild(comp.getGui()); + } + _this.headerComps[id] = comp; + }); + Object(_utils_object__WEBPACK_IMPORTED_MODULE_3__["iterateObject"])(oldComps, function (id, comp) { + _this.getGui().removeChild(comp.getGui()); + _this.destroyBean(comp); + }); + var ensureDomOrder = this.gridOptionsWrapper.isEnsureDomOrder(); + if (ensureDomOrder) { + var comps = Object(_utils_object__WEBPACK_IMPORTED_MODULE_3__["getAllValuesInObject"])(this.headerComps); + // ordering the columns by left position orders them in the order they appear on the screen + comps.sort(function (a, b) { + var leftA = a.getCtrl().getColumnGroupChild().getLeft(); + var leftB = b.getCtrl().getColumnGroupChild().getLeft(); + return leftA - leftB; + }); + var elementsInOrder = comps.map(function (c) { return c.getGui(); }); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["setDomChildOrder"])(this.getGui(), elementsInOrder); } - return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].assign({}, rowStyle, rowStyleFuncResult); }; - RowComp.prototype.createCells = function (cols) { - var _this = this; - var templateParts = []; - var newCellComps = []; - cols.forEach(function (col) { - var newCellComp = new _cellComp__WEBPACK_IMPORTED_MODULE_0__["CellComp"](_this.scope, _this.beans, col, _this.rowNode, _this, false, _this.printLayout); - var cellTemplate = newCellComp.getCreateTemplate(); - templateParts.push(cellTemplate); - newCellComps.push(newCellComp); - _this.cellComps[col.getId()] = newCellComp; - }); - var templateAndComps = { - template: templateParts.join(''), - cellComps: newCellComps - }; - return templateAndComps; + HeaderRowComp.prototype.createHeaderComp = function (headerCtrl) { + var result; + switch (this.ctrl.getType()) { + case HeaderRowType.COLUMN_GROUP: + result = new _cells_columnGroup_headerGroupCellComp__WEBPACK_IMPORTED_MODULE_6__["HeaderGroupCellComp"](headerCtrl); + break; + case HeaderRowType.FLOATING_FILTER: + result = new _cells_floatingFilter_headerFilterCellComp__WEBPACK_IMPORTED_MODULE_7__["HeaderFilterCellComp"](headerCtrl); + break; + default: + result = new _cells_column_headerCellComp__WEBPACK_IMPORTED_MODULE_5__["HeaderCellComp"](headerCtrl); + break; + } + this.createBean(result); + result.setParentComponent(this); + return result; }; - RowComp.prototype.onRowSelected = function () { - var selected = this.rowNode.isSelected(); - this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-selected', selected); }); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], HeaderRowComp.prototype, "init", null); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PreDestroy"] + ], HeaderRowComp.prototype, "destroyHeaderCtrls", null); + return HeaderRowComp; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_4__["Component"])); + + + +/***/ }), +/* 137 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderCellComp", function() { return HeaderCellComp; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(44); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57); +/* harmony import */ var _abstractCell_abstractHeaderCellComp__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(138); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - // called: - // + after row created for first time - // + after horizontal scroll, so new cells due to column virtualisation - RowComp.prototype.callAfterRowAttachedOnCells = function (newCellComps, eRow) { - var _this = this; - newCellComps.forEach(function (cellComp) { - cellComp.setParentRow(eRow); - cellComp.afterAttached(); - // if we are editing the row, then the cell needs to turn - // into edit mode - if (_this.editingRow) { - cellComp.startEditingIfEnabled(); - } - }); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - RowComp.prototype.afterRowAttached = function (rowContainerComp, eRow) { +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + +var HeaderCellComp = /** @class */ (function (_super) { + __extends(HeaderCellComp, _super); + function HeaderCellComp(ctrl) { + var _this = _super.call(this, HeaderCellComp.TEMPLATE, ctrl) || this; + _this.headerCompVersion = 0; + _this.column = ctrl.getColumnGroupChild(); + _this.pinned = ctrl.getPinned(); + return _this; + } + HeaderCellComp.prototype.postConstruct = function () { var _this = this; - this.addDomData(eRow); - this.removeSecondPassFuncs.push(function () { - rowContainerComp.removeRowElement(eRow); - }); - this.removeFirstPassFuncs.push(function () { - if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(_this.rowNode.rowTop)) { - // the row top is updated anyway, however we set it here again - // to something more reasonable for the animation - ie if the - // row top is 10000px away, the row will flash out, so this - // gives it a rounded value, so row animates out more slowly - var rowTop = _this.roundRowTopToBounds(_this.rowNode.rowTop); - _this.setRowTop(rowTop); + var eGui = this.getGui(); + var setAttribute = function (name, value, element) { + var actualElement = element ? element : eGui; + if (value != null && value != '') { + actualElement.setAttribute(name, value); } else { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(eRow, 'ag-opacity-zero'); + actualElement.removeAttribute(name); } - }); - this.eAllRowContainers.push(eRow); - // adding hover functionality adds listener to this row, so we - // do it lazily in an animation frame - if (this.useAnimationFrameForCreate) { - this.beans.taskQueue.createTask(this.addHoverFunctionality.bind(this, eRow), this.rowNode.rowIndex, 'createTasksP2'); - } - else { - this.addHoverFunctionality(eRow); + }; + var compProxy = { + setWidth: function (width) { return eGui.style.width = width; }, + addOrRemoveCssClass: function (cssClassName, on) { return _this.addOrRemoveCssClass(cssClassName, on); }, + setAriaSort: function (sort) { return sort ? Object(_utils_aria__WEBPACK_IMPORTED_MODULE_1__["setAriaSort"])(eGui, sort) : Object(_utils_aria__WEBPACK_IMPORTED_MODULE_1__["removeAriaSort"])(eGui); }, + setColId: function (id) { return setAttribute('col-id', id); }, + setTitle: function (title) { return setAttribute('title', title); }, + setAriaDescribedBy: function (value) { return Object(_utils_aria__WEBPACK_IMPORTED_MODULE_1__["setAriaDescribedBy"])(eGui, value); }, + setUserCompDetails: function (compDetails) { return _this.setUserCompDetails(compDetails); }, + getUserCompInstance: function () { return _this.headerComp; } + }; + this.ctrl.setComp(compProxy, this.getGui(), this.eResize); + var selectAllGui = this.ctrl.getSelectAllGui(); + this.eResize.insertAdjacentElement('afterend', selectAllGui); + }; + HeaderCellComp.prototype.destroyHeaderComp = function () { + if (this.headerComp) { + this.getGui().removeChild(this.headerCompGui); + this.headerComp = this.destroyBean(this.headerComp); + this.headerCompGui = undefined; } }; - RowComp.prototype.addHoverFunctionality = function (eRow) { + HeaderCellComp.prototype.setUserCompDetails = function (compDetails) { var _this = this; - // because we use animation frames to do this, it's possible the row no longer exists - // by the time we get to add it - if (!this.active) { + this.headerCompVersion++; + var versionCopy = this.headerCompVersion; + compDetails.newAgStackInstance().then(function (comp) { return _this.afterCompCreated(versionCopy, comp); }); + }; + HeaderCellComp.prototype.afterCompCreated = function (version, headerComp) { + if (version != this.headerCompVersion || !this.isAlive()) { + this.destroyBean(headerComp); return; } - // because mouseenter and mouseleave do not propagate, we cannot listen on the gridPanel - // like we do for all the other mouse events. - // because of the pinning, we cannot simply add / remove the class based on the eRow. we - // have to check all eRow's (body & pinned). so the trick is if any of the rows gets a - // mouse hover, it sets such in the rowNode, and then all three reflect the change as - // all are listening for event on the row node. - // step 1 - add listener, to set flag on row node - this.addManagedListener(eRow, 'mouseenter', function () { return _this.rowNode.onMouseEnter(); }); - this.addManagedListener(eRow, 'mouseleave', function () { return _this.rowNode.onMouseLeave(); }); - // step 2 - listen for changes on row node (which any eRow can trigger) - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_MOUSE_ENTER, function () { - // if hover turned off, we don't add the class. we do this here so that if the application - // toggles this property mid way, we remove the hover form the last row, but we stop - // adding hovers from that point onwards. - if (!_this.beans.gridOptionsWrapper.isSuppressRowHoverHighlight()) { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(eRow, 'ag-row-hover'); - } - }); - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_MOUSE_LEAVE, function () { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(eRow, 'ag-row-hover'); - }); + this.destroyHeaderComp(); + this.headerComp = headerComp; + this.headerCompGui = headerComp.getGui(); + this.getGui().appendChild(this.headerCompGui); + this.ctrl.setDragSource(this.headerCompGui); }; - // for animation, we don't want to animate entry or exit to a very far away pixel, - // otherwise the row would move so fast, it would appear to disappear. so this method - // moves the row closer to the viewport if it is far away, so the row slide in / out - // at a speed the user can see. - RowComp.prototype.roundRowTopToBounds = function (rowTop) { - var range = this.beans.gridPanel.getVScrollPosition(); - var minPixel = this.applyPaginationOffset(range.top, true) - 100; - var maxPixel = this.applyPaginationOffset(range.bottom, true) + 100; - return Math.min(Math.max(minPixel, rowTop), maxPixel); + HeaderCellComp.TEMPLATE = "
\n
\n
"; + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('eResize') + ], HeaderCellComp.prototype, "eResize", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], HeaderCellComp.prototype, "postConstruct", null); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PreDestroy"] + ], HeaderCellComp.prototype, "destroyHeaderComp", null); + return HeaderCellComp; +}(_abstractCell_abstractHeaderCellComp__WEBPACK_IMPORTED_MODULE_3__["AbstractHeaderCellComp"])); + + + +/***/ }), +/* 138 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AbstractHeaderCellComp", function() { return AbstractHeaderCellComp; }); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - RowComp.prototype.getFrameworkOverrides = function () { - return this.beans.frameworkOverrides; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); + +var AbstractHeaderCellComp = /** @class */ (function (_super) { + __extends(AbstractHeaderCellComp, _super); + function AbstractHeaderCellComp(template, ctrl) { + var _this = _super.call(this, template) || this; + _this.ctrl = ctrl; + return _this; + } + AbstractHeaderCellComp.prototype.getCtrl = function () { + return this.ctrl; + }; + return AbstractHeaderCellComp; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); + + + +/***/ }), +/* 139 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderGroupCellComp", function() { return HeaderGroupCellComp; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); +/* harmony import */ var _abstractCell_abstractHeaderCellComp__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(138); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + +var HeaderGroupCellComp = /** @class */ (function (_super) { + __extends(HeaderGroupCellComp, _super); + function HeaderGroupCellComp(ctrl) { + return _super.call(this, HeaderGroupCellComp.TEMPLATE, ctrl) || this; + } + HeaderGroupCellComp.prototype.postConstruct = function () { + var _this = this; + var eGui = this.getGui(); + var setAttribute = function (key, value) { + return value != undefined ? eGui.setAttribute(key, value) : eGui.removeAttribute(key); + }; + var compProxy = { + addOrRemoveCssClass: function (cssClassName, on) { return _this.addOrRemoveCssClass(cssClassName, on); }, + addOrRemoveResizableCssClass: function (cssClassName, on) { return _this.eResize.classList.toggle(cssClassName, on); }, + setWidth: function (width) { return eGui.style.width = width; }, + setColId: function (id) { return eGui.setAttribute("col-id", id); }, + setAriaExpanded: function (expanded) { return setAttribute('aria-expanded', expanded); }, + setTitle: function (title) { return setAttribute("title", title); }, + setUserCompDetails: function (details) { return _this.setUserCompDetails(details); } + }; + this.ctrl.setComp(compProxy, eGui, this.eResize); }; - RowComp.prototype.onRowHeightChanged = function () { - // check for exists first - if the user is resetting the row height, then - // it will be null (or undefined) momentarily until the next time the flatten - // stage is called where the row will then update again with a new height - if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(this.rowNode.rowHeight)) { - var heightPx_1 = this.rowNode.rowHeight + "px"; - this.eAllRowContainers.forEach(function (row) { return row.style.height = heightPx_1; }); - } + HeaderGroupCellComp.prototype.setUserCompDetails = function (details) { + var _this = this; + details.newAgStackInstance().then(function (comp) { return _this.afterHeaderCompCreated(comp); }); }; - RowComp.prototype.addEventListener = function (eventType, listener) { - if (eventType === 'renderedRowRemoved' || eventType === 'rowRemoved') { - eventType = _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_VIRTUAL_ROW_REMOVED; - console.warn('ag-Grid: Since version 11, event renderedRowRemoved is now called ' + _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_VIRTUAL_ROW_REMOVED); + HeaderGroupCellComp.prototype.afterHeaderCompCreated = function (headerGroupComp) { + var _this = this; + var destroyFunc = function () { return _this.destroyBean(headerGroupComp); }; + if (!this.isAlive()) { + destroyFunc(); + return; } - _super.prototype.addEventListener.call(this, eventType, listener); + this.getGui().appendChild(headerGroupComp.getGui()); + this.addDestroyFunc(destroyFunc); + this.ctrl.setDragSource(headerGroupComp.getGui()); }; - RowComp.prototype.removeEventListener = function (eventType, listener) { - if (eventType === 'renderedRowRemoved' || eventType === 'rowRemoved') { - eventType = _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_VIRTUAL_ROW_REMOVED; - console.warn('ag-Grid: Since version 11, event renderedRowRemoved and rowRemoved is now called ' + _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_VIRTUAL_ROW_REMOVED); - } - _super.prototype.removeEventListener.call(this, eventType, listener); + HeaderGroupCellComp.TEMPLATE = "
\n
\n
"; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('userComponentFactory') + ], HeaderGroupCellComp.prototype, "userComponentFactory", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eResize') + ], HeaderGroupCellComp.prototype, "eResize", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], HeaderGroupCellComp.prototype, "postConstruct", null); + return HeaderGroupCellComp; +}(_abstractCell_abstractHeaderCellComp__WEBPACK_IMPORTED_MODULE_2__["AbstractHeaderCellComp"])); + + + +/***/ }), +/* 140 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderFilterCellComp", function() { return HeaderFilterCellComp; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); +/* harmony import */ var _abstractCell_abstractHeaderCellComp__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(138); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - // note - this is NOT called by context, as we don't wire / unwire the CellComp for performance reasons. - RowComp.prototype.destroy = function (animate) { - if (animate === void 0) { animate = false; } - this.active = false; - // why do we have this method? shouldn't everything below be added as a destroy func beside - // the corresponding create logic? - this.destroyFullWidthComponents(); - if (animate) { - this.removeFirstPassFuncs.forEach(function (func) { return func(); }); - this.removeSecondPassFuncs.push(this.destroyContainingCells.bind(this)); - } - else { - this.destroyContainingCells(); - // we are not animating, so execute the second stage of removal now. - // we call getAndClear, so that they are only called once - var delayedDestroyFunctions = this.getAndClearDelayedDestroyFunctions(); - delayedDestroyFunctions.forEach(function (func) { return func(); }); - } - var event = this.createRowEvent(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_VIRTUAL_ROW_REMOVED); - this.dispatchEvent(event); - this.beans.eventService.dispatchEvent(event); - _super.prototype.destroy.call(this); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - RowComp.prototype.destroyContainingCells = function () { - this.forEachCellComp(function (renderedCell) { return renderedCell.destroy(); }); - this.destroyFullWidthComponents(); +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + +var HeaderFilterCellComp = /** @class */ (function (_super) { + __extends(HeaderFilterCellComp, _super); + function HeaderFilterCellComp(ctrl) { + return _super.call(this, HeaderFilterCellComp.TEMPLATE, ctrl) || this; + } + HeaderFilterCellComp.prototype.postConstruct = function () { + var _this = this; + var eGui = this.getGui(); + var compProxy = { + addOrRemoveCssClass: function (cssClassName, on) { return _this.addOrRemoveCssClass(cssClassName, on); }, + addOrRemoveBodyCssClass: function (cssClassName, on) { return _this.eFloatingFilterBody.classList.toggle(cssClassName, on); }, + addOrRemoveButtonWrapperCssClass: function (cssClassName, on) { return _this.eButtonWrapper.classList.toggle(cssClassName, on); }, + setCompDetails: function (compDetails) { return _this.setCompDetails(compDetails); }, + getFloatingFilterComp: function () { return _this.compPromise; }, + setWidth: function (width) { return eGui.style.width = width; }, + setMenuIcon: function (eIcon) { return _this.eButtonShowMainFilter.appendChild(eIcon); } + }; + this.ctrl.setComp(compProxy, eGui, this.eButtonShowMainFilter, this.eFloatingFilterBody); }; - // we clear so that the functions are never executed twice - RowComp.prototype.getAndClearDelayedDestroyFunctions = function () { - var result = this.removeSecondPassFuncs; - this.removeSecondPassFuncs = []; - return result; + HeaderFilterCellComp.prototype.setCompDetails = function (compDetails) { + var _this = this; + // because we are providing defaultFloatingFilterType, we know it will never be undefined; + this.compPromise = compDetails.newAgStackInstance(); + this.compPromise.then(function (comp) { return _this.afterCompCreated(comp); }); }; - RowComp.prototype.onCellFocusChanged = function () { - var rowFocused = this.beans.focusController.isRowFocused(this.rowNode.rowIndex, this.rowNode.rowPinned); - if (rowFocused !== this.rowFocused) { - this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-focus', rowFocused); }); - this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-no-focus', !rowFocused); }); - this.rowFocused = rowFocused; + HeaderFilterCellComp.prototype.afterCompCreated = function (comp) { + var _this = this; + if (!comp) { + return; } - // if we are editing, then moving the focus out of a row will stop editing - if (!rowFocused && this.editingRow) { - this.stopEditing(false); + this.addDestroyFunc(function () { return _this.context.destroyBean(comp); }); + if (!this.isAlive()) { + return; } - }; - RowComp.prototype.onPaginationChanged = function () { - var currentPage = this.beans.paginationProxy.getCurrentPage(); - // it is possible this row is in the new page, but the page number has changed, which means - // it needs to reposition itself relative to the new page - if (this.paginationPage !== currentPage) { - this.paginationPage = currentPage; - this.onTopChanged(); + this.eFloatingFilterBody.appendChild(comp.getGui()); + if (comp.afterGuiAttached) { + comp.afterGuiAttached(); } }; - RowComp.prototype.onTopChanged = function () { - this.setRowTop(this.rowNode.rowTop); + HeaderFilterCellComp.TEMPLATE = "
\n
\n
\n \n
\n
"; + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eFloatingFilterBody') + ], HeaderFilterCellComp.prototype, "eFloatingFilterBody", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eButtonWrapper') + ], HeaderFilterCellComp.prototype, "eButtonWrapper", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eButtonShowMainFilter') + ], HeaderFilterCellComp.prototype, "eButtonShowMainFilter", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], HeaderFilterCellComp.prototype, "postConstruct", null); + return HeaderFilterCellComp; +}(_abstractCell_abstractHeaderCellComp__WEBPACK_IMPORTED_MODULE_2__["AbstractHeaderCellComp"])); + + + +/***/ }), +/* 141 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderRowContainerComp", function() { return HeaderRowContainerComp; }); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(15); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(42); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(13); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(36); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(57); +/* harmony import */ var _row_headerRowComp__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(136); +/* harmony import */ var _headerRowContainerCtrl__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(142); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - // applies pagination offset, eg if on second page, and page height is 500px, then removes - // 500px from the top position, so a row with rowTop 600px is displayed at location 100px. - // reverse will take the offset away rather than add. - RowComp.prototype.applyPaginationOffset = function (topPx, reverse) { - if (reverse === void 0) { reverse = false; } - if (this.rowNode.isRowPinned()) { - return topPx; - } - var pixelOffset = this.beans.paginationProxy.getPixelOffset(); - var multiplier = reverse ? 1 : -1; - return topPx + (pixelOffset * multiplier); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - RowComp.prototype.setRowTop = function (pixels) { - // print layout uses normal flow layout for row positioning - if (this.printLayout) { - return; - } - // need to make sure rowTop is not null, as this can happen if the node was once - // visible (ie parent group was expanded) but is now not visible - if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(pixels)) { - var afterPaginationPixels = this.applyPaginationOffset(pixels); - var afterScalingPixels = this.beans.maxDivHeightScaler.getRealPixelPosition(afterPaginationPixels); - var topPx_1 = afterScalingPixels + "px"; - if (this.beans.gridOptionsWrapper.isSuppressRowTransform()) { - this.eAllRowContainers.forEach(function (row) { return row.style.top = topPx_1; }); - } - else { - this.eAllRowContainers.forEach(function (row) { return row.style.transform = "translateY(" + topPx_1 + ")"; }); +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + + +var HeaderRowContainerComp = /** @class */ (function (_super) { + __extends(HeaderRowContainerComp, _super); + function HeaderRowContainerComp(pinned) { + var _this = _super.call(this) || this; + _this.headerRowComps = {}; + _this.rowCompsList = []; + _this.pinned = pinned; + return _this; + } + HeaderRowContainerComp.prototype.init = function () { + var _this = this; + this.selectAndSetTemplate(); + var compProxy = { + addOrRemoveCssClass: function (cssClassName, on) { return _this.addOrRemoveCssClass(cssClassName, on); }, + setCtrls: function (ctrls) { return _this.setCtrls(ctrls); }, + // only gets called for center section + setCenterWidth: function (width) { return _this.eCenterContainer.style.width = width; }, + setContainerTransform: function (transform) { return _this.eCenterContainer.style.transform = transform; }, + // only gets called for pinned sections + setPinnedContainerWidth: function (width) { + var eGui = _this.getGui(); + eGui.style.width = width; + eGui.style.maxWidth = width; + eGui.style.minWidth = width; } - } - }; - // we clear so that the functions are never executed twice - RowComp.prototype.getAndClearNextVMTurnFunctions = function () { - var result = this.createSecondPassFuncs; - this.createSecondPassFuncs = []; - return result; - }; - RowComp.prototype.getRowNode = function () { - return this.rowNode; + }; + var ctrl = this.createManagedBean(new _headerRowContainerCtrl__WEBPACK_IMPORTED_MODULE_7__["HeaderRowContainerCtrl"](this.pinned)); + ctrl.setComp(compProxy, this.getGui()); + }; + HeaderRowContainerComp.prototype.selectAndSetTemplate = function () { + var pinnedLeft = this.pinned == _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_LEFT; + var pinnedRight = this.pinned == _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_RIGHT; + var template = pinnedLeft ? HeaderRowContainerComp.PINNED_LEFT_TEMPLATE : + pinnedRight ? HeaderRowContainerComp.PINNED_RIGHT_TEMPLATE : HeaderRowContainerComp.CENTER_TEMPLATE; + this.setTemplate(template); + // for left and right, we add rows directly to the root element, + // but for center container we add elements to the child container. + this.eRowContainer = this.eCenterContainer ? this.eCenterContainer : this.getGui(); }; - RowComp.prototype.getRenderedCellForColumn = function (column) { - var _this = this; - var cellComp = this.cellComps[column.getColId()]; - if (cellComp) { - return cellComp; - } - var spanList = Object.keys(this.cellComps) - .map(function (name) { return _this.cellComps[name]; }) - .filter(function (cmp) { return cmp && cmp.getColSpanningList().indexOf(column) !== -1; }); - return spanList.length ? spanList[0] : undefined; + HeaderRowContainerComp.prototype.destroyRowComps = function () { + this.setCtrls([]); }; - RowComp.prototype.onRowIndexChanged = function () { - // we only bother updating if the rowIndex is present. if it is not present, it means this row - // is child of a group node, and the group node was closed, it's the only way to have no row index. - // when this happens, row is about to be de-rendered, so we don't care, rowComp is about to die! - if (this.rowNode.rowIndex != null) { - this.onCellFocusChanged(); - this.updateRowIndexes(); - } + HeaderRowContainerComp.prototype.destroyRowComp = function (rowComp) { + this.destroyBean(rowComp); + this.eRowContainer.removeChild(rowComp.getGui()); }; - RowComp.prototype.updateRowIndexes = function () { + HeaderRowContainerComp.prototype.setCtrls = function (ctrls) { var _this = this; - var rowIndexStr = this.rowNode.getRowIndexString(); - var rowIsEven = this.rowNode.rowIndex % 2 === 0; - var rowIsEvenChanged = this.rowIsEven !== rowIsEven; - var headerRowCount = this.beans.headerNavigationService.getHeaderRowCount(); - if (rowIsEvenChanged) { - this.rowIsEven = rowIsEven; - } - this.eAllRowContainers.forEach(function (eRow) { - eRow.setAttribute('row-index', rowIndexStr); - eRow.setAttribute('aria-rowindex', (headerRowCount + _this.rowNode.rowIndex + 1).toString()); - if (!rowIsEvenChanged) { - return; - } - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(eRow, 'ag-row-even', rowIsEven); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(eRow, 'ag-row-odd', !rowIsEven); - }); - }; - RowComp.prototype.ensureDomOrder = function () { - var sides = [ - { - el: this.getBodyRowElement(), - ct: this.bodyContainerComp - }, - { - el: this.getPinnedLeftRowElement(), - ct: this.pinnedLeftContainerComp - }, { - el: this.getPinnedRightRowElement(), - ct: this.pinnedRightContainerComp - }, { - el: this.getFullWidthRowElement(), - ct: this.fullWidthContainerComp + var oldRowComps = this.headerRowComps; + this.headerRowComps = {}; + this.rowCompsList = []; + var prevGui; + var appendEnsuringDomOrder = function (rowComp) { + var eGui = rowComp.getGui(); + var notAlreadyIn = eGui.parentElement != _this.eRowContainer; + if (notAlreadyIn) { + _this.eRowContainer.appendChild(eGui); } - ]; - sides.forEach(function (side) { - if (!side.el) { - return; + if (prevGui) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["ensureDomOrder"])(_this.eRowContainer, eGui, prevGui); } - side.ct.ensureDomOrder(side.el); + prevGui = eGui; + }; + ctrls.forEach(function (ctrl) { + var ctrlId = ctrl.getInstanceId(); + var existingComp = oldRowComps[ctrlId]; + delete oldRowComps[ctrlId]; + var rowComp = existingComp ? existingComp : _this.createBean(new _row_headerRowComp__WEBPACK_IMPORTED_MODULE_6__["HeaderRowComp"](ctrl)); + _this.headerRowComps[ctrlId] = rowComp; + _this.rowCompsList.push(rowComp); + appendEnsuringDomOrder(rowComp); }); + Object(_utils_object__WEBPACK_IMPORTED_MODULE_3__["getAllValuesInObject"])(oldRowComps).forEach(function (c) { return _this.destroyRowComp(c); }); }; - // returns the pinned left container, either the normal one, or the embedded full with one if exists - RowComp.prototype.getPinnedLeftRowElement = function () { - return this.ePinnedLeftRow ? this.ePinnedLeftRow : this.eFullWidthRowLeft; - }; - // returns the pinned right container, either the normal one, or the embedded full with one if exists - RowComp.prototype.getPinnedRightRowElement = function () { - return this.ePinnedRightRow ? this.ePinnedRightRow : this.eFullWidthRowRight; - }; - // returns the body container, either the normal one, or the embedded full with one if exists - RowComp.prototype.getBodyRowElement = function () { - return this.eBodyRow ? this.eBodyRow : this.eFullWidthRowBody; - }; - // returns the full width container - RowComp.prototype.getFullWidthRowElement = function () { - return this.eFullWidthRow; - }; - RowComp.DOM_DATA_KEY_RENDERED_ROW = 'renderedRow'; - RowComp.FULL_WIDTH_CELL_RENDERER = 'fullWidthCellRenderer'; - RowComp.GROUP_ROW_RENDERER = 'groupRowRenderer'; - RowComp.GROUP_ROW_RENDERER_COMP_NAME = 'agGroupRowRenderer'; - RowComp.LOADING_CELL_RENDERER = 'loadingCellRenderer'; - RowComp.LOADING_CELL_RENDERER_COMP_NAME = 'agLoadingCellRenderer'; - RowComp.DETAIL_CELL_RENDERER = 'detailCellRenderer'; - RowComp.DETAIL_CELL_RENDERER_COMP_NAME = 'agDetailCellRenderer'; - return RowComp; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_3__["Component"])); + HeaderRowContainerComp.PINNED_LEFT_TEMPLATE = "
"; + HeaderRowContainerComp.PINNED_RIGHT_TEMPLATE = "
"; + HeaderRowContainerComp.CENTER_TEMPLATE = "
\n
\n
"; + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_5__["RefSelector"])('eCenterContainer') + ], HeaderRowContainerComp.prototype, "eCenterContainer", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], HeaderRowContainerComp.prototype, "init", null); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PreDestroy"] + ], HeaderRowContainerComp.prototype, "destroyRowComps", null); + return HeaderRowContainerComp; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_4__["Component"])); /***/ }), -/* 101 */ +/* 142 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellComp", function() { return CellComp; }); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(25); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(56); -/* harmony import */ var _checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(69); -/* harmony import */ var _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(102); -/* harmony import */ var _rowDragComp__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(103); -/* harmony import */ var _cellEditors_popupEditorWrapper__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(105); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(7); -/* harmony import */ var _dndSourceComp__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(106); -/* harmony import */ var _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(107); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderRowContainerCtrl", function() { return HeaderRowContainerCtrl; }); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(15); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(10); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(24); +/* harmony import */ var _gridBodyComp_centerWidthFeature__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(132); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(37); +/* harmony import */ var _columnDrag_bodyDropTarget__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(143); +/* harmony import */ var _row_headerRowComp__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(136); +/* harmony import */ var _row_headerRowCtrl__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(146); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -22521,16 +30679,31 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var __assign = (undefined && undefined.__assign) || function () { - __assign = Object.assign || function(t) { - for (var s, i = 1, n = arguments.length; i < n; i++) { - s = arguments[i]; - for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) - t[p] = s[p]; +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); } - return t; - }; - return __assign.apply(this, arguments); + finally { if (e) throw e.error; } + } + return ar; +}; +var __spread = (undefined && undefined.__spread) || function () { + for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); + return ar; }; @@ -22542,1748 +30715,1461 @@ var __assign = (undefined && undefined.__assign) || function () { -var CellComp = /** @class */ (function (_super) { - __extends(CellComp, _super); - function CellComp(scope, beans, column, rowNode, rowComp, autoHeightCell, printLayout) { +var HeaderRowContainerCtrl = /** @class */ (function (_super) { + __extends(HeaderRowContainerCtrl, _super); + function HeaderRowContainerCtrl(pinned) { var _this = _super.call(this) || this; - _this.hasChartRange = false; - _this.editingCell = false; - _this.suppressRefreshCell = false; - _this.scope = null; - // every time we go into edit mode, or back again, this gets incremented. - // it's the components way of dealing with the async nature of framework components, - // so if a framework component takes a while to be created, we know if the object - // is still relevant when creating is finished. eg we could click edit / un-edit 20 - // times before the first React edit component comes back - we should discard - // the first 19. - _this.cellEditorVersion = 0; - _this.cellRendererVersion = 0; - _this.scope = scope; - _this.beans = beans; - _this.column = column; - _this.rowNode = rowNode; - _this.rowComp = rowComp; - _this.autoHeightCell = autoHeightCell; - _this.printLayout = printLayout; - _this.createGridCellVo(); - _this.rangeSelectionEnabled = _this.beans.rangeController && beans.gridOptionsWrapper.isEnableRangeSelection(); - _this.cellFocused = _this.beans.focusController.isCellFocused(_this.cellPosition); - _this.firstRightPinned = _this.column.isFirstRightPinned(); - _this.lastLeftPinned = _this.column.isLastLeftPinned(); - if (_this.rangeSelectionEnabled && _this.beans.rangeController) { - var rangeController = _this.beans.rangeController; - _this.rangeCount = rangeController.getCellRangeCount(_this.cellPosition); - _this.hasChartRange = _this.getHasChartRange(); - } - _this.getValueAndFormat(); - _this.setUsingWrapper(); - _this.chooseCellRenderer(); - _this.setupColSpan(); - _this.rowSpan = _this.column.getRowSpan(_this.rowNode); + _this.groupsRowCtrls = []; + _this.pinned = pinned; return _this; } - CellComp.prototype.getCreateTemplate = function () { - var unselectable = !this.beans.gridOptionsWrapper.isEnableCellTextSelection() ? 'unselectable="on"' : ''; - var templateParts = []; - var col = this.column; - var width = this.getCellWidth(); - var left = this.modifyLeftForPrintLayout(this.getCellLeft()); - var valueToRender = this.getInitialValueToRender(); - var valueSanitised = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].get(this.column, 'colDef.template', null) ? valueToRender : _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(valueToRender); - this.tooltip = this.getToolTip(); - var tooltipSanitised = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(this.tooltip); - var colIdSanitised = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(col.getId()); - var wrapperStartTemplate = ''; - var wrapperEndTemplate = ''; - var stylesFromColDef = this.preProcessStylesFromColDef(); - var cssClasses = this.getInitialCssClasses(); - var stylesForRowSpanning = this.getStylesForRowSpanning(); - var colIdxSanitised = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(this.getAriaColumnIndex()); - if (this.usingWrapper) { - wrapperStartTemplate = "
\n "; - wrapperEndTemplate = '
'; - } - templateParts.push(""); - templateParts.push(wrapperStartTemplate); - if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(valueSanitised, true)) { - templateParts.push(valueSanitised); - } - templateParts.push(wrapperEndTemplate); - templateParts.push("
"); - return templateParts.join(''); - }; - CellComp.prototype.getStylesForRowSpanning = function () { - if (this.rowSpan === 1) { - return ''; - } - var singleRowHeight = this.beans.gridOptionsWrapper.getRowHeightAsNumber(); - var totalRowHeight = singleRowHeight * this.rowSpan; - return "height: " + totalRowHeight + "px; z-index: 1;"; - }; - CellComp.prototype.afterAttached = function () { - var querySelector = "[comp-id=\"" + this.getCompId() + "\"]"; - var eGui = this.eParentRow.querySelector(querySelector); - this.setGui(eGui); - // all of these have dependencies on the eGui, so only do them after eGui is set - this.addDomData(); - this.populateTemplate(); - this.createCellRendererInstance(true); - this.angular1Compile(); - this.refreshHandle(); - if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(this.tooltip) && !this.beans.gridOptionsWrapper.isEnableBrowserTooltips()) { - this.createManagedBean(new _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_9__["TooltipFeature"](this, 'cell'), this.beans.context); + HeaderRowContainerCtrl.prototype.setComp = function (comp, eGui) { + this.comp = comp; + this.setupCenterWidth(); + this.setupPinnedWidth(); + this.setupDragAndDrop(eGui); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_GRID_COLUMNS_CHANGED, this.onGridColumnsChanged.bind(this)); + this.ctrlsService.registerHeaderContainer(this, this.pinned); + if (this.columnModel.isReady()) { + this.refresh(); } }; - CellComp.prototype.onColumnHover = function () { - var isHovered = this.beans.columnHoverService.isHovered(this.column); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), 'ag-column-hover', isHovered); + HeaderRowContainerCtrl.prototype.setupDragAndDrop = function (dropContainer) { + var bodyDropTarget = new _columnDrag_bodyDropTarget__WEBPACK_IMPORTED_MODULE_7__["BodyDropTarget"](this.pinned, dropContainer); + this.createManagedBean(bodyDropTarget); }; - CellComp.prototype.onCellChanged = function (event) { - var eventImpactsThisCell = event.column === this.column; - if (eventImpactsThisCell) { - this.refreshCell({}); - } + HeaderRowContainerCtrl.prototype.refresh = function (keepColumns) { + var _this = this; + if (keepColumns === void 0) { keepColumns = false; } + var sequence = new _utils__WEBPACK_IMPORTED_MODULE_6__["NumberSequence"](); + var focusedHeaderPosition = this.focusService.getFocusHeaderToUseAfterRefresh(); + var refreshColumnGroups = function () { + var groupRowCount = _this.columnModel.getHeaderRowCount() - 1; + _this.groupsRowCtrls = _this.destroyBeans(_this.groupsRowCtrls); + for (var i = 0; i < groupRowCount; i++) { + var ctrl = _this.createBean(new _row_headerRowCtrl__WEBPACK_IMPORTED_MODULE_9__["HeaderRowCtrl"](sequence.next(), _this.pinned, _row_headerRowComp__WEBPACK_IMPORTED_MODULE_8__["HeaderRowType"].COLUMN_GROUP)); + _this.groupsRowCtrls.push(ctrl); + } + }; + var refreshColumns = function () { + var rowIndex = sequence.next(); + var needNewInstance = _this.columnsRowCtrl == null || !keepColumns || _this.columnsRowCtrl.getRowIndex() !== rowIndex; + if (needNewInstance) { + _this.destroyBean(_this.columnsRowCtrl); + _this.columnsRowCtrl = _this.createBean(new _row_headerRowCtrl__WEBPACK_IMPORTED_MODULE_9__["HeaderRowCtrl"](rowIndex, _this.pinned, _row_headerRowComp__WEBPACK_IMPORTED_MODULE_8__["HeaderRowType"].COLUMN)); + } + }; + var refreshFilters = function () { + var includeFloatingFilter = !_this.columnModel.isPivotMode() && _this.columnModel.hasFloatingFilters(); + var destroyPreviousComp = function () { + _this.filtersRowCtrl = _this.destroyBean(_this.filtersRowCtrl); + }; + if (!includeFloatingFilter) { + destroyPreviousComp(); + return; + } + var rowIndex = sequence.next(); + if (_this.filtersRowCtrl) { + var rowIndexMismatch = _this.filtersRowCtrl.getRowIndex() !== rowIndex; + if (!keepColumns || rowIndexMismatch) { + destroyPreviousComp(); + } + } + if (!_this.filtersRowCtrl) { + _this.filtersRowCtrl = _this.createBean(new _row_headerRowCtrl__WEBPACK_IMPORTED_MODULE_9__["HeaderRowCtrl"](rowIndex, _this.pinned, _row_headerRowComp__WEBPACK_IMPORTED_MODULE_8__["HeaderRowType"].FLOATING_FILTER)); + } + }; + refreshColumnGroups(); + refreshColumns(); + refreshFilters(); + var allCtrls = this.getAllCtrls(); + this.comp.setCtrls(allCtrls); + this.restoreFocusOnHeader(focusedHeaderPosition); }; - CellComp.prototype.getCellLeft = function () { - var mostLeftCol; - if (this.beans.gridOptionsWrapper.isEnableRtl() && this.colsSpanning) { - mostLeftCol = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].last(this.colsSpanning); - } - else { - mostLeftCol = this.column; + HeaderRowContainerCtrl.prototype.restoreFocusOnHeader = function (position) { + if (position == null || position.column.getPinned() != this.pinned) { + return; } - return mostLeftCol.getLeft(); + this.focusService.focusHeaderPosition({ headerPosition: position }); }; - CellComp.prototype.getCellWidth = function () { - if (!this.colsSpanning) { - return this.column.getActualWidth(); + HeaderRowContainerCtrl.prototype.getAllCtrls = function () { + var res = __spread(this.groupsRowCtrls, [this.columnsRowCtrl]); + if (this.filtersRowCtrl) { + res.push(this.filtersRowCtrl); } - return this.colsSpanning.reduce(function (width, col) { return width + col.getActualWidth(); }, 0); + return res; }; - CellComp.prototype.onFlashCells = function (event) { - var cellId = this.beans.cellPositionUtils.createId(this.cellPosition); - var shouldFlash = event.cells[cellId]; - if (shouldFlash) { - this.animateCell('highlight'); - } + // grid cols have changed - this also means the number of rows in the header can have + // changed. so we remove all the old rows and insert new ones for a complete refresh + HeaderRowContainerCtrl.prototype.onGridColumnsChanged = function () { + this.refresh(true); }; - CellComp.prototype.setupColSpan = function () { - // if no col span is active, then we don't set it up, as it would be wasteful of CPU - if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(this.getComponentHolder().colSpan)) { + HeaderRowContainerCtrl.prototype.setupCenterWidth = function () { + var _this = this; + if (this.pinned != null) { return; } - // because we are col spanning, a reorder of the cols can change what cols we are spanning over - this.addManagedListener(this.beans.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayColumnsChanged.bind(this)); - // because we are spanning over multiple cols, we check for width any time any cols width changes. - // this is expensive - really we should be explicitly checking only the cols we are spanning over - // instead of every col, however it would be tricky code to track the cols we are spanning over, so - // because hardly anyone will be using colSpan, am favouring this easier way for more maintainable code. - this.addManagedListener(this.beans.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, this.onWidthChanged.bind(this)); - this.colsSpanning = this.getColSpanningList(); - }; - CellComp.prototype.getColSpanningList = function () { - var colSpan = this.column.getColSpan(this.rowNode); - var colsSpanning = []; - // if just one col, the col span is just the column we are in - if (colSpan === 1) { - colsSpanning.push(this.column); - } - else { - var pointer = this.column; - var pinned = this.column.getPinned(); - for (var i = 0; pointer && i < colSpan; i++) { - colsSpanning.push(pointer); - pointer = this.beans.columnController.getDisplayedColAfter(pointer); - if (!pointer || _utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(pointer)) { - break; - } - // we do not allow col spanning to span outside of pinned areas - if (pinned !== pointer.getPinned()) { - break; - } - } - } - return colsSpanning; - }; - CellComp.prototype.onDisplayColumnsChanged = function () { - var colsSpanning = this.getColSpanningList(); - if (!_utils__WEBPACK_IMPORTED_MODULE_7__["_"].areEqual(this.colsSpanning, colsSpanning)) { - this.colsSpanning = colsSpanning; - this.onWidthChanged(); - this.onLeftChanged(); // left changes when doing RTL - } + this.createManagedBean(new _gridBodyComp_centerWidthFeature__WEBPACK_IMPORTED_MODULE_5__["CenterWidthFeature"](function (width) { return _this.comp.setCenterWidth(width + "px"); })); }; - CellComp.prototype.getAriaColumnIndex = function () { - var allColumns = this.beans.columnController.getAllDisplayedColumns(); - return (allColumns.indexOf(this.column) + 1).toString(); + HeaderRowContainerCtrl.prototype.setHorizontalScroll = function (offset) { + this.comp.setContainerTransform("translateX(" + offset + "px)"); }; - CellComp.prototype.refreshAriaIndex = function () { - var colIdx = this.getAriaColumnIndex(); - var el = this.usingWrapper ? this.eCellValue : this.getGui(); - el.setAttribute('aria-colindex', colIdx); - }; - CellComp.prototype.getInitialCssClasses = function () { - var cssClasses = ["ag-cell", "ag-cell-not-inline-editing"]; - // if we are putting the cell into a dummy container, to work out it's height, - // then we don't put the height css in, as we want cell to fit height in that case. - if (!this.autoHeightCell) { - cssClasses.push('ag-cell-auto-height'); - } - var doingFocusCss = !this.beans.gridOptionsWrapper.isSuppressCellSelection(); - if (doingFocusCss && this.cellFocused) { - // otherwise the class depends on the focus state - cssClasses.push('ag-cell-focus'); - } - if (this.firstRightPinned) { - cssClasses.push('ag-cell-first-right-pinned'); - } - if (this.lastLeftPinned) { - cssClasses.push('ag-cell-last-left-pinned'); - } - if (this.beans.columnHoverService.isHovered(this.column)) { - cssClasses.push('ag-column-hover'); - } - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].pushAll(cssClasses, this.preProcessClassesFromColDef()); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].pushAll(cssClasses, this.preProcessCellClassRules()); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].pushAll(cssClasses, this.getInitialRangeClasses()); - // if using the wrapper, this class goes on the wrapper instead - if (!this.usingWrapper) { - cssClasses.push('ag-cell-value'); + HeaderRowContainerCtrl.prototype.setupPinnedWidth = function () { + var _this = this; + if (this.pinned == null) { + return; } - return cssClasses; - }; - CellComp.prototype.getInitialValueToRender = function () { - // if using a cellRenderer, then render the html from the cell renderer if it exists - if (this.usingCellRenderer) { - if (typeof this.cellRendererGui === 'string') { - return this.cellRendererGui; + var pinningLeft = this.pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_LEFT; + var pinningRight = this.pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_RIGHT; + var listener = function () { + var width = pinningLeft ? _this.pinnedWidthService.getPinnedLeftWidth() : _this.pinnedWidthService.getPinnedRightWidth(); + if (width == null) { + return; + } // can happen at initialisation, width not yet set + var hidden = width == 0; + var isRtl = _this.gridOptionsWrapper.isEnableRtl(); + var scrollbarWidth = _this.gridOptionsWrapper.getScrollbarWidth(); + // if there is a scroll showing (and taking up space, so Windows, and not iOS) + // in the body, then we add extra space to keep header aligned with the body, + // as body width fits the cols and the scrollbar + var addPaddingForScrollbar = _this.scrollVisibleService.isVerticalScrollShowing() && ((isRtl && pinningLeft) || (!isRtl && pinningRight)); + var widthWithPadding = addPaddingForScrollbar ? width + scrollbarWidth : width; + _this.comp.setPinnedContainerWidth(widthWithPadding + 'px'); + _this.comp.addOrRemoveCssClass('ag-hidden', hidden); + }; + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_LEFT_PINNED_WIDTH_CHANGED, listener); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_RIGHT_PINNED_WIDTH_CHANGED, listener); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_SCROLL_VISIBILITY_CHANGED, listener); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_SCROLLBAR_WIDTH_CHANGED, listener); + }; + HeaderRowContainerCtrl.prototype.getHeaderCtrlForColumn = function (column) { + if (column instanceof _entities_column__WEBPACK_IMPORTED_MODULE_3__["Column"]) { + if (!this.columnsRowCtrl) { + return; } - return ''; - } - var colDef = this.getComponentHolder(); - if (colDef.template) { - // template is really only used for angular 1 - as people using ng1 are used to providing templates with - // bindings in it. in ng2, people will hopefully want to provide components, not templates. - return colDef.template; + return this.columnsRowCtrl.getHeaderCellCtrl(column); } - if (colDef.templateUrl) { - // likewise for templateUrl - it's for ng1 really - when we move away from ng1, we can take these out. - // niall was pro angular 1 when writing template and templateUrl, if writing from scratch now, would - // not do these, but would follow a pattern that was friendly towards components, not templates. - var template = this.beans.templateService.getTemplate(colDef.templateUrl, this.refreshCell.bind(this, true)); - return template || ''; - } - return this.getValueToUse(); - }; - CellComp.prototype.getRenderedRow = function () { - return this.rowComp; - }; - CellComp.prototype.isSuppressNavigable = function () { - return this.column.isSuppressNavigable(this.rowNode); - }; - CellComp.prototype.getCellRenderer = function () { - return this.cellRenderer; - }; - CellComp.prototype.getCellEditor = function () { - return this.cellEditor; - }; - // + stop editing {forceRefresh: true, suppressFlash: true} - // + event cellChanged {} - // + cellRenderer.params.refresh() {} -> method passes 'as is' to the cellRenderer, so params could be anything - // + rowComp: event dataChanged {animate: update, newData: !update} - // + rowComp: api refreshCells() {animate: true/false} - // + rowRenderer: api softRefreshView() {} - CellComp.prototype.refreshCell = function (params) { - // if we are in the middle of 'stopEditing', then we don't refresh here, as refresh gets called explicitly - if (this.suppressRefreshCell || this.editingCell) { + if (this.groupsRowCtrls.length === 0) { return; } - var colDef = this.getComponentHolder(); - var newData = params && params.newData; - var suppressFlash = (params && params.suppressFlash) || colDef.suppressCellFlash; - var forceRefresh = params && params.forceRefresh; - var oldValue = this.value; - // get latest value without invoking the value formatter as we may not be updating the cell - this.value = this.getValue(); - // for simple values only (not objects), see if the value is the same, and if it is, skip the refresh. - // when never allow skipping after an edit, as after editing, we need to put the GUI back to the way - // if was before the edit. - var valuesDifferent = !this.valuesAreEqual(oldValue, this.value); - var dataNeedsUpdating = forceRefresh || valuesDifferent; - if (dataNeedsUpdating) { - // now invoke the value formatter as we are going to update cell - this.valueFormatted = this.beans.valueFormatterService.formatValue(this.column, this.rowNode, this.scope, this.value); - // if it's 'new data', then we don't refresh the cellRenderer, even if refresh method is available. - // this is because if the whole data is new (ie we are showing stock price 'BBA' now and not 'SSD') - // then we are not showing a movement in the stock price, rather we are showing different stock. - var cellRendererRefreshed = newData ? false : this.attemptCellRendererRefresh(); - // we do the replace if not doing refresh, or if refresh was unsuccessful. - // the refresh can be unsuccessful if we are using a framework (eg ng2 or react) and the framework - // wrapper has the refresh method, but the underlying component doesn't - if (!cellRendererRefreshed) { - this.replaceContentsAfterRefresh(); - } - // we don't want to flash the cells when processing a filter change, as otherwise the UI would - // be to busy. see comment in FilterManager with regards processingFilterChange - var processingFilterChange = this.beans.filterManager.isSuppressFlashingCellsBecauseFiltering(); - var flashCell = !suppressFlash && !processingFilterChange && - (this.beans.gridOptionsWrapper.isEnableCellChangeFlash() || colDef.enableCellChangeFlash); - if (flashCell) { - this.flashCell(); + for (var i = 0; i < this.groupsRowCtrls.length; i++) { + var ctrl = this.groupsRowCtrls[i].getHeaderCellCtrl(column); + if (ctrl) { + return ctrl; } - // need to check rules. note, we ignore colDef classes and styles, these are assumed to be static - this.postProcessStylesFromColDef(); - this.postProcessClassesFromColDef(); } - // we can't readily determine if the data in an angularjs template has changed, so here we just update - // and recompile (if applicable) - this.updateAngular1ScopeAndCompile(); - this.refreshToolTip(); - // we do cellClassRules even if the value has not changed, so that users who have rules that - // look at other parts of the row (where the other part of the row might of changed) will work. - this.postProcessCellClassRules(); - }; - // user can also call this via API - CellComp.prototype.flashCell = function (delays) { - var flashDelay = delays && delays.flashDelay; - var fadeDelay = delays && delays.fadeDelay; - this.animateCell('data-changed', flashDelay, fadeDelay); }; - CellComp.prototype.animateCell = function (cssName, flashDelay, fadeDelay) { - var fullName = "ag-cell-" + cssName; - var animationFullName = "ag-cell-" + cssName + "-animation"; - var element = this.getGui(); - var gridOptionsWrapper = this.beans.gridOptionsWrapper; - if (!flashDelay) { - flashDelay = gridOptionsWrapper.getCellFlashDelay(); - } - if (!fadeDelay) { - fadeDelay = gridOptionsWrapper.getCellFadeDelay(); + HeaderRowContainerCtrl.prototype.getHtmlElementForColumnHeader = function (column) { + /* tslint:enable */ + var cellCtrl = this.getHeaderCtrlForColumn(column); + if (!cellCtrl) { + return null; } - // we want to highlight the cells, without any animation - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(element, fullName); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(element, animationFullName); - // then once that is applied, we remove the highlight with animation - window.setTimeout(function () { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(element, fullName); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(element, animationFullName); - element.style.transition = "background-color " + fadeDelay + "ms"; - window.setTimeout(function () { - // and then to leave things as we got them, we remove the animation - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(element, animationFullName); - element.style.transition = null; - }, fadeDelay); - }, flashDelay); + return cellCtrl.getGui(); }; - CellComp.prototype.replaceContentsAfterRefresh = function () { - // otherwise we rip out the cell and replace it - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].clearElement(this.eParentOfValue); - // remove old renderer component if it exists - this.cellRenderer = this.beans.context.destroyBean(this.cellRenderer); - this.cellRendererGui = null; - // populate - this.putDataIntoCellAfterRefresh(); - this.updateAngular1ScopeAndCompile(); + HeaderRowContainerCtrl.prototype.getRowType = function (rowIndex) { + var allCtrls = this.getAllCtrls(); + var ctrl = allCtrls[rowIndex]; + return ctrl ? ctrl.getType() : undefined; }; - CellComp.prototype.updateAngular1ScopeAndCompile = function () { - if (this.beans.gridOptionsWrapper.isAngularCompileRows() && this.scope) { - this.scope.data = __assign({}, this.rowNode.data); - this.angular1Compile(); - } - }; - CellComp.prototype.angular1Compile = function () { - // if angular compiling, then need to also compile the cell again (angular compiling sucks, please wait...) - if (this.beans.gridOptionsWrapper.isAngularCompileRows()) { - var eGui = this.getGui(); - // only compile the node if it hasn't already been done - // this prevents "orphaned" node leaks - if (!eGui.classList.contains('ng-scope') || eGui.childElementCount === 0) { - var compiledElement_1 = this.beans.$compile(eGui)(this.scope); - this.addDestroyFunc(function () { return compiledElement_1.remove(); }); - } - } - }; - CellComp.prototype.postProcessStylesFromColDef = function () { - var stylesToUse = this.processStylesFromColDef(); - if (stylesToUse) { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addStylesToElement(this.getGui(), stylesToUse); - } - }; - CellComp.prototype.preProcessStylesFromColDef = function () { - return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].cssStyleObjectToMarkup(this.processStylesFromColDef()); - }; - CellComp.prototype.processStylesFromColDef = function () { - var colDef = this.getComponentHolder(); - if (colDef.cellStyle) { - var cssToUse = void 0; - if (typeof colDef.cellStyle === 'function') { - var cellStyleParams = { - value: this.value, - data: this.rowNode.data, - node: this.rowNode, - colDef: colDef, - column: this.column, - $scope: this.scope, - context: this.beans.gridOptionsWrapper.getContext(), - api: this.beans.gridOptionsWrapper.getApi() - }; - var cellStyleFunc = colDef.cellStyle; - cssToUse = cellStyleFunc(cellStyleParams); - } - else { - cssToUse = colDef.cellStyle; - } - return cssToUse; + HeaderRowContainerCtrl.prototype.focusHeader = function (rowIndex, column, event) { + var allCtrls = this.getAllCtrls(); + var ctrl = allCtrls[rowIndex]; + if (!ctrl) { + return false; } + return ctrl.focusHeader(column, event); }; - CellComp.prototype.postProcessClassesFromColDef = function () { - var _this = this; - this.processClassesFromColDef(function (className) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(_this.getGui(), className); }); - }; - CellComp.prototype.preProcessClassesFromColDef = function () { - var res = []; - this.processClassesFromColDef(function (className) { return res.push(className); }); - return res; - }; - CellComp.prototype.processClassesFromColDef = function (onApplicableClass) { - var colDef = this.getComponentHolder(); - this.beans.stylingService.processStaticCellClasses(colDef, { - value: this.value, - data: this.rowNode.data, - node: this.rowNode, - colDef: colDef, - rowIndex: this.rowNode.rowIndex, - $scope: this.scope, - api: this.beans.gridOptionsWrapper.getApi(), - columnApi: this.beans.gridOptionsWrapper.getColumnApi(), - context: this.beans.gridOptionsWrapper.getContext() - }, onApplicableClass); + HeaderRowContainerCtrl.prototype.getRowCount = function () { + return this.getAllCtrls().length; }; - CellComp.prototype.putDataIntoCellAfterRefresh = function () { - // template gets preference, then cellRenderer, then do it ourselves - var colDef = this.getComponentHolder(); - if (colDef.template) { - // template is really only used for angular 1 - as people using ng1 are used to providing templates with - // bindings in it. in ng2, people will hopefully want to provide components, not templates. - this.eParentOfValue.innerHTML = colDef.template; - } - else if (colDef.templateUrl) { - // likewise for templateUrl - it's for ng1 really - when we move away from ng1, we can take these out. - // niall was pro angular 1 when writing template and templateUrl, if writing from scratch now, would - // not do these, but would follow a pattern that was friendly towards components, not templates. - var template = this.beans.templateService.getTemplate(colDef.templateUrl, this.refreshCell.bind(this, true)); - if (template) { - this.eParentOfValue.innerHTML = template; - } - } - else { - // we can switch from using a cell renderer back to the default if a user - // is using cellRendererSelect - this.chooseCellRenderer(); - if (this.usingCellRenderer) { - this.createCellRendererInstance(); - } - else { - var valueToUse = this.getValueToUse(); - if (valueToUse != null) { - this.eParentOfValue.innerHTML = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(valueToUse); - } - } - } + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('ctrlsService') + ], HeaderRowContainerCtrl.prototype, "ctrlsService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('scrollVisibleService') + ], HeaderRowContainerCtrl.prototype, "scrollVisibleService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('pinnedWidthService') + ], HeaderRowContainerCtrl.prototype, "pinnedWidthService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnModel') + ], HeaderRowContainerCtrl.prototype, "columnModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('focusService') + ], HeaderRowContainerCtrl.prototype, "focusService", void 0); + return HeaderRowContainerCtrl; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + + + +/***/ }), +/* 143 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BodyDropTarget", function() { return BodyDropTarget; }); +/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(97); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _moveColumnFeature__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(144); +/* harmony import */ var _bodyDropPivotTarget__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(145); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(15); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(20); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - CellComp.prototype.attemptCellRendererRefresh = function () { - if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(this.cellRenderer) || !this.cellRenderer || _utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(this.cellRenderer.refresh)) { - return false; - } - // if the cell renderer has a refresh method, we call this instead of doing a refresh - var params = this.createCellRendererParams(); - // take any custom params off of the user - var finalParams = this.beans.userComponentFactory.createFinalParams(this.getComponentHolder(), this.cellRendererType, params); - var result = this.cellRenderer.refresh(finalParams); - // NOTE on undefined: previous version of the cellRenderer.refresh() interface - // returned nothing, if the method existed, we assumed it refreshed. so for - // backwards compatibility, we assume if method exists and returns nothing, - // that it was successful. - return result === true || result === undefined; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - CellComp.prototype.refreshToolTip = function () { - var newTooltip = this.getToolTip(); - if (this.tooltip === newTooltip) { - return; - } - var hasNewTooltip = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(newTooltip); - if (hasNewTooltip && this.tooltip === newTooltip.toString()) { - return; - } - var hadTooltip = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(this.tooltip); - this.tooltip = newTooltip; - if (this.beans.gridOptionsWrapper.isEnableBrowserTooltips()) { - if (hasNewTooltip) { - this.eParentOfValue.setAttribute('title', this.tooltip); - } - else { - this.eParentOfValue.removeAttribute('title'); +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + +var BodyDropTarget = /** @class */ (function (_super) { + __extends(BodyDropTarget, _super); + function BodyDropTarget(pinned, eContainer) { + var _this = _super.call(this) || this; + _this.pinned = pinned; + _this.eContainer = eContainer; + return _this; + } + BodyDropTarget.prototype.postConstruct = function () { + var _this = this; + this.ctrlsService.whenReady(function (p) { + switch (_this.pinned) { + case _constants_constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_LEFT: + _this.eSecondaryContainers = [ + [p.gridBodyCtrl.getBodyViewportElement(), p.leftRowContainerCtrl.getContainerElement()], + [p.bottomLeftRowContainerCtrl.getContainerElement()], + [p.topLeftRowContainerCtrl.getContainerElement()] + ]; + break; + case _constants_constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_RIGHT: + _this.eSecondaryContainers = [ + [p.gridBodyCtrl.getBodyViewportElement(), p.rightRowContainerCtrl.getContainerElement()], + [p.bottomRightRowContainerCtrl.getContainerElement()], + [p.topRightRowContainerCtrl.getContainerElement()] + ]; + break; + default: + _this.eSecondaryContainers = [ + [p.gridBodyCtrl.getBodyViewportElement(), p.centerRowContainerCtrl.getViewportElement()], + [p.bottomCenterRowContainerCtrl.getViewportElement()], + [p.topCenterRowContainerCtrl.getViewportElement()] + ]; + break; } - } - }; - CellComp.prototype.valuesAreEqual = function (val1, val2) { - // if the user provided an equals method, use that, otherwise do simple comparison - var colDef = this.getComponentHolder(); - var equalsMethod = colDef ? colDef.equals : null; - return equalsMethod ? equalsMethod(val1, val2) : val1 === val2; - }; - CellComp.prototype.getToolTip = function () { - var colDef = this.getComponentHolder(); - var data = this.rowNode.data; - if (colDef.tooltipField && _utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(data)) { - return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].getValueUsingField(data, colDef.tooltipField, this.column.isTooltipFieldContainsDots()); - } - var valueGetter = colDef.tooltipValueGetter || colDef.tooltip; - if (valueGetter) { - return valueGetter({ - api: this.beans.gridOptionsWrapper.getApi(), - columnApi: this.beans.gridOptionsWrapper.getColumnApi(), - colDef: colDef, - column: this.getColumn(), - context: this.beans.gridOptionsWrapper.getContext(), - value: this.value, - valueFormatted: this.valueFormatted, - rowIndex: this.cellPosition.rowIndex, - node: this.rowNode, - data: this.rowNode.data - }); - } - return null; + }); }; - CellComp.prototype.getTooltipText = function (escape) { - if (escape === void 0) { escape = true; } - return escape ? _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(this.tooltip) : this.tooltip; + BodyDropTarget.prototype.isInterestedIn = function (type) { + return type === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragSourceType"].HeaderCell || + (type === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragSourceType"].ToolPanel && this.gridOptionsWrapper.isAllowDragFromColumnsToolPanel()); }; - CellComp.prototype.processCellClassRules = function (onApplicableClass, onNotApplicableClass) { - var colDef = this.getComponentHolder(); - this.beans.stylingService.processClassRules(colDef.cellClassRules, { - value: this.value, - data: this.rowNode.data, - node: this.rowNode, - colDef: colDef, - rowIndex: this.cellPosition.rowIndex, - api: this.beans.gridOptionsWrapper.getApi(), - columnApi: this.beans.gridOptionsWrapper.getColumnApi(), - $scope: this.scope, - context: this.beans.gridOptionsWrapper.getContext() - }, onApplicableClass, onNotApplicableClass); + BodyDropTarget.prototype.getSecondaryContainers = function () { + return this.eSecondaryContainers; }; - CellComp.prototype.postProcessCellClassRules = function () { - var _this = this; - this.processCellClassRules(function (className) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(_this.getGui(), className); }, function (className) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(_this.getGui(), className); }); + BodyDropTarget.prototype.getContainer = function () { + return this.eContainer; }; - CellComp.prototype.preProcessCellClassRules = function () { - var res = []; - this.processCellClassRules(function (className) { return res.push(className); }, function (_) { - // not catered for, if creating, no need - // to remove class as it was never there - }); - return res; + BodyDropTarget.prototype.init = function () { + this.moveColumnFeature = this.createManagedBean(new _moveColumnFeature__WEBPACK_IMPORTED_MODULE_2__["MoveColumnFeature"](this.pinned, this.eContainer)); + this.bodyDropPivotTarget = this.createManagedBean(new _bodyDropPivotTarget__WEBPACK_IMPORTED_MODULE_3__["BodyDropPivotTarget"](this.pinned)); + this.dragAndDropService.addDropTarget(this); }; - // a wrapper is used when we are putting a selection checkbox in the cell with the value - CellComp.prototype.setUsingWrapper = function () { - var colDef = this.getComponentHolder(); - // never allow selection or dragging on pinned rows - if (this.rowNode.rowPinned) { - this.usingWrapper = false; - this.includeSelectionComponent = false; - this.includeRowDraggingComponent = false; - this.includeDndSourceComponent = false; - return; - } - var cbSelectionIsFunc = typeof colDef.checkboxSelection === 'function'; - var rowDraggableIsFunc = typeof colDef.rowDrag === 'function'; - var dndSourceIsFunc = typeof colDef.dndSource === 'function'; - this.includeSelectionComponent = cbSelectionIsFunc || colDef.checkboxSelection === true; - this.includeRowDraggingComponent = rowDraggableIsFunc || colDef.rowDrag === true; - this.includeDndSourceComponent = dndSourceIsFunc || colDef.dndSource === true; - var enableTextSelection = this.beans.gridOptionsWrapper.isEnableCellTextSelection(); - this.usingWrapper = enableTextSelection || this.includeRowDraggingComponent || this.includeSelectionComponent || this.includeDndSourceComponent; - }; - CellComp.prototype.chooseCellRenderer = function () { - // template gets preference, then cellRenderer, then do it ourselves - var colDef = this.getComponentHolder(); - // templates are for ng1, ideally we wouldn't have these, they are ng1 support - // inside the core which is bad - if (colDef.template || colDef.templateUrl) { - this.usingCellRenderer = false; - return; - } - var params = this.createCellRendererParams(); - var cellRenderer = this.beans.userComponentFactory.lookupComponentClassDef(colDef, 'cellRenderer', params); - var pinnedRowCellRenderer = this.beans.userComponentFactory.lookupComponentClassDef(colDef, 'pinnedRowCellRenderer', params); - if (pinnedRowCellRenderer && this.rowNode.rowPinned) { - this.cellRendererType = CellComp.CELL_RENDERER_TYPE_PINNED; - this.usingCellRenderer = true; - } - else if (cellRenderer) { - this.cellRendererType = CellComp.CELL_RENDERER_TYPE_NORMAL; - this.usingCellRenderer = true; - } - else { - this.usingCellRenderer = false; - } + BodyDropTarget.prototype.getIconName = function () { + return this.currentDropListener.getIconName(); }; - CellComp.prototype.createCellRendererInstance = function (useTaskService) { - var _this = this; - if (useTaskService === void 0) { useTaskService = false; } - if (!this.usingCellRenderer) { - return; - } - // never use task service if angularCompileRows=true, as that assume the cell renderers - // are finished when the row is created. also we never use it if animation frame service - // is turned off. - // and lastly we never use it if doing auto-height, as the auto-height service checks the - // row height directly after the cell is created, it doesn't wait around for the tasks to complete - var angularCompileRows = this.beans.gridOptionsWrapper.isAngularCompileRows(); - var suppressAnimationFrame = this.beans.gridOptionsWrapper.isSuppressAnimationFrame(); - if (angularCompileRows || suppressAnimationFrame || this.autoHeightCell) { - useTaskService = false; - } - var params = this.createCellRendererParams(); - this.cellRendererVersion++; - var callback = this.afterCellRendererCreated.bind(this, this.cellRendererVersion); - var cellRendererTypeNormal = this.cellRendererType === CellComp.CELL_RENDERER_TYPE_NORMAL; - this.createCellRendererFunc = function () { - _this.createCellRendererFunc = null; - // this can return null in the event that the user has switched from a renderer component to nothing, for example - // when using a cellRendererSelect to return a component or null depending on row data etc - var componentPromise = _this.beans.userComponentFactory.newCellRenderer(_this.getComponentHolder(), params, !cellRendererTypeNormal); - if (componentPromise) { - componentPromise.then(callback); - } - }; - if (useTaskService) { - this.beans.taskQueue.createTask(this.createCellRendererFunc, this.rowNode.rowIndex, 'createTasksP2'); - } - else { - this.createCellRendererFunc(); - } + // we want to use the bodyPivotTarget if the user is dragging columns in from the toolPanel + // and we are in pivot mode, as it has to logic to set pivot/value/group on the columns when + // dropped into the grid's body. + BodyDropTarget.prototype.isDropColumnInPivotMode = function (draggingEvent) { + // in pivot mode, then if moving a column (ie didn't come from toolpanel) then it's + // a standard column move, however if it came from the toolpanel, then we are introducing + // dimensions or values to the grid + return this.columnModel.isPivotMode() && draggingEvent.dragSource.type === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragSourceType"].ToolPanel; }; - CellComp.prototype.afterCellRendererCreated = function (cellRendererVersion, cellRenderer) { - var cellRendererNotRequired = !this.isAlive() || (cellRendererVersion !== this.cellRendererVersion); - if (cellRendererNotRequired) { - this.beans.context.destroyBean(cellRenderer); - return; - } - this.cellRenderer = cellRenderer; - this.cellRendererGui = this.cellRenderer.getGui(); - if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(this.cellRendererGui)) { - return; - } - // if async components, then it's possible the user started editing since this call was made - if (!this.editingCell) { - this.eParentOfValue.appendChild(this.cellRendererGui); - } + BodyDropTarget.prototype.onDragEnter = function (draggingEvent) { + // we pick the drop listener depending on whether we are in pivot mode are not. if we are + // in pivot mode, then dropping cols changes the row group, pivot, value stats. otherwise + // we change visibility state and position. + this.currentDropListener = this.isDropColumnInPivotMode(draggingEvent) ? this.bodyDropPivotTarget : this.moveColumnFeature; + this.currentDropListener.onDragEnter(draggingEvent); }; - CellComp.prototype.createCellRendererParams = function () { - var _this = this; - return { - value: this.value, - valueFormatted: this.valueFormatted, - getValue: this.getValue.bind(this), - setValue: function (value) { return _this.beans.valueService.setValue(_this.rowNode, _this.column, value); }, - formatValue: this.formatValue.bind(this), - data: this.rowNode.data, - node: this.rowNode, - colDef: this.getComponentHolder(), - column: this.column, - $scope: this.scope, - rowIndex: this.cellPosition.rowIndex, - api: this.beans.gridOptionsWrapper.getApi(), - columnApi: this.beans.gridOptionsWrapper.getColumnApi(), - context: this.beans.gridOptionsWrapper.getContext(), - refreshCell: this.refreshCell.bind(this), - eGridCell: this.getGui(), - eParentOfValue: this.eParentOfValue, - // these bits are not documented anywhere, so we could drop them? - // it was in the olden days to allow user to register for when rendered - // row was removed (the row comp was removed), however now that the user - // can provide components for cells, the destroy method gets call when this - // happens so no longer need to fire event. - addRowCompListener: this.rowComp ? this.rowComp.addEventListener.bind(this.rowComp) : null, - addRenderedRowListener: function (eventType, listener) { - console.warn('ag-Grid: since ag-Grid .v11, params.addRenderedRowListener() is now params.addRowCompListener()'); - if (_this.rowComp) { - _this.rowComp.addEventListener(eventType, listener); - } - } - }; + BodyDropTarget.prototype.onDragLeave = function (params) { + this.currentDropListener.onDragLeave(params); }; - CellComp.prototype.formatValue = function (value) { - var valueFormatted = this.beans.valueFormatterService.formatValue(this.column, this.rowNode, this.scope, value); - return valueFormatted != null ? valueFormatted : value; + BodyDropTarget.prototype.onDragging = function (params) { + this.currentDropListener.onDragging(params); }; - CellComp.prototype.getValueToUse = function () { - return this.valueFormatted != null ? this.valueFormatted : this.value; + BodyDropTarget.prototype.onDragStop = function (params) { + this.currentDropListener.onDragStop(params); }; - CellComp.prototype.getValueAndFormat = function () { - this.value = this.getValue(); - this.valueFormatted = this.beans.valueFormatterService.formatValue(this.column, this.rowNode, this.scope, this.value); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('dragAndDropService') + ], BodyDropTarget.prototype, "dragAndDropService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnModel') + ], BodyDropTarget.prototype, "columnModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('ctrlsService') + ], BodyDropTarget.prototype, "ctrlsService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], BodyDropTarget.prototype, "postConstruct", null); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], BodyDropTarget.prototype, "init", null); + return BodyDropTarget; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_5__["BeanStub"])); + + + +/***/ }), +/* 144 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MoveColumnFeature", function() { return MoveColumnFeature; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(15); +/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(97); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(18); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + +var MoveColumnFeature = /** @class */ (function () { + function MoveColumnFeature(pinned, eContainer) { + this.needToMoveLeft = false; + this.needToMoveRight = false; + this.pinned = pinned; + this.eContainer = eContainer; + this.centerContainer = !Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["exists"])(pinned); + } + MoveColumnFeature.prototype.init = function () { + var _this = this; + this.ctrlsService.whenReady(function () { + _this.gridBodyCon = _this.ctrlsService.getGridBodyCtrl(); + }); }; - CellComp.prototype.getValue = function () { - // if we don't check this, then the grid will render leaf groups as open even if we are not - // allowing the user to open leaf groups. confused? remember for pivot mode we don't allow - // opening leaf groups, so we have to force leafGroups to be closed in case the user expanded - // them via the API, or user user expanded them in the UI before turning on pivot mode - var lockedClosedGroup = this.rowNode.leafGroup && this.beans.columnController.isPivotMode(); - var isOpenGroup = this.rowNode.group && this.rowNode.expanded && !this.rowNode.footer && !lockedClosedGroup; - // are we showing group footers - var groupFootersEnabled = this.beans.gridOptionsWrapper.isGroupIncludeFooter(); - // if doing footers, we normally don't show agg data at group level when group is open - var groupAlwaysShowAggData = this.beans.gridOptionsWrapper.isGroupSuppressBlankHeader(); - // if doing grouping and footers, we don't want to include the agg value - // in the header when the group is open - var ignoreAggData = (isOpenGroup && groupFootersEnabled) && !groupAlwaysShowAggData; - return this.beans.valueService.getValue(this.column, this.rowNode, false, ignoreAggData); + MoveColumnFeature.prototype.getIconName = function () { + return this.pinned ? _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_PINNED : _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_MOVE; }; - CellComp.prototype.onMouseEvent = function (eventName, mouseEvent) { - if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].isStopPropagationForAgGrid(mouseEvent)) { - return; + MoveColumnFeature.prototype.onDragEnter = function (draggingEvent) { + // we do dummy drag, so make sure column appears in the right location when first placed + var columns = draggingEvent.dragItem.columns; + var dragCameFromToolPanel = draggingEvent.dragSource.type === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragSourceType"].ToolPanel; + if (dragCameFromToolPanel) { + // the if statement doesn't work if drag leaves grid, then enters again + this.setColumnsVisible(columns, true, "uiColumnDragged"); } - switch (eventName) { - case 'click': - this.onCellClicked(mouseEvent); - break; - case 'mousedown': - this.onMouseDown(mouseEvent); - break; - case 'dblclick': - this.onCellDoubleClicked(mouseEvent); - break; - case 'mouseout': - this.onMouseOut(mouseEvent); - break; - case 'mouseover': - this.onMouseOver(mouseEvent); - break; + else { + // restore previous state of visible columns upon re-entering. this means if the user drags + // a group out, and then drags the group back in, only columns that were originally visible + // will be visible again. otherwise a group with three columns (but only two visible) could + // be dragged out, then when it's dragged in again, all three are visible. this stops that. + var visibleState_1 = draggingEvent.dragItem.visibleState; + var visibleColumns = (columns || []).filter(function (column) { return visibleState_1[column.getId()]; }); + this.setColumnsVisible(visibleColumns, true, "uiColumnDragged"); } + this.setColumnsPinned(columns, this.pinned, "uiColumnDragged"); + this.onDragging(draggingEvent, true); }; - CellComp.prototype.dispatchCellContextMenuEvent = function (event) { - var colDef = this.getComponentHolder(); - var cellContextMenuEvent = this.createEvent(event, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_CONTEXT_MENU); - this.beans.eventService.dispatchEvent(cellContextMenuEvent); - if (colDef.onCellContextMenu) { - // to make the callback async, do in a timeout - window.setTimeout(function () { return colDef.onCellContextMenu(cellContextMenuEvent); }, 0); + MoveColumnFeature.prototype.onDragLeave = function (draggingEvent) { + var hideColumnOnExit = !this.gridOptionsWrapper.isSuppressDragLeaveHidesColumns() && !draggingEvent.fromNudge; + if (hideColumnOnExit) { + var dragItem = draggingEvent.dragSource.getDragItem(); + var columns = dragItem.columns; + this.setColumnsVisible(columns, false, "uiColumnDragged"); } + this.ensureIntervalCleared(); }; - CellComp.prototype.createEvent = function (domEvent, eventType) { - var event = { - node: this.rowNode, - data: this.rowNode.data, - value: this.value, - column: this.column, - colDef: this.getComponentHolder(), - context: this.beans.gridOptionsWrapper.getContext(), - api: this.beans.gridApi, - columnApi: this.beans.columnApi, - rowPinned: this.rowNode.rowPinned, - event: domEvent, - type: eventType, - rowIndex: this.rowNode.rowIndex - }; - // because we are hacking in $scope for angular 1, we have to de-reference - if (this.scope) { - event.$scope = this.scope; + MoveColumnFeature.prototype.setColumnsVisible = function (columns, visible, source) { + if (source === void 0) { source = "api"; } + if (columns) { + var allowedCols = columns.filter(function (c) { return !c.getColDef().lockVisible; }); + this.columnModel.setColumnsVisible(allowedCols, visible, source); } - return event; }; - CellComp.prototype.onMouseOut = function (mouseEvent) { - var cellMouseOutEvent = this.createEvent(mouseEvent, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_MOUSE_OUT); - this.beans.eventService.dispatchEvent(cellMouseOutEvent); - this.beans.columnHoverService.clearMouseOver(); + MoveColumnFeature.prototype.setColumnsPinned = function (columns, pinned, source) { + if (source === void 0) { source = "api"; } + if (columns) { + var allowedCols = columns.filter(function (c) { return !c.getColDef().lockPinned; }); + this.columnModel.setColumnsPinned(allowedCols, pinned, source); + } }; - CellComp.prototype.onMouseOver = function (mouseEvent) { - var cellMouseOverEvent = this.createEvent(mouseEvent, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_MOUSE_OVER); - this.beans.eventService.dispatchEvent(cellMouseOverEvent); - this.beans.columnHoverService.setMouseOver([this.column]); + MoveColumnFeature.prototype.onDragStop = function () { + this.ensureIntervalCleared(); }; - CellComp.prototype.onCellDoubleClicked = function (mouseEvent) { - var colDef = this.getComponentHolder(); - // always dispatch event to eventService - var cellDoubleClickedEvent = this.createEvent(mouseEvent, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_DOUBLE_CLICKED); - this.beans.eventService.dispatchEvent(cellDoubleClickedEvent); - // check if colDef also wants to handle event - if (typeof colDef.onCellDoubleClicked === 'function') { - // to make the callback async, do in a timeout - window.setTimeout(function () { return colDef.onCellDoubleClicked(cellDoubleClickedEvent); }, 0); + MoveColumnFeature.prototype.normaliseX = function (x) { + // flip the coordinate if doing RTL + if (this.gridOptionsWrapper.isEnableRtl()) { + var clientWidth = this.eContainer.clientWidth; + x = clientWidth - x; } - var editOnDoubleClick = !this.beans.gridOptionsWrapper.isSingleClickEdit() - && !this.beans.gridOptionsWrapper.isSuppressClickEdit(); - if (editOnDoubleClick) { - this.startRowOrCellEdit(); + // adjust for scroll only if centre container (the pinned containers don't scroll) + if (this.centerContainer) { + x += this.ctrlsService.getCenterRowContainerCtrl().getCenterViewportScrollLeft(); } + return x; }; - // called by rowRenderer when user navigates via tab key - CellComp.prototype.startRowOrCellEdit = function (keyPress, charPress) { - if (this.beans.gridOptionsWrapper.isFullRowEdit()) { - this.rowComp.startRowEditing(keyPress, charPress, this); - } - else { - this.startEditingIfEnabled(keyPress, charPress, true); + MoveColumnFeature.prototype.checkCenterForScrolling = function (xAdjustedForScroll) { + if (this.centerContainer) { + // scroll if the mouse has gone outside the grid (or just outside the scrollable part if pinning) + // putting in 50 buffer, so even if user gets to edge of grid, a scroll will happen + var firstVisiblePixel = this.ctrlsService.getCenterRowContainerCtrl().getCenterViewportScrollLeft(); + var lastVisiblePixel = firstVisiblePixel + this.ctrlsService.getCenterRowContainerCtrl().getCenterWidth(); + if (this.gridOptionsWrapper.isEnableRtl()) { + this.needToMoveRight = xAdjustedForScroll < (firstVisiblePixel + 50); + this.needToMoveLeft = xAdjustedForScroll > (lastVisiblePixel - 50); + } + else { + this.needToMoveLeft = xAdjustedForScroll < (firstVisiblePixel + 50); + this.needToMoveRight = xAdjustedForScroll > (lastVisiblePixel - 50); + } + if (this.needToMoveLeft || this.needToMoveRight) { + this.ensureIntervalStarted(); + } + else { + this.ensureIntervalCleared(); + } } }; - CellComp.prototype.isCellEditable = function () { - return this.column.isCellEditable(this.rowNode); - }; - // either called internally if single cell editing, or called by rowRenderer if row editing - CellComp.prototype.startEditingIfEnabled = function (keyPress, charPress, cellStartedEdit) { - if (keyPress === void 0) { keyPress = null; } - if (charPress === void 0) { charPress = null; } - if (cellStartedEdit === void 0) { cellStartedEdit = false; } - // don't do it if not editable - if (!this.isCellEditable()) { - return; - } - // don't do it if already editing - if (this.editingCell) { + MoveColumnFeature.prototype.onDragging = function (draggingEvent, fromEnter) { + var _this = this; + if (fromEnter === void 0) { fromEnter = false; } + this.lastDraggingEvent = draggingEvent; + // if moving up or down (ie not left or right) then do nothing + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["missing"])(draggingEvent.hDirection)) { return; } - this.editingCell = true; - this.cellEditorVersion++; - var callback = this.afterCellEditorCreated.bind(this, this.cellEditorVersion); - var params = this.createCellEditorParams(keyPress, charPress, cellStartedEdit); - this.createCellEditor(params).then(callback); - // if we don't do this, and editor component is async, then there will be a period - // when the component isn't present and keyboard navigation won't work - so example - // of user hitting tab quickly (more quickly than renderers getting created) won't work - var cellEditorAsync = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(this.cellEditor); - if (cellEditorAsync && cellStartedEdit) { - this.focusCell(true); + var mouseXNormalised = this.normaliseX(draggingEvent.x); + // if the user is dragging into the panel, ie coming from the side panel into the main grid, + // we don't want to scroll the grid this time, it would appear like the table is jumping + // each time a column is dragged in. + if (!fromEnter) { + this.checkCenterForScrolling(mouseXNormalised); } - }; - CellComp.prototype.createCellEditor = function (params) { - var _this = this; - var cellEditorPromise = this.beans.userComponentFactory.newCellEditor(this.column.getColDef(), params); - return cellEditorPromise.then(function (cellEditor) { - var isPopup = cellEditor.isPopup && cellEditor.isPopup(); - if (!isPopup) { - return cellEditor; - } - if (_this.beans.gridOptionsWrapper.isFullRowEdit()) { - console.warn('ag-Grid: popup cellEditor does not work with fullRowEdit - you cannot use them both ' + - '- either turn off fullRowEdit, or stop using popup editors.'); + var hDirectionNormalised = this.normaliseDirection(draggingEvent.hDirection); + var dragSourceType = draggingEvent.dragSource.type; + var columnsToMove = draggingEvent.dragSource.getDragItem().columns; + columnsToMove = columnsToMove.filter(function (col) { + if (col.getColDef().lockPinned) { + // if locked return true only if both col and container are same pin type. + // double equals (==) here on purpose so that null==undefined is true (for not pinned options) + return col.getPinned() == _this.pinned; } - // if a popup, then we wrap in a popup editor and return the popup - var popupEditorWrapper = new _cellEditors_popupEditorWrapper__WEBPACK_IMPORTED_MODULE_6__["PopupEditorWrapper"](cellEditor); - _this.beans.context.createBean(popupEditorWrapper); - popupEditorWrapper.init(params); - return popupEditorWrapper; + // if not pin locked, then always allowed to be in this container + return true; }); + this.attemptMoveColumns(dragSourceType, columnsToMove, hDirectionNormalised, mouseXNormalised, fromEnter); }; - CellComp.prototype.afterCellEditorCreated = function (cellEditorVersion, cellEditor) { - // if editingCell=false, means user cancelled the editor before component was ready. - // if versionMismatch, then user cancelled the edit, then started the edit again, and this - // is the first editor which is now stale. - var versionMismatch = cellEditorVersion !== this.cellEditorVersion; - var cellEditorNotNeeded = versionMismatch || !this.editingCell; - if (cellEditorNotNeeded) { - this.beans.context.destroyBean(cellEditor); - return; - } - var editingCancelledByUserComp = cellEditor.isCancelBeforeStart && cellEditor.isCancelBeforeStart(); - if (editingCancelledByUserComp) { - this.beans.context.destroyBean(cellEditor); - this.editingCell = false; - return; - } - if (!cellEditor.getGui) { - console.warn("ag-Grid: cellEditor for column " + this.column.getId() + " is missing getGui() method"); - // no getGui, for React guys, see if they attached a react component directly - if (cellEditor.render) { - console.warn("ag-Grid: we found 'render' on the component, are you trying to set a React renderer but added it as colDef.cellEditor instead of colDef.cellEditorFmk?"); + MoveColumnFeature.prototype.normaliseDirection = function (hDirection) { + if (this.gridOptionsWrapper.isEnableRtl()) { + switch (hDirection) { + case _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Left: return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Right; + case _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Right: return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Left; + default: console.error("AG Grid: Unknown direction " + hDirection); } - this.beans.context.destroyBean(cellEditor); - this.editingCell = false; - return; - } - this.cellEditor = cellEditor; - this.cellEditorInPopup = cellEditor.isPopup !== undefined && cellEditor.isPopup(); - this.setInlineEditingClass(); - if (this.cellEditorInPopup) { - this.addPopupCellEditor(); } else { - this.addInCellEditor(); - } - if (cellEditor.afterGuiAttached) { - cellEditor.afterGuiAttached(); - } - var event = this.createEvent(null, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_EDITING_STARTED); - this.beans.eventService.dispatchEvent(event); - }; - CellComp.prototype.addInCellEditor = function () { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].clearElement(this.getGui()); - if (this.cellEditor) { - this.getGui().appendChild(this.cellEditor.getGui()); + return hDirection; } - this.angular1Compile(); }; - CellComp.prototype.addPopupCellEditor = function () { - var _this = this; - var ePopupGui = this.cellEditor ? this.cellEditor.getGui() : null; - var useModelPopup = this.beans.gridOptionsWrapper.isStopEditingWhenGridLosesFocus(); - this.hideEditorPopup = this.beans.popupService.addPopup(useModelPopup, ePopupGui, true, - // callback for when popup disappears - function () { - _this.onPopupEditorClosed(); - }); - var params = { - column: this.column, - rowNode: this.rowNode, - type: 'popupCellEditor', - eventSource: this.getGui(), - ePopup: ePopupGui, - keepWithinBounds: true - }; - var position = this.cellEditor && this.cellEditor.getPopupPosition ? this.cellEditor.getPopupPosition() : 'over'; - if (position === 'under') { - this.beans.popupService.positionPopupUnderComponent(params); - } - else { - this.beans.popupService.positionPopupOverComponent(params); - } - this.angular1Compile(); - }; - CellComp.prototype.onPopupEditorClosed = function () { - // we only call stopEditing if we are editing, as - // it's possible the popup called 'stop editing' - // before this, eg if 'enter key' was pressed on - // the editor. - if (this.editingCell) { - // note: this only happens when use clicks outside of the grid. if use clicks on another - // cell, then the editing will have already stopped on this cell - this.stopRowOrCellEdit(); - // we only focus cell again if this cell is still focused. it is possible - // it is not focused if the user cancelled the edit by clicking on another - // cell outside of this one - if (this.beans.focusController.isCellFocused(this.cellPosition)) { - this.focusCell(true); - } - } + // returns the index of the first column in the list ONLY if the cols are all beside + // each other. if the cols are not beside each other, then returns null + MoveColumnFeature.prototype.calculateOldIndex = function (movingCols) { + var gridCols = this.columnModel.getAllGridColumns(); + var indexes = Object(_utils_array__WEBPACK_IMPORTED_MODULE_4__["sortNumerically"])(movingCols.map(function (col) { return gridCols.indexOf(col); })); + var firstIndex = indexes[0]; + var lastIndex = Object(_utils_array__WEBPACK_IMPORTED_MODULE_4__["last"])(indexes); + var spread = lastIndex - firstIndex; + var gapsExist = spread !== indexes.length - 1; + return gapsExist ? null : firstIndex; }; - // if we are editing inline, then we don't have the padding in the cell (set in the themes) - // to allow the text editor full access to the entire cell - CellComp.prototype.setInlineEditingClass = function () { - if (!this.isAlive()) { + MoveColumnFeature.prototype.attemptMoveColumns = function (dragSourceType, allMovingColumns, hDirection, mouseX, fromEnter) { + var draggingLeft = hDirection === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Left; + var draggingRight = hDirection === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Right; + // it is important to sort the moving columns as they are in grid columns, as the list of moving columns + // could themselves be part of 'married children' groups, which means we need to maintain the order within + // the moving list. + var allMovingColumnsOrdered = allMovingColumns.slice(); + this.columnModel.sortColumnsLikeGridColumns(allMovingColumnsOrdered); + var validMoves = this.calculateValidMoves(allMovingColumnsOrdered, draggingRight, mouseX); + // if cols are not adjacent, then this returns null. when moving, we constrain the direction of the move + // (ie left or right) to the mouse direction. however + var oldIndex = this.calculateOldIndex(allMovingColumnsOrdered); + if (validMoves.length === 0) { return; } - // ag-cell-inline-editing - appears when user is inline editing - // ag-cell-not-inline-editing - appears when user is no inline editing - // ag-cell-popup-editing - appears when user is editing cell in popup (appears on the cell, not on the popup) - // note: one of {ag-cell-inline-editing, ag-cell-not-inline-editing} is always present, they toggle. - // however {ag-cell-popup-editing} shows when popup, so you have both {ag-cell-popup-editing} - // and {ag-cell-not-inline-editing} showing at the same time. - var editingInline = this.editingCell && !this.cellEditorInPopup; - var popupEditorShowing = this.editingCell && this.cellEditorInPopup; - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), "ag-cell-inline-editing", editingInline); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), "ag-cell-not-inline-editing", !editingInline); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), "ag-cell-popup-editing", popupEditorShowing); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui().parentNode, "ag-row-inline-editing", editingInline); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui().parentNode, "ag-row-not-inline-editing", !editingInline); - }; - CellComp.prototype.createCellEditorParams = function (keyPress, charPress, cellStartedEdit) { - return { - value: this.getValue(), - keyPress: keyPress, - charPress: charPress, - column: this.column, - colDef: this.column.getColDef(), - rowIndex: this.cellPosition.rowIndex, - node: this.rowNode, - data: this.rowNode.data, - api: this.beans.gridOptionsWrapper.getApi(), - cellStartedEdit: cellStartedEdit, - columnApi: this.beans.gridOptionsWrapper.getColumnApi(), - context: this.beans.gridOptionsWrapper.getContext(), - $scope: this.scope, - onKeyDown: this.onKeyDown.bind(this), - stopEditing: this.stopEditingAndFocus.bind(this), - eGridCell: this.getGui(), - parseValue: this.parseValue.bind(this), - formatValue: this.formatValue.bind(this) - }; - }; - // cell editors call this, when they want to stop for reasons other - // than what we pick up on. eg selecting from a dropdown ends editing. - CellComp.prototype.stopEditingAndFocus = function (suppressNavigateAfterEdit) { - if (suppressNavigateAfterEdit === void 0) { suppressNavigateAfterEdit = false; } - this.stopRowOrCellEdit(); - this.focusCell(true); - if (!suppressNavigateAfterEdit) { - this.navigateAfterEdit(); + var firstValidMove = validMoves[0]; + // the two check below stop an error when the user grabs a group my a middle column, then + // it is possible the mouse pointer is to the right of a column while been dragged left. + // so we need to make sure that the mouse pointer is actually left of the left most column + // if moving left, and right of the right most column if moving right + // we check 'fromEnter' below so we move the column to the new spot if the mouse is coming from + // outside the grid, eg if the column is moving from side panel, mouse is moving left, then we should + // place the column to the RHS even if the mouse is moving left and the column is already on + // the LHS. otherwise we stick to the rule described above. + var constrainDirection = oldIndex !== null && !fromEnter; + // don't consider 'fromEnter' when dragging header cells, otherwise group can jump to opposite direction of drag + if (dragSourceType == _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragSourceType"].HeaderCell) { + constrainDirection = oldIndex !== null; } - }; - CellComp.prototype.parseValue = function (newValue) { - var colDef = this.getComponentHolder(); - var params = { - node: this.rowNode, - data: this.rowNode.data, - oldValue: this.value, - newValue: newValue, - colDef: colDef, - column: this.column, - api: this.beans.gridOptionsWrapper.getApi(), - columnApi: this.beans.gridOptionsWrapper.getColumnApi(), - context: this.beans.gridOptionsWrapper.getContext() - }; - var valueParser = colDef.valueParser; - return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(valueParser) ? this.beans.expressionService.evaluate(valueParser, params) : newValue; - }; - CellComp.prototype.focusCell = function (forceBrowserFocus) { - if (forceBrowserFocus === void 0) { forceBrowserFocus = false; } - this.beans.focusController.setFocusedCell(this.cellPosition.rowIndex, this.column, this.rowNode.rowPinned, forceBrowserFocus); - }; - CellComp.prototype.setFocusInOnEditor = function () { - if (this.editingCell) { - if (this.cellEditor && this.cellEditor.focusIn) { - // if the editor is present, then we just focus it - this.cellEditor.focusIn(); + if (constrainDirection) { + // only allow left drag if this column is moving left + if (draggingLeft && firstValidMove >= oldIndex) { + return; } - else { - // if the editor is not present, it means async cell editor (eg React fibre) - // and we are trying to set focus before the cell editor is present, so we - // focus the cell instead - this.focusCell(true); + // only allow right drag if this column is moving right + if (draggingRight && firstValidMove <= oldIndex) { + return; } } - }; - CellComp.prototype.isEditing = function () { - return this.editingCell; - }; - CellComp.prototype.onKeyDown = function (event) { - var key = event.which || event.keyCode; - switch (key) { - case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_ENTER: - this.onEnterKeyDown(event); - break; - case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_F2: - this.onF2KeyDown(); - break; - case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_ESCAPE: - this.onEscapeKeyDown(); - break; - case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_TAB: - this.onTabKeyDown(event); - break; - case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_BACKSPACE: - case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_DELETE: - this.onBackspaceOrDeleteKeyPressed(key); - break; - case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_DOWN: - case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_UP: - case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_RIGHT: - case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_LEFT: - this.onNavigationKeyPressed(event, key); - break; + for (var i = 0; i < validMoves.length; i++) { + var move = validMoves[i]; + if (!this.columnModel.doesMovePassRules(allMovingColumnsOrdered, move)) { + continue; + } + this.columnModel.moveColumns(allMovingColumnsOrdered, move, "uiColumnDragged"); + // important to return here, so once we do the first valid move, we don't try do any more + return; } }; - CellComp.prototype.setFocusOutOnEditor = function () { - if (this.editingCell && this.cellEditor && this.cellEditor.focusOut) { - this.cellEditor.focusOut(); + MoveColumnFeature.prototype.calculateValidMoves = function (movingCols, draggingRight, mouseX) { + var isMoveBlocked = this.gridOptionsWrapper.isSuppressMovableColumns() || movingCols.some(function (col) { return col.getColDef().suppressMovable; }); + if (isMoveBlocked) { + return []; } - }; - CellComp.prototype.onNavigationKeyPressed = function (event, key) { - if (this.editingCell) { - return; + // this is the list of cols on the screen, so it's these we use when comparing the x mouse position + var allDisplayedCols = this.columnModel.getDisplayedColumns(this.pinned); + // but this list is the list of all cols, when we move a col it's the index within this list that gets used, + // so the result we return has to be and index location for this list + var allGridCols = this.columnModel.getAllGridColumns(); + var movingDisplayedCols = allDisplayedCols.filter(function (col) { return Object(_utils_array__WEBPACK_IMPORTED_MODULE_4__["includes"])(movingCols, col); }); + var otherDisplayedCols = allDisplayedCols.filter(function (col) { return !Object(_utils_array__WEBPACK_IMPORTED_MODULE_4__["includes"])(movingCols, col); }); + var otherGridCols = allGridCols.filter(function (col) { return !Object(_utils_array__WEBPACK_IMPORTED_MODULE_4__["includes"])(movingCols, col); }); + // work out how many DISPLAYED columns fit before the 'x' position. this gives us the displayIndex. + // for example, if cols are a,b,c,d and we find a,b fit before 'x', then we want to place the moving + // col between b and c (so that it is under the mouse position). + var displayIndex = 0; + var availableWidth = mouseX; + // if we are dragging right, then the columns will be to the left of the mouse, so we also want to + // include the width of the moving columns + if (draggingRight) { + var widthOfMovingDisplayedCols_1 = 0; + movingDisplayedCols.forEach(function (col) { return widthOfMovingDisplayedCols_1 += col.getActualWidth(); }); + availableWidth -= widthOfMovingDisplayedCols_1; } - if (event.shiftKey && this.rangeSelectionEnabled) { - this.onShiftRangeSelect(key); + if (availableWidth > 0) { + // now count how many of the displayed columns will fit to the left + for (var i = 0; i < otherDisplayedCols.length; i++) { + var col = otherDisplayedCols[i]; + availableWidth -= col.getActualWidth(); + if (availableWidth < 0) { + break; + } + displayIndex++; + } + // trial and error, if going right, we adjust by one, i didn't manage to quantify why, but it works + if (draggingRight) { + displayIndex++; + } + } + // the display index is with respect to all the showing columns, however when we move, it's with + // respect to all grid columns, so we need to translate from display index to grid index + var firstValidMove; + if (displayIndex > 0) { + var leftColumn = otherDisplayedCols[displayIndex - 1]; + firstValidMove = otherGridCols.indexOf(leftColumn) + 1; } else { - this.beans.rowRenderer.navigateToNextCell(event, key, this.cellPosition, true); + firstValidMove = otherGridCols.indexOf(otherDisplayedCols[0]); + if (firstValidMove === -1) { + firstValidMove = 0; + } } - // if we don't prevent default, the grid will scroll with the navigation keys - event.preventDefault(); - }; - CellComp.prototype.onShiftRangeSelect = function (key) { - if (!this.beans.rangeController) { - return; + var validMoves = [firstValidMove]; + var numberComparator = function (a, b) { return a - b; }; + // add in other valid moves due to hidden columns and married children. for example, a particular + // move might break a group that has married children (so move isn't valid), however there could + // be hidden columns (not displayed) that we could jump over to make the move valid. because + // they are hidden, user doesn't see any different, however it allows moves that would otherwise + // not work. for example imagine a group with 9 columns and all columns are hidden except the + // middle one (so 4 hidden to left, 4 hidden to right), then when moving 'firstValidMove' will + // be relative to the not-shown column, however we need to consider the move jumping over all the + // hidden children. if we didn't do this, then if the group just described was at the end (RHS) of the + // grid, there would be no way to put a column after it (as the grid would only consider beside the + // visible column, which would fail valid move rules). + if (draggingRight) { + // if dragging right, then we add all the additional moves to the right. so in other words + // if the next move is not valid, find the next move to the right that is valid. + var pointer = firstValidMove + 1; + var lastIndex = allGridCols.length - 1; + while (pointer <= lastIndex) { + validMoves.push(pointer); + pointer++; + } + // adding columns here means the order is now messed up + validMoves.sort(numberComparator); } - var endCell = this.beans.rangeController.extendLatestRangeInDirection(key); - if (endCell) { - this.beans.rowRenderer.ensureCellVisible(endCell); + else { + // if dragging left we do the reverse of dragging right, we add in all the valid moves to the + // left. however we also have to consider moves to the right for all hidden columns first. + // (this logic is hard to reason with, it was worked out with trial and error, + // more observation rather than science). + // add moves to the right + var pointer = firstValidMove; + var lastIndex = allGridCols.length - 1; + var displacedCol = allGridCols[pointer]; + while (pointer <= lastIndex && this.isColumnHidden(allDisplayedCols, displacedCol)) { + pointer++; + validMoves.push(pointer); + displacedCol = allGridCols[pointer]; + } + // add moves to the left + pointer = firstValidMove - 1; + var firstDisplayIndex = 0; + while (pointer >= firstDisplayIndex) { + validMoves.push(pointer); + pointer--; + } + // adding columns here means the order is now messed up + validMoves.sort(numberComparator).reverse(); } + return validMoves; }; - CellComp.prototype.onTabKeyDown = function (event) { - this.beans.rowRenderer.onTabKeyDown(this, event); - }; - CellComp.prototype.onBackspaceOrDeleteKeyPressed = function (key) { - if (!this.editingCell) { - this.startRowOrCellEdit(key); - } + // isHidden takes into account visible=false and group=closed, ie it is not displayed + MoveColumnFeature.prototype.isColumnHidden = function (displayedColumns, col) { + return displayedColumns.indexOf(col) < 0; }; - CellComp.prototype.onEnterKeyDown = function (e) { - if (this.editingCell || this.rowComp.isEditing()) { - this.stopEditingAndFocus(); - } - else { - if (this.beans.gridOptionsWrapper.isEnterMovesDown()) { - this.beans.rowRenderer.navigateToNextCell(null, _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_DOWN, this.cellPosition, false); + MoveColumnFeature.prototype.ensureIntervalStarted = function () { + if (!this.movingIntervalId) { + this.intervalCount = 0; + this.failedMoveAttempts = 0; + this.movingIntervalId = window.setInterval(this.moveInterval.bind(this), 100); + if (this.needToMoveLeft) { + this.dragAndDropService.setGhostIcon(_dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_LEFT, true); } else { - e.preventDefault(); - this.startRowOrCellEdit(_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_ENTER); + this.dragAndDropService.setGhostIcon(_dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_RIGHT, true); } } }; - CellComp.prototype.navigateAfterEdit = function () { - var fullRowEdit = this.beans.gridOptionsWrapper.isFullRowEdit(); - if (fullRowEdit) { - return; - } - var enterMovesDownAfterEdit = this.beans.gridOptionsWrapper.isEnterMovesDownAfterEdit(); - if (enterMovesDownAfterEdit) { - this.beans.rowRenderer.navigateToNextCell(null, _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_DOWN, this.cellPosition, false); - } - }; - CellComp.prototype.onF2KeyDown = function () { - if (!this.editingCell) { - this.startRowOrCellEdit(_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_F2); + MoveColumnFeature.prototype.ensureIntervalCleared = function () { + if (this.movingIntervalId) { + window.clearInterval(this.movingIntervalId); + this.movingIntervalId = null; + this.dragAndDropService.setGhostIcon(_dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_MOVE); } }; - CellComp.prototype.onEscapeKeyDown = function () { - if (this.editingCell) { - this.stopRowOrCellEdit(true); - this.focusCell(true); + MoveColumnFeature.prototype.moveInterval = function () { + // the amounts we move get bigger at each interval, so the speed accelerates, starting a bit slow + // and getting faster. this is to give smoother user experience. we max at 100px to limit the speed. + var pixelsToMove; + this.intervalCount++; + pixelsToMove = 10 + (this.intervalCount * 5); + if (pixelsToMove > 100) { + pixelsToMove = 100; } - }; - CellComp.prototype.onKeyPress = function (event) { - // check this, in case focus is on a (for example) a text field inside the cell, - // in which cse we should not be listening for these key pressed - var eventTarget = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].getTarget(event); - var eventOnChildComponent = eventTarget !== this.getGui(); - if (eventOnChildComponent || this.editingCell) { - return; + var pixelsMoved = null; + var scrollFeature = this.gridBodyCon.getScrollFeature(); + if (this.needToMoveLeft) { + pixelsMoved = scrollFeature.scrollHorizontally(-pixelsToMove); } - var pressedChar = String.fromCharCode(event.charCode); - if (pressedChar === ' ') { - this.onSpaceKeyPressed(event); + else if (this.needToMoveRight) { + pixelsMoved = scrollFeature.scrollHorizontally(pixelsToMove); } - else if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].isEventFromPrintableCharacter(event)) { - this.startRowOrCellEdit(null, pressedChar); - // if we don't prevent default, then the keypress also gets applied to the text field - // (at least when doing the default editor), but we need to allow the editor to decide - // what it wants to do. we only do this IF editing was started - otherwise it messes - // up when the use is not doing editing, but using rendering with text fields in cellRenderer - // (as it would block the the user from typing into text fields). - event.preventDefault(); + if (pixelsMoved !== 0) { + this.onDragging(this.lastDraggingEvent); + this.failedMoveAttempts = 0; } - }; - CellComp.prototype.onSpaceKeyPressed = function (event) { - var gridOptionsWrapper = this.beans.gridOptionsWrapper; - if (!this.editingCell && gridOptionsWrapper.isRowSelection()) { - var newSelection = !this.rowNode.isSelected(); - if (newSelection || gridOptionsWrapper.isRowDeselection()) { - this.rowNode.setSelected(newSelection); + else { + // we count the failed move attempts. if we fail to move 7 times, then we pin the column. + // this is how we achieve pining by dragging the column to the edge of the grid. + this.failedMoveAttempts++; + var columns = this.lastDraggingEvent.dragItem.columns; + var columnsThatCanPin = columns.filter(function (c) { return !c.getColDef().lockPinned; }); + if (columnsThatCanPin.length > 0) { + this.dragAndDropService.setGhostIcon(_dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_PINNED); + if (this.failedMoveAttempts > 7) { + var pinType = this.needToMoveLeft ? _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].PINNED_LEFT : _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].PINNED_RIGHT; + this.setColumnsPinned(columnsThatCanPin, pinType, "uiColumnDragged"); + this.dragAndDropService.nudge(); + } } } - // prevent default as space key, by default, moves browser scroll down - event.preventDefault(); }; - CellComp.prototype.onMouseDown = function (mouseEvent) { - var ctrlKey = mouseEvent.ctrlKey, metaKey = mouseEvent.metaKey, shiftKey = mouseEvent.shiftKey; - var target = mouseEvent.target; - var _a = this.beans, eventService = _a.eventService, rangeController = _a.rangeController; - // do not change the range for right-clicks inside an existing range - if (this.isRightClickInExistingRange(mouseEvent)) { + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], MoveColumnFeature.prototype, "columnModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('dragAndDropService') + ], MoveColumnFeature.prototype, "dragAndDropService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') + ], MoveColumnFeature.prototype, "gridOptionsWrapper", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('ctrlsService') + ], MoveColumnFeature.prototype, "ctrlsService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], MoveColumnFeature.prototype, "init", null); + return MoveColumnFeature; +}()); + + + +/***/ }), +/* 145 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BodyDropPivotTarget", function() { return BodyDropPivotTarget; }); +/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(97); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + +var BodyDropPivotTarget = /** @class */ (function () { + function BodyDropPivotTarget(pinned) { + this.columnsToAggregate = []; + this.columnsToGroup = []; + this.columnsToPivot = []; + this.pinned = pinned; + } + /** Callback for when drag enters */ + BodyDropPivotTarget.prototype.onDragEnter = function (draggingEvent) { + var _this = this; + this.clearColumnsList(); + // in pivot mode, we don't accept any drops if functions are read only + if (this.gridOptionsWrapper.isFunctionsReadOnly()) { return; } - if (!shiftKey || (rangeController && !rangeController.getCellRanges().length)) { - // We only need to pass true to focusCell when the browser is IE/Edge and we are trying - // to focus the cell itself. This should never be true if the mousedown was triggered - // due to a click on a cell editor for example. - var forceBrowserFocus = (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].isBrowserIE() || _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isBrowserEdge()) && !this.editingCell; - this.focusCell(forceBrowserFocus); - } - else { - // if a range is being changed, we need to make sure the focused cell does not change. - mouseEvent.preventDefault(); - } - // if we are clicking on a checkbox, we need to make sure the cell wrapping that checkbox - // is focused but we don't want to change the range selection, so return here. - if (this.containsWidget(target)) { + var dragColumns = draggingEvent.dragItem.columns; + if (!dragColumns) { return; } - if (rangeController) { - var thisCell = this.cellPosition; - if (shiftKey) { - rangeController.extendLatestRangeToCell(thisCell); + dragColumns.forEach(function (column) { + // we don't allow adding secondary columns + if (!column.isPrimary()) { + return; } - else { - var ctrlKeyPressed = ctrlKey || metaKey; - rangeController.setRangeToCell(thisCell, ctrlKeyPressed); + if (column.isAnyFunctionActive()) { + return; } - } - eventService.dispatchEvent(this.createEvent(mouseEvent, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_MOUSE_DOWN)); - }; - CellComp.prototype.isRightClickInExistingRange = function (mouseEvent) { - var rangeController = this.beans.rangeController; - if (rangeController) { - var cellInRange = rangeController.isCellInAnyRange(this.getCellPosition()); - if (cellInRange && mouseEvent.button === 2) { - return true; + if (column.isAllowValue()) { + _this.columnsToAggregate.push(column); + } + else if (column.isAllowRowGroup()) { + _this.columnsToGroup.push(column); + } + else if (column.isAllowPivot()) { + _this.columnsToPivot.push(column); } + }); + }; + BodyDropPivotTarget.prototype.getIconName = function () { + var totalColumns = this.columnsToAggregate.length + this.columnsToGroup.length + this.columnsToPivot.length; + if (totalColumns > 0) { + return this.pinned ? _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragAndDropService"].ICON_PINNED : _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragAndDropService"].ICON_MOVE; } - return false; + return null; }; - CellComp.prototype.containsWidget = function (target) { - return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isElementChildOfClass(target, 'ag-selection-checkbox', 3); + /** Callback for when drag leaves */ + BodyDropPivotTarget.prototype.onDragLeave = function (draggingEvent) { + // if we are taking columns out of the center, then we remove them from the report + this.clearColumnsList(); }; - // returns true if on iPad and this is second 'click' event in 200ms - CellComp.prototype.isDoubleClickOnIPad = function () { - if (!_utils__WEBPACK_IMPORTED_MODULE_7__["_"].isIOSUserAgent() || _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isEventSupported('dblclick')) { - return false; - } - var nowMillis = new Date().getTime(); - var res = nowMillis - this.lastIPadMouseClickEvent < 200; - this.lastIPadMouseClickEvent = nowMillis; - return res; + BodyDropPivotTarget.prototype.clearColumnsList = function () { + this.columnsToAggregate.length = 0; + this.columnsToGroup.length = 0; + this.columnsToPivot.length = 0; }; - CellComp.prototype.onCellClicked = function (mouseEvent) { - // iPad doesn't have double click - so we need to mimic it to enable editing for iPad. - if (this.isDoubleClickOnIPad()) { - this.onCellDoubleClicked(mouseEvent); - mouseEvent.preventDefault(); // if we don't do this, then iPad zooms in - return; + /** Callback for when dragging */ + BodyDropPivotTarget.prototype.onDragging = function (draggingEvent) { + }; + /** Callback for when drag stops */ + BodyDropPivotTarget.prototype.onDragStop = function (draggingEvent) { + if (this.columnsToAggregate.length > 0) { + this.columnModel.addValueColumns(this.columnsToAggregate, "toolPanelDragAndDrop"); } - var _a = this.beans, eventService = _a.eventService, gridOptionsWrapper = _a.gridOptionsWrapper; - var cellClickedEvent = this.createEvent(mouseEvent, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_CLICKED); - eventService.dispatchEvent(cellClickedEvent); - var colDef = this.getComponentHolder(); - if (colDef.onCellClicked) { - // to make callback async, do in a timeout - window.setTimeout(function () { return colDef.onCellClicked(cellClickedEvent); }, 0); + if (this.columnsToGroup.length > 0) { + this.columnModel.addRowGroupColumns(this.columnsToGroup, "toolPanelDragAndDrop"); } - var editOnSingleClick = (gridOptionsWrapper.isSingleClickEdit() || colDef.singleClickEdit) - && !gridOptionsWrapper.isSuppressClickEdit(); - if (editOnSingleClick) { - this.startRowOrCellEdit(); + if (this.columnsToPivot.length > 0) { + this.columnModel.addPivotColumns(this.columnsToPivot, "toolPanelDragAndDrop"); } }; - CellComp.prototype.createGridCellVo = function () { - this.cellPosition = { - rowIndex: this.rowNode.rowIndex, - rowPinned: this.rowNode.rowPinned, - column: this.column - }; - }; - CellComp.prototype.getCellPosition = function () { - return this.cellPosition; - }; - CellComp.prototype.getParentRow = function () { - return this.eParentRow; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnModel') + ], BodyDropPivotTarget.prototype, "columnModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') + ], BodyDropPivotTarget.prototype, "gridOptionsWrapper", void 0); + return BodyDropPivotTarget; +}()); + + + +/***/ }), +/* 146 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderRowCtrl", function() { return HeaderRowCtrl; }); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(15); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(24); +/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(107); +/* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(43); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(13); +/* harmony import */ var _cells_floatingFilter_headerFilterCellCtrl__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(147); +/* harmony import */ var _cells_column_headerCellCtrl__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(154); +/* harmony import */ var _cells_columnGroup_headerGroupCellCtrl__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(159); +/* harmony import */ var _headerRowComp__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(136); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(7); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - CellComp.prototype.setParentRow = function (eParentRow) { - this.eParentRow = eParentRow; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - CellComp.prototype.getColumn = function () { - return this.column; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + + + + + + +var instanceIdSequence = 0; +var HeaderRowCtrl = /** @class */ (function (_super) { + __extends(HeaderRowCtrl, _super); + function HeaderRowCtrl(rowIndex, pinned, type) { + var _this = _super.call(this) || this; + _this.instanceId = instanceIdSequence++; + _this.headerCellCtrls = {}; + _this.rowIndex = rowIndex; + _this.pinned = pinned; + _this.type = type; + return _this; + } + HeaderRowCtrl.prototype.getInstanceId = function () { + return this.instanceId; }; - CellComp.prototype.getComponentHolder = function () { - return this.column.getColDef(); + HeaderRowCtrl.prototype.setComp = function (comp) { + this.comp = comp; + this.onRowHeightChanged(); + this.onVirtualColumnsChanged(); + this.setWidth(); + this.addEventListeners(); + if (Object(_utils_browser__WEBPACK_IMPORTED_MODULE_5__["isBrowserSafari"])()) { + // fix for a Safari rendering bug that caused the header to flicker above chart panels + // as you move the mouse over the header + this.comp.setTransform('translateZ(0)'); + } + comp.setAriaRowIndex(this.rowIndex + 1); + }; + HeaderRowCtrl.prototype.addEventListeners = function () { + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_RESIZED, this.onColumnResized.bind(this)); + // when print layout changes, it changes what columns are in what section + this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_4__["GridOptionsWrapper"].PROP_DOM_LAYOUT, this.onDisplayedColumnsChanged.bind(this)); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this)); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_VIRTUAL_COLUMNS_CHANGED, this.onVirtualColumnsChanged.bind(this)); + this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_4__["GridOptionsWrapper"].PROP_HEADER_HEIGHT, this.onRowHeightChanged.bind(this)); + this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_4__["GridOptionsWrapper"].PROP_PIVOT_HEADER_HEIGHT, this.onRowHeightChanged.bind(this)); + this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_4__["GridOptionsWrapper"].PROP_GROUP_HEADER_HEIGHT, this.onRowHeightChanged.bind(this)); + this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_4__["GridOptionsWrapper"].PROP_PIVOT_GROUP_HEADER_HEIGHT, this.onRowHeightChanged.bind(this)); + this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_4__["GridOptionsWrapper"].PROP_FLOATING_FILTERS_HEIGHT, this.onRowHeightChanged.bind(this)); + }; + HeaderRowCtrl.prototype.getHeaderCellCtrl = function (column) { + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_11__["values"])(this.headerCellCtrls).find(function (cellCtrl) { return cellCtrl.getColumnGroupChild() === column; }); + }; + HeaderRowCtrl.prototype.onDisplayedColumnsChanged = function () { + this.onVirtualColumnsChanged(); + this.setWidth(); }; - CellComp.prototype.detach = function () { - this.eParentRow.removeChild(this.getGui()); + HeaderRowCtrl.prototype.getType = function () { + return this.type; }; - // if the row is also getting destroyed, then we don't need to remove from dom, - // as the row will also get removed, so no need to take out the cells from the row - // if the row is going (removing is an expensive operation, so only need to remove - // the top part) - // - // note - this is NOT called by context, as we don't wire / unwire the CellComp for performance reasons. - CellComp.prototype.destroy = function () { - if (this.createCellRendererFunc) { - this.beans.taskQueue.cancelTask(this.createCellRendererFunc); - } - this.stopEditing(); - this.cellRenderer = this.beans.context.destroyBean(this.cellRenderer); - this.beans.context.destroyBean(this.selectionHandle); - _super.prototype.destroy.call(this); + HeaderRowCtrl.prototype.onColumnResized = function () { + this.setWidth(); }; - CellComp.prototype.onLeftChanged = function () { - var left = this.modifyLeftForPrintLayout(this.getCellLeft()); - this.getGui().style.left = left + 'px'; - this.refreshAriaIndex(); + HeaderRowCtrl.prototype.setWidth = function () { + var width = this.getWidthForRow(); + this.comp.setWidth(width + "px"); }; - CellComp.prototype.modifyLeftForPrintLayout = function (leftPosition) { - if (!this.printLayout || this.column.getPinned() === _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_LEFT) { - return leftPosition; - } - if (this.column.getPinned() === _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_RIGHT) { - var leftWidth_1 = this.beans.columnController.getPinnedLeftContainerWidth(); - var bodyWidth = this.beans.columnController.getBodyContainerWidth(); - return leftWidth_1 + bodyWidth + leftPosition; + HeaderRowCtrl.prototype.getWidthForRow = function () { + var printLayout = this.gridOptionsWrapper.getDomLayout() === _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].DOM_LAYOUT_PRINT; + if (printLayout) { + var pinned = this.pinned != null; + if (pinned) { + return 0; + } + return this.columnModel.getContainerWidth(_constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_RIGHT) + + this.columnModel.getContainerWidth(_constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_LEFT) + + this.columnModel.getContainerWidth(null); } - // is in body - var leftWidth = this.beans.columnController.getPinnedLeftContainerWidth(); - return leftWidth + leftPosition; - }; - CellComp.prototype.onWidthChanged = function () { - var width = this.getCellWidth(); - this.getGui().style.width = width + 'px'; + // if not printing, just return the width as normal + return this.columnModel.getContainerWidth(this.pinned); }; - CellComp.prototype.getRangeBorders = function () { - var _this = this; - var isRtl = this.beans.gridOptionsWrapper.isEnableRtl(); - var top = false; - var right = false; - var bottom = false; - var left = false; - var thisCol = this.cellPosition.column; - var _a = this.beans, rangeController = _a.rangeController, columnController = _a.columnController; - var leftCol; - var rightCol; - if (isRtl) { - leftCol = columnController.getDisplayedColAfter(thisCol); - rightCol = columnController.getDisplayedColBefore(thisCol); + HeaderRowCtrl.prototype.onRowHeightChanged = function () { + var headerRowCount = this.columnModel.getHeaderRowCount(); + var sizes = []; + var numberOfFloating = 0; + var groupHeight; + var headerHeight; + if (this.columnModel.isPivotMode()) { + groupHeight = this.gridOptionsWrapper.getPivotGroupHeaderHeight(); + headerHeight = this.gridOptionsWrapper.getPivotHeaderHeight(); } else { - leftCol = columnController.getDisplayedColBefore(thisCol); - rightCol = columnController.getDisplayedColAfter(thisCol); - } - var ranges = rangeController.getCellRanges().filter(function (range) { return rangeController.isCellInSpecificRange(_this.cellPosition, range); }); - // this means we are the first column in the grid - if (!leftCol) { - left = true; - } - // this means we are the last column in the grid - if (!rightCol) { - right = true; - } - for (var i = 0; i < ranges.length; i++) { - if (top && right && bottom && left) { - break; - } - var range = ranges[i]; - var startRow = rangeController.getRangeStartRow(range); - var endRow = rangeController.getRangeEndRow(range); - if (!top && this.beans.rowPositionUtils.sameRow(startRow, this.cellPosition)) { - top = true; - } - if (!bottom && this.beans.rowPositionUtils.sameRow(endRow, this.cellPosition)) { - bottom = true; - } - if (!left && range.columns.indexOf(leftCol) < 0) { - left = true; - } - if (!right && range.columns.indexOf(rightCol) < 0) { - right = true; + if (this.columnModel.hasFloatingFilters()) { + headerRowCount++; + numberOfFloating = 1; } + groupHeight = this.gridOptionsWrapper.getGroupHeaderHeight(); + headerHeight = this.gridOptionsWrapper.getHeaderHeight(); } - return { top: top, right: right, bottom: bottom, left: left }; - }; - CellComp.prototype.getInitialRangeClasses = function () { - var classes = []; - if (!this.rangeSelectionEnabled || !this.rangeCount) { - return classes; + var numberOfNonGroups = 1 + numberOfFloating; + var numberOfGroups = headerRowCount - numberOfNonGroups; + for (var i = 0; i < numberOfGroups; i++) { + sizes.push(groupHeight); } - classes.push('ag-cell-range-selected'); - if (this.hasChartRange) { - classes.push('ag-cell-range-chart'); + sizes.push(headerHeight); + for (var i = 0; i < numberOfFloating; i++) { + sizes.push(this.gridOptionsWrapper.getFloatingFiltersHeight()); } - var count = Math.min(this.rangeCount, 4); - classes.push("ag-cell-range-selected-" + count); - if (this.isSingleCell()) { - classes.push('ag-cell-range-single-cell'); + var rowHeight = 0; + for (var i = 0; i < this.rowIndex; i++) { + rowHeight += sizes[i]; } - if (this.rangeCount > 0) { - var borders = this.getRangeBorders(); - if (borders.top) { - classes.push('ag-cell-range-top'); + this.comp.setTop(rowHeight + 'px'); + this.comp.setHeight(sizes[this.rowIndex] + 'px'); + }; + HeaderRowCtrl.prototype.getPinned = function () { + return this.pinned; + }; + HeaderRowCtrl.prototype.getRowIndex = function () { + return this.rowIndex; + }; + HeaderRowCtrl.prototype.onVirtualColumnsChanged = function () { + var _this = this; + var oldCtrls = this.headerCellCtrls; + this.headerCellCtrls = {}; + var columns = this.getColumnsInViewport(); + columns.forEach(function (child) { + // skip groups that have no displayed children. this can happen when the group is broken, + // and this section happens to have nothing to display for the open / closed state. + // (a broken group is one that is split, ie columns in the group have a non-group column + // in between them) + if (child.isEmptyGroup()) { + return; + } + var idOfChild = child.getUniqueId(); + // if we already have this cell rendered, do nothing + var headerCtrl = oldCtrls[idOfChild]; + delete oldCtrls[idOfChild]; + // it's possible there is a new Column with the same ID, but it's for a different Column. + // this is common with pivoting, where the pivot cols change, but the id's are still pivot_0, + // pivot_1 etc. so if new col but same ID, need to remove the old col here first as we are + // about to replace it in the this.headerComps map. + var forOldColumn = headerCtrl && headerCtrl.getColumnGroupChild() != child; + if (forOldColumn) { + _this.destroyBean(headerCtrl); + headerCtrl = undefined; + } + if (headerCtrl == null) { + switch (_this.type) { + case _headerRowComp__WEBPACK_IMPORTED_MODULE_10__["HeaderRowType"].FLOATING_FILTER: + headerCtrl = _this.createBean(new _cells_floatingFilter_headerFilterCellCtrl__WEBPACK_IMPORTED_MODULE_7__["HeaderFilterCellCtrl"](child, _this)); + break; + case _headerRowComp__WEBPACK_IMPORTED_MODULE_10__["HeaderRowType"].COLUMN_GROUP: + headerCtrl = _this.createBean(new _cells_columnGroup_headerGroupCellCtrl__WEBPACK_IMPORTED_MODULE_9__["HeaderGroupCellCtrl"](child, _this)); + break; + default: + headerCtrl = _this.createBean(new _cells_column_headerCellCtrl__WEBPACK_IMPORTED_MODULE_8__["HeaderCellCtrl"](child, _this)); + break; + } } - if (borders.right) { - classes.push('ag-cell-range-right'); + _this.headerCellCtrls[idOfChild] = headerCtrl; + }); + // we want to keep columns that are focused, otherwise keyboard navigation breaks + var isFocusedAndDisplayed = function (ctrl) { + var isFocused = _this.focusService.isHeaderWrapperFocused(ctrl); + if (!isFocused) { + return false; } - if (borders.bottom) { - classes.push('ag-cell-range-bottom'); + var isDisplayed = _this.columnModel.isDisplayed(ctrl.getColumnGroupChild()); + return isDisplayed; + }; + Object(_utils_object__WEBPACK_IMPORTED_MODULE_6__["iterateObject"])(oldCtrls, function (id, oldCtrl) { + var keepCtrl = isFocusedAndDisplayed(oldCtrl); + if (keepCtrl) { + _this.headerCellCtrls[id] = oldCtrl; } - if (borders.left) { - classes.push('ag-cell-range-left'); + else { + _this.destroyBean(oldCtrl); } - } - if (!!this.selectionHandle) { - classes.push('ag-cell-range-handle'); - } - return classes; + }); + var ctrlsToDisplay = Object(_utils_object__WEBPACK_IMPORTED_MODULE_6__["getAllValuesInObject"])(this.headerCellCtrls); + this.comp.setHeaderCtrls(ctrlsToDisplay); }; - CellComp.prototype.onRowIndexChanged = function () { - // when index changes, this influences items that need the index, so we update the - // grid cell so they are working off the new index. - this.createGridCellVo(); - // when the index of the row changes, ie means the cell may have lost or gained focus - this.onCellFocused(); - // check range selection - this.onRangeSelectionChanged(); + HeaderRowCtrl.prototype.destroyCtrls = function () { + var _this = this; + Object(_utils_object__WEBPACK_IMPORTED_MODULE_6__["iterateObject"])(this.headerCellCtrls, function (key, ctrl) { + _this.destroyBean(ctrl); + }); + this.headerCellCtrls = {}; }; - CellComp.prototype.onRangeSelectionChanged = function () { - var rangeController = this.beans.rangeController; - if (!rangeController) { - return; - } - var _a = this, cellPosition = _a.cellPosition, rangeCount = _a.rangeCount; - var newRangeCount = rangeController.getCellRangeCount(cellPosition); - var element = this.getGui(); - if (rangeCount !== newRangeCount) { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-selected', newRangeCount !== 0); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-selected-1', newRangeCount === 1); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-selected-2', newRangeCount === 2); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-selected-3', newRangeCount === 3); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-selected-4', newRangeCount >= 4); - this.rangeCount = newRangeCount; - } - var hasChartRange = this.getHasChartRange(); - if (hasChartRange !== this.hasChartRange) { - this.hasChartRange = hasChartRange; - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-chart', this.hasChartRange); - } - this.updateRangeBorders(); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-single-cell', this.isSingleCell()); - this.refreshHandle(); + HeaderRowCtrl.prototype.getColumnsInViewport = function () { + var printLayout = this.gridOptionsWrapper.getDomLayout() === _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].DOM_LAYOUT_PRINT; + return printLayout ? this.getColumnsInViewportPrintLayout() : this.getColumnsInViewportNormalLayout(); }; - CellComp.prototype.getHasChartRange = function () { - var rangeController = this.beans.rangeController; - if (!this.rangeCount || !rangeController) { - return false; + HeaderRowCtrl.prototype.getColumnsInViewportPrintLayout = function () { + var _this = this; + // for print layout, we add all columns into the center + if (this.pinned != null) { + return []; } - var cellRanges = rangeController.getCellRanges(); - return cellRanges.length > 0 && cellRanges.every(function (range) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].includes([_interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_4__["CellRangeType"].DIMENSION, _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_4__["CellRangeType"].VALUE], range.type); }); + var viewportColumns = []; + var actualDepth = this.getActualDepth(); + [_constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_LEFT, null, _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_RIGHT].forEach(function (pinned) { + var items = _this.columnModel.getVirtualHeaderGroupRow(pinned, actualDepth); + viewportColumns = viewportColumns.concat(items); + }); + return viewportColumns; }; - CellComp.prototype.shouldHaveSelectionHandle = function () { - var _a = this.beans, gridOptionsWrapper = _a.gridOptionsWrapper, rangeController = _a.rangeController; - var cellRanges = rangeController.getCellRanges(); - var rangesLen = cellRanges.length; - if (this.rangeCount < 1 || rangesLen < 1) { + HeaderRowCtrl.prototype.getActualDepth = function () { + return this.type == _headerRowComp__WEBPACK_IMPORTED_MODULE_10__["HeaderRowType"].FLOATING_FILTER ? this.rowIndex - 1 : this.rowIndex; + }; + HeaderRowCtrl.prototype.getColumnsInViewportNormalLayout = function () { + // when in normal layout, we add the columns for that container only + return this.columnModel.getVirtualHeaderGroupRow(this.pinned, this.getActualDepth()); + }; + HeaderRowCtrl.prototype.focusHeader = function (column, event) { + var allCtrls = Object(_utils_object__WEBPACK_IMPORTED_MODULE_6__["getAllValuesInObject"])(this.headerCellCtrls); + var ctrl = allCtrls.find(function (ctrl) { return ctrl.getColumnGroupChild() == column; }); + if (!ctrl) { return false; } - var cellRange = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].last(cellRanges); - var cellPosition = this.getCellPosition(); - var fillHandleIsAvailable = rangesLen === 1 && - (gridOptionsWrapper.isEnableFillHandle() || gridOptionsWrapper.isEnableRangeHandle()) && - !this.editingCell; - if (this.hasChartRange) { - var hasCategoryRange = cellRanges[0].type === _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_4__["CellRangeType"].DIMENSION; - var isCategoryCell = hasCategoryRange && rangeController.isCellInSpecificRange(cellPosition, cellRanges[0]); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), 'ag-cell-range-chart-category', isCategoryCell); - fillHandleIsAvailable = cellRange.type === _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_4__["CellRangeType"].VALUE; - } - return fillHandleIsAvailable && - cellRange.endRow != null && - rangeController.isContiguousRange(cellRange) && - rangeController.isBottomRightCell(cellRange, cellPosition); - }; - CellComp.prototype.addSelectionHandle = function () { - var _a = this.beans, gridOptionsWrapper = _a.gridOptionsWrapper, context = _a.context, rangeController = _a.rangeController; - var cellRangeType = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].last(rangeController.getCellRanges()).type; - var selectionHandleFill = gridOptionsWrapper.isEnableFillHandle() && _utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(cellRangeType); - var type = selectionHandleFill ? _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_4__["SelectionHandleType"].FILL : _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_4__["SelectionHandleType"].RANGE; - if (this.selectionHandle && this.selectionHandle.getType() !== type) { - this.selectionHandle = this.beans.context.destroyBean(this.selectionHandle); - } - if (!this.selectionHandle) { - this.selectionHandle = this.beans.selectionHandleFactory.createSelectionHandle(type); - } - this.selectionHandle.refresh(this); + ctrl.focus(event); + return true; }; - CellComp.prototype.updateRangeBordersIfRangeCount = function () { - // we only need to update range borders if we are in a range - if (this.rangeCount > 0) { - this.updateRangeBorders(); - this.refreshHandle(); - } + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnModel') + ], HeaderRowCtrl.prototype, "columnModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('focusService') + ], HeaderRowCtrl.prototype, "focusService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_2__["PreDestroy"] + ], HeaderRowCtrl.prototype, "destroyCtrls", null); + return HeaderRowCtrl; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + + + +/***/ }), +/* 147 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderFilterCellCtrl", function() { return HeaderFilterCellCtrl; }); +/* harmony import */ var _abstractCell_abstractHeaderCellCtrl__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(148); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(65); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(10); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(23); +/* harmony import */ var _gridApi__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(149); +/* harmony import */ var _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(152); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(42); +/* harmony import */ var _utils_icon__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(48); +/* harmony import */ var _widgets_managedFocusFeature__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(64); +/* harmony import */ var _hoverFeature__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(153); +/* harmony import */ var _components_framework_componentTypes__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(103); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + + + + + + +var HeaderFilterCellCtrl = /** @class */ (function (_super) { + __extends(HeaderFilterCellCtrl, _super); + function HeaderFilterCellCtrl(column, parentRowCtrl) { + var _this = _super.call(this, column, parentRowCtrl) || this; + _this.column = column; + return _this; + } + HeaderFilterCellCtrl.prototype.setComp = function (comp, eGui, eButtonShowMainFilter, eFloatingFilterBody) { + _super.prototype.setGui.call(this, eGui); + this.comp = comp; + this.eButtonShowMainFilter = eButtonShowMainFilter; + this.eFloatingFilterBody = eFloatingFilterBody; + var colDef = this.column.getColDef(); + var filterExists = !!colDef.filter || !!colDef.filterFramework; + var floatingFilterExists = !!colDef.floatingFilter; + this.active = filterExists && floatingFilterExists; + this.setupWidth(); + this.setupLeft(); + this.setupHover(); + this.setupFocus(); + this.setupUserComp(); + this.setupSyncWithFilter(); + this.setupUi(); + this.addManagedListener(this.eButtonShowMainFilter, 'click', this.showParentFilter.bind(this)); }; - CellComp.prototype.refreshHandle = function () { - if (!this.beans.rangeController) { + HeaderFilterCellCtrl.prototype.setupUi = function () { + this.comp.addOrRemoveButtonWrapperCssClass('ag-hidden', !this.active || this.suppressFilterButton); + if (!this.active) { return; } - var shouldHaveSelectionHandle = this.shouldHaveSelectionHandle(); - if (this.selectionHandle && !shouldHaveSelectionHandle) { - this.selectionHandle = this.beans.context.destroyBean(this.selectionHandle); - } - if (shouldHaveSelectionHandle) { - this.addSelectionHandle(); + this.comp.addOrRemoveBodyCssClass('ag-floating-filter-full-body', this.suppressFilterButton); + this.comp.addOrRemoveBodyCssClass('ag-floating-filter-body', !this.suppressFilterButton); + var eMenuIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_8__["createIconNoSpan"])('filter', this.gridOptionsWrapper, this.column); + if (eMenuIcon) { + this.eButtonShowMainFilter.appendChild(eMenuIcon); } - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), 'ag-cell-range-handle', !!this.selectionHandle); }; - CellComp.prototype.updateRangeBorders = function () { - var rangeBorders = this.getRangeBorders(); - var isSingleCell = this.isSingleCell(); - var isTop = !isSingleCell && rangeBorders.top; - var isRight = !isSingleCell && rangeBorders.right; - var isBottom = !isSingleCell && rangeBorders.bottom; - var isLeft = !isSingleCell && rangeBorders.left; - var element = this.getGui(); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-top', isTop); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-right', isRight); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-bottom', isBottom); - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-left', isLeft); + HeaderFilterCellCtrl.prototype.setupFocus = function () { + this.createManagedBean(new _widgets_managedFocusFeature__WEBPACK_IMPORTED_MODULE_9__["ManagedFocusFeature"](this.eGui, { + shouldStopEventPropagation: this.shouldStopEventPropagation.bind(this), + onTabKeyDown: this.onTabKeyDown.bind(this), + handleKeyDown: this.handleKeyDown.bind(this), + onFocusIn: this.onFocusIn.bind(this) + })); }; - CellComp.prototype.onFirstRightPinnedChanged = function () { - var firstRightPinned = this.column.isFirstRightPinned(); - if (this.firstRightPinned !== firstRightPinned) { - this.firstRightPinned = firstRightPinned; - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), 'ag-cell-first-right-pinned', firstRightPinned); + HeaderFilterCellCtrl.prototype.onTabKeyDown = function (e) { + var eDocument = this.gridOptionsWrapper.getDocument(); + var activeEl = eDocument.activeElement; + var wrapperHasFocus = activeEl === this.eGui; + if (wrapperHasFocus) { + return; + } + var nextFocusableEl = this.focusService.findNextFocusableElement(this.eGui, null, e.shiftKey); + if (nextFocusableEl) { + this.beans.headerNavigationService.scrollToColumn(this.column); + e.preventDefault(); + nextFocusableEl.focus(); + return; } - }; - CellComp.prototype.onLastLeftPinnedChanged = function () { - var lastLeftPinned = this.column.isLastLeftPinned(); - if (this.lastLeftPinned !== lastLeftPinned) { - this.lastLeftPinned = lastLeftPinned; - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), 'ag-cell-last-left-pinned', lastLeftPinned); + var nextFocusableColumn = this.findNextColumnWithFloatingFilter(e.shiftKey); + if (!nextFocusableColumn) { + return; + } + if (this.focusService.focusHeaderPosition({ + headerPosition: { + headerRowIndex: this.getParentRowCtrl().getRowIndex(), + column: nextFocusableColumn + }, + event: e + })) { + e.preventDefault(); } }; - CellComp.prototype.populateTemplate = function () { - if (this.usingWrapper) { - this.eParentOfValue = this.getRefElement('eCellValue'); - this.eCellWrapper = this.getRefElement('eCellWrapper'); - this.eCellValue = this.getRefElement('eCellValue'); - if (this.includeRowDraggingComponent) { - this.addRowDragging(); - } - if (this.includeDndSourceComponent) { - this.addDndSource(); - } - if (this.includeSelectionComponent) { - this.addSelectionCheckbox(); + HeaderFilterCellCtrl.prototype.findNextColumnWithFloatingFilter = function (backwards) { + var columModel = this.beans.columnModel; + var nextCol = this.column; + do { + nextCol = backwards + ? columModel.getDisplayedColBefore(nextCol) + : columModel.getDisplayedColAfter(nextCol); + if (!nextCol) { + break; } - } - else { - this.eParentOfValue = this.getGui(); - } + } while (!nextCol.getColDef().filter || !nextCol.getColDef().floatingFilter); + return nextCol; }; - CellComp.prototype.getFrameworkOverrides = function () { - return this.beans.frameworkOverrides; + HeaderFilterCellCtrl.prototype.handleKeyDown = function (e) { + var eDocument = this.gridOptionsWrapper.getDocument(); + var activeEl = eDocument.activeElement; + var wrapperHasFocus = activeEl === this.eGui; + switch (e.key) { + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].UP: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].DOWN: + if (!wrapperHasFocus) { + e.preventDefault(); + } + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].LEFT: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].RIGHT: + if (wrapperHasFocus) { + return; + } + e.stopPropagation(); + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].ENTER: + if (wrapperHasFocus) { + if (this.focusService.focusInto(this.eGui)) { + e.preventDefault(); + } + } + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].ESCAPE: + if (!wrapperHasFocus) { + this.eGui.focus(); + } + } }; - CellComp.prototype.addRowDragging = function () { - var pagination = this.beans.gridOptionsWrapper.isPagination(); - var rowDragManaged = this.beans.gridOptionsWrapper.isRowDragManaged(); - var clientSideRowModelActive = this.beans.gridOptionsWrapper.isRowModelDefault(); - if (rowDragManaged) { - // row dragging only available in default row model - if (!clientSideRowModelActive) { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].doOnce(function () { return console.warn('ag-Grid: managed row dragging is only allowed in the Client Side Row Model'); }, 'CellComp.addRowDragging'); - return; - } - if (pagination) { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].doOnce(function () { return console.warn('ag-Grid: managed row dragging is not possible when doing pagination'); }, 'CellComp.addRowDragging'); - return; + HeaderFilterCellCtrl.prototype.onFocusIn = function (e) { + var isRelatedWithin = this.eGui.contains(e.relatedTarget); + // when the focus is already within the component, + // we default to the browser's behavior + if (isRelatedWithin) { + return; + } + var notFromHeaderWrapper = !!e.relatedTarget && !e.relatedTarget.classList.contains('ag-floating-filter'); + var fromWithinHeader = !!e.relatedTarget && Object(_utils_dom__WEBPACK_IMPORTED_MODULE_7__["isElementChildOfClass"])(e.relatedTarget, 'ag-floating-filter'); + if (notFromHeaderWrapper && fromWithinHeader && e.target === this.eGui) { + var lastFocusEvent = this.lastFocusEvent; + var fromTab = !!(lastFocusEvent && lastFocusEvent.key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].TAB); + if (lastFocusEvent && fromTab) { + var shouldFocusLast = lastFocusEvent.shiftKey; + this.focusService.focusInto(this.eGui, shouldFocusLast); } } - var rowDraggingComp = new _rowDragComp__WEBPACK_IMPORTED_MODULE_5__["RowDragComp"](this.rowNode, this.column, this.getValueToUse(), this.beans); - this.createManagedBean(rowDraggingComp, this.beans.context); - // put the checkbox in before the value - this.eCellWrapper.insertBefore(rowDraggingComp.getGui(), this.eParentOfValue); - }; - CellComp.prototype.addDndSource = function () { - var dndSourceComp = new _dndSourceComp__WEBPACK_IMPORTED_MODULE_8__["DndSourceComp"](this.rowNode, this.column, this.getValueToUse(), this.beans, this.getGui()); - this.createManagedBean(dndSourceComp, this.beans.context); - // put the checkbox in before the value - this.eCellWrapper.insertBefore(dndSourceComp.getGui(), this.eParentOfValue); + var rowIndex = this.getRowIndex(); + this.beans.focusService.setFocusedHeader(rowIndex, this.column); }; - CellComp.prototype.addSelectionCheckbox = function () { + HeaderFilterCellCtrl.prototype.setupHover = function () { var _this = this; - var cbSelectionComponent = new _checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_3__["CheckboxSelectionComponent"](); - this.beans.context.createBean(cbSelectionComponent); - var visibleFunc = this.getComponentHolder().checkboxSelection; - visibleFunc = typeof visibleFunc === 'function' ? visibleFunc : null; - cbSelectionComponent.init({ rowNode: this.rowNode, column: this.column, visibleFunc: visibleFunc }); - this.addDestroyFunc(function () { return _this.beans.context.destroyBean(cbSelectionComponent); }); - // put the checkbox in before the value - this.eCellWrapper.insertBefore(cbSelectionComponent.getGui(), this.eParentOfValue); - }; - CellComp.prototype.addDomData = function () { - var _this = this; - var element = this.getGui(); - this.beans.gridOptionsWrapper.setDomData(element, CellComp.DOM_DATA_KEY_CELL_COMP, this); - this.addDestroyFunc(function () { return _this.beans.gridOptionsWrapper.setDomData(element, CellComp.DOM_DATA_KEY_CELL_COMP, null); }); + this.createManagedBean(new _hoverFeature__WEBPACK_IMPORTED_MODULE_10__["HoverFeature"]([this.column], this.eGui)); + var listener = function () { + if (!_this.gridOptionsWrapper.isColumnHoverHighlight()) { + return; + } + var hovered = _this.columnHoverService.isHovered(_this.column); + _this.comp.addOrRemoveCssClass('ag-column-hover', hovered); + }; + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_COLUMN_HOVER_CHANGED, listener); + listener(); }; - CellComp.prototype.isSingleCell = function () { - var rangeController = this.beans.rangeController; - return this.rangeCount === 1 && rangeController && !rangeController.isMoreThanOneCell(); + HeaderFilterCellCtrl.prototype.setupLeft = function () { + var setLeftFeature = new _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_6__["SetLeftFeature"](this.column, this.eGui, this.beans); + this.createManagedBean(setLeftFeature); }; - CellComp.prototype.onCellFocused = function (event) { - var cellFocused = this.beans.focusController.isCellFocused(this.cellPosition); - // see if we need to change the classes on this cell - if (cellFocused !== this.cellFocused) { - // if we are not doing cell selection, then the focus class does not change - var doingFocusCss = !this.beans.gridOptionsWrapper.isSuppressCellSelection(); - if (doingFocusCss) { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), 'ag-cell-focus', cellFocused); - } - this.cellFocused = cellFocused; + HeaderFilterCellCtrl.prototype.setupUserComp = function () { + var _this = this; + if (!this.active) { + return; } - // see if we need to force browser focus - this can happen if focus is programmatically set - if (cellFocused && event && event.forceBrowserFocus) { - var focusEl = this.getFocusableElement(); - focusEl.focus(); - // Fix for AG-3465 "IE11 - After editing cell's content, selection doesn't go one cell below on enter" - // IE can fail to focus the cell after the first call to focus(), and needs a second call - if (!document.activeElement || document.activeElement === document.body) { - focusEl.focus(); - } + var colDef = this.column.getColDef(); + var filterParams = this.filterManager.createFilterParams(this.column, colDef); + var finalFilterParams = this.userComponentFactory.mergeParamsWithApplicationProvidedParams(colDef, _components_framework_componentTypes__WEBPACK_IMPORTED_MODULE_11__["FilterComponent"], filterParams); + var defaultFloatingFilterType = this.userComponentFactory.getDefaultFloatingFilterType(colDef); + if (defaultFloatingFilterType == null) { + defaultFloatingFilterType = 'agReadOnlyFloatingFilter'; } - // if another cell was focused, and we are editing, then stop editing - var fullRowEdit = this.beans.gridOptionsWrapper.isFullRowEdit(); - if (!cellFocused && !fullRowEdit && this.editingCell) { - this.stopRowOrCellEdit(); + var params = { + api: this.gridApi, + column: this.column, + filterParams: finalFilterParams, + currentParentModel: function () { return _this.currentParentModel(); }, + parentFilterInstance: function (cb) { return _this.parentFilterInstance(cb); }, + showParentFilter: function () { return _this.showParentFilter(); }, + suppressFilterButton: false // This one might be overridden from the colDef + }; + // this is unusual - we need a params value OUTSIDE the component the params are for. + // the params are for the floating filter component, but this property is actually for the wrapper. + this.suppressFilterButton = colDef.floatingFilterComponentParams ? !!colDef.floatingFilterComponentParams.suppressFilterButton : false; + var compDetails = this.userComponentFactory.getFloatingFilterCompDetails(colDef, params, defaultFloatingFilterType); + if (compDetails) { + this.comp.setCompDetails(compDetails); } }; - // pass in 'true' to cancel the editing. - CellComp.prototype.stopRowOrCellEdit = function (cancel) { - if (cancel === void 0) { cancel = false; } - if (this.beans.gridOptionsWrapper.isFullRowEdit()) { - this.rowComp.stopRowEditing(cancel); - } - else { - this.stopEditing(cancel); - } + HeaderFilterCellCtrl.prototype.currentParentModel = function () { + var filterComponent = this.getFilterComponent(false); + return filterComponent ? filterComponent.resolveNow(null, function (filter) { return filter && filter.getModel(); }) : null; }; - CellComp.prototype.stopEditing = function (cancel) { - if (cancel === void 0) { cancel = false; } - if (!this.editingCell) { + HeaderFilterCellCtrl.prototype.getFilterComponent = function (createIfDoesNotExist) { + if (createIfDoesNotExist === void 0) { createIfDoesNotExist = true; } + return this.filterManager.getFilterComponent(this.column, 'NO_UI', createIfDoesNotExist); + }; + HeaderFilterCellCtrl.prototype.parentFilterInstance = function (callback) { + var filterComponent = this.getFilterComponent(); + if (filterComponent == null) { return; } - // if no cell editor, this means due to async, that the cell editor never got initialised, - // so we just carry on regardless as if the editing was never started. - if (!this.cellEditor) { - this.editingCell = false; + filterComponent.then(function (instance) { + callback(Object(_gridApi__WEBPACK_IMPORTED_MODULE_5__["unwrapUserComp"])(instance)); + }); + }; + HeaderFilterCellCtrl.prototype.showParentFilter = function () { + var eventSource = this.suppressFilterButton ? this.eFloatingFilterBody : this.eButtonShowMainFilter; + this.menuFactory.showMenuAfterButtonClick(this.column, eventSource, 'floatingFilter', 'filterMenuTab', ['filterMenuTab']); + }; + HeaderFilterCellCtrl.prototype.setupSyncWithFilter = function () { + var _this = this; + if (!this.active) { return; } - var oldValue = this.getValue(); - var newValueExists = false; - var newValue; - if (!cancel) { - // also have another option here to cancel after editing, so for example user could have a popup editor and - // it is closed by user clicking outside the editor. then the editor will close automatically (with false - // passed above) and we need to see if the editor wants to accept the new value. - var userWantsToCancel = this.cellEditor.isCancelAfterEnd && this.cellEditor.isCancelAfterEnd(); - if (!userWantsToCancel) { - newValue = this.cellEditor.getValue(); - newValueExists = true; - } - } - // it is important we set this after setValue() above, as otherwise the cell will flash - // when editing stops. the 'refresh' method checks editing, and doesn't refresh editing cells. - // thus it will skip the refresh on this cell until the end of this method where we call - // refresh directly and we suppress the flash. - this.editingCell = false; - // important to clear this out - as parts of the code will check for - // this to see if an async cellEditor has yet to be created - this.cellEditor = this.beans.context.destroyBean(this.cellEditor); - this.cellEditor = null; - if (this.cellEditorInPopup && this.hideEditorPopup) { - this.hideEditorPopup(); - this.hideEditorPopup = null; - } - else { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].clearElement(this.getGui()); - // put the cell back the way it was before editing - if (this.usingWrapper) { - // if wrapper, then put the wrapper back - this.getGui().appendChild(this.eCellWrapper); - } - else if (this.cellRenderer) { - // if cellRenderer, then put the gui back in. if the renderer has - // a refresh, it will be called. however if it doesn't, then later - // the renderer will be destroyed and a new one will be created. - // we know it's a dom element (not a string) because we converted - // it after the gui was attached if it was a string. - var eCell = this.cellRendererGui; - // can be null if cell was previously null / contained empty string, - // this will result in new value not being rendered. - if (eCell) { - this.getGui().appendChild(eCell); - } + var syncWithFilter = function (filterChangedEvent) { + var compPromise = _this.comp.getFloatingFilterComp(); + if (!compPromise) { + return; } + var parentModel = _this.currentParentModel(); + compPromise.then(function (comp) { + if (comp) { + comp.onParentModelChanged(parentModel, filterChangedEvent); + } + }); + }; + this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_3__["Column"].EVENT_FILTER_CHANGED, syncWithFilter); + if (this.filterManager.isFilterActive(this.column)) { + syncWithFilter(null); } - this.setInlineEditingClass(); - this.refreshHandle(); - if (newValueExists && newValue !== oldValue) { - // we suppressRefreshCell because the call to rowNode.setDataValue() results in change detection - // getting triggered, which results in all cells getting refreshed. we do not want this refresh - // to happen on this call as we want to call it explicitly below. otherwise refresh gets called twice. - // if we only did this refresh (and not the one below) then the cell would flash and not be forced. - this.suppressRefreshCell = true; - this.rowNode.setDataValue(this.column, newValue); - this.suppressRefreshCell = false; - } - // we suppress the flash, as it is not correct to flash the cell the user has finished editing, - // the user doesn't need to flash as they were the one who did the edit, the flash is pointless - // (as the flash is meant to draw the user to a change that they didn't manually do themselves). - this.refreshCell({ forceRefresh: true, suppressFlash: true }); - var event = this.createEvent(null, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_EDITING_STOPPED); - this.beans.eventService.dispatchEvent(event); }; - CellComp.DOM_DATA_KEY_CELL_COMP = 'cellComp'; - CellComp.CELL_RENDERER_TYPE_NORMAL = 'cellRenderer'; - CellComp.CELL_RENDERER_TYPE_PINNED = 'pinnedRowCellRenderer'; - return CellComp; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_2__["Component"])); + HeaderFilterCellCtrl.prototype.setupWidth = function () { + var _this = this; + var listener = function () { + var width = _this.column.getActualWidth() + "px"; + _this.comp.setWidth(width); + }; + this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_3__["Column"].EVENT_WIDTH_CHANGED, listener); + listener(); + }; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('userComponentFactory') + ], HeaderFilterCellCtrl.prototype, "userComponentFactory", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('filterManager') + ], HeaderFilterCellCtrl.prototype, "filterManager", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnHoverService') + ], HeaderFilterCellCtrl.prototype, "columnHoverService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridApi') + ], HeaderFilterCellCtrl.prototype, "gridApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('menuFactory') + ], HeaderFilterCellCtrl.prototype, "menuFactory", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('beans') + ], HeaderFilterCellCtrl.prototype, "beans", void 0); + return HeaderFilterCellCtrl; +}(_abstractCell_abstractHeaderCellCtrl__WEBPACK_IMPORTED_MODULE_0__["AbstractHeaderCellCtrl"])); /***/ }), -/* 102 */ +/* 148 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SelectionHandleType", function() { return SelectionHandleType; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellRangeType", function() { return CellRangeType; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AbstractHeaderCellCtrl", function() { return AbstractHeaderCellCtrl; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _utils_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(49); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var SelectionHandleType; -(function (SelectionHandleType) { - SelectionHandleType[SelectionHandleType["FILL"] = 0] = "FILL"; - SelectionHandleType[SelectionHandleType["RANGE"] = 1] = "RANGE"; -})(SelectionHandleType || (SelectionHandleType = {})); -var CellRangeType; -(function (CellRangeType) { - CellRangeType[CellRangeType["VALUE"] = 0] = "VALUE"; - CellRangeType[CellRangeType["DIMENSION"] = 1] = "DIMENSION"; -})(CellRangeType || (CellRangeType = {})); - - -/***/ }), -/* 103 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowDragComp", function() { return RowDragComp; }); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(68); -/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(104); -/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(44); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(41); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -24309,2217 +32195,1909 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta - - - - -var RowDragComp = /** @class */ (function (_super) { - __extends(RowDragComp, _super); - function RowDragComp(rowNode, column, cellValue, beans) { - var _this = _super.call(this, "
") || this; - _this.rowNode = rowNode; - _this.column = column; - _this.cellValue = cellValue; - _this.beans = beans; +var instanceIdSequence = 0; +var AbstractHeaderCellCtrl = /** @class */ (function (_super) { + __extends(AbstractHeaderCellCtrl, _super); + function AbstractHeaderCellCtrl(columnGroupChild, parentRowCtrl) { + var _this = _super.call(this) || this; + _this.lastFocusEvent = null; + _this.columnGroupChild = columnGroupChild; + _this.parentRowCtrl = parentRowCtrl; + // unique id to this instance, including the column ID to help with debugging in React as it's used in 'key' + _this.instanceId = columnGroupChild.getUniqueId() + '-' + instanceIdSequence++; return _this; } - RowDragComp.prototype.postConstruct = function () { - var eGui = this.getGui(); - eGui.appendChild(_utils__WEBPACK_IMPORTED_MODULE_6__["_"].createIconNoSpan('rowDrag', this.beans.gridOptionsWrapper, null)); - this.addDragSource(); - this.checkCompatibility(); - var strategy = this.beans.gridOptionsWrapper.isRowDragManaged() ? - new ManagedVisibilityStrategy(this, this.beans, this.rowNode, this.column) : - new NonManagedVisibilityStrategy(this, this.beans, this.rowNode, this.column); - this.createManagedBean(strategy, this.beans.context); - }; - RowDragComp.prototype.getSelectedCount = function () { - var multiRowEnabled = this.beans.gridOptionsWrapper.isEnableMultiRowDragging(); - if (!multiRowEnabled) { - return 1; - } - var selection = this.beans.selectionController.getSelectedNodes(); - return selection.indexOf(this.rowNode) !== -1 ? selection.length : 1; + AbstractHeaderCellCtrl.prototype.shouldStopEventPropagation = function (e) { + var _a = this.focusService.getFocusedHeader(), headerRowIndex = _a.headerRowIndex, column = _a.column; + return Object(_utils_keyboard__WEBPACK_IMPORTED_MODULE_2__["isUserSuppressingHeaderKeyboardEvent"])(this.gridOptionsWrapper, e, headerRowIndex, column); }; - // returns true if all compatibility items work out - RowDragComp.prototype.checkCompatibility = function () { - var managed = this.beans.gridOptionsWrapper.isRowDragManaged(); - var treeData = this.beans.gridOptionsWrapper.isTreeData(); - if (treeData && managed) { - _utils__WEBPACK_IMPORTED_MODULE_6__["_"].doOnce(function () { - return console.warn('ag-Grid: If using row drag with tree data, you cannot have rowDragManaged=true'); - }, 'RowDragComp.managedAndTreeData'); - } + AbstractHeaderCellCtrl.prototype.setGui = function (eGui) { + this.eGui = eGui; + this.addDomData(); }; - RowDragComp.prototype.addDragSource = function () { + AbstractHeaderCellCtrl.prototype.addDomData = function () { var _this = this; - var dragItem = { - rowNode: this.rowNode, - columns: [this.column], - defaultTextValue: this.cellValue, - }; - var rowDragText = this.column.getColDef().rowDragText; - var dragSource = { - type: _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_3__["DragSourceType"].RowDrag, - eElement: this.getGui(), - dragItemName: function () { - var dragItemCount = _this.getSelectedCount(); - if (rowDragText) { - return rowDragText(dragItem, dragItemCount); - } - return dragItemCount === 1 ? _this.cellValue : dragItemCount + " rows"; - }, - getDragItem: function () { return dragItem; }, - dragStartPixels: 0 - }; - this.beans.dragAndDropService.addDragSource(dragSource, true); - this.addDestroyFunc(function () { return _this.beans.dragAndDropService.removeDragSource(dragSource); }); + var key = AbstractHeaderCellCtrl.DOM_DATA_KEY_HEADER_CTRL; + this.gridOptionsWrapper.setDomData(this.eGui, key, this); + this.addDestroyFunc(function () { return _this.gridOptionsWrapper.setDomData(_this.eGui, key, null); }); }; - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], RowDragComp.prototype, "postConstruct", null); - return RowDragComp; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); - -var VisibilityStrategy = /** @class */ (function (_super) { - __extends(VisibilityStrategy, _super); - function VisibilityStrategy(parent, rowNode, column) { - var _this = _super.call(this) || this; - _this.parent = parent; - _this.column = column; - _this.rowNode = rowNode; - return _this; - } - VisibilityStrategy.prototype.setDisplayedOrVisible = function (neverDisplayed) { - if (neverDisplayed) { - this.parent.setDisplayed(false); - } - else { - var shown = this.column.isRowDrag(this.rowNode); - var isShownSometimes = _utils__WEBPACK_IMPORTED_MODULE_6__["_"].isFunction(this.column.getColDef().rowDrag); - // if shown sometimes, them some rows can have drag handle while other don't, - // so we use setVisible to keep the handles horizontally aligned (as setVisible - // keeps the empty space, whereas setDisplayed looses the space) - if (isShownSometimes) { - this.parent.setDisplayed(true); - this.parent.setVisible(shown); - } - else { - this.parent.setDisplayed(shown); - } - } + AbstractHeaderCellCtrl.prototype.getGui = function () { + return this.eGui; }; - return VisibilityStrategy; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_5__["BeanStub"])); -// when non managed, the visibility depends on suppressRowDrag property only -var NonManagedVisibilityStrategy = /** @class */ (function (_super) { - __extends(NonManagedVisibilityStrategy, _super); - function NonManagedVisibilityStrategy(parent, beans, rowNode, column) { - var _this = _super.call(this, parent, rowNode, column) || this; - _this.beans = beans; - return _this; - } - NonManagedVisibilityStrategy.prototype.postConstruct = function () { - this.addManagedListener(this.beans.gridOptionsWrapper, 'suppressRowDrag', this.onSuppressRowDrag.bind(this)); - // in case data changes, then we need to update visibility of drag item - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_DATA_CHANGED, this.workOutVisibility.bind(this)); - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_CELL_CHANGED, this.workOutVisibility.bind(this)); - this.workOutVisibility(); + AbstractHeaderCellCtrl.prototype.focus = function (event) { + if (!this.eGui) { + return false; + } + this.lastFocusEvent = event || null; + this.eGui.focus(); + return true; }; - NonManagedVisibilityStrategy.prototype.onSuppressRowDrag = function () { - this.workOutVisibility(); + AbstractHeaderCellCtrl.prototype.getRowIndex = function () { + return this.parentRowCtrl.getRowIndex(); }; - NonManagedVisibilityStrategy.prototype.workOutVisibility = function () { - // only show the drag if both sort and filter are not present - var neverDisplayed = this.beans.gridOptionsWrapper.isSuppressRowDrag(); - this.setDisplayedOrVisible(neverDisplayed); + AbstractHeaderCellCtrl.prototype.getParentRowCtrl = function () { + return this.parentRowCtrl; }; - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], NonManagedVisibilityStrategy.prototype, "postConstruct", null); - return NonManagedVisibilityStrategy; -}(VisibilityStrategy)); -// when managed, the visibility depends on sort, filter and row group, as well as suppressRowDrag property -var ManagedVisibilityStrategy = /** @class */ (function (_super) { - __extends(ManagedVisibilityStrategy, _super); - function ManagedVisibilityStrategy(parent, beans, rowNode, column) { - var _this = _super.call(this, parent, rowNode, column) || this; - _this.beans = beans; - return _this; - } - ManagedVisibilityStrategy.prototype.postConstruct = function () { - // we do not show the component if sort, filter or grouping is active - this.addManagedListener(this.beans.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_SORT_CHANGED, this.workOutVisibility.bind(this)); - this.addManagedListener(this.beans.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_FILTER_CHANGED, this.workOutVisibility.bind(this)); - this.addManagedListener(this.beans.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, this.workOutVisibility.bind(this)); - // in case data changes, then we need to update visibility of drag item - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_DATA_CHANGED, this.workOutVisibility.bind(this)); - this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_CELL_CHANGED, this.workOutVisibility.bind(this)); - this.addManagedListener(this.beans.gridOptionsWrapper, 'suppressRowDrag', this.onSuppressRowDrag.bind(this)); - this.workOutVisibility(); + AbstractHeaderCellCtrl.prototype.getPinned = function () { + return this.parentRowCtrl.getPinned(); }; - ManagedVisibilityStrategy.prototype.onSuppressRowDrag = function () { - this.workOutVisibility(); + AbstractHeaderCellCtrl.prototype.getInstanceId = function () { + return this.instanceId; }; - ManagedVisibilityStrategy.prototype.workOutVisibility = function () { - // only show the drag if both sort and filter are not present - var rowDragFeature = this.beans.gridPanel.getRowDragFeature(); - var shouldPreventRowMove = rowDragFeature && rowDragFeature.shouldPreventRowMove(); - var suppressRowDrag = this.beans.gridOptionsWrapper.isSuppressRowDrag(); - var hasExternalDropZones = this.beans.dragAndDropService.hasExternalDropZones(); - var neverDisplayed = (shouldPreventRowMove && !hasExternalDropZones) || suppressRowDrag; - this.setDisplayedOrVisible(neverDisplayed); + AbstractHeaderCellCtrl.prototype.getColumnGroupChild = function () { + return this.columnGroupChild; }; + AbstractHeaderCellCtrl.DOM_DATA_KEY_HEADER_CTRL = 'headerCtrl'; __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], ManagedVisibilityStrategy.prototype, "postConstruct", null); - return ManagedVisibilityStrategy; -}(VisibilityStrategy)); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('focusService') + ], AbstractHeaderCellCtrl.prototype, "focusService", void 0); + return AbstractHeaderCellCtrl; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); + /***/ }), -/* 104 */ +/* 149 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DragSourceType", function() { return DragSourceType; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "VerticalDirection", function() { return VerticalDirection; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HorizontalDirection", function() { return HorizontalDirection; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DragAndDropService", function() { return DragAndDropService; }); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(41); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "unwrapUserComp", function() { return unwrapUserComp; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridApi", function() { return GridApi; }); +/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(107); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(15); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _interfaces_iExcelCreator__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(150); +/* harmony import */ var _entities_sideBar__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(108); +/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(16); +/* harmony import */ var _interfaces_iClientSideRowModel__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(151); +/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(17); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(13); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(7); +/* harmony import */ var _utils_string__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(26); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(14); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + + + + + + +function unwrapUserComp(comp) { + var compAsAny = comp; + var isProxy = compAsAny != null && compAsAny.getFrameworkComponentInstance != null; + return isProxy ? compAsAny.getFrameworkComponentInstance() : comp; +} +var GridApi = /** @class */ (function () { + function GridApi() { + this.detailGridInfoMap = {}; + this.destroyCalled = false; + } + GridApi.prototype.registerOverlayWrapperComp = function (overlayWrapperComp) { + this.overlayWrapperComp = overlayWrapperComp; + }; + GridApi.prototype.registerSideBarComp = function (sideBarComp) { + this.sideBarComp = sideBarComp; + }; + GridApi.prototype.init = function () { + var _this = this; + switch (this.rowModel.getType()) { + case _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE: + this.clientSideRowModel = this.rowModel; + break; + case _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_INFINITE: + this.infiniteRowModel = this.rowModel; + break; + case _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE: + this.serverSideRowModel = this.rowModel; + break; + } + this.ctrlsService.whenReady(function () { + _this.gridBodyCon = _this.ctrlsService.getGridBodyCtrl(); + }); + }; + /** Used internally by grid. Not intended to be used by the client. Interface may change between releases. */ + GridApi.prototype.__getAlignedGridService = function () { + return this.alignedGridsService; + }; + /** Used internally by grid. Not intended to be used by the client. Interface may change between releases. */ + GridApi.prototype.__getContext = function () { + return this.context; + }; + /** Register a detail grid with the master grid when it is created. */ + GridApi.prototype.addDetailGridInfo = function (id, gridInfo) { + this.detailGridInfoMap[id] = gridInfo; + }; + /** Unregister a detail grid from the master grid when it is destroyed. */ + GridApi.prototype.removeDetailGridInfo = function (id) { + this.detailGridInfoMap[id] = undefined; + }; + /** Returns the `DetailGridInfo` corresponding to the supplied `detailGridId`. */ + GridApi.prototype.getDetailGridInfo = function (id) { + return this.detailGridInfoMap[id]; + }; + /** Iterates through each `DetailGridInfo` in the grid and calls the supplied callback on each. */ + GridApi.prototype.forEachDetailGridInfo = function (callback) { + var index = 0; + Object(_utils_object__WEBPACK_IMPORTED_MODULE_8__["iterateObject"])(this.detailGridInfoMap, function (id, gridInfo) { + // check for undefined, as old references will still be lying around + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(gridInfo)) { + callback(gridInfo, index); + index++; + } + }); + }; + /** Similar to `exportDataAsCsv`, except returns the result as a string rather than download it. */ + GridApi.prototype.getDataAsCsv = function (params) { + if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].CsvExportModule, 'api.getDataAsCsv')) { + return this.csvCreator.getDataAsCsv(params); + } + }; + /** Downloads a CSV export of the grid's data. */ + GridApi.prototype.exportDataAsCsv = function (params) { + if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].CsvExportModule, 'api.exportDataAsCSv')) { + this.csvCreator.exportDataAsCsv(params); + } + }; + GridApi.prototype.getExcelExportMode = function (params) { + var baseParams = this.gridOptionsWrapper.getDefaultExportParams('excel'); + var mergedParams = Object.assign({ exportMode: 'xlsx' }, baseParams, params); + return mergedParams.exportMode; + }; + /** Similar to `exportDataAsExcel`, except instead of downloading a file, it will return a [Blob](https://developer.mozilla.org/en-US/docs/Web/API/Blob) to be processed by the user. */ + GridApi.prototype.getDataAsExcel = function (params) { + if (!_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].ExcelExportModule, 'api.getDataAsExcel')) { + return; + } + var exportMode = this.getExcelExportMode(params); + if (this.excelCreator.getFactoryMode(exportMode) === _interfaces_iExcelCreator__WEBPACK_IMPORTED_MODULE_3__["ExcelFactoryMode"].MULTI_SHEET) { + console.warn('AG Grid: The Excel Exporter is currently on Multi Sheet mode. End that operation by calling `api.getMultipleSheetAsExcel()` or `api.exportMultipleSheetsAsExcel()`'); + return; + } + return this.excelCreator.getDataAsExcel(params); + }; + /** Downloads an Excel export of the grid's data. */ + GridApi.prototype.exportDataAsExcel = function (params) { + if (!_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].ExcelExportModule, 'api.exportDataAsExcel')) { + return; + } + var exportMode = this.getExcelExportMode(params); + if (this.excelCreator.getFactoryMode(exportMode) === _interfaces_iExcelCreator__WEBPACK_IMPORTED_MODULE_3__["ExcelFactoryMode"].MULTI_SHEET) { + console.warn('AG Grid: The Excel Exporter is currently on Multi Sheet mode. End that operation by calling `api.getMultipleSheetAsExcel()` or `api.exportMultipleSheetsAsExcel()`'); + return; + } + this.excelCreator.exportDataAsExcel(params); + }; + /** This is method to be used to get the grid's data as a sheet, that will later be exported either by `getMultipleSheetsAsExcel()` or `exportMultipleSheetsAsExcel()`. */ + GridApi.prototype.getSheetDataForExcel = function (params) { + if (!_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].ExcelExportModule, 'api.getSheetDataForExcel')) { + return; + } + var exportMode = this.getExcelExportMode(params); + this.excelCreator.setFactoryMode(_interfaces_iExcelCreator__WEBPACK_IMPORTED_MODULE_3__["ExcelFactoryMode"].MULTI_SHEET, exportMode); + return this.excelCreator.getSheetDataForExcel(params); + }; + /** Similar to `exportMultipleSheetsAsExcel`, except instead of downloading a file, it will return a [Blob](https://developer.mozilla.org/en-US/docs/Web/API/Blob) to be processed by the user. */ + GridApi.prototype.getMultipleSheetsAsExcel = function (params) { + if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].ExcelExportModule, 'api.getMultipleSheetsAsExcel')) { + return this.excelCreator.getMultipleSheetsAsExcel(params); + } + }; + /** Downloads an Excel export of multiple sheets in one file. */ + GridApi.prototype.exportMultipleSheetsAsExcel = function (params) { + if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].ExcelExportModule, 'api.exportMultipleSheetsAsExcel')) { + return this.excelCreator.exportMultipleSheetsAsExcel(params); + } + }; + /** @deprecated */ + GridApi.prototype.setEnterpriseDatasource = function (datasource) { + console.warn("AG Grid: since version 18.x, api.setEnterpriseDatasource() should be replaced with api.setServerSideDatasource()"); + this.setServerSideDatasource(datasource); + }; + /** + * Sets an ARIA property in the grid panel (element with `role=\"grid\"`), and removes an ARIA property when the value is null. + * + * Example: `api.setGridAriaProperty('label', 'my grid')` will set `aria-label=\"my grid\"`. + * + * `api.setGridAriaProperty('label', null)` will remove the `aria-label` attribute from the grid element. + */ + GridApi.prototype.setGridAriaProperty = function (property, value) { + if (!property) { + return; + } + var eGrid = this.ctrlsService.getGridBodyCtrl().getGui(); + var ariaProperty = "aria-" + property; + if (value === null) { + eGrid.removeAttribute(ariaProperty); + } + else { + eGrid.setAttribute(ariaProperty, value); + } + }; + /** Set new datasource for Server-Side Row Model. */ + GridApi.prototype.setServerSideDatasource = function (datasource) { + if (this.serverSideRowModel) { + // should really have an IEnterpriseRowModel interface, so we are not casting to any + this.serverSideRowModel.setDatasource(datasource); + } + else { + console.warn("AG Grid: you can only use an enterprise datasource when gridOptions.rowModelType is '" + _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE + "'"); + } + }; + /** Set new datasource for Infinite Row Model. */ + GridApi.prototype.setDatasource = function (datasource) { + if (this.gridOptionsWrapper.isRowModelInfinite()) { + this.rowModel.setDatasource(datasource); + } + else { + console.warn("AG Grid: you can only use a datasource when gridOptions.rowModelType is '" + _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_INFINITE + "'"); + } + }; + /** Set new datasource for Viewport Row Model. */ + GridApi.prototype.setViewportDatasource = function (viewportDatasource) { + if (this.gridOptionsWrapper.isRowModelViewport()) { + // this is bad coding, because it's using an interface that's exposed in the enterprise. + // really we should create an interface in the core for viewportDatasource and let + // the enterprise implement it, rather than casting to 'any' here + this.rowModel.setViewportDatasource(viewportDatasource); + } + else { + console.warn("AG Grid: you can only use a viewport datasource when gridOptions.rowModelType is '" + _constants_constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_VIEWPORT + "'"); + } + }; + /** Set the row data. */ + GridApi.prototype.setRowData = function (rowData) { + // immutable service is part of the CSRM module, if missing, no CSRM + var missingImmutableService = this.immutableService == null; + if (missingImmutableService) { + console.warn('AG Grid: you can only set rowData when using the Client Side Row Model'); + return; + } + // if no keys provided provided for rows, then we can tread the operation as Immutable + if (this.immutableService.isActive()) { + this.immutableService.setRowData(rowData); + } + else { + this.selectionService.reset(); + this.clientSideRowModel.setRowData(rowData); + } + }; + /** @deprecated */ + GridApi.prototype.setFloatingTopRowData = function (rows) { + console.warn('AG Grid: since v12, api.setFloatingTopRowData() is now api.setPinnedTopRowData()'); + this.setPinnedTopRowData(rows); + }; + /** @deprecated */ + GridApi.prototype.setFloatingBottomRowData = function (rows) { + console.warn('AG Grid: since v12, api.setFloatingBottomRowData() is now api.setPinnedBottomRowData()'); + this.setPinnedBottomRowData(rows); + }; + /** @deprecated */ + GridApi.prototype.getFloatingTopRowCount = function () { + console.warn('AG Grid: since v12, api.getFloatingTopRowCount() is now api.getPinnedTopRowCount()'); + return this.getPinnedTopRowCount(); + }; + /** @deprecated */ + GridApi.prototype.getFloatingBottomRowCount = function () { + console.warn('AG Grid: since v12, api.getFloatingBottomRowCount() is now api.getPinnedBottomRowCount()'); + return this.getPinnedBottomRowCount(); + }; + /** @deprecated */ + GridApi.prototype.getFloatingTopRow = function (index) { + console.warn('AG Grid: since v12, api.getFloatingTopRow() is now api.getPinnedTopRow()'); + return this.getPinnedTopRow(index); + }; + /** @deprecated */ + GridApi.prototype.getFloatingBottomRow = function (index) { + console.warn('AG Grid: since v12, api.getFloatingBottomRow() is now api.getPinnedBottomRow()'); + return this.getPinnedBottomRow(index); + }; + /** Set the top pinned rows. Call with no rows / undefined to clear top pinned rows. */ + GridApi.prototype.setPinnedTopRowData = function (rows) { + this.pinnedRowModel.setPinnedTopRowData(rows); + }; + /** Set the bottom pinned rows. Call with no rows / undefined to clear bottom pinned rows. */ + GridApi.prototype.setPinnedBottomRowData = function (rows) { + this.pinnedRowModel.setPinnedBottomRowData(rows); + }; + /** Gets the number of top pinned rows. */ + GridApi.prototype.getPinnedTopRowCount = function () { + return this.pinnedRowModel.getPinnedTopRowCount(); + }; + /** Gets the number of bottom pinned rows. */ + GridApi.prototype.getPinnedBottomRowCount = function () { + return this.pinnedRowModel.getPinnedBottomRowCount(); + }; + /** Gets the top pinned row with the specified index. */ + GridApi.prototype.getPinnedTopRow = function (index) { + return this.pinnedRowModel.getPinnedTopRow(index); + }; + /** Gets the top pinned row with the specified index. */ + GridApi.prototype.getPinnedBottomRow = function (index) { + return this.pinnedRowModel.getPinnedBottomRow(index); + }; + /** + * Call to set new column definitions. The grid will redraw all the column headers, and then redraw all of the rows. + */ + GridApi.prototype.setColumnDefs = function (colDefs, source) { + if (source === void 0) { source = "api"; } + this.columnModel.setColumnDefs(colDefs, source); + }; + /** Call to set new auto group column definition. The grid will recreate any auto-group columns if present. */ + GridApi.prototype.setAutoGroupColumnDef = function (colDef, source) { + if (source === void 0) { source = "api"; } + this.gridOptionsWrapper.setProperty('autoGroupColumnDef', colDef, true); + }; + /** Call to set new Default Column Definition. */ + GridApi.prototype.setDefaultColDef = function (colDef, source) { + if (source === void 0) { source = "api"; } + this.gridOptionsWrapper.setProperty('defaultColDef', colDef, true); + }; + GridApi.prototype.expireValueCache = function () { + this.valueCache.expire(); + }; + /** + * Returns an object with two properties: + * - `top`: The top pixel position of the current scroll in the grid + * - `bottom`: The bottom pixel position of the current scroll in the grid + */ + GridApi.prototype.getVerticalPixelRange = function () { + return this.gridBodyCon.getScrollFeature().getVScrollPosition(); + }; + /** + * Returns an object with two properties: + * - `left`: The left pixel position of the current scroll in the grid + * - `right`: The right pixel position of the current scroll in the grid + */ + GridApi.prototype.getHorizontalPixelRange = function () { + return this.gridBodyCon.getScrollFeature().getHScrollPosition(); + }; + /** If `true`, the horizontal scrollbar will always be present, even if not required. Otherwise, it will only be displayed when necessary. */ + GridApi.prototype.setAlwaysShowHorizontalScroll = function (show) { + this.gridOptionsWrapper.setProperty('alwaysShowHorizontalScroll', show); + }; + /** If `true`, the vertical scrollbar will always be present, even if not required. Otherwise it will only be displayed when necessary. */ + GridApi.prototype.setAlwaysShowVerticalScroll = function (show) { + this.gridOptionsWrapper.setProperty('alwaysShowVerticalScroll', show); + }; + /** Force refresh all tool panels by calling their `refresh` method. */ + GridApi.prototype.refreshToolPanel = function () { + if (!this.sideBarComp) { + return; + } + this.sideBarComp.refresh(); }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + /** Performs change detection on all cells, refreshing cells where required. */ + GridApi.prototype.refreshCells = function (params) { + if (params === void 0) { params = {}; } + if (Array.isArray(params)) { + // the old version of refreshCells() took an array of rowNodes for the first argument + console.warn('since AG Grid v11.1, refreshCells() now takes parameters, please see the documentation.'); + return; + } + this.rowRenderer.refreshCells(params); }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - -var DragSourceType; -(function (DragSourceType) { - DragSourceType[DragSourceType["ToolPanel"] = 0] = "ToolPanel"; - DragSourceType[DragSourceType["HeaderCell"] = 1] = "HeaderCell"; - DragSourceType[DragSourceType["RowDrag"] = 2] = "RowDrag"; - DragSourceType[DragSourceType["ChartPanel"] = 3] = "ChartPanel"; -})(DragSourceType || (DragSourceType = {})); -var VerticalDirection; -(function (VerticalDirection) { - VerticalDirection[VerticalDirection["Up"] = 0] = "Up"; - VerticalDirection[VerticalDirection["Down"] = 1] = "Down"; -})(VerticalDirection || (VerticalDirection = {})); -var HorizontalDirection; -(function (HorizontalDirection) { - HorizontalDirection[HorizontalDirection["Left"] = 0] = "Left"; - HorizontalDirection[HorizontalDirection["Right"] = 1] = "Right"; -})(HorizontalDirection || (HorizontalDirection = {})); -var DragAndDropService = /** @class */ (function (_super) { - __extends(DragAndDropService, _super); - function DragAndDropService() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.dragSourceAndParamsList = []; - _this.dropTargets = []; - return _this; - } - DragAndDropService_1 = DragAndDropService; - DragAndDropService.prototype.init = function () { - this.ePinnedIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('columnMovePin', this.gridOptionsWrapper, null); - this.eHideIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('columnMoveHide', this.gridOptionsWrapper, null); - this.eMoveIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('columnMoveMove', this.gridOptionsWrapper, null); - this.eLeftIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('columnMoveLeft', this.gridOptionsWrapper, null); - this.eRightIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('columnMoveRight', this.gridOptionsWrapper, null); - this.eGroupIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('columnMoveGroup', this.gridOptionsWrapper, null); - this.eAggregateIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('columnMoveValue', this.gridOptionsWrapper, null); - this.ePivotIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('columnMovePivot', this.gridOptionsWrapper, null); - this.eDropNotAllowedIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('dropNotAllowed', this.gridOptionsWrapper, null); + /** Flash rows, columns or individual cells. */ + GridApi.prototype.flashCells = function (params) { + if (params === void 0) { params = {}; } + this.rowRenderer.flashCells(params); }; - DragAndDropService.prototype.addDragSource = function (dragSource, allowTouch) { - if (allowTouch === void 0) { allowTouch = false; } - var params = { - eElement: dragSource.eElement, - dragStartPixels: dragSource.dragStartPixels, - onDragStart: this.onDragStart.bind(this, dragSource), - onDragStop: this.onDragStop.bind(this), - onDragging: this.onDragging.bind(this) - }; - this.dragSourceAndParamsList.push({ params: params, dragSource: dragSource }); - this.dragService.addDragSource(params, allowTouch); + /** Remove row(s) from the DOM and recreate them again from scratch. */ + GridApi.prototype.redrawRows = function (params) { + if (params === void 0) { params = {}; } + var rowNodes = params ? params.rowNodes : undefined; + this.rowRenderer.redrawRows(rowNodes); }; - DragAndDropService.prototype.removeDragSource = function (dragSource) { - var sourceAndParams = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].find(this.dragSourceAndParamsList, function (item) { return item.dragSource === dragSource; }); - if (sourceAndParams) { - this.dragService.removeDragSource(sourceAndParams.params); - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].removeFromArray(this.dragSourceAndParamsList, sourceAndParams); - } + GridApi.prototype.setFunctionsReadOnly = function (readOnly) { + this.gridOptionsWrapper.setProperty('functionsReadOnly', readOnly); }; - DragAndDropService.prototype.clearDragSourceParamsList = function () { - var _this = this; - this.dragSourceAndParamsList.forEach(function (sourceAndParams) { return _this.dragService.removeDragSource(sourceAndParams.params); }); - this.dragSourceAndParamsList.length = 0; + /** Redraws the header. Useful if a column name changes, or something else that changes how the column header is displayed. */ + GridApi.prototype.refreshHeader = function () { + this.ctrlsService.getHeaderRowContainerCtrls().forEach(function (c) { return c.refresh(); }); }; - DragAndDropService.prototype.nudge = function () { - if (this.dragging) { - this.onDragging(this.eventLastTime, true); - } + /** Returns `true` if any filter is set. This includes quick filter, advanced filter or external filter. */ + GridApi.prototype.isAnyFilterPresent = function () { + return this.filterManager.isAnyFilterPresent(); }; - DragAndDropService.prototype.onDragStart = function (dragSource, mouseEvent) { - this.dragging = true; - this.dragSource = dragSource; - this.eventLastTime = mouseEvent; - this.dragItem = this.dragSource.getDragItem(); - this.lastDropTarget = this.dragSource.dragSourceDropTarget; - if (this.dragSource.onDragStarted) { - this.dragSource.onDragStarted(); + /** Returns `true` if any column filter is set, otherwise `false`. */ + GridApi.prototype.isColumnFilterPresent = function () { + return this.filterManager.isAdvancedFilterPresent(); + }; + /** Returns `true` if the quick filter is set, otherwise `false`. */ + GridApi.prototype.isQuickFilterPresent = function () { + return this.filterManager.isQuickFilterPresent(); + }; + /** + * Returns the row model inside the table. + * From here you can see the original rows, rows after filter has been applied, + * rows after aggregation has been applied, and the final set of 'to be displayed' rows. + */ + GridApi.prototype.getModel = function () { + return this.rowModel; + }; + /** Expand or collapse a specific row node. */ + GridApi.prototype.setRowNodeExpanded = function (rowNode, expanded) { + if (rowNode) { + rowNode.setExpanded(expanded); } - this.createGhost(); }; - DragAndDropService.prototype.onDragStop = function (mouseEvent) { - this.eventLastTime = null; - this.dragging = false; - if (this.dragSource.onDragStopped) { - this.dragSource.onDragStopped(); + /** + * If after getting the model, you expand or collapse a group, call this method to inform the grid. + * It will work out the final set of 'to be displayed' rows again (i.e. expand or collapse the group visually). + */ + GridApi.prototype.onGroupExpandedOrCollapsed = function (deprecated_refreshFromIndex) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(this.clientSideRowModel)) { + console.warn('AG Grid: cannot call onGroupExpandedOrCollapsed unless using normal row model'); } - if (this.lastDropTarget && this.lastDropTarget.onDragStop) { - var draggingEvent = this.createDropTargetEvent(this.lastDropTarget, mouseEvent, null, null, false); - this.lastDropTarget.onDragStop(draggingEvent); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(deprecated_refreshFromIndex)) { + console.warn('AG Grid: api.onGroupExpandedOrCollapsed - refreshFromIndex parameter is no longer used, the grid will refresh all rows'); } - this.lastDropTarget = null; - this.dragItem = null; - this.removeGhost(); + // we don't really want the user calling this if only one rowNode was expanded, instead they should be + // calling rowNode.setExpanded(boolean) - this way we do a 'keepRenderedRows=false' so that the whole + // grid gets refreshed again - otherwise the row with the rowNodes that were changed won't get updated, + // and thus the expand icon in the group cell won't get 'opened' or 'closed'. + this.clientSideRowModel.refreshModel({ step: _interfaces_iClientSideRowModel__WEBPACK_IMPORTED_MODULE_6__["ClientSideRowModelSteps"].MAP }); }; - DragAndDropService.prototype.onDragging = function (mouseEvent, fromNudge) { - var hDirection = this.getHorizontalDirection(mouseEvent); - var vDirection = this.getVerticalDirection(mouseEvent); - this.eventLastTime = mouseEvent; - this.positionGhost(mouseEvent); - // check if mouseEvent intersects with any of the drop targets - var dropTarget = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].find(this.dropTargets, this.isMouseOnDropTarget.bind(this, mouseEvent)); - if (dropTarget !== this.lastDropTarget) { - this.leaveLastTargetIfExists(mouseEvent, hDirection, vDirection, fromNudge); - this.enterDragTargetIfExists(dropTarget, mouseEvent, hDirection, vDirection, fromNudge); - this.lastDropTarget = dropTarget; + GridApi.prototype.refreshInMemoryRowModel = function (step) { + console.warn("ag-grid: since version 18.x, api.refreshInMemoryRowModel() should be replaced with api.refreshClientSideRowModel()"); + this.refreshClientSideRowModel(step); + }; + /** Gets the Client-Side Row Model to refresh, executing the grouping, filtering and sorting again. */ + GridApi.prototype.refreshClientSideRowModel = function (step) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(this.clientSideRowModel)) { + console.warn('cannot call refreshClientSideRowModel unless using normal row model'); } - else if (dropTarget && dropTarget.onDragging) { - var draggingEvent = this.createDropTargetEvent(dropTarget, mouseEvent, hDirection, vDirection, fromNudge); - dropTarget.onDragging(draggingEvent); + var paramsStep = _interfaces_iClientSideRowModel__WEBPACK_IMPORTED_MODULE_6__["ClientSideRowModelSteps"].EVERYTHING; + var stepsMapped = { + group: _interfaces_iClientSideRowModel__WEBPACK_IMPORTED_MODULE_6__["ClientSideRowModelSteps"].EVERYTHING, + filter: _interfaces_iClientSideRowModel__WEBPACK_IMPORTED_MODULE_6__["ClientSideRowModelSteps"].FILTER, + map: _interfaces_iClientSideRowModel__WEBPACK_IMPORTED_MODULE_6__["ClientSideRowModelSteps"].MAP, + aggregate: _interfaces_iClientSideRowModel__WEBPACK_IMPORTED_MODULE_6__["ClientSideRowModelSteps"].AGGREGATE, + sort: _interfaces_iClientSideRowModel__WEBPACK_IMPORTED_MODULE_6__["ClientSideRowModelSteps"].SORT, + pivot: _interfaces_iClientSideRowModel__WEBPACK_IMPORTED_MODULE_6__["ClientSideRowModelSteps"].PIVOT + }; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(step)) { + paramsStep = stepsMapped[step]; } - }; - DragAndDropService.prototype.enterDragTargetIfExists = function (dropTarget, mouseEvent, hDirection, vDirection, fromNudge) { - if (!dropTarget) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(paramsStep)) { + console.error("AG Grid: invalid step " + step + ", available steps are " + Object.keys(stepsMapped).join(', ')); return; } - if (dropTarget.onDragEnter) { - var dragEnterEvent = this.createDropTargetEvent(dropTarget, mouseEvent, hDirection, vDirection, fromNudge); - dropTarget.onDragEnter(dragEnterEvent); + var animate = !this.gridOptionsWrapper.isSuppressAnimationFrame(); + var modelParams = { + step: paramsStep, + keepRenderedRows: true, + keepEditingRows: true, + animate: animate + }; + this.clientSideRowModel.refreshModel(modelParams); + }; + /** Returns `true` when there are no more animation frames left to process. */ + GridApi.prototype.isAnimationFrameQueueEmpty = function () { + return this.animationFrameService.isQueueEmpty(); + }; + GridApi.prototype.flushAllAnimationFrames = function () { + this.animationFrameService.flushAllFrames(); + }; + /** + * Returns the row node with the given ID. + * The row node ID is the one you provide from the callback `getRowNodeId(data)`, + * otherwise the ID is a number (cast as string) auto-generated by the grid when + * the row data is set. + */ + GridApi.prototype.getRowNode = function (id) { + return this.rowModel.getRowNode(id); + }; + /** + * Gets the sizes that various UI elements will be rendered at with the current theme. + * If you override the row or header height using `gridOptions`, the override value you provided will be returned. + */ + GridApi.prototype.getSizesForCurrentTheme = function () { + return { + rowHeight: this.gridOptionsWrapper.getRowHeightAsNumber(), + headerHeight: this.gridOptionsWrapper.getHeaderHeight() + }; + }; + /** Expand all groups. */ + GridApi.prototype.expandAll = function () { + if (this.clientSideRowModel) { + this.clientSideRowModel.expandOrCollapseAll(true); + } + else if (this.serverSideRowModel) { + this.serverSideRowModel.expandAll(true); + } + else { + console.warn('AG Grid: expandAll only works with Client Side Row Model and Server Side Row Model'); } - this.setGhostIcon(dropTarget.getIconName ? dropTarget.getIconName() : null); }; - DragAndDropService.prototype.leaveLastTargetIfExists = function (mouseEvent, hDirection, vDirection, fromNudge) { - if (!this.lastDropTarget) { - return; + /** Collapse all groups. */ + GridApi.prototype.collapseAll = function () { + if (this.clientSideRowModel) { + this.clientSideRowModel.expandOrCollapseAll(false); } - if (this.lastDropTarget.onDragLeave) { - var dragLeaveEvent = this.createDropTargetEvent(this.lastDropTarget, mouseEvent, hDirection, vDirection, fromNudge); - this.lastDropTarget.onDragLeave(dragLeaveEvent); + else if (this.serverSideRowModel) { + this.serverSideRowModel.expandAll(false); + } + else { + console.warn('AG Grid: collapseAll only works with Client Side Row Model and Server Side Row Model'); } - this.setGhostIcon(null); }; - DragAndDropService.prototype.getAllContainersFromDropTarget = function (dropTarget) { - var containers = [dropTarget.getContainer()]; - var secondaryContainers = dropTarget.getSecondaryContainers ? dropTarget.getSecondaryContainers() : null; - if (secondaryContainers) { - containers = containers.concat(secondaryContainers); + /** Gets the tool panel instance corresponding to the supplied `id`. */ + GridApi.prototype.getToolPanelInstance = function (id) { + if (!this.sideBarComp) { + console.warn('AG Grid: toolPanel is only available in AG Grid Enterprise'); + return; } - return containers; + var comp = this.sideBarComp.getToolPanelInstance(id); + return unwrapUserComp(comp); }; - // checks if the mouse is on the drop target. it checks eContainer and eSecondaryContainers - DragAndDropService.prototype.isMouseOnDropTarget = function (mouseEvent, dropTarget) { - var mouseOverTarget = false; - this.getAllContainersFromDropTarget(dropTarget) - .filter(function (eContainer) { return eContainer; }) // secondary can be missing - .forEach(function (eContainer) { - var rect = eContainer.getBoundingClientRect(); - // if element is not visible, then width and height are zero - if (rect.width === 0 || rect.height === 0) { - return; - } - var horizontalFit = mouseEvent.clientX >= rect.left && mouseEvent.clientX <= rect.right; - var verticalFit = mouseEvent.clientY >= rect.top && mouseEvent.clientY <= rect.bottom; - if (horizontalFit && verticalFit) { - mouseOverTarget = true; - } - }); - return mouseOverTarget && dropTarget.isInterestedIn(this.dragSource.type); + GridApi.prototype.addVirtualRowListener = function (eventName, rowIndex, callback) { + if (typeof eventName !== 'string') { + console.warn('AG Grid: addVirtualRowListener is deprecated, please use addRenderedRowListener.'); + } + this.addRenderedRowListener(eventName, rowIndex, callback); }; - DragAndDropService.prototype.addDropTarget = function (dropTarget) { - this.dropTargets.push(dropTarget); + /** + * Registers a callback to a virtual row. + * A virtual row is a row that is visually rendered on the screen (rows that are not visible because of the scroll position are not rendered). + * Unlike normal events, you do not need to unregister rendered row listeners. + * When the rendered row is removed from the grid, all associated rendered row listeners will also be removed. + * Currently supports only one event, `virtualRowRemoved`; + * listen for this event if your `cellRenderer` needs to do cleanup when the row no longer exists. + */ + GridApi.prototype.addRenderedRowListener = function (eventName, rowIndex, callback) { + if (eventName === 'virtualRowSelected') { + console.warn("AG Grid: event virtualRowSelected is deprecated, to register for individual row\n selection events, add a listener directly to the row node."); + } + this.rowRenderer.addRenderedRowListener(eventName, rowIndex, callback); }; - DragAndDropService.prototype.removeDropTarget = function (dropTarget) { - this.dropTargets = this.dropTargets.filter(function (target) { return target.getContainer() !== dropTarget.getContainer(); }); + /** Pass a quick filter text into the grid for filtering. */ + GridApi.prototype.setQuickFilter = function (newFilter) { + this.filterManager.setQuickFilter(newFilter); }; - DragAndDropService.prototype.hasExternalDropZones = function () { - return this.dropTargets.some(function (zones) { return zones.external; }); + GridApi.prototype.selectIndex = function (index, tryMulti, suppressEvents) { + console.warn('AG Grid: do not use api for selection, call node.setSelected(value) instead'); + if (suppressEvents) { + console.warn('AG Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it'); + } + this.selectionService.selectIndex(index, tryMulti); }; - DragAndDropService.prototype.findExternalZone = function (params) { - var externalTargets = this.dropTargets.filter(function (target) { return target.external; }); - return _utils__WEBPACK_IMPORTED_MODULE_2__["_"].find(externalTargets, function (zone) { return zone.getContainer() === params.getContainer(); }); + GridApi.prototype.deselectIndex = function (index, suppressEvents) { + if (suppressEvents === void 0) { suppressEvents = false; } + console.warn('AG Grid: do not use api for selection, call node.setSelected(value) instead'); + if (suppressEvents) { + console.warn('AG Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it'); + } + this.selectionService.deselectIndex(index); }; - DragAndDropService.prototype.getHorizontalDirection = function (event) { - var clientX = this.eventLastTime.clientX; - var eClientX = event.clientX; - if (clientX === eClientX) { - return null; + GridApi.prototype.selectNode = function (node, tryMulti, suppressEvents) { + if (tryMulti === void 0) { tryMulti = false; } + if (suppressEvents === void 0) { suppressEvents = false; } + console.warn('AG Grid: API for selection is deprecated, call node.setSelected(value) instead'); + if (suppressEvents) { + console.warn('AG Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it'); } - return clientX > eClientX ? HorizontalDirection.Left : HorizontalDirection.Right; + node.setSelectedParams({ newValue: true, clearSelection: !tryMulti }); }; - DragAndDropService.prototype.getVerticalDirection = function (event) { - var clientY = this.eventLastTime.clientY; - var eClientY = event.clientY; - if (clientY === eClientY) { - return null; + GridApi.prototype.deselectNode = function (node, suppressEvents) { + if (suppressEvents === void 0) { suppressEvents = false; } + console.warn('AG Grid: API for selection is deprecated, call node.setSelected(value) instead'); + if (suppressEvents) { + console.warn('AG Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it'); } - return clientY > eClientY ? VerticalDirection.Up : VerticalDirection.Down; + node.setSelectedParams({ newValue: false }); }; - DragAndDropService.prototype.createDropTargetEvent = function (dropTarget, event, hDirection, vDirection, fromNudge) { - // localise x and y to the target - var dropZoneTarget = dropTarget.getContainer(); - var rect = dropZoneTarget.getBoundingClientRect(); - var _a = this, api = _a.gridApi, columnApi = _a.columnApi, dragItem = _a.dragItem, dragSource = _a.dragSource; - var x = event.clientX - rect.left; - var y = event.clientY - rect.top; - return { event: event, x: x, y: y, vDirection: vDirection, hDirection: hDirection, dragSource: dragSource, fromNudge: fromNudge, dragItem: dragItem, api: api, columnApi: columnApi, dropZoneTarget: dropZoneTarget }; + /** Select all rows, regardless of filtering and rows that are not visible due to grouping being enabled and their groups not expanded. */ + GridApi.prototype.selectAll = function () { + this.selectionService.selectAllRowNodes(); }; - DragAndDropService.prototype.positionGhost = function (event) { - var ghost = this.eGhost; - var ghostRect = ghost.getBoundingClientRect(); - var ghostHeight = ghostRect.height; - // for some reason, without the '-2', it still overlapped by 1 or 2 pixels, which - // then brought in scrollbars to the browser. no idea why, but putting in -2 here - // works around it which is good enough for me. - var browserWidth = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].getBodyWidth() - 2; - var browserHeight = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].getBodyHeight() - 2; - var top = event.pageY - (ghostHeight / 2); - var left = event.pageX - 10; - var usrDocument = this.gridOptionsWrapper.getDocument(); - var windowScrollY = window.pageYOffset || usrDocument.documentElement.scrollTop; - var windowScrollX = window.pageXOffset || usrDocument.documentElement.scrollLeft; - // check ghost is not positioned outside of the browser - if (browserWidth > 0 && ((left + ghost.clientWidth) > (browserWidth + windowScrollX))) { - left = browserWidth + windowScrollX - ghost.clientWidth; - } - if (left < 0) { - left = 0; - } - if (browserHeight > 0 && ((top + ghost.clientHeight) > (browserHeight + windowScrollY))) { - top = browserHeight + windowScrollY - ghost.clientHeight; + /** Clear all row selections, regardless of filtering. */ + GridApi.prototype.deselectAll = function () { + this.selectionService.deselectAllRowNodes(); + }; + /** Select all filtered rows. */ + GridApi.prototype.selectAllFiltered = function () { + this.selectionService.selectAllRowNodes(true); + }; + /** Clear all filtered selections. */ + GridApi.prototype.deselectAllFiltered = function () { + this.selectionService.deselectAllRowNodes(true); + }; + GridApi.prototype.recomputeAggregates = function () { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(this.clientSideRowModel)) { + console.warn('cannot call recomputeAggregates unless using normal row model'); } - if (top < 0) { - top = 0; + console.warn("recomputeAggregates is deprecated, please call api.refreshClientSideRowModel('aggregate') instead"); + this.clientSideRowModel.refreshModel({ step: _interfaces_iClientSideRowModel__WEBPACK_IMPORTED_MODULE_6__["ClientSideRowModelSteps"].AGGREGATE }); + }; + /** Sets columns to adjust in size to fit the grid horizontally. */ + GridApi.prototype.sizeColumnsToFit = function () { + this.gridBodyCon.sizeColumnsToFit(); + }; + /** Show the 'loading' overlay. */ + GridApi.prototype.showLoadingOverlay = function () { + this.overlayWrapperComp.showLoadingOverlay(); + }; + /** Show the 'no rows' overlay. */ + GridApi.prototype.showNoRowsOverlay = function () { + this.overlayWrapperComp.showNoRowsOverlay(); + }; + /** Hides the overlay if showing. */ + GridApi.prototype.hideOverlay = function () { + this.overlayWrapperComp.hideOverlay(); + }; + GridApi.prototype.isNodeSelected = function (node) { + console.warn('AG Grid: no need to call api.isNodeSelected(), just call node.isSelected() instead'); + return node.isSelected(); + }; + GridApi.prototype.getSelectedNodesById = function () { + console.error('AG Grid: since version 3.4, getSelectedNodesById no longer exists, use getSelectedNodes() instead'); + return null; + }; + /** + * Returns a list of selected nodes. + * Getting the underlying node (rather than the data) is useful when working with tree / aggregated data, + * as the node can be traversed. + */ + GridApi.prototype.getSelectedNodes = function () { + return this.selectionService.getSelectedNodes(); + }; + /** Returns a list of selected rows (i.e. row data that you provided). */ + GridApi.prototype.getSelectedRows = function () { + return this.selectionService.getSelectedRows(); + }; + /** + * Returns a list of all selected nodes at 'best cost', a feature to be used with groups / trees. + * If a group has all its children selected, then the group appears in the result, but not the children. + * Designed for use with `'children'` as the group selection type, where groups don't actually appear in the selection normally. + */ + GridApi.prototype.getBestCostNodeSelection = function () { + return this.selectionService.getBestCostNodeSelection(); + }; + /** Retrieve rendered nodes. Due to virtualisation this will contain only the current visible rows and those in the buffer. */ + GridApi.prototype.getRenderedNodes = function () { + return this.rowRenderer.getRenderedNodes(); + }; + GridApi.prototype.ensureColIndexVisible = function (index) { + console.warn('AG Grid: ensureColIndexVisible(index) no longer supported, use ensureColumnVisible(colKey) instead.'); + }; + /** + * Ensures the column is visible by scrolling the table if needed. + * @param key - The column to ensure visible + * @param position - Where the column will be positioned. + * - `auto` - Scrolls the minimum amount to make sure the column is visible. + * - `start` - Scrolls the column to the start of the viewport. + * - `middle` - Scrolls the column to the middle of the viewport. + * - `end` - Scrolls the column to the end of the viewport. + */ + GridApi.prototype.ensureColumnVisible = function (key, position) { + if (position === void 0) { position = 'auto'; } + this.gridBodyCon.getScrollFeature().ensureColumnVisible(key, position); + }; + /** + * Ensures the row index is visible by vertically scrolling the grid. + * If a position of `'top'`, `'middle'` or `'bottom'` is supplied, the grid will scroll the grid to place the row at the top, middle or bottom respectively. + * Otherwise, the grid will do the minimum scrolling possible to show the row. + * i.e. + * - if the grid needs to scroll up then it will scroll so that the row is at the top, + * - if the grid needs to scroll down then it will scroll so that the row is at the bottom, + * - if the row is already in view then the grid will do nothing. + */ + GridApi.prototype.ensureIndexVisible = function (index, position) { + this.gridBodyCon.getScrollFeature().ensureIndexVisible(index, position); + }; + /** + * Ensures a row node is visible, scrolling the grid if needed. + * Provide either: + * - the node, + * - the data object + * - a comparator function (that takes the node as a parameter, and returns `true` for match or `false` for no match). + */ + GridApi.prototype.ensureNodeVisible = function (comparator, position) { + if (position === void 0) { position = null; } + this.gridBodyCon.getScrollFeature().ensureNodeVisible(comparator, position); + }; + /** + * Similar to `forEachNode`, except lists all the leaf nodes. + * This effectively goes through all the data that you provided to the grid before the grid performed any grouping. + * If using tree data, goes through all the nodes for the data you provided, including nodes that have children, + * but excluding groups the grid created where gaps were missing in the hierarchy. + */ + GridApi.prototype.forEachLeafNode = function (callback) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(this.clientSideRowModel)) { + console.warn('cannot call forEachNode unless using normal row model'); } - ghost.style.left = left + "px"; - ghost.style.top = top + "px"; + this.clientSideRowModel.forEachLeafNode(callback); }; - DragAndDropService.prototype.removeGhost = function () { - if (this.eGhost && this.eGhostParent) { - this.eGhostParent.removeChild(this.eGhost); + /** + * Iterates through each node (row) in the grid and calls the callback for each node. + * This works similar to the `forEach` method on a JavaScript array. + * This is called for every node, ignoring any filtering or sorting applied within the grid. + * If using the Infinite Row Model, then this gets called for each page loaded in the page cache. + */ + GridApi.prototype.forEachNode = function (callback) { + this.rowModel.forEachNode(callback); + }; + /** Similar to `forEachNode`, except skips any filtered out data. */ + GridApi.prototype.forEachNodeAfterFilter = function (callback) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(this.clientSideRowModel)) { + console.warn('cannot call forEachNodeAfterFilter unless using normal row model'); } - this.eGhost = null; + this.clientSideRowModel.forEachNodeAfterFilter(callback); }; - DragAndDropService.prototype.createGhost = function () { - this.eGhost = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].loadTemplate(DragAndDropService_1.GHOST_TEMPLATE); - var theme = this.environment.getTheme().theme; - if (theme) { - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(this.eGhost, theme); + /** Similar to `forEachNodeAfterFilter`, except the callbacks are called in the order the rows are displayed in the grid. */ + GridApi.prototype.forEachNodeAfterFilterAndSort = function (callback) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(this.clientSideRowModel)) { + console.warn('cannot call forEachNodeAfterFilterAndSort unless using normal row model'); } - this.eGhostIcon = this.eGhost.querySelector('.ag-dnd-ghost-icon'); - this.setGhostIcon(null); - var eText = this.eGhost.querySelector('.ag-dnd-ghost-label'); - var dragItemName = this.dragSource.dragItemName; - if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].isFunction(dragItemName)) { - dragItemName = dragItemName(); + this.clientSideRowModel.forEachNodeAfterFilterAndSort(callback); + }; + /** + * Returns the filter component instance for a column. + * `key` can be a string field name or a ColDef object (matches on object reference, useful if field names are not unique). + * If your filter is created asynchronously, `getFilterInstance` will return `null` so you will need to use the `callback` to access the filter instance instead. + */ + GridApi.prototype.getFilterInstance = function (key, callback) { + var res = this.getFilterInstanceImpl(key, function (instance) { + if (!callback) { + return; + } + var unwrapped = unwrapUserComp(instance); + callback(unwrapped); + }); + var unwrapped = unwrapUserComp(res); + return unwrapped; + }; + GridApi.prototype.getFilterInstanceImpl = function (key, callback) { + var column = this.columnModel.getPrimaryColumn(key); + if (!column) { + return undefined; } - eText.innerHTML = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].escape(dragItemName); - this.eGhost.style.height = '25px'; - this.eGhost.style.top = '20px'; - this.eGhost.style.left = '20px'; - var usrDocument = this.gridOptionsWrapper.getDocument(); - this.eGhostParent = usrDocument.querySelector('body'); - if (!this.eGhostParent) { - console.warn('ag-Grid: could not find document body, it is needed for dragging columns'); + var filterPromise = this.filterManager.getFilterComponent(column, 'NO_UI'); + var currentValue = filterPromise && filterPromise.resolveNow(null, function (filterComp) { return filterComp; }); + if (currentValue) { + setTimeout(callback, 0, currentValue); } - else { - this.eGhostParent.appendChild(this.eGhost); + else if (filterPromise) { + filterPromise.then(function (comp) { + callback(comp); + }); } + return currentValue; }; - DragAndDropService.prototype.setGhostIcon = function (iconName, shake) { - if (shake === void 0) { shake = false; } - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].clearElement(this.eGhostIcon); - var eIcon; - if (!iconName) { - iconName = this.dragSource.defaultIconName || DragAndDropService_1.ICON_NOT_ALLOWED; - } - switch (iconName) { - case DragAndDropService_1.ICON_PINNED: - eIcon = this.ePinnedIcon; - break; - case DragAndDropService_1.ICON_MOVE: - eIcon = this.eMoveIcon; - break; - case DragAndDropService_1.ICON_LEFT: - eIcon = this.eLeftIcon; - break; - case DragAndDropService_1.ICON_RIGHT: - eIcon = this.eRightIcon; - break; - case DragAndDropService_1.ICON_GROUP: - eIcon = this.eGroupIcon; - break; - case DragAndDropService_1.ICON_AGGREGATE: - eIcon = this.eAggregateIcon; - break; - case DragAndDropService_1.ICON_PIVOT: - eIcon = this.ePivotIcon; - break; - case DragAndDropService_1.ICON_NOT_ALLOWED: - eIcon = this.eDropNotAllowedIcon; - break; - case DragAndDropService_1.ICON_HIDE: - eIcon = this.eHideIcon; - break; + /** Destroys a filter. Useful to force a particular filter to be created from scratch again. */ + GridApi.prototype.destroyFilter = function (key) { + var column = this.columnModel.getPrimaryColumn(key); + if (column) { + return this.filterManager.destroyFilter(column, "filterDestroyed"); } - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(this.eGhostIcon, 'ag-shake-left-to-right', shake); - if (eIcon === this.eHideIcon && this.gridOptionsWrapper.isSuppressDragLeaveHidesColumns()) { + }; + /** Gets the status panel instance corresponding to the supplied `id`. */ + GridApi.prototype.getStatusPanel = function (key) { + if (!this.statusBarService) { return; } - if (eIcon) { - this.eGhostIcon.appendChild(eIcon); + var comp = this.statusBarService.getStatusPanel(key); + return unwrapUserComp(comp); + }; + GridApi.prototype.getColumnDef = function (key) { + var column = this.columnModel.getPrimaryColumn(key); + if (column) { + return column.getColDef(); } + return null; }; - var DragAndDropService_1; - DragAndDropService.ICON_PINNED = 'pinned'; - DragAndDropService.ICON_MOVE = 'move'; - DragAndDropService.ICON_LEFT = 'left'; - DragAndDropService.ICON_RIGHT = 'right'; - DragAndDropService.ICON_GROUP = 'group'; - DragAndDropService.ICON_AGGREGATE = 'aggregate'; - DragAndDropService.ICON_PIVOT = 'pivot'; - DragAndDropService.ICON_NOT_ALLOWED = 'notAllowed'; - DragAndDropService.ICON_HIDE = 'hide'; - DragAndDropService.GHOST_TEMPLATE = "
\n \n
\n
"; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], DragAndDropService.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('dragService') - ], DragAndDropService.prototype, "dragService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('environment') - ], DragAndDropService.prototype, "environment", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnApi') - ], DragAndDropService.prototype, "columnApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridApi') - ], DragAndDropService.prototype, "gridApi", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], DragAndDropService.prototype, "init", null); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PreDestroy"] - ], DragAndDropService.prototype, "clearDragSourceParamsList", null); - DragAndDropService = DragAndDropService_1 = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('dragAndDropService') - ], DragAndDropService); - return DragAndDropService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); - - - -/***/ }), -/* 105 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PopupEditorWrapper", function() { return PopupEditorWrapper; }); -/* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(55); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + /** + * Returns the current column definitions. + */ + GridApi.prototype.getColumnDefs = function () { return this.columnModel.getColumnDefs(); }; + /** Informs the grid that a filter has changed. This is typically called after a filter change through one of the filter APIs. */ + GridApi.prototype.onFilterChanged = function () { + this.filterManager.onFilterChanged(); }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + /** + * Gets the grid to act as if the sort was changed. + * Useful if you update some values and want to get the grid to reorder them according to the new values. + */ + GridApi.prototype.onSortChanged = function () { + this.sortController.onSortChanged(); + }; + /** Sets the state of all the advanced filters. Provide it with what you get from `getFilterModel()` to restore filter state. */ + GridApi.prototype.setFilterModel = function (model) { + this.filterManager.setFilterModel(model); + }; + /** Gets the current state of all the advanced filters. Used for saving filter state. */ + GridApi.prototype.getFilterModel = function () { + return this.filterManager.getFilterModel(); + }; + /** Returns the focused cell (or the last focused cell if the grid lost focus). */ + GridApi.prototype.getFocusedCell = function () { + return this.focusService.getFocusedCell(); + }; + /** Clears the focused cell. */ + GridApi.prototype.clearFocusedCell = function () { + return this.focusService.clearFocusedCell(); + }; + /** Sets the focus to the specified cell. `rowPinned` can be either 'top', 'bottom' or null (for not pinned). */ + GridApi.prototype.setFocusedCell = function (rowIndex, colKey, rowPinned) { + this.focusService.setFocusedCell(rowIndex, colKey, rowPinned, true); + }; + /** Sets the `suppressRowDrag` property. */ + GridApi.prototype.setSuppressRowDrag = function (value) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_SUPPRESS_ROW_DRAG, value); + }; + /** Sets the `suppressMoveWhenRowDragging` property. */ + GridApi.prototype.setSuppressMoveWhenRowDragging = function (value) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_SUPPRESS_MOVE_WHEN_ROW_DRAG, value); + }; + /** Sets the `suppressRowClickSelection` property. */ + GridApi.prototype.setSuppressRowClickSelection = function (value) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_SUPPRESS_ROW_CLICK_SELECTION, value); }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - -var PopupEditorWrapper = /** @class */ (function (_super) { - __extends(PopupEditorWrapper, _super); - function PopupEditorWrapper(cellEditor) { - var _this = _super.call(this, "
") || this; - _this.getGuiCalledOnChild = false; - _this.cellEditor = cellEditor; - return _this; - } - PopupEditorWrapper.prototype.onKeyDown = function (event) { - if (!_utils__WEBPACK_IMPORTED_MODULE_2__["_"].isUserSuppressingKeyboardEvent(this.gridOptionsWrapper, event, this.params.node, this.params.column, true)) { - this.params.onKeyDown(event); - } + /** Adds a drop zone outside of the grid where rows can be dropped. */ + GridApi.prototype.addRowDropZone = function (params) { + this.gridBodyCon.getRowDragFeature().addRowDropZone(params); }; - PopupEditorWrapper.prototype.getGui = function () { - // we call getGui() on child here (rather than in the constructor) - // as we should wait for 'init' to be called on child first. - if (!this.getGuiCalledOnChild) { - this.appendChild(this.cellEditor.getGui()); - this.getGuiCalledOnChild = true; + /** Removes an external drop zone added by `addRowDropZone`. */ + GridApi.prototype.removeRowDropZone = function (params) { + var activeDropTarget = this.dragAndDropService.findExternalZone(params); + if (activeDropTarget) { + this.dragAndDropService.removeDropTarget(activeDropTarget); } - return _super.prototype.getGui.call(this); }; - PopupEditorWrapper.prototype.init = function (params) { - var _this = this; - this.params = params; - this.gridOptionsWrapper.setDomData(this.getGui(), PopupEditorWrapper.DOM_KEY_POPUP_EDITOR_WRAPPER, true); - this.addDestroyFunc(function () { return _this.destroyBean(_this.cellEditor); }); - this.addManagedListener( - // this needs to be 'super' and not 'this' as if we call 'this', - // it ends up called 'getGui()' on the child before 'init' was called, - // which is not good - _super.prototype.getGui.call(this), 'keydown', this.onKeyDown.bind(this)); + /** Returns the `RowDropZoneParams` to be used by another grid's `addRowDropZone` method. */ + GridApi.prototype.getRowDropZoneParams = function (events) { + return this.gridBodyCon.getRowDragFeature().getRowDropZone(events); }; - PopupEditorWrapper.prototype.afterGuiAttached = function () { - if (this.cellEditor.afterGuiAttached) { - this.cellEditor.afterGuiAttached(); - } + /** Sets the height in pixels for the row containing the column label header. */ + GridApi.prototype.setHeaderHeight = function (headerHeight) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_HEADER_HEIGHT, headerHeight); }; - PopupEditorWrapper.prototype.getValue = function () { - return this.cellEditor.getValue(); + /** + * Switch between layout options: `normal`, `autoHeight`, `print`. + * Defaults to `normal` if no domLayout provided. + */ + GridApi.prototype.setDomLayout = function (domLayout) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_DOM_LAYOUT, domLayout); }; - PopupEditorWrapper.prototype.isCancelBeforeStart = function () { - if (this.cellEditor.isCancelBeforeStart) { - return this.cellEditor.isCancelBeforeStart(); - } + /** Sets the `enableCellTextSelection` property. */ + GridApi.prototype.setEnableCellTextSelection = function (selectable) { + this.gridBodyCon.setCellTextSelection(selectable); }; - PopupEditorWrapper.prototype.isCancelAfterEnd = function () { - if (this.cellEditor.isCancelAfterEnd) { - return this.cellEditor.isCancelAfterEnd(); - } + /** Sets the preferred direction for the selection fill handle. */ + GridApi.prototype.setFillHandleDirection = function (direction) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_FILL_HANDLE_DIRECTION, direction); }; - PopupEditorWrapper.prototype.getPopupPosition = function () { - if (this.cellEditor.getPopupPosition) { - return this.cellEditor.getPopupPosition(); - } + /** Sets the height in pixels for the rows containing header column groups. */ + GridApi.prototype.setGroupHeaderHeight = function (headerHeight) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GROUP_HEADER_HEIGHT, headerHeight); }; - PopupEditorWrapper.prototype.focusIn = function () { - if (this.cellEditor.focusIn) { - this.cellEditor.focusIn(); - } + /** Sets the height in pixels for the row containing the floating filters. */ + GridApi.prototype.setFloatingFiltersHeight = function (headerHeight) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_FLOATING_FILTERS_HEIGHT, headerHeight); }; - PopupEditorWrapper.prototype.focusOut = function () { - if (this.cellEditor.focusOut) { - this.cellEditor.focusOut(); - } + /** Sets the height in pixels for the row containing the columns when in pivot mode. */ + GridApi.prototype.setPivotHeaderHeight = function (headerHeight) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_PIVOT_HEADER_HEIGHT, headerHeight); }; - PopupEditorWrapper.DOM_KEY_POPUP_EDITOR_WRAPPER = 'popupEditorWrapper'; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], PopupEditorWrapper.prototype, "gridOptionsWrapper", void 0); - return PopupEditorWrapper; -}(_widgets_popupComponent__WEBPACK_IMPORTED_MODULE_0__["PopupComponent"])); - - - -/***/ }), -/* 106 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DndSourceComp", function() { return DndSourceComp; }); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + /** Sets the height in pixels for the row containing header column groups when in pivot mode. */ + GridApi.prototype.setPivotGroupHeaderHeight = function (headerHeight) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_PIVOT_GROUP_HEADER_HEIGHT, headerHeight); }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + GridApi.prototype.setIsExternalFilterPresent = function (isExternalFilterPresentFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_IS_EXTERNAL_FILTER_PRESENT, isExternalFilterPresentFunc); }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - -var DndSourceComp = /** @class */ (function (_super) { - __extends(DndSourceComp, _super); - function DndSourceComp(rowNode, column, cellValue, beans, eCell) { - var _this = _super.call(this, "
") || this; - _this.rowNode = rowNode; - _this.column = column; - _this.cellValue = cellValue; - _this.beans = beans; - _this.eCell = eCell; - return _this; - } - DndSourceComp.prototype.postConstruct = function () { - var eGui = this.getGui(); - eGui.appendChild(_utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIconNoSpan('rowDrag', this.beans.gridOptionsWrapper, null)); - this.addDragSource(); - this.checkVisibility(); + GridApi.prototype.setDoesExternalFilterPass = function (doesExternalFilterPassFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_DOES_EXTERNAL_FILTER_PASS, doesExternalFilterPassFunc); }; - DndSourceComp.prototype.addDragSource = function () { - this.addGuiEventListener('dragstart', this.onDragStart.bind(this)); + GridApi.prototype.setNavigateToNextCell = function (navigateToNextCellFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_NAVIGATE_TO_NEXT_CELL, navigateToNextCellFunc); }; - DndSourceComp.prototype.onDragStart = function (dragEvent) { - var _this = this; - var providedOnRowDrag = this.column.getColDef().dndSourceOnRowDrag; - var isIE = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].isBrowserIE(); - if (!isIE) { - dragEvent.dataTransfer.setDragImage(this.eCell, 0, 0); - } - // default behaviour is to convert data to json and set into drag component - var defaultOnRowDrag = function () { - try { - var jsonData = JSON.stringify(_this.rowNode.data); - if (isIE) { - dragEvent.dataTransfer.setData('text', jsonData); - } - else { - dragEvent.dataTransfer.setData('application/json', jsonData); - dragEvent.dataTransfer.setData('text/plain', jsonData); - } - } - catch (e) { - // if we cannot convert the data to json, then we do not set the type - } - }; - if (providedOnRowDrag) { - providedOnRowDrag({ rowNode: this.rowNode, dragEvent: dragEvent }); - } - else { - defaultOnRowDrag(); - } + GridApi.prototype.setTabToNextCell = function (tabToNextCellFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_TAB_TO_NEXT_CELL, tabToNextCellFunc); }; - DndSourceComp.prototype.checkVisibility = function () { - var visible = this.column.isDndSource(this.rowNode); - this.setDisplayed(visible); + GridApi.prototype.setTabToNextHeader = function (tabToNextHeaderFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_TAB_TO_NEXT_HEADER, tabToNextHeaderFunc); }; - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], DndSourceComp.prototype, "postConstruct", null); - return DndSourceComp; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); - - - -/***/ }), -/* 107 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TooltipFeature", function() { return TooltipFeature; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + GridApi.prototype.setNavigateToNextHeader = function (navigateToNextHeaderFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_NAVIGATE_TO_NEXT_HEADER, navigateToNextHeaderFunc); }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + GridApi.prototype.setGroupRowAggNodes = function (groupRowAggNodesFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GROUP_ROW_AGG_NODES, groupRowAggNodesFunc); }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - -var TooltipStates; -(function (TooltipStates) { - TooltipStates[TooltipStates["NOTHING"] = 0] = "NOTHING"; - TooltipStates[TooltipStates["WAITING_TO_SHOW"] = 1] = "WAITING_TO_SHOW"; - TooltipStates[TooltipStates["SHOWING"] = 2] = "SHOWING"; -})(TooltipStates || (TooltipStates = {})); -var TooltipFeature = /** @class */ (function (_super) { - __extends(TooltipFeature, _super); - function TooltipFeature(parentComp, location) { - var _this = _super.call(this) || this; - _this.DEFAULT_HIDE_TOOLTIP_TIMEOUT = 10000; - _this.SHOW_QUICK_TOOLTIP_DIFF = 1000; - _this.FADE_OUT_TOOLTIP_TIMEOUT = 1000; - _this.state = TooltipStates.NOTHING; - // when showing the tooltip, we need to make sure it's the most recent instance we request, as due to - // async we could request two tooltips before the first instance returns, in which case we should - // disregard the second instance. - _this.tooltipInstanceCount = 0; - _this.tooltipMouseTrack = false; - _this.parentComp = parentComp; - _this.location = location; - return _this; - } - TooltipFeature.prototype.postConstruct = function () { - this.tooltipShowDelay = this.gridOptionsWrapper.getTooltipShowDelay() || 2000; - this.tooltipMouseTrack = this.gridOptionsWrapper.isTooltipMouseTrack(); - var el = this.parentComp.getGui(); - this.addManagedListener(el, 'mouseenter', this.onMouseEnter.bind(this)); - this.addManagedListener(el, 'mouseleave', this.onMouseLeave.bind(this)); - this.addManagedListener(el, 'mousemove', this.onMouseMove.bind(this)); - this.addManagedListener(el, 'mousedown', this.onMouseDown.bind(this)); + GridApi.prototype.setGetBusinessKeyForNode = function (getBusinessKeyForNodeFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GET_BUSINESS_KEY_FOR_NODE, getBusinessKeyForNodeFunc); }; - TooltipFeature.prototype.destroy = function () { - // if this component gets destroyed while tooltip is showing, need to make sure - // we don't end with no mouseLeave event resulting in zombie tooltip - this.setToDoNothing(); - _super.prototype.destroy.call(this); + GridApi.prototype.setGetChildCount = function (getChildCountFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GET_CHILD_COUNT, getChildCountFunc); }; - TooltipFeature.prototype.onMouseEnter = function (e) { - // if another tooltip was hidden very recently, we only wait 200ms to show, not the normal waiting time - var delay = this.isLastTooltipHiddenRecently() ? 200 : this.tooltipShowDelay; - this.showTooltipTimeoutId = window.setTimeout(this.showTooltip.bind(this), delay); - this.lastMouseEvent = e; - this.state = TooltipStates.WAITING_TO_SHOW; + GridApi.prototype.setProcessRowPostCreate = function (processRowPostCreateFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_PROCESS_ROW_POST_CREATE, processRowPostCreateFunc); }; - TooltipFeature.prototype.onMouseLeave = function () { - this.setToDoNothing(); + GridApi.prototype.setGetRowNodeId = function (getRowNodeIdFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GET_ROW_NODE_ID, getRowNodeIdFunc); }; - TooltipFeature.prototype.setToDoNothing = function () { - if (this.state === TooltipStates.SHOWING) { - this.hideTooltip(); - } - this.clearTimeouts(); - this.state = TooltipStates.NOTHING; + GridApi.prototype.setGetRowClass = function (rowClassFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GET_ROW_CLASS, rowClassFunc); }; - TooltipFeature.prototype.onMouseMove = function (e) { - // there is a delay from the time we mouseOver a component and the time the - // tooltip is displayed, so we need to track mousemove to be able to correctly - // position the tooltip when showTooltip is called. - this.lastMouseEvent = e; - if (this.tooltipMouseTrack && - this.state === TooltipStates.SHOWING && - this.tooltipComp) { - this.positionTooltipUnderLastMouseEvent(); - } + GridApi.prototype.setIsFullWidthCell = function (isFullWidthCellFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_IS_FULL_WIDTH_CELL, isFullWidthCellFunc); }; - TooltipFeature.prototype.onMouseDown = function () { - this.setToDoNothing(); + GridApi.prototype.setIsRowSelectable = function (isRowSelectableFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_IS_ROW_SELECTABLE, isRowSelectableFunc); }; - TooltipFeature.prototype.hideTooltip = function () { - // check if comp exists - due to async, although we asked for - // one, the instance may not be back yet - if (this.tooltipComp) { - this.destroyTooltipComp(); - TooltipFeature.lastTooltipHideTime = new Date().getTime(); - } - this.state = TooltipStates.NOTHING; + GridApi.prototype.setIsRowMaster = function (isRowMasterFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_IS_ROW_MASTER, isRowMasterFunc); }; - TooltipFeature.prototype.destroyTooltipComp = function () { - var _this = this; - // add class to fade out the tooltip - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(this.tooltipComp.getGui(), 'ag-tooltip-hiding'); - // make local copies of these variables, as we use them in the async function below, - // and we clear then to 'undefined' later, so need to take a copy before they are undefined. - var tooltipPopupDestroyFunc = this.tooltipPopupDestroyFunc; - var tooltipComp = this.tooltipComp; - window.setTimeout(function () { - tooltipPopupDestroyFunc(); - _this.getContext().destroyBean(tooltipComp); - }, this.FADE_OUT_TOOLTIP_TIMEOUT); - this.tooltipPopupDestroyFunc = undefined; - this.tooltipComp = undefined; + GridApi.prototype.setPostSort = function (postSortFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_POST_SORT, postSortFunc); }; - TooltipFeature.prototype.isLastTooltipHiddenRecently = function () { - // return true if <1000ms since last time we hid a tooltip - var now = new Date().getTime(); - var then = TooltipFeature.lastTooltipHideTime; - return (now - then) < this.SHOW_QUICK_TOOLTIP_DIFF; + GridApi.prototype.setGetDocument = function (getDocumentFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GET_DOCUMENT, getDocumentFunc); }; - TooltipFeature.prototype.showTooltip = function () { - var tooltipText = this.parentComp.getTooltipText(); - if (!tooltipText) { - this.setToDoNothing(); - return; - } - this.state = TooltipStates.SHOWING; - this.tooltipInstanceCount++; - var params = { - location: this.location, - api: this.gridApi, - columnApi: this.columnApi, - colDef: this.parentComp.getComponentHolder(), - column: this.parentComp.getColumn, - context: this.gridOptionsWrapper.getContext(), - rowIndex: this.parentComp.getCellPosition && this.parentComp.getCellPosition().rowIndex, - value: tooltipText - }; - // we pass in tooltipInstanceCount so the callback knows what the count was when - // we requested the tooltip, so if another tooltip was requested in the mean time - // we disregard it - var callback = this.newTooltipComponentCallback.bind(this, this.tooltipInstanceCount); - this.userComponentFactory.newTooltipComponent(params).then(callback); + GridApi.prototype.setGetContextMenuItems = function (getContextMenuItemsFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GET_CONTEXT_MENU_ITEMS, getContextMenuItemsFunc); }; - TooltipFeature.prototype.newTooltipComponentCallback = function (tooltipInstanceCopy, tooltipComp) { - var compNoLongerNeeded = this.state !== TooltipStates.SHOWING || this.tooltipInstanceCount !== tooltipInstanceCopy; - if (compNoLongerNeeded) { - this.getContext().destroyBean(tooltipComp); - return; - } - var eGui = tooltipComp.getGui(); - this.tooltipComp = tooltipComp; - if (!_utils__WEBPACK_IMPORTED_MODULE_2__["_"].containsClass(eGui, 'ag-tooltip')) { - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(eGui, 'ag-tooltip-custom'); - } - this.tooltipPopupDestroyFunc = this.popupService.addPopup(false, eGui, false); - this.positionTooltipUnderLastMouseEvent(); - this.hideTooltipTimeoutId = window.setTimeout(this.hideTooltip.bind(this), this.DEFAULT_HIDE_TOOLTIP_TIMEOUT); + GridApi.prototype.setGetMainMenuItems = function (getMainMenuItemsFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GET_MAIN_MENU_ITEMS, getMainMenuItemsFunc); }; - TooltipFeature.prototype.positionTooltipUnderLastMouseEvent = function () { - this.popupService.positionPopupUnderMouseEvent({ - type: 'tooltip', - mouseEvent: this.lastMouseEvent, - ePopup: this.tooltipComp.getGui(), - nudgeY: 18 - }); + GridApi.prototype.setProcessCellForClipboard = function (processCellForClipboardFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_PROCESS_CELL_FOR_CLIPBOARD, processCellForClipboardFunc); }; - TooltipFeature.prototype.clearTimeouts = function () { - if (this.showTooltipTimeoutId) { - window.clearTimeout(this.showTooltipTimeoutId); - this.showTooltipTimeoutId = undefined; - } - if (this.hideTooltipTimeoutId) { - window.clearTimeout(this.hideTooltipTimeoutId); - this.hideTooltipTimeoutId = undefined; - } + GridApi.prototype.setSendToClipboard = function (sendToClipboardFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_SEND_TO_CLIPBOARD, sendToClipboardFunc); }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('popupService') - ], TooltipFeature.prototype, "popupService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('userComponentFactory') - ], TooltipFeature.prototype, "userComponentFactory", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') - ], TooltipFeature.prototype, "columnApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') - ], TooltipFeature.prototype, "gridApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], TooltipFeature.prototype, "gridOptionsWrapper", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], TooltipFeature.prototype, "postConstruct", null); - return TooltipFeature; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); - - - -/***/ }), -/* 108 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderRootComp", function() { return HeaderRootComp; }); -/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(50); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _headerContainer__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(109); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(57); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(25); -/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(12); -/* harmony import */ var _widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(117); -/* harmony import */ var _header_headerNavigationService__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(124); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + GridApi.prototype.setProcessCellFromClipboard = function (processCellFromClipboardFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_PROCESS_CELL_FROM_CLIPBOARD, processCellFromClipboardFunc); }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + GridApi.prototype.setProcessSecondaryColDef = function (processSecondaryColDefFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_PROCESS_TO_SECONDARY_COLDEF, processSecondaryColDefFunc); }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - - - - - - - -var HeaderRootComp = /** @class */ (function (_super) { - __extends(HeaderRootComp, _super); - function HeaderRootComp() { - var _this = _super.call(this, HeaderRootComp.TEMPLATE) || this; - _this.headerContainers = new Map(); - return _this; - } - HeaderRootComp.prototype.postConstruct = function () { - var _this = this; - _super.prototype.postConstruct.call(this); - this.printLayout = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_5__["Constants"].DOM_LAYOUT_PRINT; - this.gridApi.registerHeaderRootComp(this); - this.autoWidthCalculator.registerHeaderRootComp(this); - this.registerHeaderContainer(new _headerContainer__WEBPACK_IMPORTED_MODULE_2__["HeaderContainer"](this.eHeaderContainer, this.eHeaderViewport, null), 'center'); - this.registerHeaderContainer(new _headerContainer__WEBPACK_IMPORTED_MODULE_2__["HeaderContainer"](this.ePinnedLeftHeader, null, _constants__WEBPACK_IMPORTED_MODULE_5__["Constants"].PINNED_LEFT), 'left'); - this.registerHeaderContainer(new _headerContainer__WEBPACK_IMPORTED_MODULE_2__["HeaderContainer"](this.ePinnedRightHeader, null, _constants__WEBPACK_IMPORTED_MODULE_5__["Constants"].PINNED_RIGHT), 'right'); - this.headerContainers.forEach(function (container) { return _this.createManagedBean(container); }); - this.headerNavigationService.registerHeaderRoot(this); - // shotgun way to get labels to change, eg from sum(amount) to avg(amount) - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_VALUE_CHANGED, this.refreshHeader.bind(this)); - this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_DOM_LAYOUT, this.onDomLayoutChanged.bind(this)); - // for setting ag-pivot-on / ag-pivot-off CSS classes - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_PIVOT_MODE_CHANGED, this.onPivotModeChanged.bind(this)); - this.onPivotModeChanged(); - this.addPreventHeaderScroll(); - if (this.columnController.isReady()) { - this.refreshHeader(); - } + GridApi.prototype.setProcessSecondaryColGroupDef = function (processSecondaryColGroupDefFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_PROCESS_SECONDARY_COL_GROUP_DEF, processSecondaryColGroupDefFunc); }; - HeaderRootComp.prototype.registerGridComp = function (gridPanel) { - this.gridPanel = gridPanel; - this.headerContainers.forEach(function (c) { return c.setupDragAndDrop(gridPanel); }); + GridApi.prototype.setPostProcessPopup = function (postProcessPopupFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_POST_PROCESS_POPUP, postProcessPopupFunc); }; - HeaderRootComp.prototype.registerHeaderContainer = function (headerContainer, type) { - this.headerContainers.set(type, headerContainer); + GridApi.prototype.setDefaultGroupOrderComparator = function (defaultGroupOrderComparatorFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_DEFAULT_GROUP_ORDER_COMPARATOR, defaultGroupOrderComparatorFunc); }; - HeaderRootComp.prototype.onTabKeyDown = function (e) { - var isRtl = this.gridOptionsWrapper.isEnableRtl(); - var direction = e.shiftKey !== isRtl - ? _header_headerNavigationService__WEBPACK_IMPORTED_MODULE_8__["HeaderNavigationDirection"].LEFT - : _header_headerNavigationService__WEBPACK_IMPORTED_MODULE_8__["HeaderNavigationDirection"].RIGHT; - if (this.headerNavigationService.navigateHorizontally(direction, true) || - this.focusController.focusNextGridCoreContainer(e.shiftKey)) { - e.preventDefault(); - } + GridApi.prototype.setGetChartToolbarItems = function (getChartToolbarItemsFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GET_CHART_TOOLBAR_ITEMS, getChartToolbarItemsFunc); }; - HeaderRootComp.prototype.handleKeyDown = function (e) { - var direction; - switch (e.keyCode) { - case _constants__WEBPACK_IMPORTED_MODULE_5__["Constants"].KEY_LEFT: - direction = _header_headerNavigationService__WEBPACK_IMPORTED_MODULE_8__["HeaderNavigationDirection"].LEFT; - case _constants__WEBPACK_IMPORTED_MODULE_5__["Constants"].KEY_RIGHT: - if (!_utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(direction)) { - direction = _header_headerNavigationService__WEBPACK_IMPORTED_MODULE_8__["HeaderNavigationDirection"].RIGHT; - } - this.headerNavigationService.navigateHorizontally(direction); - break; - case _constants__WEBPACK_IMPORTED_MODULE_5__["Constants"].KEY_UP: - direction = _header_headerNavigationService__WEBPACK_IMPORTED_MODULE_8__["HeaderNavigationDirection"].UP; - case _constants__WEBPACK_IMPORTED_MODULE_5__["Constants"].KEY_DOWN: - if (!_utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(direction)) { - direction = _header_headerNavigationService__WEBPACK_IMPORTED_MODULE_8__["HeaderNavigationDirection"].DOWN; - } - if (this.headerNavigationService.navigateVertically(direction)) { - e.preventDefault(); - } - break; - default: - return; + GridApi.prototype.setPaginationNumberFormatter = function (paginationNumberFormatterFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_PAGINATION_NUMBER_FORMATTER, paginationNumberFormatterFunc); + }; + GridApi.prototype.setGetServerSideStoreParams = function (getServerSideStoreParamsFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GET_SERVER_SIDE_STORE_PARAMS, getServerSideStoreParamsFunc); + }; + GridApi.prototype.setIsServerSideGroupOpenByDefault = function (isServerSideGroupOpenByDefaultFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_IS_SERVER_SIDE_GROUPS_OPEN_BY_DEFAULT, isServerSideGroupOpenByDefaultFunc); + }; + GridApi.prototype.setIsApplyServerSideTransaction = function (isApplyServerSideTransactionFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_IS_APPLY_SERVER_SIDE_TRANSACTION, isApplyServerSideTransactionFunc); + }; + GridApi.prototype.setIsServerSideGroup = function (isServerSideGroupFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_IS_SERVER_SIDE_GROUP, isServerSideGroupFunc); + }; + GridApi.prototype.setGetServerSideGroupKey = function (getServerSideGroupKeyFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GET_SERVER_SIDE_GROUP_KEY, getServerSideGroupKeyFunc); + }; + GridApi.prototype.setGetRowStyle = function (rowStyleFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GET_ROW_STYLE, rowStyleFunc); + }; + GridApi.prototype.setGetRowHeight = function (rowHeightFunc) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GET_ROW_HEIGHT, rowHeightFunc); + }; + /** Returns `true` if the side bar is visible. */ + GridApi.prototype.isSideBarVisible = function () { + return this.sideBarComp ? this.sideBarComp.isDisplayed() : false; + }; + /** Show/hide the entire side bar, including any visible panel and the tab buttons. */ + GridApi.prototype.setSideBarVisible = function (show) { + if (!this.sideBarComp) { + if (show) { + console.warn('AG Grid: sideBar is not loaded'); + } + return; } + this.sideBarComp.setDisplayed(show); }; - HeaderRootComp.prototype.onFocusOut = function (e) { - var relatedTarget = e.relatedTarget; - var eGui = this.getGui(); - if (!relatedTarget && eGui.contains(document.activeElement)) { + /** Sets the side bar position relative to the grid. Possible values are `'left'` or `'right'`. */ + GridApi.prototype.setSideBarPosition = function (position) { + if (!this.sideBarComp) { + console.warn('AG Grid: sideBar is not loaded'); return; } - if (!eGui.contains(relatedTarget)) { - this.focusController.clearFocusedHeader(); + this.sideBarComp.setSideBarPosition(position); + }; + /** Opens a particular tool panel. Provide the ID of the tool panel to open. */ + GridApi.prototype.openToolPanel = function (key) { + if (!this.sideBarComp) { + console.warn('AG Grid: toolPanel is only available in AG Grid Enterprise'); + return; } + this.sideBarComp.openToolPanel(key); }; - HeaderRootComp.prototype.onDomLayoutChanged = function () { - var newValue = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_5__["Constants"].DOM_LAYOUT_PRINT; - if (this.printLayout !== newValue) { - this.printLayout = newValue; - this.refreshHeader(); + /** Closes the currently open tool panel (if any). */ + GridApi.prototype.closeToolPanel = function () { + if (!this.sideBarComp) { + console.warn('AG Grid: toolPanel is only available in AG Grid Enterprise'); + return; } + this.sideBarComp.close(); }; - HeaderRootComp.prototype.setHorizontalScroll = function (offset) { - this.eHeaderContainer.style.transform = "translateX(" + offset + "px)"; + /** Returns the ID of the currently shown tool panel if any, otherwise `null`. */ + GridApi.prototype.getOpenedToolPanel = function () { + return this.sideBarComp ? this.sideBarComp.openedItem() : null; }; - HeaderRootComp.prototype.forEachHeaderElement = function (callback) { - this.headerContainers.forEach(function (childContainer) { return childContainer.forEachHeaderElement(callback); }); + /** Returns the current side bar configuration. If a shortcut was used, returns the detailed long form. */ + GridApi.prototype.getSideBar = function () { + return this.gridOptionsWrapper.getSideBar(); }; - HeaderRootComp.prototype.refreshHeader = function () { - this.headerContainers.forEach(function (container) { return container.refresh(); }); + /** Resets the side bar to the provided configuration. The parameter is the same as the sideBar grid property. The side bar is re-created from scratch with the new config. */ + GridApi.prototype.setSideBar = function (def) { + this.gridOptionsWrapper.setProperty('sideBar', _entities_sideBar__WEBPACK_IMPORTED_MODULE_4__["SideBarDefParser"].parse(def)); }; - HeaderRootComp.prototype.onPivotModeChanged = function () { - var pivotMode = this.columnController.isPivotMode(); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["addOrRemoveCssClass"])(this.getGui(), 'ag-pivot-on', pivotMode); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["addOrRemoveCssClass"])(this.getGui(), 'ag-pivot-off', !pivotMode); + GridApi.prototype.setSuppressClipboardPaste = function (value) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_SUPPRESS_CLIPBOARD_PASTE, value); }; - HeaderRootComp.prototype.setHeight = function (height) { - // one extra pixel is needed here to account for the - // height of the border - var px = height + 1 + "px"; - this.getGui().style.height = px; - this.getGui().style.minHeight = px; + /** Returns `true` if the tool panel is showing, otherwise `false`. */ + GridApi.prototype.isToolPanelShowing = function () { + return this.sideBarComp.isToolPanelShowing(); }; - // if the user is in floating filter and hits tab a few times, the header can - // end up scrolling to show items off the screen, leaving the grid and header - // and the grid columns no longer in sync. - HeaderRootComp.prototype.addPreventHeaderScroll = function () { - var _this = this; - this.addManagedListener(this.eHeaderViewport, 'scroll', function () { - // if the header scrolls, the header will be out of sync. so we reset the - // header scroll, and then scroll the body, which will in turn set the offset - // on the header, giving the impression that the header scrolled as expected. - var scrollLeft = _this.eHeaderViewport.scrollLeft; - if (scrollLeft !== 0) { - _this.gridPanel.scrollHorizontally(scrollLeft); - _this.eHeaderViewport.scrollLeft = 0; + GridApi.prototype.doLayout = function () { + var message = "AG Grid - since version 25.1, doLayout was taken out, as it's not needed. The grid responds to grid size changes automatically"; + Object(_utils_function__WEBPACK_IMPORTED_MODULE_11__["doOnce"])(function () { return console.warn(message); }, 'doLayoutDeprecated'); + }; + /** Tells the grid to recalculate the row heights. */ + GridApi.prototype.resetRowHeights = function () { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["exists"])(this.clientSideRowModel)) { + if (this.columnModel.isAutoRowHeightActive()) { + console.warn('AG Grid: calling gridApi.resetRowHeights() makes no sense when using Auto Row Height.'); + return; } - }); + this.clientSideRowModel.resetRowHeights(); + } }; - HeaderRootComp.prototype.getHeaderContainers = function () { - return this.headerContainers; + GridApi.prototype.setGroupRemoveSingleChildren = function (value) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GROUP_REMOVE_SINGLE_CHILDREN, value); }; - HeaderRootComp.prototype.setHeaderContainerWidth = function (width) { - this.eHeaderContainer.style.width = width + "px"; + GridApi.prototype.setGroupRemoveLowestSingleChildren = function (value) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GROUP_REMOVE_LOWEST_SINGLE_CHILDREN, value); }; - HeaderRootComp.prototype.setLeftVisible = function (visible) { - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["setDisplayed"])(this.ePinnedLeftHeader, visible); + /** Tells the grid a row height has changed. To be used after calling `rowNode.setRowHeight(newHeight)`. */ + GridApi.prototype.onRowHeightChanged = function () { + if (this.clientSideRowModel) { + this.clientSideRowModel.onRowHeightChanged(); + } + else if (this.serverSideRowModel) { + this.serverSideRowModel.onRowHeightChanged(); + } }; - HeaderRootComp.prototype.setRightVisible = function (visible) { - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["setDisplayed"])(this.ePinnedRightHeader, visible); + /** + * Gets the value for a column for a particular `rowNode` (row). + * This is useful if you want the raw value of a cell e.g. if implementing your own CSV export. + */ + GridApi.prototype.getValue = function (colKey, rowNode) { + var column = this.columnModel.getPrimaryColumn(colKey); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(column)) { + column = this.columnModel.getGridColumn(colKey); + } + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(column)) { + return null; + } + return this.valueService.getValue(column, rowNode); }; - HeaderRootComp.TEMPLATE = "
\n
\n
\n
\n
\n
\n
"; - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('ePinnedLeftHeader') - ], HeaderRootComp.prototype, "ePinnedLeftHeader", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('ePinnedRightHeader') - ], HeaderRootComp.prototype, "ePinnedRightHeader", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eHeaderContainer') - ], HeaderRootComp.prototype, "eHeaderContainer", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eHeaderViewport') - ], HeaderRootComp.prototype, "eHeaderViewport", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], HeaderRootComp.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController') - ], HeaderRootComp.prototype, "columnController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridApi') - ], HeaderRootComp.prototype, "gridApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('autoWidthCalculator') - ], HeaderRootComp.prototype, "autoWidthCalculator", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('headerNavigationService') - ], HeaderRootComp.prototype, "headerNavigationService", void 0); - return HeaderRootComp; -}(_widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_7__["ManagedFocusComponent"])); - - - -/***/ }), -/* 109 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderContainer", function() { return HeaderContainer; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43); -/* harmony import */ var _headerRowComp__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(110); -/* harmony import */ var _bodyDropTarget__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(121); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(25); -/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(12); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(41); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + /** Add an event listener for the specified `eventType`. Works similar to `addEventListener` for a browser DOM element. */ + GridApi.prototype.addEventListener = function (eventType, listener) { + var async = this.gridOptionsWrapper.useAsyncEvents(); + this.eventService.addEventListener(eventType, listener, async); }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + /** Add an event listener for all event types coming from the grid. */ + GridApi.prototype.addGlobalListener = function (listener) { + var async = this.gridOptionsWrapper.useAsyncEvents(); + this.eventService.addGlobalListener(listener, async); }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - - - - -var HeaderContainer = /** @class */ (function (_super) { - __extends(HeaderContainer, _super); - function HeaderContainer(eContainer, eViewport, pinned) { - var _this = _super.call(this) || this; - _this.headerRowComps = []; - _this.eContainer = eContainer; - _this.pinned = pinned; - _this.eViewport = eViewport; - return _this; - } - HeaderContainer.prototype.forEachHeaderElement = function (callback) { - this.headerRowComps.forEach(function (headerRowComp) { return headerRowComp.forEachHeaderElement(callback); }); - }; - HeaderContainer.prototype.init = function () { - this.scrollWidth = this.gridOptionsWrapper.getScrollbarWidth(); - // if value changes, then if not pivoting, we at least need to change the label eg from sum() to avg(), - // if pivoting, then the columns have changed - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_VALUE_CHANGED, this.onColumnValueChanged.bind(this)), - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, this.onColumnRowGroupChanged.bind(this)), - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_GRID_COLUMNS_CHANGED, this.onGridColumnsChanged.bind(this)), - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_SCROLL_VISIBILITY_CHANGED, this.onScrollVisibilityChanged.bind(this)), - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_RESIZED, this.onColumnResized.bind(this)), - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this)); - }; - // if row group changes, that means we may need to add aggFuncs to the column headers, - // if the grid goes from no aggregation (ie no grouping) to grouping - HeaderContainer.prototype.onColumnRowGroupChanged = function () { - this.onGridColumnsChanged(); + /** Remove an event listener. */ + GridApi.prototype.removeEventListener = function (eventType, listener) { + var async = this.gridOptionsWrapper.useAsyncEvents(); + this.eventService.removeEventListener(eventType, listener, async); }; - // if the agg func of a column changes, then we may need to update the agg func in columns header - HeaderContainer.prototype.onColumnValueChanged = function () { - this.onGridColumnsChanged(); + /** Remove a global event listener. */ + GridApi.prototype.removeGlobalListener = function (listener) { + var async = this.gridOptionsWrapper.useAsyncEvents(); + this.eventService.removeGlobalListener(listener, async); }; - HeaderContainer.prototype.onColumnResized = function () { - this.setWidthOfPinnedContainer(); + GridApi.prototype.dispatchEvent = function (event) { + this.eventService.dispatchEvent(event); + }; + /** Will destroy the grid and release resources. If you are using a framework you do not need to call this, as the grid links in with the framework lifecycle. However if you are using Web Components or native JavaScript, you do need to call this, to avoid a memory leak in your application. */ + GridApi.prototype.destroy = function () { + // this is needed as GridAPI is a bean, and GridAPI.destroy() is called as part + // of context.destroy(). so we need to stop the infinite loop. + if (this.destroyCalled) { + return; + } + this.destroyCalled = true; + // destroy the UI first (as they use the services) + var gridCtrl = this.ctrlsService.getGridCtrl(); + if (gridCtrl) { + gridCtrl.destroyGridUi(); + } + // destroy the services + this.context.destroy(); + }; + GridApi.prototype.cleanDownReferencesToAvoidMemoryLeakInCaseApplicationIsKeepingReferenceToDestroyedGrid = function () { + // some users were raising support issues with regards memory leaks. the problem was the customers applications + // were keeping references to the API. trying to educate them all would be difficult, easier to just remove + // all references in the API so at least the core grid can be garbage collected. + // + // wait about 100ms before clearing down the references, in case user has some cleanup to do, + // and needs to deference the API first + setTimeout(_utils_object__WEBPACK_IMPORTED_MODULE_8__["removeAllReferences"].bind(window, this, 'Grid API'), 100); }; - HeaderContainer.prototype.onDisplayedColumnsChanged = function () { - this.setWidthOfPinnedContainer(); + GridApi.prototype.warnIfDestroyed = function (methodName) { + if (this.destroyCalled) { + console.warn("AG Grid: Grid API method " + methodName + " was called on a grid that was destroyed."); + } + return this.destroyCalled; + }; + /** Reset the quick filter cache text on every rowNode. */ + GridApi.prototype.resetQuickFilter = function () { + if (this.warnIfDestroyed('resetQuickFilter')) { + return; + } + this.rowModel.forEachNode(function (node) { return node.quickFilterAggregateText = null; }); + }; + GridApi.prototype.getRangeSelections = function () { + console.warn("AG Grid: in v20.1.x, api.getRangeSelections() is gone, please use getCellRanges() instead.\n We had to change how cell selections works a small bit to allow charting to integrate. The return type of\n getCellRanges() is a bit different, please check the AG Grid documentation."); + return null; + }; + /** Returns the list of selected cell ranges. */ + GridApi.prototype.getCellRanges = function () { + if (this.rangeService) { + return this.rangeService.getCellRanges(); + } + console.warn('AG Grid: cell range selection is only available in AG Grid Enterprise'); + return null; + }; + GridApi.prototype.camelCaseToHumanReadable = function (camelCase) { + return Object(_utils_string__WEBPACK_IMPORTED_MODULE_10__["camelCaseToHumanText"])(camelCase); }; - HeaderContainer.prototype.onScrollVisibilityChanged = function () { - this.setWidthOfPinnedContainer(); + GridApi.prototype.addRangeSelection = function (deprecatedNoLongerUsed) { + console.warn('AG Grid: As of version 21.x, range selection changed slightly to allow charting integration. Please call api.addCellRange() instead of api.addRangeSelection()'); }; - HeaderContainer.prototype.setWidthOfPinnedContainer = function () { - var pinningLeft = this.pinned === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_LEFT; - var pinningRight = this.pinned === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_RIGHT; - var controller = this.columnController; - var isRtl = this.gridOptionsWrapper.isEnableRtl(); - if (pinningLeft || pinningRight) { - // size to fit all columns - var width = controller[pinningLeft ? 'getPinnedLeftContainerWidth' : 'getPinnedRightContainerWidth'](); - // if there is a scroll showing (and taking up space, so Windows, and not iOS) - // in the body, then we add extra space to keep header aligned with the body, - // as body width fits the cols and the scrollbar - var addPaddingForScrollbar = this.scrollVisibleService.isVerticalScrollShowing() && ((isRtl && pinningLeft) || (!isRtl && pinningRight)); - if (addPaddingForScrollbar) { - width += this.scrollWidth; - } - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["setFixedWidth"])(this.eContainer, width); + /** Adds the provided cell range to the selected ranges. */ + GridApi.prototype.addCellRange = function (params) { + if (!this.rangeService) { + console.warn('AG Grid: cell range selection is only available in AG Grid Enterprise'); } + this.rangeService.addCellRange(params); }; - HeaderContainer.prototype.getRowComps = function () { - return this.headerRowComps; + /** Clears the selected ranges. */ + GridApi.prototype.clearRangeSelection = function () { + if (!this.rangeService) { + console.warn('AG Grid: cell range selection is only available in AG Grid Enterprise'); + } + this.rangeService.removeAllCellRanges(); }; - // grid cols have changed - this also means the number of rows in the header can have - // changed. so we remove all the old rows and insert new ones for a complete refresh - HeaderContainer.prototype.onGridColumnsChanged = function () { - this.removeAndCreateAllRowComps(); + /** Reverts the last cell edit. */ + GridApi.prototype.undoCellEditing = function () { + this.undoRedoService.undo(); }; - HeaderContainer.prototype.removeAndCreateAllRowComps = function () { - this.removeHeaderRowComps(); - this.createHeaderRowComps(); + /** Re-applies the most recently undone cell edit. */ + GridApi.prototype.redoCellEditing = function () { + this.undoRedoService.redo(); }; - // we expose this for gridOptions.api.refreshHeader() to call - HeaderContainer.prototype.refresh = function () { - this.removeAndCreateAllRowComps(); + /** Returns current number of available cell edit undo operations. */ + GridApi.prototype.getCurrentUndoSize = function () { + return this.undoRedoService.getCurrentUndoStackSize(); }; - HeaderContainer.prototype.setupDragAndDrop = function (gridComp) { - var dropContainer = this.eViewport ? this.eViewport : this.eContainer; - var bodyDropTarget = new _bodyDropTarget__WEBPACK_IMPORTED_MODULE_3__["BodyDropTarget"](this.pinned, dropContainer); - this.createManagedBean(bodyDropTarget); - bodyDropTarget.registerGridComp(gridComp); + /** Returns current number of available cell edit redo operations. */ + GridApi.prototype.getCurrentRedoSize = function () { + return this.undoRedoService.getCurrentRedoStackSize(); }; - HeaderContainer.prototype.removeHeaderRowComps = function () { - var _this = this; - this.headerRowComps.forEach(function (headerRowComp) { return _this.destroyBean(headerRowComp); }); - this.headerRowComps.length = 0; - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["clearElement"])(this.eContainer); + /** Returns a list of models with information about the charts that are currently rendered from the grid. */ + GridApi.prototype.getChartModels = function () { + if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].RangeSelectionModule, 'api.getChartModels') && + _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].GridChartsModule, 'api.getChartModels')) { + return this.chartService.getChartModels(); + } }; - HeaderContainer.prototype.createHeaderRowComps = function () { - // if we are displaying header groups, then we have many rows here. - // go through each row of the header, one by one. - var rowCount = this.columnController.getHeaderRowCount(); - for (var dept = 0; dept < rowCount; dept++) { - var groupRow = dept !== (rowCount - 1); - var type = groupRow ? _headerRowComp__WEBPACK_IMPORTED_MODULE_2__["HeaderRowType"].COLUMN_GROUP : _headerRowComp__WEBPACK_IMPORTED_MODULE_2__["HeaderRowType"].COLUMN; - var headerRowComp = new _headerRowComp__WEBPACK_IMPORTED_MODULE_2__["HeaderRowComp"](dept, type, this.pinned, this.dropTarget); - this.createBean(headerRowComp); - this.headerRowComps.push(headerRowComp); - headerRowComp.setRowIndex(this.headerRowComps.length - 1); - this.eContainer.appendChild(headerRowComp.getGui()); + /** Returns the `ChartRef` using the supplied `chartId`. */ + GridApi.prototype.getChartRef = function (chartId) { + if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].RangeSelectionModule, 'api.getChartRef') && + _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].GridChartsModule, 'api.getChartRef')) { + return this.chartService.getChartRef(chartId); } - if (!this.columnController.isPivotMode() && this.columnController.hasFloatingFilters()) { - var headerRowComp = new _headerRowComp__WEBPACK_IMPORTED_MODULE_2__["HeaderRowComp"](rowCount, _headerRowComp__WEBPACK_IMPORTED_MODULE_2__["HeaderRowType"].FLOATING_FILTER, this.pinned, this.dropTarget); - this.createBean(headerRowComp); - this.headerRowComps.push(headerRowComp); - headerRowComp.setRowIndex(this.headerRowComps.length - 1); - this.eContainer.appendChild(headerRowComp.getGui()); + }; + /** Returns a string containing the requested data URL which contains a representation of the chart image. */ + GridApi.prototype.getChartImageDataURL = function (params) { + if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].RangeSelectionModule, 'api.getChartImageDataURL') && + _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].GridChartsModule, 'api.getChartImageDataURL')) { + return this.chartService.getChartImageDataURL(params); } }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], HeaderContainer.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], HeaderContainer.prototype, "columnController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('scrollVisibleService') - ], HeaderContainer.prototype, "scrollVisibleService", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], HeaderContainer.prototype, "init", null); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PreDestroy"] - ], HeaderContainer.prototype, "removeHeaderRowComps", null); - return HeaderContainer; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_6__["BeanStub"])); - - - -/***/ }), -/* 110 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderRowType", function() { return HeaderRowType; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderRowComp", function() { return HeaderRowComp; }); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(50); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43); -/* harmony import */ var _header_headerWrapperComp__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(111); -/* harmony import */ var _headerGroup_headerGroupWrapperComp__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(118); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(25); -/* harmony import */ var _filter_floating_floatingFilterWrapper__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(119); -/* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(13); -/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(14); -/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(17); -/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(12); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + /** Used to programmatically create charts from a range. */ + GridApi.prototype.createRangeChart = function (params) { + if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].RangeSelectionModule, 'api.createRangeChart') && + _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].GridChartsModule, 'api.createRangeChart')) { + return this.chartService.createRangeChart(params); + } }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + /** Used to programmatically create cross filter charts from a range. */ + GridApi.prototype.createCrossFilterChart = function (params) { + if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].RangeSelectionModule, 'api.createCrossFilterChart') && + _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].GridChartsModule, 'api.createCrossFilterChart')) { + return this.chartService.createCrossFilterChart(params); + } }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - - - - - - - - - -var HeaderRowType; -(function (HeaderRowType) { - HeaderRowType[HeaderRowType["COLUMN_GROUP"] = 0] = "COLUMN_GROUP"; - HeaderRowType[HeaderRowType["COLUMN"] = 1] = "COLUMN"; - HeaderRowType[HeaderRowType["FLOATING_FILTER"] = 2] = "FLOATING_FILTER"; -})(HeaderRowType || (HeaderRowType = {})); -var HeaderRowComp = /** @class */ (function (_super) { - __extends(HeaderRowComp, _super); - function HeaderRowComp(dept, type, pinned, dropTarget) { - var _this = _super.call(this, /* html */ "
") || this; - _this.headerComps = {}; - _this.dept = dept; - _this.type = type; - _this.pinned = pinned; - _this.dropTarget = dropTarget; - var niceClassName = HeaderRowType[type].toLowerCase().replace(/_/g, '-'); - _this.addCssClass("ag-header-row-" + niceClassName); - if (Object(_utils_browser__WEBPACK_IMPORTED_MODULE_8__["isBrowserSafari"])()) { - // fix for a Safari rendering bug that caused the header to flicker above chart panels - // as you move the mouse over the header - _this.getGui().style.transform = 'translateZ(0)'; + /** Restores a chart using the `ChartModel` that was previously obtained from `getChartModels()`. */ + GridApi.prototype.restoreChart = function (chartModel, chartContainer) { + if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].RangeSelectionModule, 'api.restoreChart') && + _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].GridChartsModule, 'api.restoreChart')) { + return this.chartService.restoreChart(chartModel, chartContainer); } - return _this; - } - HeaderRowComp.prototype.forEachHeaderElement = function (callback) { - var _this = this; - Object.keys(this.headerComps).forEach(function (key) { - callback(_this.headerComps[key]); - }); }; - HeaderRowComp.prototype.setRowIndex = function (idx) { - this.rowIndex = idx; - this.getGui().setAttribute('aria-rowindex', (idx + 1).toString()); + /** Used to programmatically create pivot charts from a grid. */ + GridApi.prototype.createPivotChart = function (params) { + if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].RangeSelectionModule, 'api.createPivotChart') && + _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_7__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].GridChartsModule, 'api.createPivotChart')) { + return this.chartService.createPivotChart(params); + } }; - HeaderRowComp.prototype.getRowIndex = function () { - return this.rowIndex; + /** Copies the selected rows to the clipboard. */ + GridApi.prototype.copySelectedRowsToClipboard = function (params) { + if (!this.clipboardService) { + console.warn('AG Grid: clipboard is only available in AG Grid Enterprise'); + } + this.clipboardService.copySelectedRowsToClipboard(params); }; - HeaderRowComp.prototype.getType = function () { - return this.type; + /** Copies the selected ranges to the clipboard. */ + GridApi.prototype.copySelectedRangeToClipboard = function (params) { + if (!this.clipboardService) { + console.warn('AG Grid: clipboard is only available in AG Grid Enterprise'); + } + this.clipboardService.copySelectedRangeToClipboard(params); }; - HeaderRowComp.prototype.destroyAllChildComponents = function () { - var idsOfAllChildren = Object.keys(this.headerComps); - this.destroyChildComponents(idsOfAllChildren); + /** Copies the selected range down, similar to `Ctrl + D` in Excel. */ + GridApi.prototype.copySelectedRangeDown = function () { + if (!this.clipboardService) { + console.warn('AG Grid: clipboard is only available in AG Grid Enterprise'); + } + this.clipboardService.copyRangeDown(); }; - HeaderRowComp.prototype.destroyChildComponents = function (idsToDestroy, keepFocused) { - var _this = this; - idsToDestroy.forEach(function (id) { - var childHeaderWrapper = _this.headerComps[id]; - if (keepFocused && - !childHeaderWrapper.getColumn().isMoving() && - _this.focusController.isHeaderWrapperFocused(childHeaderWrapper)) { - return; - } - _this.getGui().removeChild(childHeaderWrapper.getGui()); - _this.destroyBean(childHeaderWrapper); - delete _this.headerComps[id]; - }); + /** Shows the column menu after and positions it relative to the provided button element. Use in conjunction with your own header template. */ + GridApi.prototype.showColumnMenuAfterButtonClick = function (colKey, buttonElement) { + // use grid column so works with pivot mode + var column = this.columnModel.getGridColumn(colKey); + this.menuFactory.showMenuAfterButtonClick(column, buttonElement, 'columnMenu'); }; - HeaderRowComp.prototype.onRowHeightChanged = function () { - var headerRowCount = this.columnController.getHeaderRowCount(); - var sizes = []; - var numberOfFloating = 0; - var groupHeight; - var headerHeight; - if (this.columnController.isPivotMode()) { - groupHeight = this.gridOptionsWrapper.getPivotGroupHeaderHeight(); - headerHeight = this.gridOptionsWrapper.getPivotHeaderHeight(); - } - else { - if (this.columnController.hasFloatingFilters()) { - headerRowCount++; - numberOfFloating = 1; - } - groupHeight = this.gridOptionsWrapper.getGroupHeaderHeight(); - headerHeight = this.gridOptionsWrapper.getHeaderHeight(); - } - var numberOfNonGroups = 1 + numberOfFloating; - var numberOfGroups = headerRowCount - numberOfNonGroups; - for (var i = 0; i < numberOfGroups; i++) { - sizes.push(groupHeight); + /** Shows the column menu after and positions it relative to the mouse event. Use in conjunction with your own header template. */ + GridApi.prototype.showColumnMenuAfterMouseClick = function (colKey, mouseEvent) { + // use grid column so works with pivot mode + var column = this.columnModel.getGridColumn(colKey); + if (!column) { + column = this.columnModel.getPrimaryColumn(colKey); } - sizes.push(headerHeight); - for (var i = 0; i < numberOfFloating; i++) { - sizes.push(this.gridOptionsWrapper.getFloatingFiltersHeight()); + if (!column) { + console.error("AG Grid: column '" + colKey + "' not found"); + return; } - var rowHeight = 0; - for (var i = 0; i < this.dept; i++) { - rowHeight += sizes[i]; + this.menuFactory.showMenuAfterMouseEvent(column, mouseEvent); + }; + /** Hides any visible context menu or column menu. */ + GridApi.prototype.hidePopupMenu = function () { + // hide the context menu if in enterprise + if (this.contextMenuFactory) { + this.contextMenuFactory.hideActiveMenu(); } - this.getGui().style.top = rowHeight + 'px'; - this.getGui().style.height = sizes[this.dept] + 'px'; + // and hide the column menu always + this.menuFactory.hideActiveMenu(); }; - //noinspection JSUnusedLocalSymbols - HeaderRowComp.prototype.init = function () { - this.onRowHeightChanged(); - this.onVirtualColumnsChanged(); - this.setWidth(); - this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__["GridOptionsWrapper"].PROP_HEADER_HEIGHT, this.onRowHeightChanged.bind(this)); - this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__["GridOptionsWrapper"].PROP_PIVOT_HEADER_HEIGHT, this.onRowHeightChanged.bind(this)); - this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__["GridOptionsWrapper"].PROP_GROUP_HEADER_HEIGHT, this.onRowHeightChanged.bind(this)); - this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__["GridOptionsWrapper"].PROP_PIVOT_GROUP_HEADER_HEIGHT, this.onRowHeightChanged.bind(this)); - this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__["GridOptionsWrapper"].PROP_FLOATING_FILTERS_HEIGHT, this.onRowHeightChanged.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_VIRTUAL_COLUMNS_CHANGED, this.onVirtualColumnsChanged.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_RESIZED, this.onColumnResized.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_GRID_COLUMNS_CHANGED, this.onGridColumnsChanged.bind(this)); + /** DOM element to use as the popup parent for grid popups (context menu, column menu etc). */ + GridApi.prototype.setPopupParent = function (ePopupParent) { + this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_POPUP_PARENT, ePopupParent); }; - HeaderRowComp.prototype.onColumnResized = function () { - this.setWidth(); + /** Navigates the grid focus to the next cell, as if tabbing. */ + GridApi.prototype.tabToNextCell = function (event) { + return this.navigationService.tabToNextCell(false, event); }; - HeaderRowComp.prototype.setWidth = function () { - var width = this.getWidthForRow(); - this.getGui().style.width = width + 'px'; + /** Navigates the grid focus to the previous cell, as if shift-tabbing. */ + GridApi.prototype.tabToPreviousCell = function (event) { + return this.navigationService.tabToNextCell(true, event); }; - HeaderRowComp.prototype.getWidthForRow = function () { - var printLayout = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_6__["Constants"].DOM_LAYOUT_PRINT; - if (printLayout) { - var centerRow = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(this.pinned); - if (centerRow) { - return this.columnController.getContainerWidth(_constants__WEBPACK_IMPORTED_MODULE_6__["Constants"].PINNED_RIGHT) - + this.columnController.getContainerWidth(_constants__WEBPACK_IMPORTED_MODULE_6__["Constants"].PINNED_LEFT) - + this.columnController.getContainerWidth(null); - } - return 0; - } - // if not printing, just return the width as normal - return this.columnController.getContainerWidth(this.pinned); + /** Returns the list of active cell renderer instances. */ + GridApi.prototype.getCellRendererInstances = function (params) { + if (params === void 0) { params = {}; } + var res = this.rowRenderer.getCellRendererInstances(params); + var unwrapped = res.map(unwrapUserComp); + return unwrapped; }; - HeaderRowComp.prototype.onGridColumnsChanged = function () { - this.removeAndDestroyAllChildComponents(); + /** Returns the list of active cell editor instances. Optionally provide parameters to restrict to certain columns / row nodes. */ + GridApi.prototype.getCellEditorInstances = function (params) { + if (params === void 0) { params = {}; } + var res = this.rowRenderer.getCellEditorInstances(params); + var unwrapped = res.map(unwrapUserComp); + return unwrapped; }; - HeaderRowComp.prototype.removeAndDestroyAllChildComponents = function () { - var idsOfAllChildren = Object.keys(this.headerComps); - this.destroyChildComponents(idsOfAllChildren); + /** If the grid is editing, returns back details of the editing cell(s). */ + GridApi.prototype.getEditingCells = function () { + return this.rowRenderer.getEditingCells(); }; - HeaderRowComp.prototype.onDisplayedColumnsChanged = function () { - this.onVirtualColumnsChanged(); - this.setWidth(); + /** If a cell is editing, it stops the editing. Pass `true` if you want to cancel the editing (i.e. don't accept changes). */ + GridApi.prototype.stopEditing = function (cancel) { + if (cancel === void 0) { cancel = false; } + this.rowRenderer.stopEditing(cancel); }; - HeaderRowComp.prototype.getItemsAtDepth = function () { - var _this = this; - var printLayout = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_6__["Constants"].DOM_LAYOUT_PRINT; - if (printLayout) { - // for print layout, we add all columns into the center - var centerContainer = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(this.pinned); - if (centerContainer) { - var result_1 = []; - [_constants__WEBPACK_IMPORTED_MODULE_6__["Constants"].PINNED_LEFT, null, _constants__WEBPACK_IMPORTED_MODULE_6__["Constants"].PINNED_RIGHT].forEach(function (pinned) { - var items = _this.columnController.getVirtualHeaderGroupRow(pinned, _this.type == HeaderRowType.FLOATING_FILTER ? - _this.dept - 1 : - _this.dept); - result_1 = result_1.concat(items); - }); - return result_1; - } - return []; + /** Start editing the provided cell. If another cell is editing, the editing will be stopped in that other cell. */ + GridApi.prototype.startEditingCell = function (params) { + var column = this.columnModel.getGridColumn(params.colKey); + if (!column) { + console.warn("AG Grid: no column found for " + params.colKey); + return; } - // when in normal layout, we add the columns for that container only - return this.columnController.getVirtualHeaderGroupRow(this.pinned, this.type == HeaderRowType.FLOATING_FILTER ? - this.dept - 1 : - this.dept); - }; - HeaderRowComp.prototype.onVirtualColumnsChanged = function () { - var _this = this; - var currentChildIds = Object.keys(this.headerComps); - var correctChildIds = []; - var itemsAtDepth = this.getItemsAtDepth(); - itemsAtDepth.forEach(function (child) { - // skip groups that have no displayed children. this can happen when the group is broken, - // and this section happens to have nothing to display for the open / closed state. - // (a broken group is one that is split, ie columns in the group have a non-group column - // in between them) - if (child.isEmptyGroup()) { - return; - } - var idOfChild = child.getUniqueId(); - var eParentContainer = _this.getGui(); - // if we already have this cell rendered, do nothing - var colAlreadyInDom = currentChildIds.indexOf(idOfChild) >= 0; - var headerComp; - var eHeaderCompGui; - if (colAlreadyInDom) { - Object(_utils_array__WEBPACK_IMPORTED_MODULE_10__["removeFromArray"])(currentChildIds, idOfChild); - } - else { - headerComp = _this.createHeaderComp(child); - _this.headerComps[idOfChild] = headerComp; - eHeaderCompGui = headerComp.getGui(); - eParentContainer.appendChild(eHeaderCompGui); - } - correctChildIds.push(idOfChild); - }); - // at this point, anything left in currentChildIds is an element that is no longer in the viewport - this.destroyChildComponents(currentChildIds, true); - var ensureDomOrder = this.gridOptionsWrapper.isEnsureDomOrder(); - if (ensureDomOrder) { - var correctChildOrder = correctChildIds.map(function (id) { return _this.headerComps[id].getGui(); }); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_11__["setDomChildOrder"])(this.getGui(), correctChildOrder); + var cellPosition = { + rowIndex: params.rowIndex, + rowPinned: params.rowPinned || null, + column: column + }; + var notPinned = params.rowPinned == null; + if (notPinned) { + this.gridBodyCon.getScrollFeature().ensureIndexVisible(params.rowIndex); } - }; - HeaderRowComp.prototype.createHeaderComp = function (columnGroupChild) { - var result; - switch (this.type) { - case HeaderRowType.COLUMN: - result = new _header_headerWrapperComp__WEBPACK_IMPORTED_MODULE_4__["HeaderWrapperComp"](columnGroupChild, this.dropTarget, this.pinned); - break; - case HeaderRowType.COLUMN_GROUP: - result = new _headerGroup_headerGroupWrapperComp__WEBPACK_IMPORTED_MODULE_5__["HeaderGroupWrapperComp"](columnGroupChild, this.dropTarget, this.pinned); - break; - case HeaderRowType.FLOATING_FILTER: - result = new _filter_floating_floatingFilterWrapper__WEBPACK_IMPORTED_MODULE_7__["FloatingFilterWrapper"](columnGroupChild, this.pinned); - break; + var cell = this.navigationService.getCellByPosition(cellPosition); + if (!cell) { + return; } - this.createBean(result); - result.setParentComponent(this); - return result; - }; - HeaderRowComp.prototype.getHeaderComps = function () { - return this.headerComps; - }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], HeaderRowComp.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController') - ], HeaderRowComp.prototype, "columnController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('focusController') - ], HeaderRowComp.prototype, "focusController", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PreDestroy"] - ], HeaderRowComp.prototype, "destroyAllChildComponents", null); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], HeaderRowComp.prototype, "init", null); - return HeaderRowComp; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); - - - -/***/ }), -/* 111 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderWrapperComp", function() { return HeaderWrapperComp; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(35); -/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(104); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25); -/* harmony import */ var _cssClassApplier__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(112); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(43); -/* harmony import */ var _hoverFeature__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(113); -/* harmony import */ var _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(114); -/* harmony import */ var _selectAllFeature__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(115); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(57); -/* harmony import */ var _widgets_touchListener__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(65); -/* harmony import */ var _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(107); -/* harmony import */ var _abstractHeaderWrapper__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(116); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + cell.startRowOrCellEdit(params.key, params.charPress); }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - - - - - - - - - - - -var HeaderWrapperComp = /** @class */ (function (_super) { - __extends(HeaderWrapperComp, _super); - function HeaderWrapperComp(column, dragSourceDropTarget, pinned) { - var _this = _super.call(this, HeaderWrapperComp.TEMPLATE) || this; - _this.column = column; - _this.dragSourceDropTarget = dragSourceDropTarget; - _this.pinned = pinned; - return _this; - } - HeaderWrapperComp.prototype.postConstruct = function () { - _super.prototype.postConstruct.call(this); - var colDef = this.getComponentHolder(); - var displayName = this.columnController.getDisplayNameForColumn(this.column, 'header', true); - var enableSorting = colDef.sortable; - var enableMenu = this.menuEnabled = this.menuFactory.isMenuEnabled(this.column) && !colDef.suppressMenu; - this.appendHeaderComp(displayName, enableSorting, enableMenu); - this.setupWidth(); - this.setupMovingCss(); - this.setupTooltip(); - this.setupResize(); - this.setupMenuClass(); - this.setupSortableClass(enableSorting); - this.addColumnHoverListener(); - this.addDisplayMenuListeners(); - this.cbSelectAll.setInputAriaLabel('Toggle Selection of All Rows'); - this.createManagedBean(new _hoverFeature__WEBPACK_IMPORTED_MODULE_6__["HoverFeature"]([this.column], this.getGui())); - this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_FILTER_ACTIVE_CHANGED, this.onFilterChanged.bind(this)); - this.onFilterChanged(); - this.createManagedBean(new _selectAllFeature__WEBPACK_IMPORTED_MODULE_8__["SelectAllFeature"](this.cbSelectAll, this.column)); - var setLeftFeature = new _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_7__["SetLeftFeature"](this.column, this.getGui(), this.beans); - this.createManagedBean(setLeftFeature); - this.addAttributes(); - _cssClassApplier__WEBPACK_IMPORTED_MODULE_4__["CssClassApplier"].addHeaderClassesFromColDef(colDef, this.getGui(), this.gridOptionsWrapper, this.column, null); + /** Add an aggregation function with the specified key. */ + GridApi.prototype.addAggFunc = function (key, aggFunc) { + if (this.aggFuncService) { + this.aggFuncService.addAggFunc(key, aggFunc); + } }; - HeaderWrapperComp.prototype.addDisplayMenuListeners = function () { - var mouseListener = this.onMouseOverOut.bind(this); - this.addGuiEventListener('mouseenter', mouseListener); - this.addGuiEventListener('mouseleave', mouseListener); + /** Add aggregations function with the specified keys. */ + GridApi.prototype.addAggFuncs = function (aggFuncs) { + if (this.aggFuncService) { + this.aggFuncService.addAggFuncs(aggFuncs); + } }; - HeaderWrapperComp.prototype.onMouseOverOut = function (e) { - if (this.headerComp && this.headerComp.setActiveParent) { - this.headerComp.setActiveParent(e.type === 'mouseenter'); + /** Clears all aggregation functions (including those provided by the grid). */ + GridApi.prototype.clearAggFuncs = function () { + if (this.aggFuncService) { + this.aggFuncService.clear(); } }; - HeaderWrapperComp.prototype.onFocusIn = function (e) { - if (!this.getGui().contains(e.relatedTarget)) { - var headerRow = this.getParentComponent(); - this.focusController.setFocusedHeader(headerRow.getRowIndex(), this.getColumn()); + /** Apply transactions to the server side row model. */ + GridApi.prototype.applyServerSideTransaction = function (transaction) { + if (!this.serverSideTransactionManager) { + console.warn('AG Grid: Cannot apply Server Side Transaction if not using the Server Side Row Model.'); + return; } - if (this.headerComp && this.headerComp.setActiveParent) { - this.headerComp.setActiveParent(true); + return this.serverSideTransactionManager.applyTransaction(transaction); + }; + GridApi.prototype.applyServerSideTransactionAsync = function (transaction, callback) { + if (!this.serverSideTransactionManager) { + console.warn('AG Grid: Cannot apply Server Side Transaction if not using the Server Side Row Model.'); + return; } + return this.serverSideTransactionManager.applyTransactionAsync(transaction, callback); }; - HeaderWrapperComp.prototype.onFocusOut = function (e) { - if (!this.headerComp || - !this.headerComp.setActiveParent || - this.getGui().contains(e.relatedTarget)) { + /** Gets all failed server side loads to retry. */ + GridApi.prototype.retryServerSideLoads = function () { + if (!this.serverSideRowModel) { + console.warn('AG Grid: API retryServerSideLoads() can only be used when using Server-Side Row Model.'); return; } - this.headerComp.setActiveParent(false); + this.serverSideRowModel.retryLoads(); }; - HeaderWrapperComp.prototype.handleKeyDown = function (e) { - var headerComp = this.headerComp; - if (!headerComp) { + GridApi.prototype.flushServerSideAsyncTransactions = function () { + if (!this.serverSideTransactionManager) { + console.warn('AG Grid: Cannot flush Server Side Transaction if not using the Server Side Row Model.'); return; } - if (e.keyCode === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_SPACE) { - var checkbox = this.cbSelectAll; - if (checkbox.isDisplayed() && !checkbox.getGui().contains(document.activeElement)) { - checkbox.setValue(!checkbox.getValue()); - } + return this.serverSideTransactionManager.flushAsyncTransactions(); + }; + /** Update row data. Pass a transaction object with lists for `add`, `remove` and `update`. */ + GridApi.prototype.applyTransaction = function (rowDataTransaction) { + if (!this.clientSideRowModel) { + console.error('AG Grid: updateRowData() only works with ClientSideRowModel. Working with InfiniteRowModel was deprecated in v23.1 and removed in v24.1'); + return; } - if (e.keyCode === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_ENTER) { - if (e.ctrlKey || e.metaKey) { - if (this.menuEnabled && headerComp.showMenu) { - e.preventDefault(); - headerComp.showMenu(); - } - } - else if (this.sortable) { - var multiSort = e.shiftKey; - this.sortController.progressSort(this.column, multiSort, "uiColumnSorted"); - } + var res = this.clientSideRowModel.updateRowData(rowDataTransaction); + // refresh all the full width rows + this.rowRenderer.refreshFullWidthRows(res.update); + // do change detection for all present cells + if (!this.gridOptionsWrapper.isSuppressChangeDetection()) { + this.rowRenderer.refreshCells(); } + return res; }; - HeaderWrapperComp.prototype.getComponentHolder = function () { - return this.column.getColDef(); - }; - HeaderWrapperComp.prototype.addColumnHoverListener = function () { - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_5__["Events"].EVENT_COLUMN_HOVER_CHANGED, this.onColumnHover.bind(this)); - this.onColumnHover(); + /** @deprecated */ + GridApi.prototype.updateRowData = function (rowDataTransaction) { + var message = 'AG Grid: as of v23.1, grid API updateRowData(transaction) is now called applyTransaction(transaction). updateRowData is deprecated and will be removed in a future major release.'; + Object(_utils_function__WEBPACK_IMPORTED_MODULE_11__["doOnce"])(function () { return console.warn(message); }, 'updateRowData deprecated'); + return this.applyTransaction(rowDataTransaction); }; - HeaderWrapperComp.prototype.onColumnHover = function () { - var isHovered = this.columnHoverService.isHovered(this.column); - _utils__WEBPACK_IMPORTED_MODULE_13__["_"].addOrRemoveCssClass(this.getGui(), 'ag-column-hover', isHovered); + /** Same as `applyTransaction` except executes asynchronously for efficiency. */ + GridApi.prototype.applyTransactionAsync = function (rowDataTransaction, callback) { + if (!this.clientSideRowModel) { + console.error('AG Grid: api.applyTransactionAsync() only works with ClientSideRowModel.'); + return; + } + this.clientSideRowModel.batchUpdateRowData(rowDataTransaction, callback); }; - HeaderWrapperComp.prototype.setupSortableClass = function (enableSorting) { - if (!enableSorting) { + /** Executes any remaining asynchronous grid transactions, if any are waiting to be executed. */ + GridApi.prototype.flushAsyncTransactions = function () { + if (!this.clientSideRowModel) { + console.error('AG Grid: api.applyTransactionAsync() only works with ClientSideRowModel.'); return; } - var element = this.getGui(); - _utils__WEBPACK_IMPORTED_MODULE_13__["_"].addCssClass(element, 'ag-header-cell-sortable'); - this.sortable = true; + this.clientSideRowModel.flushAsyncTransactions(); }; - HeaderWrapperComp.prototype.onFilterChanged = function () { - var filterPresent = this.column.isFilterActive(); - _utils__WEBPACK_IMPORTED_MODULE_13__["_"].addOrRemoveCssClass(this.getGui(), 'ag-header-cell-filtered', filterPresent); + /** @deprecated */ + GridApi.prototype.batchUpdateRowData = function (rowDataTransaction, callback) { + var message = 'AG Grid: as of v23.1, grid API batchUpdateRowData(transaction, callback) is now called applyTransactionAsync(transaction, callback). batchUpdateRowData is deprecated and will be removed in a future major release.'; + Object(_utils_function__WEBPACK_IMPORTED_MODULE_11__["doOnce"])(function () { return console.warn(message); }, 'batchUpdateRowData deprecated'); + this.applyTransactionAsync(rowDataTransaction, callback); }; - HeaderWrapperComp.prototype.appendHeaderComp = function (displayName, enableSorting, enableMenu) { - var _this = this; - var params = { - column: this.column, - displayName: displayName, - enableSorting: enableSorting, - enableMenu: enableMenu, - showColumnMenu: function (source) { - _this.gridApi.showColumnMenuAfterButtonClick(_this.column, source); - }, - progressSort: function (multiSort) { - _this.sortController.progressSort(_this.column, !!multiSort, "uiColumnSorted"); - }, - setSort: function (sort, multiSort) { - _this.sortController.setSortForColumn(_this.column, sort, !!multiSort, "uiColumnSorted"); - }, - api: this.gridApi, - columnApi: this.columnApi, - context: this.gridOptionsWrapper.getContext() - }; - var callback = this.afterHeaderCompCreated.bind(this, displayName); - this.userComponentFactory.newHeaderComponent(params).then(callback); + GridApi.prototype.insertItemsAtIndex = function (index, items, skipRefresh) { + if (skipRefresh === void 0) { skipRefresh = false; } + console.warn('AG Grid: insertItemsAtIndex() is deprecated, use updateRowData(transaction) instead.'); + this.updateRowData({ add: items, addIndex: index, update: null, remove: null }); }; - HeaderWrapperComp.prototype.afterHeaderCompCreated = function (displayName, headerComp) { - var _this = this; - this.getGui().appendChild(headerComp.getGui()); - this.addDestroyFunc(function () { - _this.getContext().destroyBean(headerComp); - }); - this.setupMove(headerComp.getGui(), displayName); - this.headerComp = headerComp; + GridApi.prototype.removeItems = function (rowNodes, skipRefresh) { + if (skipRefresh === void 0) { skipRefresh = false; } + console.warn('AG Grid: removeItems() is deprecated, use updateRowData(transaction) instead.'); + var dataToRemove = rowNodes.map(function (rowNode) { return rowNode.data; }); + this.updateRowData({ add: null, addIndex: null, update: null, remove: dataToRemove }); }; - HeaderWrapperComp.prototype.onColumnMovingChanged = function () { - // this function adds or removes the moving css, based on if the col is moving. - // this is what makes the header go dark when it is been moved (gives impression to - // user that the column was picked up). - if (this.column.isMoving()) { - _utils__WEBPACK_IMPORTED_MODULE_13__["_"].addCssClass(this.getGui(), 'ag-header-cell-moving'); + GridApi.prototype.addItems = function (items, skipRefresh) { + if (skipRefresh === void 0) { skipRefresh = false; } + console.warn('AG Grid: addItems() is deprecated, use updateRowData(transaction) instead.'); + this.updateRowData({ add: items, addIndex: null, update: null, remove: null }); + }; + GridApi.prototype.refreshVirtualPageCache = function () { + console.warn('AG Grid: refreshVirtualPageCache() is now called refreshInfiniteCache(), please call refreshInfiniteCache() instead'); + this.refreshInfiniteCache(); + }; + GridApi.prototype.refreshInfinitePageCache = function () { + console.warn('AG Grid: refreshInfinitePageCache() is now called refreshInfiniteCache(), please call refreshInfiniteCache() instead'); + this.refreshInfiniteCache(); + }; + /** + * Marks all the currently loaded blocks in the cache for reload. + * If you have 10 blocks in the cache, all 10 will be marked for reload. + * The old data will continue to be displayed until the new data is loaded. + */ + GridApi.prototype.refreshInfiniteCache = function () { + if (this.infiniteRowModel) { + this.infiniteRowModel.refreshCache(); } else { - _utils__WEBPACK_IMPORTED_MODULE_13__["_"].removeCssClass(this.getGui(), 'ag-header-cell-moving'); + console.warn("AG Grid: api.refreshInfiniteCache is only available when rowModelType='infinite'."); } }; - HeaderWrapperComp.prototype.setupMove = function (eHeaderCellLabel, displayName) { - var _this = this; - var colDef = this.column.getColDef(); - var suppressMove = this.gridOptionsWrapper.isSuppressMovableColumns() - || this.getComponentHolder().suppressMovable - || colDef.lockPosition; - if (suppressMove && - !colDef.enableRowGroup && - !colDef.enablePivot) { - return; - } - if (eHeaderCellLabel) { - var dragSource_1 = { - type: _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragSourceType"].HeaderCell, - eElement: eHeaderCellLabel, - defaultIconName: _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_HIDE, - getDragItem: function () { return _this.createDragItem(); }, - dragItemName: displayName, - dragSourceDropTarget: this.dragSourceDropTarget, - onDragStarted: function () { return !suppressMove && _this.column.setMoving(true, "uiColumnMoved"); }, - onDragStopped: function () { return !suppressMove && _this.column.setMoving(false, "uiColumnMoved"); } - }; - this.dragAndDropService.addDragSource(dragSource_1, true); - this.addDestroyFunc(function () { return _this.dragAndDropService.removeDragSource(dragSource_1); }); - } + GridApi.prototype.purgeVirtualPageCache = function () { + console.warn('AG Grid: purgeVirtualPageCache() is now called purgeInfiniteCache(), please call purgeInfiniteCache() instead'); + this.purgeInfinitePageCache(); }; - HeaderWrapperComp.prototype.createDragItem = function () { - var visibleState = {}; - visibleState[this.column.getId()] = this.column.isVisible(); - return { - columns: [this.column], - visibleState: visibleState - }; + GridApi.prototype.purgeInfinitePageCache = function () { + console.warn('AG Grid: purgeInfinitePageCache() is now called purgeInfiniteCache(), please call purgeInfiniteCache() instead'); + this.purgeInfiniteCache(); }; - HeaderWrapperComp.prototype.setupResize = function () { - var _this = this; - var colDef = this.getComponentHolder(); - // if no eResize in template, do nothing - if (!this.eResize) { - return; + /** + * Purges the cache. + * The grid is then told to refresh. Only the blocks required to display the current data on screen are fetched (typically no more than 2). + * The grid will display nothing while the new blocks are loaded. + * Use this to immediately remove the old data from the user. + */ + GridApi.prototype.purgeInfiniteCache = function () { + if (this.infiniteRowModel) { + this.infiniteRowModel.purgeCache(); } - if (!this.column.isResizable()) { - _utils__WEBPACK_IMPORTED_MODULE_13__["_"].removeFromParent(this.eResize); - return; + else { + console.warn("AG Grid: api.purgeInfiniteCache is only available when rowModelType='infinite'."); } - var finishedWithResizeFunc = this.horizontalResizeService.addResizeBar({ - eResizeBar: this.eResize, - onResizeStart: this.onResizeStart.bind(this), - onResizing: this.onResizing.bind(this, false), - onResizeEnd: this.onResizing.bind(this, true) - }); - this.addDestroyFunc(finishedWithResizeFunc); - var weWantAutoSize = !this.gridOptionsWrapper.isSuppressAutoSize() && !colDef.suppressAutoSize; - var skipHeaderOnAutoSize = this.gridOptionsWrapper.isSkipHeaderOnAutoSize(); - if (weWantAutoSize) { - this.addManagedListener(this.eResize, 'dblclick', function () { - _this.columnController.autoSizeColumn(_this.column, skipHeaderOnAutoSize, "uiColumnResized"); - }); - var touchListener = new _widgets_touchListener__WEBPACK_IMPORTED_MODULE_10__["TouchListener"](this.eResize); - this.addManagedListener(touchListener, _widgets_touchListener__WEBPACK_IMPORTED_MODULE_10__["TouchListener"].EVENT_DOUBLE_TAP, function () { - _this.columnController.autoSizeColumn(_this.column, skipHeaderOnAutoSize, "uiColumnResized"); + }; + /** @deprecated */ + GridApi.prototype.purgeEnterpriseCache = function (route) { + console.warn("ag-grid: since version 18.x, api.purgeEnterpriseCache() should be replaced with api.purgeServerSideCache()"); + this.purgeServerSideCache(route); + }; + /** @deprecated */ + GridApi.prototype.purgeServerSideCache = function (route) { + if (route === void 0) { route = []; } + if (this.serverSideRowModel) { + console.warn("AG Grid: since v25.0, api.purgeServerSideCache is deprecated. Please use api.refreshServerSideStore({purge: true}) instead."); + this.refreshServerSideStore({ + route: route, + purge: true }); - this.addDestroyFunc(touchListener.destroy.bind(touchListener)); } - }; - HeaderWrapperComp.prototype.onResizing = function (finished, resizeAmount) { - var resizeAmountNormalised = this.normaliseResizeAmount(resizeAmount); - var columnWidths = [{ key: this.column, newWidth: this.resizeStartWidth + resizeAmountNormalised }]; - this.columnController.setColumnWidths(columnWidths, this.resizeWithShiftKey, finished, "uiColumnDragged"); - if (finished) { - _utils__WEBPACK_IMPORTED_MODULE_13__["_"].removeCssClass(this.getGui(), 'ag-column-resizing'); + else { + console.warn("AG Grid: api.purgeServerSideCache is only available when rowModelType='serverSide'."); } }; - HeaderWrapperComp.prototype.onResizeStart = function (shiftKey) { - this.resizeStartWidth = this.column.getActualWidth(); - this.resizeWithShiftKey = shiftKey; - _utils__WEBPACK_IMPORTED_MODULE_13__["_"].addCssClass(this.getGui(), 'ag-column-resizing'); - }; - HeaderWrapperComp.prototype.getTooltipText = function () { - var colDef = this.getComponentHolder(); - return colDef.headerTooltip; - }; - HeaderWrapperComp.prototype.setupTooltip = function () { - var tooltipText = this.getTooltipText(); - // add tooltip if exists - if (tooltipText == null) { - return; + /** + * Refresh a server-side store. + * If you pass no parameters, then the top level cache is purged. + * To purge a child cache, pass in the string of keys to get to the child cache. + */ + GridApi.prototype.refreshServerSideStore = function (params) { + if (this.serverSideRowModel) { + this.serverSideRowModel.refreshStore(params); } - if (this.gridOptionsWrapper.isEnableBrowserTooltips()) { - this.getGui().setAttribute('title', tooltipText); + else { + console.warn("AG Grid: api.refreshServerSideStore is only available when rowModelType='serverSide'."); + } + }; + /** Returns info on all server side stores. */ + GridApi.prototype.getServerSideStoreState = function () { + if (this.serverSideRowModel) { + return this.serverSideRowModel.getStoreState(); } else { - this.createManagedBean(new _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_11__["TooltipFeature"](this, 'header')); + console.warn("AG Grid: api.getServerSideStoreState is only available when rowModelType='serverSide'."); + return []; } }; - HeaderWrapperComp.prototype.setupMovingCss = function () { - this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_MOVING_CHANGED, this.onColumnMovingChanged.bind(this)); - this.onColumnMovingChanged(); + GridApi.prototype.getVirtualRowCount = function () { + console.warn('AG Grid: getVirtualRowCount() is now called getInfiniteRowCount(), please call getInfiniteRowCount() instead'); + return this.getInfiniteRowCount(); }; - HeaderWrapperComp.prototype.addAttributes = function () { - this.getGui().setAttribute("col-id", this.column.getColId()); + /** The row count defines how many rows the grid allows scrolling to. */ + GridApi.prototype.getInfiniteRowCount = function () { + if (this.infiniteRowModel) { + return this.infiniteRowModel.getRowCount(); + } + else { + console.warn("AG Grid: api.getVirtualRowCount is only available when rowModelType='virtual'."); + } }; - HeaderWrapperComp.prototype.setupWidth = function () { - this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_WIDTH_CHANGED, this.onColumnWidthChanged.bind(this)); - this.onColumnWidthChanged(); + GridApi.prototype.isMaxRowFound = function () { + console.warn("AG Grid: api.isLastRowIndexKnown is deprecated, please use api.isLastRowIndexKnown()"); + return this.isLastRowIndexKnown(); }; - HeaderWrapperComp.prototype.setupMenuClass = function () { - this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_MENU_VISIBLE_CHANGED, this.onMenuVisible.bind(this)); - this.onColumnWidthChanged(); + /** Returns `true` if grid allows for scrolling past the last row to load more rows, thus providing infinite scroll. */ + GridApi.prototype.isLastRowIndexKnown = function () { + if (this.infiniteRowModel) { + return this.infiniteRowModel.isLastRowIndexKnown(); + } + else { + console.warn("AG Grid: api.isMaxRowFound is only available when rowModelType='virtual'."); + } }; - HeaderWrapperComp.prototype.onMenuVisible = function () { - this.addOrRemoveCssClass('ag-column-menu-visible', this.column.isMenuVisible()); + GridApi.prototype.setVirtualRowCount = function (rowCount, maxRowFound) { + console.warn('AG Grid: setVirtualRowCount() is now called setInfiniteRowCount(), please call setInfiniteRowCount() instead'); + this.setRowCount(rowCount, maxRowFound); }; - HeaderWrapperComp.prototype.onColumnWidthChanged = function () { - this.getGui().style.width = this.column.getActualWidth() + 'px'; + GridApi.prototype.setInfiniteRowCount = function (rowCount, maxRowFound) { + console.warn('AG Grid: setInfiniteRowCount() is now called setRowCount(), please call setRowCount() instead'); + this.setRowCount(rowCount, maxRowFound); }; - // optionally inverts the drag, depending on pinned and RTL - // note - this method is duplicated in RenderedHeaderGroupCell - should refactor out? - HeaderWrapperComp.prototype.normaliseResizeAmount = function (dragChange) { - var result = dragChange; - if (this.gridOptionsWrapper.isEnableRtl()) { - // for RTL, dragging left makes the col bigger, except when pinning left - if (this.pinned !== _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_LEFT) { - result *= -1; - } + /** + * Sets the `rowCount` and `lastRowIndexKnown` properties. + * The second parameter, `lastRowIndexKnown`, is optional and if left out, only `rowCount` is set. + * Set `rowCount` to adjust the height of the vertical scroll. + * Set `lastRowIndexKnown` to enable / disable searching for more rows. + * Use this method if you add or remove rows into the dataset and need to reset the number of rows or put the data back into 'look for data' mode. + */ + GridApi.prototype.setRowCount = function (rowCount, maxRowFound) { + if (this.infiniteRowModel) { + this.infiniteRowModel.setRowCount(rowCount, maxRowFound); } else { - // for LTR (ie normal), dragging left makes the col smaller, except when pinning right - if (this.pinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_RIGHT) { - result *= -1; - } + console.warn("AG Grid: api.setRowCount is only available for Infinite Row Model."); } - return result; }; - HeaderWrapperComp.TEMPLATE = "
\n
\n \n
"; + GridApi.prototype.getVirtualPageState = function () { + console.warn('AG Grid: getVirtualPageState() is now called getCacheBlockState(), please call getCacheBlockState() instead'); + return this.getCacheBlockState(); + }; + GridApi.prototype.getInfinitePageState = function () { + console.warn('AG Grid: getInfinitePageState() is now called getCacheBlockState(), please call getCacheBlockState() instead'); + return this.getCacheBlockState(); + }; + /** + * Returns an object representing the state of the cache. This is useful for debugging and understanding how the cache is working. + */ + GridApi.prototype.getCacheBlockState = function () { + return this.rowNodeBlockLoader.getBlockState(); + }; + GridApi.prototype.checkGridSize = function () { + console.warn("in AG Grid v25.2.0, checkGridSize() was removed, as it was legacy and didn't do anything uesful."); + }; + GridApi.prototype.getFirstRenderedRow = function () { + console.warn('in AG Grid v12, getFirstRenderedRow() was renamed to getFirstDisplayedRow()'); + return this.getFirstDisplayedRow(); + }; + /** Get the index of the first displayed row due to scrolling (includes invisible rendered rows in the buffer). */ + GridApi.prototype.getFirstDisplayedRow = function () { + return this.rowRenderer.getFirstVirtualRenderedRow(); + }; + GridApi.prototype.getLastRenderedRow = function () { + console.warn('in AG Grid v12, getLastRenderedRow() was renamed to getLastDisplayedRow()'); + return this.getLastDisplayedRow(); + }; + /** Get the index of the last displayed row due to scrolling (includes invisible rendered rows in the buffer). */ + GridApi.prototype.getLastDisplayedRow = function () { + return this.rowRenderer.getLastVirtualRenderedRow(); + }; + /** Returns the displayed `RowNode` at the given `index`. */ + GridApi.prototype.getDisplayedRowAtIndex = function (index) { + return this.rowModel.getRow(index); + }; + /** Returns the total number of displayed rows. */ + GridApi.prototype.getDisplayedRowCount = function () { + return this.rowModel.getRowCount(); + }; + /** + * Returns `true` when the last page is known. + * This will always be `true` if you are using the Client-Side Row Model for pagination. + * Returns `false` when the last page is not known; this only happens when using Infinite Row Model. + */ + GridApi.prototype.paginationIsLastPageFound = function () { + return this.paginationProxy.isLastPageFound(); + }; + /** Returns how many rows are being shown per page. */ + GridApi.prototype.paginationGetPageSize = function () { + return this.paginationProxy.getPageSize(); + }; + /** Sets the `paginationPageSize`, then re-paginates the grid so the changes are applied immediately. */ + GridApi.prototype.paginationSetPageSize = function (size) { + this.gridOptionsWrapper.setProperty('paginationPageSize', size); + }; + /** Returns the 0-based index of the page which is showing. */ + GridApi.prototype.paginationGetCurrentPage = function () { + return this.paginationProxy.getCurrentPage(); + }; + /** Returns the total number of pages. Returns `null` if `paginationIsLastPageFound() === false`. */ + GridApi.prototype.paginationGetTotalPages = function () { + return this.paginationProxy.getTotalPages(); + }; + /** The total number of rows. Returns `null` if `paginationIsLastPageFound() === false`. */ + GridApi.prototype.paginationGetRowCount = function () { + return this.paginationProxy.getMasterRowCount(); + }; + /** Navigates to the next page. */ + GridApi.prototype.paginationGoToNextPage = function () { + this.paginationProxy.goToNextPage(); + }; + /** Navigates to the previous page. */ + GridApi.prototype.paginationGoToPreviousPage = function () { + this.paginationProxy.goToPreviousPage(); + }; + /** Navigates to the first page. */ + GridApi.prototype.paginationGoToFirstPage = function () { + this.paginationProxy.goToFirstPage(); + }; + /** Navigates to the last page. */ + GridApi.prototype.paginationGoToLastPage = function () { + this.paginationProxy.goToLastPage(); + }; + /** Goes to the specified page. If the page requested doesn't exist, it will go to the last page. */ + GridApi.prototype.paginationGoToPage = function (page) { + this.paginationProxy.goToPage(page); + }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], HeaderWrapperComp.prototype, "gridOptionsWrapper", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('immutableService') + ], GridApi.prototype, "immutableService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('dragAndDropService') - ], HeaderWrapperComp.prototype, "dragAndDropService", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('csvCreator') + ], GridApi.prototype, "csvCreator", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], HeaderWrapperComp.prototype, "columnController", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('excelCreator') + ], GridApi.prototype, "excelCreator", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('horizontalResizeService') - ], HeaderWrapperComp.prototype, "horizontalResizeService", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('rowRenderer') + ], GridApi.prototype, "rowRenderer", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('menuFactory') - ], HeaderWrapperComp.prototype, "menuFactory", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('navigationService') + ], GridApi.prototype, "navigationService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') - ], HeaderWrapperComp.prototype, "gridApi", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('filterManager') + ], GridApi.prototype, "filterManager", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') - ], HeaderWrapperComp.prototype, "columnApi", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnModel') + ], GridApi.prototype, "columnModel", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('sortController') - ], HeaderWrapperComp.prototype, "sortController", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('selectionService') + ], GridApi.prototype, "selectionService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('userComponentFactory') - ], HeaderWrapperComp.prototype, "userComponentFactory", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper') + ], GridApi.prototype, "gridOptionsWrapper", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnHoverService') - ], HeaderWrapperComp.prototype, "columnHoverService", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('valueService') + ], GridApi.prototype, "valueService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('alignedGridsService') + ], GridApi.prototype, "alignedGridsService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('eventService') + ], GridApi.prototype, "eventService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('pinnedRowModel') + ], GridApi.prototype, "pinnedRowModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('context') + ], GridApi.prototype, "context", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('rowModel') + ], GridApi.prototype, "rowModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('sortController') + ], GridApi.prototype, "sortController", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('paginationProxy') + ], GridApi.prototype, "paginationProxy", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('focusService') + ], GridApi.prototype, "focusService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('dragAndDropService') + ], GridApi.prototype, "dragAndDropService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('rangeService') + ], GridApi.prototype, "rangeService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('clipboardService') + ], GridApi.prototype, "clipboardService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('aggFuncService') + ], GridApi.prototype, "aggFuncService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('menuFactory') + ], GridApi.prototype, "menuFactory", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('contextMenuFactory') + ], GridApi.prototype, "contextMenuFactory", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('valueCache') + ], GridApi.prototype, "valueCache", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('animationFrameService') + ], GridApi.prototype, "animationFrameService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('statusBarService') + ], GridApi.prototype, "statusBarService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('chartService') + ], GridApi.prototype, "chartService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('undoRedoService') + ], GridApi.prototype, "undoRedoService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('rowNodeBlockLoader') + ], GridApi.prototype, "rowNodeBlockLoader", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('ssrmTransactionManager') + ], GridApi.prototype, "serverSideTransactionManager", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('beans') - ], HeaderWrapperComp.prototype, "beans", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('ctrlsService') + ], GridApi.prototype, "ctrlsService", void 0); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eResize') - ], HeaderWrapperComp.prototype, "eResize", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('frameworkComponentWrapper') + ], GridApi.prototype, "frameworkComponentWrapper", void 0); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('cbSelectAll') - ], HeaderWrapperComp.prototype, "cbSelectAll", void 0); - return HeaderWrapperComp; -}(_abstractHeaderWrapper__WEBPACK_IMPORTED_MODULE_12__["AbstractHeaderWrapper"])); + _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] + ], GridApi.prototype, "init", null); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_2__["PreDestroy"] + ], GridApi.prototype, "cleanDownReferencesToAvoidMemoryLeakInCaseApplicationIsKeepingReferenceToDestroyedGrid", null); + GridApi = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Bean"])('gridApi') + ], GridApi); + return GridApi; +}()); /***/ }), -/* 112 */ +/* 150 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CssClassApplier", function() { return CssClassApplier; }); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ExcelFactoryMode", function() { return ExcelFactoryMode; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ - -var CssClassApplier = /** @class */ (function () { - function CssClassApplier() { - } - CssClassApplier.addHeaderClassesFromColDef = function (abstractColDef, eHeaderCell, gridOptionsWrapper, column, columnGroup) { - if (_utils__WEBPACK_IMPORTED_MODULE_0__["_"].missing(abstractColDef)) { - return; - } - this.addColumnClassesFromCollDef(abstractColDef.headerClass, abstractColDef, eHeaderCell, gridOptionsWrapper, column, columnGroup); - }; - CssClassApplier.addToolPanelClassesFromColDef = function (abstractColDef, eHeaderCell, gridOptionsWrapper, column, columnGroup) { - if (_utils__WEBPACK_IMPORTED_MODULE_0__["_"].missing(abstractColDef)) { - return; - } - this.addColumnClassesFromCollDef(abstractColDef.toolPanelClass, abstractColDef, eHeaderCell, gridOptionsWrapper, column, columnGroup); - }; - CssClassApplier.addColumnClassesFromCollDef = function (classesOrFunc, abstractColDef, eHeaderCell, gridOptionsWrapper, column, columnGroup) { - if (_utils__WEBPACK_IMPORTED_MODULE_0__["_"].missing(classesOrFunc)) { - return; - } - var classToUse; - if (typeof classesOrFunc === 'function') { - var params = { - // bad naming, as colDef here can be a group or a column, - // however most people won't appreciate the difference, - // so keeping it as colDef to avoid confusion. - colDef: abstractColDef, - column: column, - columnGroup: columnGroup, - context: gridOptionsWrapper.getContext(), - api: gridOptionsWrapper.getApi() - }; - var headerClassFunc = classesOrFunc; - classToUse = headerClassFunc(params); - } - else { - classToUse = classesOrFunc; - } - if (typeof classToUse === 'string') { - _utils__WEBPACK_IMPORTED_MODULE_0__["_"].addCssClass(eHeaderCell, classToUse); - } - else if (Array.isArray(classToUse)) { - classToUse.forEach(function (cssClassItem) { - _utils__WEBPACK_IMPORTED_MODULE_0__["_"].addCssClass(eHeaderCell, cssClassItem); - }); - } - }; - return CssClassApplier; -}()); - +// Excel Export +var ExcelFactoryMode; +(function (ExcelFactoryMode) { + ExcelFactoryMode[ExcelFactoryMode["SINGLE_SHEET"] = 0] = "SINGLE_SHEET"; + ExcelFactoryMode[ExcelFactoryMode["MULTI_SHEET"] = 1] = "MULTI_SHEET"; +})(ExcelFactoryMode || (ExcelFactoryMode = {})); /***/ }), -/* 113 */ +/* 151 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HoverFeature", function() { return HoverFeature; }); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(41); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ClientSideRowModelSteps", function() { return ClientSideRowModelSteps; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - -var HoverFeature = /** @class */ (function (_super) { - __extends(HoverFeature, _super); - function HoverFeature(columns, element) { - var _this = _super.call(this) || this; - _this.columns = columns; - _this.element = element; - return _this; - } - HoverFeature.prototype.postConstruct = function () { - this.addMouseHoverListeners(); - }; - HoverFeature.prototype.addMouseHoverListeners = function () { - this.addManagedListener(this.element, 'mouseout', this.onMouseOut.bind(this)); - this.addManagedListener(this.element, 'mouseover', this.onMouseOver.bind(this)); - }; - HoverFeature.prototype.onMouseOut = function () { - this.columnHoverService.clearMouseOver(); - }; - HoverFeature.prototype.onMouseOver = function () { - this.columnHoverService.setMouseOver(this.columns); - }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnHoverService') - ], HoverFeature.prototype, "columnHoverService", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], HoverFeature.prototype, "postConstruct", null); - return HoverFeature; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); - +var ClientSideRowModelSteps; +(function (ClientSideRowModelSteps) { + ClientSideRowModelSteps["EVERYTHING"] = "group"; + ClientSideRowModelSteps["FILTER"] = "filter"; + ClientSideRowModelSteps["SORT"] = "sort"; + ClientSideRowModelSteps["MAP"] = "map"; + ClientSideRowModelSteps["AGGREGATE"] = "aggregate"; + ClientSideRowModelSteps["PIVOT"] = "pivot"; + ClientSideRowModelSteps["NOTHING"] = "nothing"; +})(ClientSideRowModelSteps || (ClientSideRowModelSteps = {})); /***/ }), -/* 114 */ +/* 152 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SetLeftFeature", function() { return SetLeftFeature; }); -/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(35); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(10); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(15); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(12); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(44); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(18); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(24); +/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(107); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -26547,6 +34125,10 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta + + + + var SetLeftFeature = /** @class */ (function (_super) { __extends(SetLeftFeature, _super); function SetLeftFeature(columnOrGroup, eCell, beans, colsSpanning) { @@ -26556,7 +34138,6 @@ var SetLeftFeature = /** @class */ (function (_super) { _this.ariaEl = _this.eCell.querySelector('[role=columnheader]') || _this.eCell; _this.colsSpanning = colsSpanning; _this.beans = beans; - _this.printLayout = beans.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].DOM_LAYOUT_PRINT; return _this; } SetLeftFeature.prototype.setColsSpanning = function (colsSpanning) { @@ -26565,17 +34146,22 @@ var SetLeftFeature = /** @class */ (function (_super) { }; SetLeftFeature.prototype.getColumnOrGroup = function () { if (this.beans.gridOptionsWrapper.isEnableRtl() && this.colsSpanning) { - return _utils__WEBPACK_IMPORTED_MODULE_4__["_"].last(this.colsSpanning); + return Object(_utils_array__WEBPACK_IMPORTED_MODULE_5__["last"])(this.colsSpanning); } return this.columnOrGroup; }; SetLeftFeature.prototype.postConstruct = function () { this.addManagedListener(this.columnOrGroup, _entities_column__WEBPACK_IMPORTED_MODULE_0__["Column"].EVENT_LEFT_CHANGED, this.onLeftChanged.bind(this)); this.setLeftFirstTime(); + // when in print layout, the left position is also dependent on the width of the pinned sections. + // so additionally update left if any column width changes. + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_7__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, this.onLeftChanged.bind(this)); + // setting left has a dependency on print layout + this.addManagedListener(this.beans.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_8__["GridOptionsWrapper"].PROP_DOM_LAYOUT, this.onLeftChanged.bind(this)); }; SetLeftFeature.prototype.setLeftFirstTime = function () { var suppressMoveAnimation = this.beans.gridOptionsWrapper.isSuppressColumnMoveAnimation(); - var oldLeftExists = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].exists(this.columnOrGroup.getOldLeft()); + var oldLeftExists = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_6__["exists"])(this.columnOrGroup.getOldLeft()); var animateColumnMove = this.beans.columnAnimationService.isActive() && oldLeftExists && !suppressMoveAnimation; if (animateColumnMove) { this.animateInLeft(); @@ -26586,19 +34172,22 @@ var SetLeftFeature = /** @class */ (function (_super) { }; SetLeftFeature.prototype.animateInLeft = function () { var _this = this; - var left = this.getColumnOrGroup().getLeft(); - var oldLeft = this.getColumnOrGroup().getOldLeft(); - this.setLeft(oldLeft); + var colOrGroup = this.getColumnOrGroup(); + var left = colOrGroup.getLeft(); + var oldLeft = colOrGroup.getOldLeft(); + var oldActualLeft = this.modifyLeftForPrintLayout(colOrGroup, oldLeft); + var actualLeft = this.modifyLeftForPrintLayout(colOrGroup, left); + this.setLeft(oldActualLeft); // we must keep track of the left we want to set to, as this would otherwise lead to a race // condition, if the user changed the left value many times in one VM turn, then we want to make // make sure the actualLeft we set in the timeout below (in the next VM turn) is the correct left // position. eg if user changes column position twice, then setLeft() below executes twice in next // VM turn, but only one (the correct one) should get applied. - this.actualLeft = left; + this.actualLeft = actualLeft; this.beans.columnAnimationService.executeNextVMTurn(function () { // test this left value is the latest one to be applied, and if not, do nothing - if (_this.actualLeft === left) { - _this.setLeft(left); + if (_this.actualLeft === actualLeft) { + _this.setLeft(actualLeft); } }); }; @@ -26609,515 +34198,66 @@ var SetLeftFeature = /** @class */ (function (_super) { this.setLeft(this.actualLeft); }; SetLeftFeature.prototype.modifyLeftForPrintLayout = function (colOrGroup, leftPosition) { - if (!this.printLayout) { + var printLayout = this.beans.gridOptionsWrapper.getDomLayout() === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].DOM_LAYOUT_PRINT; + if (!printLayout) { return leftPosition; } - if (colOrGroup.getPinned() === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_LEFT) { + if (colOrGroup.getPinned() === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_LEFT) { return leftPosition; } - if (colOrGroup.getPinned() === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_RIGHT) { - var leftWidth_1 = this.beans.columnController.getPinnedLeftContainerWidth(); - var bodyWidth = this.beans.columnController.getBodyContainerWidth(); - return leftWidth_1 + bodyWidth + leftPosition; + var leftWidth = this.beans.columnModel.getDisplayedColumnsLeftWidth(); + if (colOrGroup.getPinned() === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_RIGHT) { + var bodyWidth = this.beans.columnModel.getBodyContainerWidth(); + return leftWidth + bodyWidth + leftPosition; } // is in body - var leftWidth = this.beans.columnController.getPinnedLeftContainerWidth(); return leftWidth + leftPosition; }; SetLeftFeature.prototype.setLeft = function (value) { // if the value is null, then that means the column is no longer // displayed. there is logic in the rendering to fade these columns // out, so we don't try and change their left positions. - if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].exists(value)) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_6__["exists"])(value)) { this.eCell.style.left = value + "px"; } - if (this.columnOrGroup instanceof _entities_column__WEBPACK_IMPORTED_MODULE_0__["Column"]) { - var colIndex = this.beans.columnController.getAllDisplayedColumns().indexOf(this.columnOrGroup); - this.ariaEl.setAttribute('aria-colindex', (colIndex + 1).toString()); - } - else { - this.ariaEl.removeAttribute('aria-colindex'); - } - }; - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"] - ], SetLeftFeature.prototype, "postConstruct", null); - return SetLeftFeature; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); - - - -/***/ }), -/* 115 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SelectAllFeature", function() { return SelectAllFeature; }); -/* harmony import */ var _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(70); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(25); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - - -var SelectAllFeature = /** @class */ (function (_super) { - __extends(SelectAllFeature, _super); - function SelectAllFeature(cbSelectAll, column) { - var _this = _super.call(this) || this; - _this.cbSelectAllVisible = false; - _this.processingEventFromCheckbox = false; - _this.cbSelectAll = cbSelectAll; - _this.column = column; - var colDef = column.getColDef(); - _this.filteredOnly = colDef ? !!colDef.headerCheckboxSelectionFilteredOnly : false; - return _this; - } - SelectAllFeature.prototype.postConstruct = function () { - this.showOrHideSelectAll(); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.showOrHideSelectAll.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_SELECTION_CHANGED, this.onSelectionChanged.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_MODEL_UPDATED, this.onModelChanged.bind(this)); - this.addManagedListener(this.cbSelectAll, _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_0__["AgCheckbox"].EVENT_CHANGED, this.onCbSelectAll.bind(this)); - }; - SelectAllFeature.prototype.showOrHideSelectAll = function () { - this.cbSelectAllVisible = this.isCheckboxSelection(); - this.cbSelectAll.setDisplayed(this.cbSelectAllVisible); - if (this.cbSelectAllVisible) { - // in case user is trying this feature with the wrong model type - this.checkRightRowModelType(); - // make sure checkbox is showing the right state - this.updateStateOfCheckbox(); - } - }; - SelectAllFeature.prototype.onModelChanged = function () { - if (!this.cbSelectAllVisible) { - return; - } - this.updateStateOfCheckbox(); - }; - SelectAllFeature.prototype.onSelectionChanged = function () { - if (!this.cbSelectAllVisible) { - return; - } - this.updateStateOfCheckbox(); - }; - SelectAllFeature.prototype.getNextCheckboxState = function (selectionCount) { - // if no rows, always have it unselected - if (selectionCount.selected === 0 && selectionCount.notSelected === 0) { - return false; - } - // if mix of selected and unselected, this is the tri-state - if (selectionCount.selected > 0 && selectionCount.notSelected > 0) { - return null; - } - // only selected - if (selectionCount.selected > 0) { - return true; - } - // nothing selected - return false; - }; - SelectAllFeature.prototype.updateStateOfCheckbox = function () { - if (this.processingEventFromCheckbox) { - return; - } - this.processingEventFromCheckbox = true; - var selectionCount = this.getSelectionCount(); - var allSelected = this.getNextCheckboxState(selectionCount); - this.cbSelectAll.setValue(allSelected); - this.processingEventFromCheckbox = false; - }; - SelectAllFeature.prototype.getSelectionCount = function () { - var _this = this; - var selectedCount = 0; - var notSelectedCount = 0; - var callback = function (node) { - if (_this.gridOptionsWrapper.isGroupSelectsChildren() && node.group) { - return; - } - if (node.isSelected()) { - selectedCount++; - } - else if (!node.selectable) { - // don't count non-selectable nodes! - } - else { - notSelectedCount++; - } - }; - if (this.filteredOnly) { - this.gridApi.forEachNodeAfterFilter(callback); - } - else { - this.gridApi.forEachNode(callback); - } - return { - notSelected: notSelectedCount, - selected: selectedCount - }; - }; - SelectAllFeature.prototype.checkRightRowModelType = function () { - var rowModelType = this.rowModel.getType(); - var rowModelMatches = rowModelType === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE; - if (!rowModelMatches) { - console.warn("ag-Grid: selectAllCheckbox is only available if using normal row model, you are using " + rowModelType); - } - }; - SelectAllFeature.prototype.onCbSelectAll = function () { - if (this.processingEventFromCheckbox) { - return; - } - if (!this.cbSelectAllVisible) { - return; - } - var value = this.cbSelectAll.getValue(); - if (value) { - this.selectionController.selectAllRowNodes(this.filteredOnly); - } - else { - this.selectionController.deselectAllRowNodes(this.filteredOnly); - } - }; - SelectAllFeature.prototype.isCheckboxSelection = function () { - var result = this.column.getColDef().headerCheckboxSelection; - if (typeof result === 'function') { - var func = result; - result = func({ - column: this.column, - colDef: this.column.getColDef(), - columnApi: this.columnApi, - api: this.gridApi - }); - } - if (result) { - if (this.gridOptionsWrapper.isRowModelServerSide()) { - console.warn('headerCheckboxSelection is not supported for Server Side Row Model'); - return false; - } - if (this.gridOptionsWrapper.isRowModelInfinite()) { - console.warn('headerCheckboxSelection is not supported for Infinite Row Model'); - return false; - } - if (this.gridOptionsWrapper.isRowModelViewport()) { - console.warn('headerCheckboxSelection is not supported for Viewport Row Model'); - return false; - } - // otherwise the row model is compatible, so return true - return true; - } - return false; - }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridApi') - ], SelectAllFeature.prototype, "gridApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnApi') - ], SelectAllFeature.prototype, "columnApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('rowModel') - ], SelectAllFeature.prototype, "rowModel", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('selectionController') - ], SelectAllFeature.prototype, "selectionController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper') - ], SelectAllFeature.prototype, "gridOptionsWrapper", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] - ], SelectAllFeature.prototype, "postConstruct", null); - return SelectAllFeature; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); - - - -/***/ }), -/* 116 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AbstractHeaderWrapper", function() { return AbstractHeaderWrapper; }); -/* harmony import */ var _widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(117); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); - -var AbstractHeaderWrapper = /** @class */ (function (_super) { - __extends(AbstractHeaderWrapper, _super); - function AbstractHeaderWrapper() { - return _super !== null && _super.apply(this, arguments) || this; - } - AbstractHeaderWrapper.prototype.getColumn = function () { - return this.column; - }; - AbstractHeaderWrapper.prototype.getPinned = function () { - return this.pinned; - }; - return AbstractHeaderWrapper; -}(_widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_0__["ManagedFocusComponent"])); - - - -/***/ }), -/* 117 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ManagedFocusComponent", function() { return ManagedFocusComponent; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - -/** - * This provides logic to override the default browser focus logic. - * - * When the component gets focus, it uses the grid logic to find out what should be focused, - * and then focuses that instead. - * - * This is how we ensure when user tabs into the relevant section, we focus the correct item. - * For example GridCore extends ManagedFocusComponent, and it ensures when it receives focus - * that focus goes to the first cell of the first header row. - */ -var ManagedFocusComponent = /** @class */ (function (_super) { - __extends(ManagedFocusComponent, _super); - function ManagedFocusComponent() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.skipTabGuardFocus = false; - return _this; - } - ManagedFocusComponent.prototype.postConstruct = function () { - var focusableElement = this.getFocusableElement(); - if (!focusableElement) { - return; - } - this.wireFocusManagement(); - }; - ManagedFocusComponent.prototype.wireFocusManagement = function () { - var _this = this; - var focusableElement = this.getFocusableElement(); - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(focusableElement, ManagedFocusComponent.FOCUS_MANAGED_CLASS); - if (this.isFocusableContainer()) { - this.topTabGuard = this.createTabGuard('top'); - this.bottomTabGuard = this.createTabGuard('bottom'); - this.addTabGuards(); - this.activateTabGuards(); - this.forEachTabGuard(function (tabGuards) { - _this.addManagedListener(tabGuards, 'focus', _this.onFocus.bind(_this)); - }); - } - if (this.onTabKeyDown || this.handleKeyDown) { - this.addKeyDownListeners(focusableElement); - } - this.addManagedListener(focusableElement, 'focusin', this.onFocusIn.bind(this)); - this.addManagedListener(focusableElement, 'focusout', this.onFocusOut.bind(this)); - }; - /* - * Override this method to return true if this component will contain multiple focus-managed - * elements within. When set to true, this component will add tabGuards that will be responsible - * for receiving focus from outside and focusing an internal element using the focusInnerElementMethod - */ - ManagedFocusComponent.prototype.isFocusableContainer = function () { - return false; - }; - /* - * Override this method if focusing the default element requires special logic. - */ - ManagedFocusComponent.prototype.focusInnerElement = function (fromBottom) { - var focusable = this.focusController.findFocusableElements(this.getFocusableElement(), '.ag-tab-guard, :not([tabindex="-1"])'); - if (!focusable.length) { - return; - } - focusable[fromBottom ? focusable.length - 1 : 0].focus(); - }; - ManagedFocusComponent.prototype.onFocusIn = function (e) { - if (!this.isFocusableContainer()) { - return; - } - this.deactivateTabGuards(); - }; - ManagedFocusComponent.prototype.onFocusOut = function (e) { - if (!this.isFocusableContainer()) { - return; - } - var focusEl = this.getFocusableElement(); - if (!focusEl.contains(e.relatedTarget)) { - this.activateTabGuards(); - } - }; - ManagedFocusComponent.prototype.forceFocusOutOfContainer = function () { - this.activateTabGuards(); - this.skipTabGuardFocus = true; - this.bottomTabGuard.focus(); - }; - ManagedFocusComponent.prototype.appendChild = function (newChild, container) { - if (!this.isFocusableContainer()) { - _super.prototype.appendChild.call(this, newChild, container); - } - else { - if (!_utils__WEBPACK_IMPORTED_MODULE_3__["_"].isNodeOrElement(newChild)) { - newChild = newChild.getGui(); - } - var bottomTabGuard = this.bottomTabGuard; - if (bottomTabGuard) { - bottomTabGuard.insertAdjacentElement('beforebegin', newChild); - } - else { - _super.prototype.appendChild.call(this, newChild, container); - } + var indexColumn; + if (this.columnOrGroup instanceof _entities_column__WEBPACK_IMPORTED_MODULE_0__["Column"]) { + indexColumn = this.columnOrGroup; } - }; - ManagedFocusComponent.prototype.createTabGuard = function (side) { - var tabGuard = document.createElement('div'); - tabGuard.classList.add('ag-tab-guard'); - tabGuard.classList.add("ag-tab-guard-" + side); - return tabGuard; - }; - ManagedFocusComponent.prototype.addTabGuards = function () { - var focusableEl = this.getFocusableElement(); - focusableEl.insertAdjacentElement('afterbegin', this.topTabGuard); - focusableEl.insertAdjacentElement('beforeend', this.bottomTabGuard); - }; - ManagedFocusComponent.prototype.forEachTabGuard = function (callback) { - [this.topTabGuard, this.bottomTabGuard].forEach(callback); - }; - ManagedFocusComponent.prototype.addKeyDownListeners = function (eGui) { - var _this = this; - this.addManagedListener(eGui, 'keydown', function (e) { - if (e.defaultPrevented) { + else { + var columnGroup = this.columnOrGroup; + var children = columnGroup.getLeafColumns(); + if (!children.length) { return; } - if (e.keyCode === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_TAB && _this.onTabKeyDown) { - _this.onTabKeyDown(e); + if (children.length > 1) { + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_4__["setAriaColSpan"])(this.ariaEl, children.length); } - else if (_this.handleKeyDown) { - _this.handleKeyDown(e); - } - }); - }; - ManagedFocusComponent.prototype.onFocus = function (e) { - if (!this.isFocusableContainer()) { - return; - } - if (this.skipTabGuardFocus) { - this.skipTabGuardFocus = false; - return; + indexColumn = children[0]; } - this.focusInnerElement(e.target === this.bottomTabGuard); - }; - ManagedFocusComponent.prototype.activateTabGuards = function () { - this.forEachTabGuard(function (tabGuard) { return tabGuard.setAttribute('tabIndex', '0'); }); - }; - ManagedFocusComponent.prototype.deactivateTabGuards = function () { - this.forEachTabGuard(function (tabGuards) { return tabGuards.removeAttribute('tabindex'); }); + var index = this.beans.columnModel.getAriaColumnIndex(indexColumn); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_4__["setAriaColIndex"])(this.ariaEl, index); }; - ManagedFocusComponent.FOCUS_MANAGED_CLASS = 'ag-focus-managed'; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusController') - ], ManagedFocusComponent.prototype, "focusController", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], ManagedFocusComponent.prototype, "postConstruct", null); - return ManagedFocusComponent; -}(_component__WEBPACK_IMPORTED_MODULE_1__["Component"])); + _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"] + ], SetLeftFeature.prototype, "postConstruct", null); + return SetLeftFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 118 */ +/* 153 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderGroupWrapperComp", function() { return HeaderGroupWrapperComp; }); -/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(35); -/* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(34); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37); -/* harmony import */ var _cssClassApplier__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(112); -/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(104); -/* harmony import */ var _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(114); -/* harmony import */ var _hoverFeature__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(113); -/* harmony import */ var _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(107); -/* harmony import */ var _header_abstractHeaderWrapper__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(116); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HoverFeature", function() { return HoverFeature; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -27142,389 +34282,64 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta }; - - - - - - - - - -var HeaderGroupWrapperComp = /** @class */ (function (_super) { - __extends(HeaderGroupWrapperComp, _super); - function HeaderGroupWrapperComp(columnGroup, dragSourceDropTarget, pinned) { - var _this = _super.call(this, HeaderGroupWrapperComp.TEMPLATE) || this; - // the children can change, we keep destroy functions related to listening to the children here - _this.removeChildListenersFuncs = []; - _this.column = columnGroup; - _this.dragSourceDropTarget = dragSourceDropTarget; - _this.pinned = pinned; +var HoverFeature = /** @class */ (function (_super) { + __extends(HoverFeature, _super); + function HoverFeature(columns, element) { + var _this = _super.call(this) || this; + _this.columns = columns; + _this.element = element; return _this; } - HeaderGroupWrapperComp.prototype.postConstruct = function () { - _super.prototype.postConstruct.call(this); - _cssClassApplier__WEBPACK_IMPORTED_MODULE_4__["CssClassApplier"].addHeaderClassesFromColDef(this.getComponentHolder(), this.getGui(), this.gridOptionsWrapper, null, this.column); - var displayName = this.columnController.getDisplayNameForColumnGroup(this.column, 'header'); - this.appendHeaderGroupComp(displayName); - this.setupResize(); - this.addClasses(); - this.setupWidth(); - this.addAttributes(); - this.setupMovingCss(); - this.setupTooltip(); - this.createManagedBean(new _hoverFeature__WEBPACK_IMPORTED_MODULE_7__["HoverFeature"](this.column.getOriginalColumnGroup().getLeafColumns(), this.getGui())); - this.createManagedBean(new _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_6__["SetLeftFeature"](this.column, this.getGui(), this.beans)); - }; - HeaderGroupWrapperComp.prototype.onFocusIn = function (e) { - if (!this.getGui().contains(e.relatedTarget)) { - var headerRow = this.getParentComponent(); - this.beans.focusController.setFocusedHeader(headerRow.getRowIndex(), this.getColumn()); - } - }; - HeaderGroupWrapperComp.prototype.handleKeyDown = function (e) { - var activeEl = document.activeElement; - var eGui = this.getGui(); - var wrapperHasFocus = activeEl === eGui; - switch (e.keyCode) { - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_ENTER: - if (wrapperHasFocus) { - var column = this.getColumn(); - var expandable = column.isExpandable(); - if (expandable) { - var newExpandedValue = !column.isExpanded(); - this.columnController.setColumnGroupOpened(column.getOriginalColumnGroup(), newExpandedValue, "uiColumnExpanded"); - } - } - } - }; - HeaderGroupWrapperComp.prototype.setupMovingCss = function () { - var _this = this; - var originalColumnGroup = this.column.getOriginalColumnGroup(); - var leafColumns = originalColumnGroup.getLeafColumns(); - leafColumns.forEach(function (col) { - _this.addManagedListener(col, _entities_column__WEBPACK_IMPORTED_MODULE_0__["Column"].EVENT_MOVING_CHANGED, _this.onColumnMovingChanged.bind(_this)); - }); - this.onColumnMovingChanged(); - }; - HeaderGroupWrapperComp.prototype.getComponentHolder = function () { - return this.column.getColGroupDef(); - }; - HeaderGroupWrapperComp.prototype.getTooltipText = function () { - var colGroupDef = this.getComponentHolder(); - return colGroupDef && colGroupDef.headerTooltip; - }; - HeaderGroupWrapperComp.prototype.setupTooltip = function () { - var tooltipText = this.getTooltipText(); - if (tooltipText == null) { - return; - } - if (this.gridOptionsWrapper.isEnableBrowserTooltips()) { - this.getGui().setAttribute('title', tooltipText); - } - else { - this.createManagedBean(new _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_8__["TooltipFeature"](this, 'headerGroup')); - } - }; - HeaderGroupWrapperComp.prototype.onColumnMovingChanged = function () { - // this function adds or removes the moving css, based on if the col is moving. - // this is what makes the header go dark when it is been moved (gives impression to - // user that the column was picked up). - _utils__WEBPACK_IMPORTED_MODULE_10__["_"].addOrRemoveCssClass(this.getGui(), 'ag-header-cell-moving', this.column.isMoving()); - }; - HeaderGroupWrapperComp.prototype.addAttributes = function () { - this.getGui().setAttribute("col-id", this.column.getUniqueId()); - }; - HeaderGroupWrapperComp.prototype.appendHeaderGroupComp = function (displayName) { - var _this = this; - var params = { - displayName: displayName, - columnGroup: this.column, - setExpanded: function (expanded) { - _this.columnController.setColumnGroupOpened(_this.column.getOriginalColumnGroup(), expanded, "gridInitializing"); - }, - api: this.gridApi, - columnApi: this.columnApi, - context: this.gridOptionsWrapper.getContext() - }; - if (!displayName) { - var columnGroup = this.column; - var leafCols = columnGroup.getLeafColumns(); - // find the top most column group that represents the same columns. so if we are dragging a group, we also - // want to visually show the parent groups dragging for the same column set. for example imaging 5 levels - // of grouping, with each group only containing the next group, and the last group containing three columns, - // then when you move any group (even the lowest level group) you are in-fact moving all the groups, as all - // the groups represent the same column set. - while (columnGroup.getParent() && columnGroup.getParent().getLeafColumns().length === leafCols.length) { - columnGroup = columnGroup.getParent(); - } - var colGroupDef = columnGroup.getColGroupDef(); - if (colGroupDef) { - displayName = colGroupDef.headerName; - } - if (!displayName) { - displayName = leafCols ? this.columnController.getDisplayNameForColumn(leafCols[0], 'header', true) : ''; - } - } - var callback = this.afterHeaderCompCreated.bind(this, displayName); - this.userComponentFactory.newHeaderGroupComponent(params).then(callback); - }; - HeaderGroupWrapperComp.prototype.afterHeaderCompCreated = function (displayName, headerGroupComp) { - var _this = this; - this.getGui().appendChild(headerGroupComp.getGui()); - this.addDestroyFunc(function () { - _this.getContext().destroyBean(headerGroupComp); - }); - this.setupMove(headerGroupComp.getGui(), displayName); - }; - HeaderGroupWrapperComp.prototype.addClasses = function () { - // having different classes below allows the style to not have a bottom border - // on the group header, if no group is specified - // columnGroup.getColGroupDef - var style = this.column.isPadding() ? 'no' : 'with'; - this.addCssClass("ag-header-group-cell-" + style + "-group"); - }; - HeaderGroupWrapperComp.prototype.setupMove = function (eHeaderGroup, displayName) { - var _this = this; - if (!eHeaderGroup) { - return; - } - if (this.isSuppressMoving()) { - return; - } - var allLeafColumns = this.column.getOriginalColumnGroup().getLeafColumns(); - var dragSource = { - type: _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_5__["DragSourceType"].HeaderCell, - eElement: eHeaderGroup, - defaultIconName: _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_5__["DragAndDropService"].ICON_HIDE, - dragItemName: displayName, - // we add in the original group leaf columns, so we move both visible and non-visible items - getDragItem: this.getDragItemForGroup.bind(this), - dragSourceDropTarget: this.dragSourceDropTarget, - onDragStarted: function () { return allLeafColumns.forEach(function (col) { return col.setMoving(true, "uiColumnDragged"); }); }, - onDragStopped: function () { return allLeafColumns.forEach(function (col) { return col.setMoving(false, "uiColumnDragged"); }); } - }; - this.dragAndDropService.addDragSource(dragSource, true); - this.addDestroyFunc(function () { return _this.dragAndDropService.removeDragSource(dragSource); }); - }; - // when moving the columns, we want to move all the columns (contained within the DragItem) in this group in one go, - // and in the order they are currently in the screen. - HeaderGroupWrapperComp.prototype.getDragItemForGroup = function () { - var allColumnsOriginalOrder = this.column.getOriginalColumnGroup().getLeafColumns(); - // capture visible state, used when re-entering grid to dictate which columns should be visible - var visibleState = {}; - allColumnsOriginalOrder.forEach(function (column) { return visibleState[column.getId()] = column.isVisible(); }); - var allColumnsCurrentOrder = []; - this.columnController.getAllDisplayedColumns().forEach(function (column) { - if (allColumnsOriginalOrder.indexOf(column) >= 0) { - allColumnsCurrentOrder.push(column); - _utils__WEBPACK_IMPORTED_MODULE_10__["_"].removeFromArray(allColumnsOriginalOrder, column); - } - }); - // we are left with non-visible columns, stick these in at the end - allColumnsOriginalOrder.forEach(function (column) { return allColumnsCurrentOrder.push(column); }); - // create and return dragItem - return { - columns: allColumnsCurrentOrder, - visibleState: visibleState - }; - }; - HeaderGroupWrapperComp.prototype.isSuppressMoving = function () { - // if any child is fixed, then don't allow moving - var childSuppressesMoving = false; - this.column.getLeafColumns().forEach(function (column) { - if (column.getColDef().suppressMovable || column.getColDef().lockPosition) { - childSuppressesMoving = true; - } - }); - var result = childSuppressesMoving || this.gridOptionsWrapper.isSuppressMovableColumns(); - return result; - }; - HeaderGroupWrapperComp.prototype.setupWidth = function () { - // we need to listen to changes in child columns, as they impact our width - this.addListenersToChildrenColumns(); - // the children belonging to this group can change, so we need to add and remove listeners as they change - this.addManagedListener(this.column, _entities_columnGroup__WEBPACK_IMPORTED_MODULE_1__["ColumnGroup"].EVENT_DISPLAYED_CHILDREN_CHANGED, this.onDisplayedChildrenChanged.bind(this)); - this.onWidthChanged(); - // the child listeners are not tied to this components life-cycle, as children can get added and removed - // to the group - hence they are on a different life-cycle. so we must make sure the existing children - // listeners are removed when we finally get destroyed - this.addDestroyFunc(this.removeListenersOnChildrenColumns.bind(this)); - }; - HeaderGroupWrapperComp.prototype.onDisplayedChildrenChanged = function () { - this.addListenersToChildrenColumns(); - this.onWidthChanged(); - }; - HeaderGroupWrapperComp.prototype.addListenersToChildrenColumns = function () { - var _this = this; - // first destroy any old listeners - this.removeListenersOnChildrenColumns(); - // now add new listeners to the new set of children - var widthChangedListener = this.onWidthChanged.bind(this); - this.column.getLeafColumns().forEach(function (column) { - column.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_0__["Column"].EVENT_WIDTH_CHANGED, widthChangedListener); - column.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_0__["Column"].EVENT_VISIBLE_CHANGED, widthChangedListener); - _this.removeChildListenersFuncs.push(function () { - column.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_0__["Column"].EVENT_WIDTH_CHANGED, widthChangedListener); - column.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_0__["Column"].EVENT_VISIBLE_CHANGED, widthChangedListener); - }); - }); - }; - HeaderGroupWrapperComp.prototype.removeListenersOnChildrenColumns = function () { - this.removeChildListenersFuncs.forEach(function (func) { return func(); }); - this.removeChildListenersFuncs = []; - }; - HeaderGroupWrapperComp.prototype.onWidthChanged = function () { - this.getGui().style.width = this.column.getActualWidth() + 'px'; - }; - HeaderGroupWrapperComp.prototype.setupResize = function () { - var _this = this; - this.eHeaderCellResize = this.getRefElement('agResize'); - if (!this.column.isResizable()) { - _utils__WEBPACK_IMPORTED_MODULE_10__["_"].removeFromParent(this.eHeaderCellResize); - return; - } - var finishedWithResizeFunc = this.horizontalResizeService.addResizeBar({ - eResizeBar: this.eHeaderCellResize, - onResizeStart: this.onResizeStart.bind(this), - onResizing: this.onResizing.bind(this, false), - onResizeEnd: this.onResizing.bind(this, true) - }); - this.addDestroyFunc(finishedWithResizeFunc); - if (!this.gridOptionsWrapper.isSuppressAutoSize()) { - var skipHeaderOnAutoSize_1 = this.gridOptionsWrapper.isSkipHeaderOnAutoSize(); - this.eHeaderCellResize.addEventListener('dblclick', function (event) { - // get list of all the column keys we are responsible for - var keys = []; - _this.column.getDisplayedLeafColumns().forEach(function (column) { - // not all cols in the group may be participating with auto-resize - if (!column.getColDef().suppressAutoSize) { - keys.push(column.getColId()); - } - }); - if (keys.length > 0) { - _this.columnController.autoSizeColumns(keys, skipHeaderOnAutoSize_1, "uiColumnResized"); - } - }); + HoverFeature.prototype.postConstruct = function () { + if (this.gridOptionsWrapper.isColumnHoverHighlight()) { + this.addMouseHoverListeners(); } }; - HeaderGroupWrapperComp.prototype.onResizeStart = function (shiftKey) { - var _this = this; - var leafCols = this.column.getDisplayedLeafColumns(); - this.resizeCols = leafCols.filter(function (col) { return col.isResizable(); }); - this.resizeStartWidth = 0; - this.resizeCols.forEach(function (col) { return _this.resizeStartWidth += col.getActualWidth(); }); - this.resizeRatios = []; - this.resizeCols.forEach(function (col) { return _this.resizeRatios.push(col.getActualWidth() / _this.resizeStartWidth); }); - var takeFromGroup = null; - if (shiftKey) { - takeFromGroup = this.columnController.getDisplayedGroupAfter(this.column); - } - if (takeFromGroup) { - var takeFromLeafCols = takeFromGroup.getDisplayedLeafColumns(); - this.resizeTakeFromCols = takeFromLeafCols.filter(function (col) { return col.isResizable(); }); - this.resizeTakeFromStartWidth = 0; - this.resizeTakeFromCols.forEach(function (col) { return _this.resizeTakeFromStartWidth += col.getActualWidth(); }); - this.resizeTakeFromRatios = []; - this.resizeTakeFromCols.forEach(function (col) { return _this.resizeTakeFromRatios.push(col.getActualWidth() / _this.resizeTakeFromStartWidth); }); - } - else { - this.resizeTakeFromCols = null; - this.resizeTakeFromStartWidth = null; - this.resizeTakeFromRatios = null; - } - _utils__WEBPACK_IMPORTED_MODULE_10__["_"].addCssClass(this.getGui(), 'ag-column-resizing'); + HoverFeature.prototype.addMouseHoverListeners = function () { + this.addManagedListener(this.element, 'mouseout', this.onMouseOut.bind(this)); + this.addManagedListener(this.element, 'mouseover', this.onMouseOver.bind(this)); }; - HeaderGroupWrapperComp.prototype.onResizing = function (finished, resizeAmount) { - var resizeSets = []; - var resizeAmountNormalised = this.normaliseDragChange(resizeAmount); - resizeSets.push({ - columns: this.resizeCols, - ratios: this.resizeRatios, - width: this.resizeStartWidth + resizeAmountNormalised - }); - if (this.resizeTakeFromCols) { - resizeSets.push({ - columns: this.resizeTakeFromCols, - ratios: this.resizeTakeFromRatios, - width: this.resizeTakeFromStartWidth - resizeAmountNormalised - }); - } - this.columnController.resizeColumnSets(resizeSets, finished, 'uiColumnDragged'); - if (finished) { - _utils__WEBPACK_IMPORTED_MODULE_10__["_"].removeCssClass(this.getGui(), 'ag-column-resizing'); - } + HoverFeature.prototype.onMouseOut = function () { + this.columnHoverService.clearMouseOver(); }; - // optionally inverts the drag, depending on pinned and RTL - // note - this method is duplicated in RenderedHeaderCell - should refactor out? - HeaderGroupWrapperComp.prototype.normaliseDragChange = function (dragChange) { - var result = dragChange; - if (this.gridOptionsWrapper.isEnableRtl()) { - // for RTL, dragging left makes the col bigger, except when pinning left - if (this.pinned !== _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_LEFT) { - result *= -1; - } - } - else if (this.pinned === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_RIGHT) { - // for LTR (ie normal), dragging left makes the col smaller, except when pinning right - result *= -1; - } - return result; + HoverFeature.prototype.onMouseOver = function () { + this.columnHoverService.setMouseOver(this.columns); }; - HeaderGroupWrapperComp.TEMPLATE = "
\n
\n
"; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('gridOptionsWrapper') - ], HeaderGroupWrapperComp.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('columnController') - ], HeaderGroupWrapperComp.prototype, "columnController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('horizontalResizeService') - ], HeaderGroupWrapperComp.prototype, "horizontalResizeService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('dragAndDropService') - ], HeaderGroupWrapperComp.prototype, "dragAndDropService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('userComponentFactory') - ], HeaderGroupWrapperComp.prototype, "userComponentFactory", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('beans') - ], HeaderGroupWrapperComp.prototype, "beans", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('gridApi') - ], HeaderGroupWrapperComp.prototype, "gridApi", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnHoverService') + ], HoverFeature.prototype, "columnHoverService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('columnApi') - ], HeaderGroupWrapperComp.prototype, "columnApi", void 0); - return HeaderGroupWrapperComp; -}(_header_abstractHeaderWrapper__WEBPACK_IMPORTED_MODULE_9__["AbstractHeaderWrapper"])); + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], HoverFeature.prototype, "postConstruct", null); + return HoverFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 119 */ +/* 154 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FloatingFilterWrapper", function() { return FloatingFilterWrapper; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(35); -/* harmony import */ var _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(114); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(57); -/* harmony import */ var _headerRendering_hoverFeature__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(113); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(43); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7); -/* harmony import */ var _provided_readOnlyFloatingFilter__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(120); -/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(38); -/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(39); -/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(12); -/* harmony import */ var _utils_icon__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(23); -/* harmony import */ var _headerRendering_header_abstractHeaderWrapper__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(116); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(25); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderCellCtrl", function() { return HeaderCellCtrl; }); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(65); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(97); +/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(10); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(24); +/* harmony import */ var _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(152); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(44); +/* harmony import */ var _widgets_managedFocusFeature__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(64); +/* harmony import */ var _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(119); +/* harmony import */ var _abstractCell_abstractHeaderCellCtrl__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(148); +/* harmony import */ var _cssClassApplier__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(155); +/* harmony import */ var _hoverFeature__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(153); +/* harmony import */ var _resizeFeature__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(156); +/* harmony import */ var _selectAllFeature__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(157); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -27561,378 +34376,478 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var FloatingFilterWrapper = /** @class */ (function (_super) { - __extends(FloatingFilterWrapper, _super); - function FloatingFilterWrapper(column, pinned) { - var _this = _super.call(this, FloatingFilterWrapper.TEMPLATE) || this; +var HeaderCellCtrl = /** @class */ (function (_super) { + __extends(HeaderCellCtrl, _super); + function HeaderCellCtrl(column, parentRowCtrl) { + var _this = _super.call(this, column, parentRowCtrl) || this; + _this.refreshFunctions = []; + _this.userHeaderClasses = new Set(); _this.column = column; - _this.pinned = pinned; return _this; } - FloatingFilterWrapper.prototype.postConstruct = function () { - _super.prototype.postConstruct.call(this); - this.setupFloatingFilter(); + HeaderCellCtrl.prototype.setComp = function (comp, eGui, eResize) { + var _this = this; + _super.prototype.setGui.call(this, eGui); + this.comp = comp; + this.colDefVersion = this.columnModel.getColDefVersion(); + this.updateState(); this.setupWidth(); - this.setupLeftPositioning(); - this.setupColumnHover(); - this.createManagedBean(new _headerRendering_hoverFeature__WEBPACK_IMPORTED_MODULE_4__["HoverFeature"]([this.column], this.getGui())); - this.addManagedListener(this.eButtonShowMainFilter, 'click', this.showParentFilter.bind(this)); + this.setupMovingCss(); + this.setupMenuClass(); + this.setupSortableClass(); + this.addColumnHoverListener(); + this.setupFilterCss(); + this.setupColId(); + this.setupClassesFromColDef(); + this.setupTooltip(); + this.addActiveHeaderMouseListeners(); + this.setupSelectAll(); + this.setupUserComp(); + this.createManagedBean(new _resizeFeature__WEBPACK_IMPORTED_MODULE_12__["ResizeFeature"](this.getPinned(), this.column, eResize, comp, this)); + this.createManagedBean(new _hoverFeature__WEBPACK_IMPORTED_MODULE_11__["HoverFeature"]([this.column], eGui)); + this.createManagedBean(new _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_5__["SetLeftFeature"](this.column, eGui, this.beans)); + this.createManagedBean(new _widgets_managedFocusFeature__WEBPACK_IMPORTED_MODULE_7__["ManagedFocusFeature"](eGui, { + shouldStopEventPropagation: function (e) { return _this.shouldStopEventPropagation(e); }, + onTabKeyDown: function () { return null; }, + handleKeyDown: this.handleKeyDown.bind(this), + onFocusIn: this.onFocusIn.bind(this), + onFocusOut: this.onFocusOut.bind(this) + })); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_NEW_COLUMNS_LOADED, this.onNewColumnsLoaded.bind(this)); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_COLUMN_VALUE_CHANGED, this.onColumnValueChanged.bind(this)); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, this.onColumnRowGroupChanged.bind(this)); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_COLUMN_PIVOT_CHANGED, this.onColumnPivotChanged.bind(this)); }; - FloatingFilterWrapper.prototype.onTabKeyDown = function (e) { - var activeEl = document.activeElement; - var eGui = this.getGui(); - var wrapperHasFocus = activeEl === eGui; - if (wrapperHasFocus) { + HeaderCellCtrl.prototype.setupUserComp = function () { + var compDetails = this.lookupUserCompDetails(); + this.setCompDetails(compDetails); + }; + HeaderCellCtrl.prototype.setCompDetails = function (compDetails) { + this.userCompDetails = compDetails; + this.comp.setUserCompDetails(compDetails); + }; + HeaderCellCtrl.prototype.lookupUserCompDetails = function () { + var params = this.createParams(); + var colDef = this.column.getColDef(); + return this.userComponentFactory.getHeaderCompDetails(colDef, params); + }; + HeaderCellCtrl.prototype.createParams = function () { + var _this = this; + var colDef = this.column.getColDef(); + var params = { + column: this.column, + displayName: this.displayName, + enableSorting: colDef.sortable, + enableMenu: this.menuEnabled, + showColumnMenu: function (source) { + _this.gridApi.showColumnMenuAfterButtonClick(_this.column, source); + }, + progressSort: function (multiSort) { + _this.sortController.progressSort(_this.column, !!multiSort, "uiColumnSorted"); + }, + setSort: function (sort, multiSort) { + _this.sortController.setSortForColumn(_this.column, sort, !!multiSort, "uiColumnSorted"); + }, + api: this.gridApi, + columnApi: this.columnApi, + context: this.gridOptionsWrapper.getContext(), + eGridHeader: this.getGui() + }; + return params; + }; + HeaderCellCtrl.prototype.setupSelectAll = function () { + this.selectAllFeature = this.createManagedBean(new _selectAllFeature__WEBPACK_IMPORTED_MODULE_13__["SelectAllFeature"](this.column)); + this.selectAllFeature.setComp(this.comp); + }; + HeaderCellCtrl.prototype.getSelectAllGui = function () { + return this.selectAllFeature.getCheckboxGui(); + }; + HeaderCellCtrl.prototype.handleKeyDown = function (e) { + if (e.key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_0__["KeyCode"].SPACE) { + this.selectAllFeature.onSpaceKeyPressed(e); + } + if (e.key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_0__["KeyCode"].ENTER) { + this.onEnterKeyPressed(e); + } + }; + HeaderCellCtrl.prototype.onEnterKeyPressed = function (e) { + /// THIS IS BAD - we are assuming the header is not a user provided comp + var headerComp = this.comp.getUserCompInstance(); + if (!headerComp) { return; } - e.preventDefault(); - var nextFocusableEl = this.focusController.findNextFocusableElement(eGui, null, e.shiftKey); - if (nextFocusableEl) { - nextFocusableEl.focus(); + if (e.ctrlKey || e.metaKey) { + if (this.menuEnabled && headerComp.showMenu) { + e.preventDefault(); + headerComp.showMenu(); + } } - else { - eGui.focus(); + else if (this.sortable) { + var multiSort = e.shiftKey; + this.sortController.progressSort(this.column, multiSort, "uiColumnSorted"); } }; - FloatingFilterWrapper.prototype.handleKeyDown = function (e) { - var activeEl = document.activeElement; - var eGui = this.getGui(); - var wrapperHasFocus = activeEl === eGui; - switch (e.keyCode) { - case _constants__WEBPACK_IMPORTED_MODULE_13__["Constants"].KEY_UP: - case _constants__WEBPACK_IMPORTED_MODULE_13__["Constants"].KEY_DOWN: - if (!wrapperHasFocus) { - e.preventDefault(); - } - case _constants__WEBPACK_IMPORTED_MODULE_13__["Constants"].KEY_LEFT: - case _constants__WEBPACK_IMPORTED_MODULE_13__["Constants"].KEY_RIGHT: - if (wrapperHasFocus) { - return; - } - e.stopPropagation(); - case _constants__WEBPACK_IMPORTED_MODULE_13__["Constants"].KEY_ENTER: - if (wrapperHasFocus) { - if (this.focusController.focusFirstFocusableElement(eGui)) { - e.preventDefault(); - } + HeaderCellCtrl.prototype.isMenuEnabled = function () { + return this.menuEnabled; + }; + HeaderCellCtrl.prototype.onFocusIn = function (e) { + if (!this.getGui().contains(e.relatedTarget)) { + var rowIndex = this.getRowIndex(); + this.focusService.setFocusedHeader(rowIndex, this.column); + } + this.setActiveHeader(true); + }; + HeaderCellCtrl.prototype.onFocusOut = function (e) { + if (this.getGui().contains(e.relatedTarget)) { + return; + } + this.setActiveHeader(false); + }; + HeaderCellCtrl.prototype.setupTooltip = function () { + var _this = this; + var tooltipCtrl = { + getColumn: function () { return _this.column; }, + getColDef: function () { return _this.column.getColDef(); }, + getGui: function () { return _this.eGui; }, + getLocation: function () { return 'header'; }, + getTooltipValue: function () { + var res = _this.column.getColDef().headerTooltip; + return res; + }, + }; + var tooltipFeature = this.createManagedBean(new _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_8__["TooltipFeature"](tooltipCtrl, this.beans)); + tooltipFeature.setComp(this.comp); + this.refreshFunctions.push(function () { return tooltipFeature.refreshToolTip(); }); + }; + HeaderCellCtrl.prototype.setupClassesFromColDef = function () { + var _this = this; + var refreshHeaderClasses = function () { + var colDef = _this.column.getColDef(); + var goa = _this.gridOptionsWrapper; + var classes = _cssClassApplier__WEBPACK_IMPORTED_MODULE_10__["CssClassApplier"].getHeaderClassesFromColDef(colDef, goa, _this.column, null); + var oldClasses = _this.userHeaderClasses; + _this.userHeaderClasses = new Set(classes); + classes.forEach(function (c) { + if (oldClasses.has(c)) { + // class already added, no need to apply it, but remove from old set + oldClasses.delete(c); } - break; - case _constants__WEBPACK_IMPORTED_MODULE_13__["Constants"].KEY_ESCAPE: - if (!wrapperHasFocus) { - this.getGui().focus(); + else { + // class new since last time, so apply it + _this.comp.addOrRemoveCssClass(c, true); } + }); + // now old set only has classes that were applied last time, but not this time, so remove them + oldClasses.forEach(function (c) { return _this.comp.addOrRemoveCssClass(c, false); }); + }; + this.refreshFunctions.push(refreshHeaderClasses); + refreshHeaderClasses(); + }; + HeaderCellCtrl.prototype.setDragSource = function (eSource) { + var _this = this; + this.dragSourceElement = eSource; + this.removeDragSource(); + if (!eSource) { + return; + } + if (!this.draggable) { + return; } + this.moveDragSource = { + type: _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragSourceType"].HeaderCell, + eElement: eSource, + defaultIconName: _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_HIDE, + getDragItem: function () { return _this.createDragItem(); }, + dragItemName: this.displayName, + onDragStarted: function () { return _this.column.setMoving(true, "uiColumnMoved"); }, + onDragStopped: function () { return _this.column.setMoving(false, "uiColumnMoved"); } + }; + this.dragAndDropService.addDragSource(this.moveDragSource, true); }; - FloatingFilterWrapper.prototype.onFocusIn = function (e) { - var eGui = this.getGui(); - if (!eGui.contains(e.relatedTarget)) { - var headerRow = this.getParentComponent(); - this.beans.focusController.setFocusedHeader(headerRow.getRowIndex(), this.getColumn()); + HeaderCellCtrl.prototype.createDragItem = function () { + var visibleState = {}; + visibleState[this.column.getId()] = this.column.isVisible(); + return { + columns: [this.column], + visibleState: visibleState + }; + }; + HeaderCellCtrl.prototype.removeDragSource = function () { + if (this.moveDragSource) { + this.dragAndDropService.removeDragSource(this.moveDragSource); + this.moveDragSource = undefined; } }; - FloatingFilterWrapper.prototype.setupFloatingFilter = function () { - var _this = this; + HeaderCellCtrl.prototype.onNewColumnsLoaded = function () { + var colDefVersionNow = this.columnModel.getColDefVersion(); + if (colDefVersionNow != this.colDefVersion) { + this.colDefVersion = colDefVersionNow; + this.refresh(); + } + }; + HeaderCellCtrl.prototype.updateState = function () { var colDef = this.column.getColDef(); - if (colDef.filter && colDef.floatingFilter) { - this.floatingFilterCompPromise = this.getFloatingFilterInstance(); - if (this.floatingFilterCompPromise) { - this.floatingFilterCompPromise.then(function (compInstance) { - if (compInstance) { - _this.setupWithFloatingFilter(compInstance); - _this.setupSyncWithFilter(); - } - else { - _this.setupEmpty(); - } - }); - } - else { - this.setupEmpty(); - } + this.menuEnabled = this.menuFactory.isMenuEnabled(this.column) && !colDef.suppressMenu; + this.sortable = colDef.sortable; + this.displayName = this.calculateDisplayName(); + this.draggable = this.workOutDraggable(); + }; + HeaderCellCtrl.prototype.addRefreshFunction = function (func) { + this.refreshFunctions.push(func); + }; + HeaderCellCtrl.prototype.refresh = function () { + this.updateState(); + this.refreshHeaderComp(); + this.refreshFunctions.forEach(function (f) { return f(); }); + }; + HeaderCellCtrl.prototype.refreshHeaderComp = function () { + var newCompDetails = this.lookupUserCompDetails(); + var compInstance = this.comp.getUserCompInstance(); + // only try refresh if old comp exists adn it is the correct type + var attemptRefresh = compInstance != null && this.userCompDetails.componentClass == newCompDetails.componentClass; + var headerCompRefreshed = attemptRefresh ? this.attemptHeaderCompRefresh(newCompDetails.params) : false; + if (headerCompRefreshed) { + // we do this as a refresh happens after colDefs change, and it's possible the column has had it's + // draggable property toggled. no need to call this if not refreshing, as setDragSource is done + // as part of appendHeaderComp + this.setDragSource(this.dragSourceElement); } else { - this.setupEmpty(); + this.setCompDetails(newCompDetails); } }; - FloatingFilterWrapper.prototype.setupLeftPositioning = function () { - var setLeftFeature = new _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_2__["SetLeftFeature"](this.column, this.getGui(), this.beans); - this.createManagedBean(setLeftFeature); - }; - FloatingFilterWrapper.prototype.setupSyncWithFilter = function () { - var _this = this; - var syncWithFilter = function (filterChangedEvent) { - var parentModel = _this.getFilterComponent().resolveNow(null, function (filter) { return filter.getModel(); }); - _this.onParentModelChanged(parentModel, filterChangedEvent); - }; - this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_FILTER_CHANGED, syncWithFilter); - if (this.filterManager.isFilterActive(this.column)) { - syncWithFilter(null); + HeaderCellCtrl.prototype.attemptHeaderCompRefresh = function (params) { + var headerComp = this.comp.getUserCompInstance(); + if (!headerComp) { + return false; } + // if no refresh method, then we want to replace the headerComp + if (!headerComp.refresh) { + return false; + } + var res = headerComp.refresh(params); + return res; }; - // linked to event listener in template - FloatingFilterWrapper.prototype.showParentFilter = function () { - this.menuFactory.showMenuAfterButtonClick(this.column, this.eButtonShowMainFilter, 'filterMenuTab', ['filterMenuTab']); + HeaderCellCtrl.prototype.calculateDisplayName = function () { + return this.columnModel.getDisplayNameForColumn(this.column, 'header', true); }; - FloatingFilterWrapper.prototype.setupColumnHover = function () { - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_5__["Events"].EVENT_COLUMN_HOVER_CHANGED, this.onColumnHover.bind(this)); - this.onColumnHover(); + HeaderCellCtrl.prototype.checkDisplayName = function () { + // display name can change if aggFunc different, eg sum(Gold) is now max(Gold) + if (this.displayName !== this.calculateDisplayName()) { + this.refresh(); + } + }; + HeaderCellCtrl.prototype.workOutDraggable = function () { + var colDef = this.column.getColDef(); + var isSuppressMovableColumns = this.gridOptionsWrapper.isSuppressMovableColumns(); + var colCanMove = !isSuppressMovableColumns && !colDef.suppressMovable && !colDef.lockPosition; + // we should still be allowed drag the column, even if it can't be moved, if the column + // can be dragged to a rowGroup or pivot drop zone + return !!colCanMove || !!colDef.enableRowGroup || !!colDef.enablePivot; }; - FloatingFilterWrapper.prototype.onColumnHover = function () { - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_10__["addOrRemoveCssClass"])(this.getGui(), 'ag-column-hover', this.columnHoverService.isHovered(this.column)); + HeaderCellCtrl.prototype.onColumnRowGroupChanged = function () { + this.checkDisplayName(); }; - FloatingFilterWrapper.prototype.setupWidth = function () { - this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_WIDTH_CHANGED, this.onColumnWidthChanged.bind(this)); - this.onColumnWidthChanged(); + HeaderCellCtrl.prototype.onColumnPivotChanged = function () { + this.checkDisplayName(); }; - FloatingFilterWrapper.prototype.onColumnWidthChanged = function () { - this.getGui().style.width = this.column.getActualWidth() + "px"; + HeaderCellCtrl.prototype.onColumnValueChanged = function () { + this.checkDisplayName(); }; - FloatingFilterWrapper.prototype.setupWithFloatingFilter = function (floatingFilterComp) { + HeaderCellCtrl.prototype.setupWidth = function () { var _this = this; - var disposeFunc = function () { - _this.getContext().destroyBean(floatingFilterComp); + var listener = function () { + _this.comp.setWidth(_this.column.getActualWidth() + 'px'); }; - if (!this.isAlive()) { - disposeFunc(); - return; - } - this.addDestroyFunc(disposeFunc); - var floatingFilterCompUi = floatingFilterComp.getGui(); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_10__["addOrRemoveCssClass"])(this.eFloatingFilterBody, 'ag-floating-filter-body', !this.suppressFilterButton); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_10__["addOrRemoveCssClass"])(this.eFloatingFilterBody, 'ag-floating-filter-full-body', this.suppressFilterButton); - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_10__["setDisplayed"])(this.eButtonWrapper, !this.suppressFilterButton); - var eIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_11__["createIconNoSpan"])('filter', this.gridOptionsWrapper, this.column); - this.eButtonShowMainFilter.appendChild(eIcon); - this.eFloatingFilterBody.appendChild(floatingFilterCompUi); - if (floatingFilterComp.afterGuiAttached) { - floatingFilterComp.afterGuiAttached(); - } + this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_3__["Column"].EVENT_WIDTH_CHANGED, listener); + listener(); }; - FloatingFilterWrapper.prototype.parentFilterInstance = function (callback) { - this.getFilterComponent().then(callback); + HeaderCellCtrl.prototype.setupMovingCss = function () { + var _this = this; + var listener = function () { + // this is what makes the header go dark when it is been moved (gives impression to + // user that the column was picked up). + _this.comp.addOrRemoveCssClass('ag-header-cell-moving', _this.column.isMoving()); + }; + this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_3__["Column"].EVENT_MOVING_CHANGED, listener); + listener(); }; - FloatingFilterWrapper.prototype.getFilterComponent = function () { - return this.filterManager.getFilterComponent(this.column, 'NO_UI'); + HeaderCellCtrl.prototype.setupMenuClass = function () { + var _this = this; + var listener = function () { + _this.comp.addOrRemoveCssClass('ag-column-menu-visible', _this.column.isMenuVisible()); + }; + this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_3__["Column"].EVENT_MENU_VISIBLE_CHANGED, listener); + listener(); }; - FloatingFilterWrapper.prototype.getFloatingFilterInstance = function () { - var colDef = this.column.getColDef(); - var defaultFloatingFilterType; - if (typeof colDef.filter === 'string') { - // will be undefined if not in the map - defaultFloatingFilterType = FloatingFilterWrapper.filterToFloatingFilterNames[colDef.filter]; - } - else if (colDef.filterFramework) { - // If filterFramework, then grid is NOT using one of the provided filters, hence no default. - // Note: We could combine this with another part of the 'if' statement, however explicitly - // having this section makes the code easier to read. - } - else if (colDef.filter === true) { - var setFilterModuleLoaded = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_9__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__["ModuleNames"].SetFilterModule); - defaultFloatingFilterType = setFilterModuleLoaded ? 'agSetColumnFloatingFilter' : 'agTextColumnFloatingFilter'; - } - var filterParams = this.filterManager.createFilterParams(this.column, this.column.getColDef()); - var finalFilterParams = this.userComponentFactory.createFinalParams(colDef, 'filter', filterParams); - var params = { - api: this.gridApi, - column: this.column, - filterParams: finalFilterParams, - currentParentModel: this.currentParentModel.bind(this), - parentFilterInstance: this.parentFilterInstance.bind(this), - onFloatingFilterChanged: this.onFloatingFilterChanged.bind(this), - suppressFilterButton: false // This one might be overridden from the colDef + HeaderCellCtrl.prototype.setupSortableClass = function () { + var _this = this; + var updateSortableCssClass = function () { + _this.comp.addOrRemoveCssClass('ag-header-cell-sortable', !!_this.sortable); }; - // this is unusual - we need a params value OUTSIDE the component the params are for. - // the params are for the floating filter component, but this property is actually for the wrapper. - this.suppressFilterButton = colDef.floatingFilterComponentParams ? !!colDef.floatingFilterComponentParams.suppressFilterButton : false; - var promise = this.userComponentFactory.newFloatingFilterComponent(colDef, params, defaultFloatingFilterType); - if (!promise) { - var filterComponent = this.getFilterComponentPrototype(colDef); - var getModelAsStringExists = filterComponent && filterComponent.prototype && filterComponent.prototype.getModelAsString; - if (getModelAsStringExists) { - var compInstance = this.userComponentFactory.createUserComponentFromConcreteClass(_provided_readOnlyFloatingFilter__WEBPACK_IMPORTED_MODULE_7__["ReadOnlyFloatingFilter"], params); - promise = _utils__WEBPACK_IMPORTED_MODULE_6__["Promise"].resolve(compInstance); + var updateAriaSort = function () { + if (_this.sortable) { + _this.comp.setAriaSort(Object(_utils_aria__WEBPACK_IMPORTED_MODULE_6__["getAriaSortState"])(_this.column)); + } + else { + _this.comp.setAriaSort(undefined); } - } - return promise; - }; - FloatingFilterWrapper.prototype.createDynamicParams = function () { - return { - column: this.column, - colDef: this.column.getColDef(), - api: this.gridApi, - columnApi: this.columnApi }; + updateSortableCssClass(); + updateAriaSort(); + this.addRefreshFunction(updateSortableCssClass); + this.addRefreshFunction(updateAriaSort); + this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_3__["Column"].EVENT_SORT_CHANGED, updateAriaSort); }; - FloatingFilterWrapper.prototype.getFilterComponentPrototype = function (colDef) { - var resolvedComponent = this.userComponentFactory.lookupComponentClassDef(colDef, 'filter', this.createDynamicParams()); - return resolvedComponent ? resolvedComponent.component : null; - }; - FloatingFilterWrapper.prototype.setupEmpty = function () { - Object(_utils_dom__WEBPACK_IMPORTED_MODULE_10__["setDisplayed"])(this.eButtonWrapper, false); + HeaderCellCtrl.prototype.addColumnHoverListener = function () { + var _this = this; + var listener = function () { + if (!_this.gridOptionsWrapper.isColumnHoverHighlight()) { + return; + } + var isHovered = _this.columnHoverService.isHovered(_this.column); + _this.comp.addOrRemoveCssClass('ag-column-hover', isHovered); + }; + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_COLUMN_HOVER_CHANGED, listener); + listener(); }; - FloatingFilterWrapper.prototype.currentParentModel = function () { - return this.getFilterComponent().resolveNow(null, function (filter) { return filter.getModel(); }); + HeaderCellCtrl.prototype.setupFilterCss = function () { + var _this = this; + var listener = function () { + _this.comp.addOrRemoveCssClass('ag-header-cell-filtered', _this.column.isFilterActive()); + }; + this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_3__["Column"].EVENT_FILTER_ACTIVE_CHANGED, listener); + listener(); }; - FloatingFilterWrapper.prototype.onParentModelChanged = function (model, filterChangedEvent) { - if (!this.floatingFilterCompPromise) { - return; - } - this.floatingFilterCompPromise.then(function (comp) { return comp.onParentModelChanged(model, filterChangedEvent); }); + HeaderCellCtrl.prototype.setupColId = function () { + this.comp.setColId(this.column.getColId()); }; - FloatingFilterWrapper.prototype.onFloatingFilterChanged = function () { - console.warn('ag-Grid: since version 21.x, how floating filters are implemented has changed. ' + - 'Instead of calling params.onFloatingFilterChanged(), get a reference to the main filter via ' + - 'params.parentFilterInstance() and then set a value on the parent filter directly.'); + HeaderCellCtrl.prototype.addActiveHeaderMouseListeners = function () { + var _this = this; + var listener = function (e) { return _this.setActiveHeader(e.type === 'mouseenter'); }; + this.addManagedListener(this.getGui(), 'mouseenter', listener); + this.addManagedListener(this.getGui(), 'mouseleave', listener); }; - FloatingFilterWrapper.filterToFloatingFilterNames = { - set: 'agSetColumnFloatingFilter', - agSetColumnFilter: 'agSetColumnFloatingFilter', - number: 'agNumberColumnFloatingFilter', - agNumberColumnFilter: 'agNumberColumnFloatingFilter', - date: 'agDateColumnFloatingFilter', - agDateColumnFilter: 'agDateColumnFloatingFilter', - text: 'agTextColumnFloatingFilter', - agTextColumnFilter: 'agTextColumnFloatingFilter' + HeaderCellCtrl.prototype.setActiveHeader = function (active) { + this.comp.addOrRemoveCssClass('ag-header-active', active); }; - FloatingFilterWrapper.TEMPLATE = "
\n
\n
\n \n
\n
"; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnHoverService') - ], FloatingFilterWrapper.prototype, "columnHoverService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], FloatingFilterWrapper.prototype, "gridOptionsWrapper", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnModel') + ], HeaderCellCtrl.prototype, "columnModel", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('userComponentFactory') - ], FloatingFilterWrapper.prototype, "userComponentFactory", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnHoverService') + ], HeaderCellCtrl.prototype, "columnHoverService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') - ], FloatingFilterWrapper.prototype, "gridApi", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('beans') + ], HeaderCellCtrl.prototype, "beans", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') - ], FloatingFilterWrapper.prototype, "columnApi", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('sortController') + ], HeaderCellCtrl.prototype, "sortController", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager') - ], FloatingFilterWrapper.prototype, "filterManager", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('menuFactory') + ], HeaderCellCtrl.prototype, "menuFactory", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('menuFactory') - ], FloatingFilterWrapper.prototype, "menuFactory", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('dragAndDropService') + ], HeaderCellCtrl.prototype, "dragAndDropService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('beans') - ], FloatingFilterWrapper.prototype, "beans", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridApi') + ], HeaderCellCtrl.prototype, "gridApi", void 0); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eFloatingFilterBody') - ], FloatingFilterWrapper.prototype, "eFloatingFilterBody", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnApi') + ], HeaderCellCtrl.prototype, "columnApi", void 0); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eButtonWrapper') - ], FloatingFilterWrapper.prototype, "eButtonWrapper", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('userComponentFactory') + ], HeaderCellCtrl.prototype, "userComponentFactory", void 0); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eButtonShowMainFilter') - ], FloatingFilterWrapper.prototype, "eButtonShowMainFilter", void 0); - return FloatingFilterWrapper; -}(_headerRendering_header_abstractHeaderWrapper__WEBPACK_IMPORTED_MODULE_12__["AbstractHeaderWrapper"])); + _context_context__WEBPACK_IMPORTED_MODULE_1__["PreDestroy"] + ], HeaderCellCtrl.prototype, "removeDragSource", null); + return HeaderCellCtrl; +}(_abstractCell_abstractHeaderCellCtrl__WEBPACK_IMPORTED_MODULE_9__["AbstractHeaderCellCtrl"])); /***/ }), -/* 120 */ +/* 155 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ReadOnlyFloatingFilter", function() { return ReadOnlyFloatingFilter; }); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CssClassApplier", function() { return CssClassApplier; }); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - -// optional floating filter for user provided filters - instead of providing a floating filter, -// they can provide a getModelAsString() method on the filter instead. this class just displays -// the string returned from getModelAsString() -var ReadOnlyFloatingFilter = /** @class */ (function (_super) { - __extends(ReadOnlyFloatingFilter, _super); - function ReadOnlyFloatingFilter() { - return _super.call(this, /* html */ "\n
\n \n
") || this; +var CssClassApplier = /** @class */ (function () { + function CssClassApplier() { } - // this is a user component, and IComponent has "public destroy()" as part of the interface. - // so we need to override destroy() just to make the method public. - ReadOnlyFloatingFilter.prototype.destroy = function () { - _super.prototype.destroy.call(this); + CssClassApplier.getHeaderClassesFromColDef = function (abstractColDef, gridOptionsWrapper, column, columnGroup) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_0__["missing"])(abstractColDef)) { + return []; + } + return this.getColumnClassesFromCollDef(abstractColDef.headerClass, abstractColDef, gridOptionsWrapper, column, columnGroup); }; - ReadOnlyFloatingFilter.prototype.init = function (params) { - this.params = params; - var displayName = this.columnController.getDisplayNameForColumn(params.column, 'header', true); - this.eFloatingFilterText - .setDisabled(true) - .setInputAriaLabel(displayName + " Filter Input"); + CssClassApplier.getToolPanelClassesFromColDef = function (abstractColDef, gridOptionsWrapper, column, columnGroup) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_0__["missing"])(abstractColDef)) { + return []; + } + return this.getColumnClassesFromCollDef(abstractColDef.toolPanelClass, abstractColDef, gridOptionsWrapper, column, columnGroup); }; - ReadOnlyFloatingFilter.prototype.onParentModelChanged = function (parentModel) { - var _this = this; - if (!parentModel) { - this.eFloatingFilterText.setValue(''); - return; + CssClassApplier.getClassParams = function (abstractColDef, gridOptionsWrapper, column, columnGroup) { + return { + // bad naming, as colDef here can be a group or a column, + // however most people won't appreciate the difference, + // so keeping it as colDef to avoid confusion. + colDef: abstractColDef, + column: column, + columnGroup: columnGroup, + context: gridOptionsWrapper.getContext(), + api: gridOptionsWrapper.getApi() + }; + }; + CssClassApplier.getColumnClassesFromCollDef = function (classesOrFunc, abstractColDef, gridOptionsWrapper, column, columnGroup) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_0__["missing"])(classesOrFunc)) { + return []; } - this.params.parentFilterInstance(function (filterInstance) { - // getModelAsString should be present, as we check this - // in floatingFilterWrapper - if (filterInstance.getModelAsString) { - var modelAsString = filterInstance.getModelAsString(parentModel); - _this.eFloatingFilterText.setValue(modelAsString); - } - }); + var classToUse; + if (typeof classesOrFunc === 'function') { + var params = this.getClassParams(abstractColDef, gridOptionsWrapper, column, columnGroup); + classToUse = classesOrFunc(params); + } + else { + classToUse = classesOrFunc; + } + if (typeof classToUse === 'string') { + return [classToUse]; + } + if (Array.isArray(classToUse)) { + return classToUse; + } + return []; }; - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eFloatingFilterText') - ], ReadOnlyFloatingFilter.prototype, "eFloatingFilterText", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnController') - ], ReadOnlyFloatingFilter.prototype, "columnController", void 0); - return ReadOnlyFloatingFilter; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); + return CssClassApplier; +}()); /***/ }), -/* 121 */ +/* 156 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BodyDropTarget", function() { return BodyDropTarget; }); -/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(104); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _moveColumnController__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(122); -/* harmony import */ var _bodyDropPivotTarget__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(123); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(25); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(41); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ResizeFeature", function() { return ResizeFeature; }); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(15); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(42); +/* harmony import */ var _widgets_touchListener__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(82); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -27960,125 +34875,148 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta - -var DropType; -(function (DropType) { - DropType[DropType["ColumnMove"] = 0] = "ColumnMove"; - DropType[DropType["Pivot"] = 1] = "Pivot"; -})(DropType || (DropType = {})); -var BodyDropTarget = /** @class */ (function (_super) { - __extends(BodyDropTarget, _super); - function BodyDropTarget(pinned, eContainer) { +var ResizeFeature = /** @class */ (function (_super) { + __extends(ResizeFeature, _super); + function ResizeFeature(pinned, column, eResize, comp, ctrl) { var _this = _super.call(this) || this; - _this.dropListeners = {}; _this.pinned = pinned; - _this.eContainer = eContainer; + _this.column = column; + _this.eResize = eResize; + _this.comp = comp; + _this.ctrl = ctrl; return _this; } - BodyDropTarget.prototype.registerGridComp = function (gridPanel) { - this.gridPanel = gridPanel; - this.moveColumnController.registerGridComp(gridPanel); - switch (this.pinned) { - case _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_LEFT: - this.eSecondaryContainers = this.gridPanel.getDropTargetLeftContainers(); - break; - case _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_RIGHT: - this.eSecondaryContainers = this.gridPanel.getDropTargetRightContainers(); - break; - default: - this.eSecondaryContainers = this.gridPanel.getDropTargetBodyContainers(); - break; - } - }; - BodyDropTarget.prototype.isInterestedIn = function (type) { - return type === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragSourceType"].HeaderCell || - (type === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragSourceType"].ToolPanel && this.gridOptionsWrapper.isAllowDragFromColumnsToolPanel()); - }; - BodyDropTarget.prototype.getSecondaryContainers = function () { - return this.eSecondaryContainers; - }; - BodyDropTarget.prototype.getContainer = function () { - return this.eContainer; + ResizeFeature.prototype.postConstruct = function () { + var _this = this; + var colDef = this.column.getColDef(); + var destroyResizeFuncs = []; + var canResize; + var canAutosize; + var addResize = function () { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["setDisplayed"])(_this.eResize, canResize); + if (!canResize) { + return; + } + var finishedWithResizeFunc = _this.horizontalResizeService.addResizeBar({ + eResizeBar: _this.eResize, + onResizeStart: _this.onResizeStart.bind(_this), + onResizing: _this.onResizing.bind(_this, false), + onResizeEnd: _this.onResizing.bind(_this, true) + }); + destroyResizeFuncs.push(finishedWithResizeFunc); + if (canAutosize) { + var skipHeaderOnAutoSize_1 = _this.gridOptionsWrapper.isSkipHeaderOnAutoSize(); + var autoSizeColListener_1 = function () { + _this.columnModel.autoSizeColumn(_this.column, skipHeaderOnAutoSize_1, "uiColumnResized"); + }; + _this.eResize.addEventListener('dblclick', autoSizeColListener_1); + var touchListener_1 = new _widgets_touchListener__WEBPACK_IMPORTED_MODULE_4__["TouchListener"](_this.eResize); + touchListener_1.addEventListener(_widgets_touchListener__WEBPACK_IMPORTED_MODULE_4__["TouchListener"].EVENT_DOUBLE_TAP, autoSizeColListener_1); + _this.addDestroyFunc(function () { + _this.eResize.removeEventListener('dblclick', autoSizeColListener_1); + touchListener_1.removeEventListener(_widgets_touchListener__WEBPACK_IMPORTED_MODULE_4__["TouchListener"].EVENT_DOUBLE_TAP, autoSizeColListener_1); + touchListener_1.destroy(); + }); + } + }; + var removeResize = function () { + destroyResizeFuncs.forEach(function (f) { return f(); }); + destroyResizeFuncs.length = 0; + }; + var refresh = function () { + var resize = _this.column.isResizable(); + var autoSize = !_this.gridOptionsWrapper.isSuppressAutoSize() && !colDef.suppressAutoSize; + var propertyChange = resize !== canResize || autoSize !== canAutosize; + if (propertyChange) { + canResize = resize; + canAutosize = autoSize; + removeResize(); + addResize(); + } + }; + refresh(); + this.addDestroyFunc(removeResize); + this.ctrl.addRefreshFunction(refresh); }; - BodyDropTarget.prototype.init = function () { - this.moveColumnController = this.createBean(new _moveColumnController__WEBPACK_IMPORTED_MODULE_2__["MoveColumnController"](this.pinned, this.eContainer)); - var bodyDropPivotTarget = new _bodyDropPivotTarget__WEBPACK_IMPORTED_MODULE_3__["BodyDropPivotTarget"](this.pinned); - this.createBean(bodyDropPivotTarget); - this.dropListeners[DropType.ColumnMove] = this.moveColumnController; - this.dropListeners[DropType.Pivot] = bodyDropPivotTarget; - this.dragAndDropService.addDropTarget(this); + ResizeFeature.prototype.onResizing = function (finished, resizeAmount) { + var resizeAmountNormalised = this.normaliseResizeAmount(resizeAmount); + var columnWidths = [{ key: this.column, newWidth: this.resizeStartWidth + resizeAmountNormalised }]; + this.columnModel.setColumnWidths(columnWidths, this.resizeWithShiftKey, finished, "uiColumnDragged"); + if (finished) { + this.comp.addOrRemoveCssClass('ag-column-resizing', false); + } }; - BodyDropTarget.prototype.getIconName = function () { - return this.currentDropListener.getIconName(); + ResizeFeature.prototype.onResizeStart = function (shiftKey) { + this.resizeStartWidth = this.column.getActualWidth(); + this.resizeWithShiftKey = shiftKey; + this.comp.addOrRemoveCssClass('ag-column-resizing', true); }; - // we want to use the bodyPivotTarget if the user is dragging columns in from the toolPanel - // and we are in pivot mode, as it has to logic to set pivot/value/group on the columns when - // dropped into the grid's body. - BodyDropTarget.prototype.getDropType = function (draggingEvent) { - if (this.columnController.isPivotMode()) { - // in pivot mode, then if moving a column (ie didn't come from toolpanel) then it's - // a standard column move, however if it came from the toolpanel, then we are introducing - // dimensions or values to the grid - if (draggingEvent.dragSource.type === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragSourceType"].ToolPanel) { - return DropType.Pivot; + // optionally inverts the drag, depending on pinned and RTL + // note - this method is duplicated in RenderedHeaderGroupCell - should refactor out? + ResizeFeature.prototype.normaliseResizeAmount = function (dragChange) { + var result = dragChange; + var notPinningLeft = this.pinned !== _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_LEFT; + var pinningRight = this.pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_RIGHT; + if (this.gridOptionsWrapper.isEnableRtl()) { + // for RTL, dragging left makes the col bigger, except when pinning left + if (notPinningLeft) { + result *= -1; } - return DropType.ColumnMove; } - // it's a column, and not pivot mode, so always moving - return DropType.ColumnMove; - }; - BodyDropTarget.prototype.onDragEnter = function (draggingEvent) { - // we pick the drop listener depending on whether we are in pivot mode are not. if we are - // in pivot mode, then dropping cols changes the row group, pivot, value stats. otherwise - // we change visibility state and position. - // if (this.columnController.isPivotMode()) { - var dropType = this.getDropType(draggingEvent); - this.currentDropListener = this.dropListeners[dropType]; - this.currentDropListener.onDragEnter(draggingEvent); - }; - BodyDropTarget.prototype.onDragLeave = function (params) { - this.currentDropListener.onDragLeave(params); - }; - BodyDropTarget.prototype.onDragging = function (params) { - this.currentDropListener.onDragging(params); - }; - BodyDropTarget.prototype.onDragStop = function (params) { - this.currentDropListener.onDragStop(params); + else { + // for LTR (ie normal), dragging left makes the col smaller, except when pinning right + if (pinningRight) { + result *= -1; + } + } + return result; }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('dragAndDropService') - ], BodyDropTarget.prototype, "dragAndDropService", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('horizontalResizeService') + ], ResizeFeature.prototype, "horizontalResizeService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController') - ], BodyDropTarget.prototype, "columnController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], BodyDropTarget.prototype, "gridOptionsWrapper", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnModel') + ], ResizeFeature.prototype, "columnModel", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], BodyDropTarget.prototype, "init", null); - return BodyDropTarget; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_5__["BeanStub"])); + _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] + ], ResizeFeature.prototype, "postConstruct", null); + return ResizeFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 122 */ +/* 157 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MoveColumnController", function() { return MoveColumnController; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(25); -/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(104); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SelectAllFeature", function() { return SelectAllFeature; }); +/* harmony import */ var _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(158); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(23); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(15); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(44); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); @@ -28089,394 +35027,377 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var MoveColumnController = /** @class */ (function () { - function MoveColumnController(pinned, eContainer) { - this.needToMoveLeft = false; - this.needToMoveRight = false; - this.pinned = pinned; - this.eContainer = eContainer; - this.centerContainer = !_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(pinned); + + +var SelectAllFeature = /** @class */ (function (_super) { + __extends(SelectAllFeature, _super); + function SelectAllFeature(column) { + var _this = _super.call(this) || this; + _this.cbSelectAllVisible = false; + _this.processingEventFromCheckbox = false; + _this.column = column; + var colDef = column.getColDef(); + _this.filteredOnly = colDef ? !!colDef.headerCheckboxSelectionFilteredOnly : false; + return _this; } - MoveColumnController.prototype.registerGridComp = function (gridPanel) { - this.gridPanel = gridPanel; + SelectAllFeature.prototype.onSpaceKeyPressed = function (e) { + var checkbox = this.cbSelectAll; + var eDocument = this.gridOptionsWrapper.getDocument(); + if (checkbox.isDisplayed() && !checkbox.getGui().contains(eDocument.activeElement)) { + e.preventDefault(); + checkbox.setValue(!checkbox.getValue()); + } }; - MoveColumnController.prototype.init = function () { - this.logger = this.loggerFactory.create('MoveColumnController'); + SelectAllFeature.prototype.getCheckboxGui = function () { + return this.cbSelectAll.getGui(); }; - MoveColumnController.prototype.getIconName = function () { - return this.pinned ? _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_PINNED : _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_MOVE; + SelectAllFeature.prototype.setComp = function (comp) { + this.comp = comp; + this.cbSelectAll = this.createManagedBean(new _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_0__["AgCheckbox"]()); + this.cbSelectAll.addCssClass('ag-header-select-all'); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_5__["setAriaRole"])(this.cbSelectAll.getGui(), 'presentation'); + this.showOrHideSelectAll(); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_NEW_COLUMNS_LOADED, this.showOrHideSelectAll.bind(this)); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.showOrHideSelectAll.bind(this)); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_SELECTION_CHANGED, this.onSelectionChanged.bind(this)); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_MODEL_UPDATED, this.onModelChanged.bind(this)); + this.addManagedListener(this.cbSelectAll, _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_0__["AgCheckbox"].EVENT_CHANGED, this.onCbSelectAll.bind(this)); + this.cbSelectAll.getInputElement().setAttribute('tabindex', '-1'); + this.refreshSelectAllLabel(); }; - MoveColumnController.prototype.onDragEnter = function (draggingEvent) { - // we do dummy drag, so make sure column appears in the right location when first placed - var columns = draggingEvent.dragItem.columns; - var dragCameFromToolPanel = draggingEvent.dragSource.type === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragSourceType"].ToolPanel; - if (dragCameFromToolPanel) { - // the if statement doesn't work if drag leaves grid, then enters again - this.setColumnsVisible(columns, true, "uiColumnDragged"); - } - else { - // restore previous state of visible columns upon re-entering. this means if the user drags - // a group out, and then drags the group back in, only columns that were originally visible - // will be visible again. otherwise a group with three columns (but only two visible) could - // be dragged out, then when it's dragged in again, all three are visible. this stops that. - var visibleState_1 = draggingEvent.dragItem.visibleState; - var visibleColumns = columns.filter(function (column) { return visibleState_1[column.getId()]; }); - this.setColumnsVisible(visibleColumns, true, "uiColumnDragged"); + SelectAllFeature.prototype.showOrHideSelectAll = function () { + this.cbSelectAllVisible = this.isCheckboxSelection(); + this.cbSelectAll.setDisplayed(this.cbSelectAllVisible); + if (this.cbSelectAllVisible) { + // in case user is trying this feature with the wrong model type + this.checkRightRowModelType(); + // make sure checkbox is showing the right state + this.updateStateOfCheckbox(); } - this.setColumnsPinned(columns, this.pinned, "uiColumnDragged"); - this.onDragging(draggingEvent, true); + this.refreshHeaderAriaDescribedBy(this.cbSelectAllVisible); }; - MoveColumnController.prototype.onDragLeave = function (draggingEvent) { - var hideColumnOnExit = !this.gridOptionsWrapper.isSuppressDragLeaveHidesColumns() && !draggingEvent.fromNudge; - if (hideColumnOnExit) { - var dragItem = draggingEvent.dragSource.getDragItem(); - var columns = dragItem.columns; - this.setColumnsVisible(columns, false, "uiColumnDragged"); - } - this.ensureIntervalCleared(); + SelectAllFeature.prototype.refreshHeaderAriaDescribedBy = function (isSelectAllVisible) { + var describedBy = isSelectAllVisible ? this.cbSelectAll.getInputElement().id : undefined; + this.comp.setAriaDescribedBy(describedBy); }; - MoveColumnController.prototype.setColumnsVisible = function (columns, visible, source) { - if (source === void 0) { source = "api"; } - if (columns) { - var allowedCols = columns.filter(function (c) { return !c.getColDef().lockVisible; }); - this.columnController.setColumnsVisible(allowedCols, visible, source); + SelectAllFeature.prototype.onModelChanged = function () { + if (!this.cbSelectAllVisible) { + return; } + this.updateStateOfCheckbox(); }; - MoveColumnController.prototype.setColumnsPinned = function (columns, pinned, source) { - if (source === void 0) { source = "api"; } - if (columns) { - var allowedCols = columns.filter(function (c) { return !c.getColDef().lockPinned; }); - this.columnController.setColumnsPinned(allowedCols, pinned, source); + SelectAllFeature.prototype.onSelectionChanged = function () { + if (!this.cbSelectAllVisible) { + return; } + this.updateStateOfCheckbox(); }; - MoveColumnController.prototype.onDragStop = function () { - this.ensureIntervalCleared(); - }; - MoveColumnController.prototype.normaliseX = function (x) { - // flip the coordinate if doing RTL - if (this.gridOptionsWrapper.isEnableRtl()) { - var clientWidth = this.eContainer.clientWidth; - x = clientWidth - x; + SelectAllFeature.prototype.getNextCheckboxState = function (selectionCount) { + // if no rows, always have it unselected + if (selectionCount.selected === 0 && selectionCount.notSelected === 0) { + return false; } - // adjust for scroll only if centre container (the pinned containers don't scroll) - if (this.centerContainer) { - x += this.gridPanel.getCenterViewportScrollLeft(); + // if mix of selected and unselected, this is the tri-state + if (selectionCount.selected > 0 && selectionCount.notSelected > 0) { + return null; } - return x; - }; - MoveColumnController.prototype.checkCenterForScrolling = function (xAdjustedForScroll) { - if (this.centerContainer) { - // scroll if the mouse has gone outside the grid (or just outside the scrollable part if pinning) - // putting in 50 buffer, so even if user gets to edge of grid, a scroll will happen - var firstVisiblePixel = this.gridPanel.getCenterViewportScrollLeft(); - var lastVisiblePixel = firstVisiblePixel + this.gridPanel.getCenterWidth(); - if (this.gridOptionsWrapper.isEnableRtl()) { - this.needToMoveRight = xAdjustedForScroll < (firstVisiblePixel + 50); - this.needToMoveLeft = xAdjustedForScroll > (lastVisiblePixel - 50); - } - else { - this.needToMoveLeft = xAdjustedForScroll < (firstVisiblePixel + 50); - this.needToMoveRight = xAdjustedForScroll > (lastVisiblePixel - 50); - } - if (this.needToMoveLeft || this.needToMoveRight) { - this.ensureIntervalStarted(); - } - else { - this.ensureIntervalCleared(); - } + // only selected + if (selectionCount.selected > 0) { + return true; } + // nothing selected + return false; }; - MoveColumnController.prototype.onDragging = function (draggingEvent, fromEnter) { - var _this = this; - if (fromEnter === void 0) { fromEnter = false; } - this.lastDraggingEvent = draggingEvent; - // if moving up or down (ie not left or right) then do nothing - if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].missing(draggingEvent.hDirection)) { + SelectAllFeature.prototype.updateStateOfCheckbox = function () { + if (this.processingEventFromCheckbox) { return; } - var mouseXNormalised = this.normaliseX(draggingEvent.x); - // if the user is dragging into the panel, ie coming from the side panel into the main grid, - // we don't want to scroll the grid this time, it would appear like the table is jumping - // each time a column is dragged in. - if (!fromEnter) { - this.checkCenterForScrolling(mouseXNormalised); - } - var hDirectionNormalised = this.normaliseDirection(draggingEvent.hDirection); - var dragSourceType = draggingEvent.dragSource.type; - var columnsToMove = draggingEvent.dragSource.getDragItem().columns; - columnsToMove = columnsToMove.filter(function (col) { - if (col.getColDef().lockPinned) { - // if locked return true only if both col and container are same pin type. - // double equals (==) here on purpose so that null==undefined is true (for not pinned options) - return col.getPinned() == _this.pinned; + this.processingEventFromCheckbox = true; + var selectionCount = this.getSelectionCount(); + var allSelected = this.getNextCheckboxState(selectionCount); + this.cbSelectAll.setValue(allSelected); + this.refreshSelectAllLabel(); + this.processingEventFromCheckbox = false; + }; + SelectAllFeature.prototype.refreshSelectAllLabel = function () { + var translate = this.gridOptionsWrapper.getLocaleTextFunc(); + var checked = this.cbSelectAll.getValue(); + var ariaStatus = checked ? translate('ariaChecked', 'checked') : translate('ariaUnchecked', 'unchecked'); + var ariaLabel = translate('ariaRowSelectAll', 'Press Space to toggle all rows selection'); + this.cbSelectAll.setInputAriaLabel(ariaLabel + " (" + ariaStatus + ")"); + }; + SelectAllFeature.prototype.getSelectionCount = function () { + var _this = this; + var selectedCount = 0; + var notSelectedCount = 0; + var callback = function (node) { + if (_this.gridOptionsWrapper.isGroupSelectsChildren() && node.group) { + return; } - else { - // if not pin locked, then always allowed to be in this container - return true; + if (node.isSelected()) { + selectedCount++; } - }); - this.attemptMoveColumns(dragSourceType, columnsToMove, hDirectionNormalised, mouseXNormalised, fromEnter); - }; - MoveColumnController.prototype.normaliseDirection = function (hDirection) { - if (this.gridOptionsWrapper.isEnableRtl()) { - switch (hDirection) { - case _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Left: return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Right; - case _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Right: return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Left; - default: console.error("ag-Grid: Unknown direction " + hDirection); + else if (!node.selectable) { + // don't count non-selectable nodes! + } + else { + notSelectedCount++; } + }; + if (this.filteredOnly) { + this.gridApi.forEachNodeAfterFilter(callback); } else { - return hDirection; + this.gridApi.forEachNode(callback); } + return { + notSelected: notSelectedCount, + selected: selectedCount + }; }; - // returns the index of the first column in the list ONLY if the cols are all beside - // each other. if the cols are not beside each other, then returns null - MoveColumnController.prototype.calculateOldIndex = function (movingCols) { - var gridCols = this.columnController.getAllGridColumns(); - var indexes = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].sortNumerically(movingCols.map(function (col) { return gridCols.indexOf(col); })); - var firstIndex = indexes[0]; - var lastIndex = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].last(indexes); - var spread = lastIndex - firstIndex; - var gapsExist = spread !== indexes.length - 1; - return gapsExist ? null : firstIndex; + SelectAllFeature.prototype.checkRightRowModelType = function () { + var rowModelType = this.rowModel.getType(); + var rowModelMatches = rowModelType === _constants_constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE; + if (!rowModelMatches) { + console.warn("AG Grid: selectAllCheckbox is only available if using normal row model, you are using " + rowModelType); + } }; - MoveColumnController.prototype.attemptMoveColumns = function (dragSourceType, allMovingColumns, hDirection, mouseX, fromEnter) { - var draggingLeft = hDirection === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Left; - var draggingRight = hDirection === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Right; - var validMoves = this.calculateValidMoves(allMovingColumns, draggingRight, mouseX); - // if cols are not adjacent, then this returns null. when moving, we constrain the direction of the move - // (ie left or right) to the mouse direction. however - var oldIndex = this.calculateOldIndex(allMovingColumns); - if (validMoves.length === 0) { + SelectAllFeature.prototype.onCbSelectAll = function () { + if (this.processingEventFromCheckbox) { return; } - var firstValidMove = validMoves[0]; - // the two check below stop an error when the user grabs a group my a middle column, then - // it is possible the mouse pointer is to the right of a column while been dragged left. - // so we need to make sure that the mouse pointer is actually left of the left most column - // if moving left, and right of the right most column if moving right - // we check 'fromEnter' below so we move the column to the new spot if the mouse is coming from - // outside the grid, eg if the column is moving from side panel, mouse is moving left, then we should - // place the column to the RHS even if the mouse is moving left and the column is already on - // the LHS. otherwise we stick to the rule described above. - var constrainDirection = oldIndex !== null && !fromEnter; - // don't consider 'fromEnter' when dragging header cells, otherwise group can jump to opposite direction of drag - if (dragSourceType == _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragSourceType"].HeaderCell) { - constrainDirection = oldIndex !== null; + if (!this.cbSelectAllVisible) { + return; } - if (constrainDirection) { - // only allow left drag if this column is moving left - if (draggingLeft && firstValidMove >= oldIndex) { - return; - } - // only allow right drag if this column is moving right - if (draggingRight && firstValidMove <= oldIndex) { - return; - } + var value = this.cbSelectAll.getValue(); + if (value) { + this.selectionService.selectAllRowNodes(this.filteredOnly); } - for (var i = 0; i < validMoves.length; i++) { - var move = validMoves[i]; - if (!this.columnController.doesMovePassRules(allMovingColumns, move)) { - continue; - } - this.columnController.moveColumns(allMovingColumns, move, "uiColumnDragged"); - // important to return here, so once we do the first valid move, we don't try do any more - return; + else { + this.selectionService.deselectAllRowNodes(this.filteredOnly); } }; - MoveColumnController.prototype.calculateValidMoves = function (movingCols, draggingRight, mouseX) { - var isMoveBlocked = this.gridOptionsWrapper.isSuppressMovableColumns() || movingCols.some(function (col) { return col.getColDef().suppressMovable; }); - if (isMoveBlocked) { - return []; - } - // this is the list of cols on the screen, so it's these we use when comparing the x mouse position - var allDisplayedCols = this.columnController.getDisplayedColumns(this.pinned); - // but this list is the list of all cols, when we move a col it's the index within this list that gets used, - // so the result we return has to be and index location for this list - var allGridCols = this.columnController.getAllGridColumns(); - var movingDisplayedCols = allDisplayedCols.filter(function (col) { return _utils__WEBPACK_IMPORTED_MODULE_3__["_"].includes(movingCols, col); }); - var otherDisplayedCols = allDisplayedCols.filter(function (col) { return !_utils__WEBPACK_IMPORTED_MODULE_3__["_"].includes(movingCols, col); }); - var otherGridCols = allGridCols.filter(function (col) { return !_utils__WEBPACK_IMPORTED_MODULE_3__["_"].includes(movingCols, col); }); - // work out how many DISPLAYED columns fit before the 'x' position. this gives us the displayIndex. - // for example, if cols are a,b,c,d and we find a,b fit before 'x', then we want to place the moving - // col between b and c (so that it is under the mouse position). - var displayIndex = 0; - var availableWidth = mouseX; - // if we are dragging right, then the columns will be to the left of the mouse, so we also want to - // include the width of the moving columns - if (draggingRight) { - var widthOfMovingDisplayedCols_1 = 0; - movingDisplayedCols.forEach(function (col) { return widthOfMovingDisplayedCols_1 += col.getActualWidth(); }); - availableWidth -= widthOfMovingDisplayedCols_1; + SelectAllFeature.prototype.isCheckboxSelection = function () { + var result = this.column.getColDef().headerCheckboxSelection; + if (typeof result === 'function') { + var func = result; + result = func({ + column: this.column, + colDef: this.column.getColDef(), + columnApi: this.columnApi, + api: this.gridApi + }); } - if (availableWidth > 0) { - // now count how many of the displayed columns will fit to the left - for (var i = 0; i < otherDisplayedCols.length; i++) { - var col = otherDisplayedCols[i]; - availableWidth -= col.getActualWidth(); - if (availableWidth < 0) { - break; - } - displayIndex++; + if (result) { + if (this.gridOptionsWrapper.isRowModelServerSide()) { + console.warn('AG Grid: headerCheckboxSelection is not supported for Server Side Row Model'); + return false; } - // trial and error, if going right, we adjust by one, i didn't manage to quantify why, but it works - if (draggingRight) { - displayIndex++; + if (this.gridOptionsWrapper.isRowModelInfinite()) { + console.warn('AG Grid: headerCheckboxSelection is not supported for Infinite Row Model'); + return false; } - } - // the display index is with respect to all the showing columns, however when we move, it's with - // respect to all grid columns, so we need to translate from display index to grid index - var firstValidMove; - if (displayIndex > 0) { - var leftColumn = otherDisplayedCols[displayIndex - 1]; - firstValidMove = otherGridCols.indexOf(leftColumn) + 1; - } - else { - firstValidMove = otherGridCols.indexOf(otherDisplayedCols[0]); - if (firstValidMove === -1) { - firstValidMove = 0; + if (this.gridOptionsWrapper.isRowModelViewport()) { + console.warn('AG Grid: headerCheckboxSelection is not supported for Viewport Row Model'); + return false; } + // otherwise the row model is compatible, so return true + return true; } - var validMoves = [firstValidMove]; - // add in other valid moves due to hidden columns and married children. for example, a particular - // move might break a group that has married children (so move isn't valid), however there could - // be hidden columns (not displayed) that we could jump over to make the move valid. because - // they are hidden, user doesn't see any different, however it allows moves that would otherwise - // not work. for example imagine a group with 9 columns and all columns are hidden except the - // middle one (so 4 hidden to left, 4 hidden to right), then when moving 'firstValidMove' will - // be relative to the not-shown column, however we need to consider the move jumping over all the - // hidden children. if we didn't do this, then if the group just described was at the end (RHS) of the - // grid, there would be no way to put a column after it (as the grid would only consider beside the - // visible column, which would fail valid move rules). - if (draggingRight) { - // if dragging right, then we add all the additional moves to the right. so in other words - // if the next move is not valid, find the next move to the right that is valid. - var pointer = firstValidMove + 1; - var lastIndex = allGridCols.length - 1; - while (pointer <= lastIndex) { - validMoves.push(pointer); - pointer++; - } + return false; + }; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridApi') + ], SelectAllFeature.prototype, "gridApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnApi') + ], SelectAllFeature.prototype, "columnApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('rowModel') + ], SelectAllFeature.prototype, "rowModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('selectionService') + ], SelectAllFeature.prototype, "selectionService", void 0); + return SelectAllFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + + + +/***/ }), +/* 158 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgCheckbox", function() { return AgCheckbox; }); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(23); +/* harmony import */ var _agAbstractInputField__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(71); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); + + +var AgCheckbox = /** @class */ (function (_super) { + __extends(AgCheckbox, _super); + function AgCheckbox(config, className, inputType) { + if (className === void 0) { className = 'ag-checkbox'; } + if (inputType === void 0) { inputType = 'checkbox'; } + var _this = _super.call(this, config, className, inputType) || this; + _this.labelAlignment = 'right'; + _this.selected = false; + _this.readOnly = false; + _this.passive = false; + return _this; + } + AgCheckbox.prototype.addInputListeners = function () { + this.addManagedListener(this.eInput, 'click', this.onCheckboxClick.bind(this)); + this.addManagedListener(this.eLabel, 'click', this.toggle.bind(this)); + }; + AgCheckbox.prototype.getNextValue = function () { + return this.selected === undefined ? true : !this.selected; + }; + AgCheckbox.prototype.setPassive = function (passive) { + this.passive = passive; + }; + AgCheckbox.prototype.isReadOnly = function () { + return this.readOnly; + }; + AgCheckbox.prototype.setReadOnly = function (readOnly) { + this.eWrapper.classList.toggle('ag-disabled', readOnly); + this.eInput.disabled = readOnly; + this.readOnly = readOnly; + }; + AgCheckbox.prototype.setDisabled = function (disabled) { + this.eWrapper.classList.toggle('ag-disabled', disabled); + return _super.prototype.setDisabled.call(this, disabled); + }; + AgCheckbox.prototype.toggle = function () { + if (this.eInput.disabled) { + return; + } + var previousValue = this.isSelected(); + var nextValue = this.getNextValue(); + if (this.passive) { + this.dispatchChange(nextValue, previousValue); } else { - // if dragging left we do the reverse of dragging right, we add in all the valid moves to the - // left. however we also have to consider moves to the right for all hidden columns first. - // (this logic is hard to reason with, it was worked out with trial and error, - // move observation rather than science). - // add moves to the right - var pointer = firstValidMove; - var lastIndex = allGridCols.length - 1; - var displacedCol = allGridCols[pointer]; - while (pointer <= lastIndex && this.isColumnHidden(allDisplayedCols, displacedCol)) { - pointer++; - validMoves.push(pointer); - displacedCol = allGridCols[pointer]; - } - // add moves to the left - pointer = firstValidMove - 1; - var firstDisplayIndex = 0; - while (pointer >= firstDisplayIndex) { - validMoves.push(pointer); - pointer--; - } + this.setValue(nextValue); } - return validMoves; }; - // isHidden takes into account visible=false and group=closed, ie it is not displayed - MoveColumnController.prototype.isColumnHidden = function (displayedColumns, col) { - return displayedColumns.indexOf(col) < 0; + AgCheckbox.prototype.getValue = function () { + return this.isSelected(); }; - MoveColumnController.prototype.ensureIntervalStarted = function () { - if (!this.movingIntervalId) { - this.intervalCount = 0; - this.failedMoveAttempts = 0; - this.movingIntervalId = window.setInterval(this.moveInterval.bind(this), 100); - if (this.needToMoveLeft) { - this.dragAndDropService.setGhostIcon(_dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_LEFT, true); - } - else { - this.dragAndDropService.setGhostIcon(_dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_RIGHT, true); - } - } + AgCheckbox.prototype.setValue = function (value, silent) { + this.refreshSelectedClass(value); + this.setSelected(value, silent); + return this; }; - MoveColumnController.prototype.ensureIntervalCleared = function () { - if (this.moveInterval) { - window.clearInterval(this.movingIntervalId); - this.movingIntervalId = null; - this.dragAndDropService.setGhostIcon(_dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_MOVE); - } + AgCheckbox.prototype.setName = function (name) { + var input = this.getInputElement(); + input.name = name; + return this; }; - MoveColumnController.prototype.moveInterval = function () { - // the amounts we move get bigger at each interval, so the speed accelerates, starting a bit slow - // and getting faster. this is to give smoother user experience. we max at 100px to limit the speed. - var pixelsToMove; - this.intervalCount++; - pixelsToMove = 10 + (this.intervalCount * 5); - if (pixelsToMove > 100) { - pixelsToMove = 100; - } - var pixelsMoved; - if (this.needToMoveLeft) { - pixelsMoved = this.gridPanel.scrollHorizontally(-pixelsToMove); - } - else if (this.needToMoveRight) { - pixelsMoved = this.gridPanel.scrollHorizontally(pixelsToMove); + AgCheckbox.prototype.isSelected = function () { + return this.selected; + }; + AgCheckbox.prototype.setSelected = function (selected, silent) { + if (this.isSelected() === selected) { + return; } - if (pixelsMoved !== 0) { - this.onDragging(this.lastDraggingEvent); - this.failedMoveAttempts = 0; + this.previousValue = this.isSelected(); + selected = this.selected = typeof selected === 'boolean' ? selected : undefined; + this.eInput.checked = selected; + this.eInput.indeterminate = selected === undefined; + if (!silent) { + this.dispatchChange(this.selected, this.previousValue); } - else { - // we count the failed move attempts. if we fail to move 7 times, then we pin the column. - // this is how we achieve pining by dragging the column to the edge of the grid. - this.failedMoveAttempts++; - var columns = this.lastDraggingEvent.dragItem.columns; - var columnsThatCanPin = columns.filter(function (c) { return !c.getColDef().lockPinned; }); - if (columnsThatCanPin.length > 0) { - this.dragAndDropService.setGhostIcon(_dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_PINNED); - if (this.failedMoveAttempts > 7) { - var pinType = this.needToMoveLeft ? _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].PINNED_LEFT : _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].PINNED_RIGHT; - this.setColumnsPinned(columnsThatCanPin, pinType, "uiColumnDragged"); - this.dragAndDropService.nudge(); - } - } + }; + AgCheckbox.prototype.dispatchChange = function (selected, previousValue, event) { + this.dispatchEvent({ type: AgCheckbox.EVENT_CHANGED, selected: selected, previousValue: previousValue, event: event }); + var input = this.getInputElement(); + var checkboxChangedEvent = { + type: _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_CHECKBOX_CHANGED, + id: input.id, + name: input.name, + selected: selected, + previousValue: previousValue + }; + this.eventService.dispatchEvent(checkboxChangedEvent); + }; + AgCheckbox.prototype.onCheckboxClick = function (e) { + if (this.passive || this.eInput.disabled) { + return; } + var previousValue = this.isSelected(); + var selected = this.selected = e.target.checked; + this.refreshSelectedClass(selected); + this.dispatchChange(selected, previousValue, e); }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('loggerFactory') - ], MoveColumnController.prototype, "loggerFactory", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], MoveColumnController.prototype, "columnController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('dragAndDropService') - ], MoveColumnController.prototype, "dragAndDropService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], MoveColumnController.prototype, "gridOptionsWrapper", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], MoveColumnController.prototype, "init", null); - return MoveColumnController; -}()); + AgCheckbox.prototype.refreshSelectedClass = function (value) { + this.eWrapper.classList.toggle('ag-checked', value === true); + this.eWrapper.classList.toggle('ag-indeterminate', value == null); + }; + return AgCheckbox; +}(_agAbstractInputField__WEBPACK_IMPORTED_MODULE_1__["AgAbstractInputField"])); /***/ }), -/* 123 */ +/* 159 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BodyDropPivotTarget", function() { return BodyDropPivotTarget; }); -/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(104); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderGroupCellCtrl", function() { return HeaderGroupCellCtrl; }); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(65); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(97); +/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(10); +/* harmony import */ var _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(8); +/* harmony import */ var _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(152); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(18); +/* harmony import */ var _widgets_managedFocusFeature__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(64); +/* harmony import */ var _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(119); +/* harmony import */ var _abstractCell_abstractHeaderCellCtrl__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(148); +/* harmony import */ var _cssClassApplier__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(155); +/* harmony import */ var _hoverFeature__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(153); +/* harmony import */ var _groupResizeFeature__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(160); +/* harmony import */ var _groupWidthFeature__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(161); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); @@ -28485,102 +35406,253 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta }; -var BodyDropPivotTarget = /** @class */ (function () { - function BodyDropPivotTarget(pinned) { - this.columnsToAggregate = []; - this.columnsToGroup = []; - this.columnsToPivot = []; - this.pinned = pinned; + + + + + + + + + + + + +var HeaderGroupCellCtrl = /** @class */ (function (_super) { + __extends(HeaderGroupCellCtrl, _super); + function HeaderGroupCellCtrl(columnGroup, parentRowCtrl) { + var _this = _super.call(this, columnGroup, parentRowCtrl) || this; + _this.columnGroup = columnGroup; + return _this; } - /** Callback for when drag enters */ - BodyDropPivotTarget.prototype.onDragEnter = function (draggingEvent) { + HeaderGroupCellCtrl.prototype.setComp = function (comp, eGui, eResize) { + _super.prototype.setGui.call(this, eGui); + this.comp = comp; + this.displayName = this.columnModel.getDisplayNameForColumnGroup(this.columnGroup, 'header'); + this.addClasses(); + this.addAttributes(); + this.setupMovingCss(); + this.setupExpandable(); + this.setupTooltip(); + this.setupUserComp(); + var pinned = this.getParentRowCtrl().getPinned(); + var leafCols = this.columnGroup.getProvidedColumnGroup().getLeafColumns(); + this.createManagedBean(new _hoverFeature__WEBPACK_IMPORTED_MODULE_11__["HoverFeature"](leafCols, eGui)); + this.createManagedBean(new _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_5__["SetLeftFeature"](this.columnGroup, eGui, this.beans)); + this.createManagedBean(new _groupWidthFeature__WEBPACK_IMPORTED_MODULE_13__["GroupWidthFeature"](comp, this.columnGroup)); + this.groupResizeFeature = this.createManagedBean(new _groupResizeFeature__WEBPACK_IMPORTED_MODULE_12__["GroupResizeFeature"](comp, eResize, pinned, this.columnGroup)); + this.createManagedBean(new _widgets_managedFocusFeature__WEBPACK_IMPORTED_MODULE_7__["ManagedFocusFeature"](eGui, { + shouldStopEventPropagation: this.shouldStopEventPropagation.bind(this), + onTabKeyDown: function () { return undefined; }, + handleKeyDown: this.handleKeyDown.bind(this), + onFocusIn: this.onFocusIn.bind(this) + })); + }; + HeaderGroupCellCtrl.prototype.resizeLeafColumnsToFit = function () { + this.groupResizeFeature.onResizeStart(false); + this.groupResizeFeature.resizeLeafColumnsToFit(); + }; + HeaderGroupCellCtrl.prototype.setupUserComp = function () { var _this = this; - this.clearColumnsList(); - // in pivot mode, we don't accept any drops if functions are read only - if (this.gridOptionsWrapper.isFunctionsReadOnly()) { - return; - } - var dragColumns = draggingEvent.dragItem.columns; - dragColumns.forEach(function (column) { - // we don't allow adding secondary columns - if (!column.isPrimary()) { - return; - } - if (column.isAnyFunctionActive()) { - return; - } - if (column.isAllowValue()) { - _this.columnsToAggregate.push(column); + var displayName = this.displayName; + var params = { + displayName: this.displayName, + columnGroup: this.columnGroup, + setExpanded: function (expanded) { + _this.columnModel.setColumnGroupOpened(_this.columnGroup.getProvidedColumnGroup(), expanded, "gridInitializing"); + }, + api: this.gridApi, + columnApi: this.columnApi, + context: this.gridOptionsWrapper.getContext() + }; + if (!displayName) { + var columnGroup = this.columnGroup; + var leafCols = columnGroup.getLeafColumns(); + // find the top most column group that represents the same columns. so if we are dragging a group, we also + // want to visually show the parent groups dragging for the same column set. for example imaging 5 levels + // of grouping, with each group only containing the next group, and the last group containing three columns, + // then when you move any group (even the lowest level group) you are in-fact moving all the groups, as all + // the groups represent the same column set. + while (columnGroup.getParent() && columnGroup.getParent().getLeafColumns().length === leafCols.length) { + columnGroup = columnGroup.getParent(); } - else if (column.isAllowRowGroup()) { - _this.columnsToGroup.push(column); + var colGroupDef = columnGroup.getColGroupDef(); + if (colGroupDef) { + displayName = colGroupDef.headerName; } - else if (column.isAllowRowGroup()) { - _this.columnsToPivot.push(column); + if (!displayName) { + displayName = leafCols ? this.columnModel.getDisplayNameForColumn(leafCols[0], 'header', true) : ''; } - }); + } + var compDetails = this.userComponentFactory.getHeaderGroupCompDetails(params); + this.comp.setUserCompDetails(compDetails); }; - BodyDropPivotTarget.prototype.getIconName = function () { - var totalColumns = this.columnsToAggregate.length + this.columnsToGroup.length + this.columnsToPivot.length; - if (totalColumns > 0) { - return this.pinned ? _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragAndDropService"].ICON_PINNED : _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragAndDropService"].ICON_MOVE; + HeaderGroupCellCtrl.prototype.setupTooltip = function () { + var _this = this; + var colGroupDef = this.columnGroup.getColGroupDef(); + var tooltipCtrl = { + getColumn: function () { return _this.columnGroup; }, + getGui: function () { return _this.eGui; }, + getLocation: function () { return 'headerGroup'; }, + getTooltipValue: function () { return colGroupDef && colGroupDef.headerTooltip; } + }; + if (colGroupDef) { + tooltipCtrl.getColDef = function () { return colGroupDef; }; + } + var tooltipFeature = this.createManagedBean(new _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_8__["TooltipFeature"](tooltipCtrl, this.beans)); + tooltipFeature.setComp(this.comp); + }; + HeaderGroupCellCtrl.prototype.setupExpandable = function () { + var providedColGroup = this.columnGroup.getProvidedColumnGroup(); + this.refreshExpanded(); + this.addManagedListener(providedColGroup, _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_4__["ProvidedColumnGroup"].EVENT_EXPANDABLE_CHANGED, this.refreshExpanded.bind(this)); + this.addManagedListener(providedColGroup, _entities_providedColumnGroup__WEBPACK_IMPORTED_MODULE_4__["ProvidedColumnGroup"].EVENT_EXPANDED_CHANGED, this.refreshExpanded.bind(this)); + }; + HeaderGroupCellCtrl.prototype.refreshExpanded = function () { + var column = this.columnGroup; + this.expandable = column.isExpandable(); + var expanded = column.isExpanded(); + if (this.expandable) { + this.comp.setAriaExpanded(expanded ? 'true' : 'false'); } else { - return null; + this.comp.setAriaExpanded(undefined); } }; - /** Callback for when drag leaves */ - BodyDropPivotTarget.prototype.onDragLeave = function (draggingEvent) { - // if we are taking columns out of the center, then we remove them from the report - this.clearColumnsList(); + HeaderGroupCellCtrl.prototype.addAttributes = function () { + this.comp.setColId(this.columnGroup.getUniqueId()); }; - BodyDropPivotTarget.prototype.clearColumnsList = function () { - this.columnsToAggregate.length = 0; - this.columnsToGroup.length = 0; - this.columnsToPivot.length = 0; + HeaderGroupCellCtrl.prototype.addClasses = function () { + var _this = this; + var colGroupDef = this.columnGroup.getColGroupDef(); + var classes = _cssClassApplier__WEBPACK_IMPORTED_MODULE_10__["CssClassApplier"].getHeaderClassesFromColDef(colGroupDef, this.gridOptionsWrapper, null, this.columnGroup); + // having different classes below allows the style to not have a bottom border + // on the group header, if no group is specified + classes.push(this.columnGroup.isPadding() ? "ag-header-group-cell-no-group" : "ag-header-group-cell-with-group"); + classes.forEach(function (c) { return _this.comp.addOrRemoveCssClass(c, true); }); }; - /** Callback for when dragging */ - BodyDropPivotTarget.prototype.onDragging = function (draggingEvent) { + HeaderGroupCellCtrl.prototype.setupMovingCss = function () { + var _this = this; + var providedColumnGroup = this.columnGroup.getProvidedColumnGroup(); + var leafColumns = providedColumnGroup.getLeafColumns(); + // this function adds or removes the moving css, based on if the col is moving. + // this is what makes the header go dark when it is been moved (gives impression to + // user that the column was picked up). + var listener = function () { return _this.comp.addOrRemoveCssClass('ag-header-cell-moving', _this.columnGroup.isMoving()); }; + leafColumns.forEach(function (col) { + _this.addManagedListener(col, _entities_column__WEBPACK_IMPORTED_MODULE_3__["Column"].EVENT_MOVING_CHANGED, listener); + }); + listener(); }; - /** Callback for when drag stops */ - BodyDropPivotTarget.prototype.onDragStop = function (draggingEvent) { - if (this.columnsToAggregate.length > 0) { - this.columnController.addValueColumns(this.columnsToAggregate, "toolPanelDragAndDrop"); + HeaderGroupCellCtrl.prototype.onFocusIn = function (e) { + if (!this.eGui.contains(e.relatedTarget)) { + var rowIndex = this.getRowIndex(); + this.beans.focusService.setFocusedHeader(rowIndex, this.columnGroup); } - if (this.columnsToGroup.length > 0) { - this.columnController.addRowGroupColumns(this.columnsToGroup, "toolPanelDragAndDrop"); + }; + HeaderGroupCellCtrl.prototype.handleKeyDown = function (e) { + var eDocument = this.gridOptionsWrapper.getDocument(); + var activeEl = eDocument.activeElement; + var wrapperHasFocus = activeEl === this.eGui; + if (!this.expandable || !wrapperHasFocus) { + return; } - if (this.columnsToPivot.length > 0) { - this.columnController.addPivotColumns(this.columnsToPivot, "toolPanelDragAndDrop"); + if (e.key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_0__["KeyCode"].ENTER) { + var column = this.columnGroup; + var newExpandedValue = !column.isExpanded(); + this.columnModel.setColumnGroupOpened(column.getProvidedColumnGroup(), newExpandedValue, "uiColumnExpanded"); + } + }; + // unlike columns, this will only get called once, as we don't react on props on column groups + // (we will always destroy and recreate this comp if something changes) + HeaderGroupCellCtrl.prototype.setDragSource = function (eHeaderGroup) { + var _this = this; + if (this.isSuppressMoving()) { + return; } + var allLeafColumns = this.columnGroup.getProvidedColumnGroup().getLeafColumns(); + var dragSource = { + type: _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragSourceType"].HeaderCell, + eElement: eHeaderGroup, + defaultIconName: _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_HIDE, + dragItemName: this.displayName, + // we add in the original group leaf columns, so we move both visible and non-visible items + getDragItem: this.getDragItemForGroup.bind(this), + onDragStarted: function () { return allLeafColumns.forEach(function (col) { return col.setMoving(true, "uiColumnDragged"); }); }, + onDragStopped: function () { return allLeafColumns.forEach(function (col) { return col.setMoving(false, "uiColumnDragged"); }); } + }; + this.dragAndDropService.addDragSource(dragSource, true); + this.addDestroyFunc(function () { return _this.dragAndDropService.removeDragSource(dragSource); }); + }; + // when moving the columns, we want to move all the columns (contained within the DragItem) in this group in one go, + // and in the order they are currently in the screen. + HeaderGroupCellCtrl.prototype.getDragItemForGroup = function () { + var allColumnsOriginalOrder = this.columnGroup.getProvidedColumnGroup().getLeafColumns(); + // capture visible state, used when re-entering grid to dictate which columns should be visible + var visibleState = {}; + allColumnsOriginalOrder.forEach(function (column) { return visibleState[column.getId()] = column.isVisible(); }); + var allColumnsCurrentOrder = []; + this.columnModel.getAllDisplayedColumns().forEach(function (column) { + if (allColumnsOriginalOrder.indexOf(column) >= 0) { + allColumnsCurrentOrder.push(column); + Object(_utils_array__WEBPACK_IMPORTED_MODULE_6__["removeFromArray"])(allColumnsOriginalOrder, column); + } + }); + // we are left with non-visible columns, stick these in at the end + allColumnsOriginalOrder.forEach(function (column) { return allColumnsCurrentOrder.push(column); }); + // create and return dragItem + return { + columns: allColumnsCurrentOrder, + visibleState: visibleState + }; + }; + HeaderGroupCellCtrl.prototype.isSuppressMoving = function () { + // if any child is fixed, then don't allow moving + var childSuppressesMoving = false; + this.columnGroup.getLeafColumns().forEach(function (column) { + if (column.getColDef().suppressMovable || column.getColDef().lockPosition) { + childSuppressesMoving = true; + } + }); + var result = childSuppressesMoving || this.gridOptionsWrapper.isSuppressMovableColumns(); + return result; }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController') - ], BodyDropPivotTarget.prototype, "columnController", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('beans') + ], HeaderGroupCellCtrl.prototype, "beans", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], BodyDropPivotTarget.prototype, "gridOptionsWrapper", void 0); - return BodyDropPivotTarget; -}()); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnModel') + ], HeaderGroupCellCtrl.prototype, "columnModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('dragAndDropService') + ], HeaderGroupCellCtrl.prototype, "dragAndDropService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('userComponentFactory') + ], HeaderGroupCellCtrl.prototype, "userComponentFactory", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridApi') + ], HeaderGroupCellCtrl.prototype, "gridApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnApi') + ], HeaderGroupCellCtrl.prototype, "columnApi", void 0); + return HeaderGroupCellCtrl; +}(_abstractCell_abstractHeaderCellCtrl__WEBPACK_IMPORTED_MODULE_9__["AbstractHeaderCellCtrl"])); /***/ }), -/* 124 */ +/* 160 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderNavigationDirection", function() { return HeaderNavigationDirection; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderNavigationService", function() { return HeaderNavigationService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); -/* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(34); -/* harmony import */ var _headerRowComp__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(110); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GroupResizeFeature", function() { return GroupResizeFeature; }); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(15); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -28606,198 +35678,269 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta - - -var HeaderNavigationDirection; -(function (HeaderNavigationDirection) { - HeaderNavigationDirection[HeaderNavigationDirection["UP"] = 0] = "UP"; - HeaderNavigationDirection[HeaderNavigationDirection["DOWN"] = 1] = "DOWN"; - HeaderNavigationDirection[HeaderNavigationDirection["LEFT"] = 2] = "LEFT"; - HeaderNavigationDirection[HeaderNavigationDirection["RIGHT"] = 3] = "RIGHT"; -})(HeaderNavigationDirection || (HeaderNavigationDirection = {})); -var HeaderNavigationService = /** @class */ (function (_super) { - __extends(HeaderNavigationService, _super); - function HeaderNavigationService() { - return _super !== null && _super.apply(this, arguments) || this; +var GroupResizeFeature = /** @class */ (function (_super) { + __extends(GroupResizeFeature, _super); + function GroupResizeFeature(comp, eResize, pinned, columnGroup) { + var _this = _super.call(this) || this; + _this.eResize = eResize; + _this.comp = comp; + _this.pinned = pinned; + _this.columnGroup = columnGroup; + return _this; } - HeaderNavigationService.prototype.registerGridComp = function (gridPanel) { - this.gridPanel = gridPanel; - }; - HeaderNavigationService.prototype.registerHeaderRoot = function (headerRoot) { - this.headerRoot = headerRoot; - }; - HeaderNavigationService.prototype.getHeaderRowCount = function () { - var headerContainers = this.headerRoot.getHeaderContainers(); - return headerContainers.size === 0 ? 0 : this.getHeaderContainer().getRowComps().length; - }; - HeaderNavigationService.prototype.getHeaderRowType = function (idx) { - if (this.getHeaderRowCount()) { - return this.getHeaderContainer().getRowComps()[idx].getType(); + GroupResizeFeature.prototype.postConstruct = function () { + var _this = this; + if (!this.columnGroup.isResizable()) { + this.comp.addOrRemoveResizableCssClass('ag-hidden', true); + return; } - }; - HeaderNavigationService.prototype.getHeaderContainer = function (position) { - if (position === void 0) { position = 'center'; } - if (position === null) { - position = 'center'; + var finishedWithResizeFunc = this.horizontalResizeService.addResizeBar({ + eResizeBar: this.eResize, + onResizeStart: this.onResizeStart.bind(this), + onResizing: this.onResizing.bind(this, false), + onResizeEnd: this.onResizing.bind(this, true) + }); + this.addDestroyFunc(finishedWithResizeFunc); + if (!this.gridOptionsWrapper.isSuppressAutoSize()) { + var skipHeaderOnAutoSize_1 = this.gridOptionsWrapper.isSkipHeaderOnAutoSize(); + this.eResize.addEventListener('dblclick', function () { + // get list of all the column keys we are responsible for + var keys = []; + var leafCols = _this.columnGroup.getDisplayedLeafColumns(); + leafCols.forEach(function (column) { + // not all cols in the group may be participating with auto-resize + if (!column.getColDef().suppressAutoSize) { + keys.push(column.getColId()); + } + }); + if (keys.length > 0) { + _this.columnModel.autoSizeColumns({ + columns: keys, + skipHeader: skipHeaderOnAutoSize_1, + stopAtGroup: _this.columnGroup, + source: 'uiColumnResized' + }); + } + _this.resizeLeafColumnsToFit(); + }); } - return this.headerRoot.getHeaderContainers().get(position); }; - /* - * This method navigates grid header vertically - * @return {boolean} true to preventDefault on the event that caused this navigation. - */ - HeaderNavigationService.prototype.navigateVertically = function (direction, fromHeader) { - if (!fromHeader) { - fromHeader = this.focusController.getFocusedHeader(); - } - if (!fromHeader) { - return false; - } - var headerRowIndex = fromHeader.headerRowIndex, column = fromHeader.column; - var rowLen = this.getHeaderRowCount(); - var isUp = direction === HeaderNavigationDirection.UP; - var nextRow = isUp ? headerRowIndex - 1 : headerRowIndex + 1; - if (nextRow < 0) { - return false; - } - if (nextRow >= rowLen) { - // focusGridView returns false when the grid has no cells rendered. - return this.focusController.focusGridView(); - } - var currentRowType = this.getHeaderRowType(headerRowIndex); - var nextFocusColumn; - if (currentRowType === _headerRowComp__WEBPACK_IMPORTED_MODULE_3__["HeaderRowType"].COLUMN_GROUP) { - var currentColumn = column; - nextFocusColumn = isUp ? column.getParent() : currentColumn.getDisplayedChildren()[0]; + GroupResizeFeature.prototype.onResizeStart = function (shiftKey) { + var _this = this; + this.calculateInitialValues(); + var takeFromGroup = null; + if (shiftKey) { + takeFromGroup = this.columnModel.getDisplayedGroupAfter(this.columnGroup); } - else if (currentRowType === _headerRowComp__WEBPACK_IMPORTED_MODULE_3__["HeaderRowType"].FLOATING_FILTER) { - nextFocusColumn = column; + if (takeFromGroup) { + var takeFromLeafCols = takeFromGroup.getDisplayedLeafColumns(); + this.resizeTakeFromCols = takeFromLeafCols.filter(function (col) { return col.isResizable(); }); + this.resizeTakeFromStartWidth = 0; + this.resizeTakeFromCols.forEach(function (col) { return _this.resizeTakeFromStartWidth += col.getActualWidth(); }); + this.resizeTakeFromRatios = []; + this.resizeTakeFromCols.forEach(function (col) { return _this.resizeTakeFromRatios.push(col.getActualWidth() / _this.resizeTakeFromStartWidth); }); } else { - var currentColumn = column; - nextFocusColumn = isUp ? currentColumn.getParent() : currentColumn; - } - if (!nextFocusColumn) { - return false; + this.resizeTakeFromCols = null; + this.resizeTakeFromStartWidth = null; + this.resizeTakeFromRatios = null; } - this.focusController.focusHeaderPosition({ - headerRowIndex: nextRow, - column: nextFocusColumn - }); - return true; + this.comp.addOrRemoveCssClass('ag-column-resizing', true); }; - /* - * This method navigates grid header horizontally - * @return {boolean} true to preventDefault on the event that caused this navigation. - */ - HeaderNavigationService.prototype.navigateHorizontally = function (direction, fromTab) { - var focusedHeader = this.focusController.getFocusedHeader(); - var isLeft = direction === HeaderNavigationDirection.LEFT; - var isRtl = this.gridOptionsWrapper.isEnableRtl(); - var nextHeader; - var normalisedDirection; - // either navigating to the left or isRtl (cannot be both) - if (isLeft !== isRtl) { - normalisedDirection = 'Before'; - nextHeader = this.headerPositionUtils.findHeader(focusedHeader, normalisedDirection); - } - else { - normalisedDirection = 'After'; - nextHeader = this.headerPositionUtils.findHeader(focusedHeader, normalisedDirection); + GroupResizeFeature.prototype.onResizing = function (finished, resizeAmount) { + var resizeAmountNormalised = this.normaliseDragChange(resizeAmount); + var width = this.resizeStartWidth + resizeAmountNormalised; + this.resizeColumns(width, finished); + }; + GroupResizeFeature.prototype.resizeLeafColumnsToFit = function () { + var preferredSize = this.autoWidthCalculator.getPreferredWidthForColumnGroup(this.columnGroup); + this.calculateInitialValues(); + if (preferredSize > this.resizeStartWidth) { + this.resizeColumns(preferredSize, true); } - if (nextHeader) { - this.focusController.focusHeaderPosition(nextHeader, normalisedDirection); - return true; + }; + GroupResizeFeature.prototype.resizeColumns = function (totalWidth, finished) { + if (finished === void 0) { finished = true; } + var resizeSets = []; + resizeSets.push({ + columns: this.resizeCols, + ratios: this.resizeRatios, + width: totalWidth + }); + if (this.resizeTakeFromCols) { + var diff = totalWidth - this.resizeStartWidth; + resizeSets.push({ + columns: this.resizeTakeFromCols, + ratios: this.resizeTakeFromRatios, + width: this.resizeTakeFromStartWidth - diff + }); } - if (!fromTab) { - return true; + this.columnModel.resizeColumnSets({ + resizeSets: resizeSets, + finished: finished, + source: 'uiColumnDragged' + }); + if (finished) { + this.comp.addOrRemoveCssClass('ag-column-resizing', false); } - return this.focusNextHeaderRow(focusedHeader, normalisedDirection); }; - HeaderNavigationService.prototype.focusNextHeaderRow = function (focusedHeader, direction) { - var currentIndex = focusedHeader.headerRowIndex; - var nextPosition; - var nextRowIndex; - if (direction === 'Before') { - if (currentIndex === 0) { - return false; + GroupResizeFeature.prototype.calculateInitialValues = function () { + var _this = this; + var leafCols = this.columnGroup.getDisplayedLeafColumns(); + this.resizeCols = leafCols.filter(function (col) { return col.isResizable(); }); + this.resizeStartWidth = 0; + this.resizeCols.forEach(function (col) { return _this.resizeStartWidth += col.getActualWidth(); }); + this.resizeRatios = []; + this.resizeCols.forEach(function (col) { return _this.resizeRatios.push(col.getActualWidth() / _this.resizeStartWidth); }); + }; + // optionally inverts the drag, depending on pinned and RTL + // note - this method is duplicated in RenderedHeaderCell - should refactor out? + GroupResizeFeature.prototype.normaliseDragChange = function (dragChange) { + var result = dragChange; + if (this.gridOptionsWrapper.isEnableRtl()) { + // for RTL, dragging left makes the col bigger, except when pinning left + if (this.pinned !== _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_LEFT) { + result *= -1; } - nextRowIndex = currentIndex - 1; - nextPosition = this.headerPositionUtils.findColAtEdgeForHeaderRow(nextRowIndex, 'end'); - } - else { - nextRowIndex = currentIndex + 1; - nextPosition = this.headerPositionUtils.findColAtEdgeForHeaderRow(nextRowIndex, 'start'); } - if (nextPosition) { - if (nextPosition.headerRowIndex === -1) { - return this.focusController.focusGridView(nextPosition.column); - } - return this.focusController.focusHeaderPosition(nextPosition, direction); + else if (this.pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_RIGHT) { + // for LTR (ie normal), dragging left makes the col smaller, except when pinning right + result *= -1; } - return false; + return result; }; - HeaderNavigationService.prototype.scrollToColumn = function (column, direction) { - if (direction === void 0) { direction = 'After'; } - if (column.getPinned()) { - return; - } - var columnToScrollTo; - if (column instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_2__["ColumnGroup"]) { - var columns = column.getDisplayedLeafColumns(); - columnToScrollTo = direction === 'Before' ? _utils__WEBPACK_IMPORTED_MODULE_4__["_"].last(columns) : columns[0]; - } - else { - columnToScrollTo = column; - } - this.gridPanel.ensureColumnVisible(columnToScrollTo); - // need to nudge the scrolls for the floating items. otherwise when we set focus on a non-visible - // floating cell, the scrolls get out of sync - this.gridPanel.horizontallyScrollHeaderCenterAndFloatingCenter(); - // need to flush frames, to make sure the correct cells are rendered - this.animationFrameService.flushAllFrames(); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('horizontalResizeService') + ], GroupResizeFeature.prototype, "horizontalResizeService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('autoWidthCalculator') + ], GroupResizeFeature.prototype, "autoWidthCalculator", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnModel') + ], GroupResizeFeature.prototype, "columnModel", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] + ], GroupResizeFeature.prototype, "postConstruct", null); + return GroupResizeFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + + + +/***/ }), +/* 161 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GroupWidthFeature", function() { return GroupWidthFeature; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(10); +/* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(9); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + +var GroupWidthFeature = /** @class */ (function (_super) { + __extends(GroupWidthFeature, _super); + function GroupWidthFeature(comp, columnGroup) { + var _this = _super.call(this) || this; + // the children can change, we keep destroy functions related to listening to the children here + _this.removeChildListenersFuncs = []; + _this.columnGroup = columnGroup; + _this.comp = comp; + return _this; + } + GroupWidthFeature.prototype.postConstruct = function () { + // we need to listen to changes in child columns, as they impact our width + this.addListenersToChildrenColumns(); + // the children belonging to this group can change, so we need to add and remove listeners as they change + this.addManagedListener(this.columnGroup, _entities_columnGroup__WEBPACK_IMPORTED_MODULE_3__["ColumnGroup"].EVENT_DISPLAYED_CHILDREN_CHANGED, this.onDisplayedChildrenChanged.bind(this)); + this.onWidthChanged(); + // the child listeners are not tied to this components life-cycle, as children can get added and removed + // to the group - hence they are on a different life-cycle. so we must make sure the existing children + // listeners are removed when we finally get destroyed + this.addDestroyFunc(this.removeListenersOnChildrenColumns.bind(this)); + }; + GroupWidthFeature.prototype.addListenersToChildrenColumns = function () { + var _this = this; + // first destroy any old listeners + this.removeListenersOnChildrenColumns(); + // now add new listeners to the new set of children + var widthChangedListener = this.onWidthChanged.bind(this); + this.columnGroup.getLeafColumns().forEach(function (column) { + column.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_WIDTH_CHANGED, widthChangedListener); + column.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_VISIBLE_CHANGED, widthChangedListener); + _this.removeChildListenersFuncs.push(function () { + column.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_WIDTH_CHANGED, widthChangedListener); + column.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_VISIBLE_CHANGED, widthChangedListener); + }); + }); + }; + GroupWidthFeature.prototype.removeListenersOnChildrenColumns = function () { + this.removeChildListenersFuncs.forEach(function (func) { return func(); }); + this.removeChildListenersFuncs = []; + }; + GroupWidthFeature.prototype.onDisplayedChildrenChanged = function () { + this.addListenersToChildrenColumns(); + this.onWidthChanged(); + }; + GroupWidthFeature.prototype.onWidthChanged = function () { + this.comp.setWidth(this.columnGroup.getActualWidth() + 'px'); }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], HeaderNavigationService.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusController') - ], HeaderNavigationService.prototype, "focusController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('headerPositionUtils') - ], HeaderNavigationService.prototype, "headerPositionUtils", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('animationFrameService') - ], HeaderNavigationService.prototype, "animationFrameService", void 0); - HeaderNavigationService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('headerNavigationService') - ], HeaderNavigationService); - return HeaderNavigationService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], GroupWidthFeature.prototype, "postConstruct", null); + return GroupWidthFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 125 */ +/* 162 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FilterManager", function() { return FilterManager; }); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43); -/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(38); -/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(39); -/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(17); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(41); -/* harmony import */ var _utils_set__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(29); -/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(14); -/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(16); -/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(12); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(23); +/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(16); +/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(17); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(20); +/* harmony import */ var _utils_set__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(52); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(7); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(13); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(42); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -28814,6 +35957,17 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); +var __assign = (undefined && undefined.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); @@ -28830,12 +35984,12 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta - var FilterManager = /** @class */ (function (_super) { __extends(FilterManager, _super); function FilterManager() { var _this = _super !== null && _super.apply(this, arguments) || this; - _this.allFilters = new Map(); + _this.allAdvancedFilters = new Map(); + _this.activeAdvancedFilters = []; _this.quickFilter = null; _this.quickFilterParts = null; // this is true when the grid is processing the filter change. this is used by the cell comps, so that they @@ -28848,13 +36002,12 @@ var FilterManager = /** @class */ (function (_super) { } FilterManager_1 = FilterManager; FilterManager.prototype.init = function () { - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DATA_CHANGED, this.onNewRowsLoaded.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_NEW_COLUMNS_LOADED, this.onNewColumnsLoaded.bind(this)); + var _this = this; + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DATA_CHANGED, function (source) { return _this.onNewRowsLoaded(source); }); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_GRID_COLUMNS_CHANGED, function () { return _this.onColumnsChanged(); }); this.quickFilter = this.parseQuickFilter(this.gridOptionsWrapper.getQuickFilterText()); this.setQuickFilterParts(); this.allowShowChangeAfterFilter = this.gridOptionsWrapper.isAllowShowChangeAfterFilter(); - // check this here, in case there is a filter from the start - this.checkExternalFilter(); }; FilterManager.prototype.setQuickFilterParts = function () { this.quickFilterParts = this.quickFilter ? this.quickFilter.split(' ') : null; @@ -28862,64 +36015,80 @@ var FilterManager = /** @class */ (function (_super) { FilterManager.prototype.setFilterModel = function (model) { var _this = this; var allPromises = []; + var previousModel = this.getFilterModel(); if (model) { // mark the filters as we set them, so any active filters left over we stop - var modelKeys_1 = Object(_utils_set__WEBPACK_IMPORTED_MODULE_7__["convertToSet"])(Object.keys(model)); - this.allFilters.forEach(function (filterWrapper, colId) { + var modelKeys_1 = Object(_utils_set__WEBPACK_IMPORTED_MODULE_6__["convertToSet"])(Object.keys(model)); + this.allAdvancedFilters.forEach(function (filterWrapper, colId) { var newModel = model[colId]; allPromises.push(_this.setModelOnFilterWrapper(filterWrapper.filterPromise, newModel)); modelKeys_1.delete(colId); }); // at this point, processedFields contains data for which we don't have a filter working yet modelKeys_1.forEach(function (colId) { - var column = _this.columnController.getPrimaryColumn(colId); + var column = _this.columnModel.getPrimaryColumn(colId); if (!column) { - console.warn('Warning ag-grid setFilterModel - no column found for colId ' + colId); + console.warn('AG Grid: setFilterModel() - no column found for colId: ' + colId); + return; + } + if (!column.isFilterAllowed()) { + console.warn('AG Grid: setFilterModel() - unable to fully apply model, filtering disabled for colId: ' + colId); return; } var filterWrapper = _this.getOrCreateFilterWrapper(column, 'NO_UI'); + if (!filterWrapper) { + console.warn('AG-Grid: setFilterModel() - unable to fully apply model, unable to create filter for colId: ' + colId); + return; + } allPromises.push(_this.setModelOnFilterWrapper(filterWrapper.filterPromise, model[colId])); }); } else { - this.allFilters.forEach(function (filterWrapper) { + this.allAdvancedFilters.forEach(function (filterWrapper) { allPromises.push(_this.setModelOnFilterWrapper(filterWrapper.filterPromise, null)); }); } - _utils__WEBPACK_IMPORTED_MODULE_0__["Promise"].all(allPromises).then(function () { return _this.onFilterChanged(); }); + _utils__WEBPACK_IMPORTED_MODULE_0__["AgPromise"].all(allPromises).then(function () { + var currentModel = _this.getFilterModel(); + var columns = []; + _this.allAdvancedFilters.forEach(function (filterWrapper, colId) { + var before = previousModel ? previousModel[colId] : null; + var after = currentModel ? currentModel[colId] : null; + if (!_utils__WEBPACK_IMPORTED_MODULE_0__["_"].jsonEquals(before, after)) { + columns.push(filterWrapper.column); + } + }); + if (columns.length > 0) { + _this.onFilterChanged({ columns: columns }); + } + }); }; FilterManager.prototype.setModelOnFilterWrapper = function (filterPromise, newModel) { - return new _utils__WEBPACK_IMPORTED_MODULE_0__["Promise"](function (resolve) { + return new _utils__WEBPACK_IMPORTED_MODULE_0__["AgPromise"](function (resolve) { filterPromise.then(function (filter) { if (typeof filter.setModel !== 'function') { - console.warn('Warning ag-grid - filter missing setModel method, which is needed for setFilterModel'); + console.warn('AG Grid: filter missing setModel method, which is needed for setFilterModel'); resolve(); } - var promise = filter.setModel(newModel); - if (promise == null) { - resolve(); - } - else { - promise.then(function () { return resolve(); }); - } + (filter.setModel(newModel) || _utils__WEBPACK_IMPORTED_MODULE_0__["AgPromise"].resolve()).then(function () { return resolve(); }); }); }); }; FilterManager.prototype.getFilterModel = function () { var result = {}; - this.allFilters.forEach(function (filterWrapper, key) { + this.allAdvancedFilters.forEach(function (filterWrapper, key) { // because user can provide filters, we provide useful error checking and messages var filterPromise = filterWrapper.filterPromise; - var filter = filterPromise.resolveNow(null, function (filter) { return filter; }); + var filter = filterPromise.resolveNow(null, function (promiseFilter) { return promiseFilter; }); if (filter == null) { return null; } if (typeof filter.getModel !== 'function') { - console.warn('Warning ag-grid - filter API missing getModel method, which is needed for getFilterModel'); + console.warn('AG Grid: filter API missing getModel method, which is needed for getFilterModel'); return; } var model = filter.getModel(); - if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_8__["exists"])(model)) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_7__["exists"])(model)) { result[key] = model; } }); @@ -28927,67 +36096,72 @@ var FilterManager = /** @class */ (function (_super) { }; // returns true if any advanced filter (ie not quick filter) active FilterManager.prototype.isAdvancedFilterPresent = function () { - return this.advancedFilterPresent; + return this.activeAdvancedFilters.length > 0; }; // called by: // 1) onFilterChanged() // 2) onNewRowsLoaded() - FilterManager.prototype.setAdvancedFilterPresent = function () { - var atLeastOneActive = false; - this.allFilters.forEach(function (filterWrapper) { - if (atLeastOneActive) { - return; - } // no need to check any more - if (filterWrapper.filterPromise.resolveNow(false, function (filter) { return filter.isFilterActive(); })) { - atLeastOneActive = true; + FilterManager.prototype.updateActiveFilters = function () { + var _this = this; + this.activeAdvancedFilters.length = 0; + var isFilterActive = function (filter) { + if (!filter) { + return false; + } // this never happens, including to avoid compile error + if (!filter.isFilterActive) { + console.warn('AG Grid: Filter is missing isFilterActive() method'); + return false; + } + return filter.isFilterActive(); + }; + this.allAdvancedFilters.forEach(function (filterWrapper) { + if (filterWrapper.filterPromise.resolveNow(false, isFilterActive)) { + var resolvedPromise = filterWrapper.filterPromise.resolveNow(null, function (filter) { return filter; }); + _this.activeAdvancedFilters.push(resolvedPromise); } }); - this.advancedFilterPresent = atLeastOneActive; }; FilterManager.prototype.updateFilterFlagInColumns = function (source, additionalEventAttributes) { - this.allFilters.forEach(function (filterWrapper) { + this.allAdvancedFilters.forEach(function (filterWrapper) { var isFilterActive = filterWrapper.filterPromise.resolveNow(false, function (filter) { return filter.isFilterActive(); }); filterWrapper.column.setFilterActive(isFilterActive, source, additionalEventAttributes); }); }; - // returns true if quickFilter or advancedFilter FilterManager.prototype.isAnyFilterPresent = function () { - return this.isQuickFilterPresent() || this.advancedFilterPresent || this.externalFilterPresent; + return this.isQuickFilterPresent() || this.isAdvancedFilterPresent() || this.gridOptionsWrapper.isExternalFilterPresent(); }; - FilterManager.prototype.doesFilterPass = function (node, filterToSkip) { + FilterManager.prototype.doAdvancedFiltersPass = function (node, filterToSkip) { var data = node.data; - var filterPasses = true; - this.allFilters.forEach(function (filterWrapper) { - // if a filter has already failed, no need to run any more - if (!filterPasses) { - return; - } - // if no filter, always pass - if (filterWrapper == null) { - return; - } - var filter = filterWrapper.filterPromise.resolveNow(undefined, function (filter) { return filter; }); - if (filter == null || filter === filterToSkip || !filter.isFilterActive()) { - return; + for (var i = 0; i < this.activeAdvancedFilters.length; i++) { + var filter = this.activeAdvancedFilters[i]; + if (filter == null || filter === filterToSkip) { + continue; } - if (!filter.doesFilterPass) { // because users can do custom filters, give nice error message + if (typeof filter.doesFilterPass !== 'function') { + // because users can do custom filters, give nice error message throw new Error('Filter is missing method doesFilterPass'); } - filterPasses = filter.doesFilterPass({ node: node, data: data }); - }); - return filterPasses; + if (!filter.doesFilterPass({ node: node, data: data })) { + return false; + } + } + return true; }; FilterManager.prototype.parseQuickFilter = function (newFilter) { - if (!Object(_utils_generic__WEBPACK_IMPORTED_MODULE_8__["exists"])(newFilter)) { + if (!Object(_utils_generic__WEBPACK_IMPORTED_MODULE_7__["exists"])(newFilter)) { return null; } if (!this.gridOptionsWrapper.isRowModelDefault()) { - console.warn('ag-grid: quick filtering only works with the Client-Side Row Model'); + console.warn('AG Grid - Quick filtering only works with the Client-Side Row Model'); return null; } return newFilter.toUpperCase(); }; FilterManager.prototype.setQuickFilter = function (newFilter) { + if (newFilter != null && typeof newFilter !== 'string') { + console.warn("AG Grid - setQuickFilter() only supports string inputs, received: " + typeof newFilter); + return; + } var parsedFilter = this.parseQuickFilter(newFilter); if (this.quickFilter !== parsedFilter) { this.quickFilter = parsedFilter; @@ -28995,16 +36169,17 @@ var FilterManager = /** @class */ (function (_super) { this.onFilterChanged(); } }; - FilterManager.prototype.checkExternalFilter = function () { - this.externalFilterPresent = this.gridOptionsWrapper.isExternalFilterPresent(); - }; - FilterManager.prototype.onFilterChanged = function (filterInstance, additionalEventAttributes) { - this.setAdvancedFilterPresent(); + FilterManager.prototype.onFilterChanged = function (params) { + if (params === void 0) { params = {}; } + var filterInstance = params.filterInstance, additionalEventAttributes = params.additionalEventAttributes, columns = params.columns; + this.updateActiveFilters(); this.updateFilterFlagInColumns('filterChanged', additionalEventAttributes); - this.checkExternalFilter(); - this.allFilters.forEach(function (filterWrapper) { + this.allAdvancedFilters.forEach(function (filterWrapper) { + if (!filterWrapper.filterPromise) { + return; + } filterWrapper.filterPromise.then(function (filter) { - if (filter !== filterInstance && filter.onAnyFilterChanged) { + if (filter && filter !== filterInstance && filter.onAnyFilterChanged) { filter.onAnyFilterChanged(); } }); @@ -29012,10 +36187,11 @@ var FilterManager = /** @class */ (function (_super) { var filterChangedEvent = { type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_FILTER_CHANGED, api: this.gridApi, - columnApi: this.columnApi + columnApi: this.columnApi, + columns: columns || [], }; if (additionalEventAttributes) { - Object(_utils_object__WEBPACK_IMPORTED_MODULE_9__["mergeDeep"])(filterChangedEvent, additionalEventAttributes); + Object(_utils_object__WEBPACK_IMPORTED_MODULE_8__["mergeDeep"])(filterChangedEvent, additionalEventAttributes); } // because internal events are not async in ag-grid, when the dispatchEvent // method comes back, we know all listeners have finished executing. @@ -29032,14 +36208,14 @@ var FilterManager = /** @class */ (function (_super) { return this.quickFilter !== null; }; FilterManager.prototype.doesRowPassOtherFilters = function (filterToSkip, node) { - return this.doesRowPassFilter(node, filterToSkip); + return this.doesRowPassFilter({ rowNode: node, filterInstanceToSkip: filterToSkip }); }; FilterManager.prototype.doesRowPassQuickFilterNoCache = function (node, filterPart) { var _this = this; - var columns = this.columnController.getAllColumnsForQuickFilter(); - return Object(_utils_array__WEBPACK_IMPORTED_MODULE_5__["some"])(columns, function (column) { + var columns = this.columnModel.getAllColumnsForQuickFilter(); + return columns.some(function (column) { var part = _this.getQuickFilterTextForColumn(column, node); - return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_8__["exists"])(part) && part.indexOf(filterPart) >= 0; + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_7__["exists"])(part) && part.indexOf(filterPart) >= 0; }); }; FilterManager.prototype.doesRowPassQuickFilterCache = function (node, filterPart) { @@ -29052,24 +36228,24 @@ var FilterManager = /** @class */ (function (_super) { var _this = this; var usingCache = this.gridOptionsWrapper.isCacheQuickFilter(); // each part must pass, if any fails, then the whole filter fails - return Object(_utils_array__WEBPACK_IMPORTED_MODULE_5__["every"])(this.quickFilterParts, function (part) { + return this.quickFilterParts.every(function (part) { return usingCache ? _this.doesRowPassQuickFilterCache(node, part) : _this.doesRowPassQuickFilterNoCache(node, part); }); }; - FilterManager.prototype.doesRowPassFilter = function (node, filterToSkip) { + FilterManager.prototype.doesRowPassFilter = function (params) { // the row must pass ALL of the filters, so if any of them fail, // we return true. that means if a row passes the quick filter, // but fails the column filter, it fails overall // first up, check quick filter - if (this.isQuickFilterPresent() && !this.doesRowPassQuickFilter(node)) { + if (this.isQuickFilterPresent() && !this.doesRowPassQuickFilter(params.rowNode)) { return false; } // secondly, give the client a chance to reject this row - if (this.externalFilterPresent && !this.gridOptionsWrapper.doesExternalFilterPass(node)) { + if (this.gridOptionsWrapper.isExternalFilterPresent() && !this.gridOptionsWrapper.doesExternalFilterPass(params.rowNode)) { return false; } // lastly, check our internal advanced filter - if (this.advancedFilterPresent && !this.doesFilterPass(node, filterToSkip)) { + if (this.isAdvancedFilterPresent() && !this.doAdvancedFiltersPass(params.rowNode, params.filterInstanceToSkip)) { return false; } // got this far, all filters pass @@ -29089,22 +36265,22 @@ var FilterManager = /** @class */ (function (_super) { }; value = colDef.getQuickFilterText(params); } - return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_8__["exists"])(value) ? value.toString().toUpperCase() : null; + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_7__["exists"])(value) ? value.toString().toUpperCase() : null; }; FilterManager.prototype.aggregateRowForQuickFilter = function (node) { var _this = this; var stringParts = []; - var columns = this.columnController.getAllColumnsForQuickFilter(); - Object(_utils_array__WEBPACK_IMPORTED_MODULE_5__["forEach"])(columns, function (column) { + var columns = this.columnModel.getAllColumnsForQuickFilter(); + columns.forEach(function (column) { var part = _this.getQuickFilterTextForColumn(column, node); - if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_8__["exists"])(part)) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_7__["exists"])(part)) { stringParts.push(part); } }); node.quickFilterAggregateText = stringParts.join(FilterManager_1.QUICK_FILTER_SEPARATOR); }; FilterManager.prototype.onNewRowsLoaded = function (source) { - this.allFilters.forEach(function (filterWrapper) { + this.allAdvancedFilters.forEach(function (filterWrapper) { filterWrapper.filterPromise.then(function (filter) { if (filter.onNewRowsLoaded) { filter.onNewRowsLoaded(); @@ -29112,24 +36288,36 @@ var FilterManager = /** @class */ (function (_super) { }); }); this.updateFilterFlagInColumns(source); - this.setAdvancedFilterPresent(); + this.updateActiveFilters(); }; FilterManager.prototype.createValueGetter = function (column) { var _this = this; - return function (node) { return _this.valueService.getValue(column, node, true); }; + return function (_a) { + var node = _a.node; + return _this.valueService.getValue(column, node, true); + }; }; - FilterManager.prototype.getFilterComponent = function (column, source) { - return this.getOrCreateFilterWrapper(column, source).filterPromise; + FilterManager.prototype.getFilterComponent = function (column, source, createIfDoesNotExist) { + if (createIfDoesNotExist === void 0) { createIfDoesNotExist = true; } + var _a; + if (createIfDoesNotExist) { + return ((_a = this.getOrCreateFilterWrapper(column, source)) === null || _a === void 0 ? void 0 : _a.filterPromise) || null; + } + var filterWrapper = this.cachedFilter(column); + return filterWrapper ? filterWrapper.filterPromise : null; }; FilterManager.prototype.isFilterActive = function (column) { var filterWrapper = this.cachedFilter(column); - return filterWrapper && filterWrapper.filterPromise.resolveNow(false, function (filter) { return filter.isFilterActive(); }); + return !!filterWrapper && filterWrapper.filterPromise.resolveNow(false, function (filter) { return filter.isFilterActive(); }); }; FilterManager.prototype.getOrCreateFilterWrapper = function (column, source) { + if (!column.isFilterAllowed()) { + return null; + } var filterWrapper = this.cachedFilter(column); if (!filterWrapper) { filterWrapper = this.createFilterWrapper(column, source); - this.allFilters.set(column.getColId(), filterWrapper); + this.allAdvancedFilters.set(column.getColId(), filterWrapper); } else if (source !== 'NO_UI') { this.putIntoGui(filterWrapper, source); @@ -29137,50 +36325,48 @@ var FilterManager = /** @class */ (function (_super) { return filterWrapper; }; FilterManager.prototype.cachedFilter = function (column) { - return this.allFilters.get(column.getColId()); + return this.allAdvancedFilters.get(column.getColId()); }; FilterManager.prototype.createFilterInstance = function (column, $scope) { var _this = this; var defaultFilter = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].SetFilterModule) ? 'agSetColumnFilter' : 'agTextColumnFilter'; - var sanitisedColDef = Object(_utils_object__WEBPACK_IMPORTED_MODULE_9__["cloneObject"])(column.getColDef()); + var colDef = column.getColDef(); var filterInstance; - var params = this.createFilterParams(column, sanitisedColDef, $scope); - params.filterModifiedCallback = function () { - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_FILTER_MODIFIED, - api: _this.gridApi, - columnApi: _this.columnApi, - column: column, - filterInstance: filterInstance - }; - _this.eventService.dispatchEvent(event); - }; - // we modify params in a callback as we need the filter instance, and this isn't available - // when creating the params above - var modifyParamsCallback = function (params, filterInstance) { return Object(_utils_object__WEBPACK_IMPORTED_MODULE_9__["assign"])(params, { - doesRowPassOtherFilter: function (node) { return _this.doesRowPassOtherFilters(filterInstance, node); }, - filterChangedCallback: function (additionalEventAttributes) { - return _this.onFilterChanged(filterInstance, additionalEventAttributes); - } - }); }; - var res = this.userComponentFactory.newFilterComponent(sanitisedColDef, params, defaultFilter, modifyParamsCallback); - if (res) { - res.then(function (r) { return filterInstance = r; }); + var params = __assign(__assign({}, this.createFilterParams(column, colDef, $scope)), { filterModifiedCallback: function () { + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_FILTER_MODIFIED, + api: _this.gridApi, + columnApi: _this.columnApi, + column: column, + filterInstance: filterInstance + }; + _this.eventService.dispatchEvent(event); + }, filterChangedCallback: function (additionalEventAttributes) { + return _this.onFilterChanged({ filterInstance: filterInstance, additionalEventAttributes: additionalEventAttributes, columns: [column] }); + }, doesRowPassOtherFilter: function (node) { return _this.doesRowPassOtherFilters(filterInstance, node); } }); + var compDetails = this.userComponentFactory.getFilterDetails(colDef, params, defaultFilter); + if (!compDetails) { + return null; } - return res; + var componentPromise = compDetails.newAgStackInstance(); + if (componentPromise) { + componentPromise.then(function (r) { return filterInstance = r; }); + } + return componentPromise; }; FilterManager.prototype.createFilterParams = function (column, colDef, $scope) { if ($scope === void 0) { $scope = null; } var params = { api: this.gridOptionsWrapper.getApi(), + columnApi: this.gridOptionsWrapper.getColumnApi(), column: column, - colDef: colDef, + colDef: Object(_utils_object__WEBPACK_IMPORTED_MODULE_8__["cloneObject"])(colDef), rowModel: this.rowModel, - filterChangedCallback: null, - filterModifiedCallback: null, + filterChangedCallback: function () { }, + filterModifiedCallback: function () { }, valueGetter: this.createValueGetter(column), context: this.gridOptionsWrapper.getContext(), - doesRowPassOtherFilter: null + doesRowPassOtherFilter: function () { return true; }, }; // hack in scope if using AngularJS if ($scope) { @@ -29194,7 +36380,7 @@ var FilterManager = /** @class */ (function (_super) { filterPromise: null, scope: null, compiledElement: null, - guiPromise: _utils__WEBPACK_IMPORTED_MODULE_0__["Promise"].resolve(null) + guiPromise: _utils__WEBPACK_IMPORTED_MODULE_0__["AgPromise"].resolve(null) }; filterWrapper.scope = this.gridOptionsWrapper.isAngularCompileFilters() ? this.$scope.$new() : null; filterWrapper.filterPromise = this.createFilterInstance(column, filterWrapper.scope); @@ -29207,18 +36393,18 @@ var FilterManager = /** @class */ (function (_super) { var _this = this; var eFilterGui = document.createElement('div'); eFilterGui.className = 'ag-filter'; - filterWrapper.guiPromise = new _utils__WEBPACK_IMPORTED_MODULE_0__["Promise"](function (resolve) { + filterWrapper.guiPromise = new _utils__WEBPACK_IMPORTED_MODULE_0__["AgPromise"](function (resolve) { filterWrapper.filterPromise.then(function (filter) { var guiFromFilter = filter.getGui(); - if (!Object(_utils_generic__WEBPACK_IMPORTED_MODULE_8__["exists"])(guiFromFilter)) { - console.warn("getGui method from filter returned " + guiFromFilter + ", it should be a DOM element or an HTML template string."); + if (!Object(_utils_generic__WEBPACK_IMPORTED_MODULE_7__["exists"])(guiFromFilter)) { + console.warn("AG Grid: getGui method from filter returned " + guiFromFilter + ", it should be a DOM element or an HTML template string."); } // for backwards compatibility with Angular 1 - we // used to allow providing back HTML from getGui(). // once we move away from supporting Angular 1 // directly, we can change this. if (typeof guiFromFilter === 'string') { - guiFromFilter = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_10__["loadTemplate"])(guiFromFilter); + guiFromFilter = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_9__["loadTemplate"])(guiFromFilter); } eFilterGui.appendChild(guiFromFilter); if (filterWrapper.scope) { @@ -29238,48 +36424,50 @@ var FilterManager = /** @class */ (function (_super) { }); }); }; - FilterManager.prototype.onNewColumnsLoaded = function () { + FilterManager.prototype.onColumnsChanged = function () { var _this = this; - var atLeastOneFilterGone = false; - this.allFilters.forEach(function (filterWrapper) { - var oldColumn = !_this.columnController.getPrimaryColumn(filterWrapper.column); - if (oldColumn) { - atLeastOneFilterGone = true; - _this.disposeFilterWrapper(filterWrapper, 'filterDestroyed'); + var columns = []; + this.allAdvancedFilters.forEach(function (wrapper, colId) { + var currentColumn = _this.columnModel.getPrimaryColumn(colId); + if (currentColumn) { + return; } + columns.push(wrapper.column); + _this.disposeFilterWrapper(wrapper, 'filterDestroyed'); }); - if (atLeastOneFilterGone) { - this.onFilterChanged(); + if (columns.length > 0) { + this.onFilterChanged({ columns: columns }); } }; // destroys the filter, so it not longer takes part FilterManager.prototype.destroyFilter = function (column, source) { if (source === void 0) { source = 'api'; } - var filterWrapper = this.allFilters.get(column.getColId()); + var filterWrapper = this.allAdvancedFilters.get(column.getColId()); if (filterWrapper) { this.disposeFilterWrapper(filterWrapper, source); - this.onFilterChanged(); + this.onFilterChanged({ columns: [column] }); } }; FilterManager.prototype.disposeFilterWrapper = function (filterWrapper, source) { var _this = this; filterWrapper.filterPromise.then(function (filter) { - filter.setModel(null); - _this.getContext().destroyBean(filter); - filterWrapper.column.setFilterActive(false, source); - if (filterWrapper.scope) { - if (filterWrapper.compiledElement) { - filterWrapper.compiledElement.remove(); + (filter.setModel(null) || _utils__WEBPACK_IMPORTED_MODULE_0__["AgPromise"].resolve()).then(function () { + _this.getContext().destroyBean(filter); + filterWrapper.column.setFilterActive(false, source); + if (filterWrapper.scope) { + if (filterWrapper.compiledElement) { + filterWrapper.compiledElement.remove(); + } + filterWrapper.scope.$destroy(); } - filterWrapper.scope.$destroy(); - } - _this.allFilters.delete(filterWrapper.column.getColId()); + _this.allAdvancedFilters.delete(filterWrapper.column.getColId()); + }); }); }; FilterManager.prototype.destroy = function () { var _this = this; _super.prototype.destroy.call(this); - this.allFilters.forEach(function (filterWrapper) { return _this.disposeFilterWrapper(filterWrapper, 'filterDestroyed'); }); + this.allAdvancedFilters.forEach(function (filterWrapper) { return _this.disposeFilterWrapper(filterWrapper, 'filterDestroyed'); }); }; var FilterManager_1; FilterManager.QUICK_FILTER_SEPARATOR = '\n'; @@ -29289,15 +36477,12 @@ var FilterManager = /** @class */ (function (_super) { __decorate([ Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('$scope') ], FilterManager.prototype, "$scope", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], FilterManager.prototype, "gridOptionsWrapper", void 0); __decorate([ Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('valueService') ], FilterManager.prototype, "valueService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController') - ], FilterManager.prototype, "columnController", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnModel') + ], FilterManager.prototype, "columnModel", void 0); __decorate([ Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowModel') ], FilterManager.prototype, "rowModel", void 0); @@ -29320,24 +36505,26 @@ var FilterManager = /** @class */ (function (_super) { Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('filterManager') ], FilterManager); return FilterManager; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_6__["BeanStub"])); +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_5__["BeanStub"])); /***/ }), -/* 126 */ +/* 163 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ValueService", function() { return ValueService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(23); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(20); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(13); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(14); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -29364,6 +36551,8 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta + + var ValueService = /** @class */ (function (_super) { __extends(ValueService, _super); function ValueService() { @@ -29405,7 +36594,7 @@ var ValueService = /** @class */ (function (_super) { result = this.executeValueGetter(colDef.valueGetter, data, column, rowNode); } else if (this.gridOptionsWrapper.isTreeData() && (field && data)) { - result = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].getValueUsingField(data, field, column.isFieldContainsDots()); + result = Object(_utils_object__WEBPACK_IMPORTED_MODULE_3__["getValueUsingField"])(data, field, column.isFieldContainsDots()); } else if (groupDataExists) { result = rowNode.groupData[colId]; @@ -29417,31 +36606,55 @@ var ValueService = /** @class */ (function (_super) { result = this.executeValueGetter(colDef.valueGetter, data, column, rowNode); } else if (field && data) { - result = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].getValueUsingField(data, field, column.isFieldContainsDots()); + result = Object(_utils_object__WEBPACK_IMPORTED_MODULE_3__["getValueUsingField"])(data, field, column.isFieldContainsDots()); } // the result could be an expression itself, if we are allowing cell values to be expressions if (this.cellExpressions && (typeof result === 'string') && result.indexOf('=') === 0) { var cellValueGetter = result.substring(1); result = this.executeValueGetter(cellValueGetter, data, column, rowNode); } + if (result == null) { + var openedGroup = this.getOpenedGroup(rowNode, column); + if (openedGroup != null) { + return openedGroup; + } + } return result; }; + ValueService.prototype.getOpenedGroup = function (rowNode, column) { + if (!this.gridOptionsWrapper.isShowOpenedGroup()) { + return; + } + var colDef = column.getColDef(); + if (!colDef.showRowGroup) { + return; + } + var showRowGroup = column.getColDef().showRowGroup; + var pointer = rowNode.parent; + while (pointer != null) { + if (pointer.rowGroupColumn && (showRowGroup === true || showRowGroup === pointer.rowGroupColumn.getId())) { + return pointer.key; + } + pointer = pointer.parent; + } + return undefined; + }; ValueService.prototype.setValue = function (rowNode, colKey, newValue, eventSource) { - var column = this.columnController.getPrimaryColumn(colKey); + var column = this.columnModel.getPrimaryColumn(colKey); if (!rowNode || !column) { return; } // this will only happen if user is trying to paste into a group row, which doesn't make sense // the user should not be trying to paste into group rows - if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].missing(rowNode.data)) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_4__["missing"])(rowNode.data)) { rowNode.data = {}; } // for backwards compatibility we are also retrieving the newValueHandler as well as the valueSetter var _a = column.getColDef(), field = _a.field, newValueHandler = _a.newValueHandler, valueSetter = _a.valueSetter; // need either a field or a newValueHandler for this to work - if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].missing(field) && _utils__WEBPACK_IMPORTED_MODULE_2__["_"].missing(newValueHandler) && _utils__WEBPACK_IMPORTED_MODULE_2__["_"].missing(valueSetter)) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_4__["missing"])(field) && Object(_utils_generic__WEBPACK_IMPORTED_MODULE_4__["missing"])(newValueHandler) && Object(_utils_generic__WEBPACK_IMPORTED_MODULE_4__["missing"])(valueSetter)) { // we don't tell user about newValueHandler, as that is deprecated - console.warn("ag-Grid: you need either field or valueSetter set on colDef for editing to work"); + console.warn("AG Grid: you need either field or valueSetter set on colDef for editing to work"); return; } var params = { @@ -29457,10 +36670,10 @@ var ValueService = /** @class */ (function (_super) { }; params.newValue = newValue; var valueWasDifferent; - if (newValueHandler && _utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(newValueHandler)) { + if (newValueHandler && Object(_utils_generic__WEBPACK_IMPORTED_MODULE_4__["exists"])(newValueHandler)) { valueWasDifferent = newValueHandler(params); } - else if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(valueSetter)) { + else if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_4__["exists"])(valueSetter)) { valueWasDifferent = this.expressionService.evaluate(valueSetter, params); } else { @@ -29494,8 +36707,8 @@ var ValueService = /** @class */ (function (_super) { rowPinned: rowNode.rowPinned, column: params.column, api: params.api, - colDef: params.colDef, columnApi: params.columnApi, + colDef: params.colDef, context: params.context, data: rowNode.data, node: rowNode, @@ -29567,7 +36780,7 @@ var ValueService = /** @class */ (function (_super) { return result; }; ValueService.prototype.getValueCallback = function (node, field) { - var otherColumn = this.columnController.getPrimaryColumn(field); + var otherColumn = this.columnModel.getPrimaryColumn(field); if (otherColumn) { return this.getValue(otherColumn, node); } @@ -29577,28 +36790,38 @@ var ValueService = /** @class */ (function (_super) { ValueService.prototype.getKeyForNode = function (col, rowNode) { var value = this.getValue(col, rowNode); var keyCreator = col.getColDef().keyCreator; - var result = keyCreator ? keyCreator({ value: value }) : value; + var result = value; + if (keyCreator) { + var keyParams = { + value: value, + colDef: col.getColDef(), + column: col, + node: rowNode, + data: rowNode.data, + api: this.gridOptionsWrapper.getApi(), + columnApi: this.gridOptionsWrapper.getColumnApi(), + context: this.gridOptionsWrapper.getContext() + }; + result = keyCreator(keyParams); + } // if already a string, or missing, just return it if (typeof result === 'string' || result == null) { return result; } result = String(result); if (result === '[object Object]') { - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].doOnce(function () { - console.warn('ag-Grid: a column you are grouping or pivoting by has objects as values. If you want to group by complex objects then either a) use a colDef.keyCreator (se ag-Grid docs) or b) to toString() on the object to return a key'); + Object(_utils_function__WEBPACK_IMPORTED_MODULE_5__["doOnce"])(function () { + console.warn('AG Grid: a column you are grouping or pivoting by has objects as values. If you want to group by complex objects then either a) use a colDef.keyCreator (se AG Grid docs) or b) to toString() on the object to return a key'); }, 'getKeyForNode - warn about [object,object]'); } return result; }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], ValueService.prototype, "gridOptionsWrapper", void 0); __decorate([ Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('expressionService') ], ValueService.prototype, "expressionService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], ValueService.prototype, "columnController", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], ValueService.prototype, "columnModel", void 0); __decorate([ Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueCache') ], ValueService.prototype, "valueCache", void 0); @@ -29609,33 +36832,27 @@ var ValueService = /** @class */ (function (_super) { Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('valueService') ], ValueService); return ValueService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"])); +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"])); /***/ }), -/* 127 */ +/* 164 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridPanel", function() { return GridPanel; }); -/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(50); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25); -/* harmony import */ var _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(128); -/* harmony import */ var _rendering_rowComp__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(100); -/* harmony import */ var _widgets_touchListener__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(65); -/* harmony import */ var _rowDragFeature__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(129); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(56); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(57); -/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(39); -/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(38); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridBodyComp", function() { return GridBodyComp; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _styling_layoutFeature__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(165); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(44); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(36); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(57); +/* harmony import */ var _gridBodyCtrl__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(166); +/* harmony import */ var _rowContainer_rowContainerCtrl__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(125); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -29665,725 +36882,459 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta +var GRID_BODY_TEMPLATE = /* html */ "
\n \n
\n \n \n \n \n
\n
\n \n \n \n \n
\n
\n \n \n \n \n
\n \n \n
"; +var GridBodyComp = /** @class */ (function (_super) { + __extends(GridBodyComp, _super); + function GridBodyComp() { + return _super.call(this, GRID_BODY_TEMPLATE) || this; + } + GridBodyComp.prototype.init = function () { + var _this = this; + var setHeight = function (height, element) { + var heightString = height + "px"; + element.style.minHeight = heightString; + element.style.height = heightString; + }; + var compProxy = { + setRowAnimationCssOnBodyViewport: function (cssClass, animate) { return _this.setRowAnimationCssOnBodyViewport(cssClass, animate); }, + setColumnCount: function (count) { return Object(_utils_aria__WEBPACK_IMPORTED_MODULE_2__["setAriaColCount"])(_this.getGui(), count); }, + setRowCount: function (count) { return Object(_utils_aria__WEBPACK_IMPORTED_MODULE_2__["setAriaRowCount"])(_this.getGui(), count); }, + setTopHeight: function (height) { return setHeight(height, _this.eTop); }, + setBottomHeight: function (height) { return setHeight(height, _this.eBottom); }, + setTopDisplay: function (display) { return _this.eTop.style.display = display; }, + setBottomDisplay: function (display) { return _this.eBottom.style.display = display; }, + setColumnMovingCss: function (cssClass, flag) { return _this.addOrRemoveCssClass(_gridBodyCtrl__WEBPACK_IMPORTED_MODULE_5__["CSS_CLASS_COLUMN_MOVING"], flag); }, + updateLayoutClasses: function (cssClass, params) { + var bodyViewportClassList = _this.eBodyViewport.classList; + bodyViewportClassList.toggle(_styling_layoutFeature__WEBPACK_IMPORTED_MODULE_1__["LayoutCssClasses"].AUTO_HEIGHT, params.autoHeight); + bodyViewportClassList.toggle(_styling_layoutFeature__WEBPACK_IMPORTED_MODULE_1__["LayoutCssClasses"].NORMAL, params.normal); + bodyViewportClassList.toggle(_styling_layoutFeature__WEBPACK_IMPORTED_MODULE_1__["LayoutCssClasses"].PRINT, params.print); + _this.addOrRemoveCssClass(_styling_layoutFeature__WEBPACK_IMPORTED_MODULE_1__["LayoutCssClasses"].AUTO_HEIGHT, params.autoHeight); + _this.addOrRemoveCssClass(_styling_layoutFeature__WEBPACK_IMPORTED_MODULE_1__["LayoutCssClasses"].NORMAL, params.normal); + _this.addOrRemoveCssClass(_styling_layoutFeature__WEBPACK_IMPORTED_MODULE_1__["LayoutCssClasses"].PRINT, params.print); + }, + setAlwaysVerticalScrollClass: function (cssClass, on) { + return _this.eBodyViewport.classList.toggle(_gridBodyCtrl__WEBPACK_IMPORTED_MODULE_5__["CSS_CLASS_FORCE_VERTICAL_SCROLL"], on); + }, + registerBodyViewportResizeListener: function (listener) { + var unsubscribeFromResize = _this.resizeObserverService.observeResize(_this.eBodyViewport, listener); + _this.addDestroyFunc(function () { return unsubscribeFromResize(); }); + }, + setPinnedTopBottomOverflowY: function (overflow) { return _this.eTop.style.overflowY = _this.eBottom.style.overflowY = overflow; }, + setCellSelectableCss: function (cssClass, selectable) { + [_this.eTop, _this.eBodyViewport, _this.eBottom] + .forEach(function (ct) { return ct.classList.toggle(_gridBodyCtrl__WEBPACK_IMPORTED_MODULE_5__["CSS_CLASS_CELL_SELECTABLE"], selectable); }); + }, + }; + this.ctrl = this.createManagedBean(new _gridBodyCtrl__WEBPACK_IMPORTED_MODULE_5__["GridBodyCtrl"]()); + this.ctrl.setComp(compProxy, this.getGui(), this.eBodyViewport, this.eTop, this.eBottom); + if (this.rangeService || this.gridOptionsWrapper.isRowSelectionMulti()) { + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_2__["setAriaMultiSelectable"])(this.getGui(), true); + } + }; + GridBodyComp.prototype.setRowAnimationCssOnBodyViewport = function (cssClass, animateRows) { + var bodyViewportClassList = this.eBodyViewport.classList; + bodyViewportClassList.toggle(_gridBodyCtrl__WEBPACK_IMPORTED_MODULE_5__["RowAnimationCssClasses"].ANIMATION_ON, animateRows); + bodyViewportClassList.toggle(_gridBodyCtrl__WEBPACK_IMPORTED_MODULE_5__["RowAnimationCssClasses"].ANIMATION_OFF, !animateRows); + }; + GridBodyComp.prototype.getFloatingTopBottom = function () { + return [this.eTop, this.eBottom]; + }; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('resizeObserverService') + ], GridBodyComp.prototype, "resizeObserverService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('rangeService') + ], GridBodyComp.prototype, "rangeService", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eBodyViewport') + ], GridBodyComp.prototype, "eBodyViewport", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eTop') + ], GridBodyComp.prototype, "eTop", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eBottom') + ], GridBodyComp.prototype, "eBottom", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('gridHeader') + ], GridBodyComp.prototype, "headerRootComp", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], GridBodyComp.prototype, "init", null); + return GridBodyComp; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_3__["Component"])); + + +/***/ }), +/* 165 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LayoutCssClasses", function() { return LayoutCssClasses; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LayoutFeature", function() { return LayoutFeature; }); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(15); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(107); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(20); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; -// in the html below, it is important that there are no white space between some of the divs, as if there is white space, -// it won't render correctly in safari, as safari renders white space as a gap -var GRID_PANEL_NORMAL_TEMPLATE = /* html */ "
\n \n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n \n
"; -var GridPanel = /** @class */ (function (_super) { - __extends(GridPanel, _super); - function GridPanel() { - var _this = _super.call(this, GRID_PANEL_NORMAL_TEMPLATE) || this; - _this.scrollLeft = -1; - _this.scrollTop = -1; - _this.resetLastHorizontalScrollElementDebounced = _utils__WEBPACK_IMPORTED_MODULE_12__["_"].debounce(_this.resetLastHorizontalScrollElement.bind(_this), 500); +var LayoutCssClasses; +(function (LayoutCssClasses) { + LayoutCssClasses["AUTO_HEIGHT"] = "ag-layout-auto-height"; + LayoutCssClasses["NORMAL"] = "ag-layout-normal"; + LayoutCssClasses["PRINT"] = "ag-layout-print"; +})(LayoutCssClasses || (LayoutCssClasses = {})); +var LayoutFeature = /** @class */ (function (_super) { + __extends(LayoutFeature, _super); + function LayoutFeature(view) { + var _this = _super.call(this) || this; + _this.view = view; return _this; } - GridPanel.prototype.getVScrollPosition = function () { - var result = { - top: this.eBodyViewport.scrollTop, - bottom: this.eBodyViewport.scrollTop + this.eBodyViewport.offsetHeight - }; - return result; + LayoutFeature.prototype.postConstruct = function () { + this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__["GridOptionsWrapper"].PROP_DOM_LAYOUT, this.updateLayoutClasses.bind(this)); + this.updateLayoutClasses(); }; - GridPanel.prototype.getHScrollPosition = function () { - var result = { - left: this.eCenterViewport.scrollLeft, - right: this.eCenterViewport.scrollLeft + this.eCenterViewport.offsetWidth + LayoutFeature.prototype.updateLayoutClasses = function () { + var domLayout = this.gridOptionsWrapper.getDomLayout(); + var params = { + autoHeight: domLayout === _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].DOM_LAYOUT_AUTO_HEIGHT, + normal: domLayout === _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].DOM_LAYOUT_NORMAL, + print: domLayout === _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].DOM_LAYOUT_PRINT }; - return result; + var cssClass = params.autoHeight ? LayoutCssClasses.AUTO_HEIGHT : + params.print ? LayoutCssClasses.PRINT : LayoutCssClasses.NORMAL; + this.view.updateLayoutClasses(cssClass, params); }; - GridPanel.prototype.onRowDataChanged = function () { - this.showOrHideOverlay(); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') + ], LayoutFeature.prototype, "gridOptionsWrapper", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], LayoutFeature.prototype, "postConstruct", null); + return LayoutFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"])); + + + +/***/ }), +/* 166 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowAnimationCssClasses", function() { return RowAnimationCssClasses; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CSS_CLASS_CELL_SELECTABLE", function() { return CSS_CLASS_CELL_SELECTABLE; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CSS_CLASS_FORCE_VERTICAL_SCROLL", function() { return CSS_CLASS_FORCE_VERTICAL_SCROLL; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CSS_CLASS_COLUMN_MOVING", function() { return CSS_CLASS_COLUMN_MOVING; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridBodyCtrl", function() { return GridBodyCtrl; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _styling_layoutFeature__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(165); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(15); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(24); +/* harmony import */ var _gridBodyScrollFeature__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(167); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(42); +/* harmony import */ var _rowDragFeature__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(168); +/* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(43); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - GridPanel.prototype.showOrHideOverlay = function () { - var isEmpty = this.paginationProxy.isEmpty(); - var isSuppressNoRowsOverlay = this.gridOptionsWrapper.isSuppressNoRowsOverlay(); - var method = isEmpty && !isSuppressNoRowsOverlay ? 'showNoRowsOverlay' : 'hideOverlay'; - this[method](); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - GridPanel.prototype.onNewColumnsLoaded = function () { - // hide overlay if columns and rows exist, this can happen if columns are loaded after data. - // this problem exists before of the race condition between the services (column controller in this case) - // and the view (grid panel). if the model beans were all initialised first, and then the view beans second, - // this race condition would not happen. - if (this.beans.columnController.isReady() && !this.paginationProxy.isEmpty()) { - this.hideOverlay(); - } +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + + + +var RowAnimationCssClasses; +(function (RowAnimationCssClasses) { + RowAnimationCssClasses["ANIMATION_ON"] = "ag-row-animation"; + RowAnimationCssClasses["ANIMATION_OFF"] = "ag-row-no-animation"; +})(RowAnimationCssClasses || (RowAnimationCssClasses = {})); +var CSS_CLASS_CELL_SELECTABLE = 'ag-selectable'; +var CSS_CLASS_FORCE_VERTICAL_SCROLL = 'ag-force-vertical-scroll'; +var CSS_CLASS_COLUMN_MOVING = 'ag-column-moving'; +var GridBodyCtrl = /** @class */ (function (_super) { + __extends(GridBodyCtrl, _super); + function GridBodyCtrl() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.angularApplyTriggered = false; + return _this; + } + GridBodyCtrl.prototype.getScrollFeature = function () { + return this.bodyScrollFeature; }; - GridPanel.prototype.init = function () { - var _this = this; - this.scrollWidth = this.gridOptionsWrapper.getScrollbarWidth(); - this.enableRtl = this.gridOptionsWrapper.isEnableRtl(); - this.printLayout = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].DOM_LAYOUT_PRINT; - // these elements have different CSS when layout changes - this.gridOptionsWrapper.addLayoutElement(this.getGui()); - this.gridOptionsWrapper.addLayoutElement(this.eBodyViewport); - this.suppressScrollOnFloatingRow(); + GridBodyCtrl.prototype.getBodyViewportElement = function () { + return this.eBodyViewport; + }; + GridBodyCtrl.prototype.setComp = function (comp, eGridBody, eBodyViewport, eTop, eBottom) { + this.comp = comp; + this.eGridBody = eGridBody; + this.eBodyViewport = eBodyViewport; + this.eTop = eTop; + this.eBottom = eBottom; + this.setCellTextSelection(this.gridOptionsWrapper.isEnableCellTextSelect()); + this.createManagedBean(new _styling_layoutFeature__WEBPACK_IMPORTED_MODULE_2__["LayoutFeature"](this.comp)); + this.bodyScrollFeature = this.createManagedBean(new _gridBodyScrollFeature__WEBPACK_IMPORTED_MODULE_5__["GridBodyScrollFeature"](this.eBodyViewport)); + this.addRowDragListener(); this.setupRowAnimationCssClass(); - this.buildRowContainerComponents(); + this.ctrlsService.registerGridBodyCtrl(this); this.addEventListeners(); - this.addDragListeners(); - this.addScrollListener(); - if (this.gridOptionsWrapper.isRowModelDefault() && !this.gridOptionsWrapper.getRowData()) { - this.showLoadingOverlay(); - } - this.setCellTextSelection(this.gridOptionsWrapper.isEnableCellTextSelect()); - this.setPinnedContainerSize(); - this.setHeaderAndFloatingHeights(); - this.disableBrowserDragging(); - this.addMouseListeners(); - this.addKeyboardEvents(); + this.addFocusListeners([eTop, eBodyViewport, eBottom]); + this.onGridColumnsChanged(); this.addBodyViewportListener(); + this.setFloatingHeights(); + this.disableBrowserDragging(); this.addStopEditingWhenGridLosesFocus(); - this.mockContextMenuForIPad(); - this.addRowDragListener(); if (this.$scope) { this.addAngularApplyCheck(); } - this.onDisplayedColumnsWidthChanged(); - this.gridApi.registerGridComp(this); - this.alignedGridsService.registerGridComp(this); - this.headerRootComp.registerGridComp(this); - this.navigationService.registerGridComp(this); - this.headerNavigationService.registerGridComp(this); - this.heightScaler.registerGridComp(this); - this.autoHeightCalculator.registerGridComp(this); - this.columnAnimationService.registerGridComp(this); - this.autoWidthCalculator.registerGridComp(this); - this.paginationAutoPageSizeService.registerGridComp(this); - this.mouseEventService.registerGridComp(this); - this.beans.registerGridComp(this); - this.rowRenderer.registerGridComp(this); - if (this.rangeController) { - this.rangeController.registerGridComp(this); - } - [this.eCenterViewport, this.eBodyViewport].forEach(function (viewport) { - var unsubscribeFromResize = _this.resizeObserverService.observeResize(viewport, _this.onCenterViewportResized.bind(_this)); - _this.addDestroyFunc(function () { return unsubscribeFromResize(); }); - }); - [this.eTop, this.eBodyViewport, this.eBottom].forEach(function (element) { + }; + GridBodyCtrl.prototype.getComp = function () { + return this.comp; + }; + GridBodyCtrl.prototype.addEventListeners = function () { + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_GRID_COLUMNS_CHANGED, this.onGridColumnsChanged.bind(this)); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_SCROLL_VISIBILITY_CHANGED, this.onScrollVisibilityChanged.bind(this)); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_PINNED_ROW_DATA_CHANGED, this.setFloatingHeights.bind(this)); + }; + GridBodyCtrl.prototype.addFocusListeners = function (elements) { + var _this = this; + elements.forEach(function (element) { _this.addManagedListener(element, 'focusin', function () { - _utils__WEBPACK_IMPORTED_MODULE_12__["_"].addCssClass(element, 'ag-has-focus'); + element.classList.add('ag-has-focus'); }); _this.addManagedListener(element, 'focusout', function (e) { if (!element.contains(e.relatedTarget)) { - _utils__WEBPACK_IMPORTED_MODULE_12__["_"].removeCssClass(element, 'ag-has-focus'); + element.classList.remove('ag-has-focus'); } }); }); }; - GridPanel.prototype.onDomLayoutChanged = function () { - var newPrintLayout = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].DOM_LAYOUT_PRINT; - if (this.printLayout !== newPrintLayout) { - this.printLayout = newPrintLayout; - this.setWidthsOfContainers(); - // pinned containers are always hidden for print layout - this.setPinnedContainerSize(); - } - }; - GridPanel.prototype.onCenterViewportResized = function () { - if (_utils__WEBPACK_IMPORTED_MODULE_12__["_"].isVisible(this.eCenterViewport)) { - this.checkViewportAndScrolls(); - this.beans.columnController.refreshFlexedColumns(this.getCenterWidth()); - } - else { - this.bodyHeight = 0; - } - }; // used by ColumnAnimationService - GridPanel.prototype.setColumnMovingCss = function (moving) { - this.addOrRemoveCssClass('ag-column-moving', moving); + GridBodyCtrl.prototype.setColumnMovingCss = function (moving) { + this.comp.setColumnMovingCss(moving ? CSS_CLASS_COLUMN_MOVING : null, moving); }; - GridPanel.prototype.setCellTextSelection = function (selectable) { + GridBodyCtrl.prototype.setCellTextSelection = function (selectable) { if (selectable === void 0) { selectable = false; } - [this.eTop, this.eBodyViewport, this.eBottom] - .forEach(function (ct) { return _utils__WEBPACK_IMPORTED_MODULE_12__["_"].addOrRemoveCssClass(ct, 'ag-selectable', selectable); }); - }; - GridPanel.prototype.addRowDragListener = function () { - this.rowDragFeature = this.createManagedBean(new _rowDragFeature__WEBPACK_IMPORTED_MODULE_7__["RowDragFeature"](this.eBodyViewport, this)); - this.dragAndDropService.addDropTarget(this.rowDragFeature); - }; - GridPanel.prototype.getRowDragFeature = function () { - return this.rowDragFeature; + var cssClass = selectable ? CSS_CLASS_CELL_SELECTABLE : null; + this.comp.setCellSelectableCss(cssClass, selectable); }; - GridPanel.prototype.addStopEditingWhenGridLosesFocus = function () { - var _this = this; - if (!this.gridOptionsWrapper.isStopEditingWhenGridLosesFocus()) { - return; - } - var viewports = [this.eBodyViewport, this.eBottom, this.eTop]; - var focusOutListener = function (event) { - // this is the element the focus is moving to - var elementWithFocus = event.relatedTarget; - if (_utils__WEBPACK_IMPORTED_MODULE_12__["_"].getTabIndex(elementWithFocus) === null) { - _this.rowRenderer.stopEditing(); - return; - } - var clickInsideGrid = viewports.some(function (viewport) { return viewport.contains(elementWithFocus); }); - if (!clickInsideGrid) { - var popupService = _this.beans.popupService; - clickInsideGrid = - popupService.getActivePopups().some(function (popup) { return popup.contains(elementWithFocus); }) || - popupService.isElementWithinCustomPopup(elementWithFocus); - } - if (!clickInsideGrid) { - _this.rowRenderer.stopEditing(); - } - }; - viewports.forEach(function (viewport) { return _this.addManagedListener(viewport, 'focusout', focusOutListener); }); + GridBodyCtrl.prototype.onScrollVisibilityChanged = function () { + var visible = this.scrollVisibleService.isVerticalScrollShowing(); + this.setVerticalScrollPaddingVisible(visible); }; - GridPanel.prototype.addAngularApplyCheck = function () { - var _this = this; - // this makes sure if we queue up requests, we only execute oe - var applyTriggered = false; - var listener = function () { - // only need to do one apply at a time - if (applyTriggered) { - return; - } - applyTriggered = true; // mark 'need apply' to true - window.setTimeout(function () { - applyTriggered = false; - _this.$scope.$apply(); - }, 0); - }; - // these are the events we need to do an apply after - these are the ones that can end up - // with columns added or removed - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, listener); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_VIRTUAL_COLUMNS_CHANGED, listener); + GridBodyCtrl.prototype.onGridColumnsChanged = function () { + var columns = this.columnModel.getAllGridColumns(); + this.comp.setColumnCount(columns ? columns.length : 0); }; // if we do not do this, then the user can select a pic in the grid (eg an image in a custom cell renderer) // and then that will start the browser native drag n' drop, which messes up with our own drag and drop. - GridPanel.prototype.disableBrowserDragging = function () { - this.addGuiEventListener('dragstart', function (event) { - if (event.target instanceof HTMLImageElement) { - event.preventDefault(); - return false; - } - }); - }; - GridPanel.prototype.addEventListeners = function () { - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, this.onDisplayedColumnsWidthChanged.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_PINNED_ROW_DATA_CHANGED, this.setHeaderAndFloatingHeights.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DATA_CHANGED, this.onRowDataChanged.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DATA_UPDATED, this.onRowDataChanged.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_NEW_COLUMNS_LOADED, this.onNewColumnsLoaded.bind(this)); - this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_HEADER_HEIGHT, this.setHeaderAndFloatingHeights.bind(this)); - this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_PIVOT_HEADER_HEIGHT, this.setHeaderAndFloatingHeights.bind(this)); - this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GROUP_HEADER_HEIGHT, this.setHeaderAndFloatingHeights.bind(this)); - this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_PIVOT_GROUP_HEADER_HEIGHT, this.setHeaderAndFloatingHeights.bind(this)); - this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_FLOATING_FILTERS_HEIGHT, this.setHeaderAndFloatingHeights.bind(this)); - this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_DOM_LAYOUT, this.onDomLayoutChanged.bind(this)); - }; - GridPanel.prototype.addDragListeners = function () { - var _this = this; - if (!this.gridOptionsWrapper.isEnableRangeSelection() || // no range selection if no property - _utils__WEBPACK_IMPORTED_MODULE_12__["_"].missing(this.rangeController) // no range selection if not enterprise version - ) { - return; - } - var containers = [ - this.eLeftContainer, - this.eRightContainer, - this.eCenterContainer, - this.eTop, - this.eBottom - ]; - containers.forEach(function (container) { - var params = { - eElement: container, - onDragStart: _this.rangeController.onDragStart.bind(_this.rangeController), - onDragStop: _this.rangeController.onDragStop.bind(_this.rangeController), - onDragging: _this.rangeController.onDragging.bind(_this.rangeController) - }; - _this.dragService.addDragSource(params); - _this.addDestroyFunc(function () { return _this.dragService.removeDragSource(params); }); - }); - }; - GridPanel.prototype.addMouseListeners = function () { - var _this = this; - var eventNames = ['click', 'mousedown', 'dblclick', 'contextmenu', 'mouseover', 'mouseout']; - eventNames.forEach(function (eventName) { - var listener = _this.processMouseEvent.bind(_this, eventName); - _this.eAllCellContainers.forEach(function (container) { - return _this.addManagedListener(container, eventName, listener); - }); - }); - }; - GridPanel.prototype.addKeyboardEvents = function () { - var _this = this; - var eventNames = ['keydown', 'keypress']; - eventNames.forEach(function (eventName) { - var listener = _this.processKeyboardEvent.bind(_this, eventName); - _this.eAllCellContainers.forEach(function (container) { - _this.addManagedListener(container, eventName, listener); - }); - }); - }; - GridPanel.prototype.addBodyViewportListener = function () { - var _this = this; - // we want to listen for clicks directly on the eBodyViewport, so the user has a way of showing - // the context menu if no rows or columns are displayed, or user simply clicks outside of a cell - var listener = function (mouseEvent) { - var target = _utils__WEBPACK_IMPORTED_MODULE_12__["_"].getTarget(mouseEvent); - if (target === _this.eBodyViewport || target === _this.eCenterViewport) { - // show it - _this.onContextMenu(mouseEvent, null, null, null, null); - _this.preventDefaultOnContextMenu(mouseEvent); - } - }; - this.addManagedListener(this.eBodyViewport, 'contextmenu', listener); - }; - // + rangeController - used to know when to scroll when user is dragging outside the - // main viewport while doing a range selection - GridPanel.prototype.getBodyClientRect = function () { - if (!this.eBodyViewport) { - return; - } - return this.eBodyViewport.getBoundingClientRect(); - }; - GridPanel.prototype.getRowForEvent = function (event) { - var sourceElement = _utils__WEBPACK_IMPORTED_MODULE_12__["_"].getTarget(event); - while (sourceElement) { - var renderedRow = this.gridOptionsWrapper.getDomData(sourceElement, _rendering_rowComp__WEBPACK_IMPORTED_MODULE_5__["RowComp"].DOM_DATA_KEY_RENDERED_ROW); - if (renderedRow) { - return renderedRow; - } - sourceElement = sourceElement.parentElement; - } - return null; - }; - GridPanel.prototype.processKeyboardEvent = function (eventName, keyboardEvent) { - var cellComp = _utils__WEBPACK_IMPORTED_MODULE_12__["_"].getCellCompForEvent(this.gridOptionsWrapper, keyboardEvent); - if (!cellComp || keyboardEvent.defaultPrevented) { - return; - } - var rowNode = cellComp.getRenderedRow().getRowNode(); - var column = cellComp.getColumn(); - var editing = cellComp.isEditing(); - var gridProcessingAllowed = !_utils__WEBPACK_IMPORTED_MODULE_12__["_"].isUserSuppressingKeyboardEvent(this.gridOptionsWrapper, keyboardEvent, rowNode, column, editing); - if (gridProcessingAllowed) { - switch (eventName) { - case 'keydown': - // first see if it's a scroll key, page up / down, home / end etc - var wasScrollKey = !editing && this.navigationService.handlePageScrollingKey(keyboardEvent); - // if not a scroll key, then we pass onto cell - if (!wasScrollKey) { - cellComp.onKeyDown(keyboardEvent); - } - // perform clipboard and undo / redo operations - this.doGridOperations(keyboardEvent, cellComp); - break; - case 'keypress': - cellComp.onKeyPress(keyboardEvent); - break; - } - } - if (eventName === 'keydown') { - var cellKeyDownEvent = cellComp.createEvent(keyboardEvent, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_CELL_KEY_DOWN); - this.beans.eventService.dispatchEvent(cellKeyDownEvent); - } - if (eventName === 'keypress') { - var cellKeyPressEvent = cellComp.createEvent(keyboardEvent, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_CELL_KEY_PRESS); - this.beans.eventService.dispatchEvent(cellKeyPressEvent); - } - }; - GridPanel.prototype.doGridOperations = function (keyboardEvent, cellComp) { - // check if ctrl or meta key pressed - if (!keyboardEvent.ctrlKey && !keyboardEvent.metaKey) { - return; - } - // if the cell the event came from is editing, then we do not - // want to do the default shortcut keys, otherwise the editor - // (eg a text field) would not be able to do the normal cut/copy/paste - if (cellComp.isEditing()) { - return; - } - // for copy / paste, we don't want to execute when the event - // was from a child grid (happens in master detail) - if (!this.mouseEventService.isEventFromThisGrid(keyboardEvent)) { - return; - } - switch (keyboardEvent.which) { - case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_A: - return this.onCtrlAndA(keyboardEvent); - case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_C: - return this.onCtrlAndC(keyboardEvent); - case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_V: - return this.onCtrlAndV(); - case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_D: - return this.onCtrlAndD(keyboardEvent); - case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_Z: - return keyboardEvent.shiftKey ? this.undoRedoService.redo() : this.undoRedoService.undo(); - case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_Y: - return this.undoRedoService.redo(); - } - }; - // gets called by rowRenderer when new data loaded, as it will want to scroll to the top - GridPanel.prototype.scrollToTop = function () { - this.eBodyViewport.scrollTop = 0; - }; - GridPanel.prototype.processMouseEvent = function (eventName, mouseEvent) { - if (!this.mouseEventService.isEventFromThisGrid(mouseEvent) || - _utils__WEBPACK_IMPORTED_MODULE_12__["_"].isStopPropagationForAgGrid(mouseEvent)) { - return; - } - var rowComp = this.getRowForEvent(mouseEvent); - var cellComp = this.mouseEventService.getRenderedCellForEvent(mouseEvent); - if (eventName === "contextmenu") { - this.preventDefaultOnContextMenu(mouseEvent); - this.handleContextMenuMouseEvent(mouseEvent, null, rowComp, cellComp); - } - else { - if (cellComp) { - cellComp.onMouseEvent(eventName, mouseEvent); - } - if (rowComp) { - rowComp.onMouseEvent(eventName, mouseEvent); - } - } - }; - GridPanel.prototype.mockContextMenuForIPad = function () { - var _this = this; - // we do NOT want this when not in iPad, otherwise we will be doing - if (!_utils__WEBPACK_IMPORTED_MODULE_12__["_"].isIOSUserAgent()) { - return; - } - this.eAllCellContainers.forEach(function (container) { - var touchListener = new _widgets_touchListener__WEBPACK_IMPORTED_MODULE_6__["TouchListener"](container); - var longTapListener = function (event) { - var rowComp = _this.getRowForEvent(event.touchEvent); - var cellComp = _this.mouseEventService.getRenderedCellForEvent(event.touchEvent); - _this.handleContextMenuMouseEvent(null, event.touchEvent, rowComp, cellComp); - }; - _this.addManagedListener(touchListener, _widgets_touchListener__WEBPACK_IMPORTED_MODULE_6__["TouchListener"].EVENT_LONG_TAP, longTapListener); - _this.addDestroyFunc(function () { return touchListener.destroy(); }); - }); - }; - GridPanel.prototype.handleContextMenuMouseEvent = function (mouseEvent, touchEvent, rowComp, cellComp) { - var rowNode = rowComp ? rowComp.getRowNode() : null; - var column = cellComp ? cellComp.getColumn() : null; - var value = null; - if (column) { - var event_1 = mouseEvent ? mouseEvent : touchEvent; - cellComp.dispatchCellContextMenuEvent(event_1); - value = this.valueService.getValue(column, rowNode); - } - this.onContextMenu(mouseEvent, touchEvent, rowNode, column, value); - }; - GridPanel.prototype.onContextMenu = function (mouseEvent, touchEvent, rowNode, column, value) { - // to allow us to debug in chrome, we ignore the event if ctrl is pressed. - // not everyone wants this, so first 'if' below allows to turn this hack off. - if (!this.gridOptionsWrapper.isAllowContextMenuWithControlKey()) { - // then do the check - if (mouseEvent && (mouseEvent.ctrlKey || mouseEvent.metaKey)) { - return; - } - } - if (this.contextMenuFactory && !this.gridOptionsWrapper.isSuppressContextMenu()) { - var eventOrTouch = mouseEvent ? mouseEvent : touchEvent.touches[0]; - if (this.contextMenuFactory.showMenu(rowNode, column, value, eventOrTouch)) { - var event_2 = mouseEvent ? mouseEvent : touchEvent; - event_2.preventDefault(); - } - } - }; - GridPanel.prototype.preventDefaultOnContextMenu = function (mouseEvent) { - // if we don't do this, then middle click will never result in a 'click' event, as 'mousedown' - // will be consumed by the browser to mean 'scroll' (as you can scroll with the middle mouse - // button in the browser). so this property allows the user to receive middle button clicks if - // they want. - var gridOptionsWrapper = this.gridOptionsWrapper; - var which = mouseEvent.which; - if (gridOptionsWrapper.isPreventDefaultOnContextMenu() || - (gridOptionsWrapper.isSuppressMiddleClickScrolls() && which === 2)) { - mouseEvent.preventDefault(); - } - }; - GridPanel.prototype.onCtrlAndA = function (event) { - var _a = this, beans = _a.beans, pinnedRowModel = _a.pinnedRowModel, paginationProxy = _a.paginationProxy, rangeController = _a.rangeController; - var PINNED_BOTTOM = _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_BOTTOM, PINNED_TOP = _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP; - if (rangeController && paginationProxy.isRowsToRender()) { - var _b = [ - pinnedRowModel.isEmpty(PINNED_TOP), - pinnedRowModel.isEmpty(PINNED_BOTTOM) - ], isEmptyPinnedTop = _b[0], isEmptyPinnedBottom = _b[1]; - var floatingStart = isEmptyPinnedTop ? null : PINNED_TOP; - var floatingEnd = void 0; - var rowEnd = void 0; - if (isEmptyPinnedBottom) { - floatingEnd = null; - rowEnd = this.paginationProxy.getRowCount() - 1; - } - else { - floatingEnd = PINNED_BOTTOM; - rowEnd = pinnedRowModel.getPinnedBottomRowData().length - 1; - } - var allDisplayedColumns = beans.columnController.getAllDisplayedColumns(); - if (_utils__WEBPACK_IMPORTED_MODULE_12__["_"].missingOrEmpty(allDisplayedColumns)) { - return; - } - rangeController.setCellRange({ - rowStartIndex: 0, - rowStartPinned: floatingStart, - rowEndIndex: rowEnd, - rowEndPinned: floatingEnd, - columnStart: allDisplayedColumns[0], - columnEnd: _utils__WEBPACK_IMPORTED_MODULE_12__["_"].last(allDisplayedColumns) - }); - } - event.preventDefault(); - }; - GridPanel.prototype.onCtrlAndC = function (event) { - if (!this.clipboardService || this.gridOptionsWrapper.isEnableCellTextSelection()) { - return; - } - this.clipboardService.copyToClipboard(); - event.preventDefault(); - }; - GridPanel.prototype.onCtrlAndV = function () { - if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_10__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_11__["ModuleNames"].ClipboardModule) && !this.gridOptionsWrapper.isSuppressClipboardPaste()) { - this.clipboardService.pasteFromClipboard(); - } - }; - GridPanel.prototype.onCtrlAndD = function (event) { - if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_10__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_11__["ModuleNames"].ClipboardModule) && !this.gridOptionsWrapper.isSuppressClipboardPaste()) { - this.clipboardService.copyRangeDown(); - } - event.preventDefault(); - }; - // Valid values for position are bottom, middle and top - // position should be {'top','middle','bottom', or undefined/null}. - // if undefined/null, then the grid will to the minimal amount of scrolling, - // eg if grid needs to scroll up, it scrolls until row is on top, - // if grid needs to scroll down, it scrolls until row is on bottom, - // if row is already in view, grid does not scroll - GridPanel.prototype.ensureIndexVisible = function (index, position) { - // if for print or auto height, everything is always visible - if (this.printLayout) { - return; - } - var rowCount = this.paginationProxy.getRowCount(); - if (typeof index !== 'number' || index < 0 || index >= rowCount) { - console.warn('invalid row index for ensureIndexVisible: ' + index); + GridBodyCtrl.prototype.disableBrowserDragging = function () { + this.addManagedListener(this.eGridBody, 'dragstart', function (event) { + if (event.target instanceof HTMLImageElement) { + event.preventDefault(); + return false; + } + }); + }; + GridBodyCtrl.prototype.addStopEditingWhenGridLosesFocus = function () { + var _this = this; + if (!this.gridOptionsWrapper.isStopEditingWhenCellsLoseFocus()) { return; } - this.paginationProxy.goToPageWithIndex(index); - var rowNode = this.paginationProxy.getRow(index); - var rowGotShiftedDuringOperation; - do { - var startingRowTop = rowNode.rowTop; - var startingRowHeight = rowNode.rowHeight; - var paginationOffset = this.paginationProxy.getPixelOffset(); - var rowTopPixel = rowNode.rowTop - paginationOffset; - var rowBottomPixel = rowTopPixel + rowNode.rowHeight; - var scrollPosition = this.getVScrollPosition(); - var heightOffset = this.heightScaler.getOffset(); - var vScrollTop = scrollPosition.top + heightOffset; - var vScrollBottom = scrollPosition.bottom + heightOffset; - var viewportHeight = vScrollBottom - vScrollTop; - // work out the pixels for top, middle and bottom up front, - // make the if/else below easier to read - var pxTop = this.heightScaler.getScrollPositionForPixel(rowTopPixel); - var pxBottom = this.heightScaler.getScrollPositionForPixel(rowBottomPixel - viewportHeight); - // make sure if middle, the row is not outside the top of the grid - var pxMiddle = Math.min((pxTop + pxBottom) / 2, rowTopPixel); - var rowBelowViewport = vScrollTop > rowTopPixel; - var rowAboveViewport = vScrollBottom < rowBottomPixel; - var newScrollPosition = null; - if (position === 'top') { - newScrollPosition = pxTop; - } - else if (position === 'bottom') { - newScrollPosition = pxBottom; - } - else if (position === 'middle') { - newScrollPosition = pxMiddle; - } - else if (rowBelowViewport) { - // if row is before, scroll up with row at top - newScrollPosition = pxTop; + var focusOutListener = function (event) { + // this is the element the focus is moving to + var elementWithFocus = event.relatedTarget; + if (Object(_utils_browser__WEBPACK_IMPORTED_MODULE_8__["getTabIndex"])(elementWithFocus) === null) { + _this.rowRenderer.stopEditing(); + return; } - else if (rowAboveViewport) { - // if row is below, scroll down with row at bottom - newScrollPosition = pxBottom; + var clickInsideGrid = + // see if click came from inside the viewports + viewports.some(function (viewport) { return viewport.contains(elementWithFocus); }) + // and also that it's not from a detail grid + && _this.mouseEventService.isElementInThisGrid(elementWithFocus); + if (!clickInsideGrid) { + var popupService = _this.popupService; + clickInsideGrid = + popupService.getActivePopups().some(function (popup) { return popup.contains(elementWithFocus); }) || + popupService.isElementWithinCustomPopup(elementWithFocus); } - if (newScrollPosition !== null) { - this.eBodyViewport.scrollTop = newScrollPosition; - this.rowRenderer.redrawAfterScroll(); + if (!clickInsideGrid) { + _this.rowRenderer.stopEditing(); } - // the row can get shifted if during the rendering (during rowRenderer.redrawAfterScroll()), - // the height of a row changes due to lazy calculation of row heights when using - // colDef.autoHeight or gridOptions.getRowHeight. - // if row was shifted, then the position we scrolled to is incorrect. - rowGotShiftedDuringOperation = (startingRowTop !== rowNode.rowTop) - || (startingRowHeight !== rowNode.rowHeight); - } while (rowGotShiftedDuringOperation); - // so when we return back to user, the cells have rendered - this.animationFrameService.flushAllFrames(); + }; + var viewports = [this.eBodyViewport, this.eBottom, this.eTop]; + viewports.forEach(function (viewport) { return _this.addManagedListener(viewport, 'focusout', focusOutListener); }); }; - // + moveColumnController - GridPanel.prototype.getCenterWidth = function () { - return this.eCenterViewport.clientWidth; + GridBodyCtrl.prototype.updateRowCount = function () { + var headerCount = this.headerNavigationService.getHeaderRowCount(); + var modelType = this.paginationProxy.getType(); + var rowCount = -1; + if (modelType === _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) { + rowCount = 0; + this.paginationProxy.forEachNode(function (node) { + if (!node.group) { + rowCount++; + } + }); + } + var total = rowCount === -1 ? -1 : (headerCount + rowCount); + this.comp.setRowCount(total); }; - GridPanel.prototype.isVerticalScrollShowing = function () { - var isAlwaysShowVerticalScroll = this.gridOptionsWrapper.isAlwaysShowVerticalScroll(); - _utils__WEBPACK_IMPORTED_MODULE_12__["_"].addOrRemoveCssClass(this.eBodyViewport, 'ag-force-vertical-scroll', isAlwaysShowVerticalScroll); - return isAlwaysShowVerticalScroll || _utils__WEBPACK_IMPORTED_MODULE_12__["_"].isVerticalScrollShowing(this.eBodyViewport); + GridBodyCtrl.prototype.registerBodyViewportResizeListener = function (listener) { + this.comp.registerBodyViewportResizeListener(listener); }; - GridPanel.prototype.isHorizontalScrollShowing = function () { - return _utils__WEBPACK_IMPORTED_MODULE_12__["_"].isHorizontalScrollShowing(this.eCenterViewport); + GridBodyCtrl.prototype.setVerticalScrollPaddingVisible = function (visible) { + var overflowY = visible ? 'scroll' : 'hidden'; + this.comp.setPinnedTopBottomOverflowY(overflowY); }; - // gets called every time the viewport size changes. we use this to check visibility of scrollbars - // in the grid panel, and also to check size and position of viewport for row and column virtualisation. - GridPanel.prototype.checkViewportAndScrolls = function () { - // results in updating anything that depends on scroll showing - this.updateScrollVisibleService(); - // fires event if height changes, used by PaginationService, HeightScalerService, RowRenderer - this.checkBodyHeight(); - // check for virtual columns for ColumnController - this.onHorizontalViewportChanged(); - this.setPinnedContainerSize(); - // this is to cater for AG-3274, where grid is removed from the dom and then inserted back in again. - // (which happens with some implementations of tabbing). this can result in horizontal scroll getting - // reset back to the left, however no scroll event is fired. so we need to get header to also scroll - // back to the left to be kept in sync. - // adding and removing the grid from the DOM both resets the scroll position and - // triggers a resize event, so notify listeners if the scroll position has changed - if (this.scrollLeft !== this.getCenterViewportScrollLeft()) { - this.onBodyHorizontalScroll(this.eCenterViewport); - } - }; - GridPanel.prototype.updateScrollVisibleService = function () { - // because of column animation (which takes 200ms), we have to do this twice. - // eg if user removes cols anywhere except at the RHS, then the cols on the RHS - // will animate to the left to fill the gap. this animation means just after - // the cols are removed, the remaining cols are still in the original location - // at the start of the animation, so pre animation the H scrollbar is still needed, - // but post animation it is not. - this.updateScrollVisibleServiceImpl(); - setTimeout(this.updateScrollVisibleServiceImpl.bind(this), 500); + GridBodyCtrl.prototype.isVerticalScrollShowing = function () { + var show = this.gridOptionsWrapper.isAlwaysShowVerticalScroll(); + var cssClass = show ? CSS_CLASS_FORCE_VERTICAL_SCROLL : null; + this.comp.setAlwaysVerticalScrollClass(cssClass, show); + return show || Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["isVerticalScrollShowing"])(this.eBodyViewport); }; - GridPanel.prototype.updateScrollVisibleServiceImpl = function () { - var params = { - horizontalScrollShowing: false, - verticalScrollShowing: false + GridBodyCtrl.prototype.setupRowAnimationCssClass = function () { + var _this = this; + var listener = function () { + // we don't want to use row animation if scaling, as rows jump strangely as you scroll, + // when scaling and doing row animation. + var animateRows = _this.gridOptionsWrapper.isAnimateRows() && !_this.rowContainerHeightService.isStretching(); + var animateRowsCssClass = animateRows ? RowAnimationCssClasses.ANIMATION_ON : RowAnimationCssClasses.ANIMATION_OFF; + _this.comp.setRowAnimationCssOnBodyViewport(animateRowsCssClass, animateRows); }; - params.verticalScrollShowing = this.isVerticalScrollShowing(); - params.horizontalScrollShowing = this.isHorizontalScrollShowing(); - this.scrollVisibleService.setScrollsVisible(params); - this.setHorizontalScrollVisible(params.horizontalScrollShowing); - this.setVerticalScrollPaddingVisible(params.verticalScrollShowing); - }; - GridPanel.prototype.setHorizontalScrollVisible = function (visible) { - var isSuppressHorizontalScroll = this.gridOptionsWrapper.isSuppressHorizontalScroll(); - var scrollSize = visible ? (this.gridOptionsWrapper.getScrollbarWidth() || 0) : 0; - var scrollContainerSize = !isSuppressHorizontalScroll ? scrollSize : 0; - var addIEPadding = _utils__WEBPACK_IMPORTED_MODULE_12__["_"].isBrowserIE() && visible; - this.eCenterViewport.style.height = "calc(100% + " + scrollSize + "px)"; - _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setFixedHeight(this.eHorizontalScrollBody, scrollContainerSize); - // we have to add an extra pixel to the scroller viewport on IE because - // if the container has the same size as the scrollbar, the scroll button won't work - _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setFixedHeight(this.eBodyHorizontalScrollViewport, scrollContainerSize + (addIEPadding ? 1 : 0)); - _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setFixedHeight(this.eBodyHorizontalScrollContainer, scrollContainerSize); - }; - GridPanel.prototype.setVerticalScrollPaddingVisible = function (show) { - var scroller = show ? 'scroll' : 'hidden'; - this.eTop.style.overflowY = this.eBottom.style.overflowY = scroller; - this.setFakeHScrollSpacerWidths(); - }; - GridPanel.prototype.updateRowCount = function () { - var headerCount = this.headerNavigationService.getHeaderRowCount(); - var rowCount = this.paginationProxy.getRowCount(); - var total = (headerCount + rowCount).toString(); - this.getGui().setAttribute('aria-rowcount', total); + listener(); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_HEIGHT_SCALE_CHANGED, listener); }; - GridPanel.prototype.updateColumnCount = function () { - var columns = this.columnController.getAllDisplayedColumns(); - this.getGui().setAttribute('aria-colcount', columns.length.toString()); + GridBodyCtrl.prototype.getGridBodyElement = function () { + return this.eGridBody; }; - GridPanel.prototype.ensureColumnVisible = function (key) { - var column = this.columnController.getGridColumn(key); - if (!column) { - return; - } - if (column.isPinned()) { - console.warn('calling ensureIndexVisible on a ' + column.getPinned() + ' pinned column doesn\'t make sense for column ' + column.getColId()); - return; - } - if (!this.columnController.isColumnDisplayed(column)) { - console.warn('column is not currently visible'); - return; - } - var colLeftPixel = column.getLeft(); - var colRightPixel = colLeftPixel + column.getActualWidth(); - var viewportWidth = this.eCenterViewport.clientWidth; - var scrollPosition = this.getCenterViewportScrollLeft(); - var bodyWidth = this.columnController.getBodyContainerWidth(); - var viewportLeftPixel; - var viewportRightPixel; - // the logic of working out left and right viewport px is both here and in the ColumnController, - // need to refactor it out to one place - if (this.enableRtl) { - viewportLeftPixel = bodyWidth - scrollPosition - viewportWidth; - viewportRightPixel = bodyWidth - scrollPosition; - } - else { - viewportLeftPixel = scrollPosition; - viewportRightPixel = viewportWidth + scrollPosition; - } - var viewportScrolledPastCol = viewportLeftPixel > colLeftPixel; - var viewportScrolledBeforeCol = viewportRightPixel < colRightPixel; - var colToSmallForViewport = viewportWidth < column.getActualWidth(); - var alignColToLeft = viewportScrolledPastCol || colToSmallForViewport; - var alignColToRight = viewportScrolledBeforeCol; - var newScrollPosition = this.getCenterViewportScrollLeft(); - if (alignColToLeft || alignColToRight) { - if (this.enableRtl) { - newScrollPosition = alignColToLeft ? (bodyWidth - viewportWidth - colLeftPixel) : (bodyWidth - colRightPixel); + GridBodyCtrl.prototype.addBodyViewportListener = function () { + var _this = this; + // we want to listen for clicks directly on the eBodyViewport, so the user has a way of showing + // the context menu if no rows or columns are displayed, or user simply clicks outside of a cell + var listener = function (mouseEvent) { + if (_this.gridOptionsWrapper.isPreventDefaultOnContextMenu()) { + mouseEvent.preventDefault(); } - else { - newScrollPosition = alignColToLeft ? colLeftPixel : (colRightPixel - viewportWidth); + var target = mouseEvent.target; + if (target === _this.eBodyViewport || target === _this.ctrlsService.getCenterRowContainerCtrl().getViewportElement()) { + // show it + if (_this.contextMenuFactory) { + _this.contextMenuFactory.onContextMenu(mouseEvent, null, null, null, null, _this.eGridBody); + } } - this.setCenterViewportScrollLeft(newScrollPosition); + }; + this.addManagedListener(this.eBodyViewport, 'contextmenu', listener); + this.addManagedListener(this.eBodyViewport, 'wheel', this.onWheel.bind(this)); + }; + GridBodyCtrl.prototype.onWheel = function (e) { + if (!this.gridOptionsWrapper.isSuppressScrollWhenPopupsAreOpen()) { + return; } - else { - // otherwise, col is already in view, so do nothing + if (this.popupService.hasAnchoredPopup()) { + e.preventDefault(); } - // this will happen anyway, as the move will cause a 'scroll' event on the body, however - // it is possible that the ensureColumnVisible method is called from within ag-Grid and - // the caller will need to have the columns rendered to continue, which will be before - // the event has been worked on (which is the case for cell navigation). - this.onHorizontalViewportChanged(); - // so when we return back to user, the cells have rendered - this.animationFrameService.flushAllFrames(); }; - GridPanel.prototype.showLoadingOverlay = function () { - if (!this.gridOptionsWrapper.isSuppressLoadingOverlay()) { - this.overlayWrapper.showLoadingOverlay(); - } + GridBodyCtrl.prototype.getGui = function () { + return this.eGridBody; }; - GridPanel.prototype.showNoRowsOverlay = function () { - if (!this.gridOptionsWrapper.isSuppressNoRowsOverlay()) { - this.overlayWrapper.showNoRowsOverlay(); - } + // called by rowDragFeature + GridBodyCtrl.prototype.scrollVertically = function (pixels) { + var oldScrollPosition = this.eBodyViewport.scrollTop; + this.bodyScrollFeature.setVerticalScrollPosition(oldScrollPosition + pixels); + return this.eBodyViewport.scrollTop - oldScrollPosition; + }; + GridBodyCtrl.prototype.addRowDragListener = function () { + this.rowDragFeature = this.createManagedBean(new _rowDragFeature__WEBPACK_IMPORTED_MODULE_7__["RowDragFeature"](this.eBodyViewport)); + this.dragAndDropService.addDropTarget(this.rowDragFeature); + }; + GridBodyCtrl.prototype.getRowDragFeature = function () { + return this.rowDragFeature; }; - GridPanel.prototype.hideOverlay = function () { - this.overlayWrapper.hideOverlay(); + GridBodyCtrl.prototype.setFloatingHeights = function () { + var pinnedRowModel = this.pinnedRowModel; + var floatingTopHeight = pinnedRowModel.getPinnedTopTotalHeight(); + if (floatingTopHeight) { + // adding 1px for cell bottom border + floatingTopHeight += 1; + } + var floatingBottomHeight = pinnedRowModel.getPinnedBottomTotalHeight(); + if (floatingBottomHeight) { + // adding 1px for cell bottom border + floatingBottomHeight += 1; + } + this.comp.setTopHeight(floatingTopHeight); + this.comp.setBottomHeight(floatingBottomHeight); + this.comp.setTopDisplay(floatingTopHeight ? 'inherit' : 'none'); + this.comp.setBottomDisplay(floatingBottomHeight ? 'inherit' : 'none'); }; // method will call itself if no available width. this covers if the grid // isn't visible, but is just about to be visible. - GridPanel.prototype.sizeColumnsToFit = function (nextTimeout) { + GridBodyCtrl.prototype.sizeColumnsToFit = function (nextTimeout) { var _this = this; - var availableWidth = this.eBodyViewport.clientWidth; + var removeScrollWidth = this.isVerticalScrollShowing(); + var scrollWidthToRemove = removeScrollWidth ? this.gridOptionsWrapper.getScrollbarWidth() : 0; + var bodyViewportWidth = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["getInnerWidth"])(this.eBodyViewport); + var availableWidth = bodyViewportWidth - scrollWidthToRemove; if (availableWidth > 0) { - this.columnController.sizeColumnsToFit(availableWidth, "sizeColumnsToFit"); + this.columnModel.sizeColumnsToFit(availableWidth, "sizeColumnsToFit"); return; } if (nextTimeout === undefined) { @@ -30402,100 +37353,157 @@ var GridPanel = /** @class */ (function (_super) { }, 500); } else { - console.warn('ag-Grid: tried to call sizeColumnsToFit() but the grid is coming back with ' + + console.warn('AG Grid: tried to call sizeColumnsToFit() but the grid is coming back with ' + 'zero width, maybe the grid is not visible yet on the screen?'); } }; - // used by autoWidthCalculator and autoHeightCalculator - GridPanel.prototype.getCenterContainer = function () { - return this.eCenterContainer; - }; - GridPanel.prototype.getDropTargetBodyContainers = function () { - return [this.eCenterViewport, this.eTopViewport, this.eBottomViewport]; - }; - GridPanel.prototype.getDropTargetLeftContainers = function () { - return [this.eLeftContainer, this.eLeftBottom, this.eLeftTop]; + // + rangeService + GridBodyCtrl.prototype.addScrollEventListener = function (listener) { + this.eBodyViewport.addEventListener('scroll', listener); }; - GridPanel.prototype.getDropTargetRightContainers = function () { - return [this.eRightContainer, this.eRightBottom, this.eRightTop]; + // + focusService + GridBodyCtrl.prototype.removeScrollEventListener = function (listener) { + this.eBodyViewport.removeEventListener('scroll', listener); }; - GridPanel.prototype.buildRowContainerComponents = function () { - var _this = this; - this.eAllCellContainers = [ - this.eLeftContainer, this.eRightContainer, this.eCenterContainer, - this.eTop, this.eBottom, this.eFullWidthContainer - ]; - this.rowContainerComponents = { - body: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ - eContainer: this.eCenterContainer, - eWrapper: this.eCenterColsClipper, - eViewport: this.eBodyViewport - }), - fullWidth: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ - eContainer: this.eFullWidthContainer - }), - pinnedLeft: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ eContainer: this.eLeftContainer }), - pinnedRight: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ eContainer: this.eRightContainer }), - floatingTop: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ eContainer: this.eTopContainer }), - floatingTopPinnedLeft: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ eContainer: this.eLeftTop }), - floatingTopPinnedRight: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ eContainer: this.eRightTop }), - floatingTopFullWidth: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ - eContainer: this.eTopFullWidthContainer, - hideWhenNoChildren: true - }), - floatingBottom: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ eContainer: this.eBottomContainer }), - floatingBottomPinnedLeft: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ eContainer: this.eLeftBottom }), - floatingBottomPinnedRight: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ eContainer: this.eRightBottom }), - floatingBottomFullWidth: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ - eContainer: this.eBottomFullWidthContainer, - hideWhenNoChildren: true - }), - }; - _utils__WEBPACK_IMPORTED_MODULE_12__["_"].iterateObject(this.rowContainerComponents, function (key, container) { - if (container) { - _this.getContext().createBean(container); - } - }); - }; - GridPanel.prototype.setupRowAnimationCssClass = function () { + GridBodyCtrl.prototype.requestAngularApply = function () { var _this = this; - var listener = function () { - // we don't want to use row animation if scaling, as rows jump strangely as you scroll, - // when scaling and doing row animation. - var animateRows = _this.gridOptionsWrapper.isAnimateRows() && !_this.heightScaler.isScaling(); - _utils__WEBPACK_IMPORTED_MODULE_12__["_"].addOrRemoveCssClass(_this.eBodyViewport, 'ag-row-animation', animateRows); - _utils__WEBPACK_IMPORTED_MODULE_12__["_"].addOrRemoveCssClass(_this.eBodyViewport, 'ag-row-no-animation', !animateRows); - }; - listener(); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_HEIGHT_SCALE_CHANGED, listener); + if (this.angularApplyTriggered) { + return; + } + this.angularApplyTriggered = true; + window.setTimeout(function () { + _this.angularApplyTriggered = false; + _this.$scope.$apply(); + }, 0); }; - // when editing a pinned row, if the cell is half outside the scrollable area, the browser can - // scroll the column into view. we do not want this, the pinned sections should never scroll. - // so we listen to scrolls on these containers and reset the scroll if we find one. - GridPanel.prototype.suppressScrollOnFloatingRow = function () { + GridBodyCtrl.prototype.addAngularApplyCheck = function () { var _this = this; - var resetTopScroll = function () { return _this.eTopViewport.scrollLeft = 0; }; - var resetBottomScroll = function () { return _this.eTopViewport.scrollLeft = 0; }; - this.addManagedListener(this.eTopViewport, 'scroll', resetTopScroll); - this.addManagedListener(this.eBottomViewport, 'scroll', resetBottomScroll); - }; - GridPanel.prototype.getRowContainers = function () { - return this.rowContainerComponents; + // these are the events we need to do an apply after - these are the ones that can end up + // with columns added or removed + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, function () { return _this.requestAngularApply(); }); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_VIRTUAL_COLUMNS_CHANGED, function () { return _this.requestAngularApply(); }); }; - GridPanel.prototype.getFloatingTopBottom = function () { - return [this.eTop, this.eBottom]; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowContainerHeightService') + ], GridBodyCtrl.prototype, "rowContainerHeightService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('ctrlsService') + ], GridBodyCtrl.prototype, "ctrlsService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnModel') + ], GridBodyCtrl.prototype, "columnModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('scrollVisibleService') + ], GridBodyCtrl.prototype, "scrollVisibleService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Optional"])('contextMenuFactory') + ], GridBodyCtrl.prototype, "contextMenuFactory", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('headerNavigationService') + ], GridBodyCtrl.prototype, "headerNavigationService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('paginationProxy') + ], GridBodyCtrl.prototype, "paginationProxy", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('dragAndDropService') + ], GridBodyCtrl.prototype, "dragAndDropService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('pinnedRowModel') + ], GridBodyCtrl.prototype, "pinnedRowModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowRenderer') + ], GridBodyCtrl.prototype, "rowRenderer", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('popupService') + ], GridBodyCtrl.prototype, "popupService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('mouseEventService') + ], GridBodyCtrl.prototype, "mouseEventService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('$scope') + ], GridBodyCtrl.prototype, "$scope", void 0); + return GridBodyCtrl; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); + + + +/***/ }), +/* 167 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridBodyScrollFeature", function() { return GridBodyScrollFeature; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(42); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(24); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(14); +/* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(43); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(15); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - GridPanel.prototype.onDisplayedColumnsChanged = function () { - this.setPinnedContainerSize(); - this.setHeaderAndFloatingHeights(); - this.onHorizontalViewportChanged(); - this.updateScrollVisibleService(); - this.updateColumnCount(); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - GridPanel.prototype.onDisplayedColumnsWidthChanged = function () { - this.setWidthsOfContainers(); - this.onHorizontalViewportChanged(); - this.updateScrollVisibleService(); +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + +var GridBodyScrollFeature = /** @class */ (function (_super) { + __extends(GridBodyScrollFeature, _super); + function GridBodyScrollFeature(eBodyViewport) { + var _this = _super.call(this) || this; + _this.scrollLeft = -1; + _this.nextScrollTop = -1; + _this.scrollTop = -1; + _this.eBodyViewport = eBodyViewport; + _this.resetLastHorizontalScrollElementDebounced = Object(_utils_function__WEBPACK_IMPORTED_MODULE_4__["debounce"])(_this.resetLastHorizontalScrollElement.bind(_this), 500); + return _this; + } + GridBodyScrollFeature.prototype.postConstruct = function () { + var _this = this; + this.enableRtl = this.gridOptionsWrapper.isEnableRtl(); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, this.onDisplayedColumnsWidthChanged.bind(this)); + this.ctrlsService.whenReady(function (p) { + _this.centerRowContainerCon = p.centerRowContainerCtrl; + _this.onDisplayedColumnsWidthChanged(); + _this.addScrollListener(); + }); + }; + GridBodyScrollFeature.prototype.addScrollListener = function () { + var fakeHScroll = this.ctrlsService.getFakeHScrollCtrl(); + this.addManagedListener(this.centerRowContainerCon.getViewportElement(), 'scroll', this.onCenterViewportScroll.bind(this)); + this.addManagedListener(fakeHScroll.getViewport(), 'scroll', this.onFakeHorizontalScroll.bind(this)); + var onVerticalScroll = this.gridOptionsWrapper.isDebounceVerticalScrollbar() ? + Object(_utils_function__WEBPACK_IMPORTED_MODULE_4__["debounce"])(this.onVerticalScroll.bind(this), 100) + : this.onVerticalScroll.bind(this); + this.addManagedListener(this.eBodyViewport, 'scroll', onVerticalScroll); + }; + GridBodyScrollFeature.prototype.onDisplayedColumnsWidthChanged = function () { if (this.enableRtl) { // because RTL is all backwards, a change in the width of the row // can cause a change in the scroll position, without a scroll event, @@ -30505,623 +37513,452 @@ var GridPanel = /** @class */ (function (_super) { this.horizontallyScrollHeaderCenterAndFloatingCenter(); } }; - GridPanel.prototype.setWidthsOfContainers = function () { - this.setCenterWidth(); - this.setPinnedContainerSize(); - }; - GridPanel.prototype.setCenterWidth = function () { - var _a = this, headerRootComp = _a.headerRootComp, columnController = _a.columnController; - var width = columnController.getBodyContainerWidth(); - if (this.printLayout) { - var pinnedContainerWidths = columnController.getPinnedLeftContainerWidth() - + columnController.getPinnedRightContainerWidth(); - width += pinnedContainerWidths; - } - headerRootComp.setHeaderContainerWidth(width); - var widthPx = width + "px"; - this.eCenterContainer.style.width = widthPx; - this.eBottomContainer.style.width = widthPx; - this.eTopContainer.style.width = widthPx; - if (!this.printLayout) { - this.eBodyHorizontalScrollContainer.style.width = widthPx; + GridBodyScrollFeature.prototype.horizontallyScrollHeaderCenterAndFloatingCenter = function (scrollLeft) { + // when doing RTL, this method gets called once prematurely + var notYetInitialised = this.centerRowContainerCon == null; + if (notYetInitialised) { + return; } - }; - GridPanel.prototype.setPinnedLeftWidth = function () { - var _this = this; - var oldPinning = this.pinningLeft; - var widthOfCols = this.columnController.getPinnedLeftContainerWidth(); - var newPinning = this.pinningLeft = !this.printLayout && widthOfCols > 0; - var containers = [this.eLeftContainer, this.eLeftTop, this.eLeftBottom]; - if (oldPinning !== newPinning) { - this.headerRootComp.setLeftVisible(newPinning); + if (scrollLeft === undefined) { + scrollLeft = this.centerRowContainerCon.getCenterViewportScrollLeft(); } - containers.forEach(function (e) { return _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setDisplayed(e, _this.pinningLeft); }); - if (newPinning) { - containers.forEach(function (ct) { return _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setFixedWidth(ct, widthOfCols); }); + var offset = this.enableRtl ? scrollLeft : -scrollLeft; + var topCenterContainer = this.ctrlsService.getTopCenterRowContainerCtrl(); + var bottomCenterContainer = this.ctrlsService.getBottomCenterRowContainerCtrl(); + var fakeHScroll = this.ctrlsService.getFakeHScrollCtrl(); + var centerHeaderContainer = this.ctrlsService.getHeaderRowContainerCtrl(); + centerHeaderContainer.setHorizontalScroll(offset); + bottomCenterContainer.setContainerTranslateX(offset); + topCenterContainer.setContainerTranslateX(offset); + var partner = this.lastHorizontalScrollElement === this.centerRowContainerCon.getViewportElement() ? + fakeHScroll.getViewport() : this.centerRowContainerCon.getViewportElement(); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["setScrollLeft"])(partner, Math.abs(scrollLeft), this.enableRtl); + }; + GridBodyScrollFeature.prototype.isControllingScroll = function (eDiv) { + if (!this.lastHorizontalScrollElement) { + this.lastHorizontalScrollElement = eDiv; + return true; } + return eDiv === this.lastHorizontalScrollElement; }; - GridPanel.prototype.setPinnedRightWidth = function () { - var oldPinning = this.pinningRight; - var widthOfCols = this.columnController.getPinnedRightContainerWidth(); - var newPinning = this.pinningRight = !this.printLayout && widthOfCols > 0; - var containers = [this.eRightContainer, this.eRightTop, this.eRightBottom]; - if (oldPinning !== newPinning) { - this.headerRootComp.setRightVisible(newPinning); - } - containers.forEach(function (ct) { return _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setDisplayed(ct, newPinning); }); - if (newPinning) { - containers.forEach(function (ct) { return _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setFixedWidth(ct, widthOfCols); }); + GridBodyScrollFeature.prototype.onFakeHorizontalScroll = function () { + var fakeHScrollViewport = this.ctrlsService.getFakeHScrollCtrl().getViewport(); + if (!this.isControllingScroll(fakeHScrollViewport)) { + return; } + this.onBodyHorizontalScroll(fakeHScrollViewport); }; - GridPanel.prototype.setPinnedContainerSize = function () { - this.setPinnedLeftWidth(); - this.setPinnedRightWidth(); - this.setFakeHScrollSpacerWidths(); - }; - GridPanel.prototype.setFakeHScrollSpacerWidths = function () { - // we pad the right based on a) if cols are pinned to the right and - // b) if v scroll is showing on the right (normal position of scroll) - var rightSpacing = this.columnController.getPinnedRightContainerWidth(); - var scrollOnRight = !this.enableRtl && this.isVerticalScrollShowing(); - if (scrollOnRight) { - rightSpacing += this.scrollWidth; - } - _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setFixedWidth(this.eHorizontalRightSpacer, rightSpacing); - _utils__WEBPACK_IMPORTED_MODULE_12__["_"].addOrRemoveCssClass(this.eHorizontalRightSpacer, 'ag-scroller-corner', rightSpacing <= this.scrollWidth); - // we pad the left based on a) if cols are pinned to the left and - // b) if v scroll is showing on the left (happens in LTR layout only) - var leftSpacing = this.columnController.getPinnedLeftContainerWidth(); - var scrollOnLeft = this.enableRtl && this.isVerticalScrollShowing(); - if (scrollOnLeft) { - leftSpacing += this.scrollWidth; + GridBodyScrollFeature.prototype.onCenterViewportScroll = function () { + var centerContainerViewport = this.centerRowContainerCon.getViewportElement(); + if (!this.isControllingScroll(centerContainerViewport)) { + return; } - _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setFixedWidth(this.eHorizontalLeftSpacer, leftSpacing); - _utils__WEBPACK_IMPORTED_MODULE_12__["_"].addOrRemoveCssClass(this.eHorizontalLeftSpacer, 'ag-scroller-corner', leftSpacing <= this.scrollWidth); + this.onBodyHorizontalScroll(centerContainerViewport); }; - GridPanel.prototype.checkBodyHeight = function () { - var bodyHeight = this.eBodyViewport.clientHeight; - if (this.bodyHeight !== bodyHeight) { - this.bodyHeight = bodyHeight; - var event_3 = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_BODY_HEIGHT_CHANGED, - api: this.gridApi, - columnApi: this.columnApi - }; - this.eventService.dispatchEvent(event_3); + GridBodyScrollFeature.prototype.onBodyHorizontalScroll = function (eSource) { + var centerContainerViewport = this.centerRowContainerCon.getViewportElement(); + var scrollLeft = centerContainerViewport.scrollLeft; + if (this.shouldBlockScrollUpdate('horizontal', scrollLeft, true)) { + return; } + // we do Math.round() rather than Math.floor(), to mirror how scroll values are applied. + // eg if a scale is applied (ie user has zoomed the browser), then applying scroll=200 + // could result in 199.88, which then floor(199.88) = 199, however round(199.88) = 200. + // initially Math.floor() was used, however this caused (almost) infinite loop with aligned grids, + // as the scroll would move 1px at at time bouncing from one grid to the next (eg one grid would cause + // scroll to 200px, the next to 199px, then the first back to 198px and so on). + this.doHorizontalScroll(Math.round(Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["getScrollLeft"])(eSource, this.enableRtl))); + this.resetLastHorizontalScrollElementDebounced(); }; - GridPanel.prototype.setHeaderAndFloatingHeights = function () { - var _a = this, columnController = _a.columnController, gridOptionsWrapper = _a.gridOptionsWrapper, pinnedRowModel = _a.pinnedRowModel, eTop = _a.eTop, eBottom = _a.eBottom; - var numberOfFloating = 0; - var headerRowCount = columnController.getHeaderRowCount(); - var totalHeaderHeight; - var groupHeight; - var headerHeight; - if (columnController.isPivotMode()) { - groupHeight = gridOptionsWrapper.getPivotGroupHeaderHeight(); - headerHeight = gridOptionsWrapper.getPivotHeaderHeight(); - } - else { - var hasFloatingFilters = columnController.hasFloatingFilters(); - if (hasFloatingFilters) { - headerRowCount++; - numberOfFloating = 1; - } - groupHeight = gridOptionsWrapper.getGroupHeaderHeight(); - headerHeight = gridOptionsWrapper.getHeaderHeight(); + GridBodyScrollFeature.prototype.onVerticalScroll = function () { + var scrollTop = this.eBodyViewport.scrollTop; + if (this.shouldBlockScrollUpdate('vertical', scrollTop, true)) { + return; } - var numberOfNonGroups = 1 + numberOfFloating; - var numberOfGroups = headerRowCount - numberOfNonGroups; - totalHeaderHeight = numberOfFloating * gridOptionsWrapper.getFloatingFiltersHeight(); - totalHeaderHeight += numberOfGroups * groupHeight; - totalHeaderHeight += headerHeight; - this.headerRootComp.setHeight(totalHeaderHeight); - var floatingTopHeight = pinnedRowModel.getPinnedTopTotalHeight(); - if (floatingTopHeight) { - // adding 1px for cell bottom border - floatingTopHeight += 1; + this.animationFrameService.setScrollTop(scrollTop); + this.nextScrollTop = scrollTop; + if (this.gridOptionsWrapper.isSuppressAnimationFrame()) { + this.scrollTop = this.nextScrollTop; + this.redrawRowsAfterScroll(); } - var floatingBottomHeight = pinnedRowModel.getPinnedBottomTotalHeight(); - if (floatingBottomHeight) { - // adding 1px for cell bottom border - floatingBottomHeight += 1; + else { + this.animationFrameService.schedule(); } - var floatingTopHeightString = floatingTopHeight + "px"; - var floatingBottomHeightString = floatingBottomHeight + "px"; - eTop.style.minHeight = floatingTopHeightString; - eTop.style.height = floatingTopHeightString; - eTop.style.display = floatingTopHeight ? 'inherit' : 'none'; - eBottom.style.minHeight = floatingBottomHeightString; - eBottom.style.height = floatingBottomHeightString; - eBottom.style.display = floatingBottomHeight ? 'inherit' : 'none'; - this.checkBodyHeight(); - }; - GridPanel.prototype.getBodyHeight = function () { - return this.bodyHeight; - }; - // called by scrollHorizontally method and alignedGridsService - GridPanel.prototype.setHorizontalScrollPosition = function (hScrollPosition) { - this.eCenterViewport.scrollLeft = hScrollPosition; - // we need to manually do the event handling (rather than wait for the event) - // for the alignedGridsService, as if we don't, the aligned grid service gets - // notified async, and then it's 'consuming' flag doesn't get used right, and - // we can end up with an infinite loop - this.doHorizontalScroll(hScrollPosition); - }; - GridPanel.prototype.setVerticalScrollPosition = function (vScrollPosition) { - this.eBodyViewport.scrollTop = vScrollPosition; - }; - // called by the headerRootComp and moveColumnController - GridPanel.prototype.scrollHorizontally = function (pixels) { - var oldScrollPosition = this.eCenterViewport.scrollLeft; - this.setHorizontalScrollPosition(oldScrollPosition + pixels); - return this.eCenterViewport.scrollLeft - oldScrollPosition; - }; - // called by rowDragFeature - GridPanel.prototype.scrollVertically = function (pixels) { - var oldScrollPosition = this.eBodyViewport.scrollTop; - this.setVerticalScrollPosition(oldScrollPosition + pixels); - return this.eBodyViewport.scrollTop - oldScrollPosition; - }; - GridPanel.prototype.addScrollListener = function () { - this.addManagedListener(this.eCenterViewport, 'scroll', this.onCenterViewportScroll.bind(this)); - this.addManagedListener(this.eBodyHorizontalScrollViewport, 'scroll', this.onFakeHorizontalScroll.bind(this)); - this.addManagedListener(this.eBodyViewport, 'scroll', this.onVerticalScroll.bind(this)); }; - GridPanel.prototype.onVerticalScroll = function () { - var scrollTop = this.eBodyViewport.scrollTop; - this.animationFrameService.setScrollTop(scrollTop); - this.scrollTop = scrollTop; - this.redrawRowsAfterScroll(); - }; - GridPanel.prototype.isControllingScroll = function (eDiv) { - if (!this.lastHorizontalScrollElement) { - this.lastHorizontalScrollElement = eDiv; - return true; - } - return eDiv === this.lastHorizontalScrollElement; + GridBodyScrollFeature.prototype.resetLastHorizontalScrollElement = function () { + this.lastHorizontalScrollElement = null; }; - GridPanel.prototype.onFakeHorizontalScroll = function () { - if (!this.isControllingScroll(this.eBodyHorizontalScrollViewport)) { + GridBodyScrollFeature.prototype.doHorizontalScroll = function (scrollLeft) { + var fakeHScrollViewport = this.ctrlsService.getFakeHScrollCtrl().getViewport(); + var fakeScrollLeft = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["getScrollLeft"])(fakeHScrollViewport, this.enableRtl); + if (this.scrollLeft === scrollLeft && scrollLeft === fakeScrollLeft) { return; } - this.onBodyHorizontalScroll(this.eBodyHorizontalScrollViewport); + this.scrollLeft = scrollLeft; + this.fireScrollEvent('horizontal'); + this.horizontallyScrollHeaderCenterAndFloatingCenter(scrollLeft); + this.onHorizontalViewportChanged(); }; - GridPanel.prototype.onCenterViewportScroll = function () { - if (!this.isControllingScroll(this.eCenterViewport)) { - return; - } - this.onBodyHorizontalScroll(this.eCenterViewport); + GridBodyScrollFeature.prototype.fireScrollEvent = function (direction) { + var _this = this; + var bodyScrollEvent = { + type: _eventKeys__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_BODY_SCROLL, + api: this.gridApi, + columnApi: this.columnApi, + direction: direction, + left: this.scrollLeft, + top: this.scrollTop + }; + this.eventService.dispatchEvent(bodyScrollEvent); + window.clearTimeout(this.scrollTimer); + this.scrollTimer = undefined; + this.scrollTimer = window.setTimeout(function () { + var bodyScrollEndEvent = Object.assign({}, bodyScrollEvent, { + type: _eventKeys__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_BODY_SCROLL_END + }); + _this.eventService.dispatchEvent(bodyScrollEndEvent); + }, 100); }; - GridPanel.prototype.onBodyHorizontalScroll = function (eSource) { - var _a = this.eCenterViewport, scrollWidth = _a.scrollWidth, clientWidth = _a.clientWidth; - // in chrome, fractions can be in the scroll left, eg 250.342234 - which messes up our 'scrollWentPastBounds' - // formula. so we floor it to allow the formula to work. - var scrollLeft = Math.floor(_utils__WEBPACK_IMPORTED_MODULE_12__["_"].getScrollLeft(eSource, this.enableRtl)); + GridBodyScrollFeature.prototype.shouldBlockScrollUpdate = function (direction, scrollTo, touchOnly) { // touch devices allow elastic scroll - which temporally scrolls the panel outside of the viewport // (eg user uses touch to go to the left of the grid, but drags past the left, the rows will actually // scroll past the left until the user releases the mouse). when this happens, we want ignore the scroll, // as otherwise it was causing the rows and header to flicker. + if (touchOnly === void 0) { touchOnly = false; } // sometimes when scrolling, we got values that extended the maximum scroll allowed. we used to // ignore these scrolls. problem is the max scroll position could be skipped (eg the previous scroll event // could be 10px before the max position, and then current scroll event could be 20px after the max position). // if we just ignored the last event, we would be setting the scroll to 10px before the max position, when in // actual fact the user has exceeded the max scroll and thus scroll should be set to the max. - var minScroll = 0; - var maxScroll = scrollWidth - clientWidth; - if (scrollLeft < minScroll) { - scrollLeft = minScroll; + if (touchOnly && !Object(_utils_browser__WEBPACK_IMPORTED_MODULE_5__["isIOSUserAgent"])()) { + return false; } - else if (scrollLeft > maxScroll) { - scrollLeft = maxScroll; + if (direction === 'vertical') { + var clientHeight = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["getInnerHeight"])(this.eBodyViewport); + var scrollHeight = this.eBodyViewport.scrollHeight; + if (scrollTo < 0 || (scrollTo + clientHeight > scrollHeight)) { + return true; + } } - this.doHorizontalScroll(scrollLeft); - this.resetLastHorizontalScrollElementDebounced(); - }; - GridPanel.prototype.resetLastHorizontalScrollElement = function () { - this.lastHorizontalScrollElement = null; - }; - GridPanel.prototype.doHorizontalScroll = function (scrollLeft) { - this.scrollLeft = scrollLeft; - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_BODY_SCROLL, - api: this.gridApi, - columnApi: this.columnApi, - direction: 'horizontal', - left: this.scrollLeft, - top: this.scrollTop - }; - this.eventService.dispatchEvent(event); - this.horizontallyScrollHeaderCenterAndFloatingCenter(scrollLeft); - this.onHorizontalViewportChanged(); - }; - GridPanel.prototype.redrawRowsAfterScroll = function () { - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_BODY_SCROLL, - direction: 'vertical', - api: this.gridApi, - columnApi: this.columnApi, - left: this.scrollLeft, - top: this.scrollTop - }; - this.eventService.dispatchEvent(event); - }; - // this gets called whenever a change in the viewport, so we can inform column controller it has to work - // out the virtual columns again. gets called from following locations: - // + ensureColVisible, scroll, init, layoutChanged, displayedColumnsChanged, API (doLayout) - GridPanel.prototype.onHorizontalViewportChanged = function () { - var scrollWidth = this.eCenterViewport.clientWidth; - var scrollPosition = this.getCenterViewportScrollLeft(); - this.columnController.setVirtualViewportPosition(scrollWidth, scrollPosition); + if (direction === 'horizontal') { + var clientWidth = this.centerRowContainerCon.getCenterWidth(); + var scrollWidth = this.centerRowContainerCon.getViewportElement().scrollWidth; + if (this.enableRtl && Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["isRtlNegativeScroll"])()) { + if (scrollTo > 0) { + return true; + } + } + else if (scrollTo < 0) { + return true; + } + if (Math.abs(scrollTo) + clientWidth > scrollWidth) { + return true; + } + } + return false; }; - GridPanel.prototype.getCenterViewportScrollLeft = function () { - // we defer to a util, as how you calculated scrollLeft when doing RTL depends on the browser - return _utils__WEBPACK_IMPORTED_MODULE_12__["_"].getScrollLeft(this.eCenterViewport, this.enableRtl); + GridBodyScrollFeature.prototype.redrawRowsAfterScroll = function () { + this.fireScrollEvent('vertical'); }; - GridPanel.prototype.setCenterViewportScrollLeft = function (value) { - // we defer to a util, as how you calculated scrollLeft when doing RTL depends on the browser - _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setScrollLeft(this.eCenterViewport, value, this.enableRtl); + GridBodyScrollFeature.prototype.onHorizontalViewportChanged = function () { + this.centerRowContainerCon.onHorizontalViewportChanged(); }; - GridPanel.prototype.horizontallyScrollHeaderCenterAndFloatingCenter = function (scrollLeft) { - if (scrollLeft === undefined) { - scrollLeft = this.getCenterViewportScrollLeft(); + // this is to cater for AG-3274, where grid is removed from the dom and then inserted back in again. + // (which happens with some implementations of tabbing). this can result in horizontal scroll getting + // reset back to the left, however no scroll event is fired. so we need to get header to also scroll + // back to the left to be kept in sync. + // adding and removing the grid from the DOM both resets the scroll position and + // triggers a resize event, so notify listeners if the scroll position has changed + GridBodyScrollFeature.prototype.checkScrollLeft = function () { + if (this.scrollLeft !== this.centerRowContainerCon.getCenterViewportScrollLeft()) { + this.onBodyHorizontalScroll(this.centerRowContainerCon.getViewportElement()); } - var offset = this.enableRtl ? scrollLeft : -scrollLeft; - var _a = this.eCenterViewport, clientWidth = _a.clientWidth, scrollWidth = _a.scrollWidth; - var scrollWentPastBounds = Math.abs(offset) + clientWidth > scrollWidth; - if (scrollWentPastBounds || - (this.enableRtl && offset < 0) || - (!this.enableRtl && offset > 0)) { - return; + }; + GridBodyScrollFeature.prototype.executeAnimationFrameScroll = function () { + var frameNeeded = this.scrollTop != this.nextScrollTop; + if (frameNeeded) { + this.scrollTop = this.nextScrollTop; + this.redrawRowsAfterScroll(); } - this.headerRootComp.setHorizontalScroll(offset); - this.eBottomContainer.style.transform = "translateX(" + offset + "px)"; - this.eTopContainer.style.transform = "translateX(" + offset + "px)"; - var partner = this.lastHorizontalScrollElement === this.eCenterViewport ? this.eBodyHorizontalScrollViewport : this.eCenterViewport; - _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setScrollLeft(partner, scrollLeft, this.enableRtl); + return frameNeeded; }; - // + rangeController - GridPanel.prototype.addScrollEventListener = function (listener) { - this.eBodyViewport.addEventListener('scroll', listener); + // called by scrollHorizontally method and alignedGridsService + GridBodyScrollFeature.prototype.setHorizontalScrollPosition = function (hScrollPosition) { + var minScrollLeft = 0; + var maxScrollLeft = this.centerRowContainerCon.getViewportElement().scrollWidth - this.centerRowContainerCon.getCenterWidth(); + if (this.shouldBlockScrollUpdate('horizontal', hScrollPosition)) { + if (this.enableRtl && Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["isRtlNegativeScroll"])()) { + hScrollPosition = hScrollPosition > 0 ? 0 : maxScrollLeft; + } + else { + hScrollPosition = Math.min(Math.max(hScrollPosition, minScrollLeft), maxScrollLeft); + } + } + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["setScrollLeft"])(this.centerRowContainerCon.getViewportElement(), Math.abs(hScrollPosition), this.enableRtl); + // we need to manually do the event handling (rather than wait for the event) + // for the alignedGridsService, as if we don't, the aligned grid service gets + // notified async, and then it's 'consuming' flag doesn't get used right, and + // we can end up with an infinite loop + this.doHorizontalScroll(hScrollPosition); }; - // + rangeController - GridPanel.prototype.removeScrollEventListener = function (listener) { - this.eBodyViewport.removeEventListener('scroll', listener); + GridBodyScrollFeature.prototype.setVerticalScrollPosition = function (vScrollPosition) { + this.eBodyViewport.scrollTop = vScrollPosition; }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('alignedGridsService') - ], GridPanel.prototype, "alignedGridsService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], GridPanel.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowRenderer') - ], GridPanel.prototype, "rowRenderer", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('pinnedRowModel') - ], GridPanel.prototype, "pinnedRowModel", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('animationFrameService') - ], GridPanel.prototype, "animationFrameService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('navigationService') - ], GridPanel.prototype, "navigationService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('autoHeightCalculator') - ], GridPanel.prototype, "autoHeightCalculator", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnAnimationService') - ], GridPanel.prototype, "columnAnimationService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('autoWidthCalculator') - ], GridPanel.prototype, "autoWidthCalculator", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('paginationAutoPageSizeService') - ], GridPanel.prototype, "paginationAutoPageSizeService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('beans') - ], GridPanel.prototype, "beans", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('paginationProxy') - ], GridPanel.prototype, "paginationProxy", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnApi') - ], GridPanel.prototype, "columnApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridApi') - ], GridPanel.prototype, "gridApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('dragService') - ], GridPanel.prototype, "dragService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('mouseEventService') - ], GridPanel.prototype, "mouseEventService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('$scope') - ], GridPanel.prototype, "$scope", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('scrollVisibleService') - ], GridPanel.prototype, "scrollVisibleService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('valueService') - ], GridPanel.prototype, "valueService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('dragAndDropService') - ], GridPanel.prototype, "dragAndDropService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('maxDivHeightScaler') - ], GridPanel.prototype, "heightScaler", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('resizeObserverService') - ], GridPanel.prototype, "resizeObserverService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('undoRedoService') - ], GridPanel.prototype, "undoRedoService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController') - ], GridPanel.prototype, "columnController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('headerNavigationService') - ], GridPanel.prototype, "headerNavigationService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Optional"])('rangeController') - ], GridPanel.prototype, "rangeController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Optional"])('contextMenuFactory') - ], GridPanel.prototype, "contextMenuFactory", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Optional"])('clipboardService') - ], GridPanel.prototype, "clipboardService", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eBodyViewport') - ], GridPanel.prototype, "eBodyViewport", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eCenterContainer') - ], GridPanel.prototype, "eCenterContainer", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eCenterViewport') - ], GridPanel.prototype, "eCenterViewport", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eLeftContainer') - ], GridPanel.prototype, "eLeftContainer", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eRightContainer') - ], GridPanel.prototype, "eRightContainer", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eCenterColsClipper') - ], GridPanel.prototype, "eCenterColsClipper", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eHorizontalScrollBody') - ], GridPanel.prototype, "eHorizontalScrollBody", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eHorizontalLeftSpacer') - ], GridPanel.prototype, "eHorizontalLeftSpacer", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eHorizontalRightSpacer') - ], GridPanel.prototype, "eHorizontalRightSpacer", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eBodyHorizontalScrollViewport') - ], GridPanel.prototype, "eBodyHorizontalScrollViewport", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eBodyHorizontalScrollContainer') - ], GridPanel.prototype, "eBodyHorizontalScrollContainer", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eFullWidthContainer') - ], GridPanel.prototype, "eFullWidthContainer", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eTop') - ], GridPanel.prototype, "eTop", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eLeftTop') - ], GridPanel.prototype, "eLeftTop", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eRightTop') - ], GridPanel.prototype, "eRightTop", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eTopContainer') - ], GridPanel.prototype, "eTopContainer", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eTopViewport') - ], GridPanel.prototype, "eTopViewport", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eTopFullWidthContainer') - ], GridPanel.prototype, "eTopFullWidthContainer", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eBottom') - ], GridPanel.prototype, "eBottom", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eLeftBottom') - ], GridPanel.prototype, "eLeftBottom", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eRightBottom') - ], GridPanel.prototype, "eRightBottom", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eBottomContainer') - ], GridPanel.prototype, "eBottomContainer", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eBottomViewport') - ], GridPanel.prototype, "eBottomViewport", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eBottomFullWidthContainer') - ], GridPanel.prototype, "eBottomFullWidthContainer", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('headerRoot') - ], GridPanel.prototype, "headerRootComp", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('overlayWrapper') - ], GridPanel.prototype, "overlayWrapper", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], GridPanel.prototype, "init", null); - return GridPanel; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_8__["Component"])); - - - -/***/ }), -/* 128 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowContainerComponent", function() { return RowContainerComponent; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(50); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - -/** - * There are many instances of this component covering each of the areas a row can be entered - * eg body, pinned left, fullWidth. The component differs from others in that it's given the - * elements, there is no template. All of the elements are part of the GridPanel. - */ -var RowContainerComponent = /** @class */ (function () { - function RowContainerComponent(params) { - this.childCount = 0; - this.rowTemplatesToAdd = []; - this.afterGuiAttachedCallbacks = []; - // this is to cater for a 'strange behaviour' where when a panel is made visible, it is firing a scroll - // event which we want to ignore. see gridPanel.onAnyBodyScroll() - this.lastMadeVisibleTime = 0; - this.eContainer = params.eContainer; - this.eViewport = params.eViewport; - if (params.eWrapper) { - this.eWrapper = params.eWrapper; - } - this.hideWhenNoChildren = params.hideWhenNoChildren; - } - RowContainerComponent.prototype.setVerticalScrollPosition = function (verticalScrollPosition) { - this.scrollTop = verticalScrollPosition; + GridBodyScrollFeature.prototype.getVScrollPosition = function () { + var result = { + top: this.eBodyViewport.scrollTop, + bottom: this.eBodyViewport.scrollTop + this.eBodyViewport.offsetHeight + }; + return result; }; - RowContainerComponent.prototype.postConstruct = function () { - this.checkDomOrder(); - this.checkVisibility(); - this.gridOptionsWrapper.addEventListener(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_1__["GridOptionsWrapper"].PROP_DOM_LAYOUT, this.checkDomOrder.bind(this)); + GridBodyScrollFeature.prototype.getHScrollPosition = function () { + return this.centerRowContainerCon.getHScrollPosition(); }; - RowContainerComponent.prototype.checkDomOrder = function () { - this.domOrder = this.gridOptionsWrapper.isEnsureDomOrder(); + GridBodyScrollFeature.prototype.isHorizontalScrollShowing = function () { + return this.centerRowContainerCon.isHorizontalScrollShowing(); }; - RowContainerComponent.prototype.getRowElement = function (compId) { - return this.eContainer.querySelector("[comp-id=\"" + compId + "\"]"); + // called by the headerRootComp and moveColumnController + GridBodyScrollFeature.prototype.scrollHorizontally = function (pixels) { + var oldScrollPosition = this.centerRowContainerCon.getViewportElement().scrollLeft; + this.setHorizontalScrollPosition(oldScrollPosition + pixels); + return this.centerRowContainerCon.getViewportElement().scrollLeft - oldScrollPosition; }; - RowContainerComponent.prototype.setHeight = function (height) { - if (height == null) { - this.eContainer.style.height = ''; - return; + // gets called by rowRenderer when new data loaded, as it will want to scroll to the top + GridBodyScrollFeature.prototype.scrollToTop = function () { + this.eBodyViewport.scrollTop = 0; + }; + // Valid values for position are bottom, middle and top + GridBodyScrollFeature.prototype.ensureNodeVisible = function (comparator, position) { + if (position === void 0) { position = null; } + // look for the node index we want to display + var rowCount = this.rowModel.getRowCount(); + var comparatorIsAFunction = typeof comparator === 'function'; + var indexToSelect = -1; + // go through all the nodes, find the one we want to show + for (var i = 0; i < rowCount; i++) { + var node = this.rowModel.getRow(i); + if (comparatorIsAFunction) { + if (comparator(node)) { + indexToSelect = i; + break; + } + } + else { + // check object equality against node and data + if (comparator === node || comparator === node.data) { + indexToSelect = i; + break; + } + } } - this.eContainer.style.height = height + "px"; - if (this.eWrapper) { - this.eWrapper.style.height = height + "px"; + if (indexToSelect >= 0) { + this.ensureIndexVisible(indexToSelect, position); } }; - RowContainerComponent.prototype.flushRowTemplates = function () { - // if doing dom order, then rowTemplates will be empty, - // or if no rows added since last time also empty. - if (this.rowTemplatesToAdd.length !== 0) { - var htmlToAdd = this.rowTemplatesToAdd.join(''); - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].appendHtml(this.eContainer, htmlToAdd); - this.rowTemplatesToAdd.length = 0; + // Valid values for position are bottom, middle and top + // position should be {'top','middle','bottom', or undefined/null}. + // if undefined/null, then the grid will to the minimal amount of scrolling, + // eg if grid needs to scroll up, it scrolls until row is on top, + // if grid needs to scroll down, it scrolls until row is on bottom, + // if row is already in view, grid does not scroll + GridBodyScrollFeature.prototype.ensureIndexVisible = function (index, position) { + // if for print or auto height, everything is always visible + if (this.gridOptionsWrapper.getDomLayout() === _constants_constants__WEBPACK_IMPORTED_MODULE_6__["Constants"].DOM_LAYOUT_PRINT) { + return; } - // this only empty if no rows since last time, as when - // doing dom order, we still have callbacks to process - this.afterGuiAttachedCallbacks.forEach(function (func) { return func(); }); - this.afterGuiAttachedCallbacks.length = 0; - this.lastPlacedElement = null; - }; - RowContainerComponent.prototype.appendRowTemplate = function (rowTemplate, callback) { - if (this.domOrder) { - this.lastPlacedElement = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].insertTemplateWithDomOrder(this.eContainer, rowTemplate, this.lastPlacedElement); + var rowCount = this.paginationProxy.getRowCount(); + if (typeof index !== 'number' || index < 0 || index >= rowCount) { + console.warn('invalid row index for ensureIndexVisible: ' + index); + return; } - else { - this.rowTemplatesToAdd.push(rowTemplate); - } - this.afterGuiAttachedCallbacks.push(callback); - // it is important we put items in in order, so that when we open a row group, - // the new rows are inserted after the opened group, but before the rows below. - // that way, the rows below are over the new rows (as dom renders last in dom over - // items previous in dom), otherwise the child rows would cover the row below and - // that meant the user doesn't see the rows below slide away. - this.childCount++; - this.checkVisibility(); - }; - RowContainerComponent.prototype.ensureDomOrder = function (eRow) { - if (this.domOrder) { - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].ensureDomOrder(this.eContainer, eRow, this.lastPlacedElement); - this.lastPlacedElement = eRow; + var isPaging = this.gridOptionsWrapper.isPagination(); + var paginationPanelEnabled = isPaging && !this.gridOptionsWrapper.isSuppressPaginationPanel(); + if (!paginationPanelEnabled) { + this.paginationProxy.goToPageWithIndex(index); } + var rowNode = this.paginationProxy.getRow(index); + var rowGotShiftedDuringOperation; + do { + var startingRowTop = rowNode.rowTop; + var startingRowHeight = rowNode.rowHeight; + var paginationOffset = this.paginationProxy.getPixelOffset(); + var rowTopPixel = rowNode.rowTop - paginationOffset; + var rowBottomPixel = rowTopPixel + rowNode.rowHeight; + var scrollPosition = this.getVScrollPosition(); + var heightOffset = this.heightScaler.getDivStretchOffset(); + var vScrollTop = scrollPosition.top + heightOffset; + var vScrollBottom = scrollPosition.bottom + heightOffset; + var viewportHeight = vScrollBottom - vScrollTop; + // work out the pixels for top, middle and bottom up front, + // make the if/else below easier to read + var pxTop = this.heightScaler.getScrollPositionForPixel(rowTopPixel); + var pxBottom = this.heightScaler.getScrollPositionForPixel(rowBottomPixel - viewportHeight); + // make sure if middle, the row is not outside the top of the grid + var pxMiddle = Math.min((pxTop + pxBottom) / 2, rowTopPixel); + var rowBelowViewport = vScrollTop > rowTopPixel; + var rowAboveViewport = vScrollBottom < rowBottomPixel; + var newScrollPosition = null; + if (position === 'top') { + newScrollPosition = pxTop; + } + else if (position === 'bottom') { + newScrollPosition = pxBottom; + } + else if (position === 'middle') { + newScrollPosition = pxMiddle; + } + else if (rowBelowViewport) { + // if row is before, scroll up with row at top + newScrollPosition = pxTop; + } + else if (rowAboveViewport) { + // if row is below, scroll down with row at bottom + newScrollPosition = pxBottom; + } + if (newScrollPosition !== null) { + this.eBodyViewport.scrollTop = newScrollPosition; + this.rowRenderer.redrawAfterScroll(); + } + // the row can get shifted if during the rendering (during rowRenderer.redrawAfterScroll()), + // the height of a row changes due to lazy calculation of row heights when using + // colDef.autoHeight or gridOptions.getRowHeight. + // if row was shifted, then the position we scrolled to is incorrect. + rowGotShiftedDuringOperation = (startingRowTop !== rowNode.rowTop) + || (startingRowHeight !== rowNode.rowHeight); + } while (rowGotShiftedDuringOperation); + // so when we return back to user, the cells have rendered + this.animationFrameService.flushAllFrames(); }; - RowContainerComponent.prototype.removeRowElement = function (eRow) { - this.eContainer.removeChild(eRow); - this.childCount--; - this.checkVisibility(); - }; - RowContainerComponent.prototype.checkVisibility = function () { - if (!this.hideWhenNoChildren) { + GridBodyScrollFeature.prototype.ensureColumnVisible = function (key, position) { + if (position === void 0) { position = 'auto'; } + var column = this.columnModel.getGridColumn(key); + if (!column) { return; } - var eGui = this.eViewport ? this.eViewport : this.eContainer; - var visible = this.childCount > 0; - if (this.visible !== visible) { - this.visible = visible; - this.lastMadeVisibleTime = new Date().getTime(); - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].setDisplayed(eGui, visible); - // if we are showing the viewport, then the scroll is always zero, - // so we need to align with the other sections (ie if this is full - // width container, and first time showing a full width row, we need to - // scroll it so full width rows are show in right place alongside the - // body rows). without this, there was an issue with 'loading rows' for - // server side row model, as loading rows are full width, and they were - // not getting displayed in the right location when rows were expanded. - if (visible && this.eViewport) { - this.eViewport.scrollTop = this.scrollTop; - } + // calling ensureColumnVisible on a pinned column doesn't make sense + if (column.isPinned()) { + return; + } + // defensive + if (!this.columnModel.isColumnDisplayed(column)) { + return; + } + var newHorizontalScroll = this.getPositionedHorizontalScroll(column, position); + if (newHorizontalScroll !== null) { + this.centerRowContainerCon.setCenterViewportScrollLeft(newHorizontalScroll); } + // this will happen anyway, as the move will cause a 'scroll' event on the body, however + // it is possible that the ensureColumnVisible method is called from within AG Grid and + // the caller will need to have the columns rendered to continue, which will be before + // the event has been worked on (which is the case for cell navigation). + this.centerRowContainerCon.onHorizontalViewportChanged(); + // so when we return back to user, the cells have rendered + this.animationFrameService.flushAllFrames(); }; - RowContainerComponent.prototype.isMadeVisibleRecently = function () { - var now = new Date().getTime(); - var millisSinceVisible = now - this.lastMadeVisibleTime; - return millisSinceVisible < 500; + GridBodyScrollFeature.prototype.getPositionedHorizontalScroll = function (column, position) { + var _a = this.isColumnOutsideViewport(column), columnBeforeStart = _a.columnBeforeStart, columnAfterEnd = _a.columnAfterEnd; + var viewportTooSmallForColumn = this.centerRowContainerCon.getCenterWidth() < column.getActualWidth(); + var viewportWidth = this.centerRowContainerCon.getCenterWidth(); + var isRtl = this.enableRtl; + var alignColToStart = (isRtl ? columnBeforeStart : columnAfterEnd) || viewportTooSmallForColumn; + var alignColToEnd = isRtl ? columnAfterEnd : columnBeforeStart; + if (position !== 'auto') { + alignColToStart = position === 'start'; + alignColToEnd = position === 'end'; + } + var isMiddle = position === 'middle'; + if (alignColToStart || alignColToEnd || isMiddle) { + var _b = this.getColumnBounds(column), colLeft = _b.colLeft, colMiddle = _b.colMiddle, colRight = _b.colRight; + if (isMiddle) { + return colMiddle - viewportWidth / 2; + } + if (alignColToStart) { + return isRtl ? colRight : colLeft; + } + return isRtl ? (colLeft - viewportWidth) : (colRight - viewportWidth); + } + return null; }; + GridBodyScrollFeature.prototype.isColumnOutsideViewport = function (column) { + var _a = this.getViewportBounds(), viewportStart = _a.start, viewportEnd = _a.end; + var _b = this.getColumnBounds(column), colLeft = _b.colLeft, colRight = _b.colRight; + var isRtl = this.enableRtl; + var columnBeforeStart = isRtl ? (viewportStart > colRight) : (viewportEnd < colRight); + var columnAfterEnd = isRtl ? (viewportEnd < colLeft) : (viewportStart > colLeft); + return { columnBeforeStart: columnBeforeStart, columnAfterEnd: columnAfterEnd }; + }; + GridBodyScrollFeature.prototype.getColumnBounds = function (column) { + var isRtl = this.enableRtl; + var bodyWidth = this.columnModel.getBodyContainerWidth(); + var colWidth = column.getActualWidth(); + var colLeft = column.getLeft(); + var multiplier = isRtl ? -1 : 1; + var colLeftPixel = isRtl ? (bodyWidth - colLeft) : colLeft; + var colRightPixel = colLeftPixel + colWidth * multiplier; + var colMidPixel = colLeftPixel + colWidth / 2 * multiplier; + return { colLeft: colLeftPixel, colMiddle: colMidPixel, colRight: colRightPixel }; + }; + GridBodyScrollFeature.prototype.getViewportBounds = function () { + var viewportWidth = this.centerRowContainerCon.getCenterWidth(); + var scrollPosition = this.centerRowContainerCon.getCenterViewportScrollLeft(); + var viewportStartPixel = scrollPosition; + var viewportEndPixel = viewportWidth + scrollPosition; + return { start: viewportStartPixel, end: viewportEndPixel, width: viewportWidth }; + }; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('ctrlsService') + ], GridBodyScrollFeature.prototype, "ctrlsService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], RowContainerComponent.prototype, "gridOptionsWrapper", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('animationFrameService') + ], GridBodyScrollFeature.prototype, "animationFrameService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') + ], GridBodyScrollFeature.prototype, "columnApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') + ], GridBodyScrollFeature.prototype, "gridApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('paginationProxy') + ], GridBodyScrollFeature.prototype, "paginationProxy", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel') + ], GridBodyScrollFeature.prototype, "rowModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowContainerHeightService') + ], GridBodyScrollFeature.prototype, "heightScaler", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer') + ], GridBodyScrollFeature.prototype, "rowRenderer", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], GridBodyScrollFeature.prototype, "columnModel", void 0); __decorate([ _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], RowContainerComponent.prototype, "postConstruct", null); - return RowContainerComponent; -}()); + ], GridBodyScrollFeature.prototype, "postConstruct", null); + return GridBodyScrollFeature; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 129 */ +/* 168 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowDragFeature", function() { return RowDragFeature; }); -/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(104); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(44); -/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(17); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(41); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(97); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(24); +/* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(94); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(18); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(20); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(14); +/* harmony import */ var _autoScrollService__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(169); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -31155,12 +37992,25 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; -var __spreadArrays = (undefined && undefined.__spreadArrays) || function () { - for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; - for (var r = Array(s), k = 0, i = 0; i < il; i++) - for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) - r[k] = a[j]; - return r; +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; +}; +var __spread = (undefined && undefined.__spread) || function () { + for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); + return ar; }; @@ -31168,39 +38018,57 @@ var __spreadArrays = (undefined && undefined.__spreadArrays) || function () { + + + var RowDragFeature = /** @class */ (function (_super) { __extends(RowDragFeature, _super); - function RowDragFeature(eContainer, gridPanel) { + function RowDragFeature(eContainer) { var _this = _super.call(this) || this; _this.isMultiRowDrag = false; _this.isGridSorted = false; _this.isGridFiltered = false; _this.isRowGroupActive = false; _this.eContainer = eContainer; - _this.gridPanel = gridPanel; return _this; } RowDragFeature.prototype.postConstruct = function () { + var _this = this; if (this.gridOptionsWrapper.isRowModelDefault()) { this.clientSideRowModel = this.rowModel; } + var refreshStatus = function () { + _this.onSortChanged(); + _this.onFilterChanged(); + _this.onRowGroupChanged(); + }; this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_SORT_CHANGED, this.onSortChanged.bind(this)); this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_FILTER_CHANGED, this.onFilterChanged.bind(this)); this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, this.onRowGroupChanged.bind(this)); - this.onSortChanged(); - this.onFilterChanged(); - this.onRowGroupChanged(); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_MODEL_UPDATED, function () { + refreshStatus(); + }); + refreshStatus(); + this.ctrlsService.whenReady(function () { + var gridBodyCon = _this.ctrlsService.getGridBodyCtrl(); + _this.autoScrollService = new _autoScrollService__WEBPACK_IMPORTED_MODULE_8__["AutoScrollService"]({ + scrollContainer: gridBodyCon.getBodyViewportElement(), + scrollAxis: 'y', + getVerticalPosition: function () { return gridBodyCon.getScrollFeature().getVScrollPosition().top; }, + setVerticalPosition: function (position) { return gridBodyCon.getScrollFeature().setVerticalScrollPosition(position); }, + onScrollCallback: function () { _this.onDragging(_this.lastDraggingEvent); } + }); + }); }; RowDragFeature.prototype.onSortChanged = function () { - var sortModel = this.sortController.getSortModel(); - this.isGridSorted = !_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missingOrEmpty(sortModel); + this.isGridSorted = this.sortController.isSortActive(); }; RowDragFeature.prototype.onFilterChanged = function () { this.isGridFiltered = this.filterManager.isAnyFilterPresent(); }; RowDragFeature.prototype.onRowGroupChanged = function () { - var rowGroups = this.columnController.getRowGroupColumns(); - this.isRowGroupActive = !_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missingOrEmpty(rowGroups); + var rowGroups = this.columnModel.getRowGroupColumns(); + this.isRowGroupActive = !Object(_utils_generic__WEBPACK_IMPORTED_MODULE_6__["missingOrEmpty"])(rowGroups); }; RowDragFeature.prototype.getContainer = function () { return this.eContainer; @@ -31219,20 +38087,23 @@ var RowDragFeature = /** @class */ (function (_super) { return this.isGridSorted || this.isGridFiltered || this.isRowGroupActive; }; RowDragFeature.prototype.getRowNodes = function (draggingEvent) { + var _this = this; if (!this.isFromThisGrid(draggingEvent)) { - return draggingEvent.dragItem.rowNodes; + return draggingEvent.dragItem.rowNodes || []; } - var enableMultiRowDragging = this.gridOptionsWrapper.isEnableMultiRowDragging(); - var selectedNodes = this.selectionController.getSelectedNodes(); + var isRowDragMultiRow = this.gridOptionsWrapper.isRowDragMultiRow(); + var selectedNodes = __spread(this.selectionService.getSelectedNodes()).sort(function (a, b) { return _this.getRowIndexNumber(a) - _this.getRowIndexNumber(b); }); var currentNode = draggingEvent.dragItem.rowNode; - if (enableMultiRowDragging && selectedNodes.indexOf(currentNode) !== -1) { + if (isRowDragMultiRow && selectedNodes.indexOf(currentNode) !== -1) { this.isMultiRowDrag = true; - return __spreadArrays(selectedNodes); + return selectedNodes; } this.isMultiRowDrag = false; return [currentNode]; }; RowDragFeature.prototype.onDragEnter = function (draggingEvent) { + // builds a lits of all rows being dragged before firing events + draggingEvent.dragItem.rowNodes = this.getRowNodes(draggingEvent); // when entering, we fire the enter event, then in onEnterOrDragging, // we also fire the move event. so we get both events when entering. this.dispatchGridEvent(_eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DRAG_ENTER, draggingEvent); @@ -31245,10 +38116,12 @@ var RowDragFeature = /** @class */ (function (_super) { this.onEnterOrDragging(draggingEvent); }; RowDragFeature.prototype.isFromThisGrid = function (draggingEvent) { - return this.gridPanel.getGui().contains(draggingEvent.dragSource.eElement); + var dragSourceDomDataKey = draggingEvent.dragSource.dragSourceDomDataKey; + return dragSourceDomDataKey === this.gridOptionsWrapper.getDomDataKey(); }; RowDragFeature.prototype.isDropZoneWithinThisGrid = function (draggingEvent) { - var gridGui = this.gridPanel.getGui(); + var gridBodyCon = this.ctrlsService.getGridBodyCtrl(); + var gridGui = gridBodyCon.getGui(); var dropZoneTarget = draggingEvent.dropZoneTarget; return !gridGui.contains(dropZoneTarget); }; @@ -31261,23 +38134,12 @@ var RowDragFeature = /** @class */ (function (_super) { if (managedDrag) { this.doManagedDrag(draggingEvent, pixel); } - this.checkCenterForScrolling(pixel); + this.autoScrollService.check(draggingEvent.event); }; RowDragFeature.prototype.doManagedDrag = function (draggingEvent, pixel) { - var _this = this; - var rowNodes; var isFromThisGrid = this.isFromThisGrid(draggingEvent); - if (isFromThisGrid) { - rowNodes = [draggingEvent.dragItem.rowNode]; - if (this.isMultiRowDrag) { - rowNodes = __spreadArrays(this.selectionController.getSelectedNodes()).sort(function (a, b) { return _this.getRowIndexNumber(a) - _this.getRowIndexNumber(b); }); - } - draggingEvent.dragItem.rowNodes = rowNodes; - } - else { - rowNodes = draggingEvent.dragItem.rowNodes; - } var managedDrag = this.gridOptionsWrapper.isRowDragManaged(); + var rowNodes = draggingEvent.dragItem.rowNodes; if (managedDrag && this.shouldPreventRowMove()) { return; } @@ -31291,12 +38153,12 @@ var RowDragFeature = /** @class */ (function (_super) { } }; RowDragFeature.prototype.getRowIndexNumber = function (rowNode) { - return parseInt(Object(_utils_array__WEBPACK_IMPORTED_MODULE_3__["last"])(rowNode.getRowIndexString().split('-')), 10); + return parseInt(Object(_utils_array__WEBPACK_IMPORTED_MODULE_4__["last"])(rowNode.getRowIndexString().split('-')), 10); }; RowDragFeature.prototype.moveRowAndClearHighlight = function (draggingEvent) { var _this = this; var lastHighlightedRowNode = this.clientSideRowModel.getLastHighlightedRowNode(); - var isBelow = lastHighlightedRowNode && lastHighlightedRowNode.highlighted === 'below'; + var isBelow = lastHighlightedRowNode && lastHighlightedRowNode.highlighted === _entities_rowNode__WEBPACK_IMPORTED_MODULE_3__["RowHighlightPosition"].Below; var pixel = this.mouseEventService.getNormalisedPosition(draggingEvent).y; var rowNodes = draggingEvent.dragItem.rowNodes; var increment = isBelow ? 1 : 0; @@ -31309,15 +38171,15 @@ var RowDragFeature = /** @class */ (function (_super) { this.moveRows(rowNodes, pixel, increment); } else { - var getRowNodeId_1 = this.gridOptionsWrapper.getRowNodeIdFunc(); + var getRowIdFunc_1 = this.gridOptionsWrapper.getRowIdFunc(); var addIndex = this.clientSideRowModel.getRowIndexAtPixel(pixel) + 1; - if (this.clientSideRowModel.getHighlightPosition(pixel) === 'above') { + if (this.clientSideRowModel.getHighlightPosition(pixel) === _entities_rowNode__WEBPACK_IMPORTED_MODULE_3__["RowHighlightPosition"].Above) { addIndex--; } this.clientSideRowModel.updateRowData({ add: rowNodes .map(function (node) { return node.data; }) - .filter(function (data) { return !_this.clientSideRowModel.getRowNode(getRowNodeId_1 ? getRowNodeId_1(data) : data.id); }), + .filter(function (data) { return !_this.clientSideRowModel.getRowNode(getRowIdFunc_1 ? getRowIdFunc_1({ data: data, level: 0, api: _this.gridApi, columnApi: _this.columnApi }) : data.id); }), addIndex: addIndex }); } @@ -31330,69 +38192,20 @@ var RowDragFeature = /** @class */ (function (_super) { if (increment === void 0) { increment = 0; } var rowWasMoved = this.clientSideRowModel.ensureRowsAtPixel(rowNodes, pixel, increment); if (rowWasMoved) { - this.focusController.clearFocusedCell(); - if (this.rangeController) { - this.rangeController.removeAllCellRanges(); + this.focusService.clearFocusedCell(); + if (this.rangeService) { + this.rangeService.removeAllCellRanges(); } } }; - RowDragFeature.prototype.checkCenterForScrolling = function (pixel) { - // scroll if the mouse is within 50px of the grid edge - var pixelRange = this.gridPanel.getVScrollPosition(); - // console.log(`pixelRange = (${pixelRange.top}, ${pixelRange.bottom})`); - this.needToMoveUp = pixel < (pixelRange.top + 50); - this.needToMoveDown = pixel > (pixelRange.bottom - 50); - // console.log(`needToMoveUp = ${this.needToMoveUp} = pixel < (pixelRange.top + 50) = ${pixel} < (${pixelRange.top} + 50)`); - // console.log(`needToMoveDown = ${this.needToMoveDown} = pixel < (pixelRange.top + 50) = ${pixel} < (${pixelRange.top} + 50)`); - if (this.needToMoveUp || this.needToMoveDown) { - this.ensureIntervalStarted(); - } - else { - this.ensureIntervalCleared(); - } - }; - RowDragFeature.prototype.ensureIntervalStarted = function () { - if (this.movingIntervalId) { - return; - } - this.intervalCount = 0; - this.movingIntervalId = window.setInterval(this.moveInterval.bind(this), 100); - }; - RowDragFeature.prototype.ensureIntervalCleared = function () { - if (!this.moveInterval) { - return; - } - window.clearInterval(this.movingIntervalId); - this.movingIntervalId = null; - }; - RowDragFeature.prototype.moveInterval = function () { - // the amounts we move get bigger at each interval, so the speed accelerates, starting a bit slow - // and getting faster. this is to give smoother user experience. we max at 100px to limit the speed. - var pixelsToMove; - this.intervalCount++; - pixelsToMove = 10 + (this.intervalCount * 5); - if (pixelsToMove > 100) { - pixelsToMove = 100; - } - var pixelsMoved; - if (this.needToMoveDown) { - pixelsMoved = this.gridPanel.scrollVertically(pixelsToMove); - } - else if (this.needToMoveUp) { - pixelsMoved = this.gridPanel.scrollVertically(-pixelsToMove); - } - if (pixelsMoved !== 0) { - this.onDragging(this.lastDraggingEvent); - } - }; RowDragFeature.prototype.addRowDropZone = function (params) { var _this = this; if (!params.getContainer()) { - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].doOnce(function () { return console.warn('ag-Grid: addRowDropZone - A container target needs to be provided'); }, 'add-drop-zone-empty-target'); + Object(_utils_function__WEBPACK_IMPORTED_MODULE_7__["doOnce"])(function () { return console.warn('AG Grid: addRowDropZone - A container target needs to be provided'); }, 'add-drop-zone-empty-target'); return; } if (this.dragAndDropService.findExternalZone(params)) { - console.warn('ag-Grid: addRowDropZone - target already exists in the list of DropZones. Use `removeRowDropZone` before adding it again.'); + console.warn('AG Grid: addRowDropZone - target already exists in the list of DropZones. Use `removeRowDropZone` before adding it again.'); return; } var processedParams = { @@ -31434,7 +38247,7 @@ var RowDragFeature = /** @class */ (function (_super) { var onDragging = this.onDragging.bind(this); var onDragStop = this.onDragStop.bind(this); if (!events) { - return { getContainer: getContainer, onDragEnter: onDragEnter, onDragLeave: onDragLeave, onDragging: onDragging, onDragStop: onDragStop, fromGrid: true }; + return { getContainer: getContainer, onDragEnter: onDragEnter, onDragLeave: onDragLeave, onDragging: onDragging, onDragStop: onDragStop, /* @private */ fromGrid: true }; } return { getContainer: getContainer, @@ -31462,14 +38275,14 @@ var RowDragFeature = /** @class */ (function (_super) { events.onDragStop(_this.draggingToRowDragEvent(_eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DRAG_END, e)); }) : onDragStop, - fromGrid: true + fromGrid: true /* @private */ }; }; RowDragFeature.prototype.draggingToRowDragEvent = function (type, draggingEvent) { var yNormalised = this.mouseEventService.getNormalisedPosition(draggingEvent).y; - var mouseIsPastLastRow = yNormalised > this.rowModel.getCurrentPageHeight(); + var mouseIsPastLastRow = yNormalised > this.paginationProxy.getCurrentPageHeight(); var overIndex = -1; - var overNode = null; + var overNode; if (!mouseIsPastLastRow) { overIndex = this.rowModel.getRowIndexAtPixel(yNormalised); overNode = this.rowModel.getRow(overIndex); @@ -31507,7 +38320,9 @@ var RowDragFeature = /** @class */ (function (_super) { RowDragFeature.prototype.onDragLeave = function (draggingEvent) { this.dispatchGridEvent(_eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DRAG_LEAVE, draggingEvent); this.stopDragging(draggingEvent); - this.clearRowHighlight(); + if (this.gridOptionsWrapper.isRowDragManaged()) { + this.clearRowHighlight(); + } if (this.isFromThisGrid(draggingEvent)) { this.isMultiRowDrag = false; } @@ -31522,7 +38337,7 @@ var RowDragFeature = /** @class */ (function (_super) { } }; RowDragFeature.prototype.stopDragging = function (draggingEvent) { - this.ensureIntervalCleared(); + this.autoScrollService.ensureCleared(); this.getRowNodes(draggingEvent).forEach(function (rowNode) { rowNode.setDragging(false); }); @@ -31534,11 +38349,14 @@ var RowDragFeature = /** @class */ (function (_super) { Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowModel') ], RowDragFeature.prototype, "rowModel", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController') - ], RowDragFeature.prototype, "columnController", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('paginationProxy') + ], RowDragFeature.prototype, "paginationProxy", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnModel') + ], RowDragFeature.prototype, "columnModel", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('focusController') - ], RowDragFeature.prototype, "focusController", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('focusService') + ], RowDragFeature.prototype, "focusService", void 0); __decorate([ Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('sortController') ], RowDragFeature.prototype, "sortController", void 0); @@ -31546,1266 +38364,2128 @@ var RowDragFeature = /** @class */ (function (_super) { Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('filterManager') ], RowDragFeature.prototype, "filterManager", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], RowDragFeature.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('selectionController') - ], RowDragFeature.prototype, "selectionController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Optional"])('rangeController') - ], RowDragFeature.prototype, "rangeController", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('selectionService') + ], RowDragFeature.prototype, "selectionService", void 0); __decorate([ Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('mouseEventService') ], RowDragFeature.prototype, "mouseEventService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('ctrlsService') + ], RowDragFeature.prototype, "ctrlsService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Optional"])('rangeService') + ], RowDragFeature.prototype, "rangeService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnApi') + ], RowDragFeature.prototype, "columnApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridApi') + ], RowDragFeature.prototype, "gridApi", void 0); __decorate([ _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] ], RowDragFeature.prototype, "postConstruct", null); return RowDragFeature; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_4__["BeanStub"])); +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_5__["BeanStub"])); /***/ }), -/* 130 */ +/* 169 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridApi", function() { return GridApi; }); -/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(50); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(25); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37); -/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(38); -/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(39); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AutoScrollService", function() { return AutoScrollService; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var AutoScrollService = /** @class */ (function () { + function AutoScrollService(params) { + this.tickingInterval = null; + this.onScrollCallback = null; + this.scrollContainer = params.scrollContainer; + this.scrollHorizontally = params.scrollAxis.indexOf('x') !== -1; + this.scrollVertically = params.scrollAxis.indexOf('y') !== -1; + this.scrollByTick = params.scrollByTick != null ? params.scrollByTick : 20; + if (params.onScrollCallback) { + this.onScrollCallback = params.onScrollCallback; + } + if (this.scrollVertically) { + this.getVerticalPosition = params.getVerticalPosition; + this.setVerticalPosition = params.setVerticalPosition; + } + if (this.scrollHorizontally) { + this.getHorizontalPosition = params.getHorizontalPosition; + this.setHorizontalPosition = params.setHorizontalPosition; + } + this.shouldSkipVerticalScroll = params.shouldSkipVerticalScroll || (function () { return false; }); + this.shouldSkipHorizontalScroll = params.shouldSkipHorizontalScroll || (function () { return false; }); + } + AutoScrollService.prototype.check = function (mouseEvent, forceSkipVerticalScroll) { + if (forceSkipVerticalScroll === void 0) { forceSkipVerticalScroll = false; } + var skipVerticalScroll = forceSkipVerticalScroll || this.shouldSkipVerticalScroll(); + if (skipVerticalScroll && this.shouldSkipHorizontalScroll()) { + return; + } + var rect = this.scrollContainer.getBoundingClientRect(); + var scrollTick = this.scrollByTick; + this.tickLeft = mouseEvent.clientX < (rect.left + scrollTick); + this.tickRight = mouseEvent.clientX > (rect.right - scrollTick); + this.tickUp = mouseEvent.clientY < (rect.top + scrollTick) && !skipVerticalScroll; + this.tickDown = mouseEvent.clientY > (rect.bottom - scrollTick) && !skipVerticalScroll; + if (this.tickLeft || this.tickRight || this.tickUp || this.tickDown) { + this.ensureTickingStarted(); + } + else { + this.ensureCleared(); + } + }; + AutoScrollService.prototype.ensureTickingStarted = function () { + if (this.tickingInterval === null) { + this.tickingInterval = window.setInterval(this.doTick.bind(this), 100); + this.tickCount = 0; + } + }; + AutoScrollService.prototype.doTick = function () { + this.tickCount++; + var tickAmount; + tickAmount = this.tickCount > 20 ? 200 : (this.tickCount > 10 ? 80 : 40); + if (this.scrollVertically) { + var vScrollPosition = this.getVerticalPosition(); + if (this.tickUp) { + this.setVerticalPosition(vScrollPosition - tickAmount); + } + if (this.tickDown) { + this.setVerticalPosition(vScrollPosition + tickAmount); + } + } + if (this.scrollHorizontally) { + var hScrollPosition = this.getHorizontalPosition(); + if (this.tickLeft) { + this.setHorizontalPosition(hScrollPosition - tickAmount); + } + if (this.tickRight) { + this.setHorizontalPosition(hScrollPosition + tickAmount); + } + } + if (this.onScrollCallback) { + this.onScrollCallback(); + } + }; + AutoScrollService.prototype.ensureCleared = function () { + if (this.tickingInterval) { + window.clearInterval(this.tickingInterval); + this.tickingInterval = null; + } + }; + return AutoScrollService; +}()); + + + +/***/ }), +/* 170 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ExpressionService", function() { return ExpressionService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; +var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { + return function (target, key) { decorator(target, key, paramIndex); } +}; - - - -var GridApi = /** @class */ (function () { - function GridApi() { - this.detailGridInfoMap = {}; - this.destroyCalled = false; +var ExpressionService = /** @class */ (function (_super) { + __extends(ExpressionService, _super); + function ExpressionService() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.expressionToFunctionCache = {}; + return _this; } - GridApi.prototype.registerGridComp = function (gridPanel) { - this.gridPanel = gridPanel; - }; - GridApi.prototype.registerGridCore = function (gridCore) { - this.gridCore = gridCore; - }; - GridApi.prototype.registerHeaderRootComp = function (headerRootComp) { - this.headerRootComp = headerRootComp; + ExpressionService.prototype.setBeans = function (loggerFactory) { + this.logger = loggerFactory.create('ExpressionService'); }; - GridApi.prototype.init = function () { - switch (this.rowModel.getType()) { - case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE: - this.clientSideRowModel = this.rowModel; - break; - case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_INFINITE: - this.infiniteRowModel = this.rowModel; - break; - case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE: - this.serverSideRowModel = this.rowModel; - break; + ExpressionService.prototype.evaluate = function (expressionOrFunc, params) { + if (typeof expressionOrFunc === 'function') { + // valueGetter is a function, so just call it + var func = expressionOrFunc; + return func(params); + } + else if (typeof expressionOrFunc === 'string') { + // valueGetter is an expression, so execute the expression + var expression = expressionOrFunc; + return this.evaluateExpression(expression, params); + } + else { + console.error('AG Grid: value should be either a string or a function', expressionOrFunc); } }; - /** Used internally by grid. Not intended to be used by the client. Interface may change between releases. */ - GridApi.prototype.__getAlignedGridService = function () { - return this.alignedGridsService; + ExpressionService.prototype.evaluateExpression = function (expression, params) { + try { + var javaScriptFunction = this.createExpressionFunction(expression); + // the params don't have all these values, rather we add every possible + // value a params can have, which makes whatever is in the params available. + var result = javaScriptFunction(params.value, params.context, params.oldValue, params.newValue, params.value, params.node, params.data, params.colDef, params.rowIndex, params.api, params.columnApi, params.getValue, params.column, params.columnGroup); + return result; + } + catch (e) { + // the expression failed, which can happen, as it's the client that + // provides the expression. so print a nice message + // tslint:disable-next-line + console.log('Processing of the expression failed'); + // tslint:disable-next-line + console.log('Expression = ' + expression); + // tslint:disable-next-line + console.log('Params =', params); + // tslint:disable-next-line + console.log('Exception = ' + e); + return null; + } }; - GridApi.prototype.addDetailGridInfo = function (id, gridInfo) { - this.detailGridInfoMap[id] = gridInfo; + ExpressionService.prototype.createExpressionFunction = function (expression) { + // check cache first + if (this.expressionToFunctionCache[expression]) { + return this.expressionToFunctionCache[expression]; + } + // if not found in cache, return the function + var functionBody = this.createFunctionBody(expression); + var theFunction = new Function('x, ctx, oldValue, newValue, value, node, data, colDef, rowIndex, api, columnApi, getValue, column, columnGroup', functionBody); + // store in cache + this.expressionToFunctionCache[expression] = theFunction; + return theFunction; }; - GridApi.prototype.removeDetailGridInfo = function (id) { - this.detailGridInfoMap[id] = undefined; + ExpressionService.prototype.createFunctionBody = function (expression) { + // if the expression has the 'return' word in it, then use as is, + // if not, then wrap it with return and ';' to make a function + if (expression.indexOf('return') >= 0) { + return expression; + } + else { + return 'return ' + expression + ';'; + } }; - GridApi.prototype.getDetailGridInfo = function (id) { - return this.detailGridInfoMap[id]; + __decorate([ + __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('loggerFactory')) + ], ExpressionService.prototype, "setBeans", null); + ExpressionService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('expressionService') + ], ExpressionService); + return ExpressionService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + + + +/***/ }), +/* 171 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TemplateService", function() { return TemplateService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - GridApi.prototype.forEachDetailGridInfo = function (callback) { - var index = 0; - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(this.detailGridInfoMap, function (id, gridInfo) { - // check for undefined, as old references will still be lying around - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(gridInfo)) { - callback(gridInfo, index); - index++; - } - }); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - GridApi.prototype.getDataAsCsv = function (params) { - if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].CsvExportModule, 'api.getDataAsCsv')) { - return this.csvCreator.getDataAsCsv(params); +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + +var TemplateService = /** @class */ (function (_super) { + __extends(TemplateService, _super); + function TemplateService() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.templateCache = {}; + _this.waitingCallbacks = {}; + return _this; + } + // returns the template if it is loaded, or null if it is not loaded + // but will call the callback when it is loaded + TemplateService.prototype.getTemplate = function (url, callback) { + var templateFromCache = this.templateCache[url]; + if (templateFromCache) { + return templateFromCache; } - }; - GridApi.prototype.exportDataAsCsv = function (params) { - if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].CsvExportModule, 'api.exportDataAsCSv')) { - this.csvCreator.exportDataAsCsv(params); + var callbackList = this.waitingCallbacks[url]; + var that = this; + if (!callbackList) { + // first time this was called, so need a new list for callbacks + callbackList = []; + this.waitingCallbacks[url] = callbackList; + // and also need to do the http request + var client = new XMLHttpRequest(); + client.onload = function () { + that.handleHttpResult(this, url); + }; + client.open("GET", url); + client.send(); } - }; - GridApi.prototype.getDataAsExcel = function (params) { - if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].ExcelExportModule, 'api.getDataAsExcel')) { - return this.excelCreator.getDataAsExcelXml(params); + // add this callback + if (callback) { + callbackList.push(callback); } + // caller needs to wait for template to load, so return null + return null; }; - GridApi.prototype.exportDataAsExcel = function (params) { - if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].ExcelExportModule, 'api.exportDataAsExcel')) { - this.excelCreator.exportDataAsExcel(params); + TemplateService.prototype.handleHttpResult = function (httpResult, url) { + if (httpResult.status !== 200 || httpResult.response === null) { + console.warn("AG Grid: Unable to get template error " + httpResult.status + " - " + url); + return; } - }; - /** @deprecated */ - GridApi.prototype.setEnterpriseDatasource = function (datasource) { - console.warn("ag-grid: since version 18.x, api.setEnterpriseDatasource() should be replaced with api.setServerSideDatasource()"); - this.setServerSideDatasource(datasource); - }; - GridApi.prototype.setServerSideDatasource = function (datasource) { - if (this.gridOptionsWrapper.isRowModelServerSide()) { - // should really have an IEnterpriseRowModel interface, so we are not casting to any - this.rowModel.setDatasource(datasource); + // response success, so process it + // in IE9 the response is in - responseText + this.templateCache[url] = httpResult.response || httpResult.responseText; + // inform all listeners that this is now in the cache + var callbacks = this.waitingCallbacks[url]; + for (var i = 0; i < callbacks.length; i++) { + var callback = callbacks[i]; + // we could pass the callback the response, however we know the client of this code + // is the cell renderer, and it passes the 'cellRefresh' method in as the callback + // which doesn't take any parameters. + callback(); } - else { - console.warn("ag-Grid: you can only use an enterprise datasource when gridOptions.rowModelType is '" + _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE + "'"); + if (this.$scope) { + var that_1 = this; + window.setTimeout(function () { + that_1.$scope.$apply(); + }, 0); } }; - GridApi.prototype.setDatasource = function (datasource) { - if (this.gridOptionsWrapper.isRowModelInfinite()) { - this.rowModel.setDatasource(datasource); - } - else { - console.warn("ag-Grid: you can only use a datasource when gridOptions.rowModelType is '" + _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_INFINITE + "'"); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('$scope') + ], TemplateService.prototype, "$scope", void 0); + TemplateService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('templateService') + ], TemplateService); + return TemplateService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + + + +/***/ }), +/* 172 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PopupService", function() { return PopupService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(23); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(20); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(42); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(18); +/* harmony import */ var _utils_event__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(21); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(65); +/* harmony import */ var _focusService__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(173); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(37); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(44); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + + + + +var DIRECTION; +(function (DIRECTION) { + DIRECTION[DIRECTION["vertical"] = 0] = "vertical"; + DIRECTION[DIRECTION["horizontal"] = 1] = "horizontal"; +})(DIRECTION || (DIRECTION = {})); +var instanceIdSeq = 0; +var PopupService = /** @class */ (function (_super) { + __extends(PopupService, _super); + function PopupService() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.popupList = []; + return _this; + } + PopupService.prototype.postConstruct = function () { + var _this = this; + this.ctrlsService.whenReady(function (p) { + _this.gridCtrl = p.gridCtrl; + _this.addManagedListener(_this.gridCtrl, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_KEYBOARD_FOCUS, function () { + _this.popupList.forEach(function (popup) { return popup.element.classList.add(_focusService__WEBPACK_IMPORTED_MODULE_7__["FocusService"].AG_KEYBOARD_FOCUS); }); + }); + _this.addManagedListener(_this.gridCtrl, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_MOUSE_FOCUS, function () { + _this.popupList.forEach(function (popup) { return popup.element.classList.remove(_focusService__WEBPACK_IMPORTED_MODULE_7__["FocusService"].AG_KEYBOARD_FOCUS); }); + }); + }); + }; + PopupService.prototype.getPopupParent = function () { + var ePopupParent = this.gridOptionsWrapper.getPopupParent(); + if (ePopupParent) { + return ePopupParent; } + return this.gridCtrl.getGui(); }; - GridApi.prototype.setViewportDatasource = function (viewportDatasource) { - if (this.gridOptionsWrapper.isRowModelViewport()) { - // this is bad coding, because it's using an interface that's exposed in the enterprise. - // really we should create an interface in the core for viewportDatasource and let - // the enterprise implement it, rather than casting to 'any' here - this.rowModel.setViewportDatasource(viewportDatasource); + PopupService.prototype.positionPopupForMenu = function (params) { + var sourceRect = params.eventSource.getBoundingClientRect(); + var parentRect = this.getParentRect(); + var y = this.keepXYWithinBounds(params.ePopup, sourceRect.top - parentRect.top, DIRECTION.vertical); + var minWidth = (params.ePopup.clientWidth > 0) ? params.ePopup.clientWidth : 200; + params.ePopup.style.minWidth = minWidth + "px"; + var widthOfParent = parentRect.right - parentRect.left; + var maxX = widthOfParent - minWidth; + // the x position of the popup depends on RTL or LTR. for normal cases, LTR, we put the child popup + // to the right, unless it doesn't fit and we then put it to the left. for RTL it's the other way around, + // we try place it first to the left, and then if not to the right. + var x; + if (this.gridOptionsWrapper.isEnableRtl()) { + // for RTL, try left first + x = xLeftPosition(); + if (x < 0) { + x = xRightPosition(); + } + if (x > maxX) { + x = 0; + } } else { - console.warn("ag-Grid: you can only use a viewport datasource when gridOptions.rowModelType is '" + _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_VIEWPORT + "'"); - } - }; - GridApi.prototype.setRowData = function (rowData) { - if (this.gridOptionsWrapper.isRowModelDefault()) { - if (this.gridOptionsWrapper.isImmutableData()) { - var res = this.immutableService.createTransactionForRowData(rowData); - if (!res) { - return; - } - var transaction = res[0], orderIdMap = res[1]; - this.clientSideRowModel.updateRowData(transaction, orderIdMap); - // need to force updating of full width rows - note this wouldn't be necessary the full width cell comp listened - // to the data change event on the row node and refreshed itself. - this.rowRenderer.refreshFullWidthRows(); + // for LTR, try right first + x = xRightPosition(); + if (x > maxX) { + x = xLeftPosition(); } - else { - this.selectionController.reset(); - this.clientSideRowModel.setRowData(rowData); + if (x < 0) { + x = 0; } } - else { - console.warn('cannot call setRowData unless using normal row model'); + params.ePopup.style.left = x + "px"; + params.ePopup.style.top = y + "px"; + function xRightPosition() { + return sourceRect.right - parentRect.left - 2; + } + function xLeftPosition() { + return sourceRect.left - parentRect.left - minWidth; } }; - /** @deprecated */ - GridApi.prototype.setFloatingTopRowData = function (rows) { - console.warn('ag-Grid: since v12, api.setFloatingTopRowData() is now api.setPinnedTopRowData()'); - this.setPinnedTopRowData(rows); - }; - /** @deprecated */ - GridApi.prototype.setFloatingBottomRowData = function (rows) { - console.warn('ag-Grid: since v12, api.setFloatingBottomRowData() is now api.setPinnedBottomRowData()'); - this.setPinnedBottomRowData(rows); - }; - /** @deprecated */ - GridApi.prototype.getFloatingTopRowCount = function () { - console.warn('ag-Grid: since v12, api.getFloatingTopRowCount() is now api.getPinnedTopRowCount()'); - return this.getPinnedTopRowCount(); - }; - /** @deprecated */ - GridApi.prototype.getFloatingBottomRowCount = function () { - console.warn('ag-Grid: since v12, api.getFloatingBottomRowCount() is now api.getPinnedBottomRowCount()'); - return this.getPinnedBottomRowCount(); - }; - /** @deprecated */ - GridApi.prototype.getFloatingTopRow = function (index) { - console.warn('ag-Grid: since v12, api.getFloatingTopRow() is now api.getPinnedTopRow()'); - return this.getPinnedTopRow(index); - }; - /** @deprecated */ - GridApi.prototype.getFloatingBottomRow = function (index) { - console.warn('ag-Grid: since v12, api.getFloatingBottomRow() is now api.getPinnedBottomRow()'); - return this.getPinnedBottomRow(index); - }; - GridApi.prototype.setPinnedTopRowData = function (rows) { - this.pinnedRowModel.setPinnedTopRowData(rows); - }; - GridApi.prototype.setPinnedBottomRowData = function (rows) { - this.pinnedRowModel.setPinnedBottomRowData(rows); - }; - GridApi.prototype.getPinnedTopRowCount = function () { - return this.pinnedRowModel.getPinnedTopRowCount(); - }; - GridApi.prototype.getPinnedBottomRowCount = function () { - return this.pinnedRowModel.getPinnedBottomRowCount(); - }; - GridApi.prototype.getPinnedTopRow = function (index) { - return this.pinnedRowModel.getPinnedTopRow(index); - }; - GridApi.prototype.getPinnedBottomRow = function (index) { - return this.pinnedRowModel.getPinnedBottomRow(index); - }; - GridApi.prototype.setColumnDefs = function (colDefs, source) { - if (source === void 0) { source = "api"; } - this.columnController.setColumnDefs(colDefs, source); - }; - GridApi.prototype.setAutoGroupColumnDef = function (colDef, source) { - if (source === void 0) { source = "api"; } - this.gridOptionsWrapper.setProperty('autoGroupColumnDef', colDef, true); - }; - GridApi.prototype.expireValueCache = function () { - this.valueCache.expire(); - }; - GridApi.prototype.getVerticalPixelRange = function () { - return this.gridPanel.getVScrollPosition(); - }; - GridApi.prototype.getHorizontalPixelRange = function () { - return this.gridPanel.getHScrollPosition(); - }; - GridApi.prototype.setAlwaysShowVerticalScroll = function (show) { - this.gridOptionsWrapper.setProperty('alwaysShowVerticalScroll', show); + PopupService.prototype.positionPopupUnderMouseEvent = function (params) { + var ePopup = params.ePopup, nudgeX = params.nudgeX, nudgeY = params.nudgeY; + var _a = this.calculatePointerAlign(params.mouseEvent), x = _a.x, y = _a.y; + this.positionPopup({ + ePopup: ePopup, + x: x, + y: y, + nudgeX: nudgeX, + nudgeY: nudgeY, + keepWithinBounds: true + }); + this.callPostProcessPopup(params.type, params.ePopup, null, params.mouseEvent, params.column, params.rowNode); }; - GridApi.prototype.refreshToolPanel = function () { - this.gridCore.refreshSideBar(); + PopupService.prototype.calculatePointerAlign = function (e) { + var parentRect = this.getParentRect(); + return { + x: e.clientX - parentRect.left, + y: e.clientY - parentRect.top + }; }; - GridApi.prototype.refreshCells = function (params) { - if (params === void 0) { params = {}; } - if (Array.isArray(params)) { - // the old version of refreshCells() took an array of rowNodes for the first argument - console.warn('since ag-Grid v11.1, refreshCells() now takes parameters, please see the documentation.'); - return; + PopupService.prototype.positionPopupUnderComponent = function (params) { + var sourceRect = params.eventSource.getBoundingClientRect(); + var alignSide = params.alignSide || 'left'; + var parentRect = this.getParentRect(); + var x = sourceRect.left - parentRect.left; + if (alignSide === 'right') { + x -= (params.ePopup.offsetWidth - sourceRect.width); } - this.rowRenderer.refreshCells(params); + this.positionPopup({ + ePopup: params.ePopup, + nudgeX: params.nudgeX, + nudgeY: params.nudgeY, + x: x, + y: sourceRect.top - parentRect.top + sourceRect.height, + keepWithinBounds: params.keepWithinBounds + }); + this.callPostProcessPopup(params.type, params.ePopup, params.eventSource, null, params.column, params.rowNode); }; - GridApi.prototype.flashCells = function (params) { - if (params === void 0) { params = {}; } - this.rowRenderer.flashCells(params); + PopupService.prototype.positionPopupOverComponent = function (params) { + var sourceRect = params.eventSource.getBoundingClientRect(); + var parentRect = this.getParentRect(); + this.positionPopup({ + ePopup: params.ePopup, + nudgeX: params.nudgeX, + nudgeY: params.nudgeY, + x: sourceRect.left - parentRect.left, + y: sourceRect.top - parentRect.top, + keepWithinBounds: params.keepWithinBounds + }); + this.callPostProcessPopup(params.type, params.ePopup, params.eventSource, null, params.column, params.rowNode); }; - GridApi.prototype.redrawRows = function (params) { - if (params === void 0) { params = {}; } - if (params && params.rowNodes) { - this.rowRenderer.redrawRows(params.rowNodes); - } - else { - this.rowRenderer.redrawAfterModelUpdate(); + PopupService.prototype.callPostProcessPopup = function (type, ePopup, eventSource, mouseEvent, column, rowNode) { + var callback = this.gridOptionsWrapper.getPostProcessPopupFunc(); + if (callback) { + var params = { + column: column, + rowNode: rowNode, + ePopup: ePopup, + type: type, + eventSource: eventSource, + mouseEvent: mouseEvent + }; + callback(params); } }; - GridApi.prototype.timeFullRedraw = function (count) { - if (count === void 0) { count = 1; } - var iterationCount = 0; - var totalProcessing = 0; - var totalReflow = 0; - var that = this; - doOneIteration(); - function doOneIteration() { - var start = (new Date()).getTime(); - that.rowRenderer.redrawAfterModelUpdate(); - var endProcessing = (new Date()).getTime(); - window.setTimeout(function () { - var endReflow = (new Date()).getTime(); - var durationProcessing = endProcessing - start; - var durationReflow = endReflow - endProcessing; - // tslint:disable-next-line - console.log('duration: processing = ' + durationProcessing + 'ms, reflow = ' + durationReflow + 'ms'); - iterationCount++; - totalProcessing += durationProcessing; - totalReflow += durationReflow; - if (iterationCount < count) { - // wait for 1s between tests - window.setTimeout(doOneIteration, 1000); - } - else { - finish(); - } - }, 0); + PopupService.prototype.positionPopup = function (params) { + var ePopup = params.ePopup, keepWithinBounds = params.keepWithinBounds, nudgeX = params.nudgeX, nudgeY = params.nudgeY; + var x = params.x, y = params.y; + if (nudgeX) { + x += nudgeX; } - function finish() { - // tslint:disable-next-line - console.log('tests complete. iteration count = ' + iterationCount); - // tslint:disable-next-line - console.log('average processing = ' + (totalProcessing / iterationCount) + 'ms'); - // tslint:disable-next-line - console.log('average reflow = ' + (totalReflow / iterationCount) + 'ms'); + if (nudgeY) { + y += nudgeY; } + // if popup is overflowing to the bottom, move it up + if (keepWithinBounds) { + x = this.keepXYWithinBounds(ePopup, x, DIRECTION.horizontal); + y = this.keepXYWithinBounds(ePopup, y, DIRECTION.vertical); + } + ePopup.style.left = x + "px"; + ePopup.style.top = y + "px"; }; - /** @deprecated */ - GridApi.prototype.refreshView = function () { - console.warn('ag-Grid: since v11.1, refreshView() is deprecated, please call refreshCells() or redrawRows() instead'); - this.redrawRows(); - }; - /** @deprecated */ - GridApi.prototype.refreshRows = function (rowNodes) { - console.warn('since ag-Grid v11.1, refreshRows() is deprecated, please use refreshCells({rowNodes: rows}) or redrawRows({rowNodes: rows}) instead'); - this.refreshCells({ rowNodes: rowNodes }); - }; - /** @deprecated */ - GridApi.prototype.rowDataChanged = function (rows) { - console.warn('ag-Grid: rowDataChanged is deprecated, either call refreshView() to refresh everything, or call rowNode.setRowData(newData) to set value on a particular node'); - this.redrawRows(); - }; - /** @deprecated */ - GridApi.prototype.softRefreshView = function () { - console.error('ag-Grid: since v16, softRefreshView() is no longer supported. Please check the documentation on how to refresh.'); - }; - /** @deprecated */ - GridApi.prototype.refreshGroupRows = function () { - console.warn('ag-Grid: since v11.1, refreshGroupRows() is no longer supported, call refreshCells() instead. ' + - 'Because refreshCells() now does dirty checking, it will only refresh cells that have changed, so it should ' + - 'not be necessary to only refresh the group rows.'); - this.refreshCells(); - }; - GridApi.prototype.setFunctionsReadOnly = function (readOnly) { - this.gridOptionsWrapper.setProperty('functionsReadOnly', readOnly); - }; - GridApi.prototype.refreshHeader = function () { - this.headerRootComp.refreshHeader(); - this.gridPanel.setHeaderAndFloatingHeights(); - }; - GridApi.prototype.isAnyFilterPresent = function () { - return this.filterManager.isAnyFilterPresent(); - }; - /** @deprecated */ - GridApi.prototype.isAdvancedFilterPresent = function () { - console.warn('ag-Grid: isAdvancedFilterPresent() is deprecated, please use isColumnFilterPresent()'); - return this.isColumnFilterPresent(); + PopupService.prototype.getActivePopups = function () { + return this.popupList.map(function (popup) { return popup.element; }); }; - GridApi.prototype.isColumnFilterPresent = function () { - return this.filterManager.isAdvancedFilterPresent(); + PopupService.prototype.getPopupList = function () { + return this.popupList; }; - GridApi.prototype.isQuickFilterPresent = function () { - return this.filterManager.isQuickFilterPresent(); + PopupService.prototype.getParentRect = function () { + // subtract the popup parent borders, because popupParent.getBoundingClientRect + // returns the rect outside the borders, but the 0,0 coordinate for absolute + // positioning is inside the border, leading the popup to be off by the width + // of the border + var eDocument = this.gridOptionsWrapper.getDocument(); + var popupParent = this.getPopupParent(); + if (popupParent === eDocument.body) { + popupParent = eDocument.documentElement; + } + var style = getComputedStyle(popupParent); + var bounds = popupParent.getBoundingClientRect(); + return { + top: bounds.top + parseFloat(style.borderTopWidth) || 0, + left: bounds.left + parseFloat(style.borderLeftWidth) || 0, + right: bounds.right + parseFloat(style.borderRightWidth) || 0, + bottom: bounds.bottom + parseFloat(style.borderBottomWidth) || 0, + }; }; - GridApi.prototype.getModel = function () { - return this.rowModel; + PopupService.prototype.keepXYWithinBounds = function (ePopup, position, direction) { + var isVertical = direction === DIRECTION.vertical; + var sizeProperty = isVertical ? 'clientHeight' : 'clientWidth'; + var anchorProperty = isVertical ? 'top' : 'left'; + var offsetProperty = isVertical ? 'offsetHeight' : 'offsetWidth'; + var scrollPositionProperty = isVertical ? 'scrollTop' : 'scrollLeft'; + var eDocument = this.gridOptionsWrapper.getDocument(); + var docElement = eDocument.documentElement; + var popupParent = this.getPopupParent(); + var parentRect = popupParent.getBoundingClientRect(); + var documentRect = eDocument.documentElement.getBoundingClientRect(); + var isBody = popupParent === eDocument.body; + var offsetSize = ePopup[offsetProperty]; + var getSize = isVertical ? _utils_dom__WEBPACK_IMPORTED_MODULE_3__["getAbsoluteHeight"] : _utils_dom__WEBPACK_IMPORTED_MODULE_3__["getAbsoluteWidth"]; + var sizeOfParent = isBody ? (getSize(docElement) + docElement[scrollPositionProperty]) : popupParent[sizeProperty]; + if (isBody) { + sizeOfParent -= Math.abs(documentRect[anchorProperty] - parentRect[anchorProperty]); + } + var max = sizeOfParent - offsetSize; + return Math.min(Math.max(position, 0), Math.abs(max)); + }; + PopupService.prototype.keepPopupPositionedRelativeTo = function (params) { + var _this = this; + var eParent = this.getPopupParent(); + var parentRect = eParent.getBoundingClientRect(); + var sourceRect = params.element.getBoundingClientRect(); + var initialDiffTop = parentRect.top - sourceRect.top; + var initialDiffLeft = parentRect.left - sourceRect.left; + var lastDiffTop = initialDiffTop; + var lastDiffLeft = initialDiffLeft; + var topPx = params.ePopup.style.top; + var top = parseInt(topPx.substring(0, topPx.length - 1), 10); + var leftPx = params.ePopup.style.left; + var left = parseInt(leftPx.substring(0, leftPx.length - 1), 10); + return new _utils__WEBPACK_IMPORTED_MODULE_8__["AgPromise"](function (resolve) { + _this.getFrameworkOverrides().setInterval(function () { + var pRect = eParent.getBoundingClientRect(); + var sRect = params.element.getBoundingClientRect(); + var elementNotInDom = sRect.top == 0 && sRect.left == 0 && sRect.height == 0 && sRect.width == 0; + if (elementNotInDom) { + params.hidePopup(); + return; + } + var currentDiffTop = pRect.top - sRect.top; + if (currentDiffTop != lastDiffTop) { + var newTop = _this.keepXYWithinBounds(params.ePopup, top + initialDiffTop - currentDiffTop, DIRECTION.vertical); + params.ePopup.style.top = newTop + "px"; + } + lastDiffTop = currentDiffTop; + var currentDiffLeft = pRect.left - sRect.left; + if (currentDiffLeft != lastDiffLeft) { + var newLeft = _this.keepXYWithinBounds(params.ePopup, left + initialDiffLeft - currentDiffLeft, DIRECTION.horizontal); + params.ePopup.style.left = newLeft + "px"; + } + lastDiffLeft = currentDiffLeft; + }, 200).then(function (intervalId) { + var result = function () { + if (intervalId != null) { + window.clearInterval(intervalId); + } + }; + resolve(result); + }); + }); }; - GridApi.prototype.setRowNodeExpanded = function (rowNode, expanded) { - if (rowNode) { - rowNode.setExpanded(expanded); + PopupService.prototype.addPopup = function (params) { + var _this = this; + var modal = params.modal, eChild = params.eChild, closeOnEsc = params.closeOnEsc, closedCallback = params.closedCallback, click = params.click, alwaysOnTop = params.alwaysOnTop, afterGuiAttached = params.afterGuiAttached, positionCallback = params.positionCallback, anchorToElement = params.anchorToElement, ariaLabel = params.ariaLabel; + var eDocument = this.gridOptionsWrapper.getDocument(); + var destroyPositionTracker = new _utils__WEBPACK_IMPORTED_MODULE_8__["AgPromise"](function (resolve) { return resolve(function () { }); }); + if (!eDocument) { + console.warn('ag-grid: could not find the document, document is empty'); + return { hideFunc: function () { }, stopAnchoringPromise: destroyPositionTracker }; } - }; - GridApi.prototype.onGroupExpandedOrCollapsed = function (deprecated_refreshFromIndex) { - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.clientSideRowModel)) { - console.warn('ag-Grid: cannot call onGroupExpandedOrCollapsed unless using normal row model'); + var pos = this.popupList.findIndex(function (popup) { return popup.element === eChild; }); + if (pos !== -1) { + var popup = this.popupList[pos]; + return { hideFunc: popup.hideFunc, stopAnchoringPromise: popup.stopAnchoringPromise }; } - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(deprecated_refreshFromIndex)) { - console.warn('ag-Grid: api.onGroupExpandedOrCollapsed - refreshFromIndex parameter is no longer used, the grid will refresh all rows'); + var ePopupParent = this.getPopupParent(); + if (eChild.style.top == null) { + eChild.style.top = '0px'; } - // we don't really want the user calling this if only one rowNode was expanded, instead they should be - // calling rowNode.setExpanded(boolean) - this way we do a 'keepRenderedRows=false' so that the whole - // grid gets refreshed again - otherwise the row with the rowNodes that were changed won't get updated, - // and thus the expand icon in the group cell won't get 'opened' or 'closed'. - this.clientSideRowModel.refreshModel({ step: _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_MAP }); - }; - GridApi.prototype.refreshInMemoryRowModel = function (step) { - console.warn("ag-grid: since version 18.x, api.refreshInMemoryRowModel() should be replaced with api.refreshClientSideRowModel()"); - this.refreshClientSideRowModel(step); - }; - GridApi.prototype.refreshClientSideRowModel = function (step) { - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.clientSideRowModel)) { - console.warn('cannot call refreshClientSideRowModel unless using normal row model'); + if (eChild.style.left == null) { + eChild.style.left = '0px'; } - var paramsStep = _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_EVERYTHING; - var stepsMapped = { - group: _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_EVERYTHING, - filter: _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_FILTER, - map: _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_MAP, - aggregate: _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_AGGREGATE, - sort: _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_SORT, - pivot: _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_PIVOT - }; - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(step)) { - paramsStep = stepsMapped[step]; + // add env CSS class to child, in case user provided a popup parent, which means + // theme class may be missing + var eWrapper = document.createElement('div'); + var theme = this.environment.getTheme().theme; + if (theme) { + eWrapper.classList.add(theme); } - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(paramsStep)) { - console.error("ag-Grid: invalid step " + step + ", available steps are " + Object.keys(stepsMapped).join(', ')); - return; + eWrapper.classList.add('ag-popup'); + eChild.classList.add(this.gridOptionsWrapper.isEnableRtl() ? 'ag-rtl' : 'ag-ltr', 'ag-popup-child'); + if (!eChild.hasAttribute('role')) { + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_9__["setAriaRole"])(eChild, 'dialog'); } - var modelParams = { - step: paramsStep, - keepRenderedRows: true, - animate: true, - keepEditingRows: true - }; - this.clientSideRowModel.refreshModel(modelParams); - }; - GridApi.prototype.isAnimationFrameQueueEmpty = function () { - return this.animationFrameService.isQueueEmpty(); - }; - GridApi.prototype.getRowNode = function (id) { - return this.rowModel.getRowNode(id); - }; - GridApi.prototype.getSizesForCurrentTheme = function () { - return { - rowHeight: this.gridOptionsWrapper.getRowHeightAsNumber(), - headerHeight: this.gridOptionsWrapper.getHeaderHeight() - }; - }; - GridApi.prototype.expandAll = function () { - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.clientSideRowModel)) { - console.warn('ag-Grid: cannot call expandAll unless using normal row model'); - return; + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_9__["setAriaLabel"])(eChild, ariaLabel); + if (this.focusService.isKeyboardMode()) { + eChild.classList.add(_focusService__WEBPACK_IMPORTED_MODULE_7__["FocusService"].AG_KEYBOARD_FOCUS); } - this.clientSideRowModel.expandOrCollapseAll(true); - }; - GridApi.prototype.collapseAll = function () { - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.clientSideRowModel)) { - console.warn('ag-Grid: cannot call collapseAll unless using normal row model'); - return; + eWrapper.appendChild(eChild); + ePopupParent.appendChild(eWrapper); + if (alwaysOnTop) { + this.setAlwaysOnTop(eWrapper, true); } - this.clientSideRowModel.expandOrCollapseAll(false); - }; - GridApi.prototype.getToolPanelInstance = function (id) { - return this.gridCore.getToolPanelInstance(id); - }; - GridApi.prototype.addVirtualRowListener = function (eventName, rowIndex, callback) { - if (typeof eventName !== 'string') { - console.warn('ag-Grid: addVirtualRowListener is deprecated, please use addRenderedRowListener.'); + else { + this.bringPopupToFront(eWrapper); } - this.addRenderedRowListener(eventName, rowIndex, callback); - }; - GridApi.prototype.addRenderedRowListener = function (eventName, rowIndex, callback) { - if (eventName === 'virtualRowSelected') { - console.warn("ag-Grid: event virtualRowSelected is deprecated, to register for individual row\n selection events, add a listener directly to the row node."); + var popupHidden = false; + var hidePopupOnKeyboardEvent = function (event) { + if (!eWrapper.contains(eDocument.activeElement)) { + return; + } + var key = event.key; + if (key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_6__["KeyCode"].ESCAPE) { + hidePopup({ keyboardEvent: event }); + } + }; + var hidePopupOnMouseEvent = function (event) { return hidePopup({ mouseEvent: event }); }; + var hidePopupOnTouchEvent = function (event) { return hidePopup({ touchEvent: event }); }; + var hidePopup = function (popupParams) { + if (popupParams === void 0) { popupParams = {}; } + var mouseEvent = popupParams.mouseEvent, touchEvent = popupParams.touchEvent, keyboardEvent = popupParams.keyboardEvent; + if ( + // we don't hide popup if the event was on the child, or any + // children of this child + _this.isEventFromCurrentPopup({ mouseEvent: mouseEvent, touchEvent: touchEvent }, eChild) || + // if the event to close is actually the open event, then ignore it + _this.isEventSameChainAsOriginalEvent({ originalMouseEvent: click, mouseEvent: mouseEvent, touchEvent: touchEvent }) || + // this method should only be called once. the client can have different + // paths, each one wanting to close, so this method may be called multiple times. + popupHidden) { + return; + } + popupHidden = true; + ePopupParent.removeChild(eWrapper); + eDocument.removeEventListener('keydown', hidePopupOnKeyboardEvent); + eDocument.removeEventListener('mousedown', hidePopupOnMouseEvent); + eDocument.removeEventListener('touchstart', hidePopupOnTouchEvent); + eDocument.removeEventListener('contextmenu', hidePopupOnMouseEvent); + _this.eventService.removeEventListener(_events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_DRAG_STARTED, hidePopupOnMouseEvent); + if (closedCallback) { + closedCallback(mouseEvent || touchEvent || keyboardEvent); + } + _this.popupList = _this.popupList.filter(function (popup) { return popup.element !== eChild; }); + if (destroyPositionTracker) { + destroyPositionTracker.then(function (destroyFunc) { return destroyFunc && destroyFunc(); }); + } + }; + if (afterGuiAttached) { + afterGuiAttached({ hidePopup: hidePopup }); } - this.rowRenderer.addRenderedRowListener(eventName, rowIndex, callback); + // if we add these listeners now, then the current mouse + // click will be included, which we don't want + window.setTimeout(function () { + if (closeOnEsc) { + eDocument.addEventListener('keydown', hidePopupOnKeyboardEvent); + } + if (modal) { + eDocument.addEventListener('mousedown', hidePopupOnMouseEvent); + _this.eventService.addEventListener(_events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_DRAG_STARTED, hidePopupOnMouseEvent); + eDocument.addEventListener('touchstart', hidePopupOnTouchEvent); + eDocument.addEventListener('contextmenu', hidePopupOnMouseEvent); + } + }, 0); + if (positionCallback) { + positionCallback(); + } + if (anchorToElement) { + // keeps popup positioned under created, eg if context menu, if user scrolls + // using touchpad and the cell moves, it moves the popup to keep it with the cell. + destroyPositionTracker = this.keepPopupPositionedRelativeTo({ + element: anchorToElement, + ePopup: eChild, + hidePopup: hidePopup + }); + } + this.popupList.push({ + element: eChild, + wrapper: eWrapper, + hideFunc: hidePopup, + stopAnchoringPromise: destroyPositionTracker, + instanceId: instanceIdSeq++, + isAnchored: !!anchorToElement + }); + return { + hideFunc: hidePopup, + stopAnchoringPromise: destroyPositionTracker + }; }; - GridApi.prototype.setQuickFilter = function (newFilter) { - this.filterManager.setQuickFilter(newFilter); + PopupService.prototype.hasAnchoredPopup = function () { + return this.popupList.some(function (popup) { return popup.isAnchored; }); }; - GridApi.prototype.selectIndex = function (index, tryMulti, suppressEvents) { - console.warn('ag-Grid: do not use api for selection, call node.setSelected(value) instead'); - if (suppressEvents) { - console.warn('ag-Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it'); + PopupService.prototype.isEventFromCurrentPopup = function (params, target) { + var mouseEvent = params.mouseEvent, touchEvent = params.touchEvent; + var event = mouseEvent ? mouseEvent : touchEvent; + if (!event) { + return false; } - this.selectionController.selectIndex(index, tryMulti); - }; - GridApi.prototype.deselectIndex = function (index, suppressEvents) { - if (suppressEvents === void 0) { suppressEvents = false; } - console.warn('ag-Grid: do not use api for selection, call node.setSelected(value) instead'); - if (suppressEvents) { - console.warn('ag-Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it'); + var indexOfThisChild = this.popupList.findIndex(function (popup) { return popup.element === target; }); + if (indexOfThisChild === -1) { + return false; } - this.selectionController.deselectIndex(index); - }; - GridApi.prototype.selectNode = function (node, tryMulti, suppressEvents) { - if (tryMulti === void 0) { tryMulti = false; } - if (suppressEvents === void 0) { suppressEvents = false; } - console.warn('ag-Grid: API for selection is deprecated, call node.setSelected(value) instead'); - if (suppressEvents) { - console.warn('ag-Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it'); + for (var i = indexOfThisChild; i < this.popupList.length; i++) { + var popup = this.popupList[i]; + if (Object(_utils_event__WEBPACK_IMPORTED_MODULE_5__["isElementInEventPath"])(popup.element, event)) { + return true; + } } - node.setSelectedParams({ newValue: true, clearSelection: !tryMulti }); + // if the user did not write their own Custom Element to be rendered as popup + // and this component has an additional popup element, they should have the + // `ag-custom-component-popup` class to be detected as part of the Custom Component + return this.isElementWithinCustomPopup(event.target); }; - GridApi.prototype.deselectNode = function (node, suppressEvents) { - if (suppressEvents === void 0) { suppressEvents = false; } - console.warn('ag-Grid: API for selection is deprecated, call node.setSelected(value) instead'); - if (suppressEvents) { - console.warn('ag-Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it'); + PopupService.prototype.isElementWithinCustomPopup = function (el) { + var eDocument = this.gridOptionsWrapper.getDocument(); + while (el && el !== eDocument.body) { + if (el.classList.contains('ag-custom-component-popup') || el.parentElement === null) { + return true; + } + el = el.parentElement; } - node.setSelectedParams({ newValue: false }); - }; - GridApi.prototype.selectAll = function () { - this.selectionController.selectAllRowNodes(); - }; - GridApi.prototype.deselectAll = function () { - this.selectionController.deselectAllRowNodes(); - }; - GridApi.prototype.selectAllFiltered = function () { - this.selectionController.selectAllRowNodes(true); - }; - GridApi.prototype.deselectAllFiltered = function () { - this.selectionController.deselectAllRowNodes(true); + return false; }; - GridApi.prototype.recomputeAggregates = function () { - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.clientSideRowModel)) { - console.warn('cannot call recomputeAggregates unless using normal row model'); + // in some browsers, the context menu event can be fired before the click event, which means + // the context menu event could open the popup, but then the click event closes it straight away. + PopupService.prototype.isEventSameChainAsOriginalEvent = function (params) { + var originalMouseEvent = params.originalMouseEvent, mouseEvent = params.mouseEvent, touchEvent = params.touchEvent; + // we check the coordinates of the event, to see if it's the same event. there is a 1 / 1000 chance that + // the event is a different event, however that is an edge case that is not very relevant (the user clicking + // twice on the same location isn't a normal path). + // event could be mouse event or touch event. + var mouseEventOrTouch = null; + if (mouseEvent) { + // mouse event can be used direction, it has coordinates + mouseEventOrTouch = mouseEvent; } - console.warn("recomputeAggregates is deprecated, please call api.refreshClientSideRowModel('aggregate') instead"); - this.clientSideRowModel.refreshModel({ step: _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_AGGREGATE }); - }; - GridApi.prototype.sizeColumnsToFit = function () { - this.gridPanel.sizeColumnsToFit(); - }; - GridApi.prototype.showLoadingOverlay = function () { - this.gridPanel.showLoadingOverlay(); - }; - GridApi.prototype.showNoRowsOverlay = function () { - this.gridPanel.showNoRowsOverlay(); - }; - GridApi.prototype.hideOverlay = function () { - this.gridPanel.hideOverlay(); - }; - GridApi.prototype.isNodeSelected = function (node) { - console.warn('ag-Grid: no need to call api.isNodeSelected(), just call node.isSelected() instead'); - return node.isSelected(); - }; - GridApi.prototype.getSelectedNodesById = function () { - console.error('ag-Grid: since version 3.4, getSelectedNodesById no longer exists, use getSelectedNodes() instead'); - return null; - }; - GridApi.prototype.getSelectedNodes = function () { - return this.selectionController.getSelectedNodes(); - }; - GridApi.prototype.getSelectedRows = function () { - return this.selectionController.getSelectedRows(); - }; - GridApi.prototype.getBestCostNodeSelection = function () { - return this.selectionController.getBestCostNodeSelection(); - }; - GridApi.prototype.getRenderedNodes = function () { - return this.rowRenderer.getRenderedNodes(); - }; - GridApi.prototype.ensureColIndexVisible = function (index) { - console.warn('ag-Grid: ensureColIndexVisible(index) no longer supported, use ensureColumnVisible(colKey) instead.'); - }; - GridApi.prototype.ensureColumnVisible = function (key) { - this.gridPanel.ensureColumnVisible(key); - }; - // Valid values for position are bottom, middle and top - GridApi.prototype.ensureIndexVisible = function (index, position) { - this.gridPanel.ensureIndexVisible(index, position); - }; - // Valid values for position are bottom, middle and top - GridApi.prototype.ensureNodeVisible = function (comparator, position) { - this.gridCore.ensureNodeVisible(comparator, position); - }; - GridApi.prototype.forEachLeafNode = function (callback) { - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.clientSideRowModel)) { - console.warn('cannot call forEachNode unless using normal row model'); + else if (touchEvent) { + // touch event doesn't have coordinates, need it's touch object + mouseEventOrTouch = touchEvent.touches[0]; } - this.clientSideRowModel.forEachLeafNode(callback); - }; - GridApi.prototype.forEachNode = function (callback) { - this.rowModel.forEachNode(callback); - }; - GridApi.prototype.forEachNodeAfterFilter = function (callback) { - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.clientSideRowModel)) { - console.warn('cannot call forEachNodeAfterFilter unless using normal row model'); + if (mouseEventOrTouch && originalMouseEvent) { + // for x, allow 4px margin, to cover iPads, where touch (which opens menu) is followed + // by browser click (when you finger up, touch is interrupted as click in browser) + var screenX_1 = mouseEvent ? mouseEvent.screenX : 0; + var screenY_1 = mouseEvent ? mouseEvent.screenY : 0; + var xMatch = Math.abs(originalMouseEvent.screenX - screenX_1) < 5; + var yMatch = Math.abs(originalMouseEvent.screenY - screenY_1) < 5; + if (xMatch && yMatch) { + return true; + } } - this.clientSideRowModel.forEachNodeAfterFilter(callback); + return false; }; - GridApi.prototype.forEachNodeAfterFilterAndSort = function (callback) { - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.clientSideRowModel)) { - console.warn('cannot call forEachNodeAfterFilterAndSort unless using normal row model'); + PopupService.prototype.getWrapper = function (ePopup) { + while (!ePopup.classList.contains('ag-popup') && ePopup.parentElement) { + ePopup = ePopup.parentElement; } - this.clientSideRowModel.forEachNodeAfterFilterAndSort(callback); + return ePopup.classList.contains('ag-popup') ? ePopup : null; }; - GridApi.prototype.getFilterApiForColDef = function (colDef) { - console.warn('ag-grid API method getFilterApiForColDef deprecated, use getFilterInstance instead'); - return this.getFilterInstance(colDef); + PopupService.prototype.setAlwaysOnTop = function (ePopup, alwaysOnTop) { + var eWrapper = this.getWrapper(ePopup); + if (!eWrapper) { + return; + } + eWrapper.classList.toggle('ag-always-on-top', !!alwaysOnTop); + if (alwaysOnTop) { + this.bringPopupToFront(eWrapper); + } }; - GridApi.prototype.getFilterInstance = function (key, callback) { - var column = this.columnController.getPrimaryColumn(key); - if (column) { - var filterPromise = this.filterManager.getFilterComponent(column, 'NO_UI'); - var currentValue = filterPromise.resolveNow(null, function (filterComp) { return filterComp; }); - if (callback) { - if (currentValue) { - setTimeout(callback, 0, currentValue); - } - else { - filterPromise.then(callback); + PopupService.prototype.bringPopupToFront = function (ePopup) { + var parent = this.getPopupParent(); + var popupList = Array.prototype.slice.call(parent.querySelectorAll('.ag-popup')); + var popupLen = popupList.length; + var alwaysOnTopList = Array.prototype.slice.call(parent.querySelectorAll('.ag-popup.ag-always-on-top')); + var onTopLength = alwaysOnTopList.length; + var eWrapper = this.getWrapper(ePopup); + if (!eWrapper || popupLen <= 1 || !parent.contains(ePopup)) { + return; + } + var pos = popupList.indexOf(eWrapper); + var innerEls = eWrapper.querySelectorAll('div'); + var innerElsScrollMap = []; + innerEls.forEach(function (el) { + if (el.scrollTop !== 0) { + innerElsScrollMap.push([el, el.scrollTop]); + } + }); + if (onTopLength) { + var isPopupAlwaysOnTop = eWrapper.classList.contains('ag-always-on-top'); + if (isPopupAlwaysOnTop) { + if (pos !== popupLen - 1) { + Object(_utils_array__WEBPACK_IMPORTED_MODULE_4__["last"])(alwaysOnTopList).insertAdjacentElement('afterend', eWrapper); } } - return currentValue; - } - }; - GridApi.prototype.getFilterApi = function (key) { - console.warn('ag-Grid: getFilterApi is deprecated, use getFilterInstance instead'); - return this.getFilterInstance(key); - }; - GridApi.prototype.destroyFilter = function (key) { - var column = this.columnController.getPrimaryColumn(key); - if (column) { - return this.filterManager.destroyFilter(column, "filterDestroyed"); + else if (pos !== popupLen - onTopLength - 1) { + alwaysOnTopList[0].insertAdjacentElement('beforebegin', eWrapper); + } } - }; - GridApi.prototype.getStatusPanel = function (key) { - if (this.statusBarService) { - return this.statusBarService.getStatusPanel(key); + else if (pos !== popupLen - 1) { + Object(_utils_array__WEBPACK_IMPORTED_MODULE_4__["last"])(popupList).insertAdjacentElement('afterend', eWrapper); } - }; - GridApi.prototype.getColumnDef = function (key) { - var column = this.columnController.getPrimaryColumn(key); - if (column) { - return column.getColDef(); + while (innerElsScrollMap.length) { + var currentEl = innerElsScrollMap.pop(); + currentEl[0].scrollTop = currentEl[1]; } - return null; - }; - GridApi.prototype.onFilterChanged = function () { - this.filterManager.onFilterChanged(); - }; - GridApi.prototype.onSortChanged = function () { - this.sortController.onSortChanged(); - }; - GridApi.prototype.setSortModel = function (sortModel, source) { - if (source === void 0) { source = "api"; } - this.sortController.setSortModel(sortModel, source); - }; - GridApi.prototype.getSortModel = function () { - return this.sortController.getSortModel(); - }; - GridApi.prototype.setFilterModel = function (model) { - this.filterManager.setFilterModel(model); - }; - GridApi.prototype.getFilterModel = function () { - return this.filterManager.getFilterModel(); - }; - GridApi.prototype.getFocusedCell = function () { - return this.focusController.getFocusedCell(); - }; - GridApi.prototype.clearFocusedCell = function () { - return this.focusController.clearFocusedCell(); - }; - GridApi.prototype.setFocusedCell = function (rowIndex, colKey, floating) { - this.focusController.setFocusedCell(rowIndex, colKey, floating, true); - }; - GridApi.prototype.setSuppressRowDrag = function (value) { - this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_SUPPRESS_ROW_DRAG, value); - }; - GridApi.prototype.setSuppressMoveWhenRowDragging = function (value) { - this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_SUPPRESS_MOVE_WHEN_ROW_DRAG, value); + var params = { + type: 'popupToFront', + api: this.gridOptionsWrapper.getApi(), + columnApi: this.gridOptionsWrapper.getColumnApi(), + eWrapper: eWrapper + }; + this.eventService.dispatchEvent(params); }; - GridApi.prototype.setSuppressRowClickSelection = function (value) { - this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_SUPPRESS_ROW_CLICK_SELECTION, value); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('environment') + ], PopupService.prototype, "environment", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusService') + ], PopupService.prototype, "focusService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('ctrlsService') + ], PopupService.prototype, "ctrlsService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], PopupService.prototype, "postConstruct", null); + PopupService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('popupService') + ], PopupService); + return PopupService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"])); + + + +/***/ }), +/* 173 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FocusService", function() { return FocusService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(23); +/* harmony import */ var _widgets_managedFocusFeature__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(64); +/* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(43); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(15); +/* harmony import */ var _rendering_row_rowCtrl__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(113); +/* harmony import */ var _headerRendering_cells_abstractCell_abstractHeaderCellCtrl__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(148); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(18); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - GridApi.prototype.addRowDropZone = function (params) { - this.gridPanel.getRowDragFeature().addRowDropZone(params); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - GridApi.prototype.removeRowDropZone = function (params) { - var activeDropTarget = this.dragAndDropService.findExternalZone(params); - if (activeDropTarget) { - this.dragAndDropService.removeDropTarget(activeDropTarget); +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; +}; +var __spread = (undefined && undefined.__spread) || function () { + for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); + return ar; +}; + + + + + + + + + + +var FocusService = /** @class */ (function (_super) { + __extends(FocusService, _super); + function FocusService() { + return _super !== null && _super.apply(this, arguments) || this; + } + FocusService_1 = FocusService; + /** + * Adds a gridCore to the list of the gridCores monitoring Keyboard Mode + * in a specific HTMLDocument. + * + * @param doc {Document} - The Document containing the gridCore. + * @param gridCore {GridComp} - The GridCore to be monitored. + */ + FocusService.addKeyboardModeEvents = function (doc, controller) { + var docControllers = FocusService_1.instancesMonitored.get(doc); + if (docControllers && docControllers.length > 0) { + if (docControllers.indexOf(controller) === -1) { + docControllers.push(controller); + } + } + else { + FocusService_1.instancesMonitored.set(doc, [controller]); + doc.addEventListener('keydown', FocusService_1.toggleKeyboardMode); + doc.addEventListener('mousedown', FocusService_1.toggleKeyboardMode); } }; - GridApi.prototype.getRowDropZoneParams = function (events) { - return this.gridPanel.getRowDragFeature().getRowDropZone(events); - }; - GridApi.prototype.setHeaderHeight = function (headerHeight) { - this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_HEADER_HEIGHT, headerHeight); - this.doLayout(); - }; - GridApi.prototype.setGridAutoHeight = function (gridAutoHeight) { - console.warn('api.setGridAutoHeight(boolean) is deprecated, please use api.setDomLayout() instead'); - this.setDomLayout(gridAutoHeight ? 'autoHeight' : 'normal'); - }; - GridApi.prototype.setDomLayout = function (domLayout) { - this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_DOM_LAYOUT, domLayout); - }; - GridApi.prototype.setEnableCellTextSelection = function (selectable) { - this.gridPanel.setCellTextSelection(selectable); - }; - GridApi.prototype.setGroupHeaderHeight = function (headerHeight) { - this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GROUP_HEADER_HEIGHT, headerHeight); - this.doLayout(); - }; - GridApi.prototype.setFloatingFiltersHeight = function (headerHeight) { - this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_FLOATING_FILTERS_HEIGHT, headerHeight); - this.doLayout(); - }; - GridApi.prototype.setPivotGroupHeaderHeight = function (headerHeight) { - this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_PIVOT_GROUP_HEADER_HEIGHT, headerHeight); - this.doLayout(); - }; - GridApi.prototype.setPivotHeaderHeight = function (headerHeight) { - this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_PIVOT_HEADER_HEIGHT, headerHeight); - this.doLayout(); - }; - GridApi.prototype.isSideBarVisible = function () { - return this.gridCore.isSideBarVisible(); - }; - GridApi.prototype.setSideBarVisible = function (show) { - this.gridCore.setSideBarVisible(show); - }; - GridApi.prototype.setSideBarPosition = function (position) { - this.gridCore.setSideBarPosition(position); - }; - GridApi.prototype.showToolPanel = function (show) { - console.warn("ag-grid: from v19 api.showToolPanel has been deprecated in favour of api.setSideBarVisible"); - this.setSideBarVisible(show); - }; - GridApi.prototype.openToolPanel = function (key) { - this.gridCore.openToolPanel(key); - }; - GridApi.prototype.closeToolPanel = function () { - this.gridCore.closeToolPanel(); - }; - GridApi.prototype.getOpenedToolPanel = function () { - return this.gridCore.getOpenedToolPanel(); - }; - GridApi.prototype.getSideBar = function () { - return this.gridCore.getSideBar(); - }; - GridApi.prototype.setSideBar = function (def) { - return this.gridCore.setSideBar(def); + /** + * Removes a gridCore from the list of the gridCores monitoring Keyboard Mode + * in a specific HTMLDocument. + * + * @param doc {Document} - The Document containing the gridCore. + * @param gridCore {GridComp} - The GridCore to be removed. + */ + FocusService.removeKeyboardModeEvents = function (doc, controller) { + var docControllers = FocusService_1.instancesMonitored.get(doc); + var newControllers = []; + if (docControllers && docControllers.length) { + newControllers = __spread(docControllers).filter(function (currentGridCore) { return currentGridCore !== controller; }); + FocusService_1.instancesMonitored.set(doc, newControllers); + } + if (newControllers.length === 0) { + doc.removeEventListener('keydown', FocusService_1.toggleKeyboardMode); + doc.removeEventListener('mousedown', FocusService_1.toggleKeyboardMode); + } }; - GridApi.prototype.setSuppressClipboardPaste = function (value) { - this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_SUPPRESS_CLIPBOARD_PASTE, value); + /** + * This method will be called by `keydown` and `mousedown` events on all Documents monitoring + * KeyboardMode. It will then fire a KEYBOARD_FOCUS, MOUSE_FOCUS on each gridCore present in + * the Document allowing each gridCore to maintain a state for KeyboardMode. + * + * @param event {KeyboardEvent | MouseEvent | TouchEvent} - The event triggered. + */ + FocusService.toggleKeyboardMode = function (event) { + var isKeyboardActive = FocusService_1.keyboardModeActive; + var isKeyboardEvent = event.type === 'keydown'; + if (isKeyboardEvent) { + // the following keys should not toggle keyboard mode. + if (event.ctrlKey || event.metaKey || event.altKey) { + return; + } + } + if (isKeyboardActive && isKeyboardEvent || !isKeyboardActive && !isKeyboardEvent) { + return; + } + FocusService_1.keyboardModeActive = isKeyboardEvent; + var doc = event.target.ownerDocument; + if (!doc) { + return; + } + var controllersForDoc = FocusService_1.instancesMonitored.get(doc); + if (controllersForDoc) { + controllersForDoc.forEach(function (controller) { + controller.dispatchEvent({ type: isKeyboardEvent ? _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_KEYBOARD_FOCUS : _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_MOUSE_FOCUS }); + }); + } }; - GridApi.prototype.isToolPanelShowing = function () { - return this.gridCore.isToolPanelShowing(); + FocusService.prototype.init = function () { + var _this = this; + var clearFocusedCellListener = this.clearFocusedCell.bind(this); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_MODE_CHANGED, clearFocusedCellListener); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_NEW_COLUMNS_LOADED, this.onColumnEverythingChanged.bind(this)); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_GROUP_OPENED, clearFocusedCellListener); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, clearFocusedCellListener); + this.ctrlsService.whenReady(function (p) { + _this.gridCtrl = p.gridCtrl; + var doc = _this.gridOptionsWrapper.getDocument(); + FocusService_1.addKeyboardModeEvents(doc, _this.gridCtrl); + _this.addDestroyFunc(function () { return _this.unregisterGridCompController(_this.gridCtrl); }); + }); }; - GridApi.prototype.doLayout = function () { - this.gridPanel.checkViewportAndScrolls(); + FocusService.prototype.unregisterGridCompController = function (gridCompController) { + var doc = this.gridOptionsWrapper.getDocument(); + FocusService_1.removeKeyboardModeEvents(doc, gridCompController); }; - GridApi.prototype.resetRowHeights = function () { - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(this.clientSideRowModel)) { - this.clientSideRowModel.resetRowHeights(); + FocusService.prototype.onColumnEverythingChanged = function () { + // if the columns change, check and see if this column still exists. if it does, then + // we can keep the focused cell. if it doesn't, then we need to drop the focused cell. + if (!this.focusedCellPosition) { + return; + } + var col = this.focusedCellPosition.column; + var colFromColumnModel = this.columnModel.getGridColumn(col.getId()); + if (col !== colFromColumnModel) { + this.clearFocusedCell(); } }; - GridApi.prototype.setGroupRemoveSingleChildren = function (value) { - this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GROUP_REMOVE_SINGLE_CHILDREN, value); - }; - GridApi.prototype.setGroupRemoveLowestSingleChildren = function (value) { - this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GROUP_REMOVE_LOWEST_SINGLE_CHILDREN, value); + FocusService.prototype.isKeyboardMode = function () { + return FocusService_1.keyboardModeActive; }; - GridApi.prototype.onRowHeightChanged = function () { - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(this.clientSideRowModel)) { - this.clientSideRowModel.onRowHeightChanged(); + // we check if the browser is focusing something, and if it is, and + // it's the cell we think is focused, then return the cell. so this + // methods returns the cell if a) we think it has focus and b) the + // browser thinks it has focus. this then returns nothing if we + // first focus a cell, then second click outside the grid, as then the + // grid cell will still be focused as far as the grid is concerned, + // however the browser focus will have moved somewhere else. + FocusService.prototype.getFocusCellToUseAfterRefresh = function () { + var eDocument = this.gridOptionsWrapper.getDocument(); + if (this.gridOptionsWrapper.isSuppressFocusAfterRefresh() || !this.focusedCellPosition) { + return null; } + // we check that the browser is actually focusing on the grid, if it is not, then + // we have nothing to worry about. we check for ROW data, as this covers both focused Rows (for Full Width Rows) + // and Cells (covers cells as cells live in rows) + if (this.isDomDataMissingInHierarchy(eDocument.activeElement, _rendering_row_rowCtrl__WEBPACK_IMPORTED_MODULE_7__["RowCtrl"].DOM_DATA_KEY_ROW_CTRL)) { + return null; + } + return this.focusedCellPosition; }; - GridApi.prototype.getValue = function (colKey, rowNode) { - var column = this.columnController.getPrimaryColumn(colKey); - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(column)) { - column = this.columnController.getGridColumn(colKey); + FocusService.prototype.getFocusHeaderToUseAfterRefresh = function () { + var eDocument = this.gridOptionsWrapper.getDocument(); + if (this.gridOptionsWrapper.isSuppressFocusAfterRefresh() || !this.focusedHeaderPosition) { + return null; } - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(column)) { + // we check that the browser is actually focusing on the grid, if it is not, then + // we have nothing to worry about + if (this.isDomDataMissingInHierarchy(eDocument.activeElement, _headerRendering_cells_abstractCell_abstractHeaderCellCtrl__WEBPACK_IMPORTED_MODULE_8__["AbstractHeaderCellCtrl"].DOM_DATA_KEY_HEADER_CTRL)) { return null; } - return this.valueService.getValue(column, rowNode); - }; - GridApi.prototype.addEventListener = function (eventType, listener) { - var async = this.gridOptionsWrapper.useAsyncEvents(); - this.eventService.addEventListener(eventType, listener, async); - }; - GridApi.prototype.addGlobalListener = function (listener) { - var async = this.gridOptionsWrapper.useAsyncEvents(); - this.eventService.addGlobalListener(listener, async); + return this.focusedHeaderPosition; }; - GridApi.prototype.removeEventListener = function (eventType, listener) { - var async = this.gridOptionsWrapper.useAsyncEvents(); - this.eventService.removeEventListener(eventType, listener, async); + FocusService.prototype.isDomDataMissingInHierarchy = function (eBrowserCell, key) { + var ePointer = eBrowserCell; + while (ePointer) { + var data = this.gridOptionsWrapper.getDomData(ePointer, key); + if (data) { + return false; + } + ePointer = ePointer.parentNode; + } + return true; }; - GridApi.prototype.removeGlobalListener = function (listener) { - var async = this.gridOptionsWrapper.useAsyncEvents(); - this.eventService.removeGlobalListener(listener, async); + FocusService.prototype.clearFocusedCell = function () { + this.focusedCellPosition = null; + this.onCellFocused(false); }; - GridApi.prototype.dispatchEvent = function (event) { - this.eventService.dispatchEvent(event); + FocusService.prototype.getFocusedCell = function () { + return this.focusedCellPosition; }; - GridApi.prototype.destroy = function () { - // this is needed as GridAPI is a bean, and GridAPI.destroy() is called as part - // of context.destroy(). so we need to stop the infinite loop. - if (this.destroyCalled) { + FocusService.prototype.setFocusedCell = function (rowIndex, colKey, floating, forceBrowserFocus) { + if (forceBrowserFocus === void 0) { forceBrowserFocus = false; } + var gridColumn = this.columnModel.getGridColumn(colKey); + // if column doesn't exist, then blank the focused cell and return. this can happen when user sets new columns, + // and the focused cell is in a column that no longer exists. after columns change, the grid refreshes and tries + // to re-focus the focused cell. + if (!gridColumn) { + this.focusedCellPosition = null; return; } - this.destroyCalled = true; - // destroy the UI first (as they use the services) - this.context.destroyBean(this.gridCore); - // destroy the services - this.context.destroy(); + this.focusedCellPosition = gridColumn ? { rowIndex: rowIndex, rowPinned: Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["makeNull"])(floating), column: gridColumn } : null; + this.onCellFocused(forceBrowserFocus); }; - GridApi.prototype.resetQuickFilter = function () { - this.rowModel.forEachNode(function (node) { return node.quickFilterAggregateText = null; }); + FocusService.prototype.isCellFocused = function (cellPosition) { + if (this.focusedCellPosition == null) { + return false; + } + return this.focusedCellPosition.column === cellPosition.column && + this.isRowFocused(cellPosition.rowIndex, cellPosition.rowPinned); }; - GridApi.prototype.getRangeSelections = function () { - console.warn("ag-Grid: in v20.1.x, api.getRangeSelections() is gone, please use getCellRanges() instead.\n We had to change how cell selections works a small bit to allow charting to integrate. The return type of\n getCellRanges() is a bit different, please check the ag-Grid documentation."); - return null; + FocusService.prototype.isRowNodeFocused = function (rowNode) { + return this.isRowFocused(rowNode.rowIndex, rowNode.rowPinned); }; - GridApi.prototype.getCellRanges = function () { - if (this.rangeController) { - return this.rangeController.getCellRanges(); + FocusService.prototype.isHeaderWrapperFocused = function (headerCtrl) { + if (this.focusedHeaderPosition == null) { + return false; } - console.warn('ag-Grid: cell range selection is only available in ag-Grid Enterprise'); - return null; + var column = headerCtrl.getColumnGroupChild(); + var headerRowIndex = headerCtrl.getRowIndex(); + var pinned = headerCtrl.getPinned(); + var _a = this.focusedHeaderPosition, focusedColumn = _a.column, focusedHeaderRowIndex = _a.headerRowIndex; + return column === focusedColumn && + headerRowIndex === focusedHeaderRowIndex && + pinned == focusedColumn.getPinned(); }; - GridApi.prototype.camelCaseToHumanReadable = function (camelCase) { - return _utils__WEBPACK_IMPORTED_MODULE_5__["_"].camelCaseToHumanText(camelCase); + FocusService.prototype.clearFocusedHeader = function () { + this.focusedHeaderPosition = null; }; - GridApi.prototype.addRangeSelection = function (deprecatedNoLongerUsed) { - console.warn('ag-Grid: As of version 21.x, range selection changed slightly to allow charting integration. Please call api.addCellRange() instead of api.addRangeSelection()'); + FocusService.prototype.getFocusedHeader = function () { + return this.focusedHeaderPosition; }; - GridApi.prototype.addCellRange = function (params) { - if (!this.rangeController) { - console.warn('ag-Grid: cell range selection is only available in ag-Grid Enterprise'); - } - this.rangeController.addCellRange(params); + FocusService.prototype.setFocusedHeader = function (headerRowIndex, column) { + this.focusedHeaderPosition = { headerRowIndex: headerRowIndex, column: column }; }; - GridApi.prototype.clearRangeSelection = function () { - if (!this.rangeController) { - console.warn('ag-Grid: cell range selection is only available in ag-Grid Enterprise'); + FocusService.prototype.focusHeaderPosition = function (params) { + var direction = params.direction, fromTab = params.fromTab, allowUserOverride = params.allowUserOverride, event = params.event; + var headerPosition = params.headerPosition; + if (allowUserOverride) { + var gridOptionsWrapper = this.gridOptionsWrapper; + var currentPosition = this.getFocusedHeader(); + var headerRowCount = this.headerNavigationService.getHeaderRowCount(); + if (fromTab) { + var userFunc = gridOptionsWrapper.getTabToNextHeaderFunc(); + if (userFunc) { + var params_1 = { + backwards: direction === 'Before', + previousHeaderPosition: currentPosition, + nextHeaderPosition: headerPosition, + headerRowCount: headerRowCount, + api: gridOptionsWrapper.getApi(), + columnApi: gridOptionsWrapper.getColumnApi() + }; + headerPosition = userFunc(params_1); + } + } + else { + var userFunc = gridOptionsWrapper.getNavigateToNextHeaderFunc(); + if (userFunc && event) { + var params_2 = { + key: event.key, + previousHeaderPosition: currentPosition, + nextHeaderPosition: headerPosition, + headerRowCount: headerRowCount, + event: event, + api: gridOptionsWrapper.getApi(), + columnApi: gridOptionsWrapper.getColumnApi() + }; + headerPosition = userFunc(params_2); + } + } + } + if (!headerPosition) { + return false; + } + if (headerPosition.headerRowIndex === -1) { + return this.focusGridView(headerPosition.column); } - this.rangeController.removeAllCellRanges(); + this.headerNavigationService.scrollToColumn(headerPosition.column, direction); + var headerRowContainerCtrl = this.ctrlsService.getHeaderRowContainerCtrl(headerPosition.column.getPinned()); + // this will automatically call the setFocusedHeader method above + var focusSuccess = headerRowContainerCtrl.focusHeader(headerPosition.headerRowIndex, headerPosition.column, event); + return focusSuccess; }; - GridApi.prototype.undoCellEditing = function () { - this.undoRedoService.undo(); + FocusService.prototype.focusFirstHeader = function () { + var firstColumn = this.columnModel.getAllDisplayedColumns()[0]; + if (!firstColumn) { + return false; + } + if (firstColumn.getParent()) { + firstColumn = this.columnModel.getColumnGroupAtLevel(firstColumn, 0); + } + return this.focusHeaderPosition({ + headerPosition: { headerRowIndex: 0, column: firstColumn } + }); }; - GridApi.prototype.redoCellEditing = function () { - this.undoRedoService.redo(); + FocusService.prototype.focusLastHeader = function (event) { + var headerRowIndex = this.headerNavigationService.getHeaderRowCount() - 1; + var column = Object(_utils_array__WEBPACK_IMPORTED_MODULE_9__["last"])(this.columnModel.getAllDisplayedColumns()); + return this.focusHeaderPosition({ + headerPosition: { headerRowIndex: headerRowIndex, column: column }, + event: event + }); }; - GridApi.prototype.getChartModels = function () { - if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].RangeSelectionModule, 'api.getChartModels') && - _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].GridChartsModule, 'api.getChartModels')) { - return this.chartService.getChartModels(); - } + FocusService.prototype.isAnyCellFocused = function () { + return !!this.focusedCellPosition; }; - GridApi.prototype.createRangeChart = function (params) { - if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].RangeSelectionModule, 'api.createRangeChart') && - _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].GridChartsModule, 'api.createRangeChart')) { - return this.chartService.createRangeChart(params); + FocusService.prototype.isRowFocused = function (rowIndex, floating) { + if (this.focusedCellPosition == null) { + return false; } + return this.focusedCellPosition.rowIndex === rowIndex && this.focusedCellPosition.rowPinned === Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["makeNull"])(floating); }; - GridApi.prototype.createPivotChart = function (params) { - if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].RangeSelectionModule, 'api.createPivotChart') && - _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].GridChartsModule, 'api.createPivotChart')) { - return this.chartService.createPivotChart(params); + FocusService.prototype.findFocusableElements = function (rootNode, exclude, onlyUnmanaged) { + if (onlyUnmanaged === void 0) { onlyUnmanaged = false; } + var focusableString = _constants_constants__WEBPACK_IMPORTED_MODULE_6__["Constants"].FOCUSABLE_SELECTOR; + var excludeString = _constants_constants__WEBPACK_IMPORTED_MODULE_6__["Constants"].FOCUSABLE_EXCLUDE; + if (exclude) { + excludeString += ', ' + exclude; } - }; - GridApi.prototype.copySelectedRowsToClipboard = function (includeHeader, columnKeys) { - if (!this.clipboardService) { - console.warn('ag-Grid: clipboard is only available in ag-Grid Enterprise'); + if (onlyUnmanaged) { + excludeString += ', [tabindex="-1"]'; } - this.clipboardService.copySelectedRowsToClipboard(includeHeader, columnKeys); - }; - GridApi.prototype.copySelectedRangeToClipboard = function (includeHeader) { - if (!this.clipboardService) { - console.warn('ag-Grid: clipboard is only available in ag-Grid Enterprise'); + var nodes = Array.prototype.slice.apply(rootNode.querySelectorAll(focusableString)); + var excludeNodes = Array.prototype.slice.apply(rootNode.querySelectorAll(excludeString)); + if (!excludeNodes.length) { + return nodes; } - this.clipboardService.copySelectedRangeToClipboard(includeHeader); + var diff = function (a, b) { return a.filter(function (element) { return b.indexOf(element) === -1; }); }; + return diff(nodes, excludeNodes); }; - GridApi.prototype.copySelectedRangeDown = function () { - if (!this.clipboardService) { - console.warn('ag-Grid: clipboard is only available in ag-Grid Enterprise'); + FocusService.prototype.focusInto = function (rootNode, up, onlyUnmanaged) { + if (up === void 0) { up = false; } + if (onlyUnmanaged === void 0) { onlyUnmanaged = false; } + var focusableElements = this.findFocusableElements(rootNode, null, onlyUnmanaged); + var toFocus = up ? Object(_utils_array__WEBPACK_IMPORTED_MODULE_9__["last"])(focusableElements) : focusableElements[0]; + if (toFocus) { + toFocus.focus(); + return true; } - this.clipboardService.copyRangeDown(); - }; - GridApi.prototype.showColumnMenuAfterButtonClick = function (colKey, buttonElement) { - // use grid column so works with pivot mode - var column = this.columnController.getGridColumn(colKey); - this.menuFactory.showMenuAfterButtonClick(column, buttonElement); + return false; }; - GridApi.prototype.showColumnMenuAfterMouseClick = function (colKey, mouseEvent) { - // use grid column so works with pivot mode - var column = this.columnController.getGridColumn(colKey); - if (!column) { - column = this.columnController.getPrimaryColumn(colKey); + FocusService.prototype.findNextFocusableElement = function (rootNode, onlyManaged, backwards) { + if (rootNode === void 0) { rootNode = this.eGridDiv; } + var focusable = this.findFocusableElements(rootNode, onlyManaged ? ':not([tabindex="-1"])' : null); + var eDocument = this.gridOptionsWrapper.getDocument(); + var activeEl = eDocument.activeElement; + var currentIndex; + if (onlyManaged) { + currentIndex = focusable.findIndex(function (el) { return el.contains(activeEl); }); } - if (!column) { - console.error("ag-Grid: column '" + colKey + "' not found"); - return; + else { + currentIndex = focusable.indexOf(activeEl); } - this.menuFactory.showMenuAfterMouseEvent(column, mouseEvent); - }; - GridApi.prototype.hidePopupMenu = function () { - // hide the context menu if in enterprise - if (this.contextMenuFactory) { - this.contextMenuFactory.hideActiveMenu(); + var nextIndex = currentIndex + (backwards ? -1 : 1); + if (nextIndex < 0 || nextIndex >= focusable.length) { + return null; } - // and hide the column menu always - this.menuFactory.hideActiveMenu(); - }; - GridApi.prototype.setPopupParent = function (ePopupParent) { - this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_POPUP_PARENT, ePopupParent); - }; - GridApi.prototype.tabToNextCell = function () { - return this.rowRenderer.tabToNextCell(false); - }; - GridApi.prototype.tabToPreviousCell = function () { - return this.rowRenderer.tabToNextCell(true); - }; - GridApi.prototype.getCellRendererInstances = function (params) { - if (params === void 0) { params = {}; } - return this.rowRenderer.getCellRendererInstances(params); - }; - GridApi.prototype.getCellEditorInstances = function (params) { - if (params === void 0) { params = {}; } - return this.rowRenderer.getCellEditorInstances(params); - }; - GridApi.prototype.getEditingCells = function () { - return this.rowRenderer.getEditingCells(); - }; - GridApi.prototype.stopEditing = function (cancel) { - if (cancel === void 0) { cancel = false; } - this.rowRenderer.stopEditing(cancel); + return focusable[nextIndex]; }; - GridApi.prototype.startEditingCell = function (params) { - var column = this.columnController.getGridColumn(params.colKey); - if (!column) { - console.warn("ag-Grid: no column found for " + params.colKey); - return; + FocusService.prototype.isFocusUnderManagedComponent = function (rootNode) { + var eDocument = this.gridOptionsWrapper.getDocument(); + var managedContainers = rootNode.querySelectorAll("." + _widgets_managedFocusFeature__WEBPACK_IMPORTED_MODULE_3__["ManagedFocusFeature"].FOCUS_MANAGED_CLASS); + if (!managedContainers.length) { + return false; } - var cellPosition = { - rowIndex: params.rowIndex, - rowPinned: params.rowPinned, - column: column - }; - var notPinned = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(params.rowPinned); - if (notPinned) { - this.gridPanel.ensureIndexVisible(params.rowIndex); + for (var i = 0; i < managedContainers.length; i++) { + if (managedContainers[i].contains(eDocument.activeElement)) { + return true; + } } - this.rowRenderer.startEditingCell(cellPosition, params.keyPress, params.charPress); + return false; }; - GridApi.prototype.addAggFunc = function (key, aggFunc) { - if (this.aggFuncService) { - this.aggFuncService.addAggFunc(key, aggFunc); + FocusService.prototype.findTabbableParent = function (node, limit) { + if (limit === void 0) { limit = 5; } + var counter = 0; + while (node && Object(_utils_browser__WEBPACK_IMPORTED_MODULE_4__["getTabIndex"])(node) === null && ++counter <= limit) { + node = node.parentElement; } - }; - GridApi.prototype.addAggFuncs = function (aggFuncs) { - if (this.aggFuncService) { - this.aggFuncService.addAggFuncs(aggFuncs); + if (Object(_utils_browser__WEBPACK_IMPORTED_MODULE_4__["getTabIndex"])(node) === null) { + return null; } + return node; }; - GridApi.prototype.clearAggFuncs = function () { - if (this.aggFuncService) { - this.aggFuncService.clear(); + FocusService.prototype.onCellFocused = function (forceBrowserFocus) { + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_CELL_FOCUSED, + forceBrowserFocus: forceBrowserFocus, + rowIndex: null, + column: null, + floating: null, + api: this.gridApi, + columnApi: this.columnApi, + rowPinned: null, + isFullWidthCell: false + }; + if (this.focusedCellPosition) { + var rowIndex = event.rowIndex = this.focusedCellPosition.rowIndex; + var rowPinned = event.rowPinned = this.focusedCellPosition.rowPinned; + event.column = this.focusedCellPosition.column; + var rowCtrl = this.rowRenderer.getRowByPosition({ rowIndex: rowIndex, rowPinned: rowPinned }); + if (rowCtrl) { + event.isFullWidthCell = rowCtrl.isFullWidth(); + } } + this.eventService.dispatchEvent(event); }; - GridApi.prototype.applyTransaction = function (rowDataTransaction) { - var res = null; - if (this.clientSideRowModel) { - if (rowDataTransaction && rowDataTransaction.addIndex != null) { - var message_1 = 'ag-Grid: as of v23.1, transaction.addIndex is deprecated. If you want precision control of adding data, use immutableData instead'; - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].doOnce(function () { return console.warn(message_1); }, 'transaction.addIndex deprecated'); + FocusService.prototype.focusGridView = function (column, backwards) { + // if suppressCellFocus is `true`, it means the user does not want to + // navigate between the cells using tab. Instead, we put focus on either + // the header or after the grid, depending on whether tab or shift-tab was pressed. + if (this.gridOptionsWrapper.isSuppressCellFocus()) { + if (backwards) { + return this.focusLastHeader(); } - res = this.clientSideRowModel.updateRowData(rowDataTransaction); + return this.focusNextGridCoreContainer(false); } - else if (this.infiniteRowModel) { - var message_2 = 'ag-Grid: as of v23.1, transactions for Infinite Row Model are deprecated. If you want to make updates to data in Infinite Row Models, then refresh the data.'; - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].doOnce(function () { return console.warn(message_2); }, 'applyTransaction infiniteRowModel deprecated'); - this.infiniteRowModel.updateRowData(rowDataTransaction); + var nextRow = backwards + ? this.rowPositionUtils.getLastRow() + : this.rowPositionUtils.getFirstRow(); + if (!nextRow) { + return false; } - else { - console.error('ag-Grid: updateRowData() only works with ClientSideRowModel and InfiniteRowModel.'); + var rowIndex = nextRow.rowIndex, rowPinned = nextRow.rowPinned; + var focusedHeader = this.getFocusedHeader(); + if (!column && focusedHeader) { + column = focusedHeader.column; } - // refresh all the full width rows - this.rowRenderer.refreshFullWidthRows(); - // do change detection for all present cells - if (!this.gridOptionsWrapper.isSuppressChangeDetection()) { - this.rowRenderer.refreshCells(); + if (rowIndex == null || !column) { + return false; } - return res; - }; - /** @deprecated */ - GridApi.prototype.updateRowData = function (rowDataTransaction) { - var message = 'ag-Grid: as of v23.1, grid API updateRowData(transaction) is now called applyTransaction(transaction). updateRowData is deprecated and will be removed in a future major release.'; - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].doOnce(function () { return console.warn(message); }, 'updateRowData deprecated'); - return this.applyTransaction(rowDataTransaction); + this.navigationService.ensureCellVisible({ rowIndex: rowIndex, column: column, rowPinned: rowPinned }); + this.setFocusedCell(rowIndex, column, Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["makeNull"])(rowPinned), true); + if (this.rangeService) { + var cellPosition = { rowIndex: rowIndex, rowPinned: rowPinned, column: column }; + this.rangeService.setRangeToCell(cellPosition); + } + return true; }; - GridApi.prototype.applyTransactionAsync = function (rowDataTransaction, callback) { - if (!this.clientSideRowModel) { - console.error('ag-Grid: api.applyTransactionAsync() only works with ClientSideRowModel.'); - return; + FocusService.prototype.focusNextGridCoreContainer = function (backwards) { + if (this.gridCtrl.focusNextInnerContainer(backwards)) { + return true; } - this.clientSideRowModel.batchUpdateRowData(rowDataTransaction, callback); + if (!backwards) { + this.gridCtrl.forceFocusOutOfContainer(); + } + return false; }; - /** @deprecated */ - GridApi.prototype.batchUpdateRowData = function (rowDataTransaction, callback) { - var message = 'ag-Grid: as of v23.1, grid API batchUpdateRowData(transaction, callback) is now called applyTransactionAsync(transaction, callback). batchUpdateRowData is deprecated and will be removed in a future major release.'; - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].doOnce(function () { return console.warn(message); }, 'batchUpdateRowData deprecated'); - this.applyTransactionAsync(rowDataTransaction, callback); + var FocusService_1; + FocusService.AG_KEYBOARD_FOCUS = 'ag-keyboard-focus'; + FocusService.keyboardModeActive = false; + FocusService.instancesMonitored = new Map(); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('eGridDiv') + ], FocusService.prototype, "eGridDiv", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], FocusService.prototype, "columnModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('headerNavigationService') + ], FocusService.prototype, "headerNavigationService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') + ], FocusService.prototype, "columnApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') + ], FocusService.prototype, "gridApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer') + ], FocusService.prototype, "rowRenderer", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowPositionUtils') + ], FocusService.prototype, "rowPositionUtils", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('rangeService') + ], FocusService.prototype, "rangeService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('navigationService') + ], FocusService.prototype, "navigationService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('ctrlsService') + ], FocusService.prototype, "ctrlsService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], FocusService.prototype, "init", null); + FocusService = FocusService_1 = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('focusService') + ], FocusService); + return FocusService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + + + +/***/ }), +/* 174 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LoggerFactory", function() { return LoggerFactory; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Logger", function() { return Logger; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - GridApi.prototype.insertItemsAtIndex = function (index, items, skipRefresh) { - if (skipRefresh === void 0) { skipRefresh = false; } - console.warn('ag-Grid: insertItemsAtIndex() is deprecated, use updateRowData(transaction) instead.'); - this.updateRowData({ add: items, addIndex: index, update: null, remove: null }); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - GridApi.prototype.removeItems = function (rowNodes, skipRefresh) { - if (skipRefresh === void 0) { skipRefresh = false; } - console.warn('ag-Grid: removeItems() is deprecated, use updateRowData(transaction) instead.'); - var dataToRemove = rowNodes.map(function (rowNode) { return rowNode.data; }); - this.updateRowData({ add: null, addIndex: null, update: null, remove: dataToRemove }); +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; +var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { + return function (target, key) { decorator(target, key, paramIndex); } +}; + + + +var LoggerFactory = /** @class */ (function (_super) { + __extends(LoggerFactory, _super); + function LoggerFactory() { + return _super !== null && _super.apply(this, arguments) || this; + } + LoggerFactory.prototype.setBeans = function (gridOptionsWrapper) { + this.logging = gridOptionsWrapper.isDebug(); }; - GridApi.prototype.addItems = function (items, skipRefresh) { - if (skipRefresh === void 0) { skipRefresh = false; } - console.warn('ag-Grid: addItems() is deprecated, use updateRowData(transaction) instead.'); - this.updateRowData({ add: items, addIndex: null, update: null, remove: null }); + LoggerFactory.prototype.create = function (name) { + return new Logger(name, this.isLogging.bind(this)); }; - GridApi.prototype.refreshVirtualPageCache = function () { - console.warn('ag-Grid: refreshVirtualPageCache() is now called refreshInfiniteCache(), please call refreshInfiniteCache() instead'); - this.refreshInfiniteCache(); + LoggerFactory.prototype.isLogging = function () { + return this.logging; }; - GridApi.prototype.refreshInfinitePageCache = function () { - console.warn('ag-Grid: refreshInfinitePageCache() is now called refreshInfiniteCache(), please call refreshInfiniteCache() instead'); - this.refreshInfiniteCache(); + __decorate([ + __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('gridOptionsWrapper')) + ], LoggerFactory.prototype, "setBeans", null); + LoggerFactory = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('loggerFactory') + ], LoggerFactory); + return LoggerFactory; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + +var Logger = /** @class */ (function () { + function Logger(name, isLoggingFunc) { + this.name = name; + this.isLoggingFunc = isLoggingFunc; + } + Logger.prototype.isLogging = function () { + return this.isLoggingFunc(); }; - GridApi.prototype.refreshInfiniteCache = function () { - if (this.infiniteRowModel) { - this.infiniteRowModel.refreshCache(); - } - else { - console.warn("ag-Grid: api.refreshInfiniteCache is only available when rowModelType='infinite'."); + Logger.prototype.log = function (message) { + if (this.isLoggingFunc()) { + // tslint:disable-next-line + console.log('AG Grid.' + this.name + ': ' + message); } }; - GridApi.prototype.purgeVirtualPageCache = function () { - console.warn('ag-Grid: purgeVirtualPageCache() is now called purgeInfiniteCache(), please call purgeInfiniteCache() instead'); - this.purgeInfinitePageCache(); + return Logger; +}()); + + + +/***/ }), +/* 175 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AutoWidthCalculator", function() { return AutoWidthCalculator; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - GridApi.prototype.purgeInfinitePageCache = function () { - console.warn('ag-Grid: purgeInfinitePageCache() is now called purgeInfiniteCache(), please call purgeInfiniteCache() instead'); - this.purgeInfiniteCache(); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - GridApi.prototype.purgeInfiniteCache = function () { - if (this.infiniteRowModel) { - this.infiniteRowModel.purgeCache(); +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + +var AutoWidthCalculator = /** @class */ (function (_super) { + __extends(AutoWidthCalculator, _super); + function AutoWidthCalculator() { + return _super !== null && _super.apply(this, arguments) || this; + } + AutoWidthCalculator.prototype.postConstruct = function () { + var _this = this; + this.ctrlsService.whenReady(function (p) { + _this.centerRowContainerCon = p.centerRowContainerCtrl; + }); + }; + // this is the trick: we create a dummy container and clone all the cells + // into the dummy, then check the dummy's width. then destroy the dummy + // as we don't need it any more. + // drawback: only the cells visible on the screen are considered + AutoWidthCalculator.prototype.getPreferredWidthForColumn = function (column, skipHeader) { + var eHeaderCell = this.getHeaderCellForColumn(column); + // cell isn't visible + if (!eHeaderCell) { + return -1; } - else { - console.warn("ag-Grid: api.purgeInfiniteCache is only available when rowModelType='infinite'."); + var elements = this.rowRenderer.getAllCellsForColumn(column); + if (!skipHeader) { + // we only consider the lowest level cell, not the group cell. in 99% of the time, this + // will be enough. if we consider groups, then it gets too complicated for what it's worth, + // as the groups can span columns and this class only considers one column at a time. + elements.push(eHeaderCell); } + return this.addElementsToContainerAndGetWidth(elements); }; - /** @deprecated */ - GridApi.prototype.purgeEnterpriseCache = function (route) { - console.warn("ag-grid: since version 18.x, api.purgeEnterpriseCache() should be replaced with api.purgeServerSideCache()"); - this.purgeServerSideCache(route); - }; - GridApi.prototype.purgeServerSideCache = function (route) { - if (this.serverSideRowModel) { - this.serverSideRowModel.purgeCache(route); - } - else { - console.warn("ag-Grid: api.purgeServerSideCache is only available when rowModelType='enterprise'."); + AutoWidthCalculator.prototype.getPreferredWidthForColumnGroup = function (columnGroup) { + var eHeaderCell = this.getHeaderCellForColumn(columnGroup); + if (!eHeaderCell) { + return -1; } + return this.addElementsToContainerAndGetWidth([eHeaderCell]); }; - GridApi.prototype.getVirtualRowCount = function () { - console.warn('ag-Grid: getVirtualRowCount() is now called getInfiniteRowCount(), please call getInfiniteRowCount() instead'); - return this.getInfiniteRowCount(); + AutoWidthCalculator.prototype.addElementsToContainerAndGetWidth = function (elements) { + var _this = this; + var eDummyContainer = document.createElement('span'); + // position fixed, so it isn't restricted to the boundaries of the parent + eDummyContainer.style.position = 'fixed'; + // we put the dummy into the body container, so it will inherit all the + // css styles that the real cells are inheriting + var eBodyContainer = this.centerRowContainerCon.getContainerElement(); + eBodyContainer.appendChild(eDummyContainer); + elements.forEach(function (el) { return _this.cloneItemIntoDummy(el, eDummyContainer); }); + // at this point, all the clones are lined up vertically with natural widths. the dummy + // container will have a width wide enough just to fit the largest. + var dummyContainerWidth = eDummyContainer.offsetWidth; + // we are finished with the dummy container, so get rid of it + eBodyContainer.removeChild(eDummyContainer); + // we add padding as I found sometimes the gui still put '...' after some of the texts. so the + // user can configure the grid to add a few more pixels after the calculated width + var autoSizePadding = this.gridOptionsWrapper.getAutoSizePadding(); + return dummyContainerWidth + autoSizePadding; }; - GridApi.prototype.getInfiniteRowCount = function () { - if (this.infiniteRowModel) { - return this.infiniteRowModel.getVirtualRowCount(); - } - else { - console.warn("ag-Grid: api.getVirtualRowCount is only available when rowModelType='virtual'."); - } + AutoWidthCalculator.prototype.getHeaderCellForColumn = function (column) { + /* tslint:enable */ + var element = null; + this.ctrlsService.getHeaderRowContainerCtrls().forEach(function (container) { + var res = container.getHtmlElementForColumnHeader(column); + if (res != null) { + element = res; + } + }); + return element; }; - GridApi.prototype.isMaxRowFound = function () { - if (this.infiniteRowModel) { - return this.infiniteRowModel.isMaxRowFound(); + AutoWidthCalculator.prototype.cloneItemIntoDummy = function (eCell, eDummyContainer) { + // make a deep clone of the cell + var eCellClone = eCell.cloneNode(true); + // the original has a fixed width, we remove this to allow the natural width based on content + eCellClone.style.width = ''; + // the original has position = absolute, we need to remove this so it's positioned normally + eCellClone.style.position = 'static'; + eCellClone.style.left = ''; + // we put the cell into a containing div, as otherwise the cells would just line up + // on the same line, standard flow layout, by putting them into divs, they are laid + // out one per line + var eCloneParent = document.createElement('div'); + var eCloneParentClassList = eCloneParent.classList; + var isHeader = ['ag-header-cell', 'ag-header-group-cell'].some(function (cls) { return eCellClone.classList.contains(cls); }); + if (isHeader) { + eCloneParentClassList.add('ag-header', 'ag-header-row'); + eCloneParent.style.position = 'static'; } else { - console.warn("ag-Grid: api.isMaxRowFound is only available when rowModelType='virtual'."); + eCloneParentClassList.add('ag-row'); + } + // find parent using classes (headers have ag-header-cell, rows have ag-row), and copy classes from it. + // if we didn't do this, things like ag-row-level-2 would be missing if present, which sets indents + // onto group items. + var pointer = eCell.parentElement; + while (pointer) { + var isRow = ['ag-header-row', 'ag-row'].some(function (cls) { return pointer.classList.contains(cls); }); + if (isRow) { + for (var i = 0; i < pointer.classList.length; i++) { + var item = pointer.classList[i]; + // we skip ag-row-position-absolute, as this has structural CSS applied that stops the + // element from fitting into it's parent, and we need the element to stretch the parent + // as we are measuring the parents width + if (item != 'ag-row-position-absolute') { + eCloneParentClassList.add(item); + } + } + break; + } + pointer = pointer.parentElement; } + // the twig on the branch, the branch on the tree, the tree in the hole, + // the hole in the bog, the bog in the clone, the clone in the parent, + // the parent in the dummy, and the dummy down in the vall-e-ooo, OOOOOOOOO! Oh row the rattling bog.... + eCloneParent.appendChild(eCellClone); + eDummyContainer.appendChild(eCloneParent); }; - GridApi.prototype.setVirtualRowCount = function (rowCount, maxRowFound) { - console.warn('ag-Grid: setVirtualRowCount() is now called setInfiniteRowCount(), please call setInfiniteRowCount() instead'); - this.setInfiniteRowCount(rowCount, maxRowFound); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer') + ], AutoWidthCalculator.prototype, "rowRenderer", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('ctrlsService') + ], AutoWidthCalculator.prototype, "ctrlsService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowCssClassCalculator') + ], AutoWidthCalculator.prototype, "rowCssClassCalculator", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], AutoWidthCalculator.prototype, "postConstruct", null); + AutoWidthCalculator = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('autoWidthCalculator') + ], AutoWidthCalculator); + return AutoWidthCalculator; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + + + +/***/ }), +/* 176 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HorizontalResizeService", function() { return HorizontalResizeService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - GridApi.prototype.setInfiniteRowCount = function (rowCount, maxRowFound) { - if (this.infiniteRowModel) { - this.infiniteRowModel.setVirtualRowCount(rowCount, maxRowFound); - } - else { - console.warn("ag-Grid: api.setVirtualRowCount is only available when rowModelType='virtual'."); - } + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - GridApi.prototype.getVirtualPageState = function () { - console.warn('ag-Grid: getVirtualPageState() is now called getCacheBlockState(), please call getCacheBlockState() instead'); - return this.getCacheBlockState(); +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + +var HorizontalResizeService = /** @class */ (function (_super) { + __extends(HorizontalResizeService, _super); + function HorizontalResizeService() { + return _super !== null && _super.apply(this, arguments) || this; + } + HorizontalResizeService.prototype.addResizeBar = function (params) { + var _this = this; + var dragSource = { + dragStartPixels: params.dragStartPixels || 0, + eElement: params.eResizeBar, + onDragStart: this.onDragStart.bind(this, params), + onDragStop: this.onDragStop.bind(this, params), + onDragging: this.onDragging.bind(this, params) + }; + this.dragService.addDragSource(dragSource, true); + // we pass remove func back to the caller, so call can tell us when they + // are finished, and then we remove the listener from the drag source + var finishedWithResizeFunc = function () { return _this.dragService.removeDragSource(dragSource); }; + return finishedWithResizeFunc; }; - GridApi.prototype.getInfinitePageState = function () { - console.warn('ag-Grid: getInfinitePageState() is now called getCacheBlockState(), please call getCacheBlockState() instead'); - return this.getCacheBlockState(); + HorizontalResizeService.prototype.onDragStart = function (params, mouseEvent) { + this.dragStartX = mouseEvent.clientX; + this.setResizeIcons(); + var shiftKey = mouseEvent instanceof MouseEvent && mouseEvent.shiftKey === true; + params.onResizeStart(shiftKey); }; - GridApi.prototype.getCacheBlockState = function () { - if (this.infiniteRowModel) { - return this.infiniteRowModel.getBlockState(); - } - else if (this.serverSideRowModel) { - return this.serverSideRowModel.getBlockState(); - } - else { - console.warn("ag-Grid: api.getCacheBlockState() is only available when rowModelType='infinite' or rowModelType='serverSide'."); - } + HorizontalResizeService.prototype.setResizeIcons = function () { + var ctrl = this.ctrlsService.getGridCtrl(); + // change the body cursor, so when drag moves out of the drag bar, the cursor is still 'resize' (or 'move' + ctrl.setResizeCursor(true); + // we don't want text selection outside the grid (otherwise it looks weird as text highlights when we move) + ctrl.disableUserSelect(true); }; - GridApi.prototype.checkGridSize = function () { - this.gridPanel.setHeaderAndFloatingHeights(); + HorizontalResizeService.prototype.onDragStop = function (params, mouseEvent) { + params.onResizeEnd(this.resizeAmount); + this.resetIcons(); }; - GridApi.prototype.getFirstRenderedRow = function () { - console.warn('in ag-Grid v12, getFirstRenderedRow() was renamed to getFirstDisplayedRow()'); - return this.getFirstDisplayedRow(); + HorizontalResizeService.prototype.resetIcons = function () { + var ctrl = this.ctrlsService.getGridCtrl(); + ctrl.setResizeCursor(false); + ctrl.disableUserSelect(false); }; - GridApi.prototype.getFirstDisplayedRow = function () { - return this.rowRenderer.getFirstVirtualRenderedRow(); + HorizontalResizeService.prototype.onDragging = function (params, mouseEvent) { + this.resizeAmount = mouseEvent.clientX - this.dragStartX; + params.onResizing(this.resizeAmount); }; - GridApi.prototype.getLastRenderedRow = function () { - console.warn('in ag-Grid v12, getLastRenderedRow() was renamed to getLastDisplayedRow()'); - return this.getLastDisplayedRow(); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('dragService') + ], HorizontalResizeService.prototype, "dragService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('ctrlsService') + ], HorizontalResizeService.prototype, "ctrlsService", void 0); + HorizontalResizeService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('horizontalResizeService') + ], HorizontalResizeService); + return HorizontalResizeService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + + + +/***/ }), +/* 177 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridComp", function() { return GridComp; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(42); +/* harmony import */ var _focusService__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(173); +/* harmony import */ var _gridCtrl__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(178); +/* harmony import */ var _styling_layoutFeature__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(165); +/* harmony import */ var _widgets_tabGuardComp__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(179); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - GridApi.prototype.getLastDisplayedRow = function () { - return this.rowRenderer.getLastVirtualRenderedRow(); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - GridApi.prototype.getDisplayedRowAtIndex = function (index) { - return this.rowModel.getRow(index); +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + +var GridComp = /** @class */ (function (_super) { + __extends(GridComp, _super); + function GridComp(eGridDiv) { + var _this = _super.call(this, undefined) || this; + _this.eGridDiv = eGridDiv; + return _this; + } + GridComp.prototype.postConstruct = function () { + var _this = this; + this.logger = this.loggerFactory.create('GridComp'); + var compProxy = { + destroyGridUi: function () { return _this.destroyBean(_this); }, + setRtlClass: function (cssClass) { return _this.addCssClass(cssClass); }, + addOrRemoveKeyboardFocusClass: function (addOrRemove) { return _this.addOrRemoveCssClass(_focusService__WEBPACK_IMPORTED_MODULE_3__["FocusService"].AG_KEYBOARD_FOCUS, addOrRemove); }, + forceFocusOutOfContainer: this.forceFocusOutOfContainer.bind(this), + updateLayoutClasses: this.updateLayoutClasses.bind(this), + getFocusableContainers: this.getFocusableContainers.bind(this), + setUserSelect: function (value) { + _this.getGui().style.userSelect = value != null ? value : ''; + _this.getGui().style.webkitUserSelect = value != null ? value : ''; + }, + setCursor: function (value) { + _this.getGui().style.cursor = value != null ? value : ''; + } + }; + this.ctrl = this.createManagedBean(new _gridCtrl__WEBPACK_IMPORTED_MODULE_4__["GridCtrl"]()); + var template = this.createTemplate(); + this.setTemplate(template); + this.ctrl.setComp(compProxy, this.eGridDiv, this.getGui()); + this.insertGridIntoDom(); + this.initialiseTabGuard({ + // we want to override the default behaviour to do nothing for onTabKeyDown + onTabKeyDown: function () { return undefined; }, + focusInnerElement: function (fromBottom) { return _this.ctrl.focusInnerElement(fromBottom); } + }); }; - GridApi.prototype.getDisplayedRowCount = function () { - return this.rowModel.getRowCount(); + GridComp.prototype.insertGridIntoDom = function () { + var _this = this; + var eGui = this.getGui(); + this.eGridDiv.appendChild(eGui); + this.addDestroyFunc(function () { + _this.eGridDiv.removeChild(eGui); + _this.logger.log('Grid removed from DOM'); + }); + }; + GridComp.prototype.updateLayoutClasses = function (cssClass, params) { + var eRootWrapperBodyClassList = this.eRootWrapperBody.classList; + eRootWrapperBodyClassList.toggle(_styling_layoutFeature__WEBPACK_IMPORTED_MODULE_5__["LayoutCssClasses"].AUTO_HEIGHT, params.autoHeight); + eRootWrapperBodyClassList.toggle(_styling_layoutFeature__WEBPACK_IMPORTED_MODULE_5__["LayoutCssClasses"].NORMAL, params.normal); + eRootWrapperBodyClassList.toggle(_styling_layoutFeature__WEBPACK_IMPORTED_MODULE_5__["LayoutCssClasses"].PRINT, params.print); + this.addOrRemoveCssClass(_styling_layoutFeature__WEBPACK_IMPORTED_MODULE_5__["LayoutCssClasses"].AUTO_HEIGHT, params.autoHeight); + this.addOrRemoveCssClass(_styling_layoutFeature__WEBPACK_IMPORTED_MODULE_5__["LayoutCssClasses"].NORMAL, params.normal); + this.addOrRemoveCssClass(_styling_layoutFeature__WEBPACK_IMPORTED_MODULE_5__["LayoutCssClasses"].PRINT, params.print); + }; + GridComp.prototype.createTemplate = function () { + var dropZones = this.ctrl.showDropZones() ? '' : ''; + var sideBar = this.ctrl.showSideBar() ? '' : ''; + var statusBar = this.ctrl.showStatusBar() ? '' : ''; + var watermark = this.ctrl.showWatermark() ? '' : ''; + var template = /* html */ "
\n " + dropZones + "\n
\n \n " + sideBar + "\n
\n " + statusBar + "\n \n " + watermark + "\n
"; + return template; }; - GridApi.prototype.paginationIsLastPageFound = function () { - return this.paginationProxy.isLastPageFound(); + GridComp.prototype.getFocusableElement = function () { + return this.eRootWrapperBody; }; - GridApi.prototype.paginationGetPageSize = function () { - return this.paginationProxy.getPageSize(); + GridComp.prototype.getFocusableContainers = function () { + var focusableContainers = [ + this.gridBodyComp.getGui() + ]; + if (this.sideBarComp) { + focusableContainers.push(this.sideBarComp.getGui()); + } + return focusableContainers.filter(function (el) { return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["isVisible"])(el); }); }; - GridApi.prototype.paginationSetPageSize = function (size) { - this.gridOptionsWrapper.setProperty('paginationPageSize', size); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('loggerFactory') + ], GridComp.prototype, "loggerFactory", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('gridBody') + ], GridComp.prototype, "gridBodyComp", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('sideBar') + ], GridComp.prototype, "sideBarComp", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('rootWrapperBody') + ], GridComp.prototype, "eRootWrapperBody", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], GridComp.prototype, "postConstruct", null); + return GridComp; +}(_widgets_tabGuardComp__WEBPACK_IMPORTED_MODULE_6__["TabGuardComp"])); + + + +/***/ }), +/* 178 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridCtrl", function() { return GridCtrl; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(17); +/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(16); +/* harmony import */ var _styling_layoutFeature__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(165); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(24); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(18); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - GridApi.prototype.paginationGetCurrentPage = function () { - return this.paginationProxy.getCurrentPage(); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - GridApi.prototype.paginationGetTotalPages = function () { - return this.paginationProxy.getTotalPages(); +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + + + +var GridCtrl = /** @class */ (function (_super) { + __extends(GridCtrl, _super); + function GridCtrl() { + return _super !== null && _super.apply(this, arguments) || this; + } + GridCtrl.prototype.postConstruct = function () { + this.ctrlsService.registerGridCtrl(this); }; - GridApi.prototype.paginationGetRowCount = function () { - return this.paginationProxy.getMasterRowCount(); + GridCtrl.prototype.setComp = function (view, eGridDiv, eGui) { + var _this = this; + this.view = view; + this.eGridHostDiv = eGridDiv; + this.eGui = eGui; + this.mouseEventService.stampTopLevelGridCompWithGridInstance(eGridDiv); + this.createManagedBean(new _styling_layoutFeature__WEBPACK_IMPORTED_MODULE_4__["LayoutFeature"](this.view)); + // important to set rtl before doLayout, as setting the RTL class impacts the scroll position, + // which doLayout indirectly depends on + this.addRtlSupport(); + this.addManagedListener(this, _eventKeys__WEBPACK_IMPORTED_MODULE_5__["Events"].EVENT_KEYBOARD_FOCUS, function () { + _this.view.addOrRemoveKeyboardFocusClass(true); + }); + this.addManagedListener(this, _eventKeys__WEBPACK_IMPORTED_MODULE_5__["Events"].EVENT_MOUSE_FOCUS, function () { + _this.view.addOrRemoveKeyboardFocusClass(false); + }); + var unsubscribeFromResize = this.resizeObserverService.observeResize(this.eGridHostDiv, this.onGridSizeChanged.bind(this)); + this.addDestroyFunc(function () { return unsubscribeFromResize(); }); }; - GridApi.prototype.paginationGoToNextPage = function () { - this.paginationProxy.goToNextPage(); + GridCtrl.prototype.showDropZones = function () { + return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_2__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].RowGroupingModule); }; - GridApi.prototype.paginationGoToPreviousPage = function () { - this.paginationProxy.goToPreviousPage(); + GridCtrl.prototype.showSideBar = function () { + return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_2__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].SideBarModule); }; - GridApi.prototype.paginationGoToFirstPage = function () { - this.paginationProxy.goToFirstPage(); + GridCtrl.prototype.showStatusBar = function () { + return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_2__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].StatusBarModule); }; - GridApi.prototype.paginationGoToLastPage = function () { - this.paginationProxy.goToLastPage(); + GridCtrl.prototype.showWatermark = function () { + return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_2__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].EnterpriseCoreModule); }; - GridApi.prototype.paginationGoToPage = function (page) { - this.paginationProxy.goToPage(page); + GridCtrl.prototype.onGridSizeChanged = function () { + var event = { + type: _eventKeys__WEBPACK_IMPORTED_MODULE_5__["Events"].EVENT_GRID_SIZE_CHANGED, + api: this.gridApi, + columnApi: this.columnApi, + clientWidth: this.eGridHostDiv.clientWidth, + clientHeight: this.eGridHostDiv.clientHeight + }; + this.eventService.dispatchEvent(event); + }; + GridCtrl.prototype.addRtlSupport = function () { + var cssClass = this.gridOptionsWrapper.isEnableRtl() ? 'ag-rtl' : 'ag-ltr'; + this.view.setRtlClass(cssClass); + }; + GridCtrl.prototype.destroyGridUi = function () { + this.view.destroyGridUi(); + }; + GridCtrl.prototype.getGui = function () { + return this.eGui; + }; + GridCtrl.prototype.setResizeCursor = function (on) { + this.view.setCursor(on ? 'ew-resize' : null); + }; + GridCtrl.prototype.disableUserSelect = function (on) { + this.view.setUserSelect(on ? 'none' : null); + }; + GridCtrl.prototype.focusNextInnerContainer = function (backwards) { + var eDocument = this.gridOptionsWrapper.getDocument(); + var focusableContainers = this.view.getFocusableContainers(); + var idxWithFocus = focusableContainers.findIndex(function (container) { return container.contains(eDocument.activeElement); }); + var nextIdx = idxWithFocus + (backwards ? -1 : 1); + if (nextIdx <= 0 || nextIdx >= focusableContainers.length) { + return false; + } + return this.focusService.focusInto(focusableContainers[nextIdx]); + }; + GridCtrl.prototype.focusInnerElement = function (fromBottom) { + var focusableContainers = this.view.getFocusableContainers(); + if (fromBottom) { + if (focusableContainers.length > 1) { + return this.focusService.focusInto(Object(_utils_array__WEBPACK_IMPORTED_MODULE_6__["last"])(focusableContainers), true); + } + var lastColumn = Object(_utils_array__WEBPACK_IMPORTED_MODULE_6__["last"])(this.columnModel.getAllDisplayedColumns()); + if (this.focusService.focusGridView(lastColumn, true)) { + return true; + } + } + return this.focusService.focusFirstHeader(); + }; + GridCtrl.prototype.forceFocusOutOfContainer = function (up) { + if (up === void 0) { up = false; } + this.view.forceFocusOutOfContainer(up); }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('immutableService') - ], GridApi.prototype, "immutableService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('csvCreator') - ], GridApi.prototype, "csvCreator", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('excelCreator') - ], GridApi.prototype, "excelCreator", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('rowRenderer') - ], GridApi.prototype, "rowRenderer", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('filterManager') - ], GridApi.prototype, "filterManager", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnController') - ], GridApi.prototype, "columnController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('selectionController') - ], GridApi.prototype, "selectionController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper') - ], GridApi.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('valueService') - ], GridApi.prototype, "valueService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('alignedGridsService') - ], GridApi.prototype, "alignedGridsService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('eventService') - ], GridApi.prototype, "eventService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('pinnedRowModel') - ], GridApi.prototype, "pinnedRowModel", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('context') - ], GridApi.prototype, "context", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('rowModel') - ], GridApi.prototype, "rowModel", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('sortController') - ], GridApi.prototype, "sortController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('paginationProxy') - ], GridApi.prototype, "paginationProxy", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('focusController') - ], GridApi.prototype, "focusController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('dragAndDropService') - ], GridApi.prototype, "dragAndDropService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('rangeController') - ], GridApi.prototype, "rangeController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('clipboardService') - ], GridApi.prototype, "clipboardService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('aggFuncService') - ], GridApi.prototype, "aggFuncService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('menuFactory') - ], GridApi.prototype, "menuFactory", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('contextMenuFactory') - ], GridApi.prototype, "contextMenuFactory", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') + ], GridCtrl.prototype, "columnApi", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('cellRendererFactory') - ], GridApi.prototype, "cellRendererFactory", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') + ], GridCtrl.prototype, "gridApi", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('valueCache') - ], GridApi.prototype, "valueCache", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusService') + ], GridCtrl.prototype, "focusService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('animationFrameService') - ], GridApi.prototype, "animationFrameService", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('resizeObserverService') + ], GridCtrl.prototype, "resizeObserverService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('statusBarService') - ], GridApi.prototype, "statusBarService", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], GridCtrl.prototype, "columnModel", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('chartService') - ], GridApi.prototype, "chartService", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('ctrlsService') + ], GridCtrl.prototype, "ctrlsService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('undoRedoService') - ], GridApi.prototype, "undoRedoService", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('mouseEventService') + ], GridCtrl.prototype, "mouseEventService", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] - ], GridApi.prototype, "init", null); - GridApi = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Bean"])('gridApi') - ], GridApi); - return GridApi; -}()); + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], GridCtrl.prototype, "postConstruct", null); + return GridCtrl; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 131 */ +/* 179 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ExpressionService", function() { return ExpressionService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TabGuardComp", function() { return TabGuardComp; }); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(42); +/* harmony import */ var _tabGuardCtrl__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(180); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(44); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -32822,110 +40502,108 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; }; -var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { - return function (target, key) { decorator(target, key, paramIndex); } +var __spread = (undefined && undefined.__spread) || function () { + for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); + return ar; }; -var ExpressionService = /** @class */ (function (_super) { - __extends(ExpressionService, _super); - function ExpressionService() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.expressionToFunctionCache = {}; - return _this; + +var TabGuardComp = /** @class */ (function (_super) { + __extends(TabGuardComp, _super); + function TabGuardComp() { + return _super !== null && _super.apply(this, arguments) || this; } - ExpressionService.prototype.setBeans = function (loggerFactory) { - this.logger = loggerFactory.create('ExpressionService'); + TabGuardComp.prototype.initialiseTabGuard = function (params) { + this.eTopGuard = this.createTabGuard('top'); + this.eBottomGuard = this.createTabGuard('bottom'); + this.eFocusableElement = this.getFocusableElement(); + var tabGuards = [this.eTopGuard, this.eBottomGuard]; + var compProxy = { + setTabIndex: function (tabIndex) { + tabGuards.forEach(function (tabGuard) { return tabIndex != null ? tabGuard.setAttribute('tabIndex', tabIndex) : tabGuard.removeAttribute('tabIndex'); }); + } + }; + this.addTabGuards(this.eTopGuard, this.eBottomGuard); + this.tabGuardCtrl = this.createManagedBean(new _tabGuardCtrl__WEBPACK_IMPORTED_MODULE_2__["TabGuardCtrl"]({ + comp: compProxy, + eTopGuard: this.eTopGuard, + eBottomGuard: this.eBottomGuard, + eFocusableElement: this.eFocusableElement, + onFocusIn: params.onFocusIn, + onFocusOut: params.onFocusOut, + focusInnerElement: params.focusInnerElement, + handleKeyDown: params.handleKeyDown, + onTabKeyDown: params.onTabKeyDown, + shouldStopEventPropagation: params.shouldStopEventPropagation + })); }; - ExpressionService.prototype.evaluate = function (expressionOrFunc, params) { - if (typeof expressionOrFunc === 'function') { - // valueGetter is a function, so just call it - var func = expressionOrFunc; - return func(params); - } - else if (typeof expressionOrFunc === 'string') { - // valueGetter is an expression, so execute the expression - var expression = expressionOrFunc; - return this.evaluateExpression(expression, params); - } - else { - console.error('ag-Grid: value should be either a string or a function', expressionOrFunc); - } + TabGuardComp.prototype.createTabGuard = function (side) { + var tabGuard = document.createElement('div'); + tabGuard.classList.add('ag-tab-guard', "ag-tab-guard-" + side); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_3__["setAriaRole"])(tabGuard, 'presentation'); + return tabGuard; }; - ExpressionService.prototype.evaluateExpression = function (expression, params) { - try { - var javaScriptFunction = this.createExpressionFunction(expression); - // the params don't have all these values, rather we add every possible - // value a params can have, which makes whatever is in the params available. - var result = javaScriptFunction(params.value, params.context, params.oldValue, params.newValue, params.value, params.node, params.data, params.colDef, params.rowIndex, params.api, params.columnApi, params.getValue, params.column, params.columnGroup); - return result; - } - catch (e) { - // the expression failed, which can happen, as it's the client that - // provides the expression. so print a nice message - // tslint:disable-next-line - console.log('Processing of the expression failed'); - // tslint:disable-next-line - console.log('Expression = ' + expression); - // tslint:disable-next-line - console.log('Params =', params); - // tslint:disable-next-line - console.log('Exception = ' + e); - return null; - } + TabGuardComp.prototype.addTabGuards = function (topTabGuard, bottomTabGuard) { + this.eFocusableElement.insertAdjacentElement('afterbegin', topTabGuard); + this.eFocusableElement.insertAdjacentElement('beforeend', bottomTabGuard); }; - ExpressionService.prototype.createExpressionFunction = function (expression) { - // check cache first - if (this.expressionToFunctionCache[expression]) { - return this.expressionToFunctionCache[expression]; - } - // if not found in cache, return the function - var functionBody = this.createFunctionBody(expression); - var theFunction = new Function('x, ctx, oldValue, newValue, value, node, data, colDef, rowIndex, api, columnApi, getValue, column, columnGroup', functionBody); - // store in cache - this.expressionToFunctionCache[expression] = theFunction; - return theFunction; + TabGuardComp.prototype.removeAllChildrenExceptTabGuards = function () { + var tabGuards = [this.eTopGuard, this.eBottomGuard]; + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["clearElement"])(this.getFocusableElement()); + this.addTabGuards.apply(this, __spread(tabGuards)); }; - ExpressionService.prototype.createFunctionBody = function (expression) { - // if the expression has the 'return' word in it, then use as is, - // if not, then wrap it with return and ';' to make a function - if (expression.indexOf('return') >= 0) { - return expression; + TabGuardComp.prototype.forceFocusOutOfContainer = function (up) { + if (up === void 0) { up = false; } + this.tabGuardCtrl.forceFocusOutOfContainer(up); + }; + TabGuardComp.prototype.appendChild = function (newChild, container) { + if (!Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["isNodeOrElement"])(newChild)) { + newChild = newChild.getGui(); + } + var bottomTabGuard = this.eBottomGuard; + if (bottomTabGuard) { + bottomTabGuard.insertAdjacentElement('beforebegin', newChild); } else { - return 'return ' + expression + ';'; + _super.prototype.appendChild.call(this, newChild, container); } }; - __decorate([ - __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('loggerFactory')) - ], ExpressionService.prototype, "setBeans", null); - ExpressionService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('expressionService') - ], ExpressionService); - return ExpressionService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + return TabGuardComp; +}(_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); /***/ }), -/* 132 */ +/* 180 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TemplateService", function() { return TemplateService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TabGuardCtrl", function() { return TabGuardCtrl; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _managedFocusFeature__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(64); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -32951,92 +40629,161 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var TemplateService = /** @class */ (function (_super) { - __extends(TemplateService, _super); - function TemplateService() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.templateCache = {}; - _this.waitingCallbacks = {}; +var TabGuardCtrl = /** @class */ (function (_super) { + __extends(TabGuardCtrl, _super); + function TabGuardCtrl(params) { + var _this = _super.call(this) || this; + _this.skipTabGuardFocus = false; + var comp = params.comp, eTopGuard = params.eTopGuard, eBottomGuard = params.eBottomGuard, focusInnerElement = params.focusInnerElement, onFocusIn = params.onFocusIn, onFocusOut = params.onFocusOut, shouldStopEventPropagation = params.shouldStopEventPropagation, onTabKeyDown = params.onTabKeyDown, handleKeyDown = params.handleKeyDown, eFocusableElement = params.eFocusableElement; + _this.comp = comp; + _this.eTopGuard = eTopGuard; + _this.eBottomGuard = eBottomGuard; + _this.providedFocusInnerElement = focusInnerElement; + _this.eFocusableElement = eFocusableElement; + _this.providedFocusIn = onFocusIn; + _this.providedFocusOut = onFocusOut; + _this.providedShouldStopEventPropagation = shouldStopEventPropagation; + _this.providedOnTabKeyDown = onTabKeyDown; + _this.providedHandleKeyDown = handleKeyDown; return _this; } - // returns the template if it is loaded, or null if it is not loaded - // but will call the callback when it is loaded - TemplateService.prototype.getTemplate = function (url, callback) { - var templateFromCache = this.templateCache[url]; - if (templateFromCache) { - return templateFromCache; + TabGuardCtrl.prototype.postConstruct = function () { + var _this = this; + this.createManagedBean(new _managedFocusFeature__WEBPACK_IMPORTED_MODULE_2__["ManagedFocusFeature"](this.eFocusableElement, { + shouldStopEventPropagation: function () { return _this.shouldStopEventPropagation(); }, + onTabKeyDown: function (e) { return _this.onTabKeyDown(e); }, + handleKeyDown: function (e) { return _this.handleKeyDown(e); }, + onFocusIn: function (e) { return _this.onFocusIn(e); }, + onFocusOut: function (e) { return _this.onFocusOut(e); } + })); + this.activateTabGuards(); + [this.eTopGuard, this.eBottomGuard].forEach(function (guard) { return _this.addManagedListener(guard, 'focus', _this.onFocus.bind(_this)); }); + }; + TabGuardCtrl.prototype.handleKeyDown = function (e) { + if (this.providedHandleKeyDown) { + this.providedHandleKeyDown(e); } - var callbackList = this.waitingCallbacks[url]; - var that = this; - if (!callbackList) { - // first time this was called, so need a new list for callbacks - callbackList = []; - this.waitingCallbacks[url] = callbackList; - // and also need to do the http request - var client = new XMLHttpRequest(); - client.onload = function () { - that.handleHttpResult(this, url); - }; - client.open("GET", url); - client.send(); + }; + TabGuardCtrl.prototype.tabGuardsAreActive = function () { + return !!this.eTopGuard && this.eTopGuard.hasAttribute('tabIndex'); + }; + TabGuardCtrl.prototype.shouldStopEventPropagation = function () { + if (this.providedShouldStopEventPropagation) { + return this.providedShouldStopEventPropagation(); } - // add this callback - if (callback) { - callbackList.push(callback); + return false; + }; + TabGuardCtrl.prototype.activateTabGuards = function () { + this.comp.setTabIndex(this.getGridTabIndex()); + }; + TabGuardCtrl.prototype.deactivateTabGuards = function () { + this.comp.setTabIndex(); + }; + TabGuardCtrl.prototype.onFocus = function (e) { + if (this.skipTabGuardFocus) { + this.skipTabGuardFocus = false; + return; + } + var fromBottom = e.target === this.eBottomGuard; + if (this.providedFocusInnerElement) { + this.providedFocusInnerElement(fromBottom); + } + else { + this.focusInnerElement(fromBottom); } - // caller needs to wait for template to load, so return null - return null; }; - TemplateService.prototype.handleHttpResult = function (httpResult, url) { - if (httpResult.status !== 200 || httpResult.response === null) { - console.warn("Unable to get template error " + httpResult.status + " - " + url); + TabGuardCtrl.prototype.onFocusIn = function (e) { + if (this.providedFocusIn && this.providedFocusIn(e)) { return; } - // response success, so process it - // in IE9 the response is in - responseText - this.templateCache[url] = httpResult.response || httpResult.responseText; - // inform all listeners that this is now in the cache - var callbacks = this.waitingCallbacks[url]; - for (var i = 0; i < callbacks.length; i++) { - var callback = callbacks[i]; - // we could pass the callback the response, however we know the client of this code - // is the cell renderer, and it passes the 'cellRefresh' method in as the callback - // which doesn't take any parameters. - callback(); + this.deactivateTabGuards(); + }; + TabGuardCtrl.prototype.onFocusOut = function (e) { + if (this.providedFocusOut && this.providedFocusOut(e)) { + return; } - if (this.$scope) { - var that_1 = this; - window.setTimeout(function () { - that_1.$scope.$apply(); - }, 0); + if (!this.eFocusableElement.contains(e.relatedTarget)) { + this.activateTabGuards(); + } + }; + TabGuardCtrl.prototype.onTabKeyDown = function (e) { + var _this = this; + if (this.providedOnTabKeyDown) { + this.providedOnTabKeyDown(e); + return; + } + if (e.defaultPrevented) { + return; + } + var tabGuardsAreActive = this.tabGuardsAreActive(); + if (tabGuardsAreActive) { + this.deactivateTabGuards(); + } + var nextRoot = this.getNextFocusableElement(e.shiftKey); + if (tabGuardsAreActive) { + // ensure the tab guards are only re-instated once the event has finished processing, to avoid the browser + // tabbing to the tab guard from inside the component + setTimeout(function () { return _this.activateTabGuards(); }, 0); + } + if (!nextRoot) { + return; } + nextRoot.focus(); + e.preventDefault(); + }; + TabGuardCtrl.prototype.getGridTabIndex = function () { + return this.gridOptionsWrapper.getGridTabIndex(); + }; + TabGuardCtrl.prototype.focusInnerElement = function (fromBottom) { + if (fromBottom === void 0) { fromBottom = false; } + var focusable = this.focusService.findFocusableElements(this.eFocusableElement); + if (this.tabGuardsAreActive()) { + // remove tab guards from this component from list of focusable elements + focusable.splice(0, 1); + focusable.splice(focusable.length - 1, 1); + } + if (!focusable.length) { + return; + } + focusable[fromBottom ? focusable.length - 1 : 0].focus(); + }; + TabGuardCtrl.prototype.getNextFocusableElement = function (backwards) { + return this.focusService.findNextFocusableElement(this.eFocusableElement, false, backwards); + }; + TabGuardCtrl.prototype.forceFocusOutOfContainer = function (up) { + if (up === void 0) { up = false; } + var tabGuardToFocus = up ? this.eTopGuard : this.eBottomGuard; + this.activateTabGuards(); + this.skipTabGuardFocus = true; + tabGuardToFocus.focus(); }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('$scope') - ], TemplateService.prototype, "$scope", void 0); - TemplateService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('templateService') - ], TemplateService); - return TemplateService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('focusService') + ], TabGuardCtrl.prototype, "focusService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], TabGuardCtrl.prototype, "postConstruct", null); + return TabGuardCtrl; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 133 */ +/* 181 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PopupService", function() { return PopupService; }); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(25); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DragService", function() { return DragService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(23); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(20); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(18); +/* harmony import */ var _utils_mouse__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(50); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -33064,478 +40811,288 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var PopupService = /** @class */ (function (_super) { - __extends(PopupService, _super); - function PopupService() { + +/** Adds drag listening onto an element. In AG Grid this is used twice, first is resizing columns, + * second is moving the columns and column groups around (ie the 'drag' part of Drag and Drop. */ +var DragService = /** @class */ (function (_super) { + __extends(DragService, _super); + function DragService() { var _this = _super !== null && _super.apply(this, arguments) || this; - _this.popupList = []; + _this.dragEndFunctions = []; + _this.dragSources = []; return _this; } - PopupService.prototype.init = function () { - var _this = this; - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_KEYBOARD_FOCUS, function () { - _this.popupList.forEach(function (popup) { - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(popup.element, 'ag-keyboard-focus'); - }); - }); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_MOUSE_FOCUS, function () { - _this.popupList.forEach(function (popup) { - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].removeCssClass(popup.element, 'ag-keyboard-focus'); - }); - }); - }; - PopupService.prototype.registerGridCore = function (gridCore) { - this.gridCore = gridCore; - }; - PopupService.prototype.getPopupParent = function () { - var ePopupParent = this.gridOptionsWrapper.getPopupParent(); - if (ePopupParent) { - return ePopupParent; - } - return this.gridCore.getRootGui(); - }; - PopupService.prototype.positionPopupForMenu = function (params) { - var sourceRect = params.eventSource.getBoundingClientRect(); - var parentRect = this.getParentRect(); - var y = this.keepYWithinBounds(params, sourceRect.top - parentRect.top); - var minWidth = (params.ePopup.clientWidth > 0) ? params.ePopup.clientWidth : 200; - params.ePopup.style.minWidth = minWidth + "px"; - var widthOfParent = parentRect.right - parentRect.left; - var maxX = widthOfParent - minWidth; - // the x position of the popup depends on RTL or LTR. for normal cases, LTR, we put the child popup - // to the right, unless it doesn't fit and we then put it to the left. for RTL it's the other way around, - // we try place it first to the left, and then if not to the right. - var x; - if (this.gridOptionsWrapper.isEnableRtl()) { - // for RTL, try left first - x = xLeftPosition(); - if (x < 0) { - x = xRightPosition(); - } - if (x > maxX) { - x = 0; - } - } - else { - // for LTR, try right first - x = xRightPosition(); - if (x > maxX) { - x = xLeftPosition(); - } - if (x < 0) { - x = 0; - } - } - params.ePopup.style.left = x + "px"; - params.ePopup.style.top = y + "px"; - function xRightPosition() { - return sourceRect.right - parentRect.left - 2; - } - function xLeftPosition() { - return sourceRect.left - parentRect.left - minWidth; - } - }; - PopupService.prototype.positionPopupUnderMouseEvent = function (params) { - var _a = this.calculatePointerAlign(params.mouseEvent), x = _a.x, y = _a.y; - var ePopup = params.ePopup, nudgeX = params.nudgeX, nudgeY = params.nudgeY; - this.positionPopup({ - ePopup: ePopup, - x: x, - y: y, - nudgeX: nudgeX, - nudgeY: nudgeY, - keepWithinBounds: true - }); - this.callPostProcessPopup(params.type, params.ePopup, null, params.mouseEvent, params.column, params.rowNode); - }; - PopupService.prototype.calculatePointerAlign = function (e) { - var parentRect = this.getParentRect(); - return { - x: e.clientX - parentRect.left, - y: e.clientY - parentRect.top - }; - }; - PopupService.prototype.positionPopupUnderComponent = function (params) { - var sourceRect = params.eventSource.getBoundingClientRect(); - var alignSide = params.alignSide || 'left'; - var parentRect = this.getParentRect(); - var x = sourceRect.left - parentRect.left; - if (alignSide === 'right') { - x -= (params.ePopup.offsetWidth - sourceRect.width); - } - this.positionPopup({ - ePopup: params.ePopup, - minWidth: params.minWidth, - minHeight: params.minHeight, - nudgeX: params.nudgeX, - nudgeY: params.nudgeY, - x: x, - y: sourceRect.top - parentRect.top + sourceRect.height, - keepWithinBounds: params.keepWithinBounds - }); - this.callPostProcessPopup(params.type, params.ePopup, params.eventSource, null, params.column, params.rowNode); - }; - PopupService.prototype.positionPopupOverComponent = function (params) { - var sourceRect = params.eventSource.getBoundingClientRect(); - var parentRect = this.getParentRect(); - this.positionPopup({ - ePopup: params.ePopup, - minWidth: params.minWidth, - nudgeX: params.nudgeX, - nudgeY: params.nudgeY, - x: sourceRect.left - parentRect.left, - y: sourceRect.top - parentRect.top, - keepWithinBounds: params.keepWithinBounds - }); - this.callPostProcessPopup(params.type, params.ePopup, params.eventSource, null, params.column, params.rowNode); - }; - PopupService.prototype.callPostProcessPopup = function (type, ePopup, eventSource, mouseEvent, column, rowNode) { - var callback = this.gridOptionsWrapper.getPostProcessPopupFunc(); - if (callback) { - var params = { - column: column, - rowNode: rowNode, - ePopup: ePopup, - type: type, - eventSource: eventSource, - mouseEvent: mouseEvent - }; - callback(params); - } - }; - PopupService.prototype.positionPopup = function (params) { - var x = params.x; - var y = params.y; - if (params.nudgeX) { - x += params.nudgeX; - } - if (params.nudgeY) { - y += params.nudgeY; - } - // if popup is overflowing to the bottom, move it up - if (params.keepWithinBounds) { - x = this.keepXWithinBounds(params, x); - y = this.keepYWithinBounds(params, y); - } - params.ePopup.style.left = x + "px"; - params.ePopup.style.top = y + "px"; - }; - PopupService.prototype.getActivePopups = function () { - return this.popupList.map(function (popup) { return popup.element; }); - }; - PopupService.prototype.getParentRect = function () { - // subtract the popup parent borders, because popupParent.getBoundingClientRect - // returns the rect outside the borders, but the 0,0 coordinate for absolute - // positioning is inside the border, leading the popup to be off by the width - // of the border - var popupParent = this.getPopupParent(); - var eDocument = this.gridOptionsWrapper.getDocument(); - if (popupParent === eDocument.body) { - popupParent = eDocument.documentElement; - } - var style = getComputedStyle(popupParent); - var bounds = popupParent.getBoundingClientRect(); - return { - top: bounds.top + parseFloat(style.borderTopWidth) || 0, - left: bounds.left + parseFloat(style.borderLeftWidth) || 0, - right: bounds.right + parseFloat(style.borderRightWidth) || 0, - bottom: bounds.bottom + parseFloat(style.borderBottomWidth) || 0, - }; - }; - PopupService.prototype.keepYWithinBounds = function (params, y) { - var eDocument = this.gridOptionsWrapper.getDocument(); - var docElement = eDocument.documentElement; - var popupParent = this.getPopupParent(); - var parentRect = popupParent.getBoundingClientRect(); - var documentRect = eDocument.documentElement.getBoundingClientRect(); - var isBody = popupParent === eDocument.body; - var minHeight = Math.min(200, parentRect.height); - var diff = 0; - if (params.minHeight && params.minHeight < minHeight) { - minHeight = params.minHeight; - } - else if (params.ePopup.offsetHeight > 0) { - minHeight = params.ePopup.clientHeight; - diff = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].getAbsoluteHeight(params.ePopup) - minHeight; - } - var heightOfParent = isBody ? (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].getAbsoluteHeight(docElement) + docElement.scrollTop) : parentRect.height; - if (isBody) { - heightOfParent -= Math.abs(documentRect.top - parentRect.top); - } - var maxY = heightOfParent - minHeight - diff; - return Math.min(Math.max(y, 0), Math.abs(maxY)); - }; - PopupService.prototype.keepXWithinBounds = function (params, x) { - var eDocument = this.gridOptionsWrapper.getDocument(); - var docElement = eDocument.documentElement; - var popupParent = this.getPopupParent(); - var parentRect = popupParent.getBoundingClientRect(); - var documentRect = eDocument.documentElement.getBoundingClientRect(); - var isBody = popupParent === eDocument.body; - var ePopup = params.ePopup; - var minWidth = Math.min(200, parentRect.width); - var diff = 0; - if (params.minWidth && params.minWidth < minWidth) { - minWidth = params.minWidth; - } - else if (ePopup.offsetWidth > 0) { - minWidth = ePopup.offsetWidth; - ePopup.style.minWidth = minWidth + "px"; - diff = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].getAbsoluteWidth(ePopup) - minWidth; - } - var widthOfParent = isBody ? (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].getAbsoluteWidth(docElement) + docElement.scrollLeft) : parentRect.width; - if (isBody) { - widthOfParent -= Math.abs(documentRect.left - parentRect.left); - } - var maxX = widthOfParent - minWidth - diff; - return Math.min(Math.max(x, 0), Math.abs(maxX)); - }; - // adds an element to a div, but also listens to background checking for clicks, - // so that when the background is clicked, the child is removed again, giving - // a model look to popups. - PopupService.prototype.addAsModalPopup = function (eChild, closeOnEsc, closedCallback, click) { - return this.addPopup(true, eChild, closeOnEsc, closedCallback, click); + DragService.prototype.init = function () { + this.logger = this.loggerFactory.create('DragService'); }; - PopupService.prototype.addPopup = function (modal, eChild, closeOnEsc, closedCallback, click, alwaysOnTop) { - var _this = this; - var eDocument = this.gridOptionsWrapper.getDocument(); - if (!eDocument) { - console.warn('ag-grid: could not find the document, document is empty'); - return function () { }; - } - var pos = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].findIndex(this.popupList, function (popup) { return popup.element === eChild; }); - if (pos !== -1) { - var popup = this.popupList[pos]; - return popup.hideFunc; - } - var ePopupParent = this.getPopupParent(); - // for angular specifically, but shouldn't cause an issue with js or other fw's - // https://github.com/angular/angular/issues/8563 - ePopupParent.appendChild(eChild); - eChild.style.top = '0px'; - eChild.style.left = '0px'; - // add env CSS class to child, in case user provided a popup parent, which means - // theme class may be missing - var eWrapper = document.createElement('div'); - var theme = this.environment.getTheme().theme; - if (theme) { - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(eWrapper, theme); - } - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(eWrapper, 'ag-popup'); - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(eChild, this.gridOptionsWrapper.isEnableRtl() ? 'ag-rtl' : 'ag-ltr'); - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(eChild, 'ag-popup-child'); - eWrapper.appendChild(eChild); - ePopupParent.appendChild(eWrapper); - if (alwaysOnTop) { - this.setAlwaysOnTop(eWrapper, true); - } - else { - this.bringPopupToFront(eWrapper); - } - var popupHidden = false; - var hidePopupOnKeyboardEvent = function (event) { - var key = event.which || event.keyCode; - if (!eWrapper.contains(document.activeElement)) { - return; - } - switch (key) { - case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_ESCAPE: - hidePopup({ keyboardEvent: event }); - } - }; - var hidePopupOnMouseEvent = function (event) { - hidePopup({ mouseEvent: event }); - }; - var hidePopupOnTouchEvent = function (event) { - hidePopup({ touchEvent: event }); - }; - var hidePopup = function (params) { - if (params === void 0) { params = {}; } - var mouseEvent = params.mouseEvent, touchEvent = params.touchEvent, keyboardEvent = params.keyboardEvent; - if ( - // we don't hide popup if the event was on the child, or any - // children of this child - _this.isEventFromCurrentPopup({ mouseEvent: mouseEvent, touchEvent: touchEvent }, eChild) || - // if the event to close is actually the open event, then ignore it - _this.isEventSameChainAsOriginalEvent({ originalMouseEvent: click, mouseEvent: mouseEvent, touchEvent: touchEvent }) || - // this method should only be called once. the client can have different - // paths, each one wanting to close, so this method may be called multiple times. - popupHidden) { - return; - } - popupHidden = true; - ePopupParent.removeChild(eWrapper); - eDocument.removeEventListener('keydown', hidePopupOnKeyboardEvent); - eDocument.removeEventListener('mousedown', hidePopupOnMouseEvent); - eDocument.removeEventListener('touchstart', hidePopupOnTouchEvent); - eDocument.removeEventListener('contextmenu', hidePopupOnMouseEvent); - _this.eventService.removeEventListener(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DRAG_STARTED, hidePopupOnMouseEvent); - if (closedCallback) { - closedCallback(mouseEvent || touchEvent || keyboardEvent); - } - _this.popupList = _this.popupList.filter(function (popup) { return popup.element !== eChild; }); - }; - // if we add these listeners now, then the current mouse - // click will be included, which we don't want - window.setTimeout(function () { - if (closeOnEsc) { - eDocument.addEventListener('keydown', hidePopupOnKeyboardEvent); - } - if (modal) { - eDocument.addEventListener('mousedown', hidePopupOnMouseEvent); - _this.eventService.addEventListener(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DRAG_STARTED, hidePopupOnMouseEvent); - eDocument.addEventListener('touchstart', hidePopupOnTouchEvent); - eDocument.addEventListener('contextmenu', hidePopupOnMouseEvent); - } - }, 0); - this.popupList.push({ - element: eChild, - hideFunc: hidePopup - }); - return hidePopup; + DragService.prototype.removeAllListeners = function () { + this.dragSources.forEach(this.removeListener.bind(this)); + this.dragSources.length = 0; }; - PopupService.prototype.isEventFromCurrentPopup = function (params, target) { - var mouseEvent = params.mouseEvent, touchEvent = params.touchEvent; - var event = mouseEvent ? mouseEvent : touchEvent; - if (!event) { - return false; - } - var indexOfThisChild = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].findIndex(this.popupList, function (popup) { return popup.element === target; }); - if (indexOfThisChild === -1) { - return false; + DragService.prototype.removeListener = function (dragSourceAndListener) { + var element = dragSourceAndListener.dragSource.eElement; + var mouseDownListener = dragSourceAndListener.mouseDownListener; + element.removeEventListener('mousedown', mouseDownListener); + // remove touch listener only if it exists + if (dragSourceAndListener.touchEnabled) { + var touchStartListener = dragSourceAndListener.touchStartListener; + element.removeEventListener('touchstart', touchStartListener, { passive: true }); } - for (var i = indexOfThisChild; i < this.popupList.length; i++) { - var popup = this.popupList[i]; - if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].isElementInEventPath(popup.element, event)) { - return true; - } + }; + DragService.prototype.removeDragSource = function (params) { + var dragSourceAndListener = this.dragSources.find(function (item) { return item.dragSource === params; }); + if (!dragSourceAndListener) { + return; } - // if the user did not write their own Custom Element to be rendered as popup - // and this component has an additional popup element, they should have the - // `ag-custom-component-popup` class to be detected as part of the Custom Component - return this.isElementWithinCustomPopup(event.target); + this.removeListener(dragSourceAndListener); + Object(_utils_array__WEBPACK_IMPORTED_MODULE_4__["removeFromArray"])(this.dragSources, dragSourceAndListener); }; - PopupService.prototype.isElementWithinCustomPopup = function (el) { - if (!this.popupList.length) { - return false; + DragService.prototype.isDragging = function () { + return this.dragging; + }; + DragService.prototype.addDragSource = function (params, includeTouch) { + var _this = this; + if (includeTouch === void 0) { includeTouch = false; } + var mouseListener = this.onMouseDown.bind(this, params); + params.eElement.addEventListener('mousedown', mouseListener); + var touchListener = null; + var suppressTouch = this.gridOptionsWrapper.isSuppressTouch(); + if (includeTouch && !suppressTouch) { + touchListener = function (touchEvent) { + if (touchEvent.cancelable) { + touchEvent.preventDefault(); + } + _this.onTouchStart(params, touchEvent); + }; + params.eElement.addEventListener('touchstart', touchListener, { passive: true }); } - while (el && el !== document.body) { - if (el.classList.contains('ag-custom-component-popup') || el.parentElement === null) { - return true; - } - el = el.parentElement; + this.dragSources.push({ + dragSource: params, + mouseDownListener: mouseListener, + touchStartListener: touchListener, + touchEnabled: includeTouch + }); + }; + // gets called whenever mouse down on any drag source + DragService.prototype.onTouchStart = function (params, touchEvent) { + var _this = this; + this.currentDragParams = params; + this.dragging = false; + var touch = touchEvent.touches[0]; + this.touchLastTime = touch; + this.touchStart = touch; + var touchMoveEvent = function (e) { return _this.onTouchMove(e, params.eElement); }; + var touchEndEvent = function (e) { return _this.onTouchUp(e, params.eElement); }; + var documentTouchMove = function (e) { if (e.cancelable) { + e.preventDefault(); + } }; + var target = params.eElement; + var events = [ + // Prevents the page document from moving while we are dragging items around. + // preventDefault needs to be called in the touchmove listener and never inside the + // touchstart, because using touchstart causes the click event to be cancelled on touch devices. + { target: document, type: 'touchmove', listener: documentTouchMove, options: { passive: false } }, + { target: target, type: 'touchmove', listener: touchMoveEvent, options: { passive: true } }, + { target: target, type: 'touchend', listener: touchEndEvent, options: { passive: true } }, + { target: target, type: 'touchcancel', listener: touchEndEvent, options: { passive: true } } + ]; + // temporally add these listeners, for the duration of the drag + this.addTemporaryEvents(events); + // see if we want to start dragging straight away + if (params.dragStartPixels === 0) { + this.onCommonMove(touch, this.touchStart, params.eElement); } - return false; }; - // in some browsers, the context menu event can be fired before the click event, which means - // the context menu event could open the popup, but then the click event closes it straight away. - PopupService.prototype.isEventSameChainAsOriginalEvent = function (params) { - var originalMouseEvent = params.originalMouseEvent, mouseEvent = params.mouseEvent, touchEvent = params.touchEvent; - // we check the coordinates of the event, to see if it's the same event. there is a 1 / 1000 chance that - // the event is a different event, however that is an edge case that is not very relevant (the user clicking - // twice on the same location isn't a normal path). - // event could be mouse event or touch event. - var mouseEventOrTouch = null; - if (mouseEvent) { - // mouse event can be used direction, it has coordinates - mouseEventOrTouch = mouseEvent; + // gets called whenever mouse down on any drag source + DragService.prototype.onMouseDown = function (params, mouseEvent) { + var _this = this; + var e = mouseEvent; + if (params.skipMouseEvent && params.skipMouseEvent(mouseEvent)) { + return; } - else if (touchEvent) { - // touch event doesn't have coordinates, need it's touch object - mouseEventOrTouch = touchEvent.touches[0]; + // if there are two elements with parent / child relationship, and both are draggable, + // when we drag the child, we should NOT drag the parent. an example of this is row moving + // and range selection - row moving should get preference when use drags the rowDrag component. + if (e._alreadyProcessedByDragService) { + return; } - if (mouseEventOrTouch && originalMouseEvent) { - // for x, allow 4px margin, to cover iPads, where touch (which opens menu) is followed - // by browser click (when you finger up, touch is interrupted as click in browser) - var screenX_1 = mouseEvent ? mouseEvent.screenX : 0; - var screenY_1 = mouseEvent ? mouseEvent.screenY : 0; - var xMatch = Math.abs(originalMouseEvent.screenX - screenX_1) < 5; - var yMatch = Math.abs(originalMouseEvent.screenY - screenY_1) < 5; - if (xMatch && yMatch) { - return true; + e._alreadyProcessedByDragService = true; + // only interested in left button clicks + if (mouseEvent.button !== 0) { + return; + } + this.currentDragParams = params; + this.dragging = false; + this.mouseStartEvent = mouseEvent; + var eDocument = this.gridOptionsWrapper.getDocument(); + var mouseMoveEvent = function (event) { return _this.onMouseMove(event, params.eElement); }; + var mouseUpEvent = function (event) { return _this.onMouseUp(event, params.eElement); }; + var contextEvent = function (event) { return event.preventDefault(); }; + var target = eDocument; + var events = [ + { target: target, type: 'mousemove', listener: mouseMoveEvent }, + { target: target, type: 'mouseup', listener: mouseUpEvent }, + { target: target, type: 'contextmenu', listener: contextEvent } + ]; + // temporally add these listeners, for the duration of the drag + this.addTemporaryEvents(events); + //see if we want to start dragging straight away + if (params.dragStartPixels === 0) { + this.onMouseMove(mouseEvent, params.eElement); + } + }; + DragService.prototype.addTemporaryEvents = function (events) { + events.forEach(function (currentEvent) { + var target = currentEvent.target, type = currentEvent.type, listener = currentEvent.listener, options = currentEvent.options; + target.addEventListener(type, listener, options); + }); + this.dragEndFunctions.push(function () { + events.forEach(function (currentEvent) { + var target = currentEvent.target, type = currentEvent.type, listener = currentEvent.listener, options = currentEvent.options; + target.removeEventListener(type, listener, options); + }); + }); + }; + // returns true if the event is close to the original event by X pixels either vertically or horizontally. + // we only start dragging after X pixels so this allows us to know if we should start dragging yet. + DragService.prototype.isEventNearStartEvent = function (currentEvent, startEvent) { + // by default, we wait 4 pixels before starting the drag + var dragStartPixels = this.currentDragParams.dragStartPixels; + var requiredPixelDiff = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["exists"])(dragStartPixels) ? dragStartPixels : 4; + return Object(_utils_mouse__WEBPACK_IMPORTED_MODULE_5__["areEventsNear"])(currentEvent, startEvent, requiredPixelDiff); + }; + DragService.prototype.getFirstActiveTouch = function (touchList) { + for (var i = 0; i < touchList.length; i++) { + if (touchList[i].identifier === this.touchStart.identifier) { + return touchList[i]; } } - return false; + return null; }; - PopupService.prototype.getWrapper = function (ePopup) { - while (!_utils__WEBPACK_IMPORTED_MODULE_4__["_"].containsClass(ePopup, 'ag-popup') && ePopup.parentElement) { - ePopup = ePopup.parentElement; + DragService.prototype.onCommonMove = function (currentEvent, startEvent, el) { + if (!this.dragging) { + // if mouse hasn't travelled from the start position enough, do nothing + if (!this.dragging && this.isEventNearStartEvent(currentEvent, startEvent)) { + return; + } + this.dragging = true; + var event_1 = { + type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_DRAG_STARTED, + api: this.gridApi, + columnApi: this.columnApi, + target: el + }; + this.eventService.dispatchEvent(event_1); + this.currentDragParams.onDragStart(startEvent); + // we need ONE drag action at the startEvent, so that we are guaranteed the drop target + // at the start gets notified. this is because the drag can start outside of the element + // that started it, as the mouse is allowed drag away from the mouse down before it's + // considered a drag (the isEventNearStartEvent() above). if we didn't do this, then + // it would be possible to click a column by the edge, then drag outside of the drop zone + // in less than 4 pixels and the drag officially starts outside of the header but the header + // wouldn't be notified of the dragging. + this.currentDragParams.onDragging(startEvent); } - return _utils__WEBPACK_IMPORTED_MODULE_4__["_"].containsClass(ePopup, 'ag-popup') ? ePopup : null; + this.currentDragParams.onDragging(currentEvent); }; - PopupService.prototype.setAlwaysOnTop = function (ePopup, alwaysOnTop) { - var eWrapper = this.getWrapper(ePopup); - if (!eWrapper) { + DragService.prototype.onTouchMove = function (touchEvent, el) { + var touch = this.getFirstActiveTouch(touchEvent.touches); + if (!touch) { return; } - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addOrRemoveCssClass(eWrapper, 'ag-always-on-top', !!alwaysOnTop); - if (alwaysOnTop) { - this.bringPopupToFront(eWrapper); - } + // this.___statusPanel.setInfoText(Math.random() + ' onTouchMove preventDefault stopPropagation'); + this.onCommonMove(touch, this.touchStart, el); }; - PopupService.prototype.bringPopupToFront = function (ePopup) { - var parent = this.getPopupParent(); - var popupList = Array.prototype.slice.call(parent.querySelectorAll('.ag-popup')); - var popupLen = popupList.length; - var alwaysOnTopList = Array.prototype.slice.call(parent.querySelectorAll('.ag-popup.ag-always-on-top')); - var onTopLength = alwaysOnTopList.length; - var eWrapper = this.getWrapper(ePopup); - if (!eWrapper || popupLen <= 1 || !parent.contains(ePopup)) { - return; + // only gets called after a mouse down - as this is only added after mouseDown + // and is removed when mouseUp happens + DragService.prototype.onMouseMove = function (mouseEvent, el) { + // The event type can be `mousedown` when `dragStartPixels=0` + // we should only preventDefault on `mousemove`. + if (mouseEvent.type === 'mousemove' && mouseEvent.cancelable) { + mouseEvent.preventDefault(); } - var pos = popupList.indexOf(eWrapper); - if (onTopLength) { - var isPopupAlwaysOnTop = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].containsClass(eWrapper, 'ag-always-on-top'); - if (isPopupAlwaysOnTop) { - if (pos !== popupLen - 1) { - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].last(alwaysOnTopList).insertAdjacentElement('afterend', eWrapper); - } - } - else if (pos !== popupLen - onTopLength - 1) { - alwaysOnTopList[0].insertAdjacentElement('beforebegin', eWrapper); - } + this.onCommonMove(mouseEvent, this.mouseStartEvent, el); + }; + DragService.prototype.onTouchUp = function (touchEvent, el) { + var touch = this.getFirstActiveTouch(touchEvent.changedTouches); + // i haven't worked this out yet, but there is no matching touch + // when we get the touch up event. to get around this, we swap in + // the last touch. this is a hack to 'get it working' while we + // figure out what's going on, why we are not getting a touch in + // current event. + if (!touch) { + touch = this.touchLastTime; } - else if (pos !== popupLen - 1) { - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].last(popupList).insertAdjacentElement('afterend', eWrapper); + // if mouse was left up before we started to move, then this is a tap. + // we check this before onUpCommon as onUpCommon resets the dragging + // let tap = !this.dragging; + // let tapTarget = this.currentDragParams.eElement; + this.onUpCommon(touch, el); + // if tap, tell user + // console.log(`${Math.random()} tap = ${tap}`); + // if (tap) { + // tapTarget.click(); + // } + }; + DragService.prototype.onMouseUp = function (mouseEvent, el) { + this.onUpCommon(mouseEvent, el); + }; + DragService.prototype.onUpCommon = function (eventOrTouch, el) { + if (this.dragging) { + this.dragging = false; + this.currentDragParams.onDragStop(eventOrTouch); + var event_2 = { + type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_DRAG_STOPPED, + api: this.gridApi, + columnApi: this.columnApi, + target: el + }; + this.eventService.dispatchEvent(event_2); } - var params = { - type: 'popupToFront', - api: this.gridOptionsWrapper.getApi(), - columnApi: this.gridOptionsWrapper.getColumnApi(), - eWrapper: eWrapper - }; - this.eventService.dispatchEvent(params); + this.mouseStartEvent = null; + this.touchStart = null; + this.touchLastTime = null; + this.currentDragParams = null; + this.dragEndFunctions.forEach(function (func) { return func(); }); + this.dragEndFunctions.length = 0; }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], PopupService.prototype, "gridOptionsWrapper", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('loggerFactory') + ], DragService.prototype, "loggerFactory", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('environment') - ], PopupService.prototype, "environment", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') + ], DragService.prototype, "columnApi", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], PopupService.prototype, "init", null); - PopupService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('popupService') - ], PopupService); - return PopupService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"])); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') + ], DragService.prototype, "gridApi", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], DragService.prototype, "init", null); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PreDestroy"] + ], DragService.prototype, "removeAllListeners", null); + DragService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('dragService') + ], DragService); + return DragService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"])); /***/ }), -/* 134 */ +/* 182 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LoggerFactory", function() { return LoggerFactory; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Logger", function() { return Logger; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SortController", function() { return SortController; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(15); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(23); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -33558,68 +41115,197 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; -var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { - return function (target, key) { decorator(target, key, paramIndex); } -}; -var LoggerFactory = /** @class */ (function (_super) { - __extends(LoggerFactory, _super); - function LoggerFactory() { + +var SortController = /** @class */ (function (_super) { + __extends(SortController, _super); + function SortController() { return _super !== null && _super.apply(this, arguments) || this; } - LoggerFactory.prototype.setBeans = function (gridOptionsWrapper) { - this.logging = gridOptionsWrapper.isDebug(); + SortController_1 = SortController; + SortController.prototype.progressSort = function (column, multiSort, source) { + if (source === void 0) { source = "api"; } + var nextDirection = this.getNextSortDirection(column); + this.setSortForColumn(column, nextDirection, multiSort, source); }; - LoggerFactory.prototype.create = function (name) { - return new Logger(name, this.isLogging.bind(this)); + SortController.prototype.setSortForColumn = function (column, sort, multiSort, source) { + if (source === void 0) { source = "api"; } + // auto correct - if sort not legal value, then set it to 'no sort' (which is null) + if (sort !== _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_ASC && sort !== _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_DESC) { + sort = null; + } + // update sort on current col + column.setSort(sort, source); + var doingMultiSort = multiSort && !this.gridOptionsWrapper.isSuppressMultiSort(); + // clear sort on all columns except this one, and update the icons + if (!doingMultiSort) { + this.clearSortBarThisColumn(column, source); + } + // sortIndex used for knowing order of cols when multi-col sort + this.updateSortIndex(column); + this.dispatchSortChangedEvents(); }; - LoggerFactory.prototype.isLogging = function () { - return this.logging; + SortController.prototype.updateSortIndex = function (lastColToChange) { + // update sortIndex on all sorting cols + var allSortedCols = this.getColumnsWithSortingOrdered(); + var sortIndex = 0; + allSortedCols.forEach(function (col) { + if (col !== lastColToChange) { + col.setSortIndex(sortIndex); + sortIndex++; + } + }); + // last col to change always gets the last sort index, it's added to the end + if (lastColToChange.getSort()) { + lastColToChange.setSortIndex(sortIndex); + } + // clear sort index on all cols not sorting + var allCols = this.columnModel.getPrimaryAndSecondaryAndAutoColumns(); + allCols.filter(function (col) { return col.getSort() == null; }).forEach(function (col) { return col.setSortIndex(); }); }; - __decorate([ - __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('gridOptionsWrapper')) - ], LoggerFactory.prototype, "setBeans", null); - LoggerFactory = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('loggerFactory') - ], LoggerFactory); - return LoggerFactory; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); - -var Logger = /** @class */ (function () { - function Logger(name, isLoggingFunc) { - this.name = name; - this.isLoggingFunc = isLoggingFunc; - } - Logger.prototype.isLogging = function () { - return this.isLoggingFunc(); + // gets called by API, so if data changes, use can call this, which will end up + // working out the sort order again of the rows. + SortController.prototype.onSortChanged = function () { + this.dispatchSortChangedEvents(); }; - Logger.prototype.log = function (message) { - if (this.isLoggingFunc()) { - // tslint:disable-next-line - console.log('ag-Grid.' + this.name + ': ' + message); + SortController.prototype.isSortActive = function () { + // pull out all the columns that have sorting set + var allCols = this.columnModel.getPrimaryAndSecondaryAndAutoColumns(); + var sortedCols = allCols.filter(function (column) { return !!column.getSort(); }); + return sortedCols && sortedCols.length > 0; + }; + SortController.prototype.dispatchSortChangedEvents = function () { + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_SORT_CHANGED, + api: this.gridApi, + columnApi: this.columnApi + }; + this.eventService.dispatchEvent(event); + }; + SortController.prototype.clearSortBarThisColumn = function (columnToSkip, source) { + this.columnModel.getPrimaryAndSecondaryAndAutoColumns().forEach(function (columnToClear) { + // Do not clear if either holding shift, or if column in question was clicked + if (columnToClear !== columnToSkip) { + // setting to 'undefined' as null means 'none' rather than cleared, otherwise issue will arise + // if sort order is: ['desc', null , 'asc'], as it will start at null rather than 'desc'. + columnToClear.setSort(undefined, source); + } + }); + }; + SortController.prototype.getNextSortDirection = function (column) { + var sortingOrder; + if (column.getColDef().sortingOrder) { + sortingOrder = column.getColDef().sortingOrder; + } + else if (this.gridOptionsWrapper.getSortingOrder()) { + sortingOrder = this.gridOptionsWrapper.getSortingOrder(); + } + else { + sortingOrder = SortController_1.DEFAULT_SORTING_ORDER; + } + if (!Array.isArray(sortingOrder) || sortingOrder.length <= 0) { + console.warn("AG Grid: sortingOrder must be an array with at least one element, currently it's " + sortingOrder); + return null; + } + var currentIndex = sortingOrder.indexOf(column.getSort()); + var notInArray = currentIndex < 0; + var lastItemInArray = currentIndex == sortingOrder.length - 1; + var result; + if (notInArray || lastItemInArray) { + result = sortingOrder[0]; + } + else { + result = sortingOrder[currentIndex + 1]; + } + // verify the sort type exists, as the user could provide the sortingOrder, need to make sure it's valid + if (SortController_1.DEFAULT_SORTING_ORDER.indexOf(result) < 0) { + console.warn('AG Grid: invalid sort type ' + result); + return null; } + return result; }; - return Logger; -}()); + SortController.prototype.getColumnsWithSortingOrdered = function () { + // pull out all the columns that have sorting set + var allColumnsIncludingAuto = this.columnModel.getPrimaryAndSecondaryAndAutoColumns(); + var columnsWithSorting = allColumnsIncludingAuto.filter(function (column) { return !!column.getSort(); }); + // when both cols are missing sortIndex, we use the position of the col in all cols list. + // this means if colDefs only have sort, but no sortIndex, we deterministically pick which + // cols is sorted by first. + var allColsIndexes = {}; + allColumnsIncludingAuto.forEach(function (col, index) { return allColsIndexes[col.getId()] = index; }); + // put the columns in order of which one got sorted first + columnsWithSorting.sort(function (a, b) { + var iA = a.getSortIndex(); + var iB = b.getSortIndex(); + if (iA != null && iB != null) { + return iA - iB; // both present, normal comparison + } + else if (iA == null && iB == null) { + // both missing, compare using column positions + var posA = allColsIndexes[a.getId()]; + var posB = allColsIndexes[b.getId()]; + return posA > posB ? 1 : -1; + } + else if (iB == null) { + return -1; // iB missing + } + else { + return 1; // iA missing + } + }); + return columnsWithSorting; + }; + // used by server side row models, to sent sort to server + SortController.prototype.getSortModel = function () { + return this.getColumnsWithSortingOrdered().map(function (column) { return ({ + sort: column.getSort(), + colId: column.getId() + }); }); + }; + SortController.prototype.getSortOptions = function () { + return this.getColumnsWithSortingOrdered().map(function (column) { return ({ + sort: column.getSort(), + column: column + }); }); + }; + var SortController_1; + SortController.DEFAULT_SORTING_ORDER = [_constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_ASC, _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_DESC, null]; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], SortController.prototype, "columnModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') + ], SortController.prototype, "columnApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') + ], SortController.prototype, "gridApi", void 0); + SortController = SortController_1 = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('sortController') + ], SortController); + return SortController; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 135 */ +/* 183 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AutoWidthCalculator", function() { return AutoWidthCalculator; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _headerRendering_header_headerWrapperComp__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(111); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MouseEventService", function() { return MouseEventService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(15); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(20); +/* harmony import */ var _utils_event__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(21); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7); +/* harmony import */ var _rendering_cell_cellCtrl__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(114); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -33646,123 +41332,102 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var AutoWidthCalculator = /** @class */ (function (_super) { - __extends(AutoWidthCalculator, _super); - function AutoWidthCalculator() { - return _super !== null && _super.apply(this, arguments) || this; + + + + +var MouseEventService = /** @class */ (function (_super) { + __extends(MouseEventService, _super); + function MouseEventService() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.gridInstanceId = MouseEventService_1.gridInstanceSequence.next(); + return _this; } - AutoWidthCalculator.prototype.registerGridComp = function (gridPanel) { - this.gridPanel = gridPanel; + MouseEventService_1 = MouseEventService; + // we put the instance id onto the main DOM element. this is used for events, when grids are inside grids, + // so the grid can work out if the even came from this grid or a grid inside this one. see the ctrl+v logic + // for where this is used. + MouseEventService.prototype.stampTopLevelGridCompWithGridInstance = function (eGridDiv) { + eGridDiv[MouseEventService_1.GRID_DOM_KEY] = this.gridInstanceId; }; - AutoWidthCalculator.prototype.registerHeaderRootComp = function (headerRootComp) { - this.headerRootComp = headerRootComp; + MouseEventService.prototype.getRenderedCellForEvent = function (event) { + return Object(_utils_event__WEBPACK_IMPORTED_MODULE_4__["getCtrlForEvent"])(this.gridOptionsWrapper, event, _rendering_cell_cellCtrl__WEBPACK_IMPORTED_MODULE_6__["CellCtrl"].DOM_DATA_KEY_CELL_CTRL); }; - // this is the trick: we create a dummy container and clone all the cells - // into the dummy, then check the dummy's width. then destroy the dummy - // as we don't need it any more. - // drawback: only the cells visible on the screen are considered - AutoWidthCalculator.prototype.getPreferredWidthForColumn = function (column, skipHeader) { - var eHeaderCell = this.getHeaderCellForColumn(column); - // cell isn't visible - if (!eHeaderCell) { - return -1; - } - var eDummyContainer = document.createElement('span'); - // position fixed, so it isn't restricted to the boundaries of the parent - eDummyContainer.style.position = 'fixed'; - // we put the dummy into the body container, so it will inherit all the - // css styles that the real cells are inheriting - var eBodyContainer = this.gridPanel.getCenterContainer(); - eBodyContainer.appendChild(eDummyContainer); - // get all the cells that are currently displayed (this only brings back - // rendered cells, rows not rendered due to row visualisation will not be here) - this.putRowCellsIntoDummyContainer(column, eDummyContainer); - if (!skipHeader) { - // we only consider the lowest level cell, not the group cell. in 99% of the time, this - // will be enough. if we consider groups, then it gets too complicated for what it's worth, - // as the groups can span columns and this class only considers one column at a time. - this.cloneItemIntoDummy(eHeaderCell, eDummyContainer); - } - // at this point, all the clones are lined up vertically with natural widths. the dummy - // container will have a width wide enough just to fit the largest. - var dummyContainerWidth = eDummyContainer.offsetWidth; - // we are finished with the dummy container, so get rid of it - eBodyContainer.removeChild(eDummyContainer); - // we add padding as I found sometimes the gui still put '...' after some of the texts. so the - // user can configure the grid to add a few more pixels after the calculated width - var autoSizePadding = this.gridOptionsWrapper.getAutoSizePadding(); - return dummyContainerWidth + autoSizePadding; + // walks the path of the event, and returns true if this grid is the first one that it finds. if doing + // master / detail grids, and a child grid is found, then it returns false. this stops things like copy/paste + // getting executed on many grids at the same time. + MouseEventService.prototype.isEventFromThisGrid = function (event) { + var res = this.isElementInThisGrid(event.target); + return res; }; - AutoWidthCalculator.prototype.getHeaderCellForColumn = function (column) { - var comp = null; - // find the rendered header cell - this.headerRootComp.forEachHeaderElement(function (headerElement) { - if (headerElement instanceof _headerRendering_header_headerWrapperComp__WEBPACK_IMPORTED_MODULE_1__["HeaderWrapperComp"]) { - var headerWrapperComp = headerElement; - if (headerWrapperComp.getColumn() === column) { - comp = headerWrapperComp; - } + MouseEventService.prototype.isElementInThisGrid = function (element) { + var pointer = element; + while (pointer) { + var instanceId = pointer[MouseEventService_1.GRID_DOM_KEY]; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["exists"])(instanceId)) { + var eventFromThisGrid = instanceId === this.gridInstanceId; + return eventFromThisGrid; } - }); - return comp ? comp.getGui() : null; + pointer = pointer.parentElement; + } + return false; }; - AutoWidthCalculator.prototype.putRowCellsIntoDummyContainer = function (column, eDummyContainer) { - var _this = this; - var eCells = this.rowRenderer.getAllCellsForColumn(column); - eCells.forEach(function (eCell) { return _this.cloneItemIntoDummy(eCell, eDummyContainer); }); + MouseEventService.prototype.getCellPositionForEvent = function (event) { + var cellComp = this.getRenderedCellForEvent(event); + return cellComp ? cellComp.getCellPosition() : null; }; - AutoWidthCalculator.prototype.cloneItemIntoDummy = function (eCell, eDummyContainer) { - // make a deep clone of the cell - var eCellClone = eCell.cloneNode(true); - // the original has a fixed width, we remove this to allow the natural width based on content - eCellClone.style.width = ''; - // the original has position = absolute, we need to remove this so it's positioned normally - eCellClone.style.position = 'static'; - eCellClone.style.left = ''; - // we put the cell into a containing div, as otherwise the cells would just line up - // on the same line, standard flow layout, by putting them into divs, they are laid - // out one per line - var eCloneParent = document.createElement('div'); - if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].containsClass(eCellClone, 'ag-header-cell')) { - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(eCloneParent, 'ag-header'); - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(eCloneParent, 'ag-header-row'); - eCloneParent.style.position = 'static'; + MouseEventService.prototype.getNormalisedPosition = function (event) { + var gridPanelHasScrolls = this.gridOptionsWrapper.getDomLayout() === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].DOM_LAYOUT_NORMAL; + var e = event; + var x; + var y; + if (e.clientX != null || e.clientY != null) { + x = e.clientX; + y = e.clientY; } - // table-row, so that each cell is on a row. i also tried display='block', but this - // didn't work in IE - eCloneParent.style.display = 'table-row'; - // the twig on the branch, the branch on the tree, the tree in the hole, - // the hole in the bog, the bog in the clone, the clone in the parent, - // the parent in the dummy, and the dummy down in the vall-e-ooo, OOOOOOOOO! Oh row the rattling bog.... - eCloneParent.appendChild(eCellClone); - eDummyContainer.appendChild(eCloneParent); + else { + x = e.x; + y = e.y; + } + if (gridPanelHasScrolls) { + var gridBodyCon = this.ctrlsService.getGridBodyCtrl(); + var vRange = gridBodyCon.getScrollFeature().getVScrollPosition(); + var hRange = gridBodyCon.getScrollFeature().getHScrollPosition(); + x += hRange.left; + y += vRange.top; + } + return { x: x, y: y }; }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer') - ], AutoWidthCalculator.prototype, "rowRenderer", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], AutoWidthCalculator.prototype, "gridOptionsWrapper", void 0); - AutoWidthCalculator = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('autoWidthCalculator') - ], AutoWidthCalculator); - return AutoWidthCalculator; + var MouseEventService_1; + MouseEventService.gridInstanceSequence = new _utils__WEBPACK_IMPORTED_MODULE_1__["NumberSequence"](); + MouseEventService.GRID_DOM_KEY = '__ag_grid_instance'; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('ctrlsService') + ], MouseEventService.prototype, "ctrlsService", void 0); + MouseEventService = MouseEventService_1 = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('mouseEventService') + ], MouseEventService); + return MouseEventService; }(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"])); /***/ }), -/* 136 */ +/* 184 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HorizontalResizeService", function() { return HorizontalResizeService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellNavigationService", function() { return CellNavigationService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(15); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(18); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(65); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -33787,88 +41452,301 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta }; -var HorizontalResizeService = /** @class */ (function (_super) { - __extends(HorizontalResizeService, _super); - function HorizontalResizeService() { + + + + +var CellNavigationService = /** @class */ (function (_super) { + __extends(CellNavigationService, _super); + function CellNavigationService() { return _super !== null && _super.apply(this, arguments) || this; } - HorizontalResizeService.prototype.addResizeBar = function (params) { - var _this = this; - var dragSource = { - dragStartPixels: params.dragStartPixels || 0, - eElement: params.eResizeBar, - onDragStart: this.onDragStart.bind(this, params), - onDragStop: this.onDragStop.bind(this, params), - onDragging: this.onDragging.bind(this, params) + // returns null if no cell to focus on, ie at the end of the grid + CellNavigationService.prototype.getNextCellToFocus = function (key, lastCellToFocus) { + // starting with the provided cell, we keep moving until we find a cell we can + // focus on. + var pointer = lastCellToFocus; + var finished = false; + // finished will be true when either: + // a) cell found that we can focus on + // b) run out of cells (ie the method returns null) + while (!finished) { + switch (key) { + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_5__["KeyCode"].UP: + pointer = this.getCellAbove(pointer); + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_5__["KeyCode"].DOWN: + pointer = this.getCellBelow(pointer); + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_5__["KeyCode"].RIGHT: + if (this.gridOptionsWrapper.isEnableRtl()) { + pointer = this.getCellToLeft(pointer); + } + else { + pointer = this.getCellToRight(pointer); + } + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_5__["KeyCode"].LEFT: + if (this.gridOptionsWrapper.isEnableRtl()) { + pointer = this.getCellToRight(pointer); + } + else { + pointer = this.getCellToLeft(pointer); + } + break; + default: + pointer = null; + console.warn('AG Grid: unknown key for navigation ' + key); + break; + } + if (pointer) { + finished = this.isCellGoodToFocusOn(pointer); + } + else { + finished = true; + } + } + return pointer; + }; + CellNavigationService.prototype.isCellGoodToFocusOn = function (gridCell) { + var column = gridCell.column; + var rowNode; + switch (gridCell.rowPinned) { + case _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP: + rowNode = this.pinnedRowModel.getPinnedTopRow(gridCell.rowIndex); + break; + case _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM: + rowNode = this.pinnedRowModel.getPinnedBottomRow(gridCell.rowIndex); + break; + default: + rowNode = this.rowModel.getRow(gridCell.rowIndex); + break; + } + if (!rowNode) { + return false; + } + var suppressNavigable = column.isSuppressNavigable(rowNode); + return !suppressNavigable; + }; + CellNavigationService.prototype.getCellToLeft = function (lastCell) { + if (!lastCell) { + return null; + } + var colToLeft = this.columnModel.getDisplayedColBefore(lastCell.column); + if (!colToLeft) { + return null; + } + return { + rowIndex: lastCell.rowIndex, + column: colToLeft, + rowPinned: lastCell.rowPinned }; - this.dragService.addDragSource(dragSource, true); - // we pass remove func back to the caller, so call can tell us when they - // are finished, and then we remove the listener from the drag source - var finishedWithResizeFunc = function () { return _this.dragService.removeDragSource(dragSource); }; - return finishedWithResizeFunc; }; - HorizontalResizeService.prototype.onDragStart = function (params, mouseEvent) { - this.dragStartX = mouseEvent.clientX; - this.setResizeIcons(); - var shiftKey = mouseEvent instanceof MouseEvent ? mouseEvent.shiftKey === true : false; - params.onResizeStart(shiftKey); + CellNavigationService.prototype.getCellToRight = function (lastCell) { + if (!lastCell) { + return null; + } + var colToRight = this.columnModel.getDisplayedColAfter(lastCell.column); + // if already on right, do nothing + if (!colToRight) { + return null; + } + return { + rowIndex: lastCell.rowIndex, + column: colToRight, + rowPinned: lastCell.rowPinned + }; }; - HorizontalResizeService.prototype.setResizeIcons = function () { - this.oldBodyCursor = this.eGridDiv.style.cursor; - this.oldMsUserSelect = this.eGridDiv.style.msUserSelect; - this.oldWebkitUserSelect = this.eGridDiv.style.webkitUserSelect; - // change the body cursor, so when drag moves out of the drag bar, the cursor is still 'resize' (or 'move' - this.eGridDiv.style.cursor = 'ew-resize'; - // we don't want text selection outside the grid (otherwise it looks weird as text highlights when we move) - this.eGridDiv.style.msUserSelect = 'none'; - this.eGridDiv.style.webkitUserSelect = 'none'; + CellNavigationService.prototype.getRowBelow = function (rowPosition) { + // if already on top row, do nothing + var index = rowPosition.rowIndex; + var pinned = rowPosition.rowPinned; + if (this.isLastRowInContainer(rowPosition)) { + switch (pinned) { + case _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM: + // never any rows after pinned bottom + return null; + case _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP: + // if on last row of pinned top, then next row is main body (if rows exist), + // otherwise it's the pinned bottom + if (this.rowModel.isRowsToRender()) { + return { rowIndex: this.paginationProxy.getPageFirstRow(), rowPinned: null }; + } + if (this.pinnedRowModel.isRowsToRender(_constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM)) { + return { rowIndex: 0, rowPinned: _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM }; + } + return null; + default: + // if in the main body, then try pinned bottom, otherwise return nothing + if (this.pinnedRowModel.isRowsToRender(_constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM)) { + return { rowIndex: 0, rowPinned: _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM }; + } + return null; + } + } + return { rowIndex: index + 1, rowPinned: pinned }; }; - HorizontalResizeService.prototype.onDragStop = function (params, mouseEvent) { - params.onResizeEnd(this.resizeAmount); - this.resetIcons(); + CellNavigationService.prototype.getCellBelow = function (lastCell) { + if (!lastCell) { + return null; + } + var rowBelow = this.getRowBelow(lastCell); + if (rowBelow) { + return { + rowIndex: rowBelow.rowIndex, + column: lastCell.column, + rowPinned: rowBelow.rowPinned + }; + } + return null; }; - HorizontalResizeService.prototype.resetIcons = function () { - // we don't want text selection outside the grid (otherwise it looks weird as text highlights when we move) - this.eGridDiv.style.cursor = this.oldBodyCursor; - this.eGridDiv.style.msUserSelect = this.oldMsUserSelect; - this.eGridDiv.style.webkitUserSelect = this.oldWebkitUserSelect; + CellNavigationService.prototype.isLastRowInContainer = function (rowPosition) { + var pinned = rowPosition.rowPinned; + var index = rowPosition.rowIndex; + if (pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP) { + var lastTopIndex = this.pinnedRowModel.getPinnedTopRowData().length - 1; + return lastTopIndex <= index; + } + if (pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM) { + var lastBottomIndex = this.pinnedRowModel.getPinnedBottomRowData().length - 1; + return lastBottomIndex <= index; + } + var lastBodyIndex = this.paginationProxy.getPageLastRow(); + return lastBodyIndex <= index; }; - HorizontalResizeService.prototype.onDragging = function (params, mouseEvent) { - this.resizeAmount = mouseEvent.clientX - this.dragStartX; - params.onResizing(this.resizeAmount); + CellNavigationService.prototype.getRowAbove = function (rowPosition) { + // if already on top row, do nothing + var index = rowPosition.rowIndex; + var pinned = rowPosition.rowPinned; + var isFirstRow = pinned ? index === 0 : index === this.paginationProxy.getPageFirstRow(); + // if already on top row, do nothing + if (isFirstRow) { + if (pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP) { + return null; + } + if (!pinned) { + if (this.pinnedRowModel.isRowsToRender(_constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP)) { + return this.getLastFloatingTopRow(); + } + return null; + } + // last floating bottom + if (this.rowModel.isRowsToRender()) { + return this.getLastBodyCell(); + } + if (this.pinnedRowModel.isRowsToRender(_constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP)) { + return this.getLastFloatingTopRow(); + } + return null; + } + return { rowIndex: index - 1, rowPinned: pinned }; + }; + CellNavigationService.prototype.getCellAbove = function (lastCell) { + if (!lastCell) { + return null; + } + var rowAbove = this.getRowAbove({ rowIndex: lastCell.rowIndex, rowPinned: lastCell.rowPinned }); + if (rowAbove) { + return { + rowIndex: rowAbove.rowIndex, + column: lastCell.column, + rowPinned: rowAbove.rowPinned + }; + } + return null; + }; + CellNavigationService.prototype.getLastBodyCell = function () { + var lastBodyRow = this.paginationProxy.getPageLastRow(); + return { rowIndex: lastBodyRow, rowPinned: null }; + }; + CellNavigationService.prototype.getLastFloatingTopRow = function () { + var lastFloatingRow = this.pinnedRowModel.getPinnedTopRowData().length - 1; + return { rowIndex: lastFloatingRow, rowPinned: _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP }; + }; + CellNavigationService.prototype.getNextTabbedCell = function (gridCell, backwards) { + if (backwards) { + return this.getNextTabbedCellBackwards(gridCell); + } + return this.getNextTabbedCellForwards(gridCell); + }; + CellNavigationService.prototype.getNextTabbedCellForwards = function (gridCell) { + var displayedColumns = this.columnModel.getAllDisplayedColumns(); + var newRowIndex = gridCell.rowIndex; + var newFloating = gridCell.rowPinned; + // move along to the next cell + var newColumn = this.columnModel.getDisplayedColAfter(gridCell.column); + // check if end of the row, and if so, go forward a row + if (!newColumn) { + newColumn = displayedColumns[0]; + var rowBelow = this.getRowBelow(gridCell); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["missing"])(rowBelow)) { + return null; + } + // If we are tabbing and there is a paging panel present, tabbing should go + // to the paging panel instead of loading the next page. + if (!rowBelow.rowPinned && !this.paginationProxy.isRowInPage(rowBelow)) { + return null; + } + newRowIndex = rowBelow ? rowBelow.rowIndex : null; + newFloating = rowBelow ? rowBelow.rowPinned : null; + } + return { rowIndex: newRowIndex, column: newColumn, rowPinned: newFloating }; + }; + CellNavigationService.prototype.getNextTabbedCellBackwards = function (gridCell) { + var displayedColumns = this.columnModel.getAllDisplayedColumns(); + var newRowIndex = gridCell.rowIndex; + var newFloating = gridCell.rowPinned; + // move along to the next cell + var newColumn = this.columnModel.getDisplayedColBefore(gridCell.column); + // check if end of the row, and if so, go forward a row + if (!newColumn) { + newColumn = Object(_utils_array__WEBPACK_IMPORTED_MODULE_4__["last"])(displayedColumns); + var rowAbove = this.getRowAbove({ rowIndex: gridCell.rowIndex, rowPinned: gridCell.rowPinned }); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["missing"])(rowAbove)) { + return null; + } + // If we are tabbing and there is a paging panel present, tabbing should go + // to the paging panel instead of loading the next page. + if (!rowAbove.rowPinned && !this.paginationProxy.isRowInPage(rowAbove)) { + return null; + } + newRowIndex = rowAbove ? rowAbove.rowIndex : null; + newFloating = rowAbove ? rowAbove.rowPinned : null; + } + return { rowIndex: newRowIndex, column: newColumn, rowPinned: newFloating }; }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('dragService') - ], HorizontalResizeService.prototype, "dragService", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], CellNavigationService.prototype, "columnModel", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('eGridDiv') - ], HorizontalResizeService.prototype, "eGridDiv", void 0); - HorizontalResizeService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('horizontalResizeService') - ], HorizontalResizeService); - return HorizontalResizeService; + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel') + ], CellNavigationService.prototype, "rowModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('pinnedRowModel') + ], CellNavigationService.prototype, "pinnedRowModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('paginationProxy') + ], CellNavigationService.prototype, "paginationProxy", void 0); + CellNavigationService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('cellNavigationService') + ], CellNavigationService); + return CellNavigationService; }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 137 */ +/* 185 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridCore", function() { return GridCore; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43); -/* harmony import */ var _entities_sideBar__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(52); -/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(38); -/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(39); -/* harmony import */ var _widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(117); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ValueFormatterService", function() { return ValueFormatterService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -33893,465 +41771,203 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta }; - - - - - - -var GridCore = /** @class */ (function (_super) { - __extends(GridCore, _super); - function GridCore() { +var ValueFormatterService = /** @class */ (function (_super) { + __extends(ValueFormatterService, _super); + function ValueFormatterService() { return _super !== null && _super.apply(this, arguments) || this; } - GridCore.prototype.postConstruct = function () { - var _this = this; - this.logger = this.loggerFactory.create('GridCore'); - var template = this.createTemplate(); - this.setTemplate(template); - // register with services that need grid core - [ - this.gridApi, - this.rowRenderer, - this.popupService, - this.focusController - ].forEach(function (service) { return service.registerGridCore(_this); }); - if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].ClipboardModule)) { - this.clipboardService.registerGridCore(this); - } - this.gridOptionsWrapper.addLayoutElement(this.getGui()); - this.eGridDiv.appendChild(this.getGui()); - this.addDestroyFunc(function () { - _this.eGridDiv.removeChild(_this.getGui()); - }); - // if using angular, watch for quickFilter changes - if (this.$scope) { - var quickFilterUnregisterFn = this.$scope.$watch(this.quickFilterOnScope, function (newFilter) { return _this.filterManager.setQuickFilter(newFilter); }); - this.addDestroyFunc(quickFilterUnregisterFn); - } - // important to set rtl before doLayout, as setting the RTL class impacts the scroll position, - // which doLayout indirectly depends on - this.addRtlSupport(); - this.logger.log('ready'); - this.gridOptionsWrapper.addLayoutElement(this.eRootWrapperBody); - var unsubscribeFromResize = this.resizeObserverService.observeResize(this.eGridDiv, this.onGridSizeChanged.bind(this)); - this.addDestroyFunc(function () { return unsubscribeFromResize(); }); - var eGui = this.getGui(); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_KEYBOARD_FOCUS, function () { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(eGui, 'ag-keyboard-focus'); - }); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_MOUSE_FOCUS, function () { - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(eGui, 'ag-keyboard-focus'); - }); - _super.prototype.postConstruct.call(this); - }; - GridCore.prototype.getFocusableElement = function () { - return this.eRootWrapperBody; - }; - GridCore.prototype.createTemplate = function () { - var sideBarModuleLoaded = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].SideBarModule); - var statusBarModuleLoaded = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].StatusBarModule); - var rowGroupingLoaded = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].RowGroupingModule); - var enterpriseCoreLoaded = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].EnterpriseCoreModule); - var dropZones = rowGroupingLoaded ? '' : ''; - var sideBar = sideBarModuleLoaded ? '' : ''; - var statusBar = statusBarModuleLoaded ? '' : ''; - var watermark = enterpriseCoreLoaded ? '' : ''; - var template = "
\n " + dropZones + "\n
\n \n " + sideBar + "\n
\n " + statusBar + "\n \n " + watermark + "\n
"; - return template; - }; - GridCore.prototype.isFocusableContainer = function () { - return true; - }; - GridCore.prototype.getFocusableContainers = function () { - var focusableContainers = [ - this.gridPanel.getGui() - ]; - if (this.sideBarComp) { - focusableContainers.push(this.sideBarComp.getGui()); - } - return focusableContainers.filter(function (el) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isVisible(el); }); - }; - GridCore.prototype.focusNextInnerContainer = function (backwards) { - var focusableContainers = this.getFocusableContainers(); - var idxWithFocus = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].findIndex(focusableContainers, function (container) { return container.contains(document.activeElement); }); - var nextIdx = idxWithFocus + (backwards ? -1 : 1); - if (nextIdx < 0 || nextIdx >= focusableContainers.length) { - return false; - } - if (nextIdx === 0) { - return this.focusGridHeader(); - } - return this.focusController.focusFirstFocusableElement(focusableContainers[nextIdx]); - }; - GridCore.prototype.focusInnerElement = function (fromBottom) { - var focusableContainers = this.getFocusableContainers(); - if (fromBottom && focusableContainers.length > 1) { - return this.focusController.focusFirstFocusableElement(_utils__WEBPACK_IMPORTED_MODULE_7__["_"].last(focusableContainers)); - } - return this.focusGridHeader(); - }; - GridCore.prototype.focusGridHeader = function () { - var firstColumn = this.columnController.getAllDisplayedColumns()[0]; - if (!firstColumn) { - return false; - } - if (firstColumn.getParent()) { - firstColumn = this.columnController.getColumnGroupAtLevel(firstColumn, 0); - } - this.focusController.focusHeaderPosition({ - headerRowIndex: 0, - column: firstColumn - }); - return true; - }; - GridCore.prototype.onGridSizeChanged = function () { - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_GRID_SIZE_CHANGED, - api: this.gridApi, - columnApi: this.columnApi, - clientWidth: this.eGridDiv.clientWidth, - clientHeight: this.eGridDiv.clientHeight - }; - this.eventService.dispatchEvent(event); - }; - GridCore.prototype.addRtlSupport = function () { - var cssClass = this.gridOptionsWrapper.isEnableRtl() ? 'ag-rtl' : 'ag-ltr'; - _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(this.getGui(), cssClass); - }; - GridCore.prototype.getRootGui = function () { - return this.getGui(); - }; - GridCore.prototype.isSideBarVisible = function () { - if (!this.sideBarComp) { - return false; - } - return this.sideBarComp.isDisplayed(); - }; - GridCore.prototype.setSideBarVisible = function (show) { - if (!this.sideBarComp) { - if (show) { - console.warn('ag-Grid: sideBar is not loaded'); - } - return; - } - this.sideBarComp.setDisplayed(show); - }; - GridCore.prototype.setSideBarPosition = function (position) { - if (!this.sideBarComp) { - console.warn('ag-Grid: sideBar is not loaded'); - return; - } - this.sideBarComp.setSideBarPosition(position); - }; - GridCore.prototype.closeToolPanel = function () { - if (!this.sideBarComp) { - console.warn('ag-Grid: toolPanel is only available in ag-Grid Enterprise'); - return; - } - this.sideBarComp.close(); - }; - GridCore.prototype.getSideBar = function () { - return this.gridOptions.sideBar; - }; - GridCore.prototype.getToolPanelInstance = function (key) { - if (!this.sideBarComp) { - console.warn('ag-Grid: toolPanel is only available in ag-Grid Enterprise'); - return; + ValueFormatterService.prototype.formatValue = function (column, node, $scope, value, suppliedFormatter, useFormatterFromColumn) { + if (useFormatterFromColumn === void 0) { useFormatterFromColumn = true; } + var result = null; + var formatter; + var colDef = column.getColDef(); + if (suppliedFormatter) { + // use supplied formatter if provided, e.g. set filter items can have their own value formatters + formatter = suppliedFormatter; } - return this.sideBarComp.getToolPanelInstance(key); - }; - GridCore.prototype.refreshSideBar = function () { - if (this.sideBarComp) { - this.sideBarComp.refresh(); + else if (useFormatterFromColumn) { + // if row is pinned, give preference to the pinned formatter + formatter = node && node.rowPinned && colDef.pinnedRowValueFormatter ? + colDef.pinnedRowValueFormatter : colDef.valueFormatter; } - }; - GridCore.prototype.setSideBar = function (def) { - if (!this.sideBarComp) { - return; + if (formatter) { + var params = { + value: value, + node: node, + data: node ? node.data : null, + colDef: colDef, + column: column, + api: this.gridOptionsWrapper.getApi(), + columnApi: this.gridOptionsWrapper.getColumnApi(), + context: this.gridOptionsWrapper.getContext() + }; + // originally we put the angular 1 scope here, but we don't want the scope + // in the params interface, as other frameworks will see the interface, and + // angular 1 is not cool any more. so we hack the scope in here (we cannot + // include it above, as it's not in the interface, so would cause a compile error). + // in the future, when we stop supporting angular 1, we can take this out. + params.$scope = $scope; + result = this.expressionService.evaluate(formatter, params); } - this.eRootWrapperBody.removeChild(this.sideBarComp.getGui()); - this.gridOptions.sideBar = _entities_sideBar__WEBPACK_IMPORTED_MODULE_3__["SideBarDefParser"].parse(def); - this.sideBarComp.reset(); - this.eRootWrapperBody.appendChild(this.sideBarComp.getGui()); - }; - GridCore.prototype.getOpenedToolPanel = function () { - if (!this.sideBarComp) { - return null; + else if (colDef.refData) { + return colDef.refData[value] || ''; } - return this.sideBarComp.openedItem(); - }; - GridCore.prototype.openToolPanel = function (key) { - if (!this.sideBarComp) { - console.warn('ag-Grid: toolPanel is only available in ag-Grid Enterprise'); - return; + // if we don't do this, then arrays get displayed as 1,2,3, but we want 1, 2, 3 (i.e. with spaces) + if (result == null && Array.isArray(value)) { + result = value.join(', '); } - this.sideBarComp.openToolPanel(key); + return result; }; - GridCore.prototype.isToolPanelShowing = function () { - return this.sideBarComp.isToolPanelShowing(); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('expressionService') + ], ValueFormatterService.prototype, "expressionService", void 0); + ValueFormatterService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('valueFormatterService') + ], ValueFormatterService); + return ValueFormatterService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + + + +/***/ }), +/* 186 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgRadioButton", function() { return AgRadioButton; }); +/* harmony import */ var _agCheckbox__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(158); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(24); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - GridCore.prototype.destroy = function () { - this.logger.log('Grid DOM removed'); - _super.prototype.destroy.call(this); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; - // Valid values for position are bottom, middle and top - GridCore.prototype.ensureNodeVisible = function (comparator, position) { - if (position === void 0) { position = null; } - if (this.doingVirtualPaging) { - throw new Error('Cannot use ensureNodeVisible when doing virtual paging, as we cannot check rows that are not in memory'); - } - // look for the node index we want to display - var rowCount = this.rowModel.getRowCount(); - var comparatorIsAFunction = typeof comparator === 'function'; - var indexToSelect = -1; - // go through all the nodes, find the one we want to show - for (var i = 0; i < rowCount; i++) { - var node = this.rowModel.getRow(i); - if (comparatorIsAFunction) { - if (comparator(node)) { - indexToSelect = i; - break; - } - } - else { - // check object equality against node and data - if (comparator === node || comparator === node.data) { - indexToSelect = i; - break; - } - } - } - if (indexToSelect >= 0) { - this.gridPanel.ensureIndexVisible(indexToSelect, position); - } +})(); + + +var AgRadioButton = /** @class */ (function (_super) { + __extends(AgRadioButton, _super); + function AgRadioButton(config) { + return _super.call(this, config, 'ag-radio-button', 'radio') || this; + } + AgRadioButton.prototype.isSelected = function () { + return this.eInput.checked; }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptions') - ], GridCore.prototype, "gridOptions", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], GridCore.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel') - ], GridCore.prototype, "rowModel", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('resizeObserverService') - ], GridCore.prototype, "resizeObserverService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer') - ], GridCore.prototype, "rowRenderer", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager') - ], GridCore.prototype, "filterManager", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('eGridDiv') - ], GridCore.prototype, "eGridDiv", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('$scope') - ], GridCore.prototype, "$scope", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('quickFilterOnScope') - ], GridCore.prototype, "quickFilterOnScope", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('popupService') - ], GridCore.prototype, "popupService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], GridCore.prototype, "columnController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('loggerFactory') - ], GridCore.prototype, "loggerFactory", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') - ], GridCore.prototype, "columnApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') - ], GridCore.prototype, "gridApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('clipboardService') - ], GridCore.prototype, "clipboardService", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('gridPanel') - ], GridCore.prototype, "gridPanel", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('sideBar') - ], GridCore.prototype, "sideBarComp", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('rootWrapperBody') - ], GridCore.prototype, "eRootWrapperBody", void 0); - return GridCore; -}(_widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_6__["ManagedFocusComponent"])); + AgRadioButton.prototype.toggle = function () { + if (this.eInput.disabled) { + return; + } + // do not allow an active radio button to be deselected + if (!this.isSelected()) { + this.setValue(true); + } + }; + AgRadioButton.prototype.addInputListeners = function () { + _super.prototype.addInputListeners.call(this); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CHECKBOX_CHANGED, this.onChange.bind(this)); + }; + /** + * This ensures that if another radio button in the same named group is selected, we deselect this radio button. + * By default the browser does this for you, but we are managing classes ourselves in order to ensure input + * elements are styled correctly in IE11, and the DOM 'changed' event is only fired when a button is selected, + * not deselected, so we need to use our own event. + */ + AgRadioButton.prototype.onChange = function (event) { + if (event.selected && + event.name && + this.eInput.name && + this.eInput.name === event.name && + event.id && + this.eInput.id !== event.id) { + this.setValue(false, true); + } + }; + return AgRadioButton; +}(_agCheckbox__WEBPACK_IMPORTED_MODULE_0__["AgCheckbox"])); /***/ }), -/* 138 */ +/* 187 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "StandardMenuFactory", function() { return StandardMenuFactory; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "VanillaFrameworkOverrides", function() { return VanillaFrameworkOverrides; }); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(18); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - -var StandardMenuFactory = /** @class */ (function (_super) { - __extends(StandardMenuFactory, _super); - function StandardMenuFactory() { - return _super !== null && _super.apply(this, arguments) || this; +var OUTSIDE_ANGULAR_EVENTS = ['mouseover', 'mouseout', 'mouseenter', 'mouseleave']; +var PASSIVE_EVENTS = ['touchstart', 'touchend', 'touchmove', 'touchcancel']; +/** The base frameworks, eg React & Angular, override this bean with implementations specific to their requirement. */ +var VanillaFrameworkOverrides = /** @class */ (function () { + function VanillaFrameworkOverrides() { + this.isOutsideAngular = function (eventType) { return Object(_utils_array__WEBPACK_IMPORTED_MODULE_0__["includes"])(OUTSIDE_ANGULAR_EVENTS, eventType); }; } - StandardMenuFactory.prototype.hideActiveMenu = function () { - if (this.hidePopup) { - this.hidePopup(); - } + // for Vanilla JS, we use simple timeout + VanillaFrameworkOverrides.prototype.setTimeout = function (action, timeout) { + window.setTimeout(action, timeout); }; - StandardMenuFactory.prototype.showMenuAfterMouseEvent = function (column, mouseEvent) { - var _this = this; - this.showPopup(column, function (eMenu) { - _this.popupService.positionPopupUnderMouseEvent({ - column: column, - type: 'columnMenu', - mouseEvent: mouseEvent, - ePopup: eMenu - }); - }, mouseEvent.target); + VanillaFrameworkOverrides.prototype.setInterval = function (action, timeout) { + return new _utils__WEBPACK_IMPORTED_MODULE_1__["AgPromise"](function (resolve) { + resolve(window.setInterval(action, timeout)); + }); }; - StandardMenuFactory.prototype.showMenuAfterButtonClick = function (column, eventSource) { - var _this = this; - this.showPopup(column, function (eMenu) { - _this.popupService.positionPopupUnderComponent({ - type: 'columnMenu', - eventSource: eventSource, - ePopup: eMenu, - keepWithinBounds: true, - column: column - }); - }, eventSource); + // for Vanilla JS, we just add the event to the element + VanillaFrameworkOverrides.prototype.addEventListener = function (element, type, listener, useCapture) { + var isPassive = Object(_utils_array__WEBPACK_IMPORTED_MODULE_0__["includes"])(PASSIVE_EVENTS, type); + element.addEventListener(type, listener, { capture: !!useCapture, passive: isPassive }); }; - StandardMenuFactory.prototype.showPopup = function (column, positionCallback, eventSource) { - var _this = this; - var filterWrapper = this.filterManager.getOrCreateFilterWrapper(column, 'COLUMN_MENU'); - var eMenu = document.createElement('div'); - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(eMenu, 'ag-menu'); - this.tabListener = this.addManagedListener(eMenu, 'keydown', function (e) { return _this.trapFocusWithin(e, eMenu); }); - filterWrapper.guiPromise.then(function (gui) { return eMenu.appendChild(gui); }); - var hidePopup; - var bodyScrollListener = function (event) { - // if h scroll, popup is no longer over the column - if (event.direction === 'horizontal') { - hidePopup(); - } - }; - this.eventService.addEventListener('bodyScroll', bodyScrollListener); - var closedCallback = function (e) { - _this.eventService.removeEventListener('bodyScroll', bodyScrollListener); - column.setMenuVisible(false, 'contextMenu'); - var isKeyboardEvent = e instanceof KeyboardEvent; - if (_this.tabListener) { - _this.tabListener = _this.tabListener(); - } - if (isKeyboardEvent && eventSource && _utils__WEBPACK_IMPORTED_MODULE_3__["_"].isVisible(eventSource)) { - var focusableEl = _this.focusController.findTabbableParent(eventSource); - if (focusableEl) { - focusableEl.focus(); - } - } - }; - // need to show filter before positioning, as only after filter - // is visible can we find out what the width of it is - hidePopup = this.popupService.addAsModalPopup(eMenu, true, closedCallback); - positionCallback(eMenu); - filterWrapper.filterPromise.then(function (filter) { - if (filter.afterGuiAttached) { - var params = { - hidePopup: hidePopup - }; - filter.afterGuiAttached(params); - } - }); - this.hidePopup = hidePopup; - column.setMenuVisible(true, 'contextMenu'); + // for Vanilla JS, we just execute the listener + VanillaFrameworkOverrides.prototype.dispatchEvent = function (eventType, listener, global) { + if (global === void 0) { global = false; } + listener(); }; - StandardMenuFactory.prototype.trapFocusWithin = function (e, menu) { - if (e.keyCode !== _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_TAB) { - return; - } - if (this.focusController.findNextFocusableElement(menu, false, e.shiftKey)) { - return; - } - e.preventDefault(); - if (e.shiftKey) { - this.focusController.focusLastFocusableElement(menu); - } - else { - this.focusController.focusFirstFocusableElement(menu); - } + VanillaFrameworkOverrides.prototype.frameworkComponent = function (name) { + return null; }; - StandardMenuFactory.prototype.isMenuEnabled = function (column) { - // for standard, we show menu if filter is enabled, and the menu is not suppressed - return column.isFilterAllowed(); + VanillaFrameworkOverrides.prototype.isFrameworkComponent = function (comp) { + return false; }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager') - ], StandardMenuFactory.prototype, "filterManager", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('popupService') - ], StandardMenuFactory.prototype, "popupService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusController') - ], StandardMenuFactory.prototype, "focusController", void 0); - StandardMenuFactory = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('menuFactory') - ], StandardMenuFactory); - return StandardMenuFactory; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + return VanillaFrameworkOverrides; +}()); /***/ }), -/* 139 */ +/* 188 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DragService", function() { return DragService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ScrollVisibleService", function() { return ScrollVisibleService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(23); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -34377,280 +41993,96 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta - -/** Adds drag listening onto an element. In ag-Grid this is used twice, first is resizing columns, - * second is moving the columns and column groups around (ie the 'drag' part of Drag and Drop. */ -var DragService = /** @class */ (function (_super) { - __extends(DragService, _super); - function DragService() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.dragEndFunctions = []; - _this.dragSources = []; - return _this; +var ScrollVisibleService = /** @class */ (function (_super) { + __extends(ScrollVisibleService, _super); + function ScrollVisibleService() { + return _super !== null && _super.apply(this, arguments) || this; } - DragService.prototype.init = function () { - this.logger = this.loggerFactory.create('DragService'); - }; - DragService.prototype.removeAllListeners = function () { - this.dragSources.forEach(this.removeListener.bind(this)); - this.dragSources.length = 0; - }; - DragService.prototype.removeListener = function (dragSourceAndListener) { - var element = dragSourceAndListener.dragSource.eElement; - var mouseDownListener = dragSourceAndListener.mouseDownListener; - element.removeEventListener('mousedown', mouseDownListener); - // remove touch listener only if it exists - if (dragSourceAndListener.touchEnabled) { - var touchStartListener = dragSourceAndListener.touchStartListener; - element.removeEventListener('touchstart', touchStartListener, { passive: true }); - } - }; - DragService.prototype.removeDragSource = function (params) { - var dragSourceAndListener = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].find(this.dragSources, function (item) { return item.dragSource === params; }); - if (!dragSourceAndListener) { - return; - } - this.removeListener(dragSourceAndListener); - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].removeFromArray(this.dragSources, dragSourceAndListener); + ScrollVisibleService.prototype.postConstruct = function () { + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this)); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, this.onDisplayedColumnsWidthChanged.bind(this)); }; - DragService.prototype.setNoSelectToBody = function (noSelect) { - var eDocument = this.gridOptionsWrapper.getDocument(); - var eBody = eDocument.querySelector('body'); - if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(eBody)) { - // when we drag the mouse in ag-Grid, this class gets added / removed from the body, so that - // the mouse isn't selecting text when dragging. - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(eBody, 'ag-unselectable', noSelect); - } + ScrollVisibleService.prototype.onDisplayedColumnsChanged = function () { + this.update(); }; - DragService.prototype.addDragSource = function (params, includeTouch) { - if (includeTouch === void 0) { includeTouch = false; } - var mouseListener = this.onMouseDown.bind(this, params); - params.eElement.addEventListener('mousedown', mouseListener); - var touchListener = null; - var suppressTouch = this.gridOptionsWrapper.isSuppressTouch(); - if (includeTouch && !suppressTouch) { - touchListener = this.onTouchStart.bind(this, params); - params.eElement.addEventListener('touchstart', touchListener, { passive: false }); - } - this.dragSources.push({ - dragSource: params, - mouseDownListener: mouseListener, - touchStartListener: touchListener, - touchEnabled: includeTouch - }); + ScrollVisibleService.prototype.onDisplayedColumnsWidthChanged = function () { + this.update(); }; - // gets called whenever mouse down on any drag source - DragService.prototype.onTouchStart = function (params, touchEvent) { - var _this = this; - this.currentDragParams = params; - this.dragging = false; - var touch = touchEvent.touches[0]; - this.touchLastTime = touch; - this.touchStart = touch; - if (touchEvent.cancelable) { - touchEvent.preventDefault(); - } - var touchMoveEvent = function (e) { return _this.onTouchMove(e, params.eElement); }; - var touchEndEvent = function (e) { return _this.onTouchUp(e, params.eElement); }; - var target = params.eElement; - var events = [ - { target: target, type: 'touchmove', listener: touchMoveEvent, options: { passive: true } }, - { target: target, type: 'touchend', listener: touchEndEvent, options: { passive: true } }, - { target: target, type: 'touchcancel', listener: touchEndEvent, options: { passive: true } } - ]; - // temporally add these listeners, for the duration of the drag - this.addTemporaryEvents(events); - // see if we want to start dragging straight away - if (params.dragStartPixels === 0) { - this.onCommonMove(touch, this.touchStart, params.eElement); - } + ScrollVisibleService.prototype.update = function () { + // because of column animation (which takes 200ms), we have to do this twice. + // eg if user removes cols anywhere except at the RHS, then the cols on the RHS + // will animate to the left to fill the gap. this animation means just after + // the cols are removed, the remaining cols are still in the original location + // at the start of the animation, so pre animation the H scrollbar is still needed, + // but post animation it is not. + this.updateImpl(); + setTimeout(this.updateImpl.bind(this), 500); }; - // gets called whenever mouse down on any drag source - DragService.prototype.onMouseDown = function (params, mouseEvent) { - var _this = this; - var e = mouseEvent; - if (params.skipMouseEvent && params.skipMouseEvent(mouseEvent)) { - return; - } - // if there are two elements with parent / child relationship, and both are draggable, - // when we drag the child, we should NOT drag the parent. an example of this is row moving - // and range selection - row moving should get preference when use drags the rowDrag component. - if (e._alreadyProcessedByDragService) { - return; - } - e._alreadyProcessedByDragService = true; - // only interested in left button clicks - if (mouseEvent.button !== 0) { + ScrollVisibleService.prototype.updateImpl = function () { + var centerRowCtrl = this.ctrlsService.getCenterRowContainerCtrl(); + if (!centerRowCtrl) { return; } - this.currentDragParams = params; - this.dragging = false; - this.mouseStartEvent = mouseEvent; - var eDocument = this.gridOptionsWrapper.getDocument(); - this.setNoSelectToBody(true); - var mouseMoveEvent = function (e, el) { return _this.onMouseMove(e, params.eElement); }; - var mouseUpEvent = function (e, el) { return _this.onMouseUp(e, params.eElement); }; - var contextEvent = function (e) { return e.preventDefault(); }; - var target = eDocument; - var events = [ - { target: target, type: 'mousemove', listener: mouseMoveEvent }, - { target: target, type: 'mouseup', listener: mouseUpEvent }, - { target: target, type: 'contextmenu', listener: contextEvent } - ]; - // temporally add these listeners, for the duration of the drag - this.addTemporaryEvents(events); - //see if we want to start dragging straight away - if (params.dragStartPixels === 0) { - this.onMouseMove(mouseEvent, params.eElement); - } - }; - DragService.prototype.addTemporaryEvents = function (events) { - events.forEach(function (currentEvent) { - var target = currentEvent.target, type = currentEvent.type, listener = currentEvent.listener, options = currentEvent.options; - target.addEventListener(type, listener, options); - }); - this.dragEndFunctions.push(function () { - events.forEach(function (currentEvent) { - var target = currentEvent.target, type = currentEvent.type, listener = currentEvent.listener, options = currentEvent.options; - target.removeEventListener(type, listener, options); - }); - }); - }; - // returns true if the event is close to the original event by X pixels either vertically or horizontally. - // we only start dragging after X pixels so this allows us to know if we should start dragging yet. - DragService.prototype.isEventNearStartEvent = function (currentEvent, startEvent) { - // by default, we wait 4 pixels before starting the drag - var dragStartPixels = this.currentDragParams.dragStartPixels; - var requiredPixelDiff = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(dragStartPixels) ? dragStartPixels : 4; - return _utils__WEBPACK_IMPORTED_MODULE_2__["_"].areEventsNear(currentEvent, startEvent, requiredPixelDiff); - }; - DragService.prototype.getFirstActiveTouch = function (touchList) { - for (var i = 0; i < touchList.length; i++) { - if (touchList[i].identifier === this.touchStart.identifier) { - return touchList[i]; - } - } - return null; + var params = { + horizontalScrollShowing: centerRowCtrl.isHorizontalScrollShowing(), + verticalScrollShowing: this.isVerticalScrollShowing() + }; + this.setScrollsVisible(params); }; - DragService.prototype.onCommonMove = function (currentEvent, startEvent, el) { - if (!this.dragging) { - // if mouse hasn't travelled from the start position enough, do nothing - if (!this.dragging && this.isEventNearStartEvent(currentEvent, startEvent)) { - return; - } - this.dragging = true; + ScrollVisibleService.prototype.setScrollsVisible = function (params) { + var atLeastOneDifferent = this.horizontalScrollShowing !== params.horizontalScrollShowing || + this.verticalScrollShowing !== params.verticalScrollShowing; + if (atLeastOneDifferent) { + this.horizontalScrollShowing = params.horizontalScrollShowing; + this.verticalScrollShowing = params.verticalScrollShowing; var event_1 = { - type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_DRAG_STARTED, + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_SCROLL_VISIBILITY_CHANGED, api: this.gridApi, - columnApi: this.columnApi, - target: el + columnApi: this.columnApi }; this.eventService.dispatchEvent(event_1); - this.currentDragParams.onDragStart(startEvent); - } - this.currentDragParams.onDragging(currentEvent); - }; - DragService.prototype.onTouchMove = function (touchEvent, el) { - var touch = this.getFirstActiveTouch(touchEvent.touches); - if (!touch) { - return; - } - // this.___statusPanel.setInfoText(Math.random() + ' onTouchMove preventDefault stopPropagation'); - // if we don't preview default, then the browser will try and do it's own touch stuff, - // like do 'back button' (chrome does this) or scroll the page (eg drag column could be confused - // with scroll page in the app) - // touchEvent.preventDefault(); - this.onCommonMove(touch, this.touchStart, el); - }; - // only gets called after a mouse down - as this is only added after mouseDown - // and is removed when mouseUp happens - DragService.prototype.onMouseMove = function (mouseEvent, el) { - this.onCommonMove(mouseEvent, this.mouseStartEvent, el); - }; - DragService.prototype.onTouchUp = function (touchEvent, el) { - var touch = this.getFirstActiveTouch(touchEvent.changedTouches); - // i haven't worked this out yet, but there is no matching touch - // when we get the touch up event. to get around this, we swap in - // the last touch. this is a hack to 'get it working' while we - // figure out what's going on, why we are not getting a touch in - // current event. - if (!touch) { - touch = this.touchLastTime; } - // if mouse was left up before we started to move, then this is a tap. - // we check this before onUpCommon as onUpCommon resets the dragging - // let tap = !this.dragging; - // let tapTarget = this.currentDragParams.eElement; - this.onUpCommon(touch, el); - // if tap, tell user - // console.log(`${Math.random()} tap = ${tap}`); - // if (tap) { - // tapTarget.click(); - // } }; - DragService.prototype.onMouseUp = function (mouseEvent, el) { - this.onUpCommon(mouseEvent, el); + // used by pagination service - to know page height + ScrollVisibleService.prototype.isHorizontalScrollShowing = function () { + return this.horizontalScrollShowing; }; - DragService.prototype.onUpCommon = function (eventOrTouch, el) { - if (this.dragging) { - this.dragging = false; - this.currentDragParams.onDragStop(eventOrTouch); - var event_2 = { - type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_DRAG_STOPPED, - api: this.gridApi, - columnApi: this.columnApi, - target: el - }; - this.eventService.dispatchEvent(event_2); - } - this.setNoSelectToBody(false); - this.mouseStartEvent = null; - this.touchStart = null; - this.touchLastTime = null; - this.currentDragParams = null; - this.dragEndFunctions.forEach(function (func) { return func(); }); - this.dragEndFunctions.length = 0; + // used by header container + ScrollVisibleService.prototype.isVerticalScrollShowing = function () { + return this.verticalScrollShowing; }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('loggerFactory') - ], DragService.prototype, "loggerFactory", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], DragService.prototype, "gridOptionsWrapper", void 0); __decorate([ Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') - ], DragService.prototype, "columnApi", void 0); + ], ScrollVisibleService.prototype, "columnApi", void 0); __decorate([ Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') - ], DragService.prototype, "gridApi", void 0); + ], ScrollVisibleService.prototype, "gridApi", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], DragService.prototype, "init", null); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('ctrlsService') + ], ScrollVisibleService.prototype, "ctrlsService", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PreDestroy"] - ], DragService.prototype, "removeAllListeners", null); - DragService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('dragService') - ], DragService); - return DragService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"])); + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], ScrollVisibleService.prototype, "postConstruct", null); + ScrollVisibleService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('scrollVisibleService') + ], ScrollVisibleService); + return ScrollVisibleService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 140 */ +/* 189 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SortController", function() { return SortController; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "StylingService", function() { return StylingService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -34675,195 +42107,100 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta }; - - -var SortController = /** @class */ (function (_super) { - __extends(SortController, _super); - function SortController() { - var _this = _super !== null && _super.apply(this, arguments) || this; - // used by the public api, for saving the sort model - _this.getSortModel = function () { - return _this.getColumnsWithSortingOrdered().map(function (column) { return ({ - colId: column.getColId(), - sort: column.getSort() - }); }); - }; - return _this; +var StylingService = /** @class */ (function (_super) { + __extends(StylingService, _super); + function StylingService() { + return _super !== null && _super.apply(this, arguments) || this; } - SortController_1 = SortController; - SortController.prototype.progressSort = function (column, multiSort, source) { - if (source === void 0) { source = "api"; } - var nextDirection = this.getNextSortDirection(column); - this.setSortForColumn(column, nextDirection, multiSort, source); + StylingService.prototype.processAllCellClasses = function (colDef, params, onApplicableClass, onNotApplicableClass) { + this.processClassRules(colDef.cellClassRules, params, onApplicableClass, onNotApplicableClass); + this.processStaticCellClasses(colDef, params, onApplicableClass); }; - SortController.prototype.setSortForColumn = function (column, sort, multiSort, source) { - if (source === void 0) { source = "api"; } - // auto correct - if sort not legal value, then set it to 'no sort' (which is null) - if (sort !== _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_ASC && sort !== _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_DESC) { - sort = null; - } - // update sort on current col - column.setSort(sort, source); - // sortedAt used for knowing order of cols when multi-col sort - if (column.getSort()) { - var sortedAt = Number(new Date().valueOf()); - column.setSortedAt(sortedAt); - } - else { - column.setSortedAt(null); - } - var doingMultiSort = multiSort && !this.gridOptionsWrapper.isSuppressMultiSort(); - // clear sort on all columns except this one, and update the icons - if (!doingMultiSort) { - this.clearSortBarThisColumn(column, source); + StylingService.prototype.processClassRules = function (classRules, params, onApplicableClass, onNotApplicableClass) { + if (classRules == null) { + return; } - this.dispatchSortChangedEvents(); - }; - // gets called by API, so if data changes, use can call this, which will end up - // working out the sort order again of the rows. - SortController.prototype.onSortChanged = function () { - this.dispatchSortChangedEvents(); - }; - SortController.prototype.dispatchSortChangedEvents = function () { - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_SORT_CHANGED, - api: this.gridApi, - columnApi: this.columnApi + var classNames = Object.keys(classRules); + var classesToApply = {}; + var classesToRemove = {}; + var _loop_1 = function (i) { + var className = classNames[i]; + var rule = classRules[className]; + var resultOfRule; + if (typeof rule === 'string') { + resultOfRule = this_1.expressionService.evaluate(rule, params); + } + else if (typeof rule === 'function') { + resultOfRule = rule(params); + } + // in case className = 'my-class1 my-class2', we need to split into individual class names + className.split(' ').forEach(function (singleClass) { + if (singleClass == null || singleClass.trim() == '') { + return; + } + resultOfRule ? classesToApply[singleClass] = true : classesToRemove[singleClass] = true; + }); }; - this.eventService.dispatchEvent(event); - }; - SortController.prototype.clearSortBarThisColumn = function (columnToSkip, source) { - this.columnController.getPrimaryAndSecondaryAndAutoColumns().forEach(function (columnToClear) { - // Do not clear if either holding shift, or if column in question was clicked - if (!(columnToClear === columnToSkip)) { - // setting to 'undefined' as null means 'none' rather than cleared, otherwise issue will arise - // if sort order is: ['desc', null , 'asc'], as it will start at null rather than 'desc'. - columnToClear.setSort(undefined, source); - } - }); - }; - SortController.prototype.getNextSortDirection = function (column) { - var sortingOrder; - if (column.getColDef().sortingOrder) { - sortingOrder = column.getColDef().sortingOrder; - } - else if (this.gridOptionsWrapper.getSortingOrder()) { - sortingOrder = this.gridOptionsWrapper.getSortingOrder(); + var this_1 = this; + for (var i = 0; i < classNames.length; i++) { + _loop_1(i); } - else { - sortingOrder = SortController_1.DEFAULT_SORTING_ORDER; + // we remove all classes first, then add all classes second, + // in case a class appears in more than one rule, this means it will be added + // if appears in at least one truthy rule + if (onNotApplicableClass) { + Object.keys(classesToRemove).forEach(onNotApplicableClass); } - if (!Array.isArray(sortingOrder) || sortingOrder.length <= 0) { - console.warn("ag-grid: sortingOrder must be an array with at least one element, currently it's " + sortingOrder); - return null; + Object.keys(classesToApply).forEach(onApplicableClass); + }; + StylingService.prototype.getStaticCellClasses = function (colDef, params) { + var cellClass = colDef.cellClass; + if (!cellClass) { + return []; } - var currentIndex = sortingOrder.indexOf(column.getSort()); - var notInArray = currentIndex < 0; - var lastItemInArray = currentIndex == sortingOrder.length - 1; - var result; - if (notInArray || lastItemInArray) { - result = sortingOrder[0]; + var classOrClasses; + if (typeof cellClass === 'function') { + var cellClassFunc = cellClass; + classOrClasses = cellClassFunc(params); } else { - result = sortingOrder[currentIndex + 1]; + classOrClasses = cellClass; } - // verify the sort type exists, as the user could provide the sortingOrder, need to make sure it's valid - if (SortController_1.DEFAULT_SORTING_ORDER.indexOf(result) < 0) { - console.warn('ag-grid: invalid sort type ' + result); - return null; + if (typeof classOrClasses === 'string') { + classOrClasses = [classOrClasses]; } - return result; - }; - SortController.prototype.setSortModel = function (sortModel, source) { - var _this = this; - if (source === void 0) { source = "api"; } - // first up, clear any previous sort - var sortModelProvided = sortModel && sortModel.length > 0; - var allColumnsIncludingAuto = this.columnController.getPrimaryAndSecondaryAndAutoColumns(); - allColumnsIncludingAuto.forEach(function (column) { - var sortForCol = null; - var sortedAt = -1; - if (sortModelProvided && column.getColDef().sortable) { - for (var j = 0; j < sortModel.length; j++) { - var sortModelEntry = sortModel[j]; - if (typeof sortModelEntry.colId === 'string' - && typeof column.getColId() === 'string' - && _this.compareColIds(sortModelEntry, column)) { - sortForCol = sortModelEntry.sort; - sortedAt = j; - } - } - } - if (sortForCol) { - column.setSort(sortForCol, source); - column.setSortedAt(sortedAt); - } - else { - column.setSort(null, source); - column.setSortedAt(null); - } - }); - this.dispatchSortChangedEvents(); - }; - SortController.prototype.compareColIds = function (sortModelEntry, column) { - return sortModelEntry.colId === column.getColId(); - }; - SortController.prototype.getColumnsWithSortingOrdered = function () { - // pull out all the columns that have sorting set - var allColumnsIncludingAuto = this.columnController.getPrimaryAndSecondaryAndAutoColumns(); - var columnsWithSorting = allColumnsIncludingAuto.filter(function (column) { return !!column.getSort(); }); - // put the columns in order of which one got sorted first - columnsWithSorting.sort(function (a, b) { return a.sortedAt - b.sortedAt; }); - return columnsWithSorting; - }; - // used by row controller, when doing the sorting - SortController.prototype.getSortForRowController = function () { - return this.getColumnsWithSortingOrdered().map(function (column) { - var isAscending = column.getSort() === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_ASC; - return { - inverter: isAscending ? 1 : -1, - column: column - }; + return classOrClasses || []; + }; + StylingService.prototype.processStaticCellClasses = function (colDef, params, onApplicableClass) { + var classOrClasses = this.getStaticCellClasses(colDef, params); + classOrClasses.forEach(function (cssClassItem) { + onApplicableClass(cssClassItem); }); }; - var SortController_1; - SortController.DEFAULT_SORTING_ORDER = [_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_ASC, _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_DESC, null]; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], SortController.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], SortController.prototype, "columnController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') - ], SortController.prototype, "columnApi", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') - ], SortController.prototype, "gridApi", void 0); - SortController = SortController_1 = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('sortController') - ], SortController); - return SortController; + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('expressionService') + ], StylingService.prototype, "expressionService", void 0); + StylingService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('stylingService') + ], StylingService); + return StylingService; }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 141 */ +/* 190 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FocusController", function() { return FocusController; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43); -/* harmony import */ var _rendering_cellComp__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(101); -/* harmony import */ var _widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(117); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnHoverService", function() { return ColumnHoverService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(23); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(20); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -34889,320 +42226,58 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta - - - -var FocusController = /** @class */ (function (_super) { - __extends(FocusController, _super); - function FocusController() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.keyboardFocusActive = false; - return _this; +var ColumnHoverService = /** @class */ (function (_super) { + __extends(ColumnHoverService, _super); + function ColumnHoverService() { + return _super !== null && _super.apply(this, arguments) || this; } - FocusController_1 = FocusController; - FocusController.prototype.init = function () { - var eDocument = this.gridOptionsWrapper.getDocument(); - var clearFocusedCellListener = this.clearFocusedCell.bind(this); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_MODE_CHANGED, clearFocusedCellListener); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_EVERYTHING_CHANGED, this.onColumnEverythingChanged.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_GROUP_OPENED, clearFocusedCellListener); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, clearFocusedCellListener); - this.addManagedListener(eDocument, 'keydown', this.activateKeyboardMode.bind(this)); - this.addManagedListener(eDocument, 'mousedown', this.activateMouseMode.bind(this)); - }; - FocusController.prototype.registerGridCore = function (gridCore) { - this.gridCore = gridCore; - }; - FocusController.prototype.onColumnEverythingChanged = function () { - // if the columns change, check and see if this column still exists. if it does, - // then we can keep the focused cell. if it doesn't, then we need to drop the focused - // cell. - if (this.focusedCellPosition) { - var col = this.focusedCellPosition.column; - var colFromColumnController = this.columnController.getGridColumn(col.getId()); - if (col !== colFromColumnController) { - this.clearFocusedCell(); - } - } - }; - FocusController.prototype.isKeyboardFocus = function () { - return this.keyboardFocusActive; - }; - FocusController.prototype.activateMouseMode = function () { - this.keyboardFocusActive = false; - this.eventService.dispatchEvent({ type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_MOUSE_FOCUS }); - }; - FocusController.prototype.activateKeyboardMode = function () { - this.keyboardFocusActive = true; - this.eventService.dispatchEvent({ type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_KEYBOARD_FOCUS }); - }; - // we check if the browser is focusing something, and if it is, and - // it's the cell we think is focused, then return the cell. so this - // methods returns the cell if a) we think it has focus and b) the - // browser thinks it has focus. this then returns nothing if we - // first focus a cell, then second click outside the grid, as then the - // grid cell will still be focused as far as the grid is concerned, - // however the browser focus will have moved somewhere else. - FocusController.prototype.getFocusCellToUseAfterRefresh = function () { - if (this.gridOptionsWrapper.isSuppressFocusAfterRefresh() || !this.focusedCellPosition) { - return null; - } - // we check that the browser is actually focusing on the grid, if it is not, then - // we have nothing to worry about - var browserFocusedCell = this.getGridCellForDomElement(document.activeElement); - if (!browserFocusedCell) { - return null; - } - return this.focusedCellPosition; - }; - FocusController.prototype.getGridCellForDomElement = function (eBrowserCell) { - var ePointer = eBrowserCell; - while (ePointer) { - var cellComp = this.gridOptionsWrapper.getDomData(ePointer, _rendering_cellComp__WEBPACK_IMPORTED_MODULE_3__["CellComp"].DOM_DATA_KEY_CELL_COMP); - if (cellComp) { - return cellComp.getCellPosition(); - } - ePointer = ePointer.parentNode; - } - return null; - }; - FocusController.prototype.clearFocusedCell = function () { - this.focusedCellPosition = null; - this.onCellFocused(false); - }; - FocusController.prototype.getFocusedCell = function () { - return this.focusedCellPosition; - }; - FocusController.prototype.setFocusedCell = function (rowIndex, colKey, floating, forceBrowserFocus) { - if (forceBrowserFocus === void 0) { forceBrowserFocus = false; } - var column = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].makeNull(this.columnController.getGridColumn(colKey)); - this.focusedCellPosition = { rowIndex: rowIndex, rowPinned: _utils__WEBPACK_IMPORTED_MODULE_5__["_"].makeNull(floating), column: column }; - this.onCellFocused(forceBrowserFocus); - }; - FocusController.prototype.isCellFocused = function (cellPosition) { - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.focusedCellPosition)) { - return false; - } - return this.focusedCellPosition.column === cellPosition.column && this.isRowFocused(cellPosition.rowIndex, cellPosition.rowPinned); - }; - FocusController.prototype.isRowNodeFocused = function (rowNode) { - return this.isRowFocused(rowNode.rowIndex, rowNode.rowPinned); - }; - FocusController.prototype.isHeaderWrapperFocused = function (headerWrapper) { - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.focusedHeaderPosition)) { - return false; - } - var column = headerWrapper.getColumn(); - var headerRowIndex = headerWrapper.getParentComponent().getRowIndex(); - var pinned = headerWrapper.getPinned(); - var _a = this.focusedHeaderPosition, focusedColumn = _a.column, focusedHeaderRowIndex = _a.headerRowIndex; - return column === focusedColumn && - headerRowIndex === focusedHeaderRowIndex && - pinned == focusedColumn.getPinned(); - }; - FocusController.prototype.clearFocusedHeader = function () { - this.focusedHeaderPosition = null; - }; - FocusController.prototype.getFocusedHeader = function () { - return this.focusedHeaderPosition; - }; - FocusController.prototype.setFocusedHeader = function (headerRowIndex, column) { - this.focusedHeaderPosition = { headerRowIndex: headerRowIndex, column: column }; - }; - FocusController.prototype.focusHeaderPosition = function (headerPosition, direction) { - this.headerNavigationService.scrollToColumn(headerPosition.column, direction); - var childContainer = this.headerNavigationService.getHeaderContainer(headerPosition.column.getPinned()); - var rowComps = childContainer.getRowComps(); - var nextRowComp = rowComps[headerPosition.headerRowIndex]; - var headerComps = nextRowComp.getHeaderComps(); - var nextHeader = headerComps[headerPosition.column.getUniqueId()]; - if (nextHeader) { - // this will automatically call the setFocusedHeader method above - nextHeader.getFocusableElement().focus(); - return true; - } - return false; - }; - FocusController.prototype.isAnyCellFocused = function () { - return !!this.focusedCellPosition; - }; - FocusController.prototype.isRowFocused = function (rowIndex, floating) { - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.focusedCellPosition)) { - return false; - } - var floatingOrNull = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].makeNull(floating); - return this.focusedCellPosition.rowIndex === rowIndex && this.focusedCellPosition.rowPinned === floatingOrNull; - }; - FocusController.prototype.findFocusableElements = function (rootNode, exclude, onlyUnmanaged) { - var focusableString = FocusController_1.FOCUSABLE_SELECTOR; - var excludeString = FocusController_1.FOCUSABLE_EXCLUDE; - if (exclude) { - excludeString += ', ' + exclude; - } - if (onlyUnmanaged) { - excludeString += ', [tabindex="-1"]'; - } - var nodes = Array.prototype.slice.apply(rootNode.querySelectorAll(focusableString)); - var excludeNodes = Array.prototype.slice.apply(rootNode.querySelectorAll(excludeString)); - if (!excludeNodes.length) { - return nodes; - } - var diff = function (a, b) { return a.filter(function (element) { return b.indexOf(element) === -1; }); }; - return diff(nodes, excludeNodes); - }; - FocusController.prototype.focusFirstFocusableElement = function (rootNode, onlyUnmanaged) { - var focusable = this.findFocusableElements(rootNode, null, onlyUnmanaged)[0]; - if (focusable) { - focusable.focus(); - return true; - } - return false; - }; - FocusController.prototype.focusLastFocusableElement = function (rootNode, onlyUnmanaged) { - var focusable = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].last(this.findFocusableElements(rootNode, null, onlyUnmanaged)); - if (focusable) { - focusable.focus(); - return true; - } - return false; - }; - FocusController.prototype.findNextFocusableElement = function (rootNode, onlyManaged, backwards) { - var focusable = this.findFocusableElements(rootNode, onlyManaged ? ':not([tabindex="-1"])' : null); - var currentIndex; - if (onlyManaged) { - currentIndex = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].findIndex(focusable, function (el) { return el.contains(document.activeElement); }); - } - else { - currentIndex = focusable.indexOf(document.activeElement); - } - var nextIndex = currentIndex + (backwards ? -1 : 1); - if (nextIndex < 0 || nextIndex > focusable.length) { - return; - } - return focusable[nextIndex]; - }; - FocusController.prototype.isFocusUnderManagedComponent = function (rootNode) { - var managedContainers = rootNode.querySelectorAll("." + _widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_4__["ManagedFocusComponent"].FOCUS_MANAGED_CLASS); - if (!managedContainers.length) { - return false; - } - for (var i = 0; i < managedContainers.length; i++) { - if (managedContainers[i].contains(document.activeElement)) { - return true; - } - } - return false; - }; - FocusController.prototype.findTabbableParent = function (node, limit) { - if (limit === void 0) { limit = 5; } - var counter = 0; - while (node && _utils__WEBPACK_IMPORTED_MODULE_5__["_"].getTabIndex(node) === null && ++counter <= limit) { - node = node.parentElement; - } - if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].getTabIndex(node) === null) { - return null; - } - return node; - }; - FocusController.prototype.onCellFocused = function (forceBrowserFocus) { + ColumnHoverService.prototype.setMouseOver = function (columns) { + this.selectedColumns = columns; var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_CELL_FOCUSED, - forceBrowserFocus: forceBrowserFocus, - rowIndex: null, - column: null, - floating: null, + type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_HOVER_CHANGED, api: this.gridApi, - columnApi: this.columnApi, - rowPinned: null + columnApi: this.columnApi }; - if (this.focusedCellPosition) { - event.rowIndex = this.focusedCellPosition.rowIndex; - event.column = this.focusedCellPosition.column; - event.rowPinned = this.focusedCellPosition.rowPinned; - } this.eventService.dispatchEvent(event); }; - FocusController.prototype.focusGridView = function (column) { - var firstRow = this.rowPositionUtils.getFirstRow(); - if (!firstRow) { - return false; - } - var rowIndex = firstRow.rowIndex, rowPinned = firstRow.rowPinned; - var focusedHeader = this.getFocusedHeader(); - if (!column) { - column = focusedHeader.column; - } - if (!_utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(rowIndex)) { - return false; - } - this.rowRenderer.ensureCellVisible({ rowIndex: rowIndex, column: column, rowPinned: rowPinned }); - this.setFocusedCell(rowIndex, column, _utils__WEBPACK_IMPORTED_MODULE_5__["_"].makeNull(rowPinned), true); - if (this.rangeController) { - var cellPosition = { rowIndex: rowIndex, rowPinned: rowPinned, column: column }; - this.rangeController.setRangeToCell(cellPosition); - } - return true; + ColumnHoverService.prototype.clearMouseOver = function () { + this.selectedColumns = null; + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_HOVER_CHANGED, + api: this.gridApi, + columnApi: this.columnApi + }; + this.eventService.dispatchEvent(event); }; - FocusController.prototype.focusNextGridCoreContainer = function (backwards) { - if (this.gridCore.focusNextInnerContainer(backwards)) { - return true; - } - if (!backwards) { - this.gridCore.forceFocusOutOfContainer(); - } + ColumnHoverService.prototype.isHovered = function (column) { + return !!this.selectedColumns && this.selectedColumns.indexOf(column) >= 0; }; - var FocusController_1; - FocusController.FOCUSABLE_SELECTOR = '[tabindex], input, select, button, textarea'; - FocusController.FOCUSABLE_EXCLUDE = '.ag-hidden, .ag-hidden *, .ag-disabled, .ag-disabled *'; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], FocusController.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], FocusController.prototype, "columnController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('headerNavigationService') - ], FocusController.prototype, "headerNavigationService", void 0); __decorate([ Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') - ], FocusController.prototype, "columnApi", void 0); + ], ColumnHoverService.prototype, "columnApi", void 0); __decorate([ Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') - ], FocusController.prototype, "gridApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer') - ], FocusController.prototype, "rowRenderer", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowPositionUtils') - ], FocusController.prototype, "rowPositionUtils", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('rangeController') - ], FocusController.prototype, "rangeController", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], FocusController.prototype, "init", null); - FocusController = FocusController_1 = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('focusController') - ], FocusController); - return FocusController; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + ], ColumnHoverService.prototype, "gridApi", void 0); + ColumnHoverService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('columnHoverService') + ], ColumnHoverService); + return ColumnHoverService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"])); /***/ }), -/* 142 */ +/* 191 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MouseEventService", function() { return MouseEventService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnAnimationService", function() { return ColumnAnimationService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -35227,95 +42302,117 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta }; - - - -var MouseEventService = /** @class */ (function (_super) { - __extends(MouseEventService, _super); - function MouseEventService() { +var ColumnAnimationService = /** @class */ (function (_super) { + __extends(ColumnAnimationService, _super); + function ColumnAnimationService() { var _this = _super !== null && _super.apply(this, arguments) || this; - _this.gridInstanceId = MouseEventService_1.gridInstanceSequence.next(); + _this.executeNextFuncs = []; + _this.executeLaterFuncs = []; + _this.active = false; + _this.animationThreadCount = 0; return _this; } - MouseEventService_1 = MouseEventService; - MouseEventService.prototype.init = function () { - this.stampDomElementWithGridInstance(); + ColumnAnimationService.prototype.postConstruct = function () { + var _this = this; + this.ctrlsService.whenReady(function (p) { return _this.gridBodyCtrl = p.gridBodyCtrl; }); }; - MouseEventService.prototype.registerGridComp = function (gridPanel) { - this.gridPanel = gridPanel; + ColumnAnimationService.prototype.isActive = function () { + return this.active; }; - // we put the instance id onto the main DOM element. this is used for events, when grids are inside grids, - // so the grid can work out if the even came from this grid or a grid inside this one. see the ctrl+v logic - // for where this is used. - MouseEventService.prototype.stampDomElementWithGridInstance = function () { - this.eGridDiv[MouseEventService_1.GRID_DOM_KEY] = this.gridInstanceId; + ColumnAnimationService.prototype.start = function () { + if (this.active) { + return; + } + if (this.gridOptionsWrapper.isSuppressColumnMoveAnimation()) { + return; + } + // if doing RTL, we don't animate open / close as due to how the pixels are inverted, + // the animation moves all the row the the right rather than to the left (ie it's the static + // columns that actually get their coordinates updated) + if (this.gridOptionsWrapper.isEnableRtl()) { + return; + } + this.ensureAnimationCssClassPresent(); + this.active = true; }; - MouseEventService.prototype.getRenderedCellForEvent = function (event) { - return _utils__WEBPACK_IMPORTED_MODULE_1__["_"].getCellCompForEvent(this.gridOptionsWrapper, event); + ColumnAnimationService.prototype.finish = function () { + if (!this.active) { + return; + } + this.flush(); + this.active = false; }; - // walks the path of the event, and returns true if this grid is the first one that it finds. if doing - // master / detail grids, and a child grid is found, then it returns false. this stops things like copy/paste - // getting executed on many grids at the same time. - MouseEventService.prototype.isEventFromThisGrid = function (event) { - var path = _utils__WEBPACK_IMPORTED_MODULE_1__["_"].getEventPath(event); - for (var i = 0; i < path.length; i++) { - var element = path[i]; - var instanceId = element[MouseEventService_1.GRID_DOM_KEY]; - if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(instanceId)) { - var eventFromThisGrid = instanceId === this.gridInstanceId; - return eventFromThisGrid; - } + ColumnAnimationService.prototype.executeNextVMTurn = function (func) { + if (this.active) { + this.executeNextFuncs.push(func); + } + else { + func(); } - return false; }; - MouseEventService.prototype.getCellPositionForEvent = function (event) { - var cellComp = this.getRenderedCellForEvent(event); - return cellComp ? cellComp.getCellPosition() : null; + ColumnAnimationService.prototype.executeLaterVMTurn = function (func) { + if (this.active) { + this.executeLaterFuncs.push(func); + } + else { + func(); + } }; - MouseEventService.prototype.getNormalisedPosition = function (event) { - var gridPanelHasScrolls = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].DOM_LAYOUT_NORMAL; - var x = event.x, y = event.y; - if (gridPanelHasScrolls) { - var vRange = this.gridPanel.getVScrollPosition(); - var hRange = this.gridPanel.getHScrollPosition(); - return { x: x + hRange.left, y: y + vRange.top }; + ColumnAnimationService.prototype.ensureAnimationCssClassPresent = function () { + var _this = this; + // up the count, so we can tell if someone else has updated the count + // by the time the 'wait' func executes + this.animationThreadCount++; + var animationThreadCountCopy = this.animationThreadCount; + this.gridBodyCtrl.setColumnMovingCss(true); + this.executeLaterFuncs.push(function () { + // only remove the class if this thread was the last one to update it + if (_this.animationThreadCount === animationThreadCountCopy) { + _this.gridBodyCtrl.setColumnMovingCss(false); + } + }); + }; + ColumnAnimationService.prototype.flush = function () { + var nowFuncs = this.executeNextFuncs; + this.executeNextFuncs = []; + var waitFuncs = this.executeLaterFuncs; + this.executeLaterFuncs = []; + if (nowFuncs.length === 0 && waitFuncs.length === 0) { + return; } - return { x: x, y: y }; + window.setTimeout(function () { return nowFuncs.forEach(function (func) { return func(); }); }, 0); + window.setTimeout(function () { return waitFuncs.forEach(function (func) { return func(); }); }, 300); }; - var MouseEventService_1; - MouseEventService.gridInstanceSequence = new _utils__WEBPACK_IMPORTED_MODULE_1__["NumberSequence"](); - MouseEventService.GRID_DOM_KEY = '__ag_grid_instance'; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], MouseEventService.prototype, "gridOptionsWrapper", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('eGridDiv') - ], MouseEventService.prototype, "eGridDiv", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('ctrlsService') + ], ColumnAnimationService.prototype, "ctrlsService", void 0); __decorate([ _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], MouseEventService.prototype, "init", null); - MouseEventService = MouseEventService_1 = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('mouseEventService') - ], MouseEventService); - return MouseEventService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"])); + ], ColumnAnimationService.prototype, "postConstruct", null); + ColumnAnimationService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('columnAnimationService') + ], ColumnAnimationService); + return ColumnAnimationService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 143 */ +/* 192 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellNavigationService", function() { return CellNavigationService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AutoGroupColService", function() { return AutoGroupColService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(10); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(15); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(20); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(13); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -35342,291 +42439,152 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var CellNavigationService = /** @class */ (function (_super) { - __extends(CellNavigationService, _super); - function CellNavigationService() { + + +var AutoGroupColService = /** @class */ (function (_super) { + __extends(AutoGroupColService, _super); + function AutoGroupColService() { return _super !== null && _super.apply(this, arguments) || this; } - // returns null if no cell to focus on, ie at the end of the grid - CellNavigationService.prototype.getNextCellToFocus = function (key, lastCellToFocus) { - // starting with the provided cell, we keep moving until we find a cell we can - // focus on. - var pointer = lastCellToFocus; - var finished = false; - // finished will be true when either: - // a) cell found that we can focus on - // b) run out of cells (ie the method returns null) - while (!finished) { - switch (key) { - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_UP: - pointer = this.getCellAbove(pointer); - break; - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_DOWN: - pointer = this.getCellBelow(pointer); - break; - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_RIGHT: - if (this.gridOptionsWrapper.isEnableRtl()) { - pointer = this.getCellToLeft(pointer); - } - else { - pointer = this.getCellToRight(pointer); - } - break; - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_LEFT: - if (this.gridOptionsWrapper.isEnableRtl()) { - pointer = this.getCellToRight(pointer); - } - else { - pointer = this.getCellToLeft(pointer); - } - break; - default: - pointer = null; - console.warn('ag-Grid: unknown key for navigation ' + key); - break; - } - if (pointer) { - finished = this.isCellGoodToFocusOn(pointer); - } - else { - finished = true; - } - } - return pointer; - }; - CellNavigationService.prototype.isCellGoodToFocusOn = function (gridCell) { - var column = gridCell.column; - var rowNode; - switch (gridCell.rowPinned) { - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP: - rowNode = this.pinnedRowModel.getPinnedTopRow(gridCell.rowIndex); - break; - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM: - rowNode = this.pinnedRowModel.getPinnedBottomRow(gridCell.rowIndex); - break; - default: - rowNode = this.rowModel.getRow(gridCell.rowIndex); - break; - } - var suppressNavigable = column.isSuppressNavigable(rowNode); - return !suppressNavigable; - }; - CellNavigationService.prototype.getCellToLeft = function (lastCell) { - if (!lastCell) { - return null; - } - var colToLeft = this.columnController.getDisplayedColBefore(lastCell.column); - if (!colToLeft) { - return null; - } - return { - rowIndex: lastCell.rowIndex, - column: colToLeft, - rowPinned: lastCell.rowPinned - }; - }; - CellNavigationService.prototype.getCellToRight = function (lastCell) { - if (!lastCell) { - return null; - } - var colToRight = this.columnController.getDisplayedColAfter(lastCell.column); - // if already on right, do nothing - if (!colToRight) { - return null; - } - return { - rowIndex: lastCell.rowIndex, - column: colToRight, - rowPinned: lastCell.rowPinned - }; - }; - CellNavigationService.prototype.getRowBelow = function (rowPosition) { - // if already on top row, do nothing - var index = rowPosition.rowIndex; - var pinned = rowPosition.rowPinned; - if (this.isLastRowInContainer(rowPosition)) { - switch (pinned) { - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM: - // never any rows after pinned bottom - return null; - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP: - // if on last row of pinned top, then next row is main body (if rows exist), - // otherwise it's the pinned bottom - if (this.rowModel.isRowsToRender()) { - return { rowIndex: 0, rowPinned: null }; - } - else if (this.pinnedRowModel.isRowsToRender(_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM)) { - return { rowIndex: 0, rowPinned: _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM }; - } - return null; - default: - // if in the main body, then try pinned bottom, otherwise return nothing - if (this.pinnedRowModel.isRowsToRender(_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM)) { - return { rowIndex: 0, rowPinned: _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM }; - } - return null; - } + AutoGroupColService_1 = AutoGroupColService; + AutoGroupColService.prototype.createAutoGroupColumns = function (rowGroupColumns) { + var _this = this; + var groupAutoColumns = []; + var doingTreeData = this.gridOptionsWrapper.isTreeData(); + var doingMultiAutoColumn = this.gridOptionsWrapper.isGroupMultiAutoColumn(); + if (doingTreeData && doingMultiAutoColumn) { + console.warn('AG Grid: you cannot mix groupMultiAutoColumn with treeData, only one column can be used to display groups when doing tree data'); + doingMultiAutoColumn = false; } - return { rowIndex: index + 1, rowPinned: pinned }; - }; - CellNavigationService.prototype.getCellBelow = function (lastCell) { - if (!lastCell) { - return null; + // if doing groupMultiAutoColumn, then we call the method multiple times, once + // for each column we are grouping by + if (doingMultiAutoColumn) { + rowGroupColumns.forEach(function (rowGroupCol, index) { + groupAutoColumns.push(_this.createOneAutoGroupColumn(rowGroupCol, index)); + }); } - var rowBelow = this.getRowBelow(lastCell); - if (rowBelow) { - return { - rowIndex: rowBelow.rowIndex, - column: lastCell.column, - rowPinned: rowBelow.rowPinned - }; + else { + groupAutoColumns.push(this.createOneAutoGroupColumn()); } - return null; + return groupAutoColumns; }; - CellNavigationService.prototype.isLastRowInContainer = function (rowPosition) { - var pinned = rowPosition.rowPinned; - var index = rowPosition.rowIndex; - if (pinned === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP) { - var lastTopIndex = this.pinnedRowModel.getPinnedTopRowData().length - 1; - return lastTopIndex <= index; + // rowGroupCol and index are missing if groupMultiAutoColumn=false + AutoGroupColService.prototype.createOneAutoGroupColumn = function (rowGroupCol, index) { + // if one provided by user, use it, otherwise create one + var defaultAutoColDef = this.generateDefaultColDef(rowGroupCol); + // if doing multi, set the field + var colId; + if (rowGroupCol) { + colId = _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].GROUP_AUTO_COLUMN_ID + "-" + rowGroupCol.getId(); } - else if (pinned === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM) { - var lastBottomIndex = this.pinnedRowModel.getPinnedBottomRowData().length - 1; - return lastBottomIndex <= index; + else { + colId = AutoGroupColService_1.GROUP_AUTO_COLUMN_BUNDLE_ID; } - var lastBodyIndex = this.rowModel.getRowCount() - 1; - return lastBodyIndex <= index; - }; - CellNavigationService.prototype.getRowAbove = function (rowPosition) { - // if already on top row, do nothing - var index = rowPosition.rowIndex; - var pinned = rowPosition.rowPinned; - // if already on top row, do nothing - if (index === 0) { - if (pinned === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP) { - return null; - } - else if (!pinned) { - if (this.pinnedRowModel.isRowsToRender(_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP)) { - return this.getLastFloatingTopRow(); - } - return null; - } - else { - // last floating bottom - if (this.rowModel.isRowsToRender()) { - return this.getLastBodyCell(); - } - else if (this.pinnedRowModel.isRowsToRender(_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP)) { - return this.getLastFloatingTopRow(); - } - return null; + var userAutoColDef = this.gridOptionsWrapper.getAutoGroupColumnDef(); + Object(_utils_object__WEBPACK_IMPORTED_MODULE_4__["mergeDeep"])(defaultAutoColDef, userAutoColDef); + defaultAutoColDef = this.columnFactory.mergeColDefs(defaultAutoColDef); + defaultAutoColDef.colId = colId; + // For tree data the filter is always allowed + if (!this.gridOptionsWrapper.isTreeData()) { + // we would only allow filter if the user has provided field or value getter. otherwise the filter + // would not be able to work. + var noFieldOrValueGetter = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["missing"])(defaultAutoColDef.field) && Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["missing"])(defaultAutoColDef.valueGetter) && Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["missing"])(defaultAutoColDef.filterValueGetter); + if (noFieldOrValueGetter) { + defaultAutoColDef.filter = false; } } - return { rowIndex: index - 1, rowPinned: pinned }; - }; - CellNavigationService.prototype.getCellAbove = function (lastCell) { - if (!lastCell) { - return null; - } - var rowAbove = this.getRowAbove({ rowIndex: lastCell.rowIndex, rowPinned: lastCell.rowPinned }); - if (rowAbove) { - return { - rowIndex: rowAbove.rowIndex, - column: lastCell.column, - rowPinned: rowAbove.rowPinned - }; + // if showing many cols, we don't want to show more than one with a checkbox for selection + if (index && index > 0) { + defaultAutoColDef.headerCheckboxSelection = false; } - return null; - }; - CellNavigationService.prototype.getLastBodyCell = function () { - var lastBodyRow = this.rowModel.getRowCount() - 1; - return { rowIndex: lastBodyRow, rowPinned: null }; - }; - CellNavigationService.prototype.getLastFloatingTopRow = function () { - var lastFloatingRow = this.pinnedRowModel.getPinnedTopRowData().length - 1; - return { rowIndex: lastFloatingRow, rowPinned: _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP }; + var newCol = new _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"](defaultAutoColDef, null, colId, true); + this.context.createBean(newCol); + return newCol; }; - CellNavigationService.prototype.getNextTabbedCell = function (gridCell, backwards) { - if (backwards) { - return this.getNextTabbedCellBackwards(gridCell); + AutoGroupColService.prototype.generateDefaultColDef = function (rowGroupCol) { + var userDef = this.gridOptionsWrapper.getAutoGroupColumnDef(); + var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc(); + var res = { + headerName: localeTextFunc('group', 'Group') + }; + var userHasProvidedGroupCellRenderer = userDef && + (userDef.cellRenderer || userDef.cellRendererFramework || userDef.cellRendererSelector); + // only add the default group cell renderer if user hasn't provided one + if (!userHasProvidedGroupCellRenderer) { + res.cellRenderer = 'agGroupCellRenderer'; } - return this.getNextTabbedCellForwards(gridCell); - }; - CellNavigationService.prototype.getNextTabbedCellForwards = function (gridCell) { - var displayedColumns = this.columnController.getAllDisplayedColumns(); - var newRowIndex = gridCell.rowIndex; - var newFloating = gridCell.rowPinned; - // move along to the next cell - var newColumn = this.columnController.getDisplayedColAfter(gridCell.column); - // check if end of the row, and if so, go forward a row - if (!newColumn) { - newColumn = displayedColumns[0]; - var rowBelow = this.getRowBelow(gridCell); - if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].missing(rowBelow)) { - return null; + // we never allow moving the group column + // defaultAutoColDef.suppressMovable = true; + if (rowGroupCol) { + var colDef = rowGroupCol.getColDef(); + Object.assign(res, { + // cellRendererParams.groupKey: colDefToCopy.field; + headerName: this.columnModel.getDisplayNameForColumn(rowGroupCol, 'header'), + headerValueGetter: colDef.headerValueGetter + }); + if (colDef.cellRenderer || colDef.cellRendererFramework) { + Object.assign(res, { + cellRendererParams: { + innerRenderer: colDef.cellRenderer, + innerRendererFramework: colDef.cellRendererFramework, + innerRendererParams: colDef.cellRendererParams + } + }); } - newRowIndex = rowBelow ? rowBelow.rowIndex : null; - newFloating = rowBelow ? rowBelow.rowPinned : null; + res.showRowGroup = rowGroupCol.getColId(); } - return { rowIndex: newRowIndex, column: newColumn, rowPinned: newFloating }; - }; - CellNavigationService.prototype.getNextTabbedCellBackwards = function (gridCell) { - var displayedColumns = this.columnController.getAllDisplayedColumns(); - var newRowIndex = gridCell.rowIndex; - var newFloating = gridCell.rowPinned; - // move along to the next cell - var newColumn = this.columnController.getDisplayedColBefore(gridCell.column); - // check if end of the row, and if so, go forward a row - if (!newColumn) { - newColumn = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].last(displayedColumns); - var rowAbove = this.getRowAbove({ rowIndex: gridCell.rowIndex, rowPinned: gridCell.rowPinned }); - if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].missing(rowAbove)) { - return null; - } - newRowIndex = rowAbove ? rowAbove.rowIndex : null; - newFloating = rowAbove ? rowAbove.rowPinned : null; + else { + res.showRowGroup = true; } - return { rowIndex: newRowIndex, column: newColumn, rowPinned: newFloating }; + return res; }; + var AutoGroupColService_1; + AutoGroupColService.GROUP_AUTO_COLUMN_BUNDLE_ID = _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].GROUP_AUTO_COLUMN_ID; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], CellNavigationService.prototype, "columnController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel') - ], CellNavigationService.prototype, "rowModel", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('pinnedRowModel') - ], CellNavigationService.prototype, "pinnedRowModel", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], AutoGroupColService.prototype, "columnModel", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], CellNavigationService.prototype, "gridOptionsWrapper", void 0); - CellNavigationService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('cellNavigationService') - ], CellNavigationService); - return CellNavigationService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnFactory') + ], AutoGroupColService.prototype, "columnFactory", void 0); + AutoGroupColService = AutoGroupColService_1 = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('autoGroupColService') + ], AutoGroupColService); + return AutoGroupColService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"])); /***/ }), -/* 144 */ +/* 193 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellRendererFactory", function() { return CellRendererFactory; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _cellRenderers_animateSlideCellRenderer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(77); -/* harmony import */ var _cellRenderers_animateShowChangeCellRenderer__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(76); -/* harmony import */ var _cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(67); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PaginationProxy", function() { return PaginationProxy; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(23); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony import */ var _utils_number__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(46); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); @@ -35638,70 +42596,321 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var CellRendererFactory = /** @class */ (function () { - function CellRendererFactory() { - this.cellRendererMap = {}; +var PaginationProxy = /** @class */ (function (_super) { + __extends(PaginationProxy, _super); + function PaginationProxy() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.currentPage = 0; + _this.topDisplayedRowIndex = 0; + _this.bottomDisplayedRowIndex = 0; + _this.pixelOffset = 0; + _this.masterRowCount = 0; + return _this; } - CellRendererFactory_1 = CellRendererFactory; - CellRendererFactory.prototype.init = function () { - this.cellRendererMap[CellRendererFactory_1.ANIMATE_SLIDE] = _cellRenderers_animateSlideCellRenderer__WEBPACK_IMPORTED_MODULE_1__["AnimateSlideCellRenderer"]; - this.cellRendererMap[CellRendererFactory_1.ANIMATE_SHOW_CHANGE] = _cellRenderers_animateShowChangeCellRenderer__WEBPACK_IMPORTED_MODULE_2__["AnimateShowChangeCellRenderer"]; - this.cellRendererMap[CellRendererFactory_1.GROUP] = _cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_3__["GroupCellRenderer"]; - // this.registerRenderersFromGridOptions(); + PaginationProxy.prototype.postConstruct = function () { + this.active = this.gridOptionsWrapper.isPagination(); + this.paginateChildRows = this.gridOptionsWrapper.isPaginateChildRows(); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_MODEL_UPDATED, this.onModelUpdated.bind(this)); + this.addManagedListener(this.gridOptionsWrapper, 'paginationPageSize', this.onPaginationPageSizeChanged.bind(this)); + this.onModelUpdated(); }; - // private registerRenderersFromGridOptions(): void { - // let userProvidedCellRenderers = this.gridOptionsWrapper.getCellRenderers(); - // _.iterateObject(userProvidedCellRenderers, (key: string, cellRenderer: {new(): ICellRenderer} | ICellRendererFunc)=> { - // this.addCellRenderer(key, cellRenderer); - // }); - // } - CellRendererFactory.prototype.addCellRenderer = function (key, cellRenderer) { - this.cellRendererMap[key] = cellRenderer; + PaginationProxy.prototype.ensureRowHeightsValid = function (startPixel, endPixel, startLimitIndex, endLimitIndex) { + var res = this.rowModel.ensureRowHeightsValid(startPixel, endPixel, this.getPageFirstRow(), this.getPageLastRow()); + if (res) { + this.calculatePages(); + } + return res; }; - CellRendererFactory.prototype.getCellRenderer = function (key) { - var result = this.cellRendererMap[key]; - if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].missing(result)) { - console.warn('ag-Grid: unable to find cellRenderer for key ' + key); - return null; + PaginationProxy.prototype.onModelUpdated = function (modelUpdatedEvent) { + this.calculatePages(); + var paginationChangedEvent = { + type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_PAGINATION_CHANGED, + animate: modelUpdatedEvent ? modelUpdatedEvent.animate : false, + newData: modelUpdatedEvent ? modelUpdatedEvent.newData : false, + newPage: modelUpdatedEvent ? modelUpdatedEvent.newPage : false, + keepRenderedRows: modelUpdatedEvent ? modelUpdatedEvent.keepRenderedRows : false, + api: this.gridApi, + columnApi: this.columnApi + }; + this.eventService.dispatchEvent(paginationChangedEvent); + }; + PaginationProxy.prototype.onPaginationPageSizeChanged = function () { + this.calculatePages(); + var paginationChangedEvent = { + type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_PAGINATION_CHANGED, + animate: false, + newData: false, + newPage: false, + // important to keep rendered rows, otherwise every time grid is resized, + // we would destroy all the rows. + keepRenderedRows: true, + api: this.gridApi, + columnApi: this.columnApi + }; + this.eventService.dispatchEvent(paginationChangedEvent); + }; + PaginationProxy.prototype.goToPage = function (page) { + if (!this.active || this.currentPage === page) { + return; } - return result; + this.currentPage = page; + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_MODEL_UPDATED, + animate: false, + keepRenderedRows: false, + newData: false, + newPage: true, + api: this.gridApi, + columnApi: this.columnApi + }; + this.onModelUpdated(event); + }; + PaginationProxy.prototype.getPixelOffset = function () { + return this.pixelOffset; + }; + PaginationProxy.prototype.getRow = function (index) { + return this.rowModel.getRow(index); + }; + PaginationProxy.prototype.getRowNode = function (id) { + return this.rowModel.getRowNode(id); + }; + PaginationProxy.prototype.getRowIndexAtPixel = function (pixel) { + return this.rowModel.getRowIndexAtPixel(pixel); + }; + PaginationProxy.prototype.getCurrentPageHeight = function () { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["missing"])(this.topRowBounds) || Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["missing"])(this.bottomRowBounds)) { + return 0; + } + return Math.max(this.bottomRowBounds.rowTop + this.bottomRowBounds.rowHeight - this.topRowBounds.rowTop, 0); + }; + PaginationProxy.prototype.getCurrentPagePixelRange = function () { + var pageFirstPixel = this.topRowBounds ? this.topRowBounds.rowTop : 0; + var pageLastPixel = this.bottomRowBounds ? this.bottomRowBounds.rowTop + this.bottomRowBounds.rowHeight : 0; + return { pageFirstPixel: pageFirstPixel, pageLastPixel: pageLastPixel }; + }; + PaginationProxy.prototype.isRowPresent = function (rowNode) { + if (!this.rowModel.isRowPresent(rowNode)) { + return false; + } + var nodeIsInPage = rowNode.rowIndex >= this.topDisplayedRowIndex && rowNode.rowIndex <= this.bottomDisplayedRowIndex; + return nodeIsInPage; + }; + PaginationProxy.prototype.isEmpty = function () { + return this.rowModel.isEmpty(); + }; + PaginationProxy.prototype.isRowsToRender = function () { + return this.rowModel.isRowsToRender(); + }; + PaginationProxy.prototype.getNodesInRangeForSelection = function (firstInRange, lastInRange) { + return this.rowModel.getNodesInRangeForSelection(firstInRange, lastInRange); + }; + PaginationProxy.prototype.forEachNode = function (callback) { + return this.rowModel.forEachNode(callback); + }; + PaginationProxy.prototype.getType = function () { + return this.rowModel.getType(); + }; + PaginationProxy.prototype.getRowBounds = function (index) { + var res = this.rowModel.getRowBounds(index); + res.rowIndex = index; + return res; + }; + PaginationProxy.prototype.getPageFirstRow = function () { + return this.topRowBounds ? this.topRowBounds.rowIndex : -1; + }; + PaginationProxy.prototype.getPageLastRow = function () { + return this.bottomRowBounds ? this.bottomRowBounds.rowIndex : -1; + }; + PaginationProxy.prototype.getRowCount = function () { + return this.rowModel.getRowCount(); + }; + PaginationProxy.prototype.getPageForIndex = function (index) { + return Math.floor(index / this.pageSize); + }; + PaginationProxy.prototype.goToPageWithIndex = function (index) { + if (!this.active) { + return; + } + var pageNumber = this.getPageForIndex(index); + this.goToPage(pageNumber); + }; + PaginationProxy.prototype.isRowInPage = function (row) { + if (!this.active) { + return true; + } + var rowPage = this.getPageForIndex(row.rowIndex); + return rowPage === this.currentPage; + }; + PaginationProxy.prototype.isLastPageFound = function () { + return this.rowModel.isLastRowIndexKnown(); + }; + PaginationProxy.prototype.getCurrentPage = function () { + return this.currentPage; + }; + PaginationProxy.prototype.goToNextPage = function () { + this.goToPage(this.currentPage + 1); + }; + PaginationProxy.prototype.goToPreviousPage = function () { + this.goToPage(this.currentPage - 1); + }; + PaginationProxy.prototype.goToFirstPage = function () { + this.goToPage(0); + }; + PaginationProxy.prototype.goToLastPage = function () { + var rowCount = this.rowModel.getRowCount(); + var lastPage = Math.floor(rowCount / this.pageSize); + this.goToPage(lastPage); + }; + PaginationProxy.prototype.getPageSize = function () { + return this.pageSize; + }; + PaginationProxy.prototype.getTotalPages = function () { + return this.totalPages; + }; + PaginationProxy.prototype.setPageSize = function () { + // show put this into super class + this.pageSize = this.gridOptionsWrapper.getPaginationPageSize(); + if (this.pageSize == null || this.pageSize < 1) { + this.pageSize = 100; + } + }; + PaginationProxy.prototype.calculatePages = function () { + if (this.active) { + this.setPageSize(); + if (this.paginateChildRows) { + this.calculatePagesAllRows(); + } + else { + this.calculatePagesMasterRowsOnly(); + } + } + else { + this.calculatedPagesNotActive(); + } + this.topRowBounds = this.rowModel.getRowBounds(this.topDisplayedRowIndex); + if (this.topRowBounds) { + this.topRowBounds.rowIndex = this.topDisplayedRowIndex; + } + this.bottomRowBounds = this.rowModel.getRowBounds(this.bottomDisplayedRowIndex); + if (this.bottomRowBounds) { + this.bottomRowBounds.rowIndex = this.bottomDisplayedRowIndex; + } + this.setPixelOffset(Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["exists"])(this.topRowBounds) ? this.topRowBounds.rowTop : 0); + }; + PaginationProxy.prototype.setPixelOffset = function (value) { + if (this.pixelOffset === value) { + return; + } + this.pixelOffset = value; + this.eventService.dispatchEvent({ type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_PAGINATION_PIXEL_OFFSET_CHANGED }); + }; + PaginationProxy.prototype.setZeroRows = function () { + this.masterRowCount = 0; + this.topDisplayedRowIndex = 0; + this.bottomDisplayedRowIndex = -1; + this.currentPage = 0; + this.totalPages = 0; + }; + PaginationProxy.prototype.calculatePagesMasterRowsOnly = function () { + // const csrm = this.rowModel; + // const rootNode = csrm.getRootNode(); + // const masterRows = rootNode.childrenAfterSort; + this.masterRowCount = this.rowModel.getTopLevelRowCount(); + // we say <=0 (rather than =0) as viewport returns -1 when no rows + if (this.masterRowCount <= 0) { + this.setZeroRows(); + return; + } + var masterLastRowIndex = this.masterRowCount - 1; + this.totalPages = Math.floor((masterLastRowIndex) / this.pageSize) + 1; + if (this.currentPage >= this.totalPages) { + this.currentPage = this.totalPages - 1; + } + if (!Object(_utils_number__WEBPACK_IMPORTED_MODULE_4__["isNumeric"])(this.currentPage) || this.currentPage < 0) { + this.currentPage = 0; + } + var masterPageStartIndex = this.pageSize * this.currentPage; + var masterPageEndIndex = (this.pageSize * (this.currentPage + 1)) - 1; + if (masterPageEndIndex > masterLastRowIndex) { + masterPageEndIndex = masterLastRowIndex; + } + this.topDisplayedRowIndex = this.rowModel.getTopLevelRowDisplayedIndex(masterPageStartIndex); + // masterRows[masterPageStartIndex].rowIndex; + if (masterPageEndIndex === masterLastRowIndex) { + // if showing the last master row, then we want to show the very last row of the model + this.bottomDisplayedRowIndex = this.rowModel.getRowCount() - 1; + } + else { + var firstIndexNotToShow = this.rowModel.getTopLevelRowDisplayedIndex(masterPageEndIndex + 1); + //masterRows[masterPageEndIndex + 1].rowIndex; + // this gets the index of the last child - eg current row is open, we want to display all children, + // the index of the last child is one less than the index of the next parent row. + this.bottomDisplayedRowIndex = firstIndexNotToShow - 1; + } + }; + PaginationProxy.prototype.getMasterRowCount = function () { + return this.masterRowCount; + }; + PaginationProxy.prototype.calculatePagesAllRows = function () { + this.masterRowCount = this.rowModel.getRowCount(); + if (this.masterRowCount === 0) { + this.setZeroRows(); + return; + } + var maxRowIndex = this.masterRowCount - 1; + this.totalPages = Math.floor((maxRowIndex) / this.pageSize) + 1; + if (this.currentPage >= this.totalPages) { + this.currentPage = this.totalPages - 1; + } + if (!Object(_utils_number__WEBPACK_IMPORTED_MODULE_4__["isNumeric"])(this.currentPage) || this.currentPage < 0) { + this.currentPage = 0; + } + this.topDisplayedRowIndex = this.pageSize * this.currentPage; + this.bottomDisplayedRowIndex = (this.pageSize * (this.currentPage + 1)) - 1; + if (this.bottomDisplayedRowIndex > maxRowIndex) { + this.bottomDisplayedRowIndex = maxRowIndex; + } + }; + PaginationProxy.prototype.calculatedPagesNotActive = function () { + this.pageSize = this.rowModel.getRowCount(); + this.totalPages = 1; + this.currentPage = 0; + this.topDisplayedRowIndex = 0; + this.bottomDisplayedRowIndex = this.rowModel.getRowCount() - 1; }; - var CellRendererFactory_1; - CellRendererFactory.ANIMATE_SLIDE = 'animateSlide'; - CellRendererFactory.ANIMATE_SHOW_CHANGE = 'animateShowChange'; - CellRendererFactory.GROUP = 'group'; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], CellRendererFactory.prototype, "gridOptionsWrapper", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('rowModel') + ], PaginationProxy.prototype, "rowModel", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('expressionService') - ], CellRendererFactory.prototype, "expressionService", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnApi') + ], PaginationProxy.prototype, "columnApi", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('eventService') - ], CellRendererFactory.prototype, "eventService", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridApi') + ], PaginationProxy.prototype, "gridApi", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], CellRendererFactory.prototype, "init", null); - CellRendererFactory = CellRendererFactory_1 = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('cellRendererFactory') - ], CellRendererFactory); - return CellRendererFactory; -}()); + _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] + ], PaginationProxy.prototype, "postConstruct", null); + PaginationProxy = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Bean"])('paginationProxy') + ], PaginationProxy); + return PaginationProxy; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 145 */ +/* 194 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ValueFormatterService", function() { return ValueFormatterService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PaginationAutoPageSizeService", function() { return PaginationAutoPageSizeService; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(23); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -35726,79 +42935,67 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta }; -var ValueFormatterService = /** @class */ (function (_super) { - __extends(ValueFormatterService, _super); - function ValueFormatterService() { + +var PaginationAutoPageSizeService = /** @class */ (function (_super) { + __extends(PaginationAutoPageSizeService, _super); + function PaginationAutoPageSizeService() { return _super !== null && _super.apply(this, arguments) || this; } - ValueFormatterService.prototype.formatValue = function (column, node, $scope, value, suppliedFormatter, useFormatterFromColumn) { - if (useFormatterFromColumn === void 0) { useFormatterFromColumn = true; } - var result = null; - var formatter; - var colDef = column.getColDef(); - if (suppliedFormatter) { - // use supplied formatter if provided, e.g. set filter items can have their own value formatters - formatter = suppliedFormatter; - } - else if (useFormatterFromColumn) { - // if row is pinned, give preference to the pinned formatter - formatter = node && node.rowPinned && colDef.pinnedRowValueFormatter ? - colDef.pinnedRowValueFormatter : colDef.valueFormatter; - } - if (formatter) { - var params = { - value: value, - node: node, - data: node ? node.data : null, - colDef: colDef, - column: column, - api: this.gridOptionsWrapper.getApi(), - columnApi: this.gridOptionsWrapper.getColumnApi(), - context: this.gridOptionsWrapper.getContext() - }; - // originally we put the angular 1 scope here, but we don't want the scope - // in the params interface, as other frameworks will see the interface, and - // angular 1 is not cool any more. so we hack the scope in here (we cannot - // include it above, as it's not in the interface, so would cause a compile error). - // in the future, when we stop supporting angular 1, we can take this out. - params.$scope = $scope; - result = this.expressionService.evaluate(formatter, params); - } - else if (colDef.refData) { - return colDef.refData[value] || ''; + PaginationAutoPageSizeService.prototype.postConstruct = function () { + var _this = this; + this.ctrlsService.whenReady(function (p) { + _this.centerRowContainerCon = p.centerRowContainerCtrl; + _this.addManagedListener(_this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_BODY_HEIGHT_CHANGED, _this.onBodyHeightChanged.bind(_this)); + _this.addManagedListener(_this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_SCROLL_VISIBILITY_CHANGED, _this.onScrollVisibilityChanged.bind(_this)); + _this.checkPageSize(); + }); + }; + PaginationAutoPageSizeService.prototype.notActive = function () { + return !this.gridOptionsWrapper.isPaginationAutoPageSize(); + }; + PaginationAutoPageSizeService.prototype.onScrollVisibilityChanged = function () { + this.checkPageSize(); + }; + PaginationAutoPageSizeService.prototype.onBodyHeightChanged = function () { + this.checkPageSize(); + }; + PaginationAutoPageSizeService.prototype.checkPageSize = function () { + if (this.notActive()) { + return; } - // if we don't do this, then arrays get displayed as 1,2,3, but we want 1, 2, 3 (i.e. with spaces) - if (result == null && Array.isArray(value)) { - result = value.join(', '); + var rowHeight = this.gridOptionsWrapper.getRowHeightAsNumber(); + var bodyHeight = this.centerRowContainerCon.getViewportSizeFeature().getBodyHeight(); + if (bodyHeight > 0) { + var newPageSize = Math.floor(bodyHeight / rowHeight); + this.gridOptionsWrapper.setProperty('paginationPageSize', newPageSize); } - return result; }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], ValueFormatterService.prototype, "gridOptionsWrapper", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('ctrlsService') + ], PaginationAutoPageSizeService.prototype, "ctrlsService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('expressionService') - ], ValueFormatterService.prototype, "expressionService", void 0); - ValueFormatterService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('valueFormatterService') - ], ValueFormatterService); - return ValueFormatterService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] + ], PaginationAutoPageSizeService.prototype, "postConstruct", null); + PaginationAutoPageSizeService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Bean"])('paginationAutoPageSizeService') + ], PaginationAutoPageSizeService); + return PaginationAutoPageSizeService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 146 */ +/* 195 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgRadioButton", function() { return AgRadioButton; }); -/* harmony import */ var _agCheckbox__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(70); -/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(44); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ValueCache", function() { return ValueCache; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -35815,91 +43012,169 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; -var AgRadioButton = /** @class */ (function (_super) { - __extends(AgRadioButton, _super); - function AgRadioButton() { +var ValueCache = /** @class */ (function (_super) { + __extends(ValueCache, _super); + function ValueCache() { var _this = _super !== null && _super.apply(this, arguments) || this; - _this.className = 'ag-radio-button'; - _this.inputType = 'radio'; + _this.cacheVersion = 0; return _this; } - AgRadioButton.prototype.isSelected = function () { - return this.eInput.checked; + ValueCache.prototype.init = function () { + this.active = this.gridOptionsWrapper.isValueCache(); + this.neverExpires = this.gridOptionsWrapper.isValueCacheNeverExpires(); }; - AgRadioButton.prototype.toggle = function () { - var nextValue = this.getNextValue(); - this.setValue(nextValue); + ValueCache.prototype.onDataChanged = function () { + if (this.neverExpires) { + return; + } + this.expire(); }; - AgRadioButton.prototype.addInputListeners = function () { - _super.prototype.addInputListeners.call(this); - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CHECKBOX_CHANGED, this.onChange.bind(this)); + ValueCache.prototype.expire = function () { + this.cacheVersion++; }; - /** - * This ensures that if another radio button in the same named group is selected, we deselect this radio button. - * By default the browser does this for you, but we are managing classes ourselves in order to ensure input - * elements are styled correctly in IE11, and the DOM 'changed' event is only fired when a button is selected, - * not deselected, so we need to use our own event. - */ - AgRadioButton.prototype.onChange = function (event) { - if (event.selected && - event.name && - this.eInput.name && - this.eInput.name === event.name && - event.id && - this.eInput.id !== event.id) { - this.setValue(false, true); + ValueCache.prototype.setValue = function (rowNode, colId, value) { + if (this.active) { + if (rowNode.__cacheVersion !== this.cacheVersion) { + rowNode.__cacheVersion = this.cacheVersion; + rowNode.__cacheData = {}; + } + rowNode.__cacheData[colId] = value; } }; - return AgRadioButton; -}(_agCheckbox__WEBPACK_IMPORTED_MODULE_0__["AgCheckbox"])); + ValueCache.prototype.getValue = function (rowNode, colId) { + if (!this.active || rowNode.__cacheVersion !== this.cacheVersion) { + return undefined; + } + return rowNode.__cacheData[colId]; + }; + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], ValueCache.prototype, "init", null); + ValueCache = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('valueCache') + ], ValueCache); + return ValueCache; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 147 */ +/* 196 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "VanillaFrameworkOverrides", function() { return VanillaFrameworkOverrides; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ChangeDetectionService", function() { return ChangeDetectionService; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _utils_changedPath__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(110); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(15); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(23); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -/** The base frameworks, eg React & Angular 2, override this bean with implementations specific to their requirement. */ -var VanillaFrameworkOverrides = /** @class */ (function () { - function VanillaFrameworkOverrides() { +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + + +var ChangeDetectionService = /** @class */ (function (_super) { + __extends(ChangeDetectionService, _super); + function ChangeDetectionService() { + return _super !== null && _super.apply(this, arguments) || this; } - // for Vanilla JS, we use simple timeout - VanillaFrameworkOverrides.prototype.setTimeout = function (action, timeout) { - window.setTimeout(action, timeout); + ChangeDetectionService.prototype.init = function () { + if (this.rowModel.getType() === _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) { + this.clientSideRowModel = this.rowModel; + } + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_CELL_VALUE_CHANGED, this.onCellValueChanged.bind(this)); }; - // for Vanilla JS, we just add the event to the element - VanillaFrameworkOverrides.prototype.addEventListenerOutsideAngular = function (element, type, listener, useCapture) { - element.addEventListener(type, listener, useCapture); + ChangeDetectionService.prototype.onCellValueChanged = function (event) { + // Clipboard service manages its own change detection, so no need to do it here. + // The clipboard manages its own as otherwise this would happen once for every cell + // that got updated as part of a paste operation, so e.g. if 100 cells in a paste operation, + // this doChangeDetection would get called 100 times (once for each cell), instead clipboard + // service executes the logic we have here once (in essence batching up all cell changes + // into one change detection). + if (event.source === _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].SOURCE_PASTE) { + return; + } + this.doChangeDetection(event.node, event.column); }; - return VanillaFrameworkOverrides; -}()); + ChangeDetectionService.prototype.doChangeDetection = function (rowNode, column) { + if (this.gridOptionsWrapper.isSuppressChangeDetection()) { + return; + } + // step 1 of change detection is to update the aggregated values + if (this.clientSideRowModel && !rowNode.isRowPinned()) { + var onlyChangedColumns = this.gridOptionsWrapper.isAggregateOnlyChangedColumns(); + var changedPath = new _utils_changedPath__WEBPACK_IMPORTED_MODULE_2__["ChangedPath"](onlyChangedColumns, this.clientSideRowModel.getRootNode()); + changedPath.addParentNode(rowNode.parent, [column]); + this.clientSideRowModel.doAggregate(changedPath); + } + // step 2 of change detection is to refresh the cells + this.rowRenderer.refreshCells(); + }; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowModel') + ], ChangeDetectionService.prototype, "rowModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowRenderer') + ], ChangeDetectionService.prototype, "rowRenderer", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], ChangeDetectionService.prototype, "init", null); + ChangeDetectionService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('changeDetectionService') + ], ChangeDetectionService); + return ChangeDetectionService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 148 */ +/* 197 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ScrollVisibleService", function() { return ScrollVisibleService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AlignedGridsService", function() { return AlignedGridsService; }); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(23); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(20); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -35922,68 +43197,247 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; +var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { + return function (target, key) { decorator(target, key, paramIndex); } +}; -var ScrollVisibleService = /** @class */ (function (_super) { - __extends(ScrollVisibleService, _super); - function ScrollVisibleService() { - return _super !== null && _super.apply(this, arguments) || this; + + + +var AlignedGridsService = /** @class */ (function (_super) { + __extends(AlignedGridsService, _super); + function AlignedGridsService() { + var _this = _super !== null && _super.apply(this, arguments) || this; + // flag to mark if we are consuming. to avoid cyclic events (ie other grid firing back to master + // while processing a master event) we mark this if consuming an event, and if we are, then + // we don't fire back any events. + _this.consuming = false; + return _this; } - ScrollVisibleService.prototype.setScrollsVisible = function (params) { - var atLeastOneDifferent = this.horizontalScrollShowing !== params.horizontalScrollShowing || - this.verticalScrollShowing !== params.verticalScrollShowing; - if (atLeastOneDifferent) { - this.horizontalScrollShowing = params.horizontalScrollShowing; - this.verticalScrollShowing = params.verticalScrollShowing; - var event_1 = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_SCROLL_VISIBILITY_CHANGED, - api: this.gridApi, - columnApi: this.columnApi - }; - this.eventService.dispatchEvent(event_1); + AlignedGridsService.prototype.setBeans = function (loggerFactory) { + this.logger = loggerFactory.create('AlignedGridsService'); + }; + AlignedGridsService.prototype.init = function () { + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_MOVED, this.fireColumnEvent.bind(this)); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_VISIBLE, this.fireColumnEvent.bind(this)); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PINNED, this.fireColumnEvent.bind(this)); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_GROUP_OPENED, this.fireColumnEvent.bind(this)); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_RESIZED, this.fireColumnEvent.bind(this)); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_BODY_SCROLL, this.fireScrollEvent.bind(this)); + }; + // common logic across all the fire methods + AlignedGridsService.prototype.fireEvent = function (callback) { + // if we are already consuming, then we are acting on an event from a master, + // so we don't cause a cyclic firing of events + if (this.consuming) { + return; + } + // iterate through the aligned grids, and pass each aligned grid service to the callback + var otherGrids = this.gridOptionsWrapper.getAlignedGrids(); + if (otherGrids) { + otherGrids.forEach(function (otherGridOptions) { + if (otherGridOptions.api) { + var alignedGridService = otherGridOptions.api.__getAlignedGridService(); + callback(alignedGridService); + } + }); } }; - // used by pagination service - to know page height - ScrollVisibleService.prototype.isHorizontalScrollShowing = function () { - return this.horizontalScrollShowing; + // common logic across all consume methods. very little common logic, however extracting + // guarantees consistency across the methods. + AlignedGridsService.prototype.onEvent = function (callback) { + this.consuming = true; + callback(); + this.consuming = false; }; - // used by header container - ScrollVisibleService.prototype.isVerticalScrollShowing = function () { - return this.verticalScrollShowing; + AlignedGridsService.prototype.fireColumnEvent = function (event) { + this.fireEvent(function (alignedGridsService) { + alignedGridsService.onColumnEvent(event); + }); + }; + AlignedGridsService.prototype.fireScrollEvent = function (event) { + if (event.direction !== 'horizontal') { + return; + } + this.fireEvent(function (alignedGridsService) { + alignedGridsService.onScrollEvent(event); + }); + }; + AlignedGridsService.prototype.onScrollEvent = function (event) { + var _this = this; + this.onEvent(function () { + var gridBodyCon = _this.ctrlsService.getGridBodyCtrl(); + gridBodyCon.getScrollFeature().setHorizontalScrollPosition(event.left); + }); + }; + AlignedGridsService.prototype.getMasterColumns = function (event) { + var result = []; + if (event.columns) { + event.columns.forEach(function (column) { + result.push(column); + }); + } + else if (event.column) { + result.push(event.column); + } + return result; + }; + AlignedGridsService.prototype.getColumnIds = function (event) { + var result = []; + if (event.columns) { + event.columns.forEach(function (column) { + result.push(column.getColId()); + }); + } + else if (event.column) { + result.push(event.column.getColId()); + } + return result; + }; + AlignedGridsService.prototype.onColumnEvent = function (event) { + var _this = this; + this.onEvent(function () { + switch (event.type) { + case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_MOVED: + case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_VISIBLE: + case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PINNED: + case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_RESIZED: + var colEvent = event; + _this.processColumnEvent(colEvent); + break; + case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_GROUP_OPENED: + var groupOpenedEvent = event; + _this.processGroupOpenedEvent(groupOpenedEvent); + break; + case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PIVOT_CHANGED: + // we cannot support pivoting with aligned grids as the columns will be out of sync as the + // grids will have columns created based on the row data of the grid. + console.warn('AG Grid: pivoting is not supported with aligned grids. ' + + 'You can only use one of these features at a time in a grid.'); + break; + } + }); + }; + AlignedGridsService.prototype.processGroupOpenedEvent = function (groupOpenedEvent) { + // likewise for column group + var masterColumnGroup = groupOpenedEvent.columnGroup; + var otherColumnGroup = null; + if (masterColumnGroup) { + var groupId = masterColumnGroup.getGroupId(); + otherColumnGroup = this.columnModel.getProvidedColumnGroup(groupId); + } + if (masterColumnGroup && !otherColumnGroup) { + return; + } + this.logger.log('onColumnEvent-> processing ' + groupOpenedEvent + ' expanded = ' + masterColumnGroup.isExpanded()); + this.columnModel.setColumnGroupOpened(otherColumnGroup, masterColumnGroup.isExpanded(), "alignedGridChanged"); + }; + AlignedGridsService.prototype.processColumnEvent = function (colEvent) { + var _this = this; + // the column in the event is from the master grid. need to + // look up the equivalent from this (other) grid + var masterColumn = colEvent.column; + var otherColumn = null; + if (masterColumn) { + otherColumn = this.columnModel.getPrimaryColumn(masterColumn.getColId()); + } + // if event was with respect to a master column, that is not present in this + // grid, then we ignore the event + if (masterColumn && !otherColumn) { + return; + } + // in time, all the methods below should use the column ids, it's a more generic way + // of handling columns, and also allows for single or multi column events + var masterColumns = this.getMasterColumns(colEvent); + switch (colEvent.type) { + case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_MOVED: + // when the user moves columns via setColumnState, we can't depend on moving specific columns + // to an index, as there maybe be many indexes columns moved to (as wasn't result of a mouse drag). + // so only way to be sure is match the order of all columns using Column State. + { + var movedEvent = colEvent; + var srcColState = colEvent.columnApi.getColumnState(); + var destColState = srcColState.map(function (s) { return ({ colId: s.colId }); }); + this.columnModel.applyColumnState({ state: destColState, applyOrder: true }, "alignedGridChanged"); + this.logger.log("onColumnEvent-> processing " + colEvent.type + " toIndex = " + movedEvent.toIndex); + } + break; + case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_VISIBLE: + // when the user changes visibility via setColumnState, we can't depend on visibility flag in event + // as there maybe be mix of true/false (as wasn't result of a mouse click to set visiblity). + // so only way to be sure is match the visibility of all columns using Column State. + { + var visibleEvent = colEvent; + var srcColState = colEvent.columnApi.getColumnState(); + var destColState = srcColState.map(function (s) { return ({ colId: s.colId, hide: s.hide }); }); + this.columnModel.applyColumnState({ state: destColState }, "alignedGridChanged"); + this.logger.log("onColumnEvent-> processing " + colEvent.type + " visible = " + visibleEvent.visible); + } + break; + case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PINNED: + { + var pinnedEvent = colEvent; + var srcColState = colEvent.columnApi.getColumnState(); + var destColState = srcColState.map(function (s) { return ({ colId: s.colId, pinned: s.pinned }); }); + this.columnModel.applyColumnState({ state: destColState }, "alignedGridChanged"); + this.logger.log("onColumnEvent-> processing " + colEvent.type + " pinned = " + pinnedEvent.pinned); + } + break; + case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_RESIZED: + var resizedEvent_1 = colEvent; + masterColumns.forEach(function (column) { + _this.logger.log("onColumnEvent-> processing " + colEvent.type + " actualWidth = " + column.getActualWidth()); + var columnWidths = [{ key: column.getColId(), newWidth: column.getActualWidth() }]; + _this.columnModel.setColumnWidths(columnWidths, false, resizedEvent_1.finished, "alignedGridChanged"); + }); + break; + } + var gridBodyCon = this.ctrlsService.getGridBodyCtrl(); + var isVerticalScrollShowing = gridBodyCon.isVerticalScrollShowing(); + var alignedGrids = this.gridOptionsWrapper.getAlignedGrids(); + if (alignedGrids) { + alignedGrids.forEach(function (grid) { + if (grid.api) { + grid.api.setAlwaysShowVerticalScroll(isVerticalScrollShowing); + } + }); + } }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], ScrollVisibleService.prototype, "columnController", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnModel') + ], AlignedGridsService.prototype, "columnModel", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') - ], ScrollVisibleService.prototype, "columnApi", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('ctrlsService') + ], AlignedGridsService.prototype, "ctrlsService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') - ], ScrollVisibleService.prototype, "gridApi", void 0); + __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Qualifier"])('loggerFactory')) + ], AlignedGridsService.prototype, "setBeans", null); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], ScrollVisibleService.prototype, "gridOptionsWrapper", void 0); - ScrollVisibleService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('scrollVisibleService') - ], ScrollVisibleService); - return ScrollVisibleService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], AlignedGridsService.prototype, "init", null); + AlignedGridsService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('alignedGridsService') + ], AlignedGridsService); + return AlignedGridsService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"])); /***/ }), -/* 149 */ +/* 198 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "StylingService", function() { return StylingService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgComponentUtils", function() { return AgComponentUtils; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(42); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -36008,82 +43462,75 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta }; -var StylingService = /** @class */ (function (_super) { - __extends(StylingService, _super); - function StylingService() { + +var AgComponentUtils = /** @class */ (function (_super) { + __extends(AgComponentUtils, _super); + function AgComponentUtils() { return _super !== null && _super.apply(this, arguments) || this; } - StylingService.prototype.processAllCellClasses = function (colDef, params, onApplicableClass, onNotApplicableClass) { - this.processClassRules(colDef.cellClassRules, params, onApplicableClass, onNotApplicableClass); - this.processStaticCellClasses(colDef, params, onApplicableClass); + AgComponentUtils.prototype.adaptFunction = function (propertyName, jsCompFunc) { + var metadata = this.componentMetadataProvider.retrieve(propertyName); + if (metadata && metadata.functionAdapter) { + return metadata.functionAdapter(jsCompFunc); + } + return null; }; - StylingService.prototype.processClassRules = function (classRules, params, onApplicableClass, onNotApplicableClass) { - if (typeof classRules === 'object' && classRules !== null) { - var classNames = Object.keys(classRules); - for (var i = 0; i < classNames.length; i++) { - var className = classNames[i]; - var rule = classRules[className]; - var resultOfRule = void 0; - if (typeof rule === 'string') { - resultOfRule = this.expressionService.evaluate(rule, params); - } - else if (typeof rule === 'function') { - resultOfRule = rule(params); - } - if (resultOfRule) { - onApplicableClass(className); + AgComponentUtils.prototype.adaptCellRendererFunction = function (callback) { + var Adapter = /** @class */ (function () { + function Adapter() { + } + Adapter.prototype.refresh = function (params) { + return false; + }; + Adapter.prototype.getGui = function () { + return this.eGui; + }; + Adapter.prototype.init = function (params) { + var callbackResult = callback(params); + var type = typeof callbackResult; + if (type === 'string' || type === 'number' || type === 'boolean') { + this.eGui = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["loadTemplate"])('' + callbackResult + ''); + return; } - else if (onNotApplicableClass) { - onNotApplicableClass(className); + if (callbackResult == null) { + this.eGui = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["loadTemplate"])(''); + return; } - } - } + this.eGui = callbackResult; + }; + return Adapter; + }()); + return Adapter; }; - StylingService.prototype.processStaticCellClasses = function (colDef, params, onApplicableClass) { - var cellClass = colDef.cellClass; - if (cellClass) { - var classOrClasses = void 0; - if (typeof colDef.cellClass === 'function') { - var cellClassFunc = colDef.cellClass; - classOrClasses = cellClassFunc(params); - } - else { - classOrClasses = colDef.cellClass; - } - if (typeof classOrClasses === 'string') { - onApplicableClass(classOrClasses); - } - else if (Array.isArray(classOrClasses)) { - classOrClasses.forEach(function (cssClassItem) { - onApplicableClass(cssClassItem); - }); - } + AgComponentUtils.prototype.doesImplementIComponent = function (candidate) { + if (!candidate) { + return false; } + return candidate.prototype && 'getGui' in candidate.prototype; }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('expressionService') - ], StylingService.prototype, "expressionService", void 0); - StylingService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('stylingService') - ], StylingService); - return StylingService; + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("componentMetadataProvider") + ], AgComponentUtils.prototype, "componentMetadataProvider", void 0); + AgComponentUtils = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])("agComponentUtils") + ], AgComponentUtils); + return AgComponentUtils; }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 150 */ +/* 199 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnHoverService", function() { return ColumnHoverService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ComponentMetadataProvider", function() { return ComponentMetadataProvider; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -36108,59 +43555,131 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta }; - -var ColumnHoverService = /** @class */ (function (_super) { - __extends(ColumnHoverService, _super); - function ColumnHoverService() { +var ComponentMetadataProvider = /** @class */ (function (_super) { + __extends(ComponentMetadataProvider, _super); + function ComponentMetadataProvider() { return _super !== null && _super.apply(this, arguments) || this; } - ColumnHoverService.prototype.setMouseOver = function (columns) { - this.selectedColumns = columns; - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_HOVER_CHANGED, - api: this.gridApi, - columnApi: this.columnApi - }; - this.eventService.dispatchEvent(event); - }; - ColumnHoverService.prototype.clearMouseOver = function () { - this.selectedColumns = null; - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_HOVER_CHANGED, - api: this.gridApi, - columnApi: this.columnApi + ComponentMetadataProvider.prototype.postConstruct = function () { + this.componentMetaData = { + dateComponent: { + mandatoryMethodList: ['getDate', 'setDate'], + optionalMethodList: ['afterGuiAttached', 'setInputPlaceholder', 'setInputAriaLabel'] + }, + detailCellRenderer: { + mandatoryMethodList: [], + optionalMethodList: ['refresh'], + functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils) + }, + headerComponent: { + mandatoryMethodList: [], + optionalMethodList: ['refresh'] + }, + headerGroupComponent: { + mandatoryMethodList: [], + optionalMethodList: [] + }, + loadingCellRenderer: { + mandatoryMethodList: [], + optionalMethodList: [] + }, + loadingOverlayComponent: { + mandatoryMethodList: [], + optionalMethodList: [] + }, + noRowsOverlayComponent: { + mandatoryMethodList: [], + optionalMethodList: [] + }, + floatingFilterComponent: { + mandatoryMethodList: ['onParentModelChanged'], + optionalMethodList: ['afterGuiAttached'] + }, + floatingFilterWrapperComponent: { + mandatoryMethodList: [], + optionalMethodList: [] + }, + cellRenderer: { + mandatoryMethodList: [], + optionalMethodList: ['refresh', 'afterGuiAttached'], + functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils) + }, + cellEditor: { + mandatoryMethodList: ['getValue'], + optionalMethodList: ['isPopup', 'isCancelBeforeStart', 'isCancelAfterEnd', 'getPopupPosition', 'focusIn', 'focusOut', 'afterGuiAttached'] + }, + innerRenderer: { + mandatoryMethodList: [], + optionalMethodList: ['afterGuiAttached'], + functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils) + }, + fullWidthCellRenderer: { + mandatoryMethodList: [], + optionalMethodList: ['refresh', 'afterGuiAttached'], + functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils) + }, + pinnedRowCellRenderer: { + mandatoryMethodList: [], + optionalMethodList: ['refresh', 'afterGuiAttached'], + functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils) + }, + groupRowRenderer: { + mandatoryMethodList: [], + optionalMethodList: ['afterGuiAttached'], + functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils) + }, + filter: { + mandatoryMethodList: ['isFilterActive', 'doesFilterPass', 'getModel', 'setModel'], + optionalMethodList: ['afterGuiAttached', 'onNewRowsLoaded', 'getModelAsString', 'onFloatingFilterChanged'] + }, + filterComponent: { + mandatoryMethodList: ['isFilterActive', 'doesFilterPass', 'getModel', 'setModel'], + optionalMethodList: ['afterGuiAttached', 'onNewRowsLoaded', 'getModelAsString', 'onFloatingFilterChanged'] + }, + statusPanel: { + mandatoryMethodList: [], + optionalMethodList: ['afterGuiAttached'], + }, + toolPanel: { + mandatoryMethodList: [], + optionalMethodList: ['refresh', 'afterGuiAttached'] + }, + tooltipComponent: { + mandatoryMethodList: [], + optionalMethodList: [] + } }; - this.eventService.dispatchEvent(event); }; - ColumnHoverService.prototype.isHovered = function (column) { - return this.selectedColumns && this.selectedColumns.indexOf(column) >= 0; + ComponentMetadataProvider.prototype.retrieve = function (name) { + return this.componentMetaData[name]; }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') - ], ColumnHoverService.prototype, "columnApi", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("agComponentUtils") + ], ComponentMetadataProvider.prototype, "agComponentUtils", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') - ], ColumnHoverService.prototype, "gridApi", void 0); - ColumnHoverService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('columnHoverService') - ], ColumnHoverService); - return ColumnHoverService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"])); + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], ComponentMetadataProvider.prototype, "postConstruct", null); + ComponentMetadataProvider = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])("componentMetadataProvider") + ], ComponentMetadataProvider); + return ComponentMetadataProvider; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 151 */ +/* 200 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnAnimationService", function() { return ColumnAnimationService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Environment", function() { return Environment; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(14); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -36185,112 +43704,153 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta }; -var ColumnAnimationService = /** @class */ (function (_super) { - __extends(ColumnAnimationService, _super); - function ColumnAnimationService() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.executeNextFuncs = []; - _this.executeLaterFuncs = []; - _this.active = false; - _this.animationThreadCount = 0; - return _this; + +var MAT_GRID_SIZE = 8; +var BASE_GRID_SIZE = 4; +var BALHAM_GRID_SIZE = 4; +var ALPINE_GRID_SIZE = 6; +var HARD_CODED_SIZES = { + // this item is required for custom themes + 'ag-theme-custom': { + headerHeight: 25, + headerCellMinWidth: 24, + listItemHeight: BASE_GRID_SIZE * 5, + rowHeight: 25, + chartMenuPanelWidth: 220 + }, + 'ag-theme-material': { + headerHeight: MAT_GRID_SIZE * 7, + headerCellMinWidth: 48, + listItemHeight: MAT_GRID_SIZE * 4, + rowHeight: MAT_GRID_SIZE * 6, + chartMenuPanelWidth: 240 + }, + 'ag-theme-balham': { + headerHeight: BALHAM_GRID_SIZE * 8, + headerCellMinWidth: 24, + listItemHeight: BALHAM_GRID_SIZE * 6, + rowHeight: BALHAM_GRID_SIZE * 7, + chartMenuPanelWidth: 220 + }, + 'ag-theme-alpine': { + headerHeight: ALPINE_GRID_SIZE * 8, + headerCellMinWidth: 36, + listItemHeight: ALPINE_GRID_SIZE * 4, + rowHeight: ALPINE_GRID_SIZE * 7, + chartMenuPanelWidth: 240 } - ColumnAnimationService.prototype.registerGridComp = function (gridPanel) { - this.gridPanel = gridPanel; - }; - ColumnAnimationService.prototype.isActive = function () { - return this.active; - }; - ColumnAnimationService.prototype.start = function () { - if (this.active) { - return; +}; +/** + * this object contains a list of Sass variables and an array + * of CSS styles required to get the correct value. + * eg. $virtual-item-height requires a structure, so we can get its height. + *
+ *
+ *
+ *
+ *
+ */ +var SASS_PROPERTY_BUILDER = { + headerHeight: ['ag-header-row'], + headerCellMinWidth: ['ag-header-cell'], + listItemHeight: ['ag-virtual-list-item'], + rowHeight: ['ag-row'], + chartMenuPanelWidth: ['ag-chart-docked-container'] +}; +var CALCULATED_SIZES = {}; +var Environment = /** @class */ (function (_super) { + __extends(Environment, _super); + function Environment() { + return _super !== null && _super.apply(this, arguments) || this; + } + Environment.prototype.getSassVariable = function (theme, key) { + var useTheme = 'ag-theme-' + (theme.match('material') ? 'material' : theme.match('balham') ? 'balham' : theme.match('alpine') ? 'alpine' : 'custom'); + var defaultValue = HARD_CODED_SIZES[useTheme][key]; + var calculatedValue = 0; + if (!CALCULATED_SIZES[theme]) { + CALCULATED_SIZES[theme] = {}; } - if (this.gridOptionsWrapper.isSuppressColumnMoveAnimation()) { - return; + var size = CALCULATED_SIZES[theme][key]; + if (size != null) { + return size; } - // if doing RTL, we don't animate open / close as due to how the pixels are inverted, - // the animation moves all the row the the right rather than to the left (ie it's the static - // columns that actually get their coordinates updated) - if (this.gridOptionsWrapper.isEnableRtl()) { - return; + if (SASS_PROPERTY_BUILDER[key]) { + var classList = SASS_PROPERTY_BUILDER[key]; + var div = document.createElement('div'); + div.classList.add(theme); + div.style.position = 'absolute'; + var el = classList.reduce(function (prevEl, currentClass) { + var currentDiv = document.createElement('div'); + currentDiv.style.position = 'static'; + currentDiv.classList.add(currentClass); + prevEl.appendChild(currentDiv); + return currentDiv; + }, div); + if (document.body) { + document.body.appendChild(div); + var sizeName = key.toLowerCase().indexOf('height') !== -1 ? 'height' : 'width'; + calculatedValue = parseInt(window.getComputedStyle(el)[sizeName], 10); + document.body.removeChild(div); + } } - this.ensureAnimationCssClassPresent(); - this.active = true; + CALCULATED_SIZES[theme][key] = calculatedValue || defaultValue; + return CALCULATED_SIZES[theme][key]; }; - ColumnAnimationService.prototype.finish = function () { - if (!this.active) { - return; - } - this.flush(); - this.active = false; + Environment.prototype.isThemeDark = function () { + var theme = this.getTheme().theme; + return !!theme && theme.indexOf('dark') >= 0; }; - ColumnAnimationService.prototype.executeNextVMTurn = function (func) { - if (this.active) { - this.executeNextFuncs.push(func); - } - else { - func(); - } + Environment.prototype.chartMenuPanelWidth = function () { + var theme = this.getTheme().themeFamily; + return this.getSassVariable(theme, 'chartMenuPanelWidth'); }; - ColumnAnimationService.prototype.executeLaterVMTurn = function (func) { - if (this.active) { - this.executeLaterFuncs.push(func); + Environment.prototype.getTheme = function () { + var reg = /\bag-(material|(?:theme-([\w\-]*)))\b/; + var el = this.eGridDiv; + var themeMatch = null; + while (el) { + themeMatch = reg.exec(el.className); + if (!themeMatch) { + el = el.parentElement || undefined; + } + else { + break; + } } - else { - func(); + if (!themeMatch) { + return {}; } - }; - ColumnAnimationService.prototype.ensureAnimationCssClassPresent = function () { - var _this = this; - // up the count, so we can tell if someone else has updated the count - // by the time the 'wait' func executes - this.animationThreadCount++; - var animationThreadCountCopy = this.animationThreadCount; - this.gridPanel.setColumnMovingCss(true); - this.executeLaterFuncs.push(function () { - // only remove the class if this thread was the last one to update it - if (_this.animationThreadCount === animationThreadCountCopy) { - _this.gridPanel.setColumnMovingCss(false); - } - }); - }; - ColumnAnimationService.prototype.flush = function () { - var nowFuncs = this.executeNextFuncs; - this.executeNextFuncs = []; - var waitFuncs = this.executeLaterFuncs; - this.executeLaterFuncs = []; - if (nowFuncs.length === 0 && waitFuncs.length === 0) { - return; + var theme = themeMatch[0]; + var usingOldTheme = themeMatch[2] === undefined; + if (usingOldTheme) { + var newTheme_1 = theme.replace('ag-', 'ag-theme-'); + Object(_utils_function__WEBPACK_IMPORTED_MODULE_2__["doOnce"])(function () { return console.warn("AG Grid: As of v19 old theme are no longer provided. Please replace " + theme + " with " + newTheme_1 + "."); }, 'using-old-theme'); } - window.setTimeout(function () { return nowFuncs.forEach(function (func) { return func(); }); }, 0); - window.setTimeout(function () { return waitFuncs.forEach(function (func) { return func(); }); }, 300); + return { theme: theme, el: el, themeFamily: theme.replace(/-dark$/, '') }; }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], ColumnAnimationService.prototype, "gridOptionsWrapper", void 0); - ColumnAnimationService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('columnAnimationService') - ], ColumnAnimationService); - return ColumnAnimationService; + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('eGridDiv') + ], Environment.prototype, "eGridDiv", void 0); + Environment = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('environment') + ], Environment); + return Environment; }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 152 */ +/* 201 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AutoGroupColService", function() { return AutoGroupColService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(35); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AnimationFrameService", function() { return AnimationFrameService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -36315,137 +43875,211 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta }; - - - -var AutoGroupColService = /** @class */ (function (_super) { - __extends(AutoGroupColService, _super); - function AutoGroupColService() { - return _super !== null && _super.apply(this, arguments) || this; +var AnimationFrameService = /** @class */ (function (_super) { + __extends(AnimationFrameService, _super); + function AnimationFrameService() { + var _this = _super !== null && _super.apply(this, arguments) || this; + // p1 and p2 are create tasks are to do with row and cell creation. + // for them we want to execute according to row order, so we use + // TaskItem so we know what index the item is for. + _this.createTasksP1 = { list: [], sorted: false }; // eg drawing back-ground of rows + _this.createTasksP2 = { list: [], sorted: false }; // eg cell renderers, adding hover functionality + // destroy tasks are to do with row removal. they are done after row creation as the user will need to see new + // rows first (as blank is scrolled into view), when we remove the old rows (no longer in view) is not as + // important. + _this.destroyTasks = []; + _this.ticking = false; + // we need to know direction of scroll, to build up rows in the direction of + // the scroll. eg if user scrolls down, we extend the rows by building down. + _this.scrollGoingDown = true; + _this.lastScrollTop = 0; + _this.taskCount = 0; + _this.cancelledTasks = new Set(); + return _this; } - AutoGroupColService_1 = AutoGroupColService; - AutoGroupColService.prototype.createAutoGroupColumns = function (rowGroupColumns) { - var _this = this; - var groupAutoColumns = []; - var doingTreeData = this.gridOptionsWrapper.isTreeData(); - var doingMultiAutoColumn = this.gridOptionsWrapper.isGroupMultiAutoColumn(); - if (doingTreeData && doingMultiAutoColumn) { - console.warn('ag-Grid: you cannot mix groupMultiAutoColumn with treeData, only one column can be used to display groups when doing tree data'); - doingMultiAutoColumn = false; - } - // if doing groupMultiAutoColumn, then we call the method multiple times, once - // for each column we are grouping by - if (doingMultiAutoColumn) { - rowGroupColumns.forEach(function (rowGroupCol, index) { - groupAutoColumns.push(_this.createOneAutoGroupColumn(rowGroupCol, index)); - }); + AnimationFrameService.prototype.setScrollTop = function (scrollTop) { + this.scrollGoingDown = scrollTop > this.lastScrollTop; + this.lastScrollTop = scrollTop; + }; + AnimationFrameService.prototype.init = function () { + this.useAnimationFrame = !this.gridOptionsWrapper.isSuppressAnimationFrame(); + }; + AnimationFrameService.prototype.isOn = function () { + return this.useAnimationFrame; + }; + // this method is for our AG Grid sanity only - if animation frames are turned off, + // then no place in the code should be looking to add any work to be done in animation + // frames. this stops bugs - where some code is asking for a frame to be executed + // when it should not. + AnimationFrameService.prototype.verifyAnimationFrameOn = function (methodName) { + if (this.useAnimationFrame === false) { + console.warn("AG Grid: AnimationFrameService." + methodName + " called but animation frames are off"); } - else { - groupAutoColumns.push(this.createOneAutoGroupColumn()); + }; + AnimationFrameService.prototype.createTask = function (task, index, list) { + this.verifyAnimationFrameOn(list); + var taskItem = { task: task, index: index, createOrder: ++this.taskCount }; + this.addTaskToList(this[list], taskItem); + this.schedule(); + }; + AnimationFrameService.prototype.cancelTask = function (task) { + this.cancelledTasks.add(task); + }; + AnimationFrameService.prototype.addTaskToList = function (taskList, task) { + taskList.list.push(task); + taskList.sorted = false; + }; + AnimationFrameService.prototype.sortTaskList = function (taskList) { + if (taskList.sorted) { + return; } - return groupAutoColumns; + var sortDirection = this.scrollGoingDown ? 1 : -1; + // sort first by row index (taking into account scroll direction), then by + // order of task creation (always ascending, so cells will render left-to-right) + taskList.list.sort(function (a, b) { return a.index !== b.index ? sortDirection * (b.index - a.index) : b.createOrder - a.createOrder; }); + taskList.sorted = true; }; - // rowGroupCol and index are missing if groupMultiAutoColumn=false - AutoGroupColService.prototype.createOneAutoGroupColumn = function (rowGroupCol, index) { - // if one provided by user, use it, otherwise create one - var defaultAutoColDef = this.generateDefaultColDef(rowGroupCol); - // if doing multi, set the field - var colId; - if (rowGroupCol) { - colId = _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].GROUP_AUTO_COLUMN_ID + "-" + rowGroupCol.getId(); + AnimationFrameService.prototype.addDestroyTask = function (task) { + this.verifyAnimationFrameOn('createTasksP3'); + this.destroyTasks.push(task); + this.schedule(); + }; + AnimationFrameService.prototype.executeFrame = function (millis) { + this.verifyAnimationFrameOn('executeFrame'); + var p1TaskList = this.createTasksP1; + var p1Tasks = p1TaskList.list; + var p2TaskList = this.createTasksP2; + var p2Tasks = p2TaskList.list; + var destroyTasks = this.destroyTasks; + var frameStart = new Date().getTime(); + var duration = (new Date().getTime()) - frameStart; + // 16ms is 60 fps + var noMaxMillis = millis <= 0; + var gridBodyCon = this.ctrlsService.getGridBodyCtrl(); + while (noMaxMillis || duration < millis) { + var gridBodyDidSomething = gridBodyCon.getScrollFeature().executeAnimationFrameScroll(); + if (!gridBodyDidSomething) { + var task = void 0; + if (p1Tasks.length) { + this.sortTaskList(p1TaskList); + task = p1Tasks.pop().task; + } + else if (p2Tasks.length) { + this.sortTaskList(p2TaskList); + task = p2Tasks.pop().task; + } + else if (destroyTasks.length) { + task = destroyTasks.pop(); + } + else { + this.cancelledTasks.clear(); + break; + } + if (!this.cancelledTasks.has(task)) { + task(); + } + } + duration = (new Date().getTime()) - frameStart; + } + if (p1Tasks.length || p2Tasks.length || destroyTasks.length) { + this.requestFrame(); } else { - colId = AutoGroupColService_1.GROUP_AUTO_COLUMN_BUNDLE_ID; + this.stopTicking(); } - var userAutoColDef = this.gridOptionsWrapper.getAutoGroupColumnDef(); - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].mergeDeep(defaultAutoColDef, userAutoColDef); - defaultAutoColDef = this.columnFactory.mergeColDefs(defaultAutoColDef); - defaultAutoColDef.colId = colId; - // For tree data the filter is always allowed - if (!this.gridOptionsWrapper.isTreeData()) { - // we would only allow filter if the user has provided field or value getter. otherwise the filter - // would not be able to work. - var noFieldOrValueGetter = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].missing(defaultAutoColDef.field) && _utils__WEBPACK_IMPORTED_MODULE_4__["_"].missing(defaultAutoColDef.valueGetter) && _utils__WEBPACK_IMPORTED_MODULE_4__["_"].missing(defaultAutoColDef.filterValueGetter); - if (noFieldOrValueGetter) { - defaultAutoColDef.filter = false; - } + }; + AnimationFrameService.prototype.stopTicking = function () { + this.ticking = false; + }; + AnimationFrameService.prototype.flushAllFrames = function () { + if (!this.useAnimationFrame) { + return; } - // if showing many cols, we don't want to show more than one with a checkbox for selection - if (index && index > 0) { - defaultAutoColDef.headerCheckboxSelection = false; + this.executeFrame(-1); + }; + AnimationFrameService.prototype.schedule = function () { + if (!this.useAnimationFrame) { + return; + } + if (!this.ticking) { + this.ticking = true; + this.requestFrame(); } - var newCol = new _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"](defaultAutoColDef, null, colId, true); - this.context.createBean(newCol); - return newCol; }; - AutoGroupColService.prototype.generateDefaultColDef = function (rowGroupCol) { - var userAutoColDef = this.gridOptionsWrapper.getAutoGroupColumnDef(); - var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc(); - var defaultAutoColDef = { - headerName: localeTextFunc('group', 'Group') - }; - var userHasProvidedGroupCellRenderer = userAutoColDef && (userAutoColDef.cellRenderer || userAutoColDef.cellRendererFramework); - // only add the default group cell renderer if user hasn't provided one - if (!userHasProvidedGroupCellRenderer) { - defaultAutoColDef.cellRenderer = 'agGroupCellRenderer'; + AnimationFrameService.prototype.requestFrame = function () { + // check for the existence of requestAnimationFrame, and if + // it's missing, then we polyfill it with setTimeout() + var callback = this.executeFrame.bind(this, 60); + var eDocument = this.gridOptionsWrapper.getDocument(); + var win = (eDocument.defaultView || window); + if (win.requestAnimationFrame) { + win.requestAnimationFrame(callback); } - // we never allow moving the group column - // defaultAutoColDef.suppressMovable = true; - if (rowGroupCol) { - var rowGroupColDef = rowGroupCol.getColDef(); - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].assign(defaultAutoColDef, { - // cellRendererParams.groupKey: colDefToCopy.field; - headerName: this.columnController.getDisplayNameForColumn(rowGroupCol, 'header'), - headerValueGetter: rowGroupColDef.headerValueGetter - }); - if (rowGroupColDef.cellRenderer) { - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].assign(defaultAutoColDef, { - cellRendererParams: { - innerRenderer: rowGroupColDef.cellRenderer, - innerRendererParams: rowGroupColDef.cellRendererParams - } - }); - } - defaultAutoColDef.showRowGroup = rowGroupCol.getColId(); + else if (win.webkitRequestAnimationFrame) { + win.webkitRequestAnimationFrame(callback); } else { - defaultAutoColDef.showRowGroup = true; + win.setTimeout(callback, 0); } - return defaultAutoColDef; }; - var AutoGroupColService_1; - AutoGroupColService.GROUP_AUTO_COLUMN_BUNDLE_ID = _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].GROUP_AUTO_COLUMN_ID; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], AutoGroupColService.prototype, "gridOptionsWrapper", void 0); + AnimationFrameService.prototype.isQueueEmpty = function () { + return !this.ticking; + }; + // a debounce utility used for parts of the app involved with rendering. + // the advantage over normal debounce is the client can call flushAllFrames() + // to make sure all rendering is complete. we don't wait any milliseconds, + // as this is intended to batch calls in one VM turn. + AnimationFrameService.prototype.debounce = function (func) { + var _this = this; + var pending = false; + return function () { + if (!_this.isOn()) { + _this.getFrameworkOverrides().setTimeout(func, 0); + return; + } + if (pending) { + return; + } + pending = true; + _this.addDestroyTask(function () { + pending = false; + func(); + }); + }; + }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], AutoGroupColService.prototype, "columnController", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('ctrlsService') + ], AnimationFrameService.prototype, "ctrlsService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnFactory') - ], AutoGroupColService.prototype, "columnFactory", void 0); - AutoGroupColService = AutoGroupColService_1 = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('autoGroupColService') - ], AutoGroupColService); - return AutoGroupColService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"])); + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], AnimationFrameService.prototype, "init", null); + AnimationFrameService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('animationFrameService') + ], AnimationFrameService); + return AnimationFrameService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 153 */ +/* 202 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PaginationProxy", function() { return PaginationProxy; }); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(41); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NavigationService", function() { return NavigationService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(18); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(65); +/* harmony import */ var _rendering_cell_cellCtrl__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(114); +/* harmony import */ var _rendering_row_rowCtrl__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(113); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(14); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(15); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -36462,6 +44096,17 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); +var __assign = (undefined && undefined.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); @@ -36472,370 +44117,735 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var PaginationProxy = /** @class */ (function (_super) { - __extends(PaginationProxy, _super); - function PaginationProxy() { + + + + + +var NavigationService = /** @class */ (function (_super) { + __extends(NavigationService, _super); + function NavigationService() { var _this = _super !== null && _super.apply(this, arguments) || this; - _this.currentPage = 0; - _this.topDisplayedRowIndex = 0; - _this.bottomDisplayedRowIndex = 0; - _this.pixelOffset = 0; - _this.masterRowCount = 0; + _this.timeLastPageEventProcessed = 0; return _this; } - PaginationProxy.prototype.postConstruct = function () { - this.active = this.gridOptionsWrapper.isPagination(); - this.paginateChildRows = this.gridOptionsWrapper.isPaginateChildRows(); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_MODEL_UPDATED, this.onModelUpdated.bind(this)); - this.addManagedListener(this.gridOptionsWrapper, 'paginationPageSize', this.onModelUpdated.bind(this)); - this.onModelUpdated(); + NavigationService.prototype.postConstruct = function () { + var _this = this; + this.ctrlsService.whenReady(function (p) { + _this.gridBodyCon = p.gridBodyCtrl; + }); }; - PaginationProxy.prototype.ensureRowHeightsValid = function (startPixel, endPixel, startLimitIndex, endLimitIndex) { - var res = this.rowModel.ensureRowHeightsValid(startPixel, endPixel, this.getPageFirstRow(), this.getPageLastRow()); - if (res) { - this.calculatePages(); + NavigationService.prototype.handlePageScrollingKey = function (event) { + var key = event.key; + var alt = event.altKey; + var ctrl = event.ctrlKey || event.metaKey; + var currentCell = this.mouseEventService.getCellPositionForEvent(event); + if (!currentCell) { + return false; + } + var processed = false; + switch (key) { + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].PAGE_HOME: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].PAGE_END: + // handle home and end when ctrl & alt are NOT pressed + if (!ctrl && !alt) { + this.onHomeOrEndKey(key); + processed = true; + } + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].LEFT: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].RIGHT: + // handle left and right when ctrl is pressed only + if (ctrl && !alt) { + this.onCtrlLeftOrRight(key, currentCell); + processed = true; + } + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].UP: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].DOWN: + // handle up and down when ctrl is pressed only + if (ctrl && !alt) { + this.onCtrlUpOrDown(key, currentCell); + processed = true; + } + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].PAGE_DOWN: + // handle page up and page down when ctrl & alt are NOT pressed + if (!ctrl && !alt) { + this.onPageDown(currentCell); + processed = true; + } + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].PAGE_UP: + // handle page up and page down when ctrl & alt are NOT pressed + if (!ctrl && !alt) { + this.onPageUp(currentCell); + processed = true; + } + break; + } + if (processed) { + event.preventDefault(); + } + return processed; + }; + // the page up/down keys caused a problem, in that if the user + // held the page up/down key down, lots of events got generated, + // which clogged up the event queue (as they take time to process) + // which in turn froze the grid. Logic below makes sure we wait 100ms + // between processing the page up/down events, so when user has finger + // held down on key, we ignore page up/down events until 100ms has passed, + // which effectively empties the queue of page up/down events. + NavigationService.prototype.isTimeSinceLastPageEventToRecent = function () { + var now = new Date().getTime(); + var diff = now - this.timeLastPageEventProcessed; + return (diff < 100); + }; + NavigationService.prototype.setTimeLastPageEventProcessed = function () { + this.timeLastPageEventProcessed = new Date().getTime(); + }; + NavigationService.prototype.navigateTo = function (navigateParams) { + var scrollIndex = navigateParams.scrollIndex, scrollType = navigateParams.scrollType, scrollColumn = navigateParams.scrollColumn, focusIndex = navigateParams.focusIndex, focusColumn = navigateParams.focusColumn; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["exists"])(scrollColumn) && !scrollColumn.isPinned()) { + this.gridBodyCon.getScrollFeature().ensureColumnVisible(scrollColumn); + } + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["exists"])(scrollIndex)) { + this.gridBodyCon.getScrollFeature().ensureIndexVisible(scrollIndex, scrollType); + } + // make sure the cell is rendered, needed if we are to focus + this.animationFrameService.flushAllFrames(); + // if we don't do this, the range will be left on the last cell, which will leave the last focused cell + // highlighted. + this.focusService.setFocusedCell(focusIndex, focusColumn, null, true); + if (this.rangeService) { + var cellPosition = { rowIndex: focusIndex, rowPinned: null, column: focusColumn }; + this.rangeService.setRangeToCell(cellPosition); + } + }; + NavigationService.prototype.onPageDown = function (gridCell) { + if (this.isTimeSinceLastPageEventToRecent()) { + return; + } + var gridBodyCon = this.ctrlsService.getGridBodyCtrl(); + var scrollPosition = gridBodyCon.getScrollFeature().getVScrollPosition(); + var pixelsInOnePage = this.getViewportHeight(); + var pagingPixelOffset = this.paginationProxy.getPixelOffset(); + var currentPageBottomPixel = scrollPosition.top + pixelsInOnePage; + var currentPageBottomRow = this.paginationProxy.getRowIndexAtPixel(currentPageBottomPixel + pagingPixelOffset); + var scrollIndex = currentPageBottomRow; + var currentCellPixel = this.paginationProxy.getRow(gridCell.rowIndex).rowTop; + var nextCellPixel = currentCellPixel + pixelsInOnePage - pagingPixelOffset; + var focusIndex = this.paginationProxy.getRowIndexAtPixel(nextCellPixel + pagingPixelOffset); + var pageLastRow = this.paginationProxy.getPageLastRow(); + if (focusIndex === gridCell.rowIndex) { + scrollIndex = focusIndex = gridCell.rowIndex + 1; + } + if (focusIndex > pageLastRow) { + focusIndex = pageLastRow; + } + if (scrollIndex > pageLastRow) { + scrollIndex = pageLastRow; + } + if (this.isRowTallerThanView(focusIndex)) { + scrollIndex = focusIndex; } - return res; - }; - PaginationProxy.prototype.onModelUpdated = function (modelUpdatedEvent) { - this.calculatePages(); - var paginationChangedEvent = { - type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_PAGINATION_CHANGED, - animate: modelUpdatedEvent ? modelUpdatedEvent.animate : false, - newData: modelUpdatedEvent ? modelUpdatedEvent.newData : false, - newPage: modelUpdatedEvent ? modelUpdatedEvent.newPage : false, - keepRenderedRows: modelUpdatedEvent ? modelUpdatedEvent.keepRenderedRows : false, - api: this.gridApi, - columnApi: this.columnApi - }; - this.eventService.dispatchEvent(paginationChangedEvent); + this.navigateTo({ + scrollIndex: scrollIndex, + scrollType: 'top', + scrollColumn: null, + focusIndex: focusIndex, + focusColumn: gridCell.column + }); + this.setTimeLastPageEventProcessed(); }; - PaginationProxy.prototype.goToPage = function (page) { - if (!this.active) { + NavigationService.prototype.onPageUp = function (gridCell) { + if (this.isTimeSinceLastPageEventToRecent()) { return; } - if (this.currentPage === page) { - return; + var gridBodyCon = this.ctrlsService.getGridBodyCtrl(); + var scrollPosition = gridBodyCon.getScrollFeature().getVScrollPosition(); + var pixelsInOnePage = this.getViewportHeight(); + var pagingPixelOffset = this.paginationProxy.getPixelOffset(); + var currentPageTopPixel = scrollPosition.top; + var currentPageTopRow = this.paginationProxy.getRowIndexAtPixel(currentPageTopPixel + pagingPixelOffset); + var scrollIndex = currentPageTopRow; + var currentRowNode = this.paginationProxy.getRow(gridCell.rowIndex); + var nextCellPixel = currentRowNode.rowTop + currentRowNode.rowHeight - pixelsInOnePage - pagingPixelOffset; + var focusIndex = this.paginationProxy.getRowIndexAtPixel(nextCellPixel + pagingPixelOffset); + var firstRow = this.paginationProxy.getPageFirstRow(); + if (focusIndex === gridCell.rowIndex) { + scrollIndex = focusIndex = gridCell.rowIndex - 1; } - this.currentPage = page; - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_MODEL_UPDATED, - animate: false, - keepRenderedRows: false, - newData: false, - newPage: true, - api: this.gridApi, - columnApi: this.columnApi - }; - this.onModelUpdated(event); - }; - PaginationProxy.prototype.getPixelOffset = function () { - return this.pixelOffset; - }; - PaginationProxy.prototype.getRow = function (index) { - return this.rowModel.getRow(index); - }; - PaginationProxy.prototype.getRowNode = function (id) { - return this.rowModel.getRowNode(id); - }; - PaginationProxy.prototype.getRowIndexAtPixel = function (pixel) { - return this.rowModel.getRowIndexAtPixel(pixel); + if (focusIndex < firstRow) { + focusIndex = firstRow; + } + if (scrollIndex < firstRow) { + scrollIndex = firstRow; + } + var scrollType = 'bottom'; + if (this.isRowTallerThanView(focusIndex)) { + scrollIndex = focusIndex; + scrollType = 'top'; + } + this.navigateTo({ + scrollIndex: scrollIndex, + scrollType: scrollType, + scrollColumn: null, + focusIndex: focusIndex, + focusColumn: gridCell.column + }); + this.setTimeLastPageEventProcessed(); }; - PaginationProxy.prototype.getCurrentPageHeight = function () { - if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].missing(this.topRowBounds) || _utils__WEBPACK_IMPORTED_MODULE_3__["_"].missing(this.bottomRowBounds)) { - return 0; + NavigationService.prototype.getViewportHeight = function () { + var gridBodyCon = this.ctrlsService.getGridBodyCtrl(); + var scrollPosition = gridBodyCon.getScrollFeature().getVScrollPosition(); + var scrollbarWidth = this.gridOptionsWrapper.getScrollbarWidth(); + var pixelsInOnePage = scrollPosition.bottom - scrollPosition.top; + if (this.ctrlsService.getCenterRowContainerCtrl().isHorizontalScrollShowing()) { + pixelsInOnePage -= scrollbarWidth; } - return Math.max(this.bottomRowBounds.rowTop + this.bottomRowBounds.rowHeight - this.topRowBounds.rowTop, 0); + return pixelsInOnePage; }; - PaginationProxy.prototype.isRowPresent = function (rowNode) { - if (!this.rowModel.isRowPresent(rowNode)) { + NavigationService.prototype.isRowTallerThanView = function (rowIndex) { + var rowNode = this.paginationProxy.getRow(rowIndex); + if (!rowNode) { return false; } - var nodeIsInPage = rowNode.rowIndex >= this.topDisplayedRowIndex && rowNode.rowIndex <= this.bottomDisplayedRowIndex; - return nodeIsInPage; - }; - PaginationProxy.prototype.isEmpty = function () { - return this.rowModel.isEmpty(); - }; - PaginationProxy.prototype.isRowsToRender = function () { - return this.rowModel.isRowsToRender(); - }; - PaginationProxy.prototype.getNodesInRangeForSelection = function (firstInRange, lastInRange) { - return this.rowModel.getNodesInRangeForSelection(firstInRange, lastInRange); - }; - PaginationProxy.prototype.forEachNode = function (callback) { - return this.rowModel.forEachNode(callback); - }; - PaginationProxy.prototype.getType = function () { - return this.rowModel.getType(); - }; - PaginationProxy.prototype.getRowBounds = function (index) { - var res = this.rowModel.getRowBounds(index); - res.rowIndex = index; - return res; + var rowHeight = rowNode.rowHeight; + if (typeof rowHeight !== 'number') { + return false; + } + return rowHeight > this.getViewportHeight(); }; - PaginationProxy.prototype.getPageFirstRow = function () { - return this.topRowBounds ? this.topRowBounds.rowIndex : -1; + NavigationService.prototype.getIndexToFocus = function (indexToScrollTo, isDown) { + var indexToFocus = indexToScrollTo; + // for SSRM, when user hits ctrl+down, we can end up trying to focus the loading row. + // instead we focus the last row with data instead. + if (isDown) { + var node = this.paginationProxy.getRow(indexToScrollTo); + if (node && node.stub) { + indexToFocus -= 1; + } + } + return indexToFocus; }; - PaginationProxy.prototype.getPageLastRow = function () { - return this.bottomRowBounds ? this.bottomRowBounds.rowIndex : -1; + // ctrl + up/down will bring focus to same column, first/last row. no horizontal scrolling. + NavigationService.prototype.onCtrlUpOrDown = function (key, gridCell) { + var upKey = key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].UP; + var rowIndexToScrollTo = upKey ? this.paginationProxy.getPageFirstRow() : this.paginationProxy.getPageLastRow(); + this.navigateTo({ + scrollIndex: rowIndexToScrollTo, + scrollType: null, + scrollColumn: gridCell.column, + focusIndex: this.getIndexToFocus(rowIndexToScrollTo, !upKey), + focusColumn: gridCell.column + }); }; - PaginationProxy.prototype.getRowCount = function () { - return this.rowModel.getRowCount(); + // ctrl + left/right will bring focus to same row, first/last cell. no vertical scrolling. + NavigationService.prototype.onCtrlLeftOrRight = function (key, gridCell) { + var leftKey = key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].LEFT; + var allColumns = this.columnModel.getAllDisplayedColumns(); + var isRtl = this.gridOptionsWrapper.isEnableRtl(); + var columnToSelect = leftKey !== isRtl ? allColumns[0] : Object(_utils_array__WEBPACK_IMPORTED_MODULE_3__["last"])(allColumns); + this.navigateTo({ + scrollIndex: gridCell.rowIndex, + scrollType: null, + scrollColumn: columnToSelect, + focusIndex: gridCell.rowIndex, + focusColumn: columnToSelect + }); }; - PaginationProxy.prototype.goToPageWithIndex = function (index) { - if (!this.active) { + // home brings focus to top left cell, end brings focus to bottom right, grid scrolled to bring + // same cell into view (which means either scroll all the way up, or all the way down). + NavigationService.prototype.onHomeOrEndKey = function (key) { + var homeKey = key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].PAGE_HOME; + var allColumns = this.columnModel.getAllDisplayedColumns(); + var columnToSelect = homeKey ? allColumns[0] : Object(_utils_array__WEBPACK_IMPORTED_MODULE_3__["last"])(allColumns); + var scrollIndex = homeKey ? this.paginationProxy.getPageFirstRow() : this.paginationProxy.getPageLastRow(); + this.navigateTo({ + scrollIndex: scrollIndex, + scrollType: null, + scrollColumn: columnToSelect, + focusIndex: this.getIndexToFocus(scrollIndex, !homeKey), + focusColumn: columnToSelect + }); + }; + // result of keyboard event + NavigationService.prototype.onTabKeyDown = function (previous, keyboardEvent) { + var backwards = keyboardEvent.shiftKey; + var movedToNextCell = this.tabToNextCellCommon(previous, backwards, keyboardEvent); + if (movedToNextCell) { + // only prevent default if we found a cell. so if user is on last cell and hits tab, then we default + // to the normal tabbing so user can exit the grid. + keyboardEvent.preventDefault(); return; } - var pageNumber = Math.floor(index / this.pageSize); - this.goToPage(pageNumber); + // if we didn't move to next cell, then need to tab out of the cells, ie to the header (if going + // backwards) + if (backwards) { + var _a = previous.getRowPosition(), rowIndex = _a.rowIndex, rowPinned = _a.rowPinned; + var firstRow = rowPinned ? rowIndex === 0 : rowIndex === this.paginationProxy.getPageFirstRow(); + if (firstRow) { + keyboardEvent.preventDefault(); + this.focusService.focusLastHeader(keyboardEvent); + } + } + else { + // if the case it's a popup editor, the focus is on the editor and not the previous cell. + // in order for the tab navigation to work, we need to focus the browser back onto the + // previous cell. + if (previous instanceof _rendering_cell_cellCtrl__WEBPACK_IMPORTED_MODULE_5__["CellCtrl"]) { + previous.focusCell(true); + } + if (this.focusService.focusNextGridCoreContainer(backwards)) { + keyboardEvent.preventDefault(); + } + } }; - PaginationProxy.prototype.isLastPageFound = function () { - return this.rowModel.isLastRowFound(); + // comes from API + NavigationService.prototype.tabToNextCell = function (backwards, event) { + var focusedCell = this.focusService.getFocusedCell(); + // if no focus, then cannot navigate + if (!focusedCell) { + return false; + } + var cellOrRow = this.getCellByPosition(focusedCell); + // if cell is not rendered, means user has scrolled away from the cell + // or that the focusedCell is a Full Width Row + if (!cellOrRow) { + cellOrRow = this.rowRenderer.getRowByPosition(focusedCell); + if (!cellOrRow || !cellOrRow.isFullWidth()) { + return false; + } + } + return this.tabToNextCellCommon(cellOrRow, backwards, event); }; - PaginationProxy.prototype.getCurrentPage = function () { - return this.currentPage; + NavigationService.prototype.tabToNextCellCommon = function (previous, backwards, event) { + var editing = previous.isEditing(); + // if cell is not editing, there is still chance row is editing if it's Full Row Editing + if (!editing && previous instanceof _rendering_cell_cellCtrl__WEBPACK_IMPORTED_MODULE_5__["CellCtrl"]) { + var cell = previous; + var row = cell.getRowCtrl(); + if (row) { + editing = row.isEditing(); + } + } + var res; + if (editing) { + // if we are editing, we know it's not a Full Width Row (RowComp) + if (this.gridOptionsWrapper.isFullRowEdit()) { + res = this.moveToNextEditingRow(previous, backwards, event); + } + else { + res = this.moveToNextEditingCell(previous, backwards, event); + } + } + else { + res = this.moveToNextCellNotEditing(previous, backwards); + } + // if a cell wasn't found, it's possible that focus was moved to the header + return res || !!this.focusService.getFocusedHeader(); }; - PaginationProxy.prototype.goToNextPage = function () { - this.goToPage(this.currentPage + 1); + NavigationService.prototype.moveToNextEditingCell = function (previousCell, backwards, event) { + if (event === void 0) { event = null; } + var previousPos = previousCell.getCellPosition(); + // need to do this before getting next cell to edit, in case the next cell + // has editable function (eg colDef.editable=func() ) and it depends on the + // result of this cell, so need to save updates from the first edit, in case + // the value is referenced in the function. + previousCell.stopEditing(); + // find the next cell to start editing + var nextCell = this.findNextCellToFocusOn(previousPos, backwards, true); + if (nextCell == null) { + return false; + } + // only prevent default if we found a cell. so if user is on last cell and hits tab, then we default + // to the normal tabbing so user can exit the grid. + nextCell.startEditing(null, null, true, event); + nextCell.focusCell(false); + return true; }; - PaginationProxy.prototype.goToPreviousPage = function () { - this.goToPage(this.currentPage - 1); + NavigationService.prototype.moveToNextEditingRow = function (previousCell, backwards, event) { + if (event === void 0) { event = null; } + var previousPos = previousCell.getCellPosition(); + // find the next cell to start editing + var nextCell = this.findNextCellToFocusOn(previousPos, backwards, true); + if (nextCell == null) { + return false; + } + var nextPos = nextCell.getCellPosition(); + var previousEditable = this.isCellEditable(previousPos); + var nextEditable = this.isCellEditable(nextPos); + var rowsMatch = nextPos && previousPos.rowIndex === nextPos.rowIndex && previousPos.rowPinned === nextPos.rowPinned; + if (previousEditable) { + previousCell.setFocusOutOnEditor(); + } + if (!rowsMatch) { + var pRow = previousCell.getRowCtrl(); + pRow.stopEditing(); + var nRow = nextCell.getRowCtrl(); + nRow.startRowEditing(undefined, undefined, undefined, event); + } + if (nextEditable) { + nextCell.setFocusInOnEditor(); + nextCell.focusCell(); + } + else { + nextCell.focusCell(true); + } + return true; }; - PaginationProxy.prototype.goToFirstPage = function () { - this.goToPage(0); + NavigationService.prototype.moveToNextCellNotEditing = function (previousCell, backwards) { + var displayedColumns = this.columnModel.getAllDisplayedColumns(); + var cellPos; + if (previousCell instanceof _rendering_row_rowCtrl__WEBPACK_IMPORTED_MODULE_6__["RowCtrl"]) { + cellPos = __assign(__assign({}, previousCell.getRowPosition()), { column: backwards ? displayedColumns[0] : Object(_utils_array__WEBPACK_IMPORTED_MODULE_3__["last"])(displayedColumns) }); + } + else { + cellPos = previousCell.getCellPosition(); + } + // find the next cell to start editing + var nextCell = this.findNextCellToFocusOn(cellPos, backwards, false); + // only prevent default if we found a cell. so if user is on last cell and hits tab, then we default + // to the normal tabbing so user can exit the grid. + if (nextCell instanceof _rendering_cell_cellCtrl__WEBPACK_IMPORTED_MODULE_5__["CellCtrl"]) { + nextCell.focusCell(true); + } + else if (nextCell) { + return this.tryToFocusFullWidthRow(nextCell.getRowPosition(), backwards); + } + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["exists"])(nextCell); }; - PaginationProxy.prototype.goToLastPage = function () { - var rowCount = this.rowModel.getRowCount(); - var lastPage = Math.floor(rowCount / this.pageSize); - this.goToPage(lastPage); + // called by the cell, when tab is pressed while editing. + // @return: RenderedCell when navigation successful, otherwise null + NavigationService.prototype.findNextCellToFocusOn = function (previousPosition, backwards, startEditing) { + var nextPosition = previousPosition; + while (true) { + if (previousPosition !== nextPosition) { + previousPosition = nextPosition; + } + if (!backwards) { + nextPosition = this.getLastCellOfColSpan(nextPosition); + } + nextPosition = this.cellNavigationService.getNextTabbedCell(nextPosition, backwards); + // allow user to override what cell to go to next + var userFunc = this.gridOptionsWrapper.getTabToNextCellFunc(); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["exists"])(userFunc)) { + var params = { + backwards: backwards, + editing: startEditing, + previousCellPosition: previousPosition, + nextCellPosition: nextPosition ? nextPosition : null, + api: this.gridOptionsWrapper.getApi(), + columnApi: this.gridOptionsWrapper.getColumnApi() + }; + var userCell = userFunc(params); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["exists"])(userCell)) { + if (userCell.floating) { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_7__["doOnce"])(function () { console.warn("AG Grid: tabToNextCellFunc return type should have attributes: rowIndex, rowPinned, column. However you had 'floating', maybe you meant 'rowPinned'?"); }, 'no floating in userCell'); + userCell.rowPinned = userCell.floating; + } + nextPosition = { + rowIndex: userCell.rowIndex, + column: userCell.column, + rowPinned: userCell.rowPinned + }; + } + else { + nextPosition = null; + } + } + // if no 'next cell', means we have got to last cell of grid, so nothing to move to, + // so bottom right cell going forwards, or top left going backwards + if (!nextPosition) { + return null; + } + if (nextPosition.rowIndex < 0) { + var headerLen = this.headerNavigationService.getHeaderRowCount(); + this.focusService.focusHeaderPosition({ + headerPosition: { + headerRowIndex: headerLen + (nextPosition.rowIndex), + column: nextPosition.column + } + }); + return null; + } + // if editing, but cell not editable, skip cell. we do this before we do all of + // the 'ensure index visible' and 'flush all frames', otherwise if we are skipping + // a bunch of cells (eg 10 rows) then all the work on ensuring cell visible is useless + // (except for the last one) which causes grid to stall for a while. + // note - for full row edit, we do focus non-editable cells, as the row stays in edit mode. + var fullRowEdit = this.gridOptionsWrapper.isFullRowEdit(); + if (startEditing && !fullRowEdit) { + var cellIsEditable = this.isCellEditable(nextPosition); + if (!cellIsEditable) { + continue; + } + } + this.ensureCellVisible(nextPosition); + // we have to call this after ensureColumnVisible - otherwise it could be a virtual column + // or row that is not currently in view, hence the renderedCell would not exist + var nextCell = this.getCellByPosition(nextPosition); + // if next cell is fullWidth row, then no rendered cell, + // as fullWidth rows have no cells, so we skip it + if (!nextCell) { + var row = this.rowRenderer.getRowByPosition(nextPosition); + if (!row || !row.isFullWidth()) { + continue; + } + else { + return row; + } + } + if (nextCell.isSuppressNavigable()) { + continue; + } + // by default, when we click a cell, it gets selected into a range, so to keep keyboard navigation + // consistent, we set into range here also. + if (this.rangeService) { + this.rangeService.setRangeToCell(nextPosition); + } + // we successfully tabbed onto a grid cell, so return true + return nextCell; + } }; - PaginationProxy.prototype.getPageSize = function () { - return this.pageSize; + NavigationService.prototype.isCellEditable = function (cell) { + var rowNode = this.lookupRowNodeForCell(cell); + if (rowNode) { + return cell.column.isCellEditable(rowNode); + } + return false; }; - PaginationProxy.prototype.getTotalPages = function () { - return this.totalPages; + NavigationService.prototype.getCellByPosition = function (cellPosition) { + var rowCtrl = this.rowRenderer.getRowByPosition(cellPosition); + if (!rowCtrl) { + return null; + } + return rowCtrl.getCellCtrl(cellPosition.column); }; - PaginationProxy.prototype.setPageSize = function () { - // show put this into super class - this.pageSize = this.gridOptionsWrapper.getPaginationPageSize(); - if (!(this.pageSize >= 1)) { - this.pageSize = 100; + NavigationService.prototype.lookupRowNodeForCell = function (cell) { + if (cell.rowPinned === _constants_constants__WEBPACK_IMPORTED_MODULE_8__["Constants"].PINNED_TOP) { + return this.pinnedRowModel.getPinnedTopRow(cell.rowIndex); + } + if (cell.rowPinned === _constants_constants__WEBPACK_IMPORTED_MODULE_8__["Constants"].PINNED_BOTTOM) { + return this.pinnedRowModel.getPinnedBottomRow(cell.rowIndex); } + return this.paginationProxy.getRow(cell.rowIndex); }; - PaginationProxy.prototype.calculatePages = function () { - if (this.active) { - this.setPageSize(); - if (this.paginateChildRows) { - this.calculatePagesAllRows(); + // we use index for rows, but column object for columns, as the next column (by index) might not + // be visible (header grouping) so it's not reliable, so using the column object instead. + NavigationService.prototype.navigateToNextCell = function (event, key, currentCell, allowUserOverride) { + // we keep searching for a next cell until we find one. this is how the group rows get skipped + var nextCell = currentCell; + var hitEdgeOfGrid = false; + while (nextCell && (nextCell === currentCell || !this.isValidNavigateCell(nextCell))) { + // if the current cell is spanning across multiple columns, we need to move + // our current position to be the last cell on the right before finding the + // the next target. + if (this.gridOptionsWrapper.isEnableRtl()) { + if (key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].LEFT) { + nextCell = this.getLastCellOfColSpan(nextCell); + } } - else { - this.calculatePagesMasterRowsOnly(); + else if (key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].RIGHT) { + nextCell = this.getLastCellOfColSpan(nextCell); } + nextCell = this.cellNavigationService.getNextCellToFocus(key, nextCell); + // eg if going down, and nextCell=undefined, means we are gone past the last row + hitEdgeOfGrid = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["missing"])(nextCell); } - else { - this.calculatedPagesNotActive(); + if (hitEdgeOfGrid && event && event.key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].UP) { + nextCell = { + rowIndex: -1, + rowPinned: null, + column: currentCell.column + }; } - this.topRowBounds = this.rowModel.getRowBounds(this.topDisplayedRowIndex); - if (this.topRowBounds) { - this.topRowBounds.rowIndex = this.topDisplayedRowIndex; + // allow user to override what cell to go to next. when doing normal cell navigation (with keys) + // we allow this, however if processing 'enter after edit' we don't allow override + if (allowUserOverride) { + var userFunc = this.gridOptionsWrapper.getNavigateToNextCellFunc(); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["exists"])(userFunc)) { + var params = { + key: key, + previousCellPosition: currentCell, + nextCellPosition: nextCell ? nextCell : null, + event: event, + api: this.gridOptionsWrapper.getApi(), + columnApi: this.gridOptionsWrapper.getColumnApi() + }; + var userCell = userFunc(params); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["exists"])(userCell)) { + if (userCell.floating) { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_7__["doOnce"])(function () { console.warn("AG Grid: tabToNextCellFunc return type should have attributes: rowIndex, rowPinned, column. However you had 'floating', maybe you meant 'rowPinned'?"); }, 'no floating in userCell'); + userCell.rowPinned = userCell.floating; + } + nextCell = { + rowPinned: userCell.rowPinned, + rowIndex: userCell.rowIndex, + column: userCell.column + }; + } + else { + nextCell = null; + } + } } - this.bottomRowBounds = this.rowModel.getRowBounds(this.bottomDisplayedRowIndex); - if (this.bottomRowBounds) { - this.bottomRowBounds.rowIndex = this.bottomDisplayedRowIndex; + // no next cell means we have reached a grid boundary, eg left, right, top or bottom of grid + if (!nextCell) { + return; } - this.pixelOffset = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(this.topRowBounds) ? this.topRowBounds.rowTop : 0; - }; - PaginationProxy.prototype.setZeroRows = function () { - this.topDisplayedRowIndex = 0; - this.bottomDisplayedRowIndex = -1; - this.currentPage = 0; - this.totalPages = 0; - }; - PaginationProxy.prototype.calculatePagesMasterRowsOnly = function () { - // const csrm = this.rowModel; - // const rootNode = csrm.getRootNode(); - // const masterRows = rootNode.childrenAfterSort; - this.masterRowCount = this.rowModel.getTopLevelRowCount(); - if (this.masterRowCount === 0) { - this.setZeroRows(); + if (nextCell.rowIndex < 0) { + var headerLen = this.headerNavigationService.getHeaderRowCount(); + this.focusService.focusHeaderPosition({ + headerPosition: { headerRowIndex: headerLen + (nextCell.rowIndex), column: currentCell.column }, + event: event || undefined + }); return; } - var masterLastRowIndex = this.masterRowCount - 1; - this.totalPages = Math.floor((masterLastRowIndex) / this.pageSize) + 1; - if (this.currentPage >= this.totalPages) { - this.currentPage = this.totalPages - 1; + // in case we have col spanning we get the cellComp and use it to get the + // position. This was we always focus the first cell inside the spanning. + var normalisedPosition = this.getNormalisedPosition(nextCell); + if (normalisedPosition) { + this.focusPosition(normalisedPosition); } - if (!_utils__WEBPACK_IMPORTED_MODULE_3__["_"].isNumeric(this.currentPage) || this.currentPage < 0) { - this.currentPage = 0; + else { + this.tryToFocusFullWidthRow(nextCell); } - var masterPageStartIndex = this.pageSize * this.currentPage; - var masterPageEndIndex = (this.pageSize * (this.currentPage + 1)) - 1; - if (masterPageEndIndex > masterLastRowIndex) { - masterPageEndIndex = masterLastRowIndex; + }; + NavigationService.prototype.getNormalisedPosition = function (cellPosition) { + // ensureCellVisible first, to make sure cell at position is rendered. + this.ensureCellVisible(cellPosition); + var cellComp = this.getCellByPosition(cellPosition); + // not guaranteed to have a cellComp when using the SSRM as blocks are loading. + if (!cellComp) { + return null; } - this.topDisplayedRowIndex = this.rowModel.getTopLevelRowDisplayedIndex(masterPageStartIndex); - // masterRows[masterPageStartIndex].rowIndex; - if (masterPageEndIndex === masterLastRowIndex) { - // if showing the last master row, then we want to show the very last row of the model - this.bottomDisplayedRowIndex = this.rowModel.getRowCount() - 1; + cellPosition = cellComp.getCellPosition(); + // we call this again, as nextCell can be different to it's previous value due to Column Spanning + // (ie if cursor moving from right to left, and cell is spanning columns, then nextCell was the + // last column in the group, however now it's the first column in the group). if we didn't do + // ensureCellVisible again, then we could only be showing the last portion (last column) of the + // merged cells. + this.ensureCellVisible(cellPosition); + return cellPosition; + }; + NavigationService.prototype.tryToFocusFullWidthRow = function (position, backwards) { + if (backwards === void 0) { backwards = false; } + var displayedColumns = this.columnModel.getAllDisplayedColumns(); + var rowComp = this.rowRenderer.getRowByPosition(position); + if (!rowComp || !rowComp.isFullWidth()) { + return false; } - else { - var firstIndexNotToShow = this.rowModel.getTopLevelRowDisplayedIndex(masterPageEndIndex + 1); - //masterRows[masterPageEndIndex + 1].rowIndex; - // this gets the index of the last child - eg current row is open, we want to display all children, - // the index of the last child is one less than the index of the next parent row. - this.bottomDisplayedRowIndex = firstIndexNotToShow - 1; + var cellPosition = { + rowIndex: position.rowIndex, + rowPinned: position.rowPinned, + column: position.column || (backwards ? Object(_utils_array__WEBPACK_IMPORTED_MODULE_3__["last"])(displayedColumns) : displayedColumns[0]) + }; + this.focusPosition(cellPosition); + return true; + }; + NavigationService.prototype.focusPosition = function (cellPosition) { + this.focusService.setFocusedCell(cellPosition.rowIndex, cellPosition.column, cellPosition.rowPinned, true); + if (this.rangeService) { + this.rangeService.setRangeToCell(cellPosition); } }; - PaginationProxy.prototype.getMasterRowCount = function () { - return this.masterRowCount; + NavigationService.prototype.isValidNavigateCell = function (cell) { + var rowNode = this.rowPositionUtils.getRowNode(cell); + // we do not allow focusing on detail rows and full width rows + return !!rowNode; }; - PaginationProxy.prototype.calculatePagesAllRows = function () { - this.masterRowCount = this.rowModel.getRowCount(); - if (this.masterRowCount === 0) { - this.setZeroRows(); - return; + NavigationService.prototype.getLastCellOfColSpan = function (cell) { + var cellCtrl = this.getCellByPosition(cell); + if (!cellCtrl) { + return cell; } - var maxRowIndex = this.masterRowCount - 1; - this.totalPages = Math.floor((maxRowIndex) / this.pageSize) + 1; - if (this.currentPage >= this.totalPages) { - this.currentPage = this.totalPages - 1; + var colSpanningList = cellCtrl.getColSpanningList(); + if (colSpanningList.length === 1) { + return cell; } - if (!_utils__WEBPACK_IMPORTED_MODULE_3__["_"].isNumeric(this.currentPage) || this.currentPage < 0) { - this.currentPage = 0; + return { + rowIndex: cell.rowIndex, + column: Object(_utils_array__WEBPACK_IMPORTED_MODULE_3__["last"])(colSpanningList), + rowPinned: cell.rowPinned + }; + }; + NavigationService.prototype.ensureCellVisible = function (gridCell) { + // this scrolls the row into view + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["missing"])(gridCell.rowPinned)) { + this.gridBodyCon.getScrollFeature().ensureIndexVisible(gridCell.rowIndex); } - this.topDisplayedRowIndex = this.pageSize * this.currentPage; - this.bottomDisplayedRowIndex = (this.pageSize * (this.currentPage + 1)) - 1; - if (this.bottomDisplayedRowIndex > maxRowIndex) { - this.bottomDisplayedRowIndex = maxRowIndex; + if (!gridCell.column.isPinned()) { + this.gridBodyCon.getScrollFeature().ensureColumnVisible(gridCell.column); } - }; - PaginationProxy.prototype.calculatedPagesNotActive = function () { - this.pageSize = this.rowModel.getRowCount(); - this.totalPages = 1; - this.currentPage = 0; - this.topDisplayedRowIndex = 0; - this.bottomDisplayedRowIndex = this.rowModel.getRowCount() - 1; + // need to nudge the scrolls for the floating items. otherwise when we set focus on a non-visible + // floating cell, the scrolls get out of sync + this.gridBodyCon.getScrollFeature().horizontallyScrollHeaderCenterAndFloatingCenter(); + // need to flush frames, to make sure the correct cells are rendered + this.animationFrameService.flushAllFrames(); }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('rowModel') - ], PaginationProxy.prototype, "rowModel", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('mouseEventService') + ], NavigationService.prototype, "mouseEventService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper') - ], PaginationProxy.prototype, "gridOptionsWrapper", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('paginationProxy') + ], NavigationService.prototype, "paginationProxy", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('selectionController') - ], PaginationProxy.prototype, "selectionController", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusService') + ], NavigationService.prototype, "focusService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnApi') - ], PaginationProxy.prototype, "columnApi", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('animationFrameService') + ], NavigationService.prototype, "animationFrameService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridApi') - ], PaginationProxy.prototype, "gridApi", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('rangeService') + ], NavigationService.prototype, "rangeService", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] - ], PaginationProxy.prototype, "postConstruct", null); - PaginationProxy = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Bean"])('paginationProxy') - ], PaginationProxy); - return PaginationProxy; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); - - - -/***/ }), -/* 154 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PaginationAutoPageSizeService", function() { return PaginationAutoPageSizeService; }); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(41); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - -var PaginationAutoPageSizeService = /** @class */ (function (_super) { - __extends(PaginationAutoPageSizeService, _super); - function PaginationAutoPageSizeService() { - return _super !== null && _super.apply(this, arguments) || this; - } - PaginationAutoPageSizeService.prototype.registerGridComp = function (gridPanel) { - this.gridPanel = gridPanel; - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_BODY_HEIGHT_CHANGED, this.onBodyHeightChanged.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_SCROLL_VISIBILITY_CHANGED, this.onScrollVisibilityChanged.bind(this)); - this.checkPageSize(); - }; - PaginationAutoPageSizeService.prototype.notActive = function () { - return !this.gridOptionsWrapper.isPaginationAutoPageSize(); - }; - PaginationAutoPageSizeService.prototype.onScrollVisibilityChanged = function () { - this.checkPageSize(); - }; - PaginationAutoPageSizeService.prototype.onBodyHeightChanged = function () { - this.checkPageSize(); - }; - PaginationAutoPageSizeService.prototype.checkPageSize = function () { - if (this.notActive()) { - return; - } - var rowHeight = this.gridOptionsWrapper.getRowHeightAsNumber(); - var bodyHeight = this.gridPanel.getBodyHeight(); - if (bodyHeight > 0) { - var newPageSize = Math.floor(bodyHeight / rowHeight); - this.gridOptionsWrapper.setProperty('paginationPageSize', newPageSize); - } - }; + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], NavigationService.prototype, "columnModel", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper') - ], PaginationAutoPageSizeService.prototype, "gridOptionsWrapper", void 0); - PaginationAutoPageSizeService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Bean"])('paginationAutoPageSizeService') - ], PaginationAutoPageSizeService); - return PaginationAutoPageSizeService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('ctrlsService') + ], NavigationService.prototype, "ctrlsService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer') + ], NavigationService.prototype, "rowRenderer", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('headerNavigationService') + ], NavigationService.prototype, "headerNavigationService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("rowPositionUtils") + ], NavigationService.prototype, "rowPositionUtils", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("cellNavigationService") + ], NavigationService.prototype, "cellNavigationService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("pinnedRowModel") + ], NavigationService.prototype, "pinnedRowModel", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], NavigationService.prototype, "postConstruct", null); + NavigationService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('navigationService') + ], NavigationService); + return NavigationService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 155 */ +/* 203 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ValueCache", function() { return ValueCache; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowContainerHeightService", function() { return RowContainerHeightService; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(24); +/* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -36858,72 +44868,146 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; +var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { + return function (target, key) { decorator(target, key, paramIndex); } +}; -var ValueCache = /** @class */ (function (_super) { - __extends(ValueCache, _super); - function ValueCache() { + + +/** + * This class solves the 'max height' problem, where the user might want to show more data than + * the max div height actually allows. + */ +var RowContainerHeightService = /** @class */ (function (_super) { + __extends(RowContainerHeightService, _super); + function RowContainerHeightService() { var _this = _super !== null && _super.apply(this, arguments) || this; - _this.cacheVersion = 0; + // the scrollY position + _this.scrollY = 0; + // how tall the body is + _this.uiBodyHeight = 0; return _this; } - ValueCache.prototype.init = function () { - this.active = this.gridOptionsWrapper.isValueCache(); - this.neverExpires = this.gridOptionsWrapper.isValueCacheNeverExpires(); + RowContainerHeightService.prototype.agWire = function (loggerFactory) { + this.logger = loggerFactory.create("RowContainerHeightService"); }; - ValueCache.prototype.onDataChanged = function () { - if (this.neverExpires) { + RowContainerHeightService.prototype.postConstruct = function () { + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_BODY_HEIGHT_CHANGED, this.updateOffset.bind(this)); + this.maxDivHeight = Object(_utils_browser__WEBPACK_IMPORTED_MODULE_3__["getMaxDivHeight"])(); + this.logger.log('maxDivHeight = ' + this.maxDivHeight); + }; + RowContainerHeightService.prototype.isStretching = function () { + return this.stretching; + }; + RowContainerHeightService.prototype.getDivStretchOffset = function () { + return this.divStretchOffset; + }; + RowContainerHeightService.prototype.updateOffset = function () { + if (!this.stretching) { return; } - this.expire(); + var gridBodyCon = this.ctrlsService.getGridBodyCtrl(); + var newScrollY = gridBodyCon.getScrollFeature().getVScrollPosition().top; + var newBodyHeight = this.getUiBodyHeight(); + var atLeastOneChanged = newScrollY !== this.scrollY || newBodyHeight !== this.uiBodyHeight; + if (atLeastOneChanged) { + this.scrollY = newScrollY; + this.uiBodyHeight = newBodyHeight; + this.calculateOffset(); + } }; - ValueCache.prototype.expire = function () { - this.cacheVersion++; + RowContainerHeightService.prototype.calculateOffset = function () { + this.setUiContainerHeight(this.maxDivHeight); + this.pixelsToShave = this.modelHeight - this.uiContainerHeight; + this.maxScrollY = this.uiContainerHeight - this.uiBodyHeight; + var scrollPercent = this.scrollY / this.maxScrollY; + var divStretchOffset = scrollPercent * this.pixelsToShave; + this.logger.log("Div Stretch Offset = " + divStretchOffset + " (" + this.pixelsToShave + " * " + scrollPercent + ")"); + this.setDivStretchOffset(divStretchOffset); }; - ValueCache.prototype.setValue = function (rowNode, colId, value) { - if (this.active) { - if (rowNode.__cacheVersion !== this.cacheVersion) { - rowNode.__cacheVersion = this.cacheVersion; - rowNode.__cacheData = {}; - } - rowNode.__cacheData[colId] = value; + RowContainerHeightService.prototype.setUiContainerHeight = function (height) { + if (height !== this.uiContainerHeight) { + this.uiContainerHeight = height; + this.eventService.dispatchEvent({ type: _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_CONTAINER_HEIGHT_CHANGED }); } }; - ValueCache.prototype.getValue = function (rowNode, colId) { - if (!this.active || rowNode.__cacheVersion !== this.cacheVersion) { - return undefined; + RowContainerHeightService.prototype.clearOffset = function () { + this.setUiContainerHeight(this.modelHeight); + this.pixelsToShave = 0; + this.setDivStretchOffset(0); + }; + RowContainerHeightService.prototype.setDivStretchOffset = function (newOffset) { + // because we are talking pixels, no point in confusing things with half numbers + var newOffsetFloor = typeof newOffset === 'number' ? Math.floor(newOffset) : null; + if (this.divStretchOffset === newOffsetFloor) { + return; } - return rowNode.__cacheData[colId]; + this.divStretchOffset = newOffsetFloor; + this.eventService.dispatchEvent({ type: _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_HEIGHT_SCALE_CHANGED }); + }; + RowContainerHeightService.prototype.setModelHeight = function (modelHeight) { + this.modelHeight = modelHeight; + this.stretching = modelHeight != null // null happens when in print layout + && this.maxDivHeight > 0 + && modelHeight > this.maxDivHeight; + if (this.stretching) { + this.calculateOffset(); + } + else { + this.clearOffset(); + } + }; + RowContainerHeightService.prototype.getUiContainerHeight = function () { + return this.uiContainerHeight; + }; + RowContainerHeightService.prototype.getRealPixelPosition = function (modelPixel) { + return modelPixel - this.divStretchOffset; + }; + RowContainerHeightService.prototype.getUiBodyHeight = function () { + var gridBodyCon = this.ctrlsService.getGridBodyCtrl(); + var pos = gridBodyCon.getScrollFeature().getVScrollPosition(); + return pos.bottom - pos.top; + }; + RowContainerHeightService.prototype.getScrollPositionForPixel = function (rowTop) { + if (this.pixelsToShave <= 0) { + return rowTop; + } + var modelMaxScroll = this.modelHeight - this.getUiBodyHeight(); + var scrollPercent = rowTop / modelMaxScroll; + var scrollPixel = this.maxScrollY * scrollPercent; + return scrollPixel; }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], ValueCache.prototype, "gridOptionsWrapper", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('ctrlsService') + ], RowContainerHeightService.prototype, "ctrlsService", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], ValueCache.prototype, "init", null); - ValueCache = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('valueCache') - ], ValueCache); - return ValueCache; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Qualifier"])("loggerFactory")) + ], RowContainerHeightService.prototype, "agWire", null); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], RowContainerHeightService.prototype, "postConstruct", null); + RowContainerHeightService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('rowContainerHeightService') + ], RowContainerHeightService); + return RowContainerHeightService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 156 */ +/* 204 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ChangeDetectionService", function() { return ChangeDetectionService; }); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(41); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _utils_changedPath__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(97); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(43); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SelectableService", function() { return SelectableService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -36949,78 +45033,81 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta - - -var ChangeDetectionService = /** @class */ (function (_super) { - __extends(ChangeDetectionService, _super); - function ChangeDetectionService() { +var SelectableService = /** @class */ (function (_super) { + __extends(SelectableService, _super); + function SelectableService() { return _super !== null && _super.apply(this, arguments) || this; } - ChangeDetectionService.prototype.init = function () { - if (this.rowModel.getType() === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) { - this.clientSideRowModel = this.rowModel; + SelectableService.prototype.init = function () { + this.groupSelectsChildren = this.gridOptionsWrapper.isGroupSelectsChildren(); + this.isRowSelectableFunc = this.gridOptionsWrapper.getIsRowSelectableFunc(); + }; + SelectableService.prototype.updateSelectableAfterGrouping = function (rowNode) { + if (this.isRowSelectableFunc) { + var nextChildrenFunc = function (node) { return node.childrenAfterGroup; }; + this.recurseDown(rowNode.childrenAfterGroup, nextChildrenFunc); } - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_CELL_VALUE_CHANGED, this.onCellValueChanged.bind(this)); }; - ChangeDetectionService.prototype.onCellValueChanged = function (event) { - // Clipboard service manages its own change detection, so no need to do it here. - // The clipboard manages its own as otherwise this would happen once for every cell - // that got updated as part of a paste operation, so e.g. if 100 cells in a paste operation, - // this doChangeDetection would get called 100 times (once for each cell), instead clipboard - // service executes the logic we have here once (in essence batching up all cell changes - // into one change detection). - if (event.source === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].SOURCE_PASTE) { - return; + SelectableService.prototype.updateSelectableAfterFiltering = function (rowNode) { + if (this.isRowSelectableFunc) { + var nextChildrenFunc = function (node) { return node.childrenAfterFilter; }; + this.recurseDown(rowNode.childrenAfterGroup, nextChildrenFunc); } - this.doChangeDetection(event.node, event.column); }; - ChangeDetectionService.prototype.doChangeDetection = function (rowNode, column) { - if (this.gridOptionsWrapper.isSuppressChangeDetection()) { + SelectableService.prototype.recurseDown = function (children, nextChildrenFunc) { + var _this = this; + if (!children) { return; } - // step 1 of change detection is to update the aggregated values - if (this.clientSideRowModel && !rowNode.isRowPinned()) { - var onlyChangedColumns = this.gridOptionsWrapper.isAggregateOnlyChangedColumns(); - var changedPath = new _utils_changedPath__WEBPACK_IMPORTED_MODULE_2__["ChangedPath"](onlyChangedColumns, this.clientSideRowModel.getRootNode()); - changedPath.addParentNode(rowNode.parent, [column]); - this.clientSideRowModel.doAggregate(changedPath); - } - // step 2 of change detection is to refresh the cells - this.rowRenderer.refreshCells(); + children.forEach(function (child) { + if (!child.group) { + return; + } // only interested in groups + if (child.hasChildren()) { + _this.recurseDown(nextChildrenFunc(child), nextChildrenFunc); + } + var rowSelectable; + if (_this.groupSelectsChildren) { + // have this group selectable if at least one direct child is selectable + var firstSelectable = (nextChildrenFunc(child) || []).find(function (rowNode) { return rowNode.selectable === true; }); + rowSelectable = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["exists"])(firstSelectable); + } + else { + // directly retrieve selectable value from user callback + rowSelectable = _this.isRowSelectableFunc ? _this.isRowSelectableFunc(child) : false; + } + child.setRowSelectable(rowSelectable); + }); }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], ChangeDetectionService.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowModel') - ], ChangeDetectionService.prototype, "rowModel", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowRenderer') - ], ChangeDetectionService.prototype, "rowRenderer", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], ChangeDetectionService.prototype, "init", null); - ChangeDetectionService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('changeDetectionService') - ], ChangeDetectionService); - return ChangeDetectionService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], SelectableService.prototype, "init", null); + SelectableService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('selectableService') + ], SelectableService); + return SelectableService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 157 */ +/* 205 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AlignedGridsService", function() { return AlignedGridsService; }); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(43); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PaginationComp", function() { return PaginationComp; }); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(23); +/* harmony import */ var _utils_icon__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(48); +/* harmony import */ var _utils_number__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(46); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(44); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(65); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -37043,227 +45130,366 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; -var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { - return function (target, key) { decorator(target, key, paramIndex); } -}; -var AlignedGridsService = /** @class */ (function (_super) { - __extends(AlignedGridsService, _super); - function AlignedGridsService() { - var _this = _super !== null && _super.apply(this, arguments) || this; - // flag to mark if we are consuming. to avoid cyclic events (ie other grid firing back to master - // while processing a master event) we mark this if consuming an event, and if we are, then - // we don't fire back any events. - _this.consuming = false; + + +var PaginationComp = /** @class */ (function (_super) { + __extends(PaginationComp, _super); + function PaginationComp() { + var _this = _super.call(this) || this; + _this.previousAndFirstButtonsDisabled = false; + _this.nextButtonDisabled = false; + _this.lastButtonDisabled = false; return _this; } - AlignedGridsService.prototype.setBeans = function (loggerFactory) { - this.logger = loggerFactory.create('AlignedGridsService'); - }; - AlignedGridsService.prototype.registerGridComp = function (gridPanel) { - this.gridPanel = gridPanel; - }; - AlignedGridsService.prototype.init = function () { - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_MOVED, this.fireColumnEvent.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_VISIBLE, this.fireColumnEvent.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PINNED, this.fireColumnEvent.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_GROUP_OPENED, this.fireColumnEvent.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_RESIZED, this.fireColumnEvent.bind(this)); - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_BODY_SCROLL, this.fireScrollEvent.bind(this)); - }; - // common logic across all the fire methods - AlignedGridsService.prototype.fireEvent = function (callback) { - // if we are already consuming, then we are acting on an event from a master, - // so we don't cause a cyclic firing of events - if (this.consuming) { + PaginationComp.prototype.postConstruct = function () { + var _this = this; + var isRtl = this.gridOptionsWrapper.isEnableRtl(); + this.setTemplate(this.getTemplate()); + this.btFirst.insertAdjacentElement('afterbegin', Object(_utils_icon__WEBPACK_IMPORTED_MODULE_4__["createIconNoSpan"])(isRtl ? 'last' : 'first', this.gridOptionsWrapper)); + this.btPrevious.insertAdjacentElement('afterbegin', Object(_utils_icon__WEBPACK_IMPORTED_MODULE_4__["createIconNoSpan"])(isRtl ? 'next' : 'previous', this.gridOptionsWrapper)); + this.btNext.insertAdjacentElement('afterbegin', Object(_utils_icon__WEBPACK_IMPORTED_MODULE_4__["createIconNoSpan"])(isRtl ? 'previous' : 'next', this.gridOptionsWrapper)); + this.btLast.insertAdjacentElement('afterbegin', Object(_utils_icon__WEBPACK_IMPORTED_MODULE_4__["createIconNoSpan"])(isRtl ? 'first' : 'last', this.gridOptionsWrapper)); + var isPaging = this.gridOptionsWrapper.isPagination(); + var paginationPanelEnabled = isPaging && !this.gridOptionsWrapper.isSuppressPaginationPanel(); + if (!paginationPanelEnabled) { + this.setDisplayed(false); return; } - // iterate through the aligned grids, and pass each aligned grid service to the callback - var otherGrids = this.gridOptionsWrapper.getAlignedGrids(); - if (otherGrids) { - otherGrids.forEach(function (otherGridOptions) { - if (otherGridOptions.api) { - var alignedGridService = otherGridOptions.api.__getAlignedGridService(); - callback(alignedGridService); + this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_PAGINATION_CHANGED, this.onPaginationChanged.bind(this)); + [ + { el: this.btFirst, fn: this.onBtFirst.bind(this) }, + { el: this.btPrevious, fn: this.onBtPrevious.bind(this) }, + { el: this.btNext, fn: this.onBtNext.bind(this) }, + { el: this.btLast, fn: this.onBtLast.bind(this) } + ].forEach(function (item) { + var el = item.el, fn = item.fn; + _this.addManagedListener(el, 'click', fn); + _this.addManagedListener(el, 'keydown', function (e) { + if (e.key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_7__["KeyCode"].ENTER || e.key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_7__["KeyCode"].SPACE) { + e.preventDefault(); + fn(); } }); - } - }; - // common logic across all consume methods. very little common logic, however extracting - // guarantees consistency across the methods. - AlignedGridsService.prototype.onEvent = function (callback) { - this.consuming = true; - callback(); - this.consuming = false; - }; - AlignedGridsService.prototype.fireColumnEvent = function (event) { - this.fireEvent(function (alignedGridsService) { - alignedGridsService.onColumnEvent(event); }); + this.onPaginationChanged(); }; - AlignedGridsService.prototype.fireScrollEvent = function (event) { - if (event.direction !== 'horizontal') { - return; + PaginationComp.prototype.onPaginationChanged = function () { + this.enableOrDisableButtons(); + this.updateRowLabels(); + this.setCurrentPageLabel(); + this.setTotalLabels(); + }; + PaginationComp.prototype.onBtFirst = function () { + if (!this.previousAndFirstButtonsDisabled) { + this.paginationProxy.goToFirstPage(); } - this.fireEvent(function (alignedGridsService) { - alignedGridsService.onScrollEvent(event); - }); }; - AlignedGridsService.prototype.onScrollEvent = function (event) { - var _this = this; - this.onEvent(function () { - _this.gridPanel.setHorizontalScrollPosition(event.left); - }); + PaginationComp.prototype.setCurrentPageLabel = function () { + var pagesExist = this.paginationProxy.getTotalPages() > 0; + var currentPage = this.paginationProxy.getCurrentPage(); + var toDisplay = pagesExist ? currentPage + 1 : 0; + this.lbCurrent.innerHTML = this.formatNumber(toDisplay); }; - AlignedGridsService.prototype.getMasterColumns = function (event) { - var result = []; - if (event.columns) { - event.columns.forEach(function (column) { - result.push(column); - }); + PaginationComp.prototype.formatNumber = function (value) { + var userFunc = this.gridOptionsWrapper.getPaginationNumberFormatterFunc(); + if (userFunc) { + return userFunc({ value: value }); } - else if (event.column) { - result.push(event.column); + var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc(); + var thousandSeparator = localeTextFunc('thousandSeparator', ','); + var decimalSeparator = localeTextFunc('decimalSeparator', '.'); + return Object(_utils_number__WEBPACK_IMPORTED_MODULE_5__["formatNumberCommas"])(value, thousandSeparator, decimalSeparator); + }; + PaginationComp.prototype.getTemplate = function () { + var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc(); + var strPage = localeTextFunc('page', 'Page'); + var strTo = localeTextFunc('to', 'to'); + var strOf = localeTextFunc('of', 'of'); + var strFirst = localeTextFunc('firstPage', 'First Page'); + var strPrevious = localeTextFunc('previousPage', 'Previous Page'); + var strNext = localeTextFunc('nextPage', 'Next Page'); + var strLast = localeTextFunc('lastPage', 'Last Page'); + var compId = this.getCompId(); + return /* html */ "
\n \n \n " + strTo + "\n \n " + strOf + "\n \n \n \n
\n
\n \n " + strPage + "\n \n " + strOf + "\n \n \n
\n
\n
\n
"; + }; + PaginationComp.prototype.onBtNext = function () { + if (!this.nextButtonDisabled) { + this.paginationProxy.goToNextPage(); } - return result; }; - AlignedGridsService.prototype.getColumnIds = function (event) { - var result = []; - if (event.columns) { - event.columns.forEach(function (column) { - result.push(column.getColId()); - }); + PaginationComp.prototype.onBtPrevious = function () { + if (!this.previousAndFirstButtonsDisabled) { + this.paginationProxy.goToPreviousPage(); } - else if (event.column) { - result.push(event.column.getColId()); + }; + PaginationComp.prototype.onBtLast = function () { + if (!this.lastButtonDisabled) { + this.paginationProxy.goToLastPage(); } - return result; }; - AlignedGridsService.prototype.onColumnEvent = function (event) { - var _this = this; - this.onEvent(function () { - switch (event.type) { - case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_MOVED: - case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_VISIBLE: - case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PINNED: - case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_RESIZED: - var colEvent = event; - _this.processColumnEvent(colEvent); - break; - case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_GROUP_OPENED: - var groupOpenedEvent = event; - _this.processGroupOpenedEvent(groupOpenedEvent); - break; - case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PIVOT_CHANGED: - // we cannot support pivoting with aligned grids as the columns will be out of sync as the - // grids will have columns created based on the row data of the grid. - console.warn('ag-Grid: pivoting is not supported with aligned grids. ' + - 'You can only use one of these features at a time in a grid.'); - break; + PaginationComp.prototype.enableOrDisableButtons = function () { + var currentPage = this.paginationProxy.getCurrentPage(); + var maxRowFound = this.paginationProxy.isLastPageFound(); + var totalPages = this.paginationProxy.getTotalPages(); + this.previousAndFirstButtonsDisabled = currentPage === 0; + this.btFirst.classList.toggle('ag-disabled', this.previousAndFirstButtonsDisabled); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_6__["setAriaDisabled"])(this.btFirst, this.previousAndFirstButtonsDisabled); + this.btPrevious.classList.toggle('ag-disabled', this.previousAndFirstButtonsDisabled); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_6__["setAriaDisabled"])(this.btPrevious, this.previousAndFirstButtonsDisabled); + var zeroPagesToDisplay = this.isZeroPagesToDisplay(); + var onLastPage = maxRowFound && currentPage === (totalPages - 1); + this.nextButtonDisabled = onLastPage || zeroPagesToDisplay; + this.btNext.classList.toggle('ag-disabled', this.nextButtonDisabled); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_6__["setAriaDisabled"])(this.btNext, this.nextButtonDisabled); + this.lastButtonDisabled = !maxRowFound || zeroPagesToDisplay || currentPage === (totalPages - 1); + this.btLast.classList.toggle('ag-disabled', this.lastButtonDisabled); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_6__["setAriaDisabled"])(this.btLast, this.lastButtonDisabled); + }; + PaginationComp.prototype.updateRowLabels = function () { + var currentPage = this.paginationProxy.getCurrentPage(); + var pageSize = this.paginationProxy.getPageSize(); + var maxRowFound = this.paginationProxy.isLastPageFound(); + var rowCount = this.paginationProxy.isLastPageFound() ? + this.paginationProxy.getMasterRowCount() : null; + var startRow; + var endRow; + if (this.isZeroPagesToDisplay()) { + startRow = endRow = 0; + } + else { + startRow = (pageSize * currentPage) + 1; + endRow = startRow + pageSize - 1; + if (maxRowFound && endRow > rowCount) { + endRow = rowCount; } - }); + } + this.lbFirstRowOnPage.innerHTML = this.formatNumber(startRow); + if (this.rowNodeBlockLoader.isLoading()) { + this.lbLastRowOnPage.innerHTML = '?'; + } + else { + this.lbLastRowOnPage.innerHTML = this.formatNumber(endRow); + } }; - AlignedGridsService.prototype.processGroupOpenedEvent = function (groupOpenedEvent) { - // likewise for column group - var masterColumnGroup = groupOpenedEvent.columnGroup; - var otherColumnGroup; - if (masterColumnGroup) { - var groupId = masterColumnGroup.getGroupId(); - otherColumnGroup = this.columnController.getOriginalColumnGroup(groupId); + PaginationComp.prototype.isZeroPagesToDisplay = function () { + var maxRowFound = this.paginationProxy.isLastPageFound(); + var totalPages = this.paginationProxy.getTotalPages(); + return maxRowFound && totalPages === 0; + }; + PaginationComp.prototype.setTotalLabels = function () { + var lastPageFound = this.paginationProxy.isLastPageFound(); + var totalPages = this.paginationProxy.getTotalPages(); + var rowCount = lastPageFound ? this.paginationProxy.getMasterRowCount() : null; + // When `pivotMode=true` and no grouping or value columns exist, a single 'hidden' group row (root node) is in + // the grid and the pagination totals will correctly display total = 1. However this is confusing to users as + // they can't see it. To address this UX issue we simply set the totals to zero in the pagination panel. + if (rowCount === 1) { + var firstRow = this.paginationProxy.getRow(0); + // a group node with no group or agg data will not be visible to users + var hiddenGroupRow = firstRow && firstRow.group && !(firstRow.groupData || firstRow.aggData); + if (hiddenGroupRow) { + this.setTotalLabelsToZero(); + return; + } } - if (masterColumnGroup && !otherColumnGroup) { - return; + if (lastPageFound) { + this.lbTotal.innerHTML = this.formatNumber(totalPages); + this.lbRecordCount.innerHTML = this.formatNumber(rowCount); + } + else { + var moreText = this.gridOptionsWrapper.getLocaleTextFunc()('more', 'more'); + this.lbTotal.innerHTML = moreText; + this.lbRecordCount.innerHTML = moreText; } - this.logger.log('onColumnEvent-> processing ' + groupOpenedEvent + ' expanded = ' + masterColumnGroup.isExpanded()); - this.columnController.setColumnGroupOpened(otherColumnGroup, masterColumnGroup.isExpanded(), "alignedGridChanged"); }; - AlignedGridsService.prototype.processColumnEvent = function (colEvent) { + PaginationComp.prototype.setTotalLabelsToZero = function () { + this.lbFirstRowOnPage.innerHTML = this.formatNumber(0); + this.lbCurrent.innerHTML = this.formatNumber(0); + this.lbLastRowOnPage.innerHTML = this.formatNumber(0); + this.lbTotal.innerHTML = this.formatNumber(0); + this.lbRecordCount.innerHTML = this.formatNumber(0); + }; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('paginationProxy') + ], PaginationComp.prototype, "paginationProxy", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowNodeBlockLoader') + ], PaginationComp.prototype, "rowNodeBlockLoader", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('btFirst') + ], PaginationComp.prototype, "btFirst", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('btPrevious') + ], PaginationComp.prototype, "btPrevious", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('btNext') + ], PaginationComp.prototype, "btNext", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('btLast') + ], PaginationComp.prototype, "btLast", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('lbRecordCount') + ], PaginationComp.prototype, "lbRecordCount", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('lbFirstRowOnPage') + ], PaginationComp.prototype, "lbFirstRowOnPage", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('lbLastRowOnPage') + ], PaginationComp.prototype, "lbLastRowOnPage", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('lbCurrent') + ], PaginationComp.prototype, "lbCurrent", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('lbTotal') + ], PaginationComp.prototype, "lbTotal", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], PaginationComp.prototype, "postConstruct", null); + return PaginationComp; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); + + + +/***/ }), +/* 206 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ResizeObserverService", function() { return ResizeObserverService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(14); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(42); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + +var DEBOUNCE_DELAY = 50; +var ResizeObserverService = /** @class */ (function (_super) { + __extends(ResizeObserverService, _super); + function ResizeObserverService() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.polyfillFunctions = []; + return _this; + } + ResizeObserverService.prototype.observeResize = function (element, callback) { var _this = this; - // the column in the event is from the master grid. need to - // look up the equivalent from this (other) grid - var masterColumn = colEvent.column; - var otherColumn; - if (masterColumn) { - otherColumn = this.columnController.getPrimaryColumn(masterColumn.getColId()); + var eDocument = this.gridOptionsWrapper.getDocument(); + var win = (eDocument.defaultView || window); + // this gets fired too often and might cause some relayout issues + // so we add a debounce to the callback here to avoid the flashing effect. + var debouncedCallback = Object(_utils_function__WEBPACK_IMPORTED_MODULE_2__["debounce"])(callback, DEBOUNCE_DELAY); + var useBrowserResizeObserver = function () { + var resizeObserver = new win.ResizeObserver(debouncedCallback); + resizeObserver.observe(element); + return function () { return resizeObserver.disconnect(); }; + }; + var usePolyfill = function () { + // initialise to the current width and height, so first call will have no changes + var widthLastTime = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["offsetWidth"])(element); + var heightLastTime = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["offsetHeight"])(element); + // when finished, this gets turned to false. + var running = true; + var periodicallyCheckWidthAndHeight = function () { + if (running) { + var newWidth = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["offsetWidth"])(element); + var newHeight = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["offsetHeight"])(element); + var changed = newWidth !== widthLastTime || newHeight !== heightLastTime; + if (changed) { + widthLastTime = newWidth; + heightLastTime = newHeight; + callback(); + } + _this.doNextPolyfillTurn(periodicallyCheckWidthAndHeight); + } + }; + periodicallyCheckWidthAndHeight(); + // the callback function we return sets running to false + return function () { return running = false; }; + }; + var suppressResize = this.gridOptionsWrapper.isSuppressBrowserResizeObserver(); + var resizeObserverExists = !!win.ResizeObserver; + if (resizeObserverExists && !suppressResize) { + return useBrowserResizeObserver(); } - // if event was with respect to a master column, that is not present in this - // grid, then we ignore the event - if (masterColumn && !otherColumn) { + return usePolyfill(); + }; + ResizeObserverService.prototype.doNextPolyfillTurn = function (func) { + this.polyfillFunctions.push(func); + this.schedulePolyfill(); + }; + ResizeObserverService.prototype.schedulePolyfill = function () { + var _this = this; + if (this.polyfillScheduled) { return; } - // in time, all the methods below should use the column ids, it's a more generic way - // of handling columns, and also allows for single or multi column events - var columnIds = this.getColumnIds(colEvent); - var masterColumns = this.getMasterColumns(colEvent); - switch (colEvent.type) { - case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_MOVED: - var movedEvent = colEvent; - this.logger.log("onColumnEvent-> processing " + colEvent.type + " toIndex = " + movedEvent.toIndex); - this.columnController.moveColumns(columnIds, movedEvent.toIndex, "alignedGridChanged"); - break; - case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_VISIBLE: - var visibleEvent = colEvent; - this.logger.log("onColumnEvent-> processing " + colEvent.type + " visible = " + visibleEvent.visible); - this.columnController.setColumnsVisible(columnIds, visibleEvent.visible, "alignedGridChanged"); - break; - case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PINNED: - var pinnedEvent = colEvent; - this.logger.log("onColumnEvent-> processing " + colEvent.type + " pinned = " + pinnedEvent.pinned); - this.columnController.setColumnsPinned(columnIds, pinnedEvent.pinned, "alignedGridChanged"); - break; - case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_RESIZED: - var resizedEvent_1 = colEvent; - masterColumns.forEach(function (column) { - _this.logger.log("onColumnEvent-> processing " + colEvent.type + " actualWidth = " + column.getActualWidth()); - var columnWidths = [{ key: column.getColId(), newWidth: column.getActualWidth() }]; - _this.columnController.setColumnWidths(columnWidths, false, resizedEvent_1.finished, "alignedGridChanged"); - }); - break; - } - var isVerticalScrollShowing = this.gridPanel.isVerticalScrollShowing(); - var alignedGrids = this.gridOptionsWrapper.getAlignedGrids(); - alignedGrids.forEach(function (grid) { - grid.api.setAlwaysShowVerticalScroll(isVerticalScrollShowing); - }); + var executeAllFuncs = function () { + var funcs = _this.polyfillFunctions; + // make sure set scheduled to false and clear clear array + // before executing the funcs, as the funcs could add more funcs + _this.polyfillScheduled = false; + _this.polyfillFunctions = []; + funcs.forEach(function (f) { return f(); }); + }; + this.polyfillScheduled = true; + this.getFrameworkOverrides().setTimeout(executeAllFuncs, DEBOUNCE_DELAY); }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], AlignedGridsService.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController') - ], AlignedGridsService.prototype, "columnController", void 0); - __decorate([ - __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Qualifier"])('loggerFactory')) - ], AlignedGridsService.prototype, "setBeans", null); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], AlignedGridsService.prototype, "init", null); - AlignedGridsService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('alignedGridsService') - ], AlignedGridsService); - return AlignedGridsService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"])); + ResizeObserverService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('resizeObserverService') + ], ResizeObserverService); + return ResizeObserverService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 158 */ +/* 207 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgComponentUtils", function() { return AgComponentUtils; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "OverlayWrapperComponent", function() { return OverlayWrapperComponent; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(36); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(42); +/* harmony import */ var _styling_layoutFeature__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(165); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(24); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -37289,84 +45515,171 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var AgComponentUtils = /** @class */ (function (_super) { - __extends(AgComponentUtils, _super); - function AgComponentUtils() { - return _super !== null && _super.apply(this, arguments) || this; + + + +var LoadingType; +(function (LoadingType) { + LoadingType[LoadingType["Loading"] = 0] = "Loading"; + LoadingType[LoadingType["NoRows"] = 1] = "NoRows"; +})(LoadingType || (LoadingType = {})); +var OverlayWrapperComponent = /** @class */ (function (_super) { + __extends(OverlayWrapperComponent, _super); + function OverlayWrapperComponent() { + var _this = _super.call(this, OverlayWrapperComponent.TEMPLATE) || this; + _this.inProgress = false; + _this.destroyRequested = false; + return _this; } - AgComponentUtils.prototype.adaptFunction = function (propertyName, hardcodedJsFunction, componentFromFramework, source) { - if (hardcodedJsFunction == null) { - return { - component: null, - componentFromFramework: componentFromFramework, - source: source, - paramsFromSelector: null - }; + OverlayWrapperComponent.prototype.updateLayoutClasses = function (cssClass, params) { + var overlayWrapperClassList = this.eOverlayWrapper.classList; + overlayWrapperClassList.toggle(_styling_layoutFeature__WEBPACK_IMPORTED_MODULE_4__["LayoutCssClasses"].AUTO_HEIGHT, params.autoHeight); + overlayWrapperClassList.toggle(_styling_layoutFeature__WEBPACK_IMPORTED_MODULE_4__["LayoutCssClasses"].NORMAL, params.normal); + overlayWrapperClassList.toggle(_styling_layoutFeature__WEBPACK_IMPORTED_MODULE_4__["LayoutCssClasses"].PRINT, params.print); + }; + OverlayWrapperComponent.prototype.postConstruct = function () { + this.createManagedBean(new _styling_layoutFeature__WEBPACK_IMPORTED_MODULE_4__["LayoutFeature"](this)); + this.setDisplayed(false); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_5__["Events"].EVENT_ROW_DATA_CHANGED, this.onRowDataChanged.bind(this)); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_5__["Events"].EVENT_ROW_DATA_UPDATED, this.onRowDataChanged.bind(this)); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_5__["Events"].EVENT_NEW_COLUMNS_LOADED, this.onNewColumnsLoaded.bind(this)); + if (this.gridOptionsWrapper.isRowModelDefault() && !this.gridOptionsWrapper.getRowData()) { + this.showLoadingOverlay(); } - var metadata = this.componentMetadataProvider.retrieve(propertyName); - if (metadata && metadata.functionAdapter) { - return { - componentFromFramework: componentFromFramework, - component: metadata.functionAdapter(hardcodedJsFunction), - source: source, - paramsFromSelector: null - }; + this.gridApi.registerOverlayWrapperComp(this); + }; + OverlayWrapperComponent.prototype.setWrapperTypeClass = function (loadingType) { + var overlayWrapperClassList = this.eOverlayWrapper.classList; + overlayWrapperClassList.toggle('ag-overlay-loading-wrapper', loadingType === LoadingType.Loading); + overlayWrapperClassList.toggle('ag-overlay-no-rows-wrapper', loadingType === LoadingType.NoRows); + }; + OverlayWrapperComponent.prototype.showLoadingOverlay = function () { + if (this.gridOptionsWrapper.isSuppressLoadingOverlay()) { + return; } - return null; + var params = { + api: this.gridOptionsWrapper.getApi() + }; + var compDetails = this.userComponentFactory.getLoadingOverlayCompDetails(params); + var promise = compDetails.newAgStackInstance(); + this.showOverlay(promise, LoadingType.Loading); }; - AgComponentUtils.prototype.adaptCellRendererFunction = function (callback) { - var Adapter = /** @class */ (function () { - function Adapter() { - } - Adapter.prototype.refresh = function (params) { - return false; - }; - Adapter.prototype.getGui = function () { - var callbackResult = callback(this.params); - var type = typeof callbackResult; - if (type === 'string' || type === 'number' || type === 'boolean') { - return _utils__WEBPACK_IMPORTED_MODULE_2__["_"].loadTemplate('' + callbackResult + ''); - } - else { - return callbackResult; + OverlayWrapperComponent.prototype.showNoRowsOverlay = function () { + if (this.gridOptionsWrapper.isSuppressNoRowsOverlay()) { + return; + } + var params = { + api: this.gridOptionsWrapper.getApi() + }; + var compDetails = this.userComponentFactory.getNoRowsOverlayCompDetails(params); + var promise = compDetails.newAgStackInstance(); + this.showOverlay(promise, LoadingType.NoRows); + }; + OverlayWrapperComponent.prototype.showOverlay = function (workItem, type) { + var _this = this; + if (this.inProgress) { + return; + } + this.setWrapperTypeClass(type); + this.destroyActiveOverlay(); + this.inProgress = true; + if (workItem) { + workItem.then(function (comp) { + _this.inProgress = false; + _this.eOverlayWrapper.appendChild(comp.getGui()); + _this.activeOverlay = comp; + if (_this.destroyRequested) { + _this.destroyRequested = false; + _this.destroyActiveOverlay(); } - }; - Adapter.prototype.init = function (params) { - this.params = params; - }; - return Adapter; - }()); - return Adapter; + }); + } + this.setDisplayed(true); }; - AgComponentUtils.prototype.doesImplementIComponent = function (candidate) { - if (!candidate) { - return false; + OverlayWrapperComponent.prototype.destroyActiveOverlay = function () { + if (this.inProgress) { + this.destroyRequested = true; + return; + } + if (!this.activeOverlay) { + return; + } + this.activeOverlay = this.getContext().destroyBean(this.activeOverlay); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["clearElement"])(this.eOverlayWrapper); + }; + OverlayWrapperComponent.prototype.hideOverlay = function () { + this.destroyActiveOverlay(); + this.setDisplayed(false); + }; + OverlayWrapperComponent.prototype.destroy = function () { + this.destroyActiveOverlay(); + _super.prototype.destroy.call(this); + }; + OverlayWrapperComponent.prototype.showOrHideOverlay = function () { + var isEmpty = this.paginationProxy.isEmpty(); + var isSuppressNoRowsOverlay = this.gridOptionsWrapper.isSuppressNoRowsOverlay(); + if (isEmpty && !isSuppressNoRowsOverlay) { + this.showNoRowsOverlay(); + } + else { + this.hideOverlay(); + } + }; + OverlayWrapperComponent.prototype.onRowDataChanged = function () { + this.showOrHideOverlay(); + }; + OverlayWrapperComponent.prototype.onNewColumnsLoaded = function () { + // hide overlay if columns and rows exist, this can happen if columns are loaded after data. + // this problem exists before of the race condition between the services (column controller in this case) + // and the view (grid panel). if the model beans were all initialised first, and then the view beans second, + // this race condition would not happen. + if (this.columnModel.isReady() && !this.paginationProxy.isEmpty()) { + this.hideOverlay(); } - return candidate.prototype && 'getGui' in candidate.prototype; }; + // wrapping in outer div, and wrapper, is needed to center the loading icon + // The idea for centering came from here: http://www.vanseodesign.com/css/vertical-centering/ + OverlayWrapperComponent.TEMPLATE = "\n
\n
\n
\n
\n
"; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("componentMetadataProvider") - ], AgComponentUtils.prototype, "componentMetadataProvider", void 0); - AgComponentUtils = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])("agComponentUtils") - ], AgComponentUtils); - return AgComponentUtils; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('userComponentFactory') + ], OverlayWrapperComponent.prototype, "userComponentFactory", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('paginationProxy') + ], OverlayWrapperComponent.prototype, "paginationProxy", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') + ], OverlayWrapperComponent.prototype, "gridApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], OverlayWrapperComponent.prototype, "columnModel", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('eOverlayWrapper') + ], OverlayWrapperComponent.prototype, "eOverlayWrapper", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], OverlayWrapperComponent.prototype, "postConstruct", null); + return OverlayWrapperComponent; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_1__["Component"])); /***/ }), -/* 159 */ +/* 208 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ComponentMetadataProvider", function() { return ComponentMetadataProvider; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgGroupComponent", function() { return AgGroupComponent; }); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _utils_icon__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(48); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(42); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(65); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(44); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -37391,283 +45704,232 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta }; -var ComponentMetadataProvider = /** @class */ (function (_super) { - __extends(ComponentMetadataProvider, _super); - function ComponentMetadataProvider() { - return _super !== null && _super.apply(this, arguments) || this; - } - ComponentMetadataProvider.prototype.postConstruct = function () { - this.componentMetaData = { - dateComponent: { - mandatoryMethodList: ['getDate', 'setDate'], - optionalMethodList: ['afterGuiAttached', 'setInputPlaceholder'] - }, - detailCellRenderer: { - mandatoryMethodList: [], - optionalMethodList: ['refresh'] - }, - headerComponent: { - mandatoryMethodList: [], - optionalMethodList: [] - }, - headerGroupComponent: { - mandatoryMethodList: [], - optionalMethodList: [] - }, - loadingCellRenderer: { - mandatoryMethodList: [], - optionalMethodList: [] - }, - loadingOverlayComponent: { - mandatoryMethodList: [], - optionalMethodList: [] - }, - noRowsOverlayComponent: { - mandatoryMethodList: [], - optionalMethodList: [] - }, - floatingFilterComponent: { - mandatoryMethodList: ['onParentModelChanged'], - optionalMethodList: ['afterGuiAttached'] - }, - floatingFilterWrapperComponent: { - mandatoryMethodList: [], - optionalMethodList: [] - }, - cellRenderer: { - mandatoryMethodList: [], - optionalMethodList: ['refresh', 'afterGuiAttached'], - functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils) - }, - cellEditor: { - mandatoryMethodList: ['getValue'], - optionalMethodList: ['isPopup', 'isCancelBeforeStart', 'isCancelAfterEnd', 'getPopupPosition', 'focusIn', 'focusOut', 'afterGuiAttached'] - }, - innerRenderer: { - mandatoryMethodList: [], - optionalMethodList: ['afterGuiAttached'], - functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils) - }, - fullWidthCellRenderer: { - mandatoryMethodList: [], - optionalMethodList: ['refresh', 'afterGuiAttached'], - functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils) - }, - pinnedRowCellRenderer: { - mandatoryMethodList: [], - optionalMethodList: ['refresh', 'afterGuiAttached'], - functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils) - }, - groupRowInnerRenderer: { - mandatoryMethodList: [], - optionalMethodList: ['afterGuiAttached'], - functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils) - }, - groupRowRenderer: { - mandatoryMethodList: [], - optionalMethodList: ['afterGuiAttached'], - functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils) - }, - filter: { - mandatoryMethodList: ['isFilterActive', 'doesFilterPass', 'getModel', 'setModel'], - optionalMethodList: ['afterGuiAttached', 'onNewRowsLoaded', 'getModelAsString', 'onFloatingFilterChanged'] - }, - filterComponent: { - mandatoryMethodList: ['isFilterActive', 'doesFilterPass', 'getModel', 'setModel'], - optionalMethodList: ['afterGuiAttached', 'onNewRowsLoaded', 'getModelAsString', 'onFloatingFilterChanged'] - }, - statusPanel: { - mandatoryMethodList: [], - optionalMethodList: ['afterGuiAttached'], - }, - toolPanel: { - mandatoryMethodList: [], - optionalMethodList: ['refresh', 'afterGuiAttached'] - }, - tooltipComponent: { - mandatoryMethodList: [], - optionalMethodList: [] - } - }; - }; - ComponentMetadataProvider.prototype.retrieve = function (name) { - return this.componentMetaData[name]; - }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("agComponentUtils") - ], ComponentMetadataProvider.prototype, "agComponentUtils", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], ComponentMetadataProvider.prototype, "postConstruct", null); - ComponentMetadataProvider = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])("componentMetadataProvider") - ], ComponentMetadataProvider); - return ComponentMetadataProvider; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); -/***/ }), -/* 160 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Beans", function() { return Beans; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -/** Using the IoC has a slight performance consideration, which is no problem most of the - * time, unless we are trashing objects - which is the case when scrolling and rowComp - * and cellComp. So for performance reasons, RowComp and CellComp do not get autowired - * with the IoC. Instead they get passed this object which is all the beans the RowComp - * and CellComp need. Not autowiring all the cells gives performance improvement. */ -var Beans = /** @class */ (function () { - function Beans() { +var AgGroupComponent = /** @class */ (function (_super) { + __extends(AgGroupComponent, _super); + function AgGroupComponent(params) { + if (params === void 0) { params = {}; } + var _this = _super.call(this, AgGroupComponent.getTemplate(params)) || this; + _this.suppressEnabledCheckbox = true; + _this.suppressOpenCloseIcons = false; + var title = params.title, enabled = params.enabled, items = params.items, suppressEnabledCheckbox = params.suppressEnabledCheckbox, suppressOpenCloseIcons = params.suppressOpenCloseIcons; + _this.title = title; + _this.cssIdentifier = params.cssIdentifier || 'default'; + _this.enabled = enabled != null ? enabled : true; + _this.items = items || []; + _this.alignItems = params.alignItems || 'center'; + if (suppressEnabledCheckbox != null) { + _this.suppressEnabledCheckbox = suppressEnabledCheckbox; + } + if (suppressOpenCloseIcons != null) { + _this.suppressOpenCloseIcons = suppressOpenCloseIcons; + } + return _this; } - Beans.prototype.registerGridComp = function (gridPanel) { - this.gridPanel = gridPanel; + AgGroupComponent.getTemplate = function (params) { + var cssIdentifier = params.cssIdentifier || 'default'; + var direction = params.direction || 'vertical'; + return /* html */ "
\n
\n \n \n \n
\n
\n \n
\n
\n
"; }; - Beans.prototype.postConstruct = function () { - this.doingMasterDetail = this.gridOptionsWrapper.isMasterDetail(); + AgGroupComponent.prototype.postConstruct = function () { + if (this.items.length) { + var initialItems = this.items; + this.items = []; + this.addItems(initialItems); + } + var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc(); + this.cbGroupEnabled.setLabel(localeTextFunc('enabled', 'Enabled')); + if (this.title) { + this.setTitle(this.title); + } + if (this.enabled) { + this.setEnabled(this.enabled); + } + this.setAlignItems(this.alignItems); + this.hideEnabledCheckbox(this.suppressEnabledCheckbox); + this.hideOpenCloseIcons(this.suppressOpenCloseIcons); + this.setupExpandContract(); + this.refreshAriaStatus(); + this.refreshChildDisplay(); }; + AgGroupComponent.prototype.setupExpandContract = function () { + var _this = this; + this.eGroupClosedIcon.appendChild(Object(_utils_icon__WEBPACK_IMPORTED_MODULE_3__["createIcon"])('columnSelectClosed', this.gridOptionsWrapper, null)); + this.eGroupOpenedIcon.appendChild(Object(_utils_icon__WEBPACK_IMPORTED_MODULE_3__["createIcon"])('columnSelectOpen', this.gridOptionsWrapper, null)); + this.addManagedListener(this.eTitleBar, 'click', function () { return _this.toggleGroupExpand(); }); + this.addManagedListener(this.eTitleBar, 'keydown', function (e) { + switch (e.key) { + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_5__["KeyCode"].ENTER: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_5__["KeyCode"].SPACE: + e.preventDefault(); + _this.toggleGroupExpand(); + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_5__["KeyCode"].RIGHT: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_5__["KeyCode"].LEFT: + e.preventDefault(); + _this.toggleGroupExpand(e.key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_5__["KeyCode"].RIGHT); + break; + } + }); + }; + AgGroupComponent.prototype.refreshAriaStatus = function () { + if (!this.suppressOpenCloseIcons) { + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_6__["setAriaExpanded"])(this.eTitleBar, this.expanded); + } + }; + AgGroupComponent.prototype.refreshChildDisplay = function () { + var showIcon = !this.suppressOpenCloseIcons; + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setDisplayed"])(this.eToolbar, this.expanded && !this.suppressEnabledCheckbox); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setDisplayed"])(this.eGroupOpenedIcon, showIcon && this.expanded); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setDisplayed"])(this.eGroupClosedIcon, showIcon && !this.expanded); + }; + AgGroupComponent.prototype.isExpanded = function () { + return this.expanded; + }; + AgGroupComponent.prototype.setAlignItems = function (alignment) { + if (this.alignItems !== alignment) { + this.removeCssClass("ag-group-item-alignment-" + this.alignItems); + } + this.alignItems = alignment; + var newCls = "ag-group-item-alignment-" + this.alignItems; + this.addCssClass(newCls); + return this; + }; + AgGroupComponent.prototype.toggleGroupExpand = function (expanded) { + if (this.suppressOpenCloseIcons) { + this.expanded = true; + this.refreshChildDisplay(); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setDisplayed"])(this.eContainer, true); + return this; + } + expanded = expanded != null ? expanded : !this.expanded; + if (this.expanded === expanded) { + return this; + } + this.expanded = expanded; + this.refreshAriaStatus(); + this.refreshChildDisplay(); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setDisplayed"])(this.eContainer, expanded); + this.dispatchEvent({ type: this.expanded ? AgGroupComponent.EVENT_EXPANDED : AgGroupComponent.EVENT_COLLAPSED }); + return this; + }; + AgGroupComponent.prototype.addItems = function (items) { + var _this = this; + items.forEach(function (item) { return _this.addItem(item); }); + }; + AgGroupComponent.prototype.addItem = function (item) { + var container = this.eContainer; + var el = item instanceof _component__WEBPACK_IMPORTED_MODULE_0__["Component"] ? item.getGui() : item; + el.classList.add('ag-group-item', "ag-" + this.cssIdentifier + "-group-item"); + container.appendChild(el); + this.items.push(el); + }; + AgGroupComponent.prototype.hideItem = function (hide, index) { + var itemToHide = this.items[index]; + itemToHide.classList.toggle('ag-hidden', hide); + }; + AgGroupComponent.prototype.setTitle = function (title) { + this.eTitle.innerText = title; + return this; + }; + AgGroupComponent.prototype.addCssClassToTitleBar = function (cssClass) { + this.eTitleBar.classList.add(cssClass); + }; + AgGroupComponent.prototype.setEnabled = function (enabled, skipToggle) { + this.enabled = enabled; + this.refreshDisabledStyles(); + this.toggleGroupExpand(enabled); + if (!skipToggle) { + this.cbGroupEnabled.setValue(enabled); + } + return this; + }; + AgGroupComponent.prototype.isEnabled = function () { + return this.enabled; + }; + AgGroupComponent.prototype.onEnableChange = function (callbackFn) { + var _this = this; + this.cbGroupEnabled.onValueChange(function (newSelection) { + _this.setEnabled(newSelection, true); + callbackFn(newSelection); + }); + return this; + }; + AgGroupComponent.prototype.hideEnabledCheckbox = function (hide) { + this.suppressEnabledCheckbox = hide; + this.refreshChildDisplay(); + this.refreshDisabledStyles(); + return this; + }; + AgGroupComponent.prototype.hideOpenCloseIcons = function (hide) { + this.suppressOpenCloseIcons = hide; + if (hide) { + this.toggleGroupExpand(true); + } + return this; + }; + AgGroupComponent.prototype.refreshDisabledStyles = function () { + this.addOrRemoveCssClass('ag-disabled', !this.enabled); + if (this.suppressEnabledCheckbox && !this.enabled) { + this.eTitleBar.classList.add('ag-disabled-group-title-bar'); + this.eTitleBar.removeAttribute('tabindex'); + } + else { + this.eTitleBar.classList.remove('ag-disabled-group-title-bar'); + this.eTitleBar.setAttribute('tabindex', '0'); + } + this.eContainer.classList.toggle('ag-disabled-group-container', !this.enabled); + }; + AgGroupComponent.EVENT_EXPANDED = 'expanded'; + AgGroupComponent.EVENT_COLLAPSED = 'collapsed'; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('paginationProxy') - ], Beans.prototype, "paginationProxy", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('context') - ], Beans.prototype, "context", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') - ], Beans.prototype, "columnApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') - ], Beans.prototype, "gridApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], Beans.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('expressionService') - ], Beans.prototype, "expressionService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer') - ], Beans.prototype, "rowRenderer", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('$compile') - ], Beans.prototype, "$compile", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('templateService') - ], Beans.prototype, "templateService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueService') - ], Beans.prototype, "valueService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('eventService') - ], Beans.prototype, "eventService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], Beans.prototype, "columnController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('headerNavigationService') - ], Beans.prototype, "headerNavigationService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnAnimationService') - ], Beans.prototype, "columnAnimationService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('rangeController') - ], Beans.prototype, "rangeController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusController') - ], Beans.prototype, "focusController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('contextMenuFactory') - ], Beans.prototype, "contextMenuFactory", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('cellRendererFactory') - ], Beans.prototype, "cellRendererFactory", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('popupService') - ], Beans.prototype, "popupService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueFormatterService') - ], Beans.prototype, "valueFormatterService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('stylingService') - ], Beans.prototype, "stylingService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnHoverService') - ], Beans.prototype, "columnHoverService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('userComponentFactory') - ], Beans.prototype, "userComponentFactory", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('animationFrameService') - ], Beans.prototype, "taskQueue", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('dragAndDropService') - ], Beans.prototype, "dragAndDropService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('sortController') - ], Beans.prototype, "sortController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager') - ], Beans.prototype, "filterManager", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('maxDivHeightScaler') - ], Beans.prototype, "maxDivHeightScaler", void 0); + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eTitleBar') + ], AgGroupComponent.prototype, "eTitleBar", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('frameworkOverrides') - ], Beans.prototype, "frameworkOverrides", void 0); + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eGroupOpenedIcon') + ], AgGroupComponent.prototype, "eGroupOpenedIcon", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('detailRowCompCache') - ], Beans.prototype, "detailRowCompCache", void 0); + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eGroupClosedIcon') + ], AgGroupComponent.prototype, "eGroupClosedIcon", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('cellPositionUtils') - ], Beans.prototype, "cellPositionUtils", void 0); + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eToolbar') + ], AgGroupComponent.prototype, "eToolbar", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowPositionUtils') - ], Beans.prototype, "rowPositionUtils", void 0); + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('cbGroupEnabled') + ], AgGroupComponent.prototype, "cbGroupEnabled", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('selectionController') - ], Beans.prototype, "selectionController", void 0); + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eTitle') + ], AgGroupComponent.prototype, "eTitle", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('selectionHandleFactory') - ], Beans.prototype, "selectionHandleFactory", void 0); + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eContainer') + ], AgGroupComponent.prototype, "eContainer", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], Beans.prototype, "postConstruct", null); - Beans = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('beans') - ], Beans); - return Beans; -}()); + _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] + ], AgGroupComponent.prototype, "postConstruct", null); + return AgGroupComponent; +}(_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); /***/ }), -/* 161 */ +/* 209 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Environment", function() { return Environment; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgDialog", function() { return AgDialog; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _agPanel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(210); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(36); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(42); +/* harmony import */ var _utils_icon__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(48); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -37684,6 +45946,17 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); +var __assign = (undefined && undefined.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); @@ -37693,154 +45966,160 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var MAT_GRID_SIZE = 8; -var BASE_GRID_SIZE = 4; -var BALHAM_GRID_SIZE = 4; -var ALPINE_GRID_SIZE = 6; -var HARD_CODED_SIZES = { - // this item is required for custom themes - 'ag-theme-custom': { - headerHeight: 25, - headerCellMinWidth: 24, - listItemHeight: BASE_GRID_SIZE * 5, - rowHeight: 25, - chartMenuPanelWidth: 220 - }, - 'ag-theme-material': { - headerHeight: MAT_GRID_SIZE * 7, - headerCellMinWidth: 48, - listItemHeight: MAT_GRID_SIZE * 5, - rowHeight: MAT_GRID_SIZE * 6, - chartMenuPanelWidth: 240 - }, - 'ag-theme-balham': { - headerHeight: BALHAM_GRID_SIZE * 8, - headerCellMinWidth: 24, - listItemHeight: BALHAM_GRID_SIZE * 7, - rowHeight: BALHAM_GRID_SIZE * 7, - chartMenuPanelWidth: 220 - }, - 'ag-theme-alpine': { - headerHeight: ALPINE_GRID_SIZE * 8, - headerCellMinWidth: 36, - listItemHeight: ALPINE_GRID_SIZE * 5, - rowHeight: ALPINE_GRID_SIZE * 7, - chartMenuPanelWidth: 240 - } -}; -/** - * this object contains a list of Sass variables and an array - * of CSS styles required to get the correct value. - * eg. $virtual-item-height requires a structure, so we can get its height. - *
- *
- *
- *
- *
- */ -var SASS_PROPERTY_BUILDER = { - headerHeight: ['ag-header-row'], - headerCellMinWidth: ['ag-header-cell'], - listItemHeight: ['ag-virtual-list-item'], - rowHeight: ['ag-row'], - chartMenuPanelWidth: ['ag-chart-docked-container'] -}; -var CALCULATED_SIZES = {}; -var Environment = /** @class */ (function (_super) { - __extends(Environment, _super); - function Environment() { - return _super !== null && _super.apply(this, arguments) || this; + + +var AgDialog = /** @class */ (function (_super) { + __extends(AgDialog, _super); + function AgDialog(config) { + var _this = _super.call(this, __assign(__assign({}, config), { popup: true })) || this; + _this.isMaximizable = false; + _this.isMaximized = false; + _this.maximizeListeners = []; + _this.resizeListenerDestroy = null; + _this.lastPosition = { + x: 0, + y: 0, + width: 0, + height: 0 + }; + return _this; } - Environment.prototype.getSassVariable = function (theme, key) { - var useTheme = 'ag-theme-' + (theme.match('material') ? 'material' : theme.match('balham') ? 'balham' : theme.match('alpine') ? 'alpine' : 'custom'); - var defaultValue = HARD_CODED_SIZES[useTheme][key]; - var calculatedValue = 0; - if (!CALCULATED_SIZES[theme]) { - CALCULATED_SIZES[theme] = {}; + AgDialog.prototype.postConstruct = function () { + var _this = this; + var eGui = this.getGui(); + var _a = this.config, movable = _a.movable, resizable = _a.resizable, maximizable = _a.maximizable; + this.addCssClass('ag-dialog'); + _super.prototype.postConstruct.call(this); + this.addManagedListener(eGui, 'focusin', function (e) { + if (eGui.contains(e.relatedTarget)) { + return; + } + _this.popupService.bringPopupToFront(eGui); + }); + if (movable) { + this.setMovable(movable); } - if (CALCULATED_SIZES[theme][key]) { - return CALCULATED_SIZES[theme][key]; + if (maximizable) { + this.setMaximizable(maximizable); } - if (SASS_PROPERTY_BUILDER[key]) { - var classList = SASS_PROPERTY_BUILDER[key]; - var div = document.createElement('div'); - div.style.position = 'absolute'; - var el = classList.reduce(function (el, currentClass, idx) { - if (idx === 0) { - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(el, theme); - } - var div = document.createElement('div'); - div.style.position = 'static'; - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(div, currentClass); - el.appendChild(div); - return div; - }, div); - if (document.body) { - document.body.appendChild(div); - var sizeName = key.toLowerCase().indexOf('height') !== -1 ? 'height' : 'width'; - calculatedValue = parseInt(window.getComputedStyle(el)[sizeName], 10); - document.body.removeChild(div); - } + if (resizable) { + this.setResizable(resizable); } - CALCULATED_SIZES[theme][key] = calculatedValue || defaultValue; - return CALCULATED_SIZES[theme][key]; }; - Environment.prototype.isThemeDark = function () { - var theme = this.getTheme().theme; - return !!theme && theme.indexOf('dark') >= 0; + AgDialog.prototype.renderComponent = function () { + var eGui = this.getGui(); + var _a = this.config, alwaysOnTop = _a.alwaysOnTop, modal = _a.modal, title = _a.title; + var translate = this.gridOptionsWrapper.getLocaleTextFunc(); + var addPopupRes = this.popupService.addPopup({ + modal: modal, + eChild: eGui, + closeOnEsc: true, + closedCallback: this.destroy.bind(this), + alwaysOnTop: alwaysOnTop, + ariaLabel: title || translate('ariaLabelDialog', 'Dialog') + }); + if (addPopupRes) { + this.close = addPopupRes.hideFunc; + } }; - Environment.prototype.chartMenuPanelWidth = function () { - var theme = this.getTheme().themeFamily; - return this.getSassVariable(theme, 'chartMenuPanelWidth'); + AgDialog.prototype.toggleMaximize = function () { + var position = this.positionableFeature.getPosition(); + if (this.isMaximized) { + var _a = this.lastPosition, x = _a.x, y = _a.y, width = _a.width, height = _a.height; + this.setWidth(width); + this.setHeight(height); + this.positionableFeature.offsetElement(x, y); + } + else { + this.lastPosition.width = this.getWidth(); + this.lastPosition.height = this.getHeight(); + this.lastPosition.x = position.x; + this.lastPosition.y = position.y; + this.positionableFeature.offsetElement(0, 0); + this.setHeight('100%'); + this.setWidth('100%'); + } + this.isMaximized = !this.isMaximized; + this.refreshMaximizeIcon(); }; - Environment.prototype.getTheme = function () { - var reg = /\bag-(material|(?:theme-([\w\-]*)))\b/; - var el = this.eGridDiv; - var themeMatch; - while (el) { - themeMatch = reg.exec(el.className); - if (!themeMatch) { - el = el.parentElement; - } - else { - break; - } + AgDialog.prototype.refreshMaximizeIcon = function () { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["setDisplayed"])(this.maximizeIcon, !this.isMaximized); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["setDisplayed"])(this.minimizeIcon, this.isMaximized); + }; + AgDialog.prototype.clearMaximizebleListeners = function () { + if (this.maximizeListeners.length) { + this.maximizeListeners.forEach(function (destroyListener) { return destroyListener(); }); + this.maximizeListeners.length = 0; } - if (!themeMatch) { - return {}; + if (this.resizeListenerDestroy) { + this.resizeListenerDestroy(); + this.resizeListenerDestroy = null; } - var theme = themeMatch[0]; - var usingOldTheme = themeMatch[2] === undefined; - if (usingOldTheme) { - var newTheme_1 = theme.replace('ag-', 'ag-theme-'); - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].doOnce(function () { return console.warn("ag-Grid: As of v19 old theme are no longer provided. Please replace " + theme + " with " + newTheme_1 + "."); }, 'using-old-theme'); + }; + AgDialog.prototype.destroy = function () { + this.maximizeButtonComp = this.destroyBean(this.maximizeButtonComp); + this.clearMaximizebleListeners(); + _super.prototype.destroy.call(this); + }; + AgDialog.prototype.setResizable = function (resizable) { + this.positionableFeature.setResizable(resizable); + }; + AgDialog.prototype.setMovable = function (movable) { + this.positionableFeature.setMovable(movable, this.eTitleBar); + }; + AgDialog.prototype.setMaximizable = function (maximizable) { + var _this = this; + if (!maximizable) { + this.clearMaximizebleListeners(); + if (this.maximizeButtonComp) { + this.destroyBean(this.maximizeButtonComp); + this.maximizeButtonComp = this.maximizeIcon = this.minimizeIcon = undefined; + } + return; } - return { theme: theme, el: el, themeFamily: theme.replace(/-dark$/, '') }; + var eTitleBar = this.eTitleBar; + if (!eTitleBar || maximizable === this.isMaximizable) { + return; + } + var maximizeButtonComp = this.maximizeButtonComp = + this.createBean(new _component__WEBPACK_IMPORTED_MODULE_2__["Component"](/* html */ "
")); + var eGui = maximizeButtonComp.getGui(); + eGui.appendChild(this.maximizeIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_4__["createIconNoSpan"])('maximize', this.gridOptionsWrapper)); + this.maximizeIcon.classList.add('ag-panel-title-bar-button-icon'); + eGui.appendChild(this.minimizeIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_4__["createIconNoSpan"])('minimize', this.gridOptionsWrapper)); + this.minimizeIcon.classList.add('ag-panel-title-bar-button-icon', 'ag-hidden'); + maximizeButtonComp.addManagedListener(eGui, 'click', this.toggleMaximize.bind(this)); + this.addTitleBarButton(maximizeButtonComp, 0); + this.maximizeListeners.push(this.addManagedListener(eTitleBar, 'dblclick', this.toggleMaximize.bind(this))); + this.resizeListenerDestroy = this.addManagedListener(this, 'resize', function () { + _this.isMaximized = false; + _this.refreshMaximizeIcon(); + }); }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('eGridDiv') - ], Environment.prototype, "eGridDiv", void 0); - Environment = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('environment') - ], Environment); - return Environment; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('popupService') + ], AgDialog.prototype, "popupService", void 0); + return AgDialog; +}(_agPanel__WEBPACK_IMPORTED_MODULE_1__["AgPanel"])); /***/ }), -/* 162 */ +/* 210 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AnimationFrameService", function() { return AnimationFrameService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(44); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgPanel", function() { return AgPanel; }); +/* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(36); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(42); +/* harmony import */ var _utils_icon__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(48); +/* harmony import */ var _rendering_features_positionableFeature__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(211); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -37866,181 +46145,187 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var AnimationFrameService = /** @class */ (function (_super) { - __extends(AnimationFrameService, _super); - function AnimationFrameService() { - var _this = _super !== null && _super.apply(this, arguments) || this; - // p1 and p2 are create tasks are to do with row and cell creation. - // for them we want to execute according to row order, so we use - // TaskItem so we know what index the item is for. - _this.createTasksP1 = { list: [], sorted: false }; // eg drawing back-ground of rows - _this.createTasksP2 = { list: [], sorted: false }; // eg cell renderers, adding hover functionality - // destroy tasks are to do with row removal. they are done after row creation as the user will need to see new - // rows first (as blank is scrolled into view), when we remove the old rows (no longer in view) is not as - // important. - _this.destroyTasks = []; - _this.ticking = false; - // we need to know direction of scroll, to build up rows in the direction of - // the scroll. eg if user scrolls down, we extend the rows by building down. - _this.scrollGoingDown = true; - _this.lastScrollTop = 0; - _this.taskCount = 0; - _this.cancelledTasks = new Set(); + + + +var AgPanel = /** @class */ (function (_super) { + __extends(AgPanel, _super); + function AgPanel(config) { + var _this = _super.call(this, AgPanel.getTemplate(config)) || this; + _this.closable = true; + _this.config = config; return _this; } - AnimationFrameService.prototype.setScrollTop = function (scrollTop) { - this.scrollGoingDown = scrollTop > this.lastScrollTop; - this.lastScrollTop = scrollTop; - }; - AnimationFrameService.prototype.init = function () { - this.useAnimationFrame = !this.gridOptionsWrapper.isSuppressAnimationFrame(); - }; - // this method is for our ag-Grid sanity only - if animation frames are turned off, - // then no place in the code should be looking to add any work to be done in animation - // frames. this stops bugs - where some code is asking for a frame to be executed - // when it should not. - AnimationFrameService.prototype.verifyAnimationFrameOn = function (methodName) { - if (this.useAnimationFrame === false) { - console.warn("ag-Grid: AnimationFrameService." + methodName + " called but animation frames are off"); - } - }; - AnimationFrameService.prototype.createTask = function (task, index, list) { - this.verifyAnimationFrameOn(list); - var taskItem = { task: task, index: index, createOrder: ++this.taskCount }; - this.addTaskToList(this[list], taskItem); - this.schedule(); - }; - AnimationFrameService.prototype.cancelTask = function (task) { - this.cancelledTasks.add(task); - }; - AnimationFrameService.prototype.addTaskToList = function (taskList, task) { - taskList.list.push(task); - taskList.sorted = false; + AgPanel.getTemplate = function (config) { + var cssIdentifier = (config && config.cssIdentifier) || 'default'; + return /* html */ "
\n
\n \n
\n
\n
\n
"; }; - AnimationFrameService.prototype.sortTaskList = function (taskList) { - if (taskList.sorted) { - return; + AgPanel.prototype.postConstruct = function () { + var _this = this; + var _a = this.config, component = _a.component, closable = _a.closable, hideTitleBar = _a.hideTitleBar, title = _a.title, _b = _a.minWidth, minWidth = _b === void 0 ? 250 : _b, width = _a.width, _c = _a.minHeight, minHeight = _c === void 0 ? 250 : _c, height = _a.height, centered = _a.centered, popup = _a.popup, x = _a.x, y = _a.y; + this.positionableFeature = new _rendering_features_positionableFeature__WEBPACK_IMPORTED_MODULE_5__["PositionableFeature"](this.getGui(), { + minWidth: minWidth, width: width, minHeight: minHeight, height: height, centered: centered, x: x, y: y, popup: popup, + calculateTopBuffer: function () { return _this.positionableFeature.getHeight() - _this.getBodyHeight(); } + }); + this.createManagedBean(this.positionableFeature); + var eGui = this.getGui(); + if (component) { + this.setBodyComponent(component); } - var sortDirection = this.scrollGoingDown ? 1 : -1; - // sort first by row index (taking into account scroll direction), then by - // order of task creation (always ascending, so cells will render left-to-right) - taskList.list.sort(function (a, b) { return a.index !== b.index ? sortDirection * (b.index - a.index) : b.createOrder - a.createOrder; }); - taskList.sorted = true; - }; - AnimationFrameService.prototype.addDestroyTask = function (task) { - this.verifyAnimationFrameOn('createTasksP3'); - this.destroyTasks.push(task); - this.schedule(); - }; - AnimationFrameService.prototype.executeFrame = function (millis) { - this.verifyAnimationFrameOn('executeFrame'); - var p1TaskList = this.createTasksP1; - var p1Tasks = p1TaskList.list; - var p2TaskList = this.createTasksP2; - var p2Tasks = p2TaskList.list; - var destroyTasks = this.destroyTasks; - var frameStart = new Date().getTime(); - var duration = (new Date().getTime()) - frameStart; - // 16ms is 60 fps - var noMaxMillis = millis <= 0; - while (noMaxMillis || duration < millis) { - var task = void 0; - if (p1Tasks.length) { - this.sortTaskList(p1TaskList); - task = p1Tasks.pop().task; - } - else if (p2Tasks.length) { - this.sortTaskList(p2TaskList); - task = p2Tasks.pop().task; - } - else if (destroyTasks.length) { - task = destroyTasks.pop(); + if (!hideTitleBar) { + if (title) { + this.setTitle(title); } - else { - this.cancelledTasks.clear(); - break; + this.setClosable(closable != null ? closable : this.closable); + } + else { + this.eTitleBar.classList.add('ag-hidden'); + } + this.addManagedListener(this.eTitleBar, 'mousedown', function (e) { + var eDocument = _this.gridOptionsWrapper.getDocument(); + if (eGui.contains(e.relatedTarget) || + eGui.contains(eDocument.activeElement) || + _this.eTitleBarButtons.contains(e.target)) { + e.preventDefault(); + return; } - if (!this.cancelledTasks.has(task)) { - task(); + var focusEl = _this.eContentWrapper.querySelector('button, [href], input, select, textarea, [tabindex]'); + if (focusEl) { + focusEl.focus(); } - duration = (new Date().getTime()) - frameStart; - } - if (p1Tasks.length || p2Tasks.length || destroyTasks.length) { - this.requestFrame(); + }); + if (popup && this.positionableFeature.isPositioned()) { + return; } - else { - this.stopTicking(); + if (this.renderComponent) { + this.renderComponent(); } + this.positionableFeature.initialisePosition(); + this.eContentWrapper.style.height = '0'; }; - AnimationFrameService.prototype.stopTicking = function () { - this.ticking = false; - var event = { - type: _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_ANIMATION_QUEUE_EMPTY, - columnApi: this.gridOptionsWrapper.getColumnApi(), - api: this.gridOptionsWrapper.getApi() + AgPanel.prototype.renderComponent = function () { + var _this = this; + var eGui = this.getGui(); + eGui.focus(); + this.close = function () { + eGui.parentElement.removeChild(eGui); + _this.destroy(); }; - this.eventService.dispatchEvent(event); }; - AnimationFrameService.prototype.flushAllFrames = function () { - if (!this.useAnimationFrame) { - return; - } - this.executeFrame(-1); + AgPanel.prototype.getHeight = function () { + return this.positionableFeature.getHeight(); }; - AnimationFrameService.prototype.schedule = function () { - if (!this.useAnimationFrame) { - return; + AgPanel.prototype.setHeight = function (height) { + this.positionableFeature.setHeight(height); + }; + AgPanel.prototype.getWidth = function () { + return this.positionableFeature.getWidth(); + }; + AgPanel.prototype.setWidth = function (width) { + this.positionableFeature.setWidth(width); + }; + AgPanel.prototype.setClosable = function (closable) { + if (closable !== this.closable) { + this.closable = closable; } - if (!this.ticking) { - this.ticking = true; - this.requestFrame(); + if (closable) { + var closeButtonComp = this.closeButtonComp = new _component__WEBPACK_IMPORTED_MODULE_2__["Component"](AgPanel.CLOSE_BTN_TEMPLATE); + this.getContext().createBean(closeButtonComp); + var eGui = closeButtonComp.getGui(); + var child = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_4__["createIconNoSpan"])('close', this.gridOptionsWrapper); + child.classList.add('ag-panel-title-bar-button-icon'); + eGui.appendChild(child); + this.addTitleBarButton(closeButtonComp); + closeButtonComp.addManagedListener(eGui, 'click', this.onBtClose.bind(this)); + } + else if (this.closeButtonComp) { + var eGui = this.closeButtonComp.getGui(); + eGui.parentElement.removeChild(eGui); + this.closeButtonComp = this.destroyBean(this.closeButtonComp); } }; - AnimationFrameService.prototype.requestFrame = function () { - // check for the existence of requestAnimationFrame, and if - // it's missing, then we polyfill it with setTimeout() - var callback = this.executeFrame.bind(this, 60); - if (window.requestAnimationFrame) { - window.requestAnimationFrame(callback); + AgPanel.prototype.setBodyComponent = function (bodyComponent) { + bodyComponent.setParentComponent(this); + this.eContentWrapper.appendChild(bodyComponent.getGui()); + }; + AgPanel.prototype.addTitleBarButton = function (button, position) { + var eTitleBarButtons = this.eTitleBarButtons; + var buttons = eTitleBarButtons.children; + var len = buttons.length; + if (position == null) { + position = len; + } + position = Math.max(0, Math.min(position, len)); + button.addCssClass('ag-panel-title-bar-button'); + var eGui = button.getGui(); + if (position === 0) { + eTitleBarButtons.insertAdjacentElement('afterbegin', eGui); } - else if (window.webkitRequestAnimationFrame) { - window.webkitRequestAnimationFrame(callback); + else if (position === len) { + eTitleBarButtons.insertAdjacentElement('beforeend', eGui); } else { - window.setTimeout(callback, 0); + buttons[position - 1].insertAdjacentElement('afterend', eGui); } + button.setParentComponent(this); }; - AnimationFrameService.prototype.isQueueEmpty = function () { - return !this.ticking; + AgPanel.prototype.getBodyHeight = function () { + return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["getInnerHeight"])(this.eContentWrapper); + }; + AgPanel.prototype.getBodyWidth = function () { + return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["getInnerWidth"])(this.eContentWrapper); + }; + AgPanel.prototype.setTitle = function (title) { + this.eTitle.innerText = title; + }; + // called when user hits the 'x' in the top right + AgPanel.prototype.onBtClose = function () { + this.close(); + }; + AgPanel.prototype.destroy = function () { + if (this.closeButtonComp) { + this.closeButtonComp = this.destroyBean(this.closeButtonComp); + } + var eGui = this.getGui(); + if (eGui && eGui.offsetParent) { + this.close(); + } + _super.prototype.destroy.call(this); }; + AgPanel.CLOSE_BTN_TEMPLATE = "
"; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], AnimationFrameService.prototype, "gridOptionsWrapper", void 0); + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eContentWrapper') + ], AgPanel.prototype, "eContentWrapper", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], AnimationFrameService.prototype, "init", null); - AnimationFrameService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('animationFrameService') - ], AnimationFrameService); - return AnimationFrameService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"])); + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eTitleBar') + ], AgPanel.prototype, "eTitleBar", void 0); + __decorate([ + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eTitleBarButtons') + ], AgPanel.prototype, "eTitleBarButtons", void 0); + __decorate([ + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eTitle') + ], AgPanel.prototype, "eTitle", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], AgPanel.prototype, "postConstruct", null); + return AgPanel; +}(_component__WEBPACK_IMPORTED_MODULE_2__["Component"])); /***/ }), -/* 163 */ +/* 211 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NavigationService", function() { return NavigationService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(25); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(41); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PositionableFeature", function() { return PositionableFeature; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(42); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -38066,375 +46351,651 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta - -var NavigationService = /** @class */ (function (_super) { - __extends(NavigationService, _super); - function NavigationService() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.timeLastPageEventProcessed = 0; +var RESIZE_CONTAINER_STYLE = 'ag-resizer-wrapper'; +var RESIZE_TEMPLATE = /* html */ "
\n
\n
\n
\n
\n
\n
\n
\n
\n
"; +var PositionableFeature = /** @class */ (function (_super) { + __extends(PositionableFeature, _super); + function PositionableFeature(element, config) { + var _this = _super.call(this) || this; + _this.element = element; + _this.dragStartPosition = { + x: 0, + y: 0 + }; + _this.position = { + x: 0, + y: 0 + }; + _this.lastSize = { + width: -1, + height: -1 + }; + _this.positioned = false; + _this.resizersAdded = false; + _this.resizeListeners = []; + _this.boundaryEl = null; + _this.isResizing = false; + _this.isMoving = false; + _this.resizable = {}; + _this.movable = false; + _this.currentResizer = null; + _this.config = Object.assign({}, { popup: false }, config); return _this; } - NavigationService.prototype.init = function () { - this.scrollWidth = this.gridOptionsWrapper.getScrollbarWidth(); - }; - NavigationService.prototype.registerGridComp = function (gridPanel) { - this.gridPanel = gridPanel; + PositionableFeature.prototype.center = function () { + var _a = this.offsetParent, clientHeight = _a.clientHeight, clientWidth = _a.clientWidth; + var x = (clientWidth / 2) - (this.getWidth() / 2); + var y = (clientHeight / 2) - (this.getHeight() / 2); + this.offsetElement(x, y); }; - NavigationService.prototype.handlePageScrollingKey = function (event) { - var key = event.which || event.keyCode; - var alt = event.altKey; - var ctrl = event.ctrlKey; - var currentCell = this.mouseEventService.getCellPositionForEvent(event); - if (!currentCell) { - return false; + PositionableFeature.prototype.initialisePosition = function () { + var _a = this.config, centered = _a.centered, forcePopupParentAsOffsetParent = _a.forcePopupParentAsOffsetParent, minWidth = _a.minWidth, width = _a.width, minHeight = _a.minHeight, height = _a.height, x = _a.x, y = _a.y; + if (!this.offsetParent) { + this.setOffsetParent(); + } + var computedMinHeight = 0; + var computedMinWidth = 0; + // here we don't use the main offset parent but the element's offsetParent + // in order to calculated the minWidth and minHeight correctly + var isVisible = !!this.element.offsetParent; + if (isVisible) { + var boundaryEl = this.findBoundaryElement(); + var offsetParentComputedStyles = window.getComputedStyle(boundaryEl); + if (offsetParentComputedStyles.minWidth != null) { + var paddingWidth = boundaryEl.offsetWidth - this.element.offsetWidth; + computedMinWidth = parseInt(offsetParentComputedStyles.minWidth, 10) - paddingWidth; + } + if (offsetParentComputedStyles.minHeight != null) { + var paddingHeight = boundaryEl.offsetHeight - this.element.offsetHeight; + computedMinHeight = parseInt(offsetParentComputedStyles.minHeight, 10) - paddingHeight; + } + } + this.minHeight = minHeight || computedMinHeight; + this.minWidth = minWidth || computedMinWidth; + if (width) { + this.setWidth(width); } - var processed = false; - switch (key) { - case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_PAGE_HOME: - case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_PAGE_END: - // handle home and end when ctrl & alt are NOT pressed - if (!ctrl && !alt) { - this.onHomeOrEndKey(key); - processed = true; - } - break; - case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_LEFT: - case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_RIGHT: - // handle left and right when ctrl is pressed only - if (ctrl && !alt) { - this.onCtrlLeftOrRight(key, currentCell); - processed = true; - } - break; - case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_UP: - case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_DOWN: - // handle up and down when ctrl is pressed only - if (ctrl && !alt) { - this.onCtrlUpOrDown(key, currentCell); - processed = true; - } - break; - case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_PAGE_DOWN: - // handle page up and page down when ctrl & alt are NOT pressed - if (!ctrl && !alt) { - this.onPageDown(currentCell); - processed = true; - } - break; - case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_PAGE_UP: - // handle page up and page down when ctrl & alt are NOT pressed - if (!ctrl && !alt) { - this.onPageUp(currentCell); - processed = true; - } - break; + if (height) { + this.setHeight(height); } - if (processed) { - event.preventDefault(); + if (!width || !height) { + this.refreshSize(); } - return processed; + if (centered) { + this.center(); + } + else if (x || y) { + this.offsetElement(x, y); + } + else if (isVisible && forcePopupParentAsOffsetParent && this.boundaryEl) { + var top_1 = parseFloat(this.boundaryEl.style.top); + var left = parseFloat(this.boundaryEl.style.left); + this.offsetElement(isNaN(left) ? 0 : left, isNaN(top_1) ? 0 : top_1); + } + this.positioned = !!this.offsetParent; }; - // the page up/down keys caused a problem, in that if the user - // held the page up/down key down, lots of events got generated, - // which clogged up the event queue (as they take time to process) - // which in turn froze the grid. Logic below makes sure we wait 100ms - // between processing the page up/down events, so when user has finger - // held down on key, we ignore page up/down events until 100ms has passed, - // which effectively empties the queue of page up/down events. - NavigationService.prototype.isTimeSinceLastPageEventToRecent = function () { - var now = new Date().getTime(); - var diff = now - this.timeLastPageEventProcessed; - return (diff < 100); + PositionableFeature.prototype.isPositioned = function () { + return this.positioned; }; - NavigationService.prototype.setTimeLastPageEventProcessed = function () { - this.timeLastPageEventProcessed = new Date().getTime(); + PositionableFeature.prototype.getPosition = function () { + return this.position; }; - NavigationService.prototype.onPageDown = function (gridCell) { - if (this.isTimeSinceLastPageEventToRecent()) { + PositionableFeature.prototype.setMovable = function (movable, moveElement) { + if (!this.config.popup || movable === this.movable) { return; } - var scrollPosition = this.gridPanel.getVScrollPosition(); - var pixelsInOnePage = scrollPosition.bottom - scrollPosition.top; - if (this.gridPanel.isHorizontalScrollShowing()) { - pixelsInOnePage -= this.scrollWidth; + this.movable = movable; + var params = this.moveElementDragListener || { + eElement: moveElement, + onDragStart: this.onMoveStart.bind(this), + onDragging: this.onMove.bind(this), + onDragStop: this.onMoveEnd.bind(this) + }; + if (movable) { + this.dragService.addDragSource(params); + this.moveElementDragListener = params; } - var pagingPixelOffset = this.paginationProxy.getPixelOffset(); - var currentPageBottomPixel = scrollPosition.top + pixelsInOnePage; - var currentPageBottomRow = this.paginationProxy.getRowIndexAtPixel(currentPageBottomPixel + pagingPixelOffset); - var scrollIndex = currentPageBottomRow; - var currentCellPixel = this.paginationProxy.getRow(gridCell.rowIndex).rowTop; - var nextCellPixel = currentCellPixel + pixelsInOnePage - pagingPixelOffset; - var focusIndex = this.paginationProxy.getRowIndexAtPixel(nextCellPixel + pagingPixelOffset); - var pageLastRow = this.paginationProxy.getPageLastRow(); - if (focusIndex > pageLastRow) { - focusIndex = pageLastRow; + else { + this.dragService.removeDragSource(params); + this.moveElementDragListener = undefined; } - if (scrollIndex > pageLastRow) { - scrollIndex = pageLastRow; + }; + PositionableFeature.prototype.setResizable = function (resizable) { + var _this = this; + this.clearResizeListeners(); + if (resizable) { + this.addResizers(); } - this.navigateTo(scrollIndex, 'top', null, focusIndex, gridCell.column); - this.setTimeLastPageEventProcessed(); + else { + this.removeResizers(); + } + if (typeof resizable === 'boolean') { + if (resizable === false) { + return; + } + resizable = { + topLeft: resizable, + top: resizable, + topRight: resizable, + right: resizable, + bottomRight: resizable, + bottom: resizable, + bottomLeft: resizable, + left: resizable + }; + } + Object.keys(resizable).forEach(function (side) { + var resizableStructure = resizable; + var val = !!resizableStructure[side]; + var resizerEl = _this.getResizerElement(side); + var params = { + dragStartPixels: 0, + eElement: resizerEl, + onDragStart: function (e) { return _this.onResizeStart(e, side); }, + onDragging: _this.onResize.bind(_this), + onDragStop: function (e) { return _this.onResizeEnd(e, side); }, + }; + if (!!_this.resizable[side] !== val || (!_this.isAlive() && !val)) { + if (val) { + _this.dragService.addDragSource(params); + _this.resizeListeners.push(params); + resizerEl.style.pointerEvents = 'all'; + } + else { + resizerEl.style.pointerEvents = 'none'; + } + } + }); }; - NavigationService.prototype.onPageUp = function (gridCell) { - if (this.isTimeSinceLastPageEventToRecent()) { - return; + PositionableFeature.prototype.removeSizeFromEl = function () { + this.element.style.removeProperty('height'); + this.element.style.removeProperty('width'); + this.element.style.removeProperty('flex'); + }; + PositionableFeature.prototype.restoreLastSize = function () { + this.element.style.flex = '0 0 auto'; + var _a = this.lastSize, height = _a.height, width = _a.width; + if (width !== -1) { + this.element.style.width = width + "px"; } - var scrollPosition = this.gridPanel.getVScrollPosition(); - var pixelsInOnePage = scrollPosition.bottom - scrollPosition.top; - if (this.gridPanel.isHorizontalScrollShowing()) { - pixelsInOnePage -= this.scrollWidth; + if (height !== -1) { + this.element.style.height = height + "px"; } - var pagingPixelOffset = this.paginationProxy.getPixelOffset(); - var currentPageTopPixel = scrollPosition.top; - var currentPageTopRow = this.paginationProxy.getRowIndexAtPixel(currentPageTopPixel + pagingPixelOffset); - var scrollIndex = currentPageTopRow; - var currentRowNode = this.paginationProxy.getRow(gridCell.rowIndex); - var nextCellPixel = currentRowNode.rowTop + currentRowNode.rowHeight - pixelsInOnePage - pagingPixelOffset; - var focusIndex = this.paginationProxy.getRowIndexAtPixel(nextCellPixel + pagingPixelOffset); - var firstRow = this.paginationProxy.getPageFirstRow(); - if (focusIndex < firstRow) { - focusIndex = firstRow; + }; + PositionableFeature.prototype.getHeight = function () { + return this.element.offsetHeight; + }; + PositionableFeature.prototype.setHeight = function (height) { + var popup = this.config.popup; + var eGui = this.element; + var isPercent = false; + if (typeof height === 'string' && height.indexOf('%') !== -1) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["setFixedHeight"])(eGui, height); + height = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["getAbsoluteHeight"])(eGui); + isPercent = true; } - if (scrollIndex < firstRow) { - scrollIndex = firstRow; + else if (this.positioned) { + var elRect = this.element.getBoundingClientRect(); + var parentRect = this.offsetParent.getBoundingClientRect(); + height = Math.max(this.minHeight, height); + var clientHeight = this.offsetParent.clientHeight; + var yPosition = popup ? this.position.y : elRect.top; + var parentTop = popup ? 0 : parentRect.top; + if (clientHeight && (height + yPosition > clientHeight + parentTop)) { + height = clientHeight - yPosition; + } + } + if (this.getHeight() === height) { + return; + } + if (!isPercent) { + if (popup) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["setFixedHeight"])(eGui, height); + } + else { + eGui.style.height = height + "px"; + eGui.style.flex = '0 0 auto'; + this.lastSize.height = typeof height === 'number' ? height : parseFloat(height); + } + } + else { + eGui.style.maxHeight = 'unset'; + eGui.style.minHeight = 'unset'; } - this.navigateTo(scrollIndex, 'bottom', null, focusIndex, gridCell.column); - this.setTimeLastPageEventProcessed(); }; - // common logic to navigate. takes parameters: - // scrollIndex - what row to vertically scroll to - // scrollType - what position to put scroll index ie top/bottom - // scrollColumn - what column to horizontally scroll to - // focusIndex / focusColumn - for page up / down, we want to scroll to one row/column, but focus another - NavigationService.prototype.navigateTo = function (scrollIndex, scrollType, scrollColumn, focusIndex, focusColumn) { - if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(scrollColumn)) { - this.gridPanel.ensureColumnVisible(scrollColumn); + PositionableFeature.prototype.getWidth = function () { + return this.element.offsetWidth; + }; + PositionableFeature.prototype.setWidth = function (width) { + var eGui = this.element; + var popup = this.config.popup; + var isPercent = false; + if (typeof width === 'string' && width.indexOf('%') !== -1) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["setFixedWidth"])(eGui, width); + width = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["getAbsoluteWidth"])(eGui); + isPercent = true; } - if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(scrollIndex)) { - this.gridPanel.ensureIndexVisible(scrollIndex, scrollType); + else if (this.positioned) { + width = Math.max(this.minWidth, width); + var clientWidth = this.offsetParent.clientWidth; + var xPosition = popup ? this.position.x : this.element.getBoundingClientRect().left; + if (clientWidth && (width + xPosition > clientWidth)) { + width = clientWidth - xPosition; + } } - // make sure the cell is rendered, needed if we are to focus - this.animationFrameService.flushAllFrames(); - // if we don't do this, the range will be left on the last cell, which will leave the last focused cell - // highlighted. - this.focusController.setFocusedCell(focusIndex, focusColumn, null, true); - if (this.rangeController) { - var cellPosition = { rowIndex: focusIndex, rowPinned: null, column: focusColumn }; - this.rangeController.setRangeToCell(cellPosition); + if (this.getWidth() === width) { + return; + } + if (!isPercent) { + if (this.config.popup) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["setFixedWidth"])(eGui, width); + } + else { + eGui.style.width = width + "px"; + eGui.style.flex = ' unset'; + this.lastSize.width = typeof width === 'number' ? width : parseFloat(width); + } + } + else { + eGui.style.maxWidth = 'unset'; + eGui.style.minWidth = 'unset'; } }; - // ctrl + up/down will bring focus to same column, first/last row. no horizontal scrolling. - NavigationService.prototype.onCtrlUpOrDown = function (key, gridCell) { - var upKey = key === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_UP; - var rowIndexToScrollTo = upKey ? 0 : this.paginationProxy.getPageLastRow(); - this.navigateTo(rowIndexToScrollTo, null, gridCell.column, rowIndexToScrollTo, gridCell.column); + PositionableFeature.prototype.offsetElement = function (x, y) { + if (x === void 0) { x = 0; } + if (y === void 0) { y = 0; } + var ePopup = this.config.forcePopupParentAsOffsetParent ? this.boundaryEl : this.element; + this.popupService.positionPopup({ + ePopup: ePopup, + x: x, + y: y, + keepWithinBounds: true + }); + this.setPosition(parseFloat(ePopup.style.left), parseFloat(ePopup.style.top)); }; - // ctrl + left/right will bring focus to same row, first/last cell. no vertical scrolling. - NavigationService.prototype.onCtrlLeftOrRight = function (key, gridCell) { - var leftKey = key === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_LEFT; - var allColumns = this.columnController.getAllDisplayedColumns(); - var columnToSelect = leftKey ? allColumns[0] : _utils__WEBPACK_IMPORTED_MODULE_3__["_"].last(allColumns); - this.navigateTo(gridCell.rowIndex, null, columnToSelect, gridCell.rowIndex, columnToSelect); + PositionableFeature.prototype.setPosition = function (x, y) { + this.position.x = x; + this.position.y = y; }; - // home brings focus to top left cell, end brings focus to bottom right, grid scrolled to bring - // same cell into view (which means either scroll all the way up, or all the way down). - NavigationService.prototype.onHomeOrEndKey = function (key) { - var homeKey = key === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_PAGE_HOME; - var allColumns = this.columnController.getAllDisplayedColumns(); - var columnToSelect = homeKey ? allColumns[0] : _utils__WEBPACK_IMPORTED_MODULE_3__["_"].last(allColumns); - var rowIndexToScrollTo = homeKey ? 0 : this.paginationProxy.getPageLastRow(); - this.navigateTo(rowIndexToScrollTo, null, columnToSelect, rowIndexToScrollTo, columnToSelect); + PositionableFeature.prototype.updateDragStartPosition = function (x, y) { + this.dragStartPosition = { x: x, y: y }; }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('mouseEventService') - ], NavigationService.prototype, "mouseEventService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('paginationProxy') - ], NavigationService.prototype, "paginationProxy", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusController') - ], NavigationService.prototype, "focusController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('animationFrameService') - ], NavigationService.prototype, "animationFrameService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('rangeController') - ], NavigationService.prototype, "rangeController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], NavigationService.prototype, "columnController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], NavigationService.prototype, "gridOptionsWrapper", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], NavigationService.prototype, "init", null); - NavigationService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('navigationService') - ], NavigationService); - return NavigationService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"])); - - - -/***/ }), -/* 164 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MaxDivHeightScaler", function() { return MaxDivHeightScaler; }); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(41); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(44); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 - * @link http://www.ag-grid.com/ - * @license MIT - */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); + PositionableFeature.prototype.calculateMouseMovement = function (params) { + var e = params.e, isLeft = params.isLeft, isTop = params.isTop, anywhereWithin = params.anywhereWithin, topBuffer = params.topBuffer; + var xDiff = e.clientX - this.dragStartPosition.x; + var yDiff = e.clientY - this.dragStartPosition.y; + var movementX = this.shouldSkipX(e, !!isLeft, !!anywhereWithin, xDiff) ? 0 : xDiff; + var movementY = this.shouldSkipY(e, !!isTop, topBuffer, yDiff) ? 0 : yDiff; + return { movementX: movementX, movementY: movementY }; }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + PositionableFeature.prototype.shouldSkipX = function (e, isLeft, anywhereWithin, diff) { + var elRect = this.element.getBoundingClientRect(); + var parentRect = this.offsetParent.getBoundingClientRect(); + var boundaryElRect = this.boundaryEl.getBoundingClientRect(); + var xPosition = this.config.popup ? this.position.x : elRect.left; + // skip if cursor is outside of popupParent horizontally + var skipX = ((xPosition <= 0 && parentRect.left >= e.clientX) || + (parentRect.right <= e.clientX && parentRect.right <= boundaryElRect.right)); + if (skipX) { + return true; + } + if (isLeft) { + skipX = ( + // skip if we are moving to the left and the cursor + // is positioned to the right of the left side anchor + (diff < 0 && e.clientX > xPosition + parentRect.left) || + // skip if we are moving to the right and the cursor + // is positioned to the left of the dialog + (diff > 0 && e.clientX < xPosition + parentRect.left)); + } + else { + if (anywhereWithin) { + // if anywhereWithin is true, we allow to move + // as long as the cursor is within the dialog + skipX = ((diff < 0 && e.clientX > boundaryElRect.right) || + (diff > 0 && e.clientX < xPosition + parentRect.left)); + } + else { + skipX = ( + // if the movement is bound to the right side of the dialog + // we skip if we are moving to the left and the cursor + // is to the right of the dialog + (diff < 0 && e.clientX > boundaryElRect.right) || + // or skip if we are moving to the right and the cursor + // is to the left of the right side anchor + (diff > 0 && e.clientX < boundaryElRect.right)); + } + } + return skipX; + }; + PositionableFeature.prototype.shouldSkipY = function (e, isTop, topBuffer, diff) { + if (topBuffer === void 0) { topBuffer = 0; } + var elRect = this.element.getBoundingClientRect(); + var parentRect = this.offsetParent.getBoundingClientRect(); + var boundaryElRect = this.boundaryEl.getBoundingClientRect(); + var yPosition = this.config.popup ? this.position.y : elRect.top; + // skip if cursor is outside of popupParent vertically + var skipY = ((yPosition <= 0 && parentRect.top >= e.clientY) || + (parentRect.bottom <= e.clientY && parentRect.bottom <= boundaryElRect.bottom)); + if (skipY) { + return true; + } + if (isTop) { + skipY = ( + // skip if we are moving to towards top and the cursor is + // below the top anchor + topBuffer + // note: topBuffer is used when moving the dialog using the title bar + (diff < 0 && e.clientY > yPosition + parentRect.top + topBuffer) || + // skip if we are moving to the bottom and the cursor is + // above the top anchor + (diff > 0 && e.clientY < yPosition + parentRect.top)); + } + else { + skipY = ( + // skip if we are moving towards the top and the cursor + // is below the bottom anchor + (diff < 0 && e.clientY > boundaryElRect.bottom) || + // skip if we are moving towards the bottom and the cursor + // is above the bottom anchor + (diff > 0 && e.clientY < boundaryElRect.bottom)); + } + return skipY; }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - -/** - * This class solves the 'max height' problem, where the user might want to show more data than - * the max div height actually allows. - */ -var MaxDivHeightScaler = /** @class */ (function (_super) { - __extends(MaxDivHeightScaler, _super); - function MaxDivHeightScaler() { - var _this = _super !== null && _super.apply(this, arguments) || this; - // the scrollY position - _this.scrollY = 0; - // how tall the body is - _this.uiBodyHeight = 0; - return _this; - } - MaxDivHeightScaler.prototype.postConstruct = function () { - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_BODY_HEIGHT_CHANGED, this.updateOffset.bind(this)); - this.scrollBarWidth = this.gridOptionsWrapper.getScrollbarWidth(); - this.maxDivHeight = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].getMaxDivHeight(); + PositionableFeature.prototype.createResizeMap = function () { + var eGui = this.element; + this.resizerMap = { + topLeft: { element: eGui.querySelector('[ref=eTopLeftResizer]') }, + top: { element: eGui.querySelector('[ref=eTopResizer]') }, + topRight: { element: eGui.querySelector('[ref=eTopRightResizer]') }, + right: { element: eGui.querySelector('[ref=eRightResizer]') }, + bottomRight: { element: eGui.querySelector('[ref=eBottomRightResizer]') }, + bottom: { element: eGui.querySelector('[ref=eBottomResizer]') }, + bottomLeft: { element: eGui.querySelector('[ref=eBottomLeftResizer]') }, + left: { element: eGui.querySelector('[ref=eLeftResizer]') } + }; + }; + PositionableFeature.prototype.addResizers = function () { + if (this.resizersAdded) { + return; + } + var eGui = this.element; + if (!eGui) { + return; + } + var parser = new DOMParser(); + var resizers = parser.parseFromString(RESIZE_TEMPLATE, 'text/html').body; + eGui.appendChild(resizers.firstChild); + this.createResizeMap(); + this.resizersAdded = true; + }; + PositionableFeature.prototype.removeResizers = function () { + this.resizerMap = undefined; + var resizerEl = this.element.querySelector("." + RESIZE_CONTAINER_STYLE); + if (resizerEl) { + this.element.removeChild(resizerEl); + } + this.resizersAdded = false; + }; + PositionableFeature.prototype.getResizerElement = function (side) { + return this.resizerMap[side].element; }; - MaxDivHeightScaler.prototype.registerGridComp = function (gridPanel) { - this.gridPanel = gridPanel; + PositionableFeature.prototype.onResizeStart = function (e, side) { + this.boundaryEl = this.findBoundaryElement(); + if (!this.positioned) { + this.initialisePosition(); + } + this.currentResizer = { + isTop: !!side.match(/top/i), + isRight: !!side.match(/right/i), + isBottom: !!side.match(/bottom/i), + isLeft: !!side.match(/left/i), + }; + this.element.classList.add('ag-resizing'); + this.resizerMap[side].element.classList.add('ag-active'); + var _a = this.config, popup = _a.popup, forcePopupParentAsOffsetParent = _a.forcePopupParentAsOffsetParent; + if (!popup && !forcePopupParentAsOffsetParent) { + this.applySizeToSiblings(this.currentResizer.isBottom || this.currentResizer.isTop); + } + this.isResizing = true; + this.updateDragStartPosition(e.clientX, e.clientY); }; - MaxDivHeightScaler.prototype.isScaling = function () { - return this.scaling; + PositionableFeature.prototype.getSiblings = function () { + var element = this.element; + var parent = element.parentElement; + if (!parent) { + return null; + } + return Array.prototype.slice.call(parent.children).filter(function (el) { return !el.classList.contains('ag-hidden'); }); }; - MaxDivHeightScaler.prototype.getOffset = function () { - return this.offset; + PositionableFeature.prototype.getMinSizeOfSiblings = function () { + var siblings = this.getSiblings() || []; + var height = 0; + var width = 0; + for (var i = 0; i < siblings.length; i++) { + var currentEl = siblings[i]; + var isFlex = !!currentEl.style.flex && currentEl.style.flex !== '0 0 auto'; + if (currentEl === this.element) { + continue; + } + var nextHeight = this.minHeight || 0; + var nextWidth = this.minWidth || 0; + if (isFlex) { + var computedStyle = window.getComputedStyle(currentEl); + if (computedStyle.minHeight) { + nextHeight = parseInt(computedStyle.minHeight, 10); + } + if (computedStyle.minWidth) { + nextWidth = parseInt(computedStyle.minWidth, 10); + } + } + else { + nextHeight = currentEl.offsetHeight; + nextWidth = currentEl.offsetWidth; + } + height += nextHeight; + width += nextWidth; + } + return { height: height, width: width }; }; - MaxDivHeightScaler.prototype.updateOffset = function () { - if (!this.scaling) { + PositionableFeature.prototype.applySizeToSiblings = function (vertical) { + var containerToFlex = null; + var siblings = this.getSiblings(); + if (!siblings) { return; } - var newScrollY = this.gridPanel.getVScrollPosition().top; - var newBodyHeight = this.getUiBodyHeight(); - var atLeastOneChanged = newScrollY !== this.scrollY || newBodyHeight !== this.uiBodyHeight; - if (atLeastOneChanged) { - this.scrollY = newScrollY; - this.uiBodyHeight = newBodyHeight; - this.calculateOffset(); + for (var i = 0; i < siblings.length; i++) { + var el = siblings[i]; + if (el === containerToFlex) { + continue; + } + if (vertical) { + el.style.height = el.offsetHeight + "px"; + } + else { + el.style.width = el.offsetWidth + "px"; + } + el.style.flex = '0 0 auto'; + if (el === this.element) { + containerToFlex = siblings[i + 1]; + } + } + if (containerToFlex) { + containerToFlex.style.removeProperty('height'); + containerToFlex.style.removeProperty('min-height'); + containerToFlex.style.removeProperty('max-height'); + containerToFlex.style.flex = '1 1 auto'; } }; - MaxDivHeightScaler.prototype.calculateOffset = function () { - this.uiContainerHeight = this.maxDivHeight; - this.pixelsToShave = this.modelHeight - this.uiContainerHeight; - this.maxScrollY = this.uiContainerHeight - this.uiBodyHeight; - var scrollPercent = this.scrollY / this.maxScrollY; - this.setOffset(scrollPercent * this.pixelsToShave); + PositionableFeature.prototype.onResize = function (e) { + if (!this.isResizing || !this.currentResizer) { + return; + } + var _a = this.config, popup = _a.popup, forcePopupParentAsOffsetParent = _a.forcePopupParentAsOffsetParent; + var _b = this.currentResizer, isTop = _b.isTop, isRight = _b.isRight, isBottom = _b.isBottom, isLeft = _b.isLeft; + var isHorizontal = isRight || isLeft; + var isVertical = isBottom || isTop; + var _c = this.calculateMouseMovement({ e: e, isLeft: isLeft, isTop: isTop }), movementX = _c.movementX, movementY = _c.movementY; + var xPosition = this.position.x; + var yPosition = this.position.y; + var offsetLeft = 0; + var offsetTop = 0; + if (isHorizontal && movementX) { + var direction = isLeft ? -1 : 1; + var oldWidth = this.getWidth(); + var newWidth = oldWidth + (movementX * direction); + var skipWidth = false; + if (isLeft) { + offsetLeft = oldWidth - newWidth; + if (xPosition + offsetLeft <= 0 || newWidth <= this.minWidth) { + skipWidth = true; + offsetLeft = 0; + } + } + if (!skipWidth) { + this.setWidth(newWidth); + } + } + if (isVertical && movementY) { + var direction = isTop ? -1 : 1; + var oldHeight = this.getHeight(); + var newHeight = oldHeight + (movementY * direction); + var skipHeight = false; + if (isTop) { + offsetTop = oldHeight - newHeight; + if (yPosition + offsetTop <= 0 || newHeight <= this.minHeight) { + skipHeight = true; + offsetTop = 0; + } + } + else { + // do not let the size of all siblings be higher than the parent container + if (!this.config.popup && + !this.config.forcePopupParentAsOffsetParent && + oldHeight < newHeight && + (this.getMinSizeOfSiblings().height + newHeight) > this.element.parentElement.offsetHeight) { + skipHeight = true; + } + } + if (!skipHeight) { + this.setHeight(newHeight); + } + } + this.updateDragStartPosition(e.clientX, e.clientY); + if ((popup || forcePopupParentAsOffsetParent) && offsetLeft || offsetTop) { + this.offsetElement(xPosition + offsetLeft, yPosition + offsetTop); + } }; - MaxDivHeightScaler.prototype.clearOffset = function () { - this.uiContainerHeight = this.modelHeight; - this.pixelsToShave = 0; - this.setOffset(0); + PositionableFeature.prototype.onResizeEnd = function (e, side) { + this.isResizing = false; + this.currentResizer = null; + this.boundaryEl = null; + var params = { + type: 'resize', + api: this.gridOptionsWrapper.getApi(), + columnApi: this.gridOptionsWrapper.getColumnApi() + }; + this.element.classList.remove('ag-resizing'); + this.resizerMap[side].element.classList.remove('ag-active'); + this.dispatchEvent(params); }; - MaxDivHeightScaler.prototype.setOffset = function (newOffset) { - // because we are talking pixels, no point in confusing things with half numbers - var newOffsetFloor = typeof newOffset === 'number' ? Math.floor(newOffset) : null; - if (this.offset === newOffsetFloor) { + PositionableFeature.prototype.refreshSize = function () { + var eGui = this.element; + if (this.config.popup) { + if (!this.config.width) { + this.setWidth(eGui.offsetWidth); + } + if (!this.config.height) { + this.setHeight(eGui.offsetHeight); + } + } + }; + PositionableFeature.prototype.onMoveStart = function (e) { + this.boundaryEl = this.findBoundaryElement(); + if (!this.positioned) { + this.initialisePosition(); + } + this.isMoving = true; + this.element.classList.add('ag-moving'); + this.updateDragStartPosition(e.clientX, e.clientY); + }; + PositionableFeature.prototype.onMove = function (e) { + if (!this.isMoving) { return; } - this.offset = newOffsetFloor; - this.eventService.dispatchEvent({ type: _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_HEIGHT_SCALE_CHANGED }); + var _a = this.position, x = _a.x, y = _a.y; + var topBuffer; + if (this.config.calculateTopBuffer) { + topBuffer = this.config.calculateTopBuffer(); + } + var _b = this.calculateMouseMovement({ + e: e, + isTop: true, + anywhereWithin: true, + topBuffer: topBuffer + }), movementX = _b.movementX, movementY = _b.movementY; + this.offsetElement(x + movementX, y + movementY); + this.updateDragStartPosition(e.clientX, e.clientY); }; - MaxDivHeightScaler.prototype.setModelHeight = function (modelHeight) { - this.modelHeight = modelHeight; - this.scaling = this.maxDivHeight > 0 && modelHeight > this.maxDivHeight; - if (this.scaling) { - this.calculateOffset(); + PositionableFeature.prototype.onMoveEnd = function () { + this.isMoving = false; + this.boundaryEl = null; + this.element.classList.remove('ag-moving'); + }; + PositionableFeature.prototype.setOffsetParent = function () { + if (this.config.forcePopupParentAsOffsetParent) { + this.offsetParent = this.popupService.getPopupParent(); } else { - this.clearOffset(); + this.offsetParent = this.element.offsetParent; } }; - MaxDivHeightScaler.prototype.getUiContainerHeight = function () { - return this.uiContainerHeight; - }; - MaxDivHeightScaler.prototype.getRealPixelPosition = function (modelPixel) { - return modelPixel - this.offset; + PositionableFeature.prototype.findBoundaryElement = function () { + var el = this.element; + while (el) { + if (window.getComputedStyle(el).position !== 'static') { + return el; + } + el = el.parentElement; + } + return this.element; }; - MaxDivHeightScaler.prototype.getUiBodyHeight = function () { - var pos = this.gridPanel.getVScrollPosition(); - return pos.bottom - pos.top; + PositionableFeature.prototype.clearResizeListeners = function () { + while (this.resizeListeners.length) { + var params = this.resizeListeners.pop(); + this.dragService.removeDragSource(params); + } }; - MaxDivHeightScaler.prototype.getScrollPositionForPixel = function (rowTop) { - if (this.pixelsToShave <= 0) { - return rowTop; + PositionableFeature.prototype.destroy = function () { + _super.prototype.destroy.call(this); + if (this.moveElementDragListener) { + this.dragService.removeDragSource(this.moveElementDragListener); } - var modelMaxScroll = this.modelHeight - this.getUiBodyHeight(); - var scrollPercent = rowTop / modelMaxScroll; - var scrollPixel = this.maxScrollY * scrollPercent; - return scrollPixel; + this.clearResizeListeners(); + this.removeResizers(); }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], MaxDivHeightScaler.prototype, "gridOptionsWrapper", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('popupService') + ], PositionableFeature.prototype, "popupService", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], MaxDivHeightScaler.prototype, "postConstruct", null); - MaxDivHeightScaler = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('maxDivHeightScaler') - ], MaxDivHeightScaler); - return MaxDivHeightScaler; + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('dragService') + ], PositionableFeature.prototype, "dragService", void 0); + return PositionableFeature; }(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 165 */ +/* 212 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SelectableService", function() { return SelectableService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgInputTextField", function() { return AgInputTextField; }); +/* harmony import */ var _agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(71); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -38451,86 +47012,60 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - -var SelectableService = /** @class */ (function (_super) { - __extends(SelectableService, _super); - function SelectableService() { - return _super !== null && _super.apply(this, arguments) || this; +var AgInputTextField = /** @class */ (function (_super) { + __extends(AgInputTextField, _super); + function AgInputTextField(config, className, inputType) { + if (className === void 0) { className = 'ag-text-field'; } + if (inputType === void 0) { inputType = 'text'; } + return _super.call(this, config, className, inputType) || this; } - SelectableService.prototype.init = function () { - this.groupSelectsChildren = this.gridOptionsWrapper.isGroupSelectsChildren(); - this.isRowSelectableFunc = this.gridOptionsWrapper.getIsRowSelectableFunc(); - }; - SelectableService.prototype.updateSelectableAfterGrouping = function (rowNode) { - if (this.isRowSelectableFunc) { - var nextChildrenFunc = function (rowNode) { return rowNode.childrenAfterGroup; }; - this.recurseDown(rowNode.childrenAfterGroup, nextChildrenFunc); + AgInputTextField.prototype.postConstruct = function () { + _super.prototype.postConstruct.call(this); + if (this.config.allowedCharPattern) { + this.preventDisallowedCharacters(); } }; - SelectableService.prototype.updateSelectableAfterFiltering = function (rowNode) { - if (this.isRowSelectableFunc) { - var nextChildrenFunc = function (rowNode) { return rowNode.childrenAfterFilter; }; - this.recurseDown(rowNode.childrenAfterGroup, nextChildrenFunc); + AgInputTextField.prototype.setValue = function (value, silent) { + var ret = _super.prototype.setValue.call(this, value, silent); + if (this.eInput.value !== value) { + this.eInput.value = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_1__["exists"])(value) ? value : ''; } + return ret; }; - SelectableService.prototype.recurseDown = function (children, nextChildrenFunc) { - var _this = this; - children.forEach(function (child) { - if (!child.group) { - return; - } // only interested in groups - if (child.hasChildren()) { - _this.recurseDown(nextChildrenFunc(child), nextChildrenFunc); - } - var rowSelectable; - if (_this.groupSelectsChildren) { - // have this group selectable if at least one direct child is selectable - var firstSelectable = _utils__WEBPACK_IMPORTED_MODULE_1__["_"].find(nextChildrenFunc(child), 'selectable', true); - rowSelectable = _utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(firstSelectable); + AgInputTextField.prototype.preventDisallowedCharacters = function () { + var pattern = new RegExp("[" + this.config.allowedCharPattern + "]"); + var preventDisallowedCharacters = function (event) { + if (event.key && !pattern.test(event.key)) { + event.preventDefault(); } - else { - // directly retrieve selectable value from user callback - rowSelectable = _this.isRowSelectableFunc ? _this.isRowSelectableFunc(child) : false; + }; + this.addManagedListener(this.eInput, 'keypress', preventDisallowedCharacters); + this.addManagedListener(this.eInput, 'paste', function (e) { + var _a; + var text = (_a = e.clipboardData) === null || _a === void 0 ? void 0 : _a.getData('text'); + if (text && text.split('').some(function (c) { return !pattern.test(c); })) { + e.preventDefault(); } - child.setRowSelectable(rowSelectable); }); }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], SelectableService.prototype, "gridOptionsWrapper", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], SelectableService.prototype, "init", null); - SelectableService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('selectableService') - ], SelectableService); - return SelectableService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"])); + return AgInputTextField; +}(_agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractInputField"])); /***/ }), -/* 166 */ +/* 213 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AutoHeightCalculator", function() { return AutoHeightCalculator; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _cellComp__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(101); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgInputTextArea", function() { return AgInputTextArea; }); +/* harmony import */ var _agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(71); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -38547,102 +47082,44 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - -var AutoHeightCalculator = /** @class */ (function (_super) { - __extends(AutoHeightCalculator, _super); - function AutoHeightCalculator() { - return _super !== null && _super.apply(this, arguments) || this; +var AgInputTextArea = /** @class */ (function (_super) { + __extends(AgInputTextArea, _super); + function AgInputTextArea(config) { + return _super.call(this, config, 'ag-text-area', null, 'textarea') || this; } - AutoHeightCalculator.prototype.registerGridComp = function (gridPanel) { - this.gridPanel = gridPanel; + AgInputTextArea.prototype.setValue = function (value, silent) { + var ret = _super.prototype.setValue.call(this, value, silent); + this.eInput.value = value; + return ret; }; - AutoHeightCalculator.prototype.getPreferredHeightForRow = function (rowNode) { - var _this = this; - if (!this.eDummyContainer) { - this.eDummyContainer = document.createElement('div'); - // so any styles on row also get applied in dummy, otherwise - // the content in dummy may differ to the real - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(this.eDummyContainer, 'ag-row ag-row-no-focus'); - } - // we put the dummy into the body container, so it will inherit all the - // css styles that the real cells are inheriting - var eBodyContainer = this.gridPanel.getCenterContainer(); - eBodyContainer.appendChild(this.eDummyContainer); - var cellComps = []; - var autoRowHeightCols = this.columnController.getAllAutoRowHeightCols(); - var visibleAutoRowHeightCols = autoRowHeightCols.filter(function (col) { return col.isVisible(); }); - visibleAutoRowHeightCols.forEach(function (col) { - var cellComp = new _cellComp__WEBPACK_IMPORTED_MODULE_1__["CellComp"](_this.$scope, _this.beans, col, rowNode, null, true, false); - cellComp.setParentRow(_this.eDummyContainer); - cellComps.push(cellComp); - }); - var template = cellComps.map(function (cellComp) { return cellComp.getCreateTemplate(); }).join(' '); - this.eDummyContainer.innerHTML = template; - // this gets any cellComps that are using components to put the components in - cellComps.forEach(function (cellComp) { return cellComp.afterAttached(); }); - // we should be able to just take the height of the row at this point, however - // the row isn't expanding to cover the cell heights, i don't know why, i couldn't - // figure it out so instead looking at the individual cells instead - var maxCellHeight = 0; - for (var i = 0; i < this.eDummyContainer.children.length; i++) { - var child = this.eDummyContainer.children[i]; - if (child.offsetHeight > maxCellHeight) { - maxCellHeight = child.offsetHeight; - } - } - // we are finished with the dummy container, so get rid of it - eBodyContainer.removeChild(this.eDummyContainer); - cellComps.forEach(function (cellComp) { - // dunno why we need to detach first, doing it here to be consistent with code in RowComp - cellComp.detach(); - cellComp.destroy(); - }); - // in case anything left over from last time - _utils__WEBPACK_IMPORTED_MODULE_2__["_"].clearElement(this.eDummyContainer); - return maxCellHeight; + AgInputTextArea.prototype.setCols = function (cols) { + this.eInput.cols = cols; + return this; }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('beans') - ], AutoHeightCalculator.prototype, "beans", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("$scope") - ], AutoHeightCalculator.prototype, "$scope", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("columnController") - ], AutoHeightCalculator.prototype, "columnController", void 0); - AutoHeightCalculator = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('autoHeightCalculator') - ], AutoHeightCalculator); - return AutoHeightCalculator; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"])); + AgInputTextArea.prototype.setRows = function (rows) { + this.eInput.rows = rows; + return this; + }; + return AgInputTextArea; +}(_agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractInputField"])); /***/ }), -/* 167 */ +/* 214 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PaginationComp", function() { return PaginationComp; }); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(25); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgSlider", function() { return AgSlider; }); +/* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57); +/* harmony import */ var _agAbstractLabel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(68); +/* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(67); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(12); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -38669,216 +47146,98 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta - - -var PaginationComp = /** @class */ (function (_super) { - __extends(PaginationComp, _super); - function PaginationComp() { - var _this = _super.call(this) || this; - _this.previousAndFirstButtonsDisabled = false; - _this.nextButtonDisabled = false; - _this.lastButtonDisabled = false; +var AgSlider = /** @class */ (function (_super) { + __extends(AgSlider, _super); + function AgSlider(config) { + var _this = _super.call(this, config, AgSlider.TEMPLATE) || this; + _this.labelAlignment = 'top'; return _this; } - PaginationComp.prototype.postConstruct = function () { - var isRtl = this.gridOptionsWrapper.isEnableRtl(); - this.setTemplate(this.getTemplate()); - this.btFirst.insertAdjacentElement('afterbegin', _utils__WEBPACK_IMPORTED_MODULE_5__["_"].createIconNoSpan(isRtl ? 'last' : 'first', this.gridOptionsWrapper)); - this.btPrevious.insertAdjacentElement('afterbegin', _utils__WEBPACK_IMPORTED_MODULE_5__["_"].createIconNoSpan(isRtl ? 'next' : 'previous', this.gridOptionsWrapper)); - this.btNext.insertAdjacentElement('afterbegin', _utils__WEBPACK_IMPORTED_MODULE_5__["_"].createIconNoSpan(isRtl ? 'previous' : 'next', this.gridOptionsWrapper)); - this.btLast.insertAdjacentElement('afterbegin', _utils__WEBPACK_IMPORTED_MODULE_5__["_"].createIconNoSpan(isRtl ? 'first' : 'last', this.gridOptionsWrapper)); - if (this.rowModel.getType() === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE) { - this.serverSideRowModel = this.rowModel; - } - var isPaging = this.gridOptionsWrapper.isPagination(); - var paginationPanelEnabled = isPaging && !this.gridOptionsWrapper.isSuppressPaginationPanel(); - if (!paginationPanelEnabled) { - this.setDisplayed(false); - return; - } - this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_PAGINATION_CHANGED, this.onPaginationChanged.bind(this)); - this.addManagedListener(this.btFirst, 'click', this.onBtFirst.bind(this)); - this.addManagedListener(this.btLast, 'click', this.onBtLast.bind(this)); - this.addManagedListener(this.btNext, 'click', this.onBtNext.bind(this)); - this.addManagedListener(this.btPrevious, 'click', this.onBtPrevious.bind(this)); - this.onPaginationChanged(); - }; - PaginationComp.prototype.onPaginationChanged = function () { - this.enableOrDisableButtons(); - this.updateRowLabels(); - this.setCurrentPageLabel(); - this.setTotalLabels(); - }; - PaginationComp.prototype.onBtFirst = function () { - if (!this.previousAndFirstButtonsDisabled) { - this.paginationProxy.goToFirstPage(); - } - }; - PaginationComp.prototype.setCurrentPageLabel = function () { - var pagesExist = this.paginationProxy.getTotalPages() > 0; - var currentPage = this.paginationProxy.getCurrentPage(); - var toDisplay = pagesExist ? currentPage + 1 : 0; - this.lbCurrent.innerHTML = this.formatNumber(toDisplay); + AgSlider.prototype.init = function () { + this.eSlider.addCssClass('ag-slider-field'); }; - PaginationComp.prototype.formatNumber = function (value) { - var userFunc = this.gridOptionsWrapper.getPaginationNumberFormatterFunc(); - if (userFunc) { - return userFunc({ value: value }); - } - else { - return _utils__WEBPACK_IMPORTED_MODULE_5__["_"].formatNumberCommas(value); - } + AgSlider.prototype.onValueChange = function (callbackFn) { + var _this = this; + var eventChanged = _agAbstractField__WEBPACK_IMPORTED_MODULE_2__["AgAbstractField"].EVENT_CHANGED; + this.addManagedListener(this.eText, eventChanged, function () { + var textValue = parseFloat(_this.eText.getValue()); + _this.eSlider.setValue(textValue.toString(), true); + callbackFn(textValue || 0); + }); + this.addManagedListener(this.eSlider, eventChanged, function () { + var sliderValue = _this.eSlider.getValue(); + _this.eText.setValue(sliderValue, true); + callbackFn(parseFloat(sliderValue)); + }); + return this; }; - PaginationComp.prototype.getTemplate = function () { - var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc(); - var strPage = localeTextFunc('page', 'Page'); - var strTo = localeTextFunc('to', 'to'); - var strOf = localeTextFunc('of', 'of'); - var strFirst = localeTextFunc('first', 'First'); - var strPrevious = localeTextFunc('previous', 'Previous'); - var strNext = localeTextFunc('next', 'Next'); - var strLast = localeTextFunc('last', 'Last'); - return "
\n \n \n " + strTo + "\n \n " + strOf + "\n \n \n \n
\n \n
\n
\n \n
\n \n " + strPage + "\n \n " + strOf + "\n \n \n \n
\n \n
\n
\n \n
\n
\n
"; + AgSlider.prototype.setSliderWidth = function (width) { + this.eSlider.setWidth(width); + return this; }; - PaginationComp.prototype.onBtNext = function () { - if (!this.nextButtonDisabled) { - this.paginationProxy.goToNextPage(); - } + AgSlider.prototype.setTextFieldWidth = function (width) { + this.eText.setWidth(width); + return this; }; - PaginationComp.prototype.onBtPrevious = function () { - if (!this.previousAndFirstButtonsDisabled) { - this.paginationProxy.goToPreviousPage(); - } + AgSlider.prototype.setMinValue = function (minValue) { + this.eSlider.setMinValue(minValue); + this.eText.setMin(minValue); + return this; }; - PaginationComp.prototype.onBtLast = function () { - if (!this.lastButtonDisabled) { - this.paginationProxy.goToLastPage(); - } + AgSlider.prototype.setMaxValue = function (maxValue) { + this.eSlider.setMaxValue(maxValue); + this.eText.setMax(maxValue); + return this; }; - PaginationComp.prototype.enableOrDisableButtons = function () { - var currentPage = this.paginationProxy.getCurrentPage(); - var maxRowFound = this.paginationProxy.isLastPageFound(); - var totalPages = this.paginationProxy.getTotalPages(); - this.previousAndFirstButtonsDisabled = currentPage === 0; - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].addOrRemoveCssClass(this.btPrevious, 'ag-disabled', this.previousAndFirstButtonsDisabled); - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].addOrRemoveCssClass(this.btFirst, 'ag-disabled', this.previousAndFirstButtonsDisabled); - var zeroPagesToDisplay = this.isZeroPagesToDisplay(); - var onLastPage = maxRowFound && currentPage === (totalPages - 1); - this.nextButtonDisabled = onLastPage || zeroPagesToDisplay; - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].addOrRemoveCssClass(this.btNext, 'ag-disabled', this.nextButtonDisabled); - this.lastButtonDisabled = !maxRowFound || zeroPagesToDisplay || currentPage === (totalPages - 1); - _utils__WEBPACK_IMPORTED_MODULE_5__["_"].addOrRemoveCssClass(this.btLast, 'ag-disabled', this.lastButtonDisabled); + AgSlider.prototype.getValue = function () { + return this.eText.getValue(); }; - PaginationComp.prototype.updateRowLabels = function () { - var currentPage = this.paginationProxy.getCurrentPage(); - var pageSize = this.paginationProxy.getPageSize(); - var maxRowFound = this.paginationProxy.isLastPageFound(); - var rowCount = this.paginationProxy.isLastPageFound() ? - this.paginationProxy.getMasterRowCount() : null; - var startRow; - var endRow; - if (this.isZeroPagesToDisplay()) { - startRow = 0; - endRow = 0; - } - else { - startRow = (pageSize * currentPage) + 1; - endRow = startRow + pageSize - 1; - if (maxRowFound && endRow > rowCount) { - endRow = rowCount; - } - } - this.lbFirstRowOnPage.innerHTML = this.formatNumber(startRow); - if (this.serverSideRowModel && this.serverSideRowModel.isLoading()) { - this.lbLastRowOnPage.innerHTML = '?'; - } - else { - this.lbLastRowOnPage.innerHTML = this.formatNumber(endRow); + AgSlider.prototype.setValue = function (value) { + if (this.getValue() === value) { + return this; } + this.eText.setValue(value, true); + this.eSlider.setValue(value, true); + this.dispatchEvent({ type: _agAbstractField__WEBPACK_IMPORTED_MODULE_2__["AgAbstractField"].EVENT_CHANGED }); + return this; }; - PaginationComp.prototype.isZeroPagesToDisplay = function () { - var maxRowFound = this.paginationProxy.isLastPageFound(); - var totalPages = this.paginationProxy.getTotalPages(); - return maxRowFound && totalPages === 0; - }; - PaginationComp.prototype.setTotalLabels = function () { - var lastPageFound = this.paginationProxy.isLastPageFound(); - var totalPages = this.paginationProxy.getTotalPages(); - var rowCount = this.paginationProxy.isLastPageFound() ? - this.paginationProxy.getMasterRowCount() : null; - if (lastPageFound) { - this.lbTotal.innerHTML = this.formatNumber(totalPages); - this.lbRecordCount.innerHTML = this.formatNumber(rowCount); - } - else { - var moreText = this.gridOptionsWrapper.getLocaleTextFunc()('more', 'more'); - this.lbTotal.innerHTML = moreText; - this.lbRecordCount.innerHTML = moreText; - } + AgSlider.prototype.setStep = function (step) { + this.eSlider.setStep(step); + this.eText.setStep(step); + return this; }; + AgSlider.TEMPLATE = "
\n \n
\n \n \n
\n
"; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], PaginationComp.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('paginationProxy') - ], PaginationComp.prototype, "paginationProxy", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowRenderer') - ], PaginationComp.prototype, "rowRenderer", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowModel') - ], PaginationComp.prototype, "rowModel", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('btFirst') - ], PaginationComp.prototype, "btFirst", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('btPrevious') - ], PaginationComp.prototype, "btPrevious", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('btNext') - ], PaginationComp.prototype, "btNext", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('btLast') - ], PaginationComp.prototype, "btLast", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('lbRecordCount') - ], PaginationComp.prototype, "lbRecordCount", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('lbFirstRowOnPage') - ], PaginationComp.prototype, "lbFirstRowOnPage", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('lbLastRowOnPage') - ], PaginationComp.prototype, "lbLastRowOnPage", void 0); - __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('eSummaryPanel') - ], PaginationComp.prototype, "eSummaryPanel", void 0); + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eLabel') + ], AgSlider.prototype, "eLabel", void 0); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('lbCurrent') - ], PaginationComp.prototype, "lbCurrent", void 0); + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eSlider') + ], AgSlider.prototype, "eSlider", void 0); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('lbTotal') - ], PaginationComp.prototype, "lbTotal", void 0); + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eText') + ], AgSlider.prototype, "eText", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], PaginationComp.prototype, "postConstruct", null); - return PaginationComp; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); + _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"] + ], AgSlider.prototype, "init", null); + return AgSlider; +}(_agAbstractLabel__WEBPACK_IMPORTED_MODULE_1__["AgAbstractLabel"])); /***/ }), -/* 168 */ +/* 215 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ResizeObserverService", function() { return ResizeObserverService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgColorPicker", function() { return AgColorPicker; }); +/* harmony import */ var _agColorPanel__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(216); +/* harmony import */ var _agDialog__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(209); +/* harmony import */ var _agPickerField__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(69); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(44); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -38895,89 +47254,100 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var ResizeObserverService = /** @class */ (function (_super) { - __extends(ResizeObserverService, _super); - function ResizeObserverService() { - return _super !== null && _super.apply(this, arguments) || this; + +var AgColorPicker = /** @class */ (function (_super) { + __extends(AgColorPicker, _super); + function AgColorPicker(config) { + var _this = _super.call(this, config, 'ag-color-picker', 'colorPicker') || this; + if (config && config.color) { + _this.value = config.color; + } + return _this; } - ResizeObserverService.prototype.observeResize = function (element, callback, debounceDelay) { - if (debounceDelay === void 0) { debounceDelay = 50; } - // put in variable, so available to usePolyfill() function below - var frameworkFactory = this.getFrameworkOverrides(); - // this gets fired too often and might cause some relayout issues - // so we add a debounce to the callback here to avoid the flashing effect. - var debouncedCallback = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].debounce(callback, debounceDelay); - var useBrowserResizeObserver = function () { - var resizeObserver = new window.ResizeObserver(debouncedCallback); - resizeObserver.observe(element); - return function () { return resizeObserver.disconnect(); }; - }; - var usePolyfill = function () { - // initialise to the current width and height, so first call will have no changes - var widthLastTime = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].offsetWidth(element); - var heightLastTime = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].offsetHeight(element); - // when finished, this gets turned to false. - var running = true; - var periodicallyCheckWidthAndHeight = function () { - if (running) { - var newWidth = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].offsetWidth(element); - var newHeight = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].offsetHeight(element); - var changed = newWidth !== widthLastTime || newHeight !== heightLastTime; - if (changed) { - widthLastTime = newWidth; - heightLastTime = newHeight; - callback(); - } - frameworkFactory.setTimeout(periodicallyCheckWidthAndHeight, debounceDelay); - } - }; - periodicallyCheckWidthAndHeight(); - // the callback function we return sets running to false - return function () { return running = false; }; - }; - var suppressResize = this.gridOptionsWrapper.isSuppressBrowserResizeObserver(); - var resizeObserverExists = !!window.ResizeObserver; - if (resizeObserverExists && !suppressResize) { - return useBrowserResizeObserver(); + AgColorPicker.prototype.postConstruct = function () { + _super.prototype.postConstruct.call(this); + if (this.value) { + this.setValue(this.value); } - else { - return usePolyfill(); + }; + AgColorPicker.prototype.showPicker = function () { + var _this = this; + var eGuiRect = this.getGui().getBoundingClientRect(); + var colorDialog = this.createBean(new _agDialog__WEBPACK_IMPORTED_MODULE_1__["AgDialog"]({ + closable: false, + modal: true, + hideTitleBar: true, + minWidth: 190, + width: 190, + height: 250, + x: eGuiRect.right - 190, + y: eGuiRect.top - 250 + })); + this.isPickerDisplayed = true; + colorDialog.addCssClass('ag-color-dialog'); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_3__["setAriaExpanded"])(this.eWrapper, true); + var colorPanel = this.createBean(new _agColorPanel__WEBPACK_IMPORTED_MODULE_0__["AgColorPanel"]({ picker: this })); + colorPanel.addDestroyFunc(function () { + if (colorDialog.isAlive()) { + _this.destroyBean(colorDialog); + } + }); + colorDialog.setParentComponent(this); + colorDialog.setBodyComponent(colorPanel); + colorPanel.setValue(this.getValue()); + colorDialog.addDestroyFunc(function () { + // here we check if the picker was already being + // destroyed to avoid a stack overflow + if (!_this.isDestroyingPicker) { + _this.isDestroyingPicker = true; + if (colorPanel.isAlive()) { + _this.destroyBean(colorPanel); + } + } + else { + _this.isDestroyingPicker = false; + } + if (_this.isAlive()) { + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_3__["setAriaExpanded"])(_this.eWrapper, false); + _this.getFocusableElement().focus(); + } + _this.isPickerDisplayed = false; + }); + return colorDialog; + }; + AgColorPicker.prototype.setValue = function (color) { + if (this.value === color) { + return this; } + this.eDisplayField.style.backgroundColor = color; + return _super.prototype.setValue.call(this, color); }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], ResizeObserverService.prototype, "gridOptionsWrapper", void 0); - ResizeObserverService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('resizeObserverService') - ], ResizeObserverService); - return ResizeObserverService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + AgColorPicker.prototype.getValue = function () { + return this.value; + }; + return AgColorPicker; +}(_agPickerField__WEBPACK_IMPORTED_MODULE_2__["AgPickerField"])); /***/ }), -/* 169 */ +/* 216 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "OverlayWrapperComponent", function() { return OverlayWrapperComponent; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgColorPanel", function() { return AgColorPanel; }); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); +/* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(12); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -39000,116 +47370,268 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; +}; -var LoadingType; -(function (LoadingType) { - LoadingType[LoadingType["Loading"] = 0] = "Loading"; - LoadingType[LoadingType["NoRows"] = 1] = "NoRows"; -})(LoadingType || (LoadingType = {})); -var OverlayWrapperComponent = /** @class */ (function (_super) { - __extends(OverlayWrapperComponent, _super); - function OverlayWrapperComponent() { - var _this = _super.call(this, OverlayWrapperComponent.TEMPLATE) || this; - _this.inProgress = false; - _this.destroyRequested = false; + +var AgColorPanel = /** @class */ (function (_super) { + __extends(AgColorPanel, _super); + function AgColorPanel(config) { + var _this = _super.call(this, AgColorPanel.TEMPLATE) || this; + _this.H = 1; // in the [0, 1] range + _this.S = 1; // in the [0, 1] range + _this.B = 1; // in the [0, 1] range + _this.A = 1; // in the [0, 1] range + _this.isSpectrumDragging = false; + _this.isSpectrumHueDragging = false; + _this.isSpectrumAlphaDragging = false; + _this.colorChanged = false; + _this.picker = config.picker; return _this; } - OverlayWrapperComponent.prototype.postConstruct = function () { - this.gridOptionsWrapper.addLayoutElement(this.eOverlayWrapper); - this.setDisplayed(false); + AgColorPanel.prototype.postConstruct = function () { + var eGui = this.getGui(); + this.initRecentColors(); + this.addManagedListener(this.spectrumVal, 'mousedown', this.onSpectrumDraggerDown.bind(this)); + this.addManagedListener(eGui, 'mousemove', this.onSpectrumDraggerMove.bind(this)); + this.addManagedListener(this.spectrumHue, 'mousedown', this.onSpectrumHueDown.bind(this)); + this.addManagedListener(eGui, 'mousemove', this.onSpectrumHueMove.bind(this)); + this.addManagedListener(this.spectrumAlpha, 'mousedown', this.onSpectrumAlphaDown.bind(this)); + this.addManagedListener(eGui, 'mousemove', this.onSpectrumAlphaMove.bind(this)); + // Listening to `mouseup` on the document on purpose. The user might release the mouse button + // outside the UI control. When the mouse returns back to the control's area, the dragging + // of the thumb is not expected and seen as a bug. + this.addManagedListener(document, 'mouseup', this.onMouseUp.bind(this)); + this.addManagedListener(this.recentColors, 'click', this.onRecentColorClick.bind(this)); + }; + AgColorPanel.prototype.refreshSpectrumRect = function () { + return this.spectrumValRect = this.spectrumVal.getBoundingClientRect(); + }; + AgColorPanel.prototype.refreshHueRect = function () { + return this.spectrumHueRect = this.spectrumHue.getBoundingClientRect(); + }; + AgColorPanel.prototype.refreshAlphaRect = function () { + return this.spectrumAlphaRect = this.spectrumAlpha.getBoundingClientRect(); + }; + AgColorPanel.prototype.onSpectrumDraggerDown = function (e) { + this.refreshSpectrumRect(); + this.isSpectrumDragging = true; + this.moveDragger(e); + }; + AgColorPanel.prototype.onSpectrumDraggerMove = function (e) { + if (this.isSpectrumDragging) { + this.moveDragger(e); + } + }; + AgColorPanel.prototype.onSpectrumHueDown = function (e) { + this.refreshHueRect(); + this.isSpectrumHueDragging = true; + this.moveHueSlider(e); + }; + AgColorPanel.prototype.onSpectrumHueMove = function (e) { + if (this.isSpectrumHueDragging) { + this.moveHueSlider(e); + } + }; + AgColorPanel.prototype.onSpectrumAlphaDown = function (e) { + this.refreshAlphaRect(); + this.isSpectrumAlphaDragging = true; + this.moveAlphaSlider(e); + }; + AgColorPanel.prototype.onSpectrumAlphaMove = function (e) { + if (this.isSpectrumAlphaDragging) { + this.moveAlphaSlider(e); + } + }; + AgColorPanel.prototype.onMouseUp = function () { + this.isSpectrumDragging = false; + this.isSpectrumHueDragging = false; + this.isSpectrumAlphaDragging = false; + }; + AgColorPanel.prototype.moveDragger = function (e) { + var valRect = this.spectrumValRect; + if (valRect) { + var x = e.clientX - valRect.left; + var y = e.clientY - valRect.top; + x = Math.max(x, 0); + x = Math.min(x, valRect.width); + y = Math.max(y, 0); + y = Math.min(y, valRect.height); + this.setSpectrumValue(x / valRect.width, 1 - y / valRect.height); + } + }; + AgColorPanel.prototype.moveHueSlider = function (e) { + var hueRect = this.spectrumHueRect; + if (hueRect) { + var slider = this.spectrumHueSlider; + var sliderRect = slider.getBoundingClientRect(); + var x = e.clientX - hueRect.left; + x = Math.max(x, 0); + x = Math.min(x, hueRect.width); + this.H = 1 - x / hueRect.width; + slider.style.left = (x + sliderRect.width / 2) + 'px'; + this.update(); + } + }; + AgColorPanel.prototype.moveAlphaSlider = function (e) { + var alphaRect = this.spectrumAlphaRect; + if (alphaRect) { + var slider = this.spectrumAlphaSlider; + var sliderRect = slider.getBoundingClientRect(); + var x = e.clientX - alphaRect.left; + x = Math.max(x, 0); + x = Math.min(x, alphaRect.width); + this.A = x / alphaRect.width; + slider.style.left = (x + sliderRect.width / 2) + 'px'; + this.update(); + } + }; + AgColorPanel.prototype.update = function () { + var color = _utils__WEBPACK_IMPORTED_MODULE_1__["Color"].fromHSB(this.H * 360, this.S, this.B, this.A); + var spectrumColor = _utils__WEBPACK_IMPORTED_MODULE_1__["Color"].fromHSB(this.H * 360, 1, 1); + var rgbaColor = color.toRgbaString(); + // the recent color list needs to know color has actually changed + var colorPicker = this.picker; + var existingColor = _utils__WEBPACK_IMPORTED_MODULE_1__["Color"].fromString(colorPicker.getValue()); + if (existingColor.toRgbaString() !== rgbaColor) { + this.colorChanged = true; + } + colorPicker.setValue(rgbaColor); + this.spectrumColor.style.backgroundColor = spectrumColor.toRgbaString(); + this.spectrumDragger.style.backgroundColor = rgbaColor; }; - OverlayWrapperComponent.prototype.setWrapperTypeClass = function (loadingType) { - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addOrRemoveCssClass(this.eOverlayWrapper, 'ag-overlay-loading-wrapper', loadingType === LoadingType.Loading); - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addOrRemoveCssClass(this.eOverlayWrapper, 'ag-overlay-no-rows-wrapper', loadingType === LoadingType.NoRows); + /** + * @param saturation In the [0, 1] interval. + * @param brightness In the [0, 1] interval. + */ + AgColorPanel.prototype.setSpectrumValue = function (saturation, brightness) { + var valRect = this.spectrumValRect || this.refreshSpectrumRect(); + if (valRect) { + var dragger = this.spectrumDragger; + var draggerRect = dragger.getBoundingClientRect(); + saturation = Math.max(0, saturation); + saturation = Math.min(1, saturation); + brightness = Math.max(0, brightness); + brightness = Math.min(1, brightness); + this.S = saturation; + this.B = brightness; + dragger.style.left = (saturation * valRect.width - draggerRect.width / 2) + 'px'; + dragger.style.top = ((1 - brightness) * valRect.height - draggerRect.height / 2) + 'px'; + this.update(); + } }; - OverlayWrapperComponent.prototype.showLoadingOverlay = function () { - var workItem = this.userComponentFactory.newLoadingOverlayComponent({ - api: this.gridOptionsWrapper.getApi() + AgColorPanel.prototype.initRecentColors = function () { + var recentColors = AgColorPanel.recentColors; + var innerHtml = recentColors.map(function (color, index) { + return "
"; }); - this.showOverlay(workItem, LoadingType.Loading); + this.recentColors.innerHTML = innerHtml.join(''); }; - OverlayWrapperComponent.prototype.showNoRowsOverlay = function () { - var workItem = this.userComponentFactory.newNoRowsOverlayComponent({ - api: this.gridOptionsWrapper.getApi() - }); - this.showOverlay(workItem, LoadingType.NoRows); + AgColorPanel.prototype.setValue = function (val) { + var color = _utils__WEBPACK_IMPORTED_MODULE_1__["Color"].fromString(val); + var _a = __read(color.toHSB(), 3), h = _a[0], s = _a[1], b = _a[2]; + this.H = (isNaN(h) ? 0 : h) / 360; + this.A = color.a; + var spectrumHueRect = this.spectrumHueRect || this.refreshHueRect(); + var spectrumAlphaRect = this.spectrumAlphaRect || this.refreshAlphaRect(); + this.spectrumHueSlider.style.left = ((this.H - 1) * -spectrumHueRect.width) + "px"; + this.spectrumAlphaSlider.style.left = (this.A * spectrumAlphaRect.width) + "px"; + this.setSpectrumValue(s, b); }; - OverlayWrapperComponent.prototype.showOverlay = function (workItem, type) { - var _this = this; - if (this.inProgress) { + AgColorPanel.prototype.onRecentColorClick = function (e) { + var target = e.target; + if (!Object(_utils_generic__WEBPACK_IMPORTED_MODULE_4__["exists"])(target.id)) { return; } - this.setWrapperTypeClass(type); - this.destroyActiveOverlay(); - this.inProgress = true; - workItem.then(function (comp) { - _this.inProgress = false; - _this.eOverlayWrapper.appendChild(comp.getGui()); - _this.activeOverlay = comp; - if (_this.destroyRequested) { - _this.destroyRequested = false; - _this.destroyActiveOverlay(); - } - }); - this.setDisplayed(true); + var id = parseInt(target.id, 10); + this.setValue(AgColorPanel.recentColors[id]); + this.destroy(); }; - OverlayWrapperComponent.prototype.destroyActiveOverlay = function () { - if (this.inProgress) { - this.destroyRequested = true; + AgColorPanel.prototype.addRecentColor = function () { + var color = _utils__WEBPACK_IMPORTED_MODULE_1__["Color"].fromHSB(this.H * 360, this.S, this.B, this.A); + var rgbaColor = color.toRgbaString(); + var recentColors = AgColorPanel.recentColors; + if (!this.colorChanged || recentColors[0] === rgbaColor) { return; } - if (!this.activeOverlay) { - return; + // remove duplicate color + recentColors = recentColors.filter(function (currentColor) { return currentColor != rgbaColor; }); + // add color to head + recentColors = [rgbaColor].concat(recentColors); + // ensure we don't exceed max number of recent colors + if (recentColors.length > AgColorPanel.maxRecentColors) { + recentColors = recentColors.slice(0, AgColorPanel.maxRecentColors); } - this.activeOverlay = this.getContext().destroyBean(this.activeOverlay); - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].clearElement(this.eOverlayWrapper); - }; - OverlayWrapperComponent.prototype.hideOverlay = function () { - this.destroyActiveOverlay(); - this.setDisplayed(false); + AgColorPanel.recentColors = recentColors; }; - OverlayWrapperComponent.prototype.destroy = function () { - this.destroyActiveOverlay(); + AgColorPanel.prototype.destroy = function () { + this.addRecentColor(); _super.prototype.destroy.call(this); }; - // wrapping in outer div, and wrapper, is needed to center the loading icon - // The idea for centering came from here: http://www.vanseodesign.com/css/vertical-centering/ - OverlayWrapperComponent.TEMPLATE = "\n
\n
\n
\n
\n
"; + AgColorPanel.maxRecentColors = 8; + AgColorPanel.recentColors = []; + AgColorPanel.TEMPLATE = "
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
"; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], OverlayWrapperComponent.prototype, "gridOptionsWrapper", void 0); + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumColor') + ], AgColorPanel.prototype, "spectrumColor", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('userComponentFactory') - ], OverlayWrapperComponent.prototype, "userComponentFactory", void 0); + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumVal') + ], AgColorPanel.prototype, "spectrumVal", void 0); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('eOverlayWrapper') - ], OverlayWrapperComponent.prototype, "eOverlayWrapper", void 0); + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumDragger') + ], AgColorPanel.prototype, "spectrumDragger", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], OverlayWrapperComponent.prototype, "postConstruct", null); - return OverlayWrapperComponent; -}(_widgets_component__WEBPACK_IMPORTED_MODULE_1__["Component"])); + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumHue') + ], AgColorPanel.prototype, "spectrumHue", void 0); + __decorate([ + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumHueSlider') + ], AgColorPanel.prototype, "spectrumHueSlider", void 0); + __decorate([ + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumAlpha') + ], AgColorPanel.prototype, "spectrumAlpha", void 0); + __decorate([ + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumAlphaSlider') + ], AgColorPanel.prototype, "spectrumAlphaSlider", void 0); + __decorate([ + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('recentColors') + ], AgColorPanel.prototype, "recentColors", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"] + ], AgColorPanel.prototype, "postConstruct", null); + return AgColorPanel; +}(_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); /***/ }), -/* 170 */ +/* 217 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgGroupComponent", function() { return AgGroupComponent; }); -/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); -/* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgInputNumberField", function() { return AgInputNumberField; }); +/* harmony import */ var _agInputTextField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(212); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(42); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -39126,233 +47648,100 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - -var defaultItemAlign = 'center'; -var defaultDirection = 'vertical'; -var AgGroupComponent = /** @class */ (function (_super) { - __extends(AgGroupComponent, _super); - function AgGroupComponent(params) { - if (params === void 0) { params = {}; } - var _this = _super.call(this, AgGroupComponent.getTemplate(params)) || this; - _this.suppressEnabledCheckbox = true; - _this.suppressOpenCloseIcons = false; - var title = params.title, enabled = params.enabled, items = params.items, suppressEnabledCheckbox = params.suppressEnabledCheckbox, suppressOpenCloseIcons = params.suppressOpenCloseIcons; - _this.title = title; - _this.cssIdentifier = params.cssIdentifier || 'default'; - _this.enabled = enabled != null ? enabled : true; - _this.items = items || []; - _this.alignItems = params.alignItems || 'center'; - if (suppressEnabledCheckbox != null) { - _this.suppressEnabledCheckbox = suppressEnabledCheckbox; - } - if (suppressOpenCloseIcons != null) { - _this.suppressOpenCloseIcons = suppressOpenCloseIcons; - } - return _this; +var AgInputNumberField = /** @class */ (function (_super) { + __extends(AgInputNumberField, _super); + function AgInputNumberField(config) { + return _super.call(this, config, 'ag-number-field', 'number') || this; } - AgGroupComponent.getTemplate = function (params) { - var cssIdentifier = params.cssIdentifier || 'default'; - var direction = params.direction || 'vertical'; - return /* html */ "
\n
\n \n \n \n
\n
\n \n
\n
\n
"; - }; - AgGroupComponent.prototype.postConstruct = function () { - if (this.items.length) { - var initialItems = this.items; - this.items = []; - this.addItems(initialItems); - } - var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc(); - this.cbGroupEnabled.setLabel(localeTextFunc('enabled', 'Enabled')); - if (this.title) { - this.setTitle(this.title); - } - if (this.enabled) { - this.setEnabled(this.enabled); - } - this.setAlignItems(this.alignItems); - this.hideEnabledCheckbox(this.suppressEnabledCheckbox); - this.hideOpenCloseIcons(this.suppressOpenCloseIcons); - this.setupExpandContract(); - this.refreshChildDisplay(); - }; - AgGroupComponent.prototype.setupExpandContract = function () { + AgInputNumberField.prototype.postConstruct = function () { var _this = this; - this.eGroupClosedIcon.appendChild(_utils__WEBPACK_IMPORTED_MODULE_4__["_"].createIcon('columnSelectClosed', this.gridOptionsWrapper, null)); - this.eGroupOpenedIcon.appendChild(_utils__WEBPACK_IMPORTED_MODULE_4__["_"].createIcon('columnSelectOpen', this.gridOptionsWrapper, null)); - this.addManagedListener(this.eTitleBar, 'click', function () { return _this.toggleGroupExpand(); }); - this.addManagedListener(this.eTitleBar, 'keydown', function (e) { - if (e.keyCode === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_ENTER) { - _this.toggleGroupExpand(); + _super.prototype.postConstruct.call(this); + this.addManagedListener(this.eInput, 'blur', function () { + var floatedValue = parseFloat(_this.eInput.value); + var value = isNaN(floatedValue) ? '' : _this.normalizeValue(floatedValue.toString()); + if (_this.value !== value) { + _this.setValue(value); } }); + this.eInput.step = 'any'; }; - AgGroupComponent.prototype.refreshChildDisplay = function () { - var showIcon = !this.suppressOpenCloseIcons; - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].setDisplayed(this.eGroupClosedIcon, showIcon && !this.expanded); - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].setDisplayed(this.eGroupOpenedIcon, showIcon && this.expanded); - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].setDisplayed(this.eToolbar, this.expanded && !this.suppressEnabledCheckbox); - }; - AgGroupComponent.prototype.isExpanded = function () { - return this.expanded; - }; - AgGroupComponent.prototype.setAlignItems = function (alignment) { - var eGui = this.getGui(); - if (this.alignItems !== alignment) { - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].removeCssClass(eGui, "ag-group-item-alignment-" + this.alignItems); - } - this.alignItems = alignment; - var newCls = "ag-group-item-alignment-" + this.alignItems; - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(eGui, newCls); - return this; - }; - AgGroupComponent.prototype.toggleGroupExpand = function (expanded) { - if (this.suppressOpenCloseIcons) { - this.expanded = true; - this.refreshChildDisplay(); - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].setDisplayed(this.eContainer, true); - return this; + AgInputNumberField.prototype.normalizeValue = function (value) { + if (value === '') { + return ''; } - expanded = expanded != null ? expanded : !this.expanded; - if (this.expanded === expanded) { - return this; + if (this.precision) { + value = this.adjustPrecision(value); } - this.expanded = expanded; - this.refreshChildDisplay(); - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].setDisplayed(this.eContainer, expanded); - if (this.expanded) { - this.dispatchEvent({ type: AgGroupComponent.EVENT_EXPANDED }); + var val = parseFloat(value); + if (this.min != null && val < this.min) { + value = this.min.toString(); } - else { - this.dispatchEvent({ type: AgGroupComponent.EVENT_COLLAPSED }); + else if (this.max != null && val > this.max) { + value = this.max.toString(); } - return this; - }; - AgGroupComponent.prototype.addItems = function (items) { - var _this = this; - items.forEach(function (item) { return _this.addItem(item); }); - }; - AgGroupComponent.prototype.addItem = function (item) { - var container = this.eContainer; - var el = item instanceof _component__WEBPACK_IMPORTED_MODULE_0__["Component"] ? item.getGui() : item; - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(el, 'ag-group-item'); - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(el, "ag-" + this.cssIdentifier + "-group-item"); - container.appendChild(el); - this.items.push(el); - }; - AgGroupComponent.prototype.hideItem = function (hide, index) { - var itemToHide = this.items[index]; - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addOrRemoveCssClass(itemToHide, 'ag-hidden', hide); - }; - AgGroupComponent.prototype.setTitle = function (title) { - this.eTitle.innerText = title; - return this; + return value; }; - AgGroupComponent.prototype.addCssClassToTitleBar = function (cssClass) { - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(this.eTitleBar, cssClass); + AgInputNumberField.prototype.adjustPrecision = function (value) { + if (this.precision) { + var floatString = parseFloat(value).toFixed(this.precision); + value = parseFloat(floatString).toString(); + } + return value; }; - AgGroupComponent.prototype.setEnabled = function (enabled, skipToggle) { - this.enabled = enabled; - this.refreshDisabledStyles(); - this.toggleGroupExpand(enabled); - if (!skipToggle) { - this.cbGroupEnabled.setValue(enabled); + AgInputNumberField.prototype.setMin = function (min) { + if (this.min === min) { + return this; } + this.min = min; + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["addOrRemoveAttribute"])(this.eInput, 'min', min); return this; }; - AgGroupComponent.prototype.isEnabled = function () { - return this.enabled; - }; - AgGroupComponent.prototype.onEnableChange = function (callbackFn) { - var _this = this; - this.cbGroupEnabled.onValueChange(function (newSelection) { - _this.setEnabled(newSelection, true); - callbackFn(newSelection); - }); + AgInputNumberField.prototype.setMax = function (max) { + if (this.max === max) { + return this; + } + this.max = max; + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["addOrRemoveAttribute"])(this.eInput, 'max', max); return this; }; - AgGroupComponent.prototype.hideEnabledCheckbox = function (hide) { - this.suppressEnabledCheckbox = hide; - this.refreshChildDisplay(); - this.refreshDisabledStyles(); + AgInputNumberField.prototype.setPrecision = function (precision) { + this.precision = precision; return this; }; - AgGroupComponent.prototype.hideOpenCloseIcons = function (hide) { - this.suppressOpenCloseIcons = hide; - if (hide) { - this.toggleGroupExpand(true); + AgInputNumberField.prototype.setStep = function (step) { + if (this.step === step) { + return this; } + this.step = step; + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["addOrRemoveAttribute"])(this.eInput, 'step', step); return this; }; - AgGroupComponent.prototype.refreshDisabledStyles = function () { - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addOrRemoveCssClass(this.getGui(), 'ag-disabled', !this.enabled); - if (this.suppressEnabledCheckbox && !this.enabled) { - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(this.eTitleBar, 'ag-disabled-group-title-bar'); - this.eTitleBar.removeAttribute('tabindex'); - } - else { - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].removeCssClass(this.eTitleBar, 'ag-disabled-group-title-bar'); - this.eTitleBar.setAttribute('tabindex', '0'); + AgInputNumberField.prototype.setValue = function (value, silent) { + value = this.adjustPrecision(value); + var normalizedValue = this.normalizeValue(value); + if (value != normalizedValue) { + return this; } - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addOrRemoveCssClass(this.eContainer, 'ag-disabled-group-container', !this.enabled); + return _super.prototype.setValue.call(this, value, silent); }; - AgGroupComponent.EVENT_EXPANDED = 'expanded'; - AgGroupComponent.EVENT_COLLAPSED = 'collapsed'; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper') - ], AgGroupComponent.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eTitleBar') - ], AgGroupComponent.prototype, "eTitleBar", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eGroupOpenedIcon') - ], AgGroupComponent.prototype, "eGroupOpenedIcon", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eGroupClosedIcon') - ], AgGroupComponent.prototype, "eGroupClosedIcon", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eToolbar') - ], AgGroupComponent.prototype, "eToolbar", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('cbGroupEnabled') - ], AgGroupComponent.prototype, "cbGroupEnabled", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eTitle') - ], AgGroupComponent.prototype, "eTitle", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eContainer') - ], AgGroupComponent.prototype, "eContainer", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] - ], AgGroupComponent.prototype, "postConstruct", null); - return AgGroupComponent; -}(_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); + return AgInputNumberField; +}(_agInputTextField__WEBPACK_IMPORTED_MODULE_0__["AgInputTextField"])); /***/ }), -/* 171 */ +/* 218 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgDialog", function() { return AgDialog; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _agPanel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(172); -/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(56); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgInputRange", function() { return AgInputRange; }); +/* harmony import */ var _agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(71); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -39369,328 +47758,76 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - -var AgDialog = /** @class */ (function (_super) { - __extends(AgDialog, _super); - function AgDialog(config) { - var _this = _super.call(this, config) || this; - _this.RESIZE_TEMPLATE = "
\n
\n
\n
\n
\n
\n
\n
\n
\n
"; - _this.MAXIMIZE_BTN_TEMPLATE = "
"; - _this.resizable = {}; - _this.movable = false; - _this.isMoving = false; - _this.isMaximizable = false; - _this.isMaximized = false; - _this.maximizeListeners = []; - _this.resizeListenerDestroy = null; - _this.isResizing = false; - _this.lastPosition = { - x: 0, - y: 0, - width: 0, - height: 0 - }; - return _this; - } - AgDialog.prototype.postConstruct = function () { - var _this = this; - var eGui = this.getGui(); - var _a = this.config, movable = _a.movable, resizable = _a.resizable, maximizable = _a.maximizable; - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(eGui, 'ag-dialog'); - this.moveElement = this.eTitleBar; - _super.prototype.postConstruct.call(this); - this.addManagedListener(eGui, 'focusin', function (e) { - if (eGui.contains(e.relatedTarget)) { - return; - } - _this.popupService.bringPopupToFront(eGui); - }); - if (movable) { - this.setMovable(movable); - } - if (maximizable) { - this.setMaximizable(maximizable); - } - this.addResizers(); - if (resizable) { - this.setResizable(resizable); - } - }; - AgDialog.prototype.renderComponent = function () { - var eGui = this.getGui(); - var _a = this.config, alwaysOnTop = _a.alwaysOnTop, modal = _a.modal; - this.close = this.popupService.addPopup(modal, eGui, true, this.destroy.bind(this), undefined, alwaysOnTop); - eGui.focus(); - }; - AgDialog.prototype.addResizers = function () { - var eGui = this.getGui(); - if (!eGui) { - return; - } - var parser = new DOMParser(); - var resizers = parser.parseFromString(this.RESIZE_TEMPLATE, 'text/html').body; - eGui.appendChild(resizers.firstChild); - this.createMap(); - }; - AgDialog.prototype.createMap = function () { - var eGui = this.getGui(); - this.resizerMap = { - topLeft: { element: eGui.querySelector('[ref=eTopLeftResizer]') }, - top: { element: eGui.querySelector('[ref=eTopResizer]') }, - topRight: { element: eGui.querySelector('[ref=eTopRightResizer]') }, - right: { element: eGui.querySelector('[ref=eRightResizer]') }, - bottomRight: { element: eGui.querySelector('[ref=eBottomRightResizer]') }, - bottom: { element: eGui.querySelector('[ref=eBottomResizer]') }, - bottomLeft: { element: eGui.querySelector('[ref=eBottomLeftResizer]') }, - left: { element: eGui.querySelector('[ref=eLeftResizer]') } - }; - }; - AgDialog.prototype.getResizerElement = function (side) { - return this.resizerMap[side].element; - }; - AgDialog.prototype.onResizeStart = function (e) { - this.isResizing = true; - this.updateDragStartPosition(e.clientX, e.clientY); - }; - AgDialog.prototype.onResize = function (e, side) { - if (!this.isResizing) { - return; - } - var isLeft = !!side.match(/left/i); - var isRight = !!side.match(/right/i); - var isTop = !!side.match(/top/i); - var isBottom = !!side.match(/bottom/i); - var isHorizontal = isLeft || isRight; - var isVertical = isTop || isBottom; - var _a = this.calculateMouseMovement({ e: e, isLeft: isLeft, isTop: isTop }), movementX = _a.movementX, movementY = _a.movementY; - var offsetLeft = 0; - var offsetTop = 0; - if (isHorizontal && movementX) { - var direction = isLeft ? -1 : 1; - var oldWidth = this.getWidth(); - var newWidth = oldWidth + (movementX * direction); - var skipWidth = false; - if (isLeft) { - offsetLeft = oldWidth - newWidth; - if (this.position.x + offsetLeft <= 0 || newWidth <= this.minWidth) { - skipWidth = true; - offsetLeft = 0; - } - } - if (!skipWidth) { - this.setWidth(newWidth); - } - } - if (isVertical && movementY) { - var direction = isTop ? -1 : 1; - var oldHeight = this.getHeight(); - var newHeight = oldHeight + (movementY * direction); - var skipHeight = false; - if (isTop) { - offsetTop = oldHeight - newHeight; - if (this.position.y + offsetTop <= 0 || newHeight <= this.minHeight) { - skipHeight = true; - offsetTop = 0; - } - } - if (!skipHeight) { - this.setHeight(newHeight); - } - } - this.updateDragStartPosition(e.clientX, e.clientY); - if (offsetLeft || offsetTop) { - this.offsetElement(this.position.x + offsetLeft, this.position.y + offsetTop); - } - }; - AgDialog.prototype.onResizeEnd = function () { - this.isResizing = false; - var params = { - type: 'resize', - api: this.gridOptionsWrapper.getApi(), - columnApi: this.gridOptionsWrapper.getColumnApi() - }; - this.dispatchEvent(params); - }; - AgDialog.prototype.onMoveStart = function (e) { - this.isMoving = true; - this.updateDragStartPosition(e.clientX, e.clientY); - }; - AgDialog.prototype.onMove = function (e) { - if (!this.isMoving) { - return; - } - var _a = this.position, x = _a.x, y = _a.y; - var _b = this.calculateMouseMovement({ - e: e, - isTop: true, - anywhereWithin: true, - topBuffer: this.getHeight() - this.getBodyHeight() - }), movementX = _b.movementX, movementY = _b.movementY; - this.offsetElement(x + movementX, y + movementY); - this.updateDragStartPosition(e.clientX, e.clientY); - }; - AgDialog.prototype.onMoveEnd = function () { - this.isMoving = false; - }; - AgDialog.prototype.toggleMaximize = function () { - if (this.isMaximized) { - var _a = this.lastPosition, x = _a.x, y = _a.y, width = _a.width, height = _a.height; - this.setWidth(width); - this.setHeight(height); - this.offsetElement(x, y); - } - else { - this.lastPosition.width = this.getWidth(); - this.lastPosition.height = this.getHeight(); - this.lastPosition.x = this.position.x; - this.lastPosition.y = this.position.y; - this.offsetElement(0, 0); - this.setHeight('100%'); - this.setWidth('100%'); - } - this.isMaximized = !this.isMaximized; - this.refreshMaximizeIcon(); - }; - AgDialog.prototype.refreshMaximizeIcon = function () { - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addOrRemoveCssClass(this.maximizeIcon, 'ag-hidden', this.isMaximized); - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addOrRemoveCssClass(this.minimizeIcon, 'ag-hidden', !this.isMaximized); - }; - AgDialog.prototype.clearMaximizebleListeners = function () { - if (this.maximizeListeners.length) { - this.maximizeListeners.forEach(function (destroyListener) { return destroyListener(); }); - this.maximizeListeners.length = 0; +var AgInputRange = /** @class */ (function (_super) { + __extends(AgInputRange, _super); + function AgInputRange(config) { + return _super.call(this, config, 'ag-range-field', 'range') || this; + } + AgInputRange.prototype.postConstruct = function () { + _super.prototype.postConstruct.call(this); + var _a = this.config, min = _a.min, max = _a.max, step = _a.step; + if (min != null) { + this.setMinValue(min); } - if (this.resizeListenerDestroy) { - this.resizeListenerDestroy(); - this.resizeListenerDestroy = null; + if (max != null) { + this.setMaxValue(max); } + this.setStep(step || 1); }; - AgDialog.prototype.destroy = function () { - this.setResizable(false); - this.setMovable(false); - this.maximizeButtonComp = this.destroyBean(this.maximizeButtonComp); - this.clearMaximizebleListeners(); - _super.prototype.destroy.call(this); - }; - AgDialog.prototype.setResizable = function (resizable) { + AgInputRange.prototype.addInputListeners = function () { var _this = this; - if (typeof resizable === 'boolean') { - resizable = { - topLeft: resizable, - top: resizable, - topRight: resizable, - right: resizable, - bottomRight: resizable, - bottom: resizable, - bottomLeft: resizable, - left: resizable - }; - } - Object.keys(resizable).forEach(function (side) { - var r = resizable; - var s = side; - var val = !!r[s]; - var el = _this.getResizerElement(s); - var params = _this.resizerMap[s].dragSource || { - eElement: el, - onDragStart: _this.onResizeStart.bind(_this), - onDragging: function (e) { return _this.onResize(e, s); }, - onDragStop: _this.onResizeEnd.bind(_this), - }; - if (!!_this.resizable[s] !== val || (!_this.isAlive() && !val)) { - if (val) { - _this.dragService.addDragSource(params); - el.style.pointerEvents = 'all'; - } - else { - _this.dragService.removeDragSource(params); - el.style.pointerEvents = 'none'; - } - _this.resizerMap[s].dragSource = val ? params : undefined; - } + this.addManagedListener(this.eInput, 'input', function (e) { + var value = e.target.value; + _this.setValue(value); }); }; - AgDialog.prototype.setMovable = function (movable) { - if (movable === this.movable) { - return; - } - this.movable = movable; - var params = this.moveElementDragListener || { - eElement: this.moveElement, - onDragStart: this.onMoveStart.bind(this), - onDragging: this.onMove.bind(this), - onDragStop: this.onMoveEnd.bind(this) - }; - if (movable) { - this.dragService.addDragSource(params); - this.moveElementDragListener = params; - } - else { - this.dragService.removeDragSource(params); - this.moveElementDragListener = undefined; - } + AgInputRange.prototype.setMinValue = function (value) { + this.min = value; + this.eInput.setAttribute('min', value.toString()); + return this; }; - AgDialog.prototype.setMaximizable = function (maximizable) { - var _this = this; - if (maximizable === false) { - this.clearMaximizebleListeners(); - if (this.maximizeButtonComp) { - this.destroyBean(this.maximizeButtonComp); - this.maximizeButtonComp = this.maximizeIcon = this.minimizeIcon = undefined; - } - return; + AgInputRange.prototype.setMaxValue = function (value) { + this.max = value; + this.eInput.setAttribute('max', value.toString()); + return this; + }; + AgInputRange.prototype.setStep = function (value) { + this.eInput.setAttribute('step', value.toString()); + return this; + }; + AgInputRange.prototype.setValue = function (value, silent) { + if (this.min != null) { + value = Math.max(parseFloat(value), this.min).toString(); } - var eTitleBar = this.eTitleBar; - if (!eTitleBar || maximizable === this.isMaximizable) { - return; + if (this.max != null) { + value = Math.min(parseFloat(value), this.max).toString(); } - var maximizeButtonComp = this.maximizeButtonComp = new _component__WEBPACK_IMPORTED_MODULE_2__["Component"](this.MAXIMIZE_BTN_TEMPLATE); - this.getContext().createBean(maximizeButtonComp); - var eGui = maximizeButtonComp.getGui(); - eGui.appendChild(this.maximizeIcon = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].createIconNoSpan('maximize', this.gridOptionsWrapper)); - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(this.maximizeIcon, 'ag-panel-title-bar-button-icon'); - eGui.appendChild(this.minimizeIcon = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].createIconNoSpan('minimize', this.gridOptionsWrapper)); - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(this.minimizeIcon, 'ag-panel-title-bar-button-icon'); - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(this.minimizeIcon, 'ag-hidden'); - maximizeButtonComp.addManagedListener(eGui, 'click', this.toggleMaximize.bind(this)); - this.addTitleBarButton(maximizeButtonComp, 0); - this.maximizeListeners.push(this.addManagedListener(eTitleBar, 'dblclick', this.toggleMaximize.bind(this))); - this.resizeListenerDestroy = this.addManagedListener(this, 'resize', function () { - _this.isMaximized = false; - _this.refreshMaximizeIcon(); - }); + var ret = _super.prototype.setValue.call(this, value, silent); + this.eInput.value = value; + return ret; }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('dragService') - ], AgDialog.prototype, "dragService", void 0); - return AgDialog; -}(_agPanel__WEBPACK_IMPORTED_MODULE_1__["AgPanel"])); + return AgInputRange; +}(_agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractInputField"])); /***/ }), -/* 172 */ +/* 219 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgPanel", function() { return AgPanel; }); -/* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(56); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgAngleSelect", function() { return AgAngleSelect; }); +/* harmony import */ var _agAbstractLabel__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(68); +/* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(67); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(42); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -39717,356 +47854,395 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var AgPanel = /** @class */ (function (_super) { - __extends(AgPanel, _super); - function AgPanel(config) { - var _this = _super.call(this, AgPanel.getTemplate(config)) || this; - _this.closable = true; - _this.positioned = false; - _this.dragStartPosition = { - x: 0, - y: 0 - }; - _this.position = { - x: 0, - y: 0 - }; - _this.size = { - width: undefined, - height: undefined - }; - _this.config = config; + + +var AgAngleSelect = /** @class */ (function (_super) { + __extends(AgAngleSelect, _super); + function AgAngleSelect(config) { + var _this = _super.call(this, config, AgAngleSelect.TEMPLATE) || this; + _this.radius = 0; + _this.offsetX = 0; + _this.offsetY = 0; return _this; } - AgPanel.getTemplate = function (config) { - var cssIdentifier = (config && config.cssIdentifier) || 'default'; - return /* html */ "
\n
\n \n
\n
\n
\n
"; - }; - AgPanel.prototype.postConstruct = function () { + AgAngleSelect.prototype.postConstruct = function () { var _this = this; - var _a = this.config, component = _a.component, closable = _a.closable, hideTitleBar = _a.hideTitleBar, title = _a.title, minWidth = _a.minWidth, width = _a.width, minHeight = _a.minHeight, height = _a.height, centered = _a.centered, x = _a.x, y = _a.y; - var eGui = this.getGui(); - if (component) { - this.setBodyComponent(component); - } - if (!hideTitleBar) { - if (title) { - this.setTitle(title); + _super.prototype.postConstruct.call(this); + this.dragListener = { + eElement: this.eParentCircle, + dragStartPixels: 0, + onDragStart: function (e) { + _this.parentCircleRect = _this.eParentCircle.getBoundingClientRect(); + }, + onDragging: function (e) { return _this.calculateAngleDrag(e); }, + onDragStop: function () { } + }; + this.dragService.addDragSource(this.dragListener); + this.eAngleValue + .setLabel('') + .setLabelWidth(5) + .setInputWidth(45) + .setMin(0) + .setMax(360) + .setValue("" + this.degrees) + .onValueChange(function (value) { + if (value == null || value === '') { + value = '0'; } - this.setClosable(closable != null ? closable : this.closable); - } - else { - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(this.eTitleBar, 'ag-hidden'); + value = _this.eAngleValue.normalizeValue(value); + var floatValue = parseFloat(value); + if (floatValue > 180) { + floatValue = floatValue - 360; + } + _this.setValue(floatValue); + }); + this.updateNumberInput(); + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_4__["exists"])(this.getValue())) { + this.eAngleValue.setValue(this.normalizeNegativeValue(this.getValue()).toString()); } - this.addManagedListener(this.eTitleBar, 'mousedown', function (e) { - if (eGui.contains(e.relatedTarget) || - eGui.contains(document.activeElement) || - _this.eTitleBarButtons.contains(e.target)) { - e.preventDefault(); + this.addManagedListener(this, _agAbstractField__WEBPACK_IMPORTED_MODULE_3__["AgAbstractField"].EVENT_CHANGED, function () { + var eDocument = _this.gridOptionsWrapper.getDocument(); + if (_this.eAngleValue.getInputElement().contains(eDocument.activeElement)) { return; } - var focusEl = _this.eContentWrapper.querySelector('button, [href], input, select, textarea, [tabindex]'); - if (focusEl) { - focusEl.focus(); - } + _this.updateNumberInput(); }); - if (this.positioned) { - return; - } - this.minHeight = minHeight != null ? minHeight : 250; - this.minWidth = minWidth != null ? minWidth : 250; - this.popupParent = this.popupService.getPopupParent(); - if (width) { - this.setWidth(width); - } - if (height) { - this.setHeight(height); - } - if (this.renderComponent) { - this.renderComponent(); - } - if (!width || !height) { - this.refreshSize(); - } - if (centered) { - this.center(); - } - else if (x || y) { - this.offsetElement(x, y); - } - this.positioned = true; - this.eContentWrapper.style.height = '0'; }; - AgPanel.prototype.renderComponent = function () { - var _this = this; - var eGui = this.getGui(); - eGui.focus(); - this.close = function () { - eGui.parentElement.removeChild(eGui); - _this.destroy(); - }; + AgAngleSelect.prototype.updateNumberInput = function () { + var normalizedValue = this.normalizeNegativeValue(this.getValue()); + this.eAngleValue.setValue(normalizedValue.toString()); }; - AgPanel.prototype.updateDragStartPosition = function (x, y) { - this.dragStartPosition = { x: x, y: y }; + AgAngleSelect.prototype.positionChildCircle = function (radians) { + var rect = this.parentCircleRect || { width: 24, height: 24 }; + var eChildCircle = this.eChildCircle; + var centerX = rect.width / 2; + var centerY = rect.height / 2; + eChildCircle.style.left = centerX + Math.cos(radians) * 8 + "px"; + eChildCircle.style.top = centerY + Math.sin(radians) * 8 + "px"; }; - AgPanel.prototype.calculateMouseMovement = function (params) { - var parentRect = this.popupParent.getBoundingClientRect(); - var e = params.e, isLeft = params.isLeft, isTop = params.isTop, anywhereWithin = params.anywhereWithin, topBuffer = params.topBuffer; - var movementX = e.clientX - this.dragStartPosition.x; - var movementY = e.clientY - this.dragStartPosition.y; - var width = this.getWidth(); - var height = this.getHeight(); - // skip if cursor is outside of popupParent horizontally - var skipX = (parentRect.left >= e.clientX && this.position.x <= 0 || - parentRect.right <= e.clientX && parentRect.right <= this.position.x + parentRect.left + width); - if (!skipX) { - if (isLeft) { - skipX = ( - // skip if we are moving to the left and the cursor - // is positioned to the right of the left side anchor - (movementX < 0 && e.clientX > this.position.x + parentRect.left) || - // skip if we are moving to the right and the cursor - // is positioned to the left of the dialog - (movementX > 0 && e.clientX < this.position.x + parentRect.left)); - } - else { - if (anywhereWithin) { - // if anywhereWithin is true, we allow to move - // as long as the cursor is within the dialog - skipX = ((movementX < 0 && e.clientX > this.position.x + parentRect.left + width) || - (movementX > 0 && e.clientX < this.position.x + parentRect.left)); - } - else { - skipX = ( - // if the movement is bound to the right side of the dialog - // we skip if we are moving to the left and the cursor - // is to the right of the dialog - (movementX < 0 && e.clientX > this.position.x + parentRect.left + width) || - // or skip if we are moving to the right and the cursor - // is to the left of the right side anchor - (movementX > 0 && e.clientX < this.position.x + parentRect.left + width)); - } - } - } - movementX = skipX ? 0 : movementX; - var skipY = ( - // skip if cursor is outside of popupParent vertically - parentRect.top >= e.clientY && this.position.y <= 0 || - parentRect.bottom <= e.clientY && parentRect.bottom <= this.position.y + parentRect.top + height || - isTop && ( - // skip if we are moving to towards top and the cursor is - // below the top anchor + topBuffer - // note: topBuffer is used when moving the dialog using the title bar - (movementY < 0 && e.clientY > this.position.y + parentRect.top + (topBuffer || 0)) || - // skip if we are moving to the bottom and the cursor is - // above the top anchor - (movementY > 0 && e.clientY < this.position.y + parentRect.top)) || - // we are anchored to the bottom of the dialog - !isTop && ( - // skip if we are moving towards the top and the cursor - // is below the bottom anchor - (movementY < 0 && e.clientY > this.position.y + parentRect.top + height) || - // skip if we are moving towards the bottom and the cursor - // is above the bottom anchor - (movementY > 0 && e.clientY < this.position.y + parentRect.top + height))); - movementY = skipY ? 0 : movementY; - return { movementX: movementX, movementY: movementY }; + AgAngleSelect.prototype.calculatePolar = function () { + var x = this.offsetX; + var y = this.offsetY; + var radians = Math.atan2(y, x); + this.degrees = this.toDegrees(radians); + this.radius = Math.sqrt((x * x) + (y * y)); + this.positionChildCircle(radians); + }; + AgAngleSelect.prototype.calculateCartesian = function () { + var radians = this.toRadians(this.getValue()); + var radius = this.getRadius(); + this + .setOffsetX(Math.cos(radians) * radius) + .setOffsetY(Math.sin(radians) * radius); }; - AgPanel.prototype.refreshSize = function () { - var _a = this.size, width = _a.width, height = _a.height; - if (!width) { - this.setWidth(this.getGui().offsetWidth); + AgAngleSelect.prototype.setOffsetX = function (offset) { + if (this.offsetX !== offset) { + this.offsetX = offset; + this.calculatePolar(); } - if (!height) { - this.setHeight(this.getGui().offsetHeight); + return this; + }; + AgAngleSelect.prototype.setOffsetY = function (offset) { + if (this.offsetY !== offset) { + this.offsetY = offset; + this.calculatePolar(); } + return this; }; - AgPanel.prototype.offsetElement = function (x, y) { - if (x === void 0) { x = 0; } - if (y === void 0) { y = 0; } - var ePopup = this.getGui(); - this.popupService.positionPopup({ - ePopup: ePopup, - x: x, - y: y, - minWidth: this.minWidth, - minHeight: this.minHeight, - keepWithinBounds: true - }); - this.position.x = parseInt(ePopup.style.left, 10); - this.position.y = parseInt(ePopup.style.top, 10); + AgAngleSelect.prototype.calculateAngleDrag = function (e) { + var rect = this.parentCircleRect; + var centerX = rect.width / 2; + var centerY = rect.height / 2; + var x = e.clientX - rect.left; + var y = e.clientY - rect.top; + var dx = x - centerX; + var dy = y - centerY; + var radians = Math.atan2(dy, dx); + this.setValue(radians, true); }; - AgPanel.prototype.getHeight = function () { - return this.size.height; + AgAngleSelect.prototype.toDegrees = function (radians) { + return radians / Math.PI * 180; }; - AgPanel.prototype.setHeight = function (height) { - var eGui = this.getGui(); - var isPercent = false; - if (typeof height === 'string' && height.indexOf('%') !== -1) { - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].setFixedHeight(eGui, height); - height = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].getAbsoluteHeight(eGui); - isPercent = true; - } - else { - height = Math.max(this.minHeight, height); - var offsetParent = eGui.offsetParent; - if (offsetParent && offsetParent.clientHeight && (height + this.position.y > offsetParent.clientHeight)) { - height = offsetParent.clientHeight - this.position.y; - } - } - if (this.size.height === height) { - return; + AgAngleSelect.prototype.toRadians = function (degrees) { + return degrees / 180 * Math.PI; + }; + AgAngleSelect.prototype.normalizeNegativeValue = function (degrees) { + return degrees < 0 ? 360 + degrees : degrees; + }; + AgAngleSelect.prototype.normalizeAngle180 = function (radians) { + radians %= Math.PI * 2; + if (radians < -Math.PI) { + radians += Math.PI * 2; } - this.size.height = height; - if (!isPercent) { - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].setFixedHeight(eGui, height); + else if (radians >= Math.PI) { + radians -= Math.PI * 2; } - else { - eGui.style.maxHeight = 'unset'; - eGui.style.minHeight = 'unset'; + return radians; + }; + AgAngleSelect.prototype.getRadius = function () { + return this.radius; + }; + AgAngleSelect.prototype.setRadius = function (r) { + if (this.radius === r) { + return this; } + this.radius = r; + this.calculateCartesian(); + return this; }; - AgPanel.prototype.getWidth = function () { - return this.size.width; + AgAngleSelect.prototype.onValueChange = function (callbackFn) { + var _this = this; + this.addManagedListener(this, _agAbstractField__WEBPACK_IMPORTED_MODULE_3__["AgAbstractField"].EVENT_CHANGED, function () { + callbackFn(_this.degrees); + }); + return this; }; - AgPanel.prototype.setWidth = function (width) { - var eGui = this.getGui(); - var isPercent = false; - if (typeof width === 'string' && width.indexOf('%') !== -1) { - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].setFixedWidth(eGui, width); - width = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].getAbsoluteWidth(eGui); - isPercent = true; + AgAngleSelect.prototype.getValue = function (radians) { + return radians ? this.toRadians(this.degrees) : this.degrees; + }; + AgAngleSelect.prototype.setValue = function (degrees, radians) { + var radiansValue; + if (!radians) { + radiansValue = this.normalizeAngle180(this.toRadians(degrees)); } else { - width = Math.max(this.minWidth, width); - var offsetParent = eGui.offsetParent; - if (offsetParent && offsetParent.clientWidth && (width + this.position.x > offsetParent.clientWidth)) { - width = offsetParent.clientWidth - this.position.x; - } - } - if (this.size.width === width) { - return; - } - this.size.width = width; - if (!isPercent) { - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].setFixedWidth(eGui, width); + radiansValue = degrees; } - else { - eGui.style.maxWidth = 'unset'; - eGui.style.minWidth = 'unset'; + degrees = this.toDegrees(radiansValue); + if (this.degrees !== degrees) { + this.degrees = Math.floor(degrees); + this.calculateCartesian(); + this.positionChildCircle(radiansValue); + this.dispatchEvent({ type: _agAbstractField__WEBPACK_IMPORTED_MODULE_3__["AgAbstractField"].EVENT_CHANGED }); } + return this; }; - AgPanel.prototype.center = function () { - var eGui = this.getGui(); - var x = (eGui.offsetParent.clientWidth / 2) - (this.getWidth() / 2); - var y = (eGui.offsetParent.clientHeight / 2) - (this.getHeight() / 2); - this.offsetElement(x, y); + AgAngleSelect.prototype.setWidth = function (width) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["setFixedWidth"])(this.getGui(), width); + return this; }; - AgPanel.prototype.setClosable = function (closable) { - if (closable !== this.closable) { - this.closable = closable; - } - if (closable) { - var closeButtonComp = this.closeButtonComp = new _component__WEBPACK_IMPORTED_MODULE_2__["Component"](AgPanel.CLOSE_BTN_TEMPLATE); - this.getContext().createBean(closeButtonComp); - var eGui = closeButtonComp.getGui(); - eGui.appendChild(_utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(_utils__WEBPACK_IMPORTED_MODULE_3__["_"].createIconNoSpan('close', this.gridOptionsWrapper), 'ag-panel-title-bar-button-icon')); - this.addTitleBarButton(closeButtonComp); - closeButtonComp.addManagedListener(eGui, 'click', this.onBtClose.bind(this)); - } - else if (this.closeButtonComp) { - var eGui = this.closeButtonComp.getGui(); - eGui.parentElement.removeChild(eGui); - this.closeButtonComp = this.destroyBean(this.closeButtonComp); - } + AgAngleSelect.prototype.destroy = function () { + this.dragService.removeDragSource(this.dragListener); + _super.prototype.destroy.call(this); }; - AgPanel.prototype.setBodyComponent = function (bodyComponent) { - bodyComponent.setParentComponent(this); - this.eContentWrapper.appendChild(bodyComponent.getGui()); + AgAngleSelect.TEMPLATE = "
\n
\n
\n
\n
\n
\n
\n
\n \n
\n
"; + __decorate([ + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eLabel') + ], AgAngleSelect.prototype, "eLabel", void 0); + __decorate([ + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eParentCircle') + ], AgAngleSelect.prototype, "eParentCircle", void 0); + __decorate([ + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eChildCircle') + ], AgAngleSelect.prototype, "eChildCircle", void 0); + __decorate([ + Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eAngleValue') + ], AgAngleSelect.prototype, "eAngleValue", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('dragService') + ], AgAngleSelect.prototype, "dragService", void 0); + return AgAngleSelect; +}(_agAbstractLabel__WEBPACK_IMPORTED_MODULE_0__["AgAbstractLabel"])); + + + +/***/ }), +/* 220 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgToggleButton", function() { return AgToggleButton; }); +/* harmony import */ var _agCheckbox__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(158); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); }; - AgPanel.prototype.addTitleBarButton = function (button, position) { - var eTitleBarButtons = this.eTitleBarButtons; - var buttons = eTitleBarButtons.children; - var len = buttons.length; - if (position == null) { - position = len; - } - position = Math.max(0, Math.min(position, len)); - var eGui = button.getGui(); - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(eGui, 'ag-panel-title-bar-button'); - if (position === 0) { - eTitleBarButtons.insertAdjacentElement('afterbegin', eGui); - } - else if (position === len) { - eTitleBarButtons.insertAdjacentElement('beforeend', eGui); + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); + +var AgToggleButton = /** @class */ (function (_super) { + __extends(AgToggleButton, _super); + function AgToggleButton(config) { + return _super.call(this, config, 'ag-toggle-button') || this; + } + AgToggleButton.prototype.setValue = function (value, silent) { + _super.prototype.setValue.call(this, value, silent); + this.addOrRemoveCssClass('ag-selected', this.getValue()); + return this; + }; + return AgToggleButton; +}(_agCheckbox__WEBPACK_IMPORTED_MODULE_0__["AgCheckbox"])); + + + +/***/ }), +/* 221 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowPositionUtils", function() { return RowPositionUtils; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(15); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + +var RowPositionUtils = /** @class */ (function (_super) { + __extends(RowPositionUtils, _super); + function RowPositionUtils() { + return _super !== null && _super.apply(this, arguments) || this; + } + RowPositionUtils.prototype.getFirstRow = function () { + var rowIndex = 0; + var rowPinned; + if (this.pinnedRowModel.getPinnedTopRowCount()) { + rowPinned = _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP; } - else { - buttons[position - 1].insertAdjacentElement('afterend', eGui); + else if (this.rowModel.getRowCount()) { + rowPinned = null; + rowIndex = this.paginationProxy.getPageFirstRow(); } - button.setParentComponent(this); - }; - AgPanel.prototype.getBodyHeight = function () { - return _utils__WEBPACK_IMPORTED_MODULE_3__["_"].getInnerHeight(this.eContentWrapper); - }; - AgPanel.prototype.getBodyWidth = function () { - return _utils__WEBPACK_IMPORTED_MODULE_3__["_"].getInnerWidth(this.eContentWrapper); + else if (this.pinnedRowModel.getPinnedBottomRowCount()) { + rowPinned = _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM; + } + return rowPinned === undefined ? null : { rowIndex: rowIndex, rowPinned: rowPinned }; }; - AgPanel.prototype.setTitle = function (title) { - this.eTitle.innerText = title; + RowPositionUtils.prototype.getLastRow = function () { + var rowIndex; + var rowPinned = null; + var pinnedBottomCount = this.pinnedRowModel.getPinnedBottomRowCount(); + var pinnedTopCount = this.pinnedRowModel.getPinnedTopRowCount(); + if (pinnedBottomCount) { + rowPinned = _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM; + rowIndex = pinnedBottomCount - 1; + } + else if (this.rowModel.getRowCount()) { + rowPinned = null; + rowIndex = this.paginationProxy.getPageLastRow(); + } + else if (pinnedTopCount) { + rowPinned = _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP; + rowIndex = pinnedTopCount - 1; + } + return rowIndex === undefined ? null : { rowIndex: rowIndex, rowPinned: rowPinned }; }; - // called when user hits the 'x' in the top right - AgPanel.prototype.onBtClose = function () { - this.close(); + RowPositionUtils.prototype.getRowNode = function (gridRow) { + switch (gridRow.rowPinned) { + case _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP: + return this.pinnedRowModel.getPinnedTopRowData()[gridRow.rowIndex]; + case _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM: + return this.pinnedRowModel.getPinnedBottomRowData()[gridRow.rowIndex]; + default: + return this.rowModel.getRow(gridRow.rowIndex); + } }; - AgPanel.prototype.destroy = function () { - if (this.closeButtonComp) { - this.closeButtonComp = this.destroyBean(this.closeButtonComp); + RowPositionUtils.prototype.sameRow = function (rowA, rowB) { + // if both missing + if (!rowA && !rowB) { + return true; } - var eGui = this.getGui(); - if (eGui && eGui.offsetParent) { - this.close(); + // if only one missing + if ((rowA && !rowB) || (!rowA && rowB)) { + return false; } - _super.prototype.destroy.call(this); + // otherwise compare (use == to compare rowPinned because it can be null or undefined) + return rowA.rowIndex === rowB.rowIndex && rowA.rowPinned == rowB.rowPinned; + }; + // tests if this row selection is before the other row selection + RowPositionUtils.prototype.before = function (rowA, rowB) { + switch (rowA.rowPinned) { + case _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP: + // we we are floating top, and other isn't, then we are always before + if (rowB.rowPinned !== _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP) { + return true; + } + break; + case _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM: + // if we are floating bottom, and the other isn't, then we are never before + if (rowB.rowPinned !== _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM) { + return false; + } + break; + default: + // if we are not floating, but the other one is floating... + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["exists"])(rowB.rowPinned)) { + return rowB.rowPinned !== _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP; + } + break; + } + return rowA.rowIndex < rowB.rowIndex; }; - AgPanel.CLOSE_BTN_TEMPLATE = "
"; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('popupService') - ], AgPanel.prototype, "popupService", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], AgPanel.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eContentWrapper') - ], AgPanel.prototype, "eContentWrapper", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eTitleBar') - ], AgPanel.prototype, "eTitleBar", void 0); __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eTitleBarButtons') - ], AgPanel.prototype, "eTitleBarButtons", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel') + ], RowPositionUtils.prototype, "rowModel", void 0); __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eTitle') - ], AgPanel.prototype, "eTitle", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('pinnedRowModel') + ], RowPositionUtils.prototype, "pinnedRowModel", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], AgPanel.prototype, "postConstruct", null); - return AgPanel; -}(_component__WEBPACK_IMPORTED_MODULE_2__["Component"])); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('paginationProxy') + ], RowPositionUtils.prototype, "paginationProxy", void 0); + RowPositionUtils = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('rowPositionUtils') + ], RowPositionUtils); + return RowPositionUtils; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 173 */ +/* 222 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgInputTextField", function() { return AgInputTextField; }); -/* harmony import */ var _agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(71); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellPositionUtils", function() { return CellPositionUtils; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -40083,44 +48259,57 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; -var AgInputTextField = /** @class */ (function (_super) { - __extends(AgInputTextField, _super); - function AgInputTextField(config) { - var _this = _super.call(this) || this; - _this.className = 'ag-text-field'; - _this.displayTag = 'input'; - _this.inputType = 'text'; - _this.setTemplate(_this.TEMPLATE.replace(/%displayField%/g, _this.displayTag)); - if (config) { - _this.config = config; - } - return _this; +var CellPositionUtils = /** @class */ (function (_super) { + __extends(CellPositionUtils, _super); + function CellPositionUtils() { + return _super !== null && _super.apply(this, arguments) || this; } - AgInputTextField.prototype.setValue = function (value, silent) { - var ret = _super.prototype.setValue.call(this, value, silent); - if (this.eInput.value !== value) { - this.eInput.value = _utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(value) ? value : ''; - } - return ret; + CellPositionUtils.prototype.createId = function (cellPosition) { + var rowIndex = cellPosition.rowIndex, rowPinned = cellPosition.rowPinned, column = cellPosition.column; + return this.createIdFromValues(rowIndex, column, rowPinned); }; - return AgInputTextField; -}(_agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractInputField"])); + CellPositionUtils.prototype.createIdFromValues = function (rowIndex, column, rowPinned) { + return rowIndex + "." + (rowPinned == null ? 'null' : rowPinned) + "." + column.getId(); + }; + CellPositionUtils.prototype.equals = function (cellA, cellB) { + var colsMatch = cellA.column === cellB.column; + var floatingMatch = cellA.rowPinned === cellB.rowPinned; + var indexMatch = cellA.rowIndex === cellB.rowIndex; + return colsMatch && floatingMatch && indexMatch; + }; + CellPositionUtils = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('cellPositionUtils') + ], CellPositionUtils); + return CellPositionUtils; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 174 */ +/* 223 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgInputTextArea", function() { return AgInputTextArea; }); -/* harmony import */ var _agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(71); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PinnedRowModel", function() { return PinnedRowModel; }); +/* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(94); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(23); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(15); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(20); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(18); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -40137,53 +48326,169 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; -var AgInputTextArea = /** @class */ (function (_super) { - __extends(AgInputTextArea, _super); - function AgInputTextArea(config) { - var _this = _super.call(this) || this; - _this.className = 'ag-text-area'; - _this.displayTag = 'textarea'; - _this.inputType = ''; - _this.setTemplate(_this.TEMPLATE.replace(/%displayField%/g, _this.displayTag)); - if (config) { - _this.config = config; - } - return _this; + + + + + + +var PinnedRowModel = /** @class */ (function (_super) { + __extends(PinnedRowModel, _super); + function PinnedRowModel() { + return _super !== null && _super.apply(this, arguments) || this; } - AgInputTextArea.prototype.setValue = function (value, silent) { - var ret = _super.prototype.setValue.call(this, value, silent); - this.eInput.value = value; - return ret; + PinnedRowModel.prototype.init = function () { + this.setPinnedTopRowData(this.gridOptionsWrapper.getPinnedTopRowData()); + this.setPinnedBottomRowData(this.gridOptionsWrapper.getPinnedBottomRowData()); }; - AgInputTextArea.prototype.setCols = function (cols) { - this.eInput.cols = cols; - return this; + PinnedRowModel.prototype.isEmpty = function (floating) { + var rows = floating === _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP ? this.pinnedTopRows : this.pinnedBottomRows; + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["missingOrEmpty"])(rows); }; - AgInputTextArea.prototype.setRows = function (rows) { - this.eInput.rows = rows; - return this; + PinnedRowModel.prototype.isRowsToRender = function (floating) { + return !this.isEmpty(floating); }; - return AgInputTextArea; -}(_agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractInputField"])); + PinnedRowModel.prototype.getRowAtPixel = function (pixel, floating) { + var rows = floating === _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP ? this.pinnedTopRows : this.pinnedBottomRows; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["missingOrEmpty"])(rows)) { + return 0; // this should never happen, just in case, 0 is graceful failure + } + for (var i = 0; i < rows.length; i++) { + var rowNode = rows[i]; + var rowTopPixel = rowNode.rowTop + rowNode.rowHeight - 1; + // only need to range check against the top pixel, as we are going through the list + // in order, first row to hit the pixel wins + if (rowTopPixel >= pixel) { + return i; + } + } + return rows.length - 1; + }; + PinnedRowModel.prototype.setPinnedTopRowData = function (rowData) { + this.pinnedTopRows = this.createNodesFromData(rowData, true); + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_PINNED_ROW_DATA_CHANGED, + api: this.gridApi, + columnApi: this.columnApi + }; + this.eventService.dispatchEvent(event); + }; + PinnedRowModel.prototype.setPinnedBottomRowData = function (rowData) { + this.pinnedBottomRows = this.createNodesFromData(rowData, false); + var event = { + type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_PINNED_ROW_DATA_CHANGED, + api: this.gridApi, + columnApi: this.columnApi + }; + this.eventService.dispatchEvent(event); + }; + PinnedRowModel.prototype.createNodesFromData = function (allData, isTop) { + var _this = this; + var rowNodes = []; + if (allData) { + var nextRowTop_1 = 0; + allData.forEach(function (dataItem, index) { + var rowNode = new _entities_rowNode__WEBPACK_IMPORTED_MODULE_0__["RowNode"](_this.beans); + rowNode.data = dataItem; + var idPrefix = isTop ? _entities_rowNode__WEBPACK_IMPORTED_MODULE_0__["RowNode"].ID_PREFIX_TOP_PINNED : _entities_rowNode__WEBPACK_IMPORTED_MODULE_0__["RowNode"].ID_PREFIX_BOTTOM_PINNED; + rowNode.id = idPrefix + index; + rowNode.rowPinned = isTop ? _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP : _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_BOTTOM; + rowNode.setRowTop(nextRowTop_1); + rowNode.setRowHeight(_this.gridOptionsWrapper.getRowHeightForNode(rowNode).height); + rowNode.setRowIndex(index); + nextRowTop_1 += rowNode.rowHeight; + rowNodes.push(rowNode); + }); + } + return rowNodes; + }; + PinnedRowModel.prototype.getPinnedTopRowData = function () { + return this.pinnedTopRows; + }; + PinnedRowModel.prototype.getPinnedBottomRowData = function () { + return this.pinnedBottomRows; + }; + PinnedRowModel.prototype.getPinnedTopTotalHeight = function () { + return this.getTotalHeight(this.pinnedTopRows); + }; + PinnedRowModel.prototype.getPinnedTopRowCount = function () { + return this.pinnedTopRows ? this.pinnedTopRows.length : 0; + }; + PinnedRowModel.prototype.getPinnedBottomRowCount = function () { + return this.pinnedBottomRows ? this.pinnedBottomRows.length : 0; + }; + PinnedRowModel.prototype.getPinnedTopRow = function (index) { + return this.pinnedTopRows[index]; + }; + PinnedRowModel.prototype.getPinnedBottomRow = function (index) { + return this.pinnedBottomRows[index]; + }; + PinnedRowModel.prototype.forEachPinnedTopRow = function (callback) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["missingOrEmpty"])(this.pinnedTopRows)) { + return; + } + this.pinnedTopRows.forEach(callback); + }; + PinnedRowModel.prototype.forEachPinnedBottomRow = function (callback) { + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_5__["missingOrEmpty"])(this.pinnedBottomRows)) { + return; + } + this.pinnedBottomRows.forEach(callback); + }; + PinnedRowModel.prototype.getPinnedBottomTotalHeight = function () { + return this.getTotalHeight(this.pinnedBottomRows); + }; + PinnedRowModel.prototype.getTotalHeight = function (rowNodes) { + if (!rowNodes || rowNodes.length === 0) { + return 0; + } + var lastNode = Object(_utils_array__WEBPACK_IMPORTED_MODULE_6__["last"])(rowNodes); + return lastNode.rowTop + lastNode.rowHeight; + }; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnApi') + ], PinnedRowModel.prototype, "columnApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridApi') + ], PinnedRowModel.prototype, "gridApi", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('beans') + ], PinnedRowModel.prototype, "beans", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], PinnedRowModel.prototype, "init", null); + PinnedRowModel = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('pinnedRowModel') + ], PinnedRowModel); + return PinnedRowModel; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_4__["BeanStub"])); /***/ }), -/* 175 */ +/* 224 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgSlider", function() { return AgSlider; }); -/* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57); -/* harmony import */ var _agAbstractLabel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(73); -/* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(72); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UndoRedoService", function() { return UndoRedoService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(24); +/* harmony import */ var _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(225); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(15); +/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(16); +/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(17); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(20); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -40211,99 +48516,266 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var AgSlider = /** @class */ (function (_super) { - __extends(AgSlider, _super); - function AgSlider() { - var _this = _super.call(this, AgSlider.TEMPLATE) || this; - _this.labelAlignment = 'top'; + + +var UndoRedoService = /** @class */ (function (_super) { + __extends(UndoRedoService, _super); + function UndoRedoService() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.cellValueChanges = []; + _this.activeCellEdit = null; + _this.activeRowEdit = null; + _this.isPasting = false; + _this.isFilling = false; + _this.onCellValueChanged = function (event) { + var eventCell = { column: event.column, rowIndex: event.rowIndex, rowPinned: event.rowPinned }; + var isCellEditing = _this.activeCellEdit !== null && _this.cellPositionUtils.equals(_this.activeCellEdit, eventCell); + var isRowEditing = _this.activeRowEdit !== null && _this.rowPositionUtils.sameRow(_this.activeRowEdit, eventCell); + var shouldCaptureAction = isCellEditing || isRowEditing || _this.isPasting || _this.isFilling; + if (!shouldCaptureAction) { + return; + } + var rowPinned = event.rowPinned, rowIndex = event.rowIndex, column = event.column, oldValue = event.oldValue, value = event.value; + var cellValueChange = { + rowPinned: rowPinned, + rowIndex: rowIndex, + columnId: column.getColId(), + newValue: value, + oldValue: oldValue + }; + _this.cellValueChanges.push(cellValueChange); + }; + _this.clearStacks = function () { + _this.undoStack.clear(); + _this.redoStack.clear(); + }; return _this; } - AgSlider.prototype.init = function () { - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(this.eSlider.getGui(), 'ag-slider-field'); + UndoRedoService.prototype.init = function () { + if (!this.gridOptionsWrapper.isUndoRedoCellEditing()) { + return; + } + var undoRedoLimit = this.gridOptionsWrapper.getUndoRedoCellEditingLimit(); + if (undoRedoLimit <= 0) { + return; + } + this.undoStack = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["UndoRedoStack"](undoRedoLimit); + this.redoStack = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["UndoRedoStack"](undoRedoLimit); + this.addRowEditingListeners(); + this.addCellEditingListeners(); + this.addPasteListeners(); + this.addFillListeners(); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_VALUE_CHANGED, this.onCellValueChanged); + // undo / redo is restricted to actual editing so we clear the stacks when other operations are + // performed that change the order of the row / cols. + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_MODEL_UPDATED, this.clearStacks); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_PIVOT_MODE_CHANGED, this.clearStacks); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_NEW_COLUMNS_LOADED, this.clearStacks); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_GROUP_OPENED, this.clearStacks); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, this.clearStacks); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_MOVED, this.clearStacks); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_PINNED, this.clearStacks); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_VISIBLE, this.clearStacks); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_ROW_DRAG_END, this.clearStacks); }; - AgSlider.prototype.onValueChange = function (callbackFn) { + UndoRedoService.prototype.getCurrentUndoStackSize = function () { + return this.undoStack ? this.undoStack.getCurrentStackSize() : 0; + }; + UndoRedoService.prototype.getCurrentRedoStackSize = function () { + return this.redoStack ? this.redoStack.getCurrentStackSize() : 0; + }; + UndoRedoService.prototype.undo = function () { + if (!this.undoStack) { + return; + } + var undoAction = this.undoStack.pop(); + if (!undoAction || !undoAction.cellValueChanges) { + return; + } + this.processAction(undoAction, function (cellValueChange) { return cellValueChange.oldValue; }); + if (undoAction instanceof _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["FillUndoRedoAction"]) { + this.processRangeAndCellFocus(undoAction.cellValueChanges, undoAction.initialRange); + } + else { + this.processRangeAndCellFocus(undoAction.cellValueChanges); + } + this.redoStack.push(undoAction); + }; + UndoRedoService.prototype.redo = function () { + if (!this.redoStack) { + return; + } + var redoAction = this.redoStack.pop(); + if (!redoAction || !redoAction.cellValueChanges) { + return; + } + this.processAction(redoAction, function (cellValueChange) { return cellValueChange.newValue; }); + if (redoAction instanceof _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["FillUndoRedoAction"]) { + this.processRangeAndCellFocus(redoAction.cellValueChanges, redoAction.finalRange); + } + else { + this.processRangeAndCellFocus(redoAction.cellValueChanges); + } + this.undoStack.push(redoAction); + }; + UndoRedoService.prototype.processAction = function (action, valueExtractor) { var _this = this; - var eventChanged = _agAbstractField__WEBPACK_IMPORTED_MODULE_2__["AgAbstractField"].EVENT_CHANGED; - this.addManagedListener(this.eText, eventChanged, function () { - var textValue = parseFloat(_this.eText.getValue()); - _this.eSlider.setValue(textValue.toString(), true); - callbackFn(textValue || 0); - }); - this.addManagedListener(this.eSlider, eventChanged, function () { - var sliderValue = _this.eSlider.getValue(); - _this.eText.setValue(sliderValue, true); - callbackFn(parseFloat(sliderValue)); + action.cellValueChanges.forEach(function (cellValueChange) { + var rowIndex = cellValueChange.rowIndex, rowPinned = cellValueChange.rowPinned, columnId = cellValueChange.columnId; + var rowPosition = { rowIndex: rowIndex, rowPinned: rowPinned }; + var currentRow = _this.getRowNode(rowPosition); + // checks if the row has been filtered out + if (!currentRow.displayed) { + return; + } + currentRow.setDataValue(columnId, valueExtractor(cellValueChange)); }); - return this; }; - AgSlider.prototype.setSliderWidth = function (width) { - this.eSlider.setWidth(width); - return this; + UndoRedoService.prototype.processRangeAndCellFocus = function (cellValueChanges, range) { + var lastFocusedCell; + if (range) { + var startRow = range.startRow; + var endRow = range.endRow; + lastFocusedCell = { + rowPinned: startRow.rowPinned, + rowIndex: startRow.rowIndex, + columnId: range.startColumn.getColId() + }; + this.setLastFocusedCell(lastFocusedCell); + var cellRangeParams = { + rowStartIndex: startRow.rowIndex, + rowStartPinned: startRow.rowPinned, + rowEndIndex: endRow.rowIndex, + rowEndPinned: endRow.rowPinned, + columnStart: range.startColumn, + columns: range.columns + }; + this.gridApi.addCellRange(cellRangeParams); + return; + } + var cellValueChange = cellValueChanges[0]; + var rowIndex = cellValueChange.rowIndex, rowPinned = cellValueChange.rowPinned; + var rowPosition = { rowIndex: rowIndex, rowPinned: rowPinned }; + var row = this.getRowNode(rowPosition); + lastFocusedCell = { + rowPinned: cellValueChange.rowPinned, + rowIndex: row.rowIndex, + columnId: cellValueChange.columnId + }; + this.setLastFocusedCell(lastFocusedCell); }; - AgSlider.prototype.setTextFieldWidth = function (width) { - this.eText.setWidth(width); - return this; + UndoRedoService.prototype.setLastFocusedCell = function (lastFocusedCell) { + var rowIndex = lastFocusedCell.rowIndex, columnId = lastFocusedCell.columnId, rowPinned = lastFocusedCell.rowPinned; + this.gridApi.ensureIndexVisible(rowIndex); + this.gridApi.ensureColumnVisible(columnId); + if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].RangeSelectionModule)) { + this.gridApi.clearRangeSelection(); + } + this.focusService.setFocusedCell(rowIndex, columnId, rowPinned, true); }; - AgSlider.prototype.setMinValue = function (minValue) { - this.eSlider.setMinValue(minValue); - this.eText.setMin(minValue); - return this; + UndoRedoService.prototype.addRowEditingListeners = function () { + var _this = this; + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_ROW_EDITING_STARTED, function (e) { + _this.activeRowEdit = { rowIndex: e.rowIndex, rowPinned: e.rowPinned }; + }); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_ROW_EDITING_STOPPED, function () { + var action = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["UndoRedoAction"](_this.cellValueChanges); + _this.pushActionsToUndoStack(action); + _this.activeRowEdit = null; + }); }; - AgSlider.prototype.setMaxValue = function (maxValue) { - this.eSlider.setMaxValue(maxValue); - this.eText.setMax(maxValue); - return this; + UndoRedoService.prototype.addCellEditingListeners = function () { + var _this = this; + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_EDITING_STARTED, function (e) { + _this.activeCellEdit = { column: e.column, rowIndex: e.rowIndex, rowPinned: e.rowPinned }; + }); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_EDITING_STOPPED, function () { + _this.activeCellEdit = null; + var shouldPushAction = !_this.activeRowEdit && !_this.isPasting && !_this.isFilling; + if (shouldPushAction) { + var action = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["UndoRedoAction"](_this.cellValueChanges); + _this.pushActionsToUndoStack(action); + } + }); }; - AgSlider.prototype.getValue = function () { - return this.eText.getValue(); + UndoRedoService.prototype.addPasteListeners = function () { + var _this = this; + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_PASTE_START, function () { + _this.isPasting = true; + }); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_PASTE_END, function () { + var action = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["UndoRedoAction"](_this.cellValueChanges); + _this.pushActionsToUndoStack(action); + _this.isPasting = false; + }); }; - AgSlider.prototype.setValue = function (value) { - if (this.getValue() === value) { - return this; - } - this.eText.setValue(value, true); - this.eSlider.setValue(value, true); - this.dispatchEvent({ type: _agAbstractField__WEBPACK_IMPORTED_MODULE_2__["AgAbstractField"].EVENT_CHANGED }); - return this; + UndoRedoService.prototype.addFillListeners = function () { + var _this = this; + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_FILL_START, function () { + _this.isFilling = true; + }); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_FILL_END, function (event) { + var action = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["FillUndoRedoAction"](_this.cellValueChanges, event.initialRange, event.finalRange); + _this.pushActionsToUndoStack(action); + _this.isFilling = false; + }); }; - AgSlider.prototype.setStep = function (step) { - this.eSlider.setStep(step); - this.eText.setStep(step); - return this; + UndoRedoService.prototype.pushActionsToUndoStack = function (action) { + this.undoStack.push(action); + this.cellValueChanges = []; + this.redoStack.clear(); + }; + UndoRedoService.prototype.getRowNode = function (gridRow) { + switch (gridRow.rowPinned) { + case _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP: + return this.pinnedRowModel.getPinnedTopRowData()[gridRow.rowIndex]; + case _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_BOTTOM: + return this.pinnedRowModel.getPinnedBottomRowData()[gridRow.rowIndex]; + default: + return this.rowModel.getRow(gridRow.rowIndex); + } }; - AgSlider.TEMPLATE = "
\n \n
\n \n \n
\n
"; __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eLabel') - ], AgSlider.prototype, "eLabel", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusService') + ], UndoRedoService.prototype, "focusService", void 0); __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eSlider') - ], AgSlider.prototype, "eSlider", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') + ], UndoRedoService.prototype, "gridApi", void 0); __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eText') - ], AgSlider.prototype, "eText", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel') + ], UndoRedoService.prototype, "rowModel", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"] - ], AgSlider.prototype, "init", null); - return AgSlider; -}(_agAbstractLabel__WEBPACK_IMPORTED_MODULE_1__["AgAbstractLabel"])); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('pinnedRowModel') + ], UndoRedoService.prototype, "pinnedRowModel", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('cellPositionUtils') + ], UndoRedoService.prototype, "cellPositionUtils", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowPositionUtils') + ], UndoRedoService.prototype, "rowPositionUtils", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], UndoRedoService.prototype, "init", null); + UndoRedoService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('undoRedoService') + ], UndoRedoService); + return UndoRedoService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_6__["BeanStub"])); /***/ }), -/* 176 */ +/* 225 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgColorPicker", function() { return AgColorPicker; }); -/* harmony import */ var _agColorPanel__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(177); -/* harmony import */ var _agDialog__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(171); -/* harmony import */ var _agPickerField__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(178); -/* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(72); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UndoRedoAction", function() { return UndoRedoAction; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FillUndoRedoAction", function() { return FillUndoRedoAction; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UndoRedoStack", function() { return UndoRedoStack; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -40320,107 +48792,69 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); +var UndoRedoAction = /** @class */ (function () { + function UndoRedoAction(cellValueChanges) { + this.cellValueChanges = cellValueChanges; + } + return UndoRedoAction; +}()); - - - - -var AgColorPicker = /** @class */ (function (_super) { - __extends(AgColorPicker, _super); - function AgColorPicker(config) { - var _this = _super.call(this) || this; - _this.displayTag = 'div'; - _this.className = 'ag-color-picker'; - _this.pickerIcon = 'colorPicker'; - _this.setTemplate(_this.TEMPLATE.replace(/%displayField%/g, _this.displayTag)); - if (config && config.color) { - _this.value = config.color; - } +var FillUndoRedoAction = /** @class */ (function (_super) { + __extends(FillUndoRedoAction, _super); + function FillUndoRedoAction(cellValueChanges, initialRange, finalRange) { + var _this = _super.call(this, cellValueChanges) || this; + _this.initialRange = initialRange; + _this.finalRange = finalRange; return _this; } - AgColorPicker.prototype.postConstruct = function () { - _super.prototype.postConstruct.call(this); - if (this.value) { - this.setValue(this.value); - } - }; - AgColorPicker.prototype.showPicker = function () { - var _this = this; - var eGuiRect = this.getGui().getBoundingClientRect(); - var colorDialog = new _agDialog__WEBPACK_IMPORTED_MODULE_1__["AgDialog"]({ - closable: false, - modal: true, - hideTitleBar: true, - minWidth: 190, - width: 190, - height: 250, - x: eGuiRect.right - 190, - y: eGuiRect.top - 250 - }); - this.createBean(colorDialog); - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(colorDialog.getGui(), 'ag-color-dialog'); - var colorPanel = new _agColorPanel__WEBPACK_IMPORTED_MODULE_0__["AgColorPanel"]({ - picker: this - }); - this.createBean(colorPanel); - colorPanel.addDestroyFunc(function () { - if (colorDialog.isAlive()) { - _this.destroyBean(colorDialog); - } - }); - colorDialog.setParentComponent(this); - colorDialog.setBodyComponent(colorPanel); - colorPanel.setValue(this.getValue()); - colorDialog.addDestroyFunc(function () { - var wasDestroying = _this.isDestroyingPicker; - // here we check if the picker was already being - // destroyed to avoid a stackoverflow - if (!wasDestroying) { - _this.isDestroyingPicker = true; - if (colorPanel.isAlive()) { - _this.destroyBean(colorPanel); - } - } - else { - _this.isDestroyingPicker = false; - } - if (_this.isAlive()) { - _this.getFocusableElement().focus(); - } - }); - return colorDialog; + return FillUndoRedoAction; +}(UndoRedoAction)); + +var UndoRedoStack = /** @class */ (function () { + function UndoRedoStack(maxStackSize) { + this.actionStack = []; + this.maxStackSize = maxStackSize ? maxStackSize : UndoRedoStack.DEFAULT_STACK_SIZE; + this.actionStack = new Array(this.maxStackSize); + } + UndoRedoStack.prototype.pop = function () { + return this.actionStack.pop(); }; - AgColorPicker.prototype.setValue = function (color) { - if (this.value === color) { - return this; + UndoRedoStack.prototype.push = function (item) { + var shouldAddActions = item.cellValueChanges && item.cellValueChanges.length > 0; + if (!shouldAddActions) { + return; } - this.value = color; - this.eDisplayField.style.backgroundColor = color; - this.dispatchEvent({ type: _agAbstractField__WEBPACK_IMPORTED_MODULE_3__["AgAbstractField"].EVENT_CHANGED }); - return this; + if (this.actionStack.length === this.maxStackSize) { + this.actionStack.shift(); + } + this.actionStack.push(item); }; - AgColorPicker.prototype.getValue = function () { - return this.value; + UndoRedoStack.prototype.clear = function () { + this.actionStack = []; }; - return AgColorPicker; -}(_agPickerField__WEBPACK_IMPORTED_MODULE_2__["AgPickerField"])); + UndoRedoStack.prototype.getCurrentStackSize = function () { + return this.actionStack.length; + }; + UndoRedoStack.DEFAULT_STACK_SIZE = 10; + return UndoRedoStack; +}()); /***/ }), -/* 177 */ +/* 226 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgColorPanel", function() { return AgColorPanel; }); -/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7); -/* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderPositionUtils", function() { return HeaderPositionUtils; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(9); +/* harmony import */ var _row_headerRowComp__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(136); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -40447,266 +48881,80 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var AgColorPanel = /** @class */ (function (_super) { - __extends(AgColorPanel, _super); - function AgColorPanel(config) { - var _this = _super.call(this, AgColorPanel.TEMPLATE) || this; - _this.H = 1; // in the [0, 1] range - _this.S = 1; // in the [0, 1] range - _this.B = 1; // in the [0, 1] range - _this.A = 1; // in the [0, 1] range - _this.isSpectrumDragging = false; - _this.isSpectrumHueDragging = false; - _this.isSpectrumAlphaDragging = false; - _this.colorChanged = false; - _this.picker = config.picker; - return _this; +var HeaderPositionUtils = /** @class */ (function (_super) { + __extends(HeaderPositionUtils, _super); + function HeaderPositionUtils() { + return _super !== null && _super.apply(this, arguments) || this; } - AgColorPanel.prototype.postConstruct = function () { - var eGui = this.getGui(); - this.initRecentColors(); - this.addManagedListener(this.spectrumVal, 'mousedown', this.onSpectrumDraggerDown.bind(this)); - this.addManagedListener(eGui, 'mousemove', this.onSpectrumDraggerMove.bind(this)); - this.addManagedListener(this.spectrumHue, 'mousedown', this.onSpectrumHueDown.bind(this)); - this.addManagedListener(eGui, 'mousemove', this.onSpectrumHueMove.bind(this)); - this.addManagedListener(this.spectrumAlpha, 'mousedown', this.onSpectrumAlphaDown.bind(this)); - this.addManagedListener(eGui, 'mousemove', this.onSpectrumAlphaMove.bind(this)); - // Listening to `mouseup` on the document on purpose. The user might release the mouse button - // outside the UI control. When the mouse returns back to the control's area, the dragging - // of the thumb is not expected and seen as a bug. - this.addManagedListener(document, 'mouseup', this.onMouseUp.bind(this)); - this.addManagedListener(this.recentColors, 'click', this.onRecentColorClick.bind(this)); - }; - AgColorPanel.prototype.refreshSpectrumRect = function () { - return this.spectrumValRect = this.spectrumVal.getBoundingClientRect(); - }; - AgColorPanel.prototype.refreshHueRect = function () { - return this.spectrumHueRect = this.spectrumHue.getBoundingClientRect(); - }; - AgColorPanel.prototype.refreshAlphaRect = function () { - return this.spectrumAlphaRect = this.spectrumAlpha.getBoundingClientRect(); - }; - AgColorPanel.prototype.onSpectrumDraggerDown = function (e) { - this.refreshSpectrumRect(); - this.isSpectrumDragging = true; - this.moveDragger(e); - }; - AgColorPanel.prototype.onSpectrumDraggerMove = function (e) { - if (this.isSpectrumDragging) { - this.moveDragger(e); - } - }; - AgColorPanel.prototype.onSpectrumHueDown = function (e) { - this.refreshHueRect(); - this.isSpectrumHueDragging = true; - this.moveHueSlider(e); - }; - AgColorPanel.prototype.onSpectrumHueMove = function (e) { - if (this.isSpectrumHueDragging) { - this.moveHueSlider(e); - } - }; - AgColorPanel.prototype.onSpectrumAlphaDown = function (e) { - this.refreshAlphaRect(); - this.isSpectrumAlphaDragging = true; - this.moveAlphaSlider(e); - }; - AgColorPanel.prototype.onSpectrumAlphaMove = function (e) { - if (this.isSpectrumAlphaDragging) { - this.moveAlphaSlider(e); - } - }; - AgColorPanel.prototype.onMouseUp = function () { - this.isSpectrumDragging = false; - this.isSpectrumHueDragging = false; - this.isSpectrumAlphaDragging = false; - }; - AgColorPanel.prototype.moveDragger = function (e) { - var valRect = this.spectrumValRect; - if (valRect) { - var x = e.clientX - valRect.left; - var y = e.clientY - valRect.top; - x = Math.max(x, 0); - x = Math.min(x, valRect.width); - y = Math.max(y, 0); - y = Math.min(y, valRect.height); - this.setSpectrumValue(x / valRect.width, 1 - y / valRect.height); - } - }; - AgColorPanel.prototype.moveHueSlider = function (e) { - var hueRect = this.spectrumHueRect; - if (hueRect) { - var slider = this.spectrumHueSlider; - var sliderRect = slider.getBoundingClientRect(); - var x = e.clientX - hueRect.left; - x = Math.max(x, 0); - x = Math.min(x, hueRect.width); - this.H = 1 - x / hueRect.width; - slider.style.left = (x + sliderRect.width / 2) + 'px'; - this.update(); - } - }; - AgColorPanel.prototype.moveAlphaSlider = function (e) { - var alphaRect = this.spectrumAlphaRect; - if (alphaRect) { - var slider = this.spectrumAlphaSlider; - var sliderRect = slider.getBoundingClientRect(); - var x = e.clientX - alphaRect.left; - x = Math.max(x, 0); - x = Math.min(x, alphaRect.width); - this.A = x / alphaRect.width; - slider.style.left = (x + sliderRect.width / 2) + 'px'; - this.update(); - } - }; - AgColorPanel.prototype.update = function () { - var color = _utils__WEBPACK_IMPORTED_MODULE_1__["Color"].fromHSB(this.H * 360, this.S, this.B, this.A); - var spectrumColor = _utils__WEBPACK_IMPORTED_MODULE_1__["Color"].fromHSB(this.H * 360, 1, 1); - var rgbaColor = color.toRgbaString(); - // the recent color list needs to know color has actually changed - var colorPicker = this.picker; - var existingColor = _utils__WEBPACK_IMPORTED_MODULE_1__["Color"].fromString(colorPicker.getValue()); - if (existingColor.toRgbaString() !== rgbaColor) { - this.colorChanged = true; + HeaderPositionUtils.prototype.findHeader = function (focusedHeader, direction) { + var nextColumn; + var getGroupMethod; + var getColMethod; + if (focusedHeader.column instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_2__["ColumnGroup"]) { + getGroupMethod = "getDisplayedGroup" + direction; + nextColumn = this.columnModel[getGroupMethod](focusedHeader.column); } - colorPicker.setValue(rgbaColor); - this.spectrumColor.style.backgroundColor = spectrumColor.toRgbaString(); - this.spectrumDragger.style.backgroundColor = rgbaColor; - }; - /** - * @param saturation In the [0, 1] interval. - * @param brightness In the [0, 1] interval. - */ - AgColorPanel.prototype.setSpectrumValue = function (saturation, brightness) { - var valRect = this.spectrumValRect || this.refreshSpectrumRect(); - if (valRect) { - var dragger = this.spectrumDragger; - var draggerRect = dragger.getBoundingClientRect(); - saturation = Math.max(0, saturation); - saturation = Math.min(1, saturation); - brightness = Math.max(0, brightness); - brightness = Math.min(1, brightness); - this.S = saturation; - this.B = brightness; - dragger.style.left = (saturation * valRect.width - draggerRect.width / 2) + 'px'; - dragger.style.top = ((1 - brightness) * valRect.height - draggerRect.height / 2) + 'px'; - this.update(); + else { + getColMethod = "getDisplayedCol" + direction; + nextColumn = this.columnModel[getColMethod](focusedHeader.column); } - }; - AgColorPanel.prototype.initRecentColors = function () { - var recentColors = AgColorPanel.recentColors; - var innerHtml = recentColors.map(function (color, index) { - return "
"; - }); - this.recentColors.innerHTML = innerHtml.join(''); - }; - AgColorPanel.prototype.setValue = function (val) { - var color = _utils__WEBPACK_IMPORTED_MODULE_1__["Color"].fromString(val); - var _a = color.toHSB(), h = _a[0], s = _a[1], b = _a[2]; - this.H = (isNaN(h) ? 0 : h) / 360; - this.A = color.a; - var spectrumHueRect = this.spectrumHueRect || this.refreshHueRect(); - var spectrumAlphaRect = this.spectrumAlphaRect || this.refreshAlphaRect(); - this.spectrumHueSlider.style.left = ((this.H - 1) * -spectrumHueRect.width) + "px"; - this.spectrumAlphaSlider.style.left = (this.A * spectrumAlphaRect.width) + "px"; - this.setSpectrumValue(s, b); - }; - AgColorPanel.prototype.onRecentColorClick = function (e) { - var target = e.target; - if (!_utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(target.id)) { - return; + if (nextColumn) { + return { + column: nextColumn, + headerRowIndex: focusedHeader.headerRowIndex + }; } - var id = parseInt(target.id, 10); - this.setValue(AgColorPanel.recentColors[id]); - this.destroy(); }; - AgColorPanel.prototype.addRecentColor = function () { - var color = _utils__WEBPACK_IMPORTED_MODULE_1__["Color"].fromHSB(this.H * 360, this.S, this.B, this.A); - var rgbaColor = color.toRgbaString(); - var recentColors = AgColorPanel.recentColors; - if (!this.colorChanged || recentColors[0] === rgbaColor) { + HeaderPositionUtils.prototype.findColAtEdgeForHeaderRow = function (level, position) { + var displayedColumns = this.columnModel.getAllDisplayedColumns(); + var column = displayedColumns[position === 'start' ? 0 : displayedColumns.length - 1]; + if (!column) { return; } - // remove duplicate color - recentColors = recentColors.filter(function (color) { return color != rgbaColor; }); - // add color to head - recentColors = [rgbaColor].concat(recentColors); - // ensure we don't exceed max number of recent colors - if (recentColors.length > AgColorPanel.maxRecentColors) { - recentColors = recentColors.slice(0, AgColorPanel.maxRecentColors); + var childContainer = this.ctrlsService.getHeaderRowContainerCtrl(column.getPinned()); + var type = childContainer.getRowType(level); + if (type == _row_headerRowComp__WEBPACK_IMPORTED_MODULE_3__["HeaderRowType"].COLUMN_GROUP) { + var columnGroup = this.columnModel.getColumnGroupAtLevel(column, level); + return { + headerRowIndex: level, + column: columnGroup + }; } - AgColorPanel.recentColors = recentColors; - }; - AgColorPanel.prototype.destroy = function () { - this.addRecentColor(); - _super.prototype.destroy.call(this); + return { + // if type==null, means the header level didn't exist + headerRowIndex: type == null ? -1 : level, + column: column + }; }; - AgColorPanel.maxRecentColors = 8; - AgColorPanel.recentColors = []; - AgColorPanel.TEMPLATE = "
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
"; __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumColor') - ], AgColorPanel.prototype, "spectrumColor", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumVal') - ], AgColorPanel.prototype, "spectrumVal", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumDragger') - ], AgColorPanel.prototype, "spectrumDragger", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumHue') - ], AgColorPanel.prototype, "spectrumHue", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumHueSlider') - ], AgColorPanel.prototype, "spectrumHueSlider", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumAlpha') - ], AgColorPanel.prototype, "spectrumAlpha", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumAlphaSlider') - ], AgColorPanel.prototype, "spectrumAlphaSlider", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnModel') + ], HeaderPositionUtils.prototype, "columnModel", void 0); __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('recentColors') - ], AgColorPanel.prototype, "recentColors", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"] - ], AgColorPanel.prototype, "postConstruct", null); - return AgColorPanel; -}(_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('ctrlsService') + ], HeaderPositionUtils.prototype, "ctrlsService", void 0); + HeaderPositionUtils = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('headerPositionUtils') + ], HeaderPositionUtils); + return HeaderPositionUtils; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 178 */ +/* 227 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgPickerField", function() { return AgPickerField; }); -/* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(72); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25); -/* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(57); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnDefFactory", function() { return ColumnDefFactory; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(13); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); @@ -40715,224 +48963,258 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta }; - - - -var AgPickerField = /** @class */ (function (_super) { - __extends(AgPickerField, _super); - function AgPickerField() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.TEMPLATE = "
\n \n
\n <%displayField% ref=\"eDisplayField\" class=\"ag-picker-field-display\">\n
\n
\n
"; - _this.isDestroyingPicker = false; - _this.skipClick = false; - return _this; +var ColumnDefFactory = /** @class */ (function () { + function ColumnDefFactory() { } - AgPickerField.prototype.postConstruct = function () { + ColumnDefFactory.prototype.buildColumnDefs = function (cols, rowGroupColumns, pivotColumns) { var _this = this; - _super.prototype.postConstruct.call(this); - var clickHandler = function () { - if (_this.skipClick) { - _this.skipClick = false; - return; - } - if (_this.isDisabled()) { - return; - } - _this.pickerComponent = _this.showPicker(); - }; - var eGui = this.getGui(); - this.addManagedListener(eGui, 'mousedown', function (e) { - if (!_this.skipClick && - _this.pickerComponent && - _this.pickerComponent.isAlive() && - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].isVisible(_this.pickerComponent.getGui()) && - eGui.contains(e.target)) { - _this.skipClick = true; - } - }); - this.addManagedListener(eGui, 'keydown', function (e) { - switch (e.keyCode) { - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_UP: - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_DOWN: - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_ENTER: - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_SPACE: - clickHandler(); - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_ESCAPE: - e.preventDefault(); + var res = []; + var colGroupDefs = {}; + cols.forEach(function (col) { + var colDef = _this.createDefFromColumn(col, rowGroupColumns, pivotColumns); + var addToResult = true; + var childDef = colDef; + var pointer = col.getOriginalParent(); + while (pointer) { + var parentDef = null; + // we don't include padding groups, as the column groups provided + // by application didn't have these. the whole point of padding groups + // is to balance the column tree that the user provided. + if (pointer.isPadding()) { + pointer = pointer.getOriginalParent(); + continue; + } + // if colDef for this group already exists, use it + var existingParentDef = colGroupDefs[pointer.getGroupId()]; + if (existingParentDef) { + existingParentDef.children.push(childDef); + // if we added to result, it would be the second time we did it + addToResult = false; + // we don't want to continue up the tree, as it has already been + // done for this group break; + } + parentDef = _this.createDefFromGroup(pointer); + if (parentDef) { + parentDef.children = [childDef]; + colGroupDefs[parentDef.groupId] = parentDef; + childDef = parentDef; + pointer = pointer.getOriginalParent(); + } + } + if (addToResult) { + res.push(childDef); } }); - this.addManagedListener(this.eWrapper, 'click', clickHandler); - this.addManagedListener(this.eLabel, 'click', clickHandler); - if (this.pickerIcon) { - this.eIcon.appendChild(_utils__WEBPACK_IMPORTED_MODULE_4__["_"].createIconNoSpan(this.pickerIcon, this.gridOptionsWrapper, null)); - } - }; - AgPickerField.prototype.setInputWidth = function (width) { - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].setElementWidth(this.eWrapper, width); - return this; - }; - AgPickerField.prototype.getFocusableElement = function () { - return this.eWrapper; + return res; }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], AgPickerField.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eLabel') - ], AgPickerField.prototype, "eLabel", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eWrapper') - ], AgPickerField.prototype, "eWrapper", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eDisplayField') - ], AgPickerField.prototype, "eDisplayField", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eIcon') - ], AgPickerField.prototype, "eIcon", void 0); - return AgPickerField; -}(_agAbstractField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractField"])); + ColumnDefFactory.prototype.createDefFromGroup = function (group) { + var defCloned = Object(_utils_object__WEBPACK_IMPORTED_MODULE_1__["deepCloneDefinition"])(group.getColGroupDef(), ['children']); + if (defCloned) { + defCloned.groupId = group.getGroupId(); + } + return defCloned; + }; + ColumnDefFactory.prototype.createDefFromColumn = function (col, rowGroupColumns, pivotColumns) { + var colDefCloned = Object(_utils_object__WEBPACK_IMPORTED_MODULE_1__["deepCloneDefinition"])(col.getColDef()); + colDefCloned.colId = col.getColId(); + colDefCloned.width = col.getActualWidth(); + colDefCloned.rowGroup = col.isRowGroupActive(); + colDefCloned.rowGroupIndex = col.isRowGroupActive() ? rowGroupColumns.indexOf(col) : null; + colDefCloned.pivot = col.isPivotActive(); + colDefCloned.pivotIndex = col.isPivotActive() ? pivotColumns.indexOf(col) : null; + colDefCloned.aggFunc = col.isValueActive() ? col.getAggFunc() : null; + colDefCloned.hide = col.isVisible() ? undefined : true; + colDefCloned.pinned = col.isPinned() ? col.getPinned() : null; + colDefCloned.sort = col.getSort() ? col.getSort() : null; + colDefCloned.sortIndex = col.getSortIndex() != null ? col.getSortIndex() : null; + return colDefCloned; + }; + ColumnDefFactory = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('columnDefFactory') + ], ColumnDefFactory); + return ColumnDefFactory; +}()); /***/ }), -/* 179 */ +/* 228 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgInputNumberField", function() { return AgInputNumberField; }); -/* harmony import */ var _agInputTextField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(173); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowCssClassCalculator", function() { return RowCssClassCalculator; }); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(18); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(15); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; -var AgInputNumberField = /** @class */ (function (_super) { - __extends(AgInputNumberField, _super); - function AgInputNumberField() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.className = 'ag-number-field'; - _this.inputType = 'number'; - return _this; + + + +var RowCssClassCalculator = /** @class */ (function () { + function RowCssClassCalculator() { } - AgInputNumberField.prototype.postConstruct = function () { - var _this = this; - _super.prototype.postConstruct.call(this); - this.addManagedListener(this.eInput, 'blur', function () { - var floatedValue = parseFloat(_this.eInput.value); - var value = isNaN(floatedValue) ? '' : _this.normalizeValue(floatedValue.toString()); - if (_this.value !== value) { - _this.setValue(value); - } - }); - }; - AgInputNumberField.prototype.normalizeValue = function (value) { - if (value === '') { - return ''; + RowCssClassCalculator.prototype.getInitialRowClasses = function (params) { + var classes = []; + if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_0__["exists"])(params.extraCssClass)) { + classes.push(params.extraCssClass); + } + classes.push('ag-row'); + classes.push(params.rowFocused ? 'ag-row-focus' : 'ag-row-no-focus'); + if (params.fadeRowIn) { + classes.push('ag-opacity-zero'); } - if (this.precision) { - value = this.adjustPrecision(value); + classes.push(params.rowIsEven ? 'ag-row-even' : 'ag-row-odd'); + if (params.rowNode.isRowPinned()) { + classes.push('ag-row-pinned'); } - var val = parseFloat(value); - if (this.min != null && val < this.min) { - value = this.min.toString(); + if (params.rowNode.isSelected()) { + classes.push('ag-row-selected'); } - else if (this.max != null && val > this.max) { - value = this.max.toString(); + if (params.rowNode.footer) { + classes.push('ag-row-footer'); } - return value; - }; - AgInputNumberField.prototype.adjustPrecision = function (value) { - if (this.precision) { - var floatString = parseFloat(value).toFixed(this.precision); - value = parseFloat(floatString).toString(); + classes.push('ag-row-level-' + params.rowLevel); + if (params.rowNode.stub) { + classes.push('ag-row-loading'); } - return value; - }; - AgInputNumberField.prototype.setMin = function (min) { - if (this.min === min) { - return this; + if (params.fullWidthRow) { + classes.push('ag-full-width-row'); } - this.min = min; - if (this.min != null) { - this.eInput.setAttribute('min', min.toString()); + if (params.expandable) { + classes.push('ag-row-group'); + classes.push(params.rowNode.expanded ? 'ag-row-group-expanded' : 'ag-row-group-contracted'); } - else { - this.eInput.removeAttribute('min'); + if (params.rowNode.dragging) { + classes.push('ag-row-dragging'); } - return this; - }; - AgInputNumberField.prototype.setMax = function (max) { - if (this.max === max) { - return this; + Object(_utils_array__WEBPACK_IMPORTED_MODULE_1__["pushAll"])(classes, this.processClassesFromGridOptions(params.rowNode, params.scope)); + Object(_utils_array__WEBPACK_IMPORTED_MODULE_1__["pushAll"])(classes, this.preProcessRowClassRules(params.rowNode, params.scope)); + // we use absolute position unless we are doing print layout + classes.push(params.printLayout ? 'ag-row-position-relative' : 'ag-row-position-absolute'); + if (params.firstRowOnPage) { + classes.push('ag-row-first'); } - this.max = max; - if (this.max != null) { - this.eInput.setAttribute('max', max.toString()); + if (params.lastRowOnPage) { + classes.push('ag-row-last'); } - else { - this.eInput.removeAttribute('max'); + if (params.fullWidthRow) { + if (params.pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_LEFT) { + classes.push('ag-cell-last-left-pinned'); + } + if (params.pinned === _constants_constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_RIGHT) { + classes.push('ag-cell-first-right-pinned'); + } } - return this; - }; - AgInputNumberField.prototype.setPrecision = function (precision) { - this.precision = precision; - return this; + return classes; }; - AgInputNumberField.prototype.setStep = function (step) { - if (this.step === step) { - return this; - } - this.step = step; - if (step != null) { - this.eInput.setAttribute('step', step.toString()); + RowCssClassCalculator.prototype.processClassesFromGridOptions = function (rowNode, scope) { + var res = []; + var process = function (rowCls) { + if (typeof rowCls === 'string') { + res.push(rowCls); + } + else if (Array.isArray(rowCls)) { + rowCls.forEach(function (e) { return res.push(e); }); + } + }; + // part 1 - rowClass + var rowClass = this.gridOptionsWrapper.getRowClass(); + if (rowClass) { + if (typeof rowClass === 'function') { + console.warn('AG Grid: rowClass should not be a function, please use getRowClass instead'); + return []; + } + process(rowClass); } - else { - this.eInput.removeAttribute('step'); + // part 2 - rowClassFunc + var rowClassFunc = this.gridOptionsWrapper.getRowClassFunc(); + if (rowClassFunc) { + var params = { + data: rowNode.data, + node: rowNode, + rowIndex: rowNode.rowIndex, + $scope: scope, + api: this.gridOptionsWrapper.getApi(), + columnApi: this.gridOptionsWrapper.getColumnApi(), + context: this.gridOptionsWrapper.getContext() + }; + var rowClassFuncResult = rowClassFunc(params); + process(rowClassFuncResult); } - return this; + return res; }; - AgInputNumberField.prototype.setValue = function (value, silent) { - value = this.adjustPrecision(value); - var normalizedValue = this.normalizeValue(value); - if (value != normalizedValue) { - return this; + RowCssClassCalculator.prototype.preProcessRowClassRules = function (rowNode, scope) { + var res = []; + this.processRowClassRules(rowNode, scope, function (className) { + res.push(className); + }, function (className) { + // not catered for, if creating, no need + // to remove class as it was never there + }); + return res; + }; + RowCssClassCalculator.prototype.processRowClassRules = function (rowNode, scope, onApplicableClass, onNotApplicableClass) { + var rowClassParams = { + data: rowNode.data, + node: rowNode, + rowIndex: rowNode.rowIndex, + api: this.gridOptionsWrapper.getApi(), + columnApi: this.gridOptionsWrapper.getColumnApi(), + $scope: scope, + context: this.gridOptionsWrapper.getContext() + }; + this.stylingService.processClassRules(this.gridOptionsWrapper.rowClassRules(), rowClassParams, onApplicableClass, onNotApplicableClass); + }; + RowCssClassCalculator.prototype.calculateRowLevel = function (rowNode) { + if (rowNode.group) { + return rowNode.level; } - return _super.prototype.setValue.call(this, value, silent); + // if a leaf, and a parent exists, put a level of the parent, else put level of 0 for top level item + return rowNode.parent ? (rowNode.parent.level + 1) : 0; }; - return AgInputNumberField; -}(_agInputTextField__WEBPACK_IMPORTED_MODULE_0__["AgInputTextField"])); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('stylingService') + ], RowCssClassCalculator.prototype, "stylingService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper') + ], RowCssClassCalculator.prototype, "gridOptionsWrapper", void 0); + RowCssClassCalculator = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Bean"])('rowCssClassCalculator') + ], RowCssClassCalculator); + return RowCssClassCalculator; +}()); /***/ }), -/* 180 */ +/* 229 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgInputRange", function() { return AgInputRange; }); -/* harmony import */ var _agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(71); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowNodeBlockLoader", function() { return RowNodeBlockLoader; }); +/* harmony import */ var _rowNodeBlock__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(230); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(20); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -40949,87 +49231,134 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; +var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { + return function (target, key) { decorator(target, key, paramIndex); } +}; -var AgInputRange = /** @class */ (function (_super) { - __extends(AgInputRange, _super); - function AgInputRange(config) { - var _this = _super.call(this) || this; - _this.className = 'ag-range-field'; - _this.displayTag = 'input'; - _this.inputType = 'range'; - _this.setTemplate(_this.TEMPLATE.replace(/%displayField%/g, _this.displayTag)); - if (config) { - _this.config = config; - } + + +var RowNodeBlockLoader = /** @class */ (function (_super) { + __extends(RowNodeBlockLoader, _super); + function RowNodeBlockLoader() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.activeBlockLoadsCount = 0; + _this.blocks = []; + _this.active = true; return _this; } - AgInputRange.prototype.postConstruct = function () { - _super.prototype.postConstruct.call(this); - var _a = this.config, min = _a.min, max = _a.max, step = _a.step; - if (min != null) { - this.setMinValue(min); - } - if (max != null) { - this.setMaxValue(max); + RowNodeBlockLoader_1 = RowNodeBlockLoader; + RowNodeBlockLoader.prototype.postConstruct = function () { + this.maxConcurrentRequests = this.gridOptionsWrapper.getMaxConcurrentDatasourceRequests(); + var blockLoadDebounceMillis = this.gridOptionsWrapper.getBlockLoadDebounceMillis(); + if (blockLoadDebounceMillis && blockLoadDebounceMillis > 0) { + this.checkBlockToLoadDebounce = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].debounce(this.performCheckBlocksToLoad.bind(this), blockLoadDebounceMillis); } - this.setStep(step || 1); }; - AgInputRange.prototype.addInputListeners = function () { - var _this = this; - var isIE = _utils__WEBPACK_IMPORTED_MODULE_1__["_"].isBrowserIE(); - var eventName = isIE ? 'change' : 'input'; - this.addManagedListener(this.eInput, eventName, function (e) { - var value = e.target.value; - _this.setValue(value); - }); + RowNodeBlockLoader.prototype.setBeans = function (loggerFactory) { + this.logger = loggerFactory.create('RowNodeBlockLoader'); }; - AgInputRange.prototype.setMinValue = function (value) { - this.min = value; - this.eInput.setAttribute('min', value.toString()); - return this; + RowNodeBlockLoader.prototype.addBlock = function (block) { + this.blocks.push(block); + // note that we do not remove this listener when removing the block. this is because the + // cache can get destroyed (and containing blocks) when a block is loading. however the loading block + // is still counted as an active loading block and we must decrement activeBlockLoadsCount when it finishes. + block.addEventListener(_rowNodeBlock__WEBPACK_IMPORTED_MODULE_0__["RowNodeBlock"].EVENT_LOAD_COMPLETE, this.loadComplete.bind(this)); + this.checkBlockToLoad(); }; - AgInputRange.prototype.setMaxValue = function (value) { - this.max = value; - this.eInput.setAttribute('max', value.toString()); - return this; + RowNodeBlockLoader.prototype.removeBlock = function (block) { + _utils__WEBPACK_IMPORTED_MODULE_3__["_"].removeFromArray(this.blocks, block); }; - AgInputRange.prototype.setStep = function (value) { - this.step = value; - this.eInput.setAttribute('step', value.toString()); - return this; + RowNodeBlockLoader.prototype.destroy = function () { + _super.prototype.destroy.call(this); + this.active = false; }; - AgInputRange.prototype.setValue = function (value, silent) { - if (this.min != null) { - value = Math.max(parseFloat(value), this.min).toString(); + RowNodeBlockLoader.prototype.loadComplete = function () { + this.activeBlockLoadsCount--; + this.checkBlockToLoad(); + if (this.activeBlockLoadsCount == 0) { + this.dispatchEvent({ type: RowNodeBlockLoader_1.BLOCK_LOADER_FINISHED_EVENT }); } - if (this.max != null) { - value = Math.min(parseFloat(value), this.max).toString(); + }; + RowNodeBlockLoader.prototype.checkBlockToLoad = function () { + if (this.checkBlockToLoadDebounce) { + this.checkBlockToLoadDebounce(); + } + else { + this.performCheckBlocksToLoad(); } - var ret = _super.prototype.setValue.call(this, value, silent); - this.eInput.value = value; - return ret; }; - return AgInputRange; -}(_agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractInputField"])); + RowNodeBlockLoader.prototype.performCheckBlocksToLoad = function () { + if (!this.active) { + return; + } + this.printCacheStatus(); + if (this.maxConcurrentRequests != null && this.activeBlockLoadsCount >= this.maxConcurrentRequests) { + this.logger.log("checkBlockToLoad: max loads exceeded"); + return; + } + var blockToLoad = null; + this.blocks.forEach(function (block) { + if (block.getState() === _rowNodeBlock__WEBPACK_IMPORTED_MODULE_0__["RowNodeBlock"].STATE_WAITING_TO_LOAD) { + blockToLoad = block; + } + }); + if (blockToLoad) { + blockToLoad.load(); + this.activeBlockLoadsCount++; + this.printCacheStatus(); + } + }; + RowNodeBlockLoader.prototype.getBlockState = function () { + var result = {}; + this.blocks.forEach(function (block) { + var _a = block.getBlockStateJson(), id = _a.id, state = _a.state; + result[id] = state; + }); + return result; + }; + RowNodeBlockLoader.prototype.printCacheStatus = function () { + if (this.logger.isLogging()) { + this.logger.log("printCacheStatus: activePageLoadsCount = " + this.activeBlockLoadsCount + "," + + (" blocks = " + JSON.stringify(this.getBlockState()))); + } + }; + RowNodeBlockLoader.prototype.isLoading = function () { + return this.activeBlockLoadsCount > 0; + }; + var RowNodeBlockLoader_1; + RowNodeBlockLoader.BLOCK_LOADER_FINISHED_EVENT = 'blockLoaderFinished'; + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], RowNodeBlockLoader.prototype, "postConstruct", null); + __decorate([ + __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Qualifier"])('loggerFactory')) + ], RowNodeBlockLoader.prototype, "setBeans", null); + RowNodeBlockLoader = RowNodeBlockLoader_1 = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('rowNodeBlockLoader') + ], RowNodeBlockLoader); + return RowNodeBlockLoader; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"])); /***/ }), -/* 181 */ +/* 230 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgSelect", function() { return AgSelect; }); -/* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(72); -/* harmony import */ var _agPickerField__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(178); -/* harmony import */ var _agList__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(182); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowNodeBlock", function() { return RowNodeBlock; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -41046,148 +49375,105 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - -var AgSelect = /** @class */ (function (_super) { - __extends(AgSelect, _super); - function AgSelect(config) { +var RowNodeBlock = /** @class */ (function (_super) { + __extends(RowNodeBlock, _super); + function RowNodeBlock(id) { var _this = _super.call(this) || this; - _this.displayTag = 'div'; - _this.className = 'ag-select'; - _this.pickerIcon = 'smallDown'; - _this.setTemplate(_this.TEMPLATE.replace(/%displayField%/g, _this.displayTag)); + _this.state = RowNodeBlock.STATE_WAITING_TO_LOAD; + _this.version = 0; + _this.id = id; return _this; } - AgSelect.prototype.init = function () { - var _this = this; - this.listComponent = new _agList__WEBPACK_IMPORTED_MODULE_2__["AgList"]('select'); - this.getContext().createBean(this.listComponent); - this.listComponent.setParentComponent(this); - this.eWrapper.tabIndex = 0; - this.listComponent.addManagedListener(this.listComponent, _agList__WEBPACK_IMPORTED_MODULE_2__["AgList"].EVENT_ITEM_SELECTED, function () { if (_this.hideList) { - _this.hideList(); - } }); - this.listComponent.addManagedListener(this.listComponent, _agAbstractField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractField"].EVENT_CHANGED, function () { - _this.setValue(_this.listComponent.getValue(), false, true); - if (_this.hideList) { - _this.hideList(); - } - }); + RowNodeBlock.prototype.getId = function () { + return this.id; }; - AgSelect.prototype.showPicker = function () { - var _this = this; - var listGui = this.listComponent.getGui(); - var mouseWheelFunc = this.addManagedListener(document.body, 'wheel', function (e) { - if (!listGui.contains(e.target) && _this.hideList) { - _this.hideList(); - } - }); - var focusOutFunc = this.addManagedListener(listGui, 'focusout', function (e) { - if (!listGui.contains(e.relatedTarget) && _this.hideList) { - _this.hideList(); - } - }); - this.hideList = this.popupService.addPopup(true, listGui, true, function () { - _this.hideList = null; - focusOutFunc(); - mouseWheelFunc(); - if (_this.isAlive()) { - _this.getFocusableElement().focus(); - } - }); - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].setElementWidth(listGui, _utils__WEBPACK_IMPORTED_MODULE_4__["_"].getAbsoluteWidth(this.eWrapper)); - listGui.style.maxHeight = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].getInnerHeight(this.popupService.getPopupParent()) + 'px'; - listGui.style.position = 'absolute'; - this.popupService.positionPopupUnderComponent({ - type: 'ag-list', - eventSource: this.eWrapper, - ePopup: listGui, - keepWithinBounds: true - }); - this.listComponent.refreshHighlighted(); - return this.listComponent; + RowNodeBlock.prototype.load = function () { + this.state = RowNodeBlock.STATE_LOADING; + this.loadFromDatasource(); }; - AgSelect.prototype.addOptions = function (options) { - var _this = this; - options.forEach(function (option) { return _this.addOption(option); }); - return this; + RowNodeBlock.prototype.getVersion = function () { + return this.version; }; - AgSelect.prototype.addOption = function (option) { - this.listComponent.addOption(option); - return this; + RowNodeBlock.prototype.setStateWaitingToLoad = function () { + // in case any current loads in progress, this will have their results ignored + this.version++; + this.state = RowNodeBlock.STATE_WAITING_TO_LOAD; }; - AgSelect.prototype.setValue = function (value, silent, fromPicker) { - if (this.value === value) { - return; - } - if (!fromPicker) { - this.listComponent.setValue(value, true); - } - var newValue = this.listComponent.getValue(); - if (newValue === this.getValue()) { - return; + RowNodeBlock.prototype.getState = function () { + return this.state; + }; + RowNodeBlock.prototype.pageLoadFailed = function (version) { + var requestMostRecentAndLive = this.isRequestMostRecentAndLive(version); + if (requestMostRecentAndLive) { + this.state = RowNodeBlock.STATE_FAILED; + this.processServerFail(); } - this.eDisplayField.innerHTML = this.listComponent.getDisplayValue(); - return _super.prototype.setValue.call(this, value, silent); + this.dispatchLoadCompleted(false); }; - AgSelect.prototype.destroy = function () { - if (this.hideList) { - this.hideList(); + RowNodeBlock.prototype.success = function (version, params) { + this.successCommon(version, params); + }; + RowNodeBlock.prototype.pageLoaded = function (version, rows, lastRow) { + this.successCommon(version, { rowData: rows, rowCount: lastRow }); + }; + RowNodeBlock.prototype.isRequestMostRecentAndLive = function (version) { + // thisIsMostRecentRequest - if block was refreshed, then another request + // could of been sent after this one. + var thisIsMostRecentRequest = version === this.version; + // weAreNotDestroyed - if InfiniteStore is purged, then blocks are destroyed + // and new blocks created. so data loads of old blocks are discarded. + var weAreNotDestroyed = this.isAlive(); + return thisIsMostRecentRequest && weAreNotDestroyed; + }; + RowNodeBlock.prototype.successCommon = function (version, params) { + // need to dispatch load complete before processing the data, as PaginationComp checks + // RowNodeBlockLoader to see if it is still loading, so the RowNodeBlockLoader needs to + // be updated first (via LoadComplete event) before PaginationComp updates (via processServerResult method) + this.dispatchLoadCompleted(); + var requestMostRecentAndLive = this.isRequestMostRecentAndLive(version); + if (requestMostRecentAndLive) { + this.state = RowNodeBlock.STATE_LOADED; + this.processServerResult(params); } - this.getContext().destroyBean(this.listComponent); - _super.prototype.destroy.call(this); }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('popupService') - ], AgSelect.prototype, "popupService", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"] - ], AgSelect.prototype, "init", null); - return AgSelect; -}(_agPickerField__WEBPACK_IMPORTED_MODULE_1__["AgPickerField"])); + RowNodeBlock.prototype.dispatchLoadCompleted = function (success) { + if (success === void 0) { success = true; } + // we fire event regardless of processing data or now, as we want + // the concurrentLoadRequests count to be reduced in BlockLoader + var event = { + type: RowNodeBlock.EVENT_LOAD_COMPLETE, + success: success, + block: this + }; + this.dispatchEvent(event); + }; + RowNodeBlock.EVENT_LOAD_COMPLETE = 'loadComplete'; + RowNodeBlock.STATE_WAITING_TO_LOAD = 'needsLoading'; + RowNodeBlock.STATE_LOADING = 'loading'; + RowNodeBlock.STATE_LOADED = 'loaded'; + RowNodeBlock.STATE_FAILED = 'failed'; + return RowNodeBlock; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 182 */ +/* 231 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgList", function() { return AgList; }); -/* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(72); -/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowNodeSorter", function() { return RowNodeSorter; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(15); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); @@ -41197,174 +49483,103 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta - - -var AgList = /** @class */ (function (_super) { - __extends(AgList, _super); - function AgList(cssIdentifier) { - if (cssIdentifier === void 0) { cssIdentifier = 'default'; } - var _this = _super.call(this, AgList.getTemplate(cssIdentifier)) || this; - _this.cssIdentifier = cssIdentifier; - _this.options = []; - _this.itemEls = []; - return _this; +// this logic is used by both SSRM and CSRM +var RowNodeSorter = /** @class */ (function () { + function RowNodeSorter() { } - AgList.prototype.init = function () { - this.addManagedListener(this.getGui(), 'keydown', this.handleKeyDown.bind(this)); - }; - AgList.getTemplate = function (cssIdentifier) { - return "
"; + RowNodeSorter.prototype.doFullSort = function (rowNodes, sortOptions) { + var mapper = function (rowNode, pos) { return ({ currentPos: pos, rowNode: rowNode }); }; + var sortedRowNodes = rowNodes.map(mapper); + sortedRowNodes.sort(this.compareRowNodes.bind(this, sortOptions)); + return sortedRowNodes.map(function (item) { return item.rowNode; }); }; - AgList.prototype.handleKeyDown = function (e) { - var key = e.keyCode; - switch (key) { - case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_ENTER: - if (!this.highlightedEl) { - this.setValue(this.getValue()); - } - else { - var pos = this.itemEls.indexOf(this.highlightedEl); - this.setValueByIndex(pos); - } - break; - case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_DOWN: - case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_UP: - var isDown = key === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_DOWN; - var itemToHighlight = void 0; - e.preventDefault(); - if (!this.highlightedEl) { - itemToHighlight = this.itemEls[isDown ? 0 : this.itemEls.length - 1]; - } - else { - var currentIdx = this.itemEls.indexOf(this.highlightedEl); - var nextPos = currentIdx + (isDown ? 1 : -1); - nextPos = Math.min(Math.max(nextPos, 0), this.itemEls.length - 1); - itemToHighlight = this.itemEls[nextPos]; - } - this.highlightItem(itemToHighlight); - break; + RowNodeSorter.prototype.compareRowNodes = function (sortOptions, sortedNodeA, sortedNodeB) { + var nodeA = sortedNodeA.rowNode; + var nodeB = sortedNodeB.rowNode; + // Iterate columns, return the first that doesn't match + for (var i = 0, len = sortOptions.length; i < len; i++) { + var sortOption = sortOptions[i]; + var isInverted = sortOption.sort === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_DESC; + var valueA = this.getValue(nodeA, sortOption.column); + var valueB = this.getValue(nodeB, sortOption.column); + var comparatorResult = void 0; + var providedComparator = this.getComparator(sortOption, nodeA); + if (providedComparator) { + //if comparator provided, use it + comparatorResult = providedComparator(valueA, valueB, nodeA, nodeB, isInverted); + } + else { + //otherwise do our own comparison + comparatorResult = _utils__WEBPACK_IMPORTED_MODULE_1__["_"].defaultComparator(valueA, valueB, this.gridOptionsWrapper.isAccentedSort()); + } + // user provided comparators can return 'NaN' if they don't correctly handle 'undefined' values, this + // typically occurs when the comparator is used on a group row + var validResult = !isNaN(comparatorResult); + if (validResult && comparatorResult !== 0) { + return sortOption.sort === _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_ASC ? comparatorResult : comparatorResult * -1; + } } + // All matched, we make is so that the original sort order is kept: + return sortedNodeA.currentPos - sortedNodeB.currentPos; }; - AgList.prototype.addOptions = function (listOptions) { - var _this = this; - listOptions.forEach(function (listOption) { return _this.addOption(listOption); }); - return this; - }; - AgList.prototype.addOption = function (listOption) { - var value = listOption.value, text = listOption.text; - var sanitisedText = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].escape(text === undefined ? value : text); - this.options.push({ value: value, text: sanitisedText }); - this.renderOption(sanitisedText); - return this; - }; - AgList.prototype.renderOption = function (innerText) { - var _this = this; - var itemEl = document.createElement('div'); - var itemContentEl = document.createElement('span'); - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(itemEl, 'ag-list-item'); - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(itemEl, "ag-" + this.cssIdentifier + "-list-item"); - itemEl.tabIndex = -1; - itemContentEl.innerHTML = innerText; - this.itemEls.push(itemEl); - this.addManagedListener(itemEl, 'mouseover', function (e) { return _this.highlightItem(itemEl); }); - this.addManagedListener(itemEl, 'mouseleave', function () { return _this.clearHighlighted(); }); - this.addManagedListener(itemEl, 'click', function () { - var idx = _this.itemEls.indexOf(itemEl); - _this.setValueByIndex(idx); - }); - itemEl.appendChild(itemContentEl); - this.getGui().appendChild(itemEl); - }; - AgList.prototype.setValue = function (value, silent) { - if (this.value === value) { - this.fireItemSelected(); - return this; - } - if (value == null) { - this.reset(); - return this; + RowNodeSorter.prototype.getComparator = function (sortOption, rowNode) { + var column = sortOption.column; + // comparator on col get preference over everything else + var comparatorOnCol = column.getColDef().comparator; + if (comparatorOnCol != null) { + return comparatorOnCol; } - var idx = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].findIndex(this.options, function (option) { return option.value === value; }); - if (idx !== -1) { - var option = this.options[idx]; - this.value = option.value; - this.displayValue = option.text != null ? option.text : option.value; - this.highlightItem(this.itemEls[idx]); - if (!silent) { - this.fireChangeEvent(); - } + // if no comparator on col, see if we are showing a group, and if we are, get comparator from row group col + if (rowNode.rowGroupColumn) { + return rowNode.rowGroupColumn.getColDef().comparator; } - return this; - }; - AgList.prototype.setValueByIndex = function (idx) { - return this.setValue(this.options[idx].value); - }; - AgList.prototype.getValue = function () { - return this.value; - }; - AgList.prototype.getDisplayValue = function () { - return this.displayValue; - }; - AgList.prototype.refreshHighlighted = function () { - var _this = this; - this.clearHighlighted(); - var idx = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].findIndex(this.options, function (option) { return option.value === _this.value; }); - if (idx !== -1) { - this.highlightItem(this.itemEls[idx]); + if (!column.getColDef().showRowGroup) { + return; } - }; - AgList.prototype.reset = function () { - this.value = null; - this.displayValue = null; - this.clearHighlighted(); - this.fireChangeEvent(); - }; - AgList.prototype.highlightItem = function (el) { - if (!el.offsetParent) { + // if a 'field' is supplied on the autoGroupColumnDef we need to use the associated column comparator + var groupLeafField = !rowNode.group && column.getColDef().field; + if (!groupLeafField) { return; } - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].radioCssClass(el, 'ag-active-item'); - this.highlightedEl = el; - this.highlightedEl.focus(); - }; - AgList.prototype.clearHighlighted = function () { - if (!this.highlightedEl || !this.highlightedEl.offsetParent) { + var primaryColumn = this.columnModel.getPrimaryColumn(groupLeafField); + if (!primaryColumn) { return; } - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].removeCssClass(this.highlightedEl, 'ag-active-item'); - this.highlightedEl = null; - }; - AgList.prototype.fireChangeEvent = function () { - this.dispatchEvent({ type: _agAbstractField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractField"].EVENT_CHANGED }); - this.fireItemSelected(); + return primaryColumn.getColDef().comparator; }; - AgList.prototype.fireItemSelected = function () { - this.dispatchEvent({ type: AgList.EVENT_ITEM_SELECTED }); + RowNodeSorter.prototype.getValue = function (nodeA, column) { + return this.valueService.getValue(column, nodeA, false, false); }; - AgList.EVENT_ITEM_SELECTED = 'selectedItem'; __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] - ], AgList.prototype, "init", null); - return AgList; -}(_component__WEBPACK_IMPORTED_MODULE_1__["Component"])); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') + ], RowNodeSorter.prototype, "gridOptionsWrapper", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueService') + ], RowNodeSorter.prototype, "valueService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], RowNodeSorter.prototype, "columnModel", void 0); + RowNodeSorter = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('rowNodeSorter') + ], RowNodeSorter); + return RowNodeSorter; +}()); /***/ }), -/* 183 */ +/* 232 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgAngleSelect", function() { return AgAngleSelect; }); -/* harmony import */ var _agAbstractLabel__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(73); -/* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37); -/* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(72); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CtrlsService", function() { return CtrlsService; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(15); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -41386,213 +49601,190 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - - - - -var AgAngleSelect = /** @class */ (function (_super) { - __extends(AgAngleSelect, _super); - function AgAngleSelect() { - var _this = _super.call(this, AgAngleSelect.TEMPLATE) || this; - _this.radius = 0; - _this.offsetX = 0; - _this.offsetY = 0; +}; + + + +var CtrlsService = /** @class */ (function (_super) { + __extends(CtrlsService, _super); + function CtrlsService() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.ready = false; + _this.readyCallbacks = []; return _this; } - AgAngleSelect.prototype.postConstruct = function () { - var _this = this; - _super.prototype.postConstruct.call(this); - this.dragListener = { - eElement: this.eParentCircle, - dragStartPixels: 0, - onDragStart: function (e) { - _this.parentCircleRect = _this.eParentCircle.getBoundingClientRect(); - }, - onDragging: function (e) { return _this.calculateAngleDrag(e); }, - onDragStop: function () { } - }; - this.dragService.addDragSource(this.dragListener); - this.eAngleValue - .setLabel('') - .setLabelWidth(5) - .setInputWidth(45) - .setMin(0) - .setMax(360) - .setValue("" + this.degrees) - .onValueChange(function (value) { - if (value == null || value === '') { - value = '0'; - } - value = _this.eAngleValue.normalizeValue(value); - var floatValue = parseFloat(value); - if (floatValue > 180) { - floatValue = floatValue - 360; - } - _this.setValue(floatValue); - }); - this.updateNumberInput(); - if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].exists(this.getValue())) { - this.eAngleValue.setValue(this.normalizeNegativeValue(this.getValue()).toString()); + CtrlsService_1 = CtrlsService; + CtrlsService.prototype.checkReady = function () { + this.ready = + this.gridCtrl != null + && this.gridBodyCtrl != null + && this.centerRowContainerCtrl != null + && this.leftRowContainerCtrl != null + && this.rightRowContainerCtrl != null + && this.bottomCenterRowContainerCtrl != null + && this.bottomLeftRowContainerCtrl != null + && this.bottomRightRowContainerCtrl != null + && this.topCenterRowContainerCtrl != null + && this.topLeftRowContainerCtrl != null + && this.topRightRowContainerCtrl != null + && this.centerHeaderRowContainerCtrl != null + && this.leftHeaderRowContainerCtrl != null + && this.rightHeaderRowContainerCtrl != null + && this.fakeHScrollCtrl != null + && this.gridHeaderCtrl != null; + if (this.ready) { + var p_1 = this.createReadyParams(); + this.readyCallbacks.forEach(function (c) { return c(p_1); }); + this.readyCallbacks.length = 0; + } + }; + CtrlsService.prototype.whenReady = function (callback) { + if (this.ready) { + callback(this.createReadyParams()); + } + else { + this.readyCallbacks.push(callback); } - this.addManagedListener(this, _agAbstractField__WEBPACK_IMPORTED_MODULE_3__["AgAbstractField"].EVENT_CHANGED, function () { - if (_this.eAngleValue.getInputElement().contains(document.activeElement)) { - return; - } - _this.updateNumberInput(); - }); }; - AgAngleSelect.prototype.updateNumberInput = function () { - var normalizedValue = this.normalizeNegativeValue(this.getValue()); - this.eAngleValue.setValue(normalizedValue.toString()); + CtrlsService.prototype.createReadyParams = function () { + return { + centerRowContainerCtrl: this.centerRowContainerCtrl, + leftRowContainerCtrl: this.leftRowContainerCtrl, + rightRowContainerCtrl: this.rightRowContainerCtrl, + bottomCenterRowContainerCtrl: this.bottomCenterRowContainerCtrl, + bottomLeftRowContainerCtrl: this.bottomLeftRowContainerCtrl, + bottomRightRowContainerCtrl: this.bottomRightRowContainerCtrl, + topCenterRowContainerCtrl: this.topCenterRowContainerCtrl, + topLeftRowContainerCtrl: this.topLeftRowContainerCtrl, + topRightRowContainerCtrl: this.topRightRowContainerCtrl, + centerHeaderRowContainerCtrl: this.centerHeaderRowContainerCtrl, + leftHeaderRowContainerCtrl: this.leftHeaderRowContainerCtrl, + rightHeaderRowContainerCtrl: this.rightHeaderRowContainerCtrl, + fakeHScrollCtrl: this.fakeHScrollCtrl, + gridBodyCtrl: this.gridBodyCtrl, + gridCtrl: this.gridCtrl, + gridHeaderCtrl: this.gridHeaderCtrl, + }; }; - AgAngleSelect.prototype.positionChildCircle = function (radians) { - var rect = this.parentCircleRect || { width: 24, height: 24 }; - var eChildCircle = this.eChildCircle; - var centerX = rect.width / 2; - var centerY = rect.height / 2; - eChildCircle.style.left = centerX + Math.cos(radians) * 8 + "px"; - eChildCircle.style.top = centerY + Math.sin(radians) * 8 + "px"; + CtrlsService.prototype.registerFakeHScrollCtrl = function (ctrl) { + this.fakeHScrollCtrl = ctrl; + this.checkReady(); }; - AgAngleSelect.prototype.calculatePolar = function () { - var x = this.offsetX; - var y = this.offsetY; - var radians = Math.atan2(y, x); - this.degrees = this.toDegrees(radians); - this.radius = Math.sqrt((x * x) + (y * y)); - this.positionChildCircle(radians); + CtrlsService.prototype.registerGridHeaderCtrl = function (gridHeaderCtrl) { + this.gridHeaderCtrl = gridHeaderCtrl; + this.checkReady(); }; - AgAngleSelect.prototype.calculateCartesian = function () { - var radians = this.toRadians(this.getValue()); - var radius = this.getRadius(); - this - .setOffsetX(Math.cos(radians) * radius) - .setOffsetY(Math.sin(radians) * radius); + CtrlsService.prototype.registerCenterRowContainerCtrl = function (ctrl) { + this.centerRowContainerCtrl = ctrl; + this.checkReady(); }; - AgAngleSelect.prototype.setOffsetX = function (offset) { - if (this.offsetX !== offset) { - this.offsetX = offset; - this.calculatePolar(); - } - return this; + CtrlsService.prototype.registerLeftRowContainerCtrl = function (ctrl) { + this.leftRowContainerCtrl = ctrl; + this.checkReady(); }; - AgAngleSelect.prototype.setOffsetY = function (offset) { - if (this.offsetY !== offset) { - this.offsetY = offset; - this.calculatePolar(); - } - return this; + CtrlsService.prototype.registerRightRowContainerCtrl = function (ctrl) { + this.rightRowContainerCtrl = ctrl; + this.checkReady(); }; - AgAngleSelect.prototype.calculateAngleDrag = function (e) { - var rect = this.parentCircleRect; - var centerX = rect.width / 2; - var centerY = rect.height / 2; - var x = e.clientX - rect.left; - var y = e.clientY - rect.top; - var dx = x - centerX; - var dy = y - centerY; - var radians = Math.atan2(dy, dx); - this.setValue(radians, true); + CtrlsService.prototype.registerTopCenterRowContainerCtrl = function (ctrl) { + this.topCenterRowContainerCtrl = ctrl; + this.checkReady(); }; - AgAngleSelect.prototype.toDegrees = function (radians) { - return radians / Math.PI * 180; + CtrlsService.prototype.registerTopLeftRowContainerCon = function (ctrl) { + this.topLeftRowContainerCtrl = ctrl; + this.checkReady(); }; - AgAngleSelect.prototype.toRadians = function (degrees) { - return degrees / 180 * Math.PI; + CtrlsService.prototype.registerTopRightRowContainerCtrl = function (ctrl) { + this.topRightRowContainerCtrl = ctrl; + this.checkReady(); }; - AgAngleSelect.prototype.normalizeNegativeValue = function (degrees) { - return degrees < 0 ? 360 + degrees : degrees; + CtrlsService.prototype.registerBottomCenterRowContainerCtrl = function (ctrl) { + this.bottomCenterRowContainerCtrl = ctrl; + this.checkReady(); }; - AgAngleSelect.prototype.normalizeAngle180 = function (radians) { - radians %= Math.PI * 2; - if (radians < -Math.PI) { - radians += Math.PI * 2; - } - else if (radians >= Math.PI) { - radians -= Math.PI * 2; - } - return radians; + CtrlsService.prototype.registerBottomLeftRowContainerCtrl = function (ctrl) { + this.bottomLeftRowContainerCtrl = ctrl; + this.checkReady(); }; - AgAngleSelect.prototype.getRadius = function () { - return this.radius; + CtrlsService.prototype.registerBottomRightRowContainerCtrl = function (ctrl) { + this.bottomRightRowContainerCtrl = ctrl; + this.checkReady(); }; - AgAngleSelect.prototype.setRadius = function (r) { - if (this.radius === r) { - return this; + CtrlsService.prototype.registerHeaderContainer = function (ctrl, pinned) { + switch (pinned) { + case _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_LEFT: + this.leftHeaderRowContainerCtrl = ctrl; + break; + case _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_RIGHT: + this.rightHeaderRowContainerCtrl = ctrl; + break; + default: + this.centerHeaderRowContainerCtrl = ctrl; + break; } - this.radius = r; - this.calculateCartesian(); - return this; + this.checkReady(); }; - AgAngleSelect.prototype.onValueChange = function (callbackFn) { - var _this = this; - this.addManagedListener(this, _agAbstractField__WEBPACK_IMPORTED_MODULE_3__["AgAbstractField"].EVENT_CHANGED, function () { - callbackFn(_this.degrees); - }); - return this; + CtrlsService.prototype.registerGridBodyCtrl = function (ctrl) { + this.gridBodyCtrl = ctrl; + this.checkReady(); }; - AgAngleSelect.prototype.getValue = function (radians) { - return radians ? this.toRadians(this.degrees) : this.degrees; + CtrlsService.prototype.registerGridCtrl = function (ctrl) { + this.gridCtrl = ctrl; + this.checkReady(); }; - AgAngleSelect.prototype.setValue = function (degrees, radians) { - var radiansValue; - if (!radians) { - radiansValue = this.normalizeAngle180(this.toRadians(degrees)); - } - else { - radiansValue = degrees; - } - degrees = this.toDegrees(radiansValue); - if (this.degrees !== degrees) { - this.degrees = Math.floor(degrees); - this.calculateCartesian(); - this.positionChildCircle(radiansValue); - this.dispatchEvent({ type: _agAbstractField__WEBPACK_IMPORTED_MODULE_3__["AgAbstractField"].EVENT_CHANGED }); - } - return this; + CtrlsService.prototype.getFakeHScrollCtrl = function () { + return this.fakeHScrollCtrl; }; - AgAngleSelect.prototype.setWidth = function (width) { - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].setFixedWidth(this.getGui(), width); - return this; + CtrlsService.prototype.getGridHeaderCtrl = function () { + return this.gridHeaderCtrl; }; - AgAngleSelect.prototype.destroy = function () { - this.dragService.removeDragSource(this.dragListener); - _super.prototype.destroy.call(this); + CtrlsService.prototype.getGridCtrl = function () { + return this.gridCtrl; }; - AgAngleSelect.TEMPLATE = "
\n \n
\n
\n
\n
\n
\n
\n \n
\n
"; - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eLabel') - ], AgAngleSelect.prototype, "eLabel", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eParentCircle') - ], AgAngleSelect.prototype, "eParentCircle", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eChildCircle') - ], AgAngleSelect.prototype, "eChildCircle", void 0); - __decorate([ - Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eAngleValue') - ], AgAngleSelect.prototype, "eAngleValue", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])("dragService") - ], AgAngleSelect.prototype, "dragService", void 0); - return AgAngleSelect; -}(_agAbstractLabel__WEBPACK_IMPORTED_MODULE_0__["AgAbstractLabel"])); + CtrlsService.prototype.getCenterRowContainerCtrl = function () { + return this.centerRowContainerCtrl; + }; + CtrlsService.prototype.getTopCenterRowContainerCtrl = function () { + return this.topCenterRowContainerCtrl; + }; + CtrlsService.prototype.getBottomCenterRowContainerCtrl = function () { + return this.bottomCenterRowContainerCtrl; + }; + CtrlsService.prototype.getGridBodyCtrl = function () { + return this.gridBodyCtrl; + }; + CtrlsService.prototype.getHeaderRowContainerCtrls = function () { + return [this.leftHeaderRowContainerCtrl, this.rightHeaderRowContainerCtrl, this.centerHeaderRowContainerCtrl]; + }; + CtrlsService.prototype.getHeaderRowContainerCtrl = function (pinned) { + switch (pinned) { + case _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_LEFT: return this.leftHeaderRowContainerCtrl; + case _constants_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_RIGHT: return this.rightHeaderRowContainerCtrl; + default: return this.centerHeaderRowContainerCtrl; + } + }; + var CtrlsService_1; + CtrlsService.NAME = 'ctrlsService'; + CtrlsService = CtrlsService_1 = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])(CtrlsService_1.NAME) + ], CtrlsService); + return CtrlsService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 184 */ +/* 233 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgToggleButton", function() { return AgToggleButton; }); -/* harmony import */ var _agRadioButton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(146); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CtrlsFactory", function() { return CtrlsFactory; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -41609,39 +49801,55 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; -var AgToggleButton = /** @class */ (function (_super) { - __extends(AgToggleButton, _super); - function AgToggleButton() { +var CtrlsFactory = /** @class */ (function (_super) { + __extends(CtrlsFactory, _super); + function CtrlsFactory() { var _this = _super !== null && _super.apply(this, arguments) || this; - _this.className = 'ag-toggle-button'; - _this.inputType = 'checkbox'; + _this.registry = {}; return _this; } - AgToggleButton.prototype.setValue = function (value, silent) { - _super.prototype.setValue.call(this, value, silent); - _utils__WEBPACK_IMPORTED_MODULE_1__["_"].addOrRemoveCssClass(this.getGui(), 'ag-selected', this.getValue()); - return this; + CtrlsFactory.prototype.register = function (meta) { + this.registry[meta.controllerName] = meta.controllerClass; }; - return AgToggleButton; -}(_agRadioButton__WEBPACK_IMPORTED_MODULE_0__["AgRadioButton"])); + CtrlsFactory.prototype.getInstance = function (name) { + var ControllerClass = this.registry[name]; + if (ControllerClass == null) { + return undefined; + } + return new ControllerClass(); + }; + CtrlsFactory = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('ctrlsFactory') + ], CtrlsFactory); + return CtrlsFactory; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 185 */ +/* 234 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DetailRowCompCache", function() { return DetailRowCompCache; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(25); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FakeHScrollComp", function() { return FakeHScrollComp; }); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _fakeHScrollCtrl__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(235); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(42); +/* harmony import */ var _centerWidthFeature__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(132); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -41667,161 +49875,70 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -/** - * For Master Detail, it is required to keep components between expanding & collapsing parents. - * For example a user expands row A (and shows a detail grid for this row), then when row A - * is closed, we want to keep the detail grid, so next time row A is expanded the detail grid - * is showed with it's context intact, eg if user sorted in the detail grid, that sort should - * still be applied after the detail grid is shown for the second time. - */ -var DetailRowCompCache = /** @class */ (function (_super) { - __extends(DetailRowCompCache, _super); - function DetailRowCompCache() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.cacheItems = []; - return _this; + + + +var FakeHScrollComp = /** @class */ (function (_super) { + __extends(FakeHScrollComp, _super); + function FakeHScrollComp() { + return _super.call(this, FakeHScrollComp.TEMPLATE) || this; } - DetailRowCompCache.prototype.postConstruct = function () { - this.active = this.gridOptionsWrapper.isKeepDetailRows(); - this.maxCacheSize = this.gridOptionsWrapper.getKeepDetailRowsCount(); - }; - DetailRowCompCache.prototype.addOrDestroy = function (rowNode, pinned, comp) { - // only accept detail rows - var doNotUseCache = !this.active || !rowNode.detail; - if (doNotUseCache) { - this.destroyFullWidthRow(comp); - return; - } - var item = this.getCacheItem(rowNode, true); - // put the comp in the right location of the item. - // we also destroy any previous comp - this should never happen - // as the logic outside of this class shouldn't be adding same item to the - // cache twice, however we cater for it in case in future releases code - // outside of this class is changed and this could happen. - switch (pinned) { - case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].PINNED_LEFT: - this.destroyFullWidthRow(item.left); - item.left = comp; - break; - case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].PINNED_RIGHT: - this.destroyFullWidthRow(item.right); - item.right = comp; - break; - default: - this.destroyFullWidthRow(item.center); - item.center = comp; - break; - } - this.cacheItems.sort(function (a, b) { - return b.lastAccessedTime - a.lastAccessedTime; - }); - this.purgeCache(this.maxCacheSize); - }; - DetailRowCompCache.prototype.getCacheItem = function (rowNode, autoCreate) { - if (autoCreate === void 0) { autoCreate = false; } - var res; - for (var i = 0; i < this.cacheItems.length; i++) { - var item = this.cacheItems[i]; - if (item.rowNode === rowNode) { - res = item; - break; - } - } - if (!res && autoCreate) { - res = { - rowNode: rowNode - }; - this.cacheItems.push(res); - } - if (res) { - this.stampCacheItem(res); - } - return res; - }; - DetailRowCompCache.prototype.stampCacheItem = function (item) { - item.lastAccessedTime = new Date().getTime(); - }; - DetailRowCompCache.prototype.destroyFullWidthRow = function (comp) { - this.getContext().destroyBean(comp); - }; - DetailRowCompCache.prototype.purgeCache = function (startIndex) { - // delete all rows past the index of interest - for (var i = startIndex; i < this.cacheItems.length; i++) { - var item = this.cacheItems[i]; - this.destroyFullWidthRow(item.center); - this.destroyFullWidthRow(item.left); - this.destroyFullWidthRow(item.right); - } - // change the length of the array so it no longer contains the deleted items - if (this.cacheItems.length > startIndex) { - this.cacheItems.length = startIndex; - } - }; - DetailRowCompCache.prototype.get = function (rowNode, pinned) { - if (!rowNode.detail) { - return undefined; - } - var item = this.getCacheItem(rowNode); - var res; - if (item) { - switch (pinned) { - case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].PINNED_LEFT: - if (item.left) { - res = item.left; - item.left = undefined; - } - break; - case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].PINNED_RIGHT: - if (item.right) { - res = item.right; - item.right = undefined; - } - break; - default: - if (item.center) { - res = item.center; - item.center = undefined; - } - break; - } - } - return res; - }; - DetailRowCompCache.prototype.destroy = function () { - _super.prototype.destroy.call(this); - this.purgeCache(0); + FakeHScrollComp.prototype.postConstruct = function () { + var _this = this; + var compProxy = { + addOrRemoveCssClass: function (cssClassName, on) { return _this.addOrRemoveCssClass(cssClassName, on); }, + setHeight: function (height) { return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setFixedHeight"])(_this.getGui(), height); }, + setContainerHeight: function (height) { return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setFixedHeight"])(_this.eContainer, height); }, + setViewportHeight: function (height) { return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setFixedHeight"])(_this.eViewport, height); }, + setRightSpacerFixedWidth: function (width) { return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setFixedWidth"])(_this.eRightSpacer, width); }, + setLeftSpacerFixedWidth: function (width) { return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setFixedWidth"])(_this.eLeftSpacer, width); }, + includeLeftSpacerScrollerCss: function (cssClass, include) { + return _this.eLeftSpacer.classList.toggle(cssClass, include); + }, + includeRightSpacerScrollerCss: function (cssClass, include) { + return _this.eRightSpacer.classList.toggle(cssClass, include); + }, + }; + var ctrl = this.createManagedBean(new _fakeHScrollCtrl__WEBPACK_IMPORTED_MODULE_3__["FakeHScrollCtrl"]()); + ctrl.setComp(compProxy, this.getGui(), this.eViewport, this.eContainer); + this.createManagedBean(new _centerWidthFeature__WEBPACK_IMPORTED_MODULE_5__["CenterWidthFeature"](function (width) { return _this.eContainer.style.width = width + "px"; })); }; + FakeHScrollComp.TEMPLATE = "
\n
\n
\n
\n
\n
\n
"; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], DetailRowCompCache.prototype, "gridOptionsWrapper", void 0); + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eLeftSpacer') + ], FakeHScrollComp.prototype, "eLeftSpacer", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], DetailRowCompCache.prototype, "postConstruct", null); + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eRightSpacer') + ], FakeHScrollComp.prototype, "eRightSpacer", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PreDestroy"] - ], DetailRowCompCache.prototype, "destroy", null); - DetailRowCompCache = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('detailRowCompCache') - ], DetailRowCompCache); - return DetailRowCompCache; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"])); + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eViewport') + ], FakeHScrollComp.prototype, "eViewport", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eContainer') + ], FakeHScrollComp.prototype, "eContainer", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] + ], FakeHScrollComp.prototype, "postConstruct", null); + return FakeHScrollComp; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); /***/ }), -/* 186 */ +/* 235 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowPositionUtils", function() { return RowPositionUtils; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FakeHScrollCtrl", function() { return FakeHScrollCtrl; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(24); +/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(107); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -41848,100 +49965,127 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var RowPositionUtils = /** @class */ (function (_super) { - __extends(RowPositionUtils, _super); - function RowPositionUtils() { - return _super !== null && _super.apply(this, arguments) || this; + +var FakeHScrollCtrl = /** @class */ (function (_super) { + __extends(FakeHScrollCtrl, _super); + function FakeHScrollCtrl() { + return _super.call(this) || this; } - RowPositionUtils.prototype.getFirstRow = function () { - var rowIndex = 0; - var rowPinned; - if (this.pinnedRowModel.getPinnedTopRowCount()) { - rowPinned = _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP; - } - else if (this.rowModel.getRowCount()) { - rowPinned = null; - } - else if (this.pinnedRowModel.getPinnedBottomRowCount()) { - rowPinned = _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM; + FakeHScrollCtrl.prototype.setComp = function (view, eGui, eViewport, eContainer) { + this.view = view; + this.eViewport = eViewport; + this.eContainer = eContainer; + this.eGui = eGui; + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_SCROLL_VISIBILITY_CHANGED, this.onScrollVisibilityChanged.bind(this)); + this.onScrollVisibilityChanged(); + // When doing printing, this changes whether cols are pinned or not + var spacerWidthsListener = this.setFakeHScrollSpacerWidths.bind(this); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, spacerWidthsListener); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, spacerWidthsListener); + this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_4__["GridOptionsWrapper"].PROP_DOM_LAYOUT, spacerWidthsListener); + this.setFakeHScrollSpacerWidths(); + if (this.invisibleScrollbar) { + this.hideAndShowInvisibleScrollAsNeeded(); + this.addActiveListenerToggles(); } - return rowPinned === undefined ? null : { rowIndex: rowIndex, rowPinned: rowPinned }; + this.ctrlsService.registerFakeHScrollCtrl(this); }; - RowPositionUtils.prototype.getRowNode = function (gridRow) { - switch (gridRow.rowPinned) { - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP: - return this.pinnedRowModel.getPinnedTopRowData()[gridRow.rowIndex]; - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM: - return this.pinnedRowModel.getPinnedBottomRowData()[gridRow.rowIndex]; - default: - return this.rowModel.getRow(gridRow.rowIndex); - } + FakeHScrollCtrl.prototype.addActiveListenerToggles = function () { + var _this = this; + var activateEvents = ['mouseenter', 'mousedown', 'touchstart']; + var deactivateEvents = ['mouseleave', 'mouseup', 'touchend']; + activateEvents.forEach(function (eventName) { return _this.addManagedListener(_this.eGui, eventName, function () { return _this.view.addOrRemoveCssClass('ag-scrollbar-active', true); }); }); + deactivateEvents.forEach(function (eventName) { return _this.addManagedListener(_this.eGui, eventName, function () { return _this.view.addOrRemoveCssClass('ag-scrollbar-active', false); }); }); }; - RowPositionUtils.prototype.sameRow = function (rowA, rowB) { - // if both missing - if (!rowA && !rowB) { - return true; + FakeHScrollCtrl.prototype.postConstruct = function () { + this.enableRtl = this.gridOptionsWrapper.isEnableRtl(); + this.invisibleScrollbar = Object(_utils_browser__WEBPACK_IMPORTED_MODULE_1__["isInvisibleScrollbar"])(); + }; + FakeHScrollCtrl.prototype.onScrollVisibilityChanged = function () { + this.setScrollVisible(); + this.setFakeHScrollSpacerWidths(); + }; + FakeHScrollCtrl.prototype.hideAndShowInvisibleScrollAsNeeded = function () { + var _this = this; + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_BODY_SCROLL, function (params) { + if (params.direction === 'horizontal') { + _this.view.addOrRemoveCssClass('ag-scrollbar-scrolling', true); + } + }); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_BODY_SCROLL_END, function () { return _this.view.addOrRemoveCssClass('ag-scrollbar-scrolling', false); }); + }; + FakeHScrollCtrl.prototype.setFakeHScrollSpacerWidths = function () { + var vScrollShowing = this.scrollVisibleService.isVerticalScrollShowing(); + // we pad the right based on a) if cols are pinned to the right and + // b) if v scroll is showing on the right (normal position of scroll) + var rightSpacing = this.columnModel.getDisplayedColumnsRightWidth(); + var scrollOnRight = !this.enableRtl && vScrollShowing; + var scrollbarWidth = this.gridOptionsWrapper.getScrollbarWidth(); + if (scrollOnRight) { + rightSpacing += scrollbarWidth; } - // if only one missing - if ((rowA && !rowB) || (!rowA && rowB)) { - return false; + this.view.setRightSpacerFixedWidth(rightSpacing); + this.view.includeRightSpacerScrollerCss('ag-scroller-corner', rightSpacing <= scrollbarWidth); + // we pad the left based on a) if cols are pinned to the left and + // b) if v scroll is showing on the left (happens in LTR layout only) + var leftSpacing = this.columnModel.getDisplayedColumnsLeftWidth(); + var scrollOnLeft = this.enableRtl && vScrollShowing; + if (scrollOnLeft) { + leftSpacing += scrollbarWidth; } - // otherwise compare (use == to compare rowPinned because it can be null or undefined) - return rowA.rowIndex === rowB.rowIndex && rowA.rowPinned == rowB.rowPinned; + this.view.setLeftSpacerFixedWidth(leftSpacing); + this.view.includeLeftSpacerScrollerCss('ag-scroller-corner', leftSpacing <= scrollbarWidth); }; - // tests if this row selection is before the other row selection - RowPositionUtils.prototype.before = function (rowA, rowB) { - switch (rowA.rowPinned) { - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP: - // we we are floating top, and other isn't, then we are always before - if (rowB.rowPinned !== _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP) { - return true; - } - break; - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM: - // if we are floating bottom, and the other isn't, then we are never before - if (rowB.rowPinned !== _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM) { - return false; - } - break; - default: - // if we are not floating, but the other one is floating... - if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(rowB.rowPinned)) { - return rowB.rowPinned !== _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP; - } - break; - } - return rowA.rowIndex < rowB.rowIndex; + FakeHScrollCtrl.prototype.setScrollVisible = function () { + var hScrollShowing = this.scrollVisibleService.isHorizontalScrollShowing(); + var invisibleScrollbar = this.invisibleScrollbar; + var isSuppressHorizontalScroll = this.gridOptionsWrapper.isSuppressHorizontalScroll(); + var scrollbarWidth = hScrollShowing ? (this.gridOptionsWrapper.getScrollbarWidth() || 0) : 0; + var adjustedScrollbarWidth = (scrollbarWidth === 0 && invisibleScrollbar) ? 15 : scrollbarWidth; + var scrollContainerSize = !isSuppressHorizontalScroll ? adjustedScrollbarWidth : 0; + this.view.addOrRemoveCssClass('ag-scrollbar-invisible', invisibleScrollbar); + this.view.setHeight(scrollContainerSize); + this.view.setViewportHeight(scrollContainerSize); + this.view.setContainerHeight(scrollContainerSize); + }; + FakeHScrollCtrl.prototype.getViewport = function () { + return this.eViewport; + }; + FakeHScrollCtrl.prototype.getContainer = function () { + return this.eContainer; }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel') - ], RowPositionUtils.prototype, "rowModel", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('scrollVisibleService') + ], FakeHScrollCtrl.prototype, "scrollVisibleService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer') - ], RowPositionUtils.prototype, "rowRenderer", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnModel') + ], FakeHScrollCtrl.prototype, "columnModel", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('pinnedRowModel') - ], RowPositionUtils.prototype, "pinnedRowModel", void 0); - RowPositionUtils = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('rowPositionUtils') - ], RowPositionUtils); - return RowPositionUtils; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('ctrlsService') + ], FakeHScrollCtrl.prototype, "ctrlsService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] + ], FakeHScrollCtrl.prototype, "postConstruct", null); + return FakeHScrollCtrl; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 187 */ +/* 236 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellPositionUtils", function() { return CellPositionUtils; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PinnedWidthService", function() { return PinnedWidthService; }); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); +/* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(107); +/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(24); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(15); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -41966,48 +50110,70 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta }; -var CellPositionUtils = /** @class */ (function (_super) { - __extends(CellPositionUtils, _super); - function CellPositionUtils() { + + + +var PinnedWidthService = /** @class */ (function (_super) { + __extends(PinnedWidthService, _super); + function PinnedWidthService() { return _super !== null && _super.apply(this, arguments) || this; } - CellPositionUtils.prototype.createId = function (cellPosition) { - var rowIndex = cellPosition.rowIndex, rowPinned = cellPosition.rowPinned, column = cellPosition.column; - return this.createIdFromValues(rowIndex, column, rowPinned); + PinnedWidthService.prototype.postConstruct = function () { + var listener = this.checkContainerWidths.bind(this); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, listener); + this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, listener); + this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__["GridOptionsWrapper"].PROP_DOM_LAYOUT, listener); + }; + PinnedWidthService.prototype.checkContainerWidths = function () { + var printLayout = this.gridOptionsWrapper.getDomLayout() === _constants_constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].DOM_LAYOUT_PRINT; + var newLeftWidth = printLayout ? 0 : this.columnModel.getDisplayedColumnsLeftWidth(); + var newRightWidth = printLayout ? 0 : this.columnModel.getDisplayedColumnsRightWidth(); + if (newLeftWidth != this.leftWidth) { + this.leftWidth = newLeftWidth; + this.eventService.dispatchEvent({ type: _eventKeys__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_LEFT_PINNED_WIDTH_CHANGED }); + } + if (newRightWidth != this.rightWidth) { + this.rightWidth = newRightWidth; + this.eventService.dispatchEvent({ type: _eventKeys__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_RIGHT_PINNED_WIDTH_CHANGED }); + } }; - CellPositionUtils.prototype.createIdFromValues = function (rowIndex, column, rowPinned) { - return rowIndex + "." + (rowPinned == null ? 'null' : rowPinned) + "." + column.getId(); + PinnedWidthService.prototype.getPinnedRightWidth = function () { + return this.rightWidth; }; - CellPositionUtils.prototype.equals = function (cellA, cellB) { - var colsMatch = cellA.column === cellB.column; - var floatingMatch = cellA.rowPinned === cellB.rowPinned; - var indexMatch = cellA.rowIndex === cellB.rowIndex; - return colsMatch && floatingMatch && indexMatch; + PinnedWidthService.prototype.getPinnedLeftWidth = function () { + return this.leftWidth; }; - CellPositionUtils = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('cellPositionUtils') - ], CellPositionUtils); - return CellPositionUtils; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnModel') + ], PinnedWidthService.prototype, "columnModel", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] + ], PinnedWidthService.prototype, "postConstruct", null); + PinnedWidthService = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('pinnedWidthService') + ], PinnedWidthService); + return PinnedWidthService; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 188 */ +/* 237 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PinnedRowModel", function() { return PinnedRowModel; }); -/* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(68); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(41); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowContainerComp", function() { return RowContainerComp; }); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); +/* harmony import */ var _rowContainerCtrl__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(125); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(42); +/* harmony import */ var _rendering_row_rowComp__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(238); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(13); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -42024,6 +50190,17 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); +var __assign = (undefined && undefined.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); @@ -42036,159 +50213,136 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var PinnedRowModel = /** @class */ (function (_super) { - __extends(PinnedRowModel, _super); - function PinnedRowModel() { - return _super !== null && _super.apply(this, arguments) || this; + +function templateFactory() { + var name = _widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"].elementGettingCreated.getAttribute('name'); + var cssClasses = _rowContainerCtrl__WEBPACK_IMPORTED_MODULE_3__["RowContainerCtrl"].getRowContainerCssClasses(name); + var res; + var template1 = name === _rowContainerCtrl__WEBPACK_IMPORTED_MODULE_3__["RowContainerName"].CENTER; + var template2 = name === _rowContainerCtrl__WEBPACK_IMPORTED_MODULE_3__["RowContainerName"].TOP_CENTER || name === _rowContainerCtrl__WEBPACK_IMPORTED_MODULE_3__["RowContainerName"].BOTTOM_CENTER; + if (template1) { + res = /* html */ + "
\n
\n
\n
\n
"; } - PinnedRowModel.prototype.init = function () { - this.setPinnedTopRowData(this.gridOptionsWrapper.getPinnedTopRowData()); - this.setPinnedBottomRowData(this.gridOptionsWrapper.getPinnedBottomRowData()); - }; - PinnedRowModel.prototype.isEmpty = function (floating) { - var rows = floating === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP ? this.pinnedTopRows : this.pinnedBottomRows; - return _utils__WEBPACK_IMPORTED_MODULE_4__["_"].missingOrEmpty(rows); + else if (template2) { + res = /* html */ + "
\n
\n
"; + } + else { + res = /* html */ + "
"; + } + return res; +} +var RowContainerComp = /** @class */ (function (_super) { + __extends(RowContainerComp, _super); + function RowContainerComp() { + var _this = _super.call(this, templateFactory()) || this; + _this.rowComps = {}; + _this.name = _widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"].elementGettingCreated.getAttribute('name'); + _this.type = Object(_rowContainerCtrl__WEBPACK_IMPORTED_MODULE_3__["getRowContainerTypeForName"])(_this.name); + return _this; + } + RowContainerComp.prototype.postConstruct = function () { + var _this = this; + var compProxy = { + setViewportHeight: function (height) { return _this.eViewport.style.height = height; }, + setRowCtrls: function (rowCtrls) { return _this.setRowCtrls(rowCtrls); }, + setDomOrder: function (domOrder) { + _this.domOrder = domOrder; + }, + setContainerWidth: function (width) { return _this.eContainer.style.width = width; } + }; + var ctrl = this.createManagedBean(new _rowContainerCtrl__WEBPACK_IMPORTED_MODULE_3__["RowContainerCtrl"](this.name)); + ctrl.setComp(compProxy, this.eContainer, this.eViewport, this.eWrapper); }; - PinnedRowModel.prototype.isRowsToRender = function (floating) { - return !this.isEmpty(floating); + RowContainerComp.prototype.preDestroy = function () { + // destroys all row comps + this.setRowCtrls([]); }; - PinnedRowModel.prototype.getRowAtPixel = function (pixel, floating) { - var rows = floating === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP ? this.pinnedTopRows : this.pinnedBottomRows; - if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].missingOrEmpty(rows)) { - return 0; // this should never happen, just in case, 0 is graceful failure - } - for (var i = 0; i < rows.length; i++) { - var rowNode = rows[i]; - var rowTopPixel = rowNode.rowTop + rowNode.rowHeight - 1; - // only need to range check against the top pixel, as we are going through the list - // in order, first row to hit the pixel wins - if (rowTopPixel >= pixel) { - return i; + RowContainerComp.prototype.setRowCtrls = function (rowCtrls) { + var _this = this; + var oldRows = __assign({}, this.rowComps); + this.rowComps = {}; + this.lastPlacedElement = null; + var processRow = function (rowCon) { + var instanceId = rowCon.getInstanceId(); + var existingRowComp = oldRows[instanceId]; + if (existingRowComp) { + _this.rowComps[instanceId] = existingRowComp; + delete oldRows[instanceId]; + _this.ensureDomOrder(existingRowComp.getGui()); + } + else { + var rowComp = _this.newRowComp(rowCon); + _this.rowComps[instanceId] = rowComp; + _this.appendRow(rowComp.getGui()); } - } - return rows.length - 1; - }; - PinnedRowModel.prototype.setPinnedTopRowData = function (rowData) { - this.pinnedTopRows = this.createNodesFromData(rowData, true); - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_PINNED_ROW_DATA_CHANGED, - api: this.gridApi, - columnApi: this.columnApi - }; - this.eventService.dispatchEvent(event); - }; - PinnedRowModel.prototype.setPinnedBottomRowData = function (rowData) { - this.pinnedBottomRows = this.createNodesFromData(rowData, false); - var event = { - type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_PINNED_ROW_DATA_CHANGED, - api: this.gridApi, - columnApi: this.columnApi }; - this.eventService.dispatchEvent(event); + rowCtrls.forEach(processRow); + Object(_utils_object__WEBPACK_IMPORTED_MODULE_6__["getAllValuesInObject"])(oldRows).forEach(function (oldRowComp) { + _this.eContainer.removeChild(oldRowComp.getGui()); + oldRowComp.destroy(); + }); }; - PinnedRowModel.prototype.createNodesFromData = function (allData, isTop) { - var _this = this; - var rowNodes = []; - if (allData) { - var nextRowTop_1 = 0; - allData.forEach(function (dataItem, index) { - var rowNode = new _entities_rowNode__WEBPACK_IMPORTED_MODULE_0__["RowNode"](); - _this.context.createBean(rowNode); - rowNode.data = dataItem; - var idPrefix = isTop ? _entities_rowNode__WEBPACK_IMPORTED_MODULE_0__["RowNode"].ID_PREFIX_TOP_PINNED : _entities_rowNode__WEBPACK_IMPORTED_MODULE_0__["RowNode"].ID_PREFIX_BOTTOM_PINNED; - rowNode.id = idPrefix + index; - rowNode.rowPinned = isTop ? _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP : _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_BOTTOM; - rowNode.setRowTop(nextRowTop_1); - rowNode.setRowHeight(_this.gridOptionsWrapper.getRowHeightForNode(rowNode).height); - rowNode.setRowIndex(index); - nextRowTop_1 += rowNode.rowHeight; - rowNodes.push(rowNode); - }); + RowContainerComp.prototype.appendRow = function (element) { + if (this.domOrder) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["insertWithDomOrder"])(this.eContainer, element, this.lastPlacedElement); } - return rowNodes; - }; - PinnedRowModel.prototype.getPinnedTopRowData = function () { - return this.pinnedTopRows; - }; - PinnedRowModel.prototype.getPinnedBottomRowData = function () { - return this.pinnedBottomRows; - }; - PinnedRowModel.prototype.getPinnedTopTotalHeight = function () { - return this.getTotalHeight(this.pinnedTopRows); - }; - PinnedRowModel.prototype.getPinnedTopRowCount = function () { - return this.pinnedTopRows ? this.pinnedTopRows.length : 0; - }; - PinnedRowModel.prototype.getPinnedBottomRowCount = function () { - return this.pinnedBottomRows ? this.pinnedBottomRows.length : 0; - }; - PinnedRowModel.prototype.getPinnedTopRow = function (index) { - return this.pinnedTopRows[index]; - }; - PinnedRowModel.prototype.getPinnedBottomRow = function (index) { - return this.pinnedBottomRows[index]; - }; - PinnedRowModel.prototype.forEachPinnedTopRow = function (callback) { - if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].missingOrEmpty(this.pinnedTopRows)) { - return; + else { + this.eContainer.appendChild(element); } - this.pinnedTopRows.forEach(callback); + this.lastPlacedElement = element; }; - PinnedRowModel.prototype.forEachPinnedBottomRow = function (callback) { - if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].missingOrEmpty(this.pinnedBottomRows)) { - return; + RowContainerComp.prototype.ensureDomOrder = function (eRow) { + if (this.domOrder) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["ensureDomOrder"])(this.eContainer, eRow, this.lastPlacedElement); + this.lastPlacedElement = eRow; } - this.pinnedBottomRows.forEach(callback); }; - PinnedRowModel.prototype.getPinnedBottomTotalHeight = function () { - return this.getTotalHeight(this.pinnedBottomRows); - }; - PinnedRowModel.prototype.getTotalHeight = function (rowNodes) { - if (!rowNodes || rowNodes.length === 0) { - return 0; - } - else { - var lastNode = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].last(rowNodes); - return lastNode.rowTop + lastNode.rowHeight; - } + RowContainerComp.prototype.newRowComp = function (rowCtrl) { + var pinned = _rowContainerCtrl__WEBPACK_IMPORTED_MODULE_3__["RowContainerCtrl"].getPinned(this.name); + var res = new _rendering_row_rowComp__WEBPACK_IMPORTED_MODULE_5__["RowComp"](rowCtrl, this.beans, this.type); + return res; }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper') - ], PinnedRowModel.prototype, "gridOptionsWrapper", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('beans') + ], RowContainerComp.prototype, "beans", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnApi') - ], PinnedRowModel.prototype, "columnApi", void 0); + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eViewport') + ], RowContainerComp.prototype, "eViewport", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridApi') - ], PinnedRowModel.prototype, "gridApi", void 0); + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eContainer') + ], RowContainerComp.prototype, "eContainer", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eWrapper') + ], RowContainerComp.prototype, "eWrapper", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"] - ], PinnedRowModel.prototype, "init", null); - PinnedRowModel = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('pinnedRowModel') - ], PinnedRowModel); - return PinnedRowModel; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_5__["BeanStub"])); + _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] + ], RowContainerComp.prototype, "postConstruct", null); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_2__["PreDestroy"] + ], RowContainerComp.prototype, "preDestroy", null); + return RowContainerComp; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); /***/ }), -/* 189 */ +/* 238 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UndoRedoService", function() { return UndoRedoService; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(44); -/* harmony import */ var _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(190); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25); -/* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(38); -/* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(39); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(41); -/** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowComp", function() { return RowComp; }); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(42); +/* harmony import */ var _cell_cellComp__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(239); +/* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(13); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(44); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -42205,264 +50359,160 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - - -var UndoRedoService = /** @class */ (function (_super) { - __extends(UndoRedoService, _super); - function UndoRedoService() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.cellValueChanges = []; - _this.isCellEditing = false; - _this.isRowEditing = false; - _this.isPasting = false; - _this.isFilling = false; - _this.onCellValueChanged = function (event) { - var shouldCaptureAction = _this.isCellEditing || _this.isRowEditing || _this.isPasting || _this.isFilling; - if (!shouldCaptureAction) { - return; - } - var rowPinned = event.rowPinned, rowIndex = event.rowIndex, column = event.column, oldValue = event.oldValue, value = event.value; - var cellValueChange = { - rowPinned: rowPinned, - rowIndex: rowIndex, - columnId: column.getColId(), - oldValue: oldValue, - newValue: value - }; - _this.cellValueChanges.push(cellValueChange); - }; - _this.clearStacks = function () { - _this.undoStack.clear(); - _this.redoStack.clear(); +var RowComp = /** @class */ (function (_super) { + __extends(RowComp, _super); + function RowComp(ctrl, beans, containerType) { + var _this = _super.call(this) || this; + _this.cellComps = {}; + _this.beans = beans; + _this.rowCtrl = ctrl; + _this.setTemplate(/* html */ "
"); + var eGui = _this.getGui(); + var style = eGui.style; + var compProxy = { + setDomOrder: function (domOrder) { return _this.domOrder = domOrder; }, + setCellCtrls: function (cellCtrls) { return _this.setCellCtrls(cellCtrls); }, + showFullWidth: function (compDetails) { return _this.showFullWidth(compDetails); }, + getFullWidthCellRenderer: function () { return _this.getFullWidthCellRenderer(); }, + addOrRemoveCssClass: function (name, on) { return _this.addOrRemoveCssClass(name, on); }, + setUserStyles: function (styles) { return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["addStylesToElement"])(eGui, styles); }, + setTop: function (top) { return style.top = top; }, + setTransform: function (transform) { return style.transform = transform; }, + setRowIndex: function (rowIndex) { return eGui.setAttribute('row-index', rowIndex); }, + setRole: function (role) { return Object(_utils_aria__WEBPACK_IMPORTED_MODULE_4__["setAriaRole"])(eGui, role); }, + setRowId: function (rowId) { return eGui.setAttribute('row-id', rowId); }, + setRowBusinessKey: function (businessKey) { return eGui.setAttribute('row-business-key', businessKey); }, + setTabIndex: function (tabIndex) { return eGui.setAttribute('tabindex', tabIndex.toString()); } }; + ctrl.setComp(compProxy, _this.getGui(), containerType); return _this; } - UndoRedoService.prototype.init = function () { - if (!this.gridOptionsWrapper.isUndoRedoCellEditing()) { - return; - } - var undoRedoLimit = this.gridOptionsWrapper.getUndoRedoCellEditingLimit(); - if (undoRedoLimit <= 0) { - return; - } - this.undoStack = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["UndoRedoStack"](undoRedoLimit); - this.redoStack = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["UndoRedoStack"](undoRedoLimit); - this.addRowEditingListeners(); - this.addCellEditingListeners(); - this.addPasteListeners(); - this.addFillListeners(); - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_VALUE_CHANGED, this.onCellValueChanged); - // undo / redo is restricted to actual editing so we clear the stacks when other operations are - // performed that change the order of the row / cols. - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_MODEL_UPDATED, this.clearStacks); - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_PIVOT_MODE_CHANGED, this.clearStacks); - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_EVERYTHING_CHANGED, this.clearStacks); - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_GROUP_OPENED, this.clearStacks); - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, this.clearStacks); - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_MOVED, this.clearStacks); - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_PINNED, this.clearStacks); - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_VISIBLE, this.clearStacks); - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_ROW_DRAG_END, this.clearStacks); - }; - UndoRedoService.prototype.undo = function () { - if (!this.undoStack) { - return; - } - var undoAction = this.undoStack.pop(); - if (!undoAction || !undoAction.cellValueChanges) { - return; - } - this.processAction(undoAction, function (cellValueChange) { return cellValueChange.oldValue; }); - if (undoAction instanceof _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["FillUndoRedoAction"]) { - this.processRangeAndCellFocus(undoAction.cellValueChanges, undoAction.initialRange); - } - else { - this.processRangeAndCellFocus(undoAction.cellValueChanges); - } - this.redoStack.push(undoAction); + RowComp.prototype.getInitialStyle = function () { + var transform = this.rowCtrl.getInitialTransform(); + var top = this.rowCtrl.getInitialRowTop(); + return transform ? "transform: " + transform : "top: " + top; }; - UndoRedoService.prototype.redo = function () { - if (!this.redoStack) { - return; - } - var redoAction = this.redoStack.pop(); - if (!redoAction || !redoAction.cellValueChanges) { + RowComp.prototype.showFullWidth = function (compDetails) { + var _this = this; + var callback = function (cellRenderer) { + if (_this.isAlive()) { + var eGui = cellRenderer.getGui(); + _this.getGui().appendChild(eGui); + _this.rowCtrl.setupDetailRowAutoHeight(eGui); + _this.setFullWidthRowComp(cellRenderer); + } + else { + _this.beans.context.destroyBean(cellRenderer); + } + }; + // if not in cache, create new one + var res = compDetails.newAgStackInstance(); + if (!res) { return; } - this.processAction(redoAction, function (cellValueChange) { return cellValueChange.newValue; }); - if (redoAction instanceof _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["FillUndoRedoAction"]) { - this.processRangeAndCellFocus(redoAction.cellValueChanges, redoAction.finalRange); - } - else { - this.processRangeAndCellFocus(redoAction.cellValueChanges); - } - this.undoStack.push(redoAction); + res.then(callback); }; - UndoRedoService.prototype.processAction = function (action, valueExtractor) { + RowComp.prototype.setCellCtrls = function (cellCtrls) { var _this = this; - action.cellValueChanges.forEach(function (cellValueChange) { - var rowIndex = cellValueChange.rowIndex, rowPinned = cellValueChange.rowPinned, columnId = cellValueChange.columnId; - var rowPosition = { rowIndex: rowIndex, rowPinned: rowPinned }; - var currentRow = _this.getRowNode(rowPosition); - // checks if the row has been filtered out - if (currentRow.rowTop == null) { - return; + var cellsToRemove = Object.assign({}, this.cellComps); + cellCtrls.forEach(function (cellCtrl) { + var key = cellCtrl.getInstanceId(); + var existingCellComp = _this.cellComps[key]; + if (existingCellComp == null) { + _this.newCellComp(cellCtrl); + } + else { + cellsToRemove[key] = null; } - currentRow.setDataValue(columnId, valueExtractor(cellValueChange)); }); + var cellCompsToRemove = Object(_utils_object__WEBPACK_IMPORTED_MODULE_3__["getAllValuesInObject"])(cellsToRemove) + .filter(function (cellComp) { return cellComp != null; }); + this.destroyCells(cellCompsToRemove); + this.ensureDomOrder(cellCtrls); }; - UndoRedoService.prototype.processRangeAndCellFocus = function (cellValueChanges, range) { - if (range) { - var startRow = range.startRow; - var endRow = range.endRow; - var lastFocusedCell_1 = { - rowPinned: startRow.rowPinned, - rowIndex: startRow.rowIndex, - columnId: range.startColumn.getColId() - }; - this.setLastFocusedCell(lastFocusedCell_1); - var cellRangeParams = { - rowStartIndex: startRow.rowIndex, - rowStartPinned: startRow.rowPinned, - rowEndIndex: endRow.rowIndex, - rowEndPinned: endRow.rowPinned, - columnStart: range.startColumn, - columns: range.columns - }; - this.gridApi.addCellRange(cellRangeParams); + RowComp.prototype.ensureDomOrder = function (cellCtrls) { + var _this = this; + if (!this.domOrder) { return; } - var cellValueChange = cellValueChanges[0]; - var rowIndex = cellValueChange.rowIndex, rowPinned = cellValueChange.rowPinned; - var rowPosition = { rowIndex: rowIndex, rowPinned: rowPinned }; - var row = this.getRowNode(rowPosition); - var lastFocusedCell = { - rowPinned: cellValueChange.rowPinned, - rowIndex: row.rowIndex, - columnId: cellValueChange.columnId - }; - this.setLastFocusedCell(lastFocusedCell); + var elementsInOrder = []; + cellCtrls.forEach(function (cellCtrl) { + var cellComp = _this.cellComps[cellCtrl.getInstanceId()]; + if (cellComp) { + elementsInOrder.push(cellComp.getGui()); + } + }); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["setDomChildOrder"])(this.getGui(), elementsInOrder); }; - UndoRedoService.prototype.setLastFocusedCell = function (lastFocusedCell) { - var rowIndex = lastFocusedCell.rowIndex, columnId = lastFocusedCell.columnId, rowPinned = lastFocusedCell.rowPinned; - this.gridApi.ensureIndexVisible(rowIndex); - this.gridApi.ensureColumnVisible(columnId); - if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].RangeSelectionModule)) { - this.gridApi.clearRangeSelection(); - } - this.focusController.setFocusedCell(rowIndex, columnId, rowPinned, true); + RowComp.prototype.newCellComp = function (cellCtrl) { + var cellComp = new _cell_cellComp__WEBPACK_IMPORTED_MODULE_2__["CellComp"](this.rowCtrl.getScope(), this.beans, cellCtrl, this.rowCtrl.isPrintLayout(), this.getGui(), this.rowCtrl.isEditing()); + this.cellComps[cellCtrl.getInstanceId()] = cellComp; + this.getGui().appendChild(cellComp.getGui()); }; - UndoRedoService.prototype.addRowEditingListeners = function () { - var _this = this; - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_ROW_EDITING_STARTED, function () { - _this.isRowEditing = true; - }); - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_ROW_EDITING_STOPPED, function () { - var action = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["UndoRedoAction"](_this.cellValueChanges); - _this.pushActionsToUndoStack(action); - _this.isRowEditing = false; - }); + RowComp.prototype.destroy = function () { + _super.prototype.destroy.call(this); + this.destroyAllCells(); }; - UndoRedoService.prototype.addCellEditingListeners = function () { - var _this = this; - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_EDITING_STARTED, function () { - _this.isCellEditing = true; - }); - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_EDITING_STOPPED, function () { - _this.isCellEditing = false; - var shouldPushAction = !_this.isRowEditing && !_this.isPasting && !_this.isFilling; - if (shouldPushAction) { - var action = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["UndoRedoAction"](_this.cellValueChanges); - _this.pushActionsToUndoStack(action); - } - }); + RowComp.prototype.destroyAllCells = function () { + var cellsToDestroy = Object(_utils_object__WEBPACK_IMPORTED_MODULE_3__["getAllValuesInObject"])(this.cellComps).filter(function (cp) { return cp != null; }); + this.destroyCells(cellsToDestroy); }; - UndoRedoService.prototype.addPasteListeners = function () { + RowComp.prototype.setFullWidthRowComp = function (fullWidthRowComponent) { var _this = this; - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_PASTE_START, function () { - _this.isPasting = true; - }); - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_PASTE_END, function () { - var action = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["UndoRedoAction"](_this.cellValueChanges); - _this.pushActionsToUndoStack(action); - _this.isPasting = false; + if (this.fullWidthCellRenderer) { + console.error('AG Grid - should not be setting fullWidthRowComponent twice'); + } + this.fullWidthCellRenderer = fullWidthRowComponent; + this.addDestroyFunc(function () { + _this.fullWidthCellRenderer = _this.beans.context.destroyBean(_this.fullWidthCellRenderer); }); }; - UndoRedoService.prototype.addFillListeners = function () { + RowComp.prototype.getFullWidthCellRenderer = function () { + return this.fullWidthCellRenderer; + }; + RowComp.prototype.destroyCells = function (cellComps) { var _this = this; - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_FILL_START, function () { - _this.isFilling = true; - }); - this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_FILL_END, function (event) { - var action = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["FillUndoRedoAction"](_this.cellValueChanges, event.initialRange, event.finalRange); - _this.pushActionsToUndoStack(action); - _this.isFilling = false; + cellComps.forEach(function (cellComp) { + // could be old reference, ie removed cell + if (!cellComp) { + return; + } + // check cellComp belongs in this container + var instanceId = cellComp.getCtrl().getInstanceId(); + if (_this.cellComps[instanceId] !== cellComp) { + return; + } + cellComp.detach(); + cellComp.destroy(); + _this.cellComps[instanceId] = null; }); }; - UndoRedoService.prototype.pushActionsToUndoStack = function (action) { - this.undoStack.push(action); - this.cellValueChanges = []; - this.redoStack.clear(); - }; - UndoRedoService.prototype.getRowNode = function (gridRow) { - switch (gridRow.rowPinned) { - case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP: - return this.pinnedRowModel.getPinnedTopRowData()[gridRow.rowIndex]; - case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_BOTTOM: - return this.pinnedRowModel.getPinnedBottomRowData()[gridRow.rowIndex]; - default: - return this.rowModel.getRow(gridRow.rowIndex); - } - }; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], UndoRedoService.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusController') - ], UndoRedoService.prototype, "focusController", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') - ], UndoRedoService.prototype, "gridApi", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel') - ], UndoRedoService.prototype, "rowModel", void 0); - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('pinnedRowModel') - ], UndoRedoService.prototype, "pinnedRowModel", void 0); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], UndoRedoService.prototype, "init", null); - UndoRedoService = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('undoRedoService') - ], UndoRedoService); - return UndoRedoService; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_6__["BeanStub"])); + return RowComp; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); /***/ }), -/* 190 */ +/* 239 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UndoRedoAction", function() { return UndoRedoAction; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FillUndoRedoAction", function() { return FillUndoRedoAction; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UndoRedoStack", function() { return UndoRedoStack; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellComp", function() { return CellComp; }); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36); +/* harmony import */ var _cellEditors_popupEditorWrapper__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(240); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(44); +/* harmony import */ var _utils_string__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(26); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(42); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -42479,64 +50529,509 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var UndoRedoAction = /** @class */ (function () { - function UndoRedoAction(cellValueChanges) { - this.cellValueChanges = cellValueChanges; - } - return UndoRedoAction; -}()); +var __assign = (undefined && undefined.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; -var FillUndoRedoAction = /** @class */ (function (_super) { - __extends(FillUndoRedoAction, _super); - function FillUndoRedoAction(cellValueChanges, initialRange, finalRange) { - var _this = _super.call(this, cellValueChanges) || this; - _this.initialRange = initialRange; - _this.finalRange = finalRange; - return _this; - } - return FillUndoRedoAction; -}(UndoRedoAction)); -var UndoRedoStack = /** @class */ (function () { - function UndoRedoStack(maxStackSize) { - this.actionStack = []; - this.maxStackSize = maxStackSize ? maxStackSize : UndoRedoStack.DEFAULT_STACK_SIZE; - this.actionStack = new Array(this.maxStackSize); + + + + +var CellComp = /** @class */ (function (_super) { + __extends(CellComp, _super); + function CellComp(scope, beans, cellCtrl, printLayout, eRow, editingRow) { + var _this = _super.call(this) || this; + _this.scope = null; + // every time we go into edit mode, or back again, this gets incremented. + // it's the components way of dealing with the async nature of framework components, + // so if a framework component takes a while to be created, we know if the object + // is still relevant when creating is finished. eg we could click edit / un-edit 20 + // times before the first React edit component comes back - we should discard + // the first 19. + _this.rendererVersion = 0; + _this.editorVersion = 0; + _this.scope = scope; + _this.beans = beans; + _this.column = cellCtrl.getColumn(); + _this.rowNode = cellCtrl.getRowNode(); + _this.rowCtrl = cellCtrl.getRowCtrl(); + _this.eRow = eRow; + _this.setTemplate(/* html */ "
"); + var eGui = _this.getGui(); + _this.forceWrapper = cellCtrl.isForceWrapper(); + _this.refreshWrapper(false); + var setAttribute = function (name, value, element) { + var actualElement = element ? element : eGui; + if (value != null && value != '') { + actualElement.setAttribute(name, value); + } + else { + actualElement.removeAttribute(name); + } + }; + var compProxy = { + addOrRemoveCssClass: function (cssClassName, on) { return _this.addOrRemoveCssClass(cssClassName, on); }, + setUserStyles: function (styles) { return Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["addStylesToElement"])(eGui, styles); }, + getFocusableElement: function () { return _this.getFocusableElement(); }, + setTabIndex: function (tabIndex) { return setAttribute('tabindex', tabIndex.toString()); }, + setRole: function (role) { return Object(_utils_aria__WEBPACK_IMPORTED_MODULE_2__["setAriaRole"])(eGui, role); }, + setColId: function (colId) { return setAttribute('col-id', colId); }, + setTitle: function (title) { return setAttribute('title', title); }, + setIncludeSelection: function (include) { return _this.includeSelection = include; }, + setIncludeRowDrag: function (include) { return _this.includeRowDrag = include; }, + setIncludeDndSource: function (include) { return _this.includeDndSource = include; }, + setRenderDetails: function (compDetails, valueToDisplay, force) { + return _this.setRenderDetails(compDetails, valueToDisplay, force); + }, + setEditDetails: function (compDetails, popup, position) { + return _this.setEditDetails(compDetails, popup, position); + }, + getCellEditor: function () { return _this.cellEditor || null; }, + getCellRenderer: function () { return _this.cellRenderer || null; }, + getParentOfValue: function () { return _this.getParentOfValue(); } + }; + _this.cellCtrl = cellCtrl; + cellCtrl.setComp(compProxy, _this.scope, _this.getGui(), _this.eCellWrapper, printLayout, editingRow); + return _this; } - UndoRedoStack.prototype.pop = function () { - return this.actionStack.pop(); + CellComp.prototype.getParentOfValue = function () { + if (this.eCellValue) { + // if not editing, and using wrapper, then value goes in eCellValue + return this.eCellValue; + } + if (this.eCellWrapper) { + // if editing, and using wrapper, value (cell editor) goes in eCellWrapper + return this.eCellWrapper; + } + // if editing or rendering, and not using wrapper, value (or comp) is directly inside cell + return this.getGui(); }; - UndoRedoStack.prototype.push = function (item) { - var shouldAddActions = item.cellValueChanges && item.cellValueChanges.length > 0; - if (!shouldAddActions) { + CellComp.prototype.setRenderDetails = function (compDetails, valueToDisplay, forceNewCellRendererInstance) { + // this can happen if the users asks for the cell to refresh, but we are not showing the vale as we are editing + var isInlineEditing = this.cellEditor && !this.cellEditorPopupWrapper; + if (isInlineEditing) { return; } - if (this.actionStack.length === this.maxStackSize) { - this.actionStack.shift(); + // this means firstRender will be true for one pass only, as it's initialised to undefined + this.firstRender = this.firstRender == null; + var usingAngular1Template = this.isUsingAngular1Template(); + // if display template has changed, means any previous Cell Renderer is in the wrong location + var controlWrapperChanged = this.refreshWrapper(false); + // all of these have dependencies on the eGui, so only do them after eGui is set + if (compDetails) { + var neverRefresh = forceNewCellRendererInstance || controlWrapperChanged; + var cellRendererRefreshSuccessful = neverRefresh ? false : this.refreshCellRenderer(compDetails); + if (!cellRendererRefreshSuccessful) { + this.destroyRenderer(); + this.createCellRendererInstance(compDetails); + } + } + else { + this.destroyRenderer(); + if (usingAngular1Template) { + this.insertValueUsingAngular1Template(); + } + else { + this.insertValueWithoutCellRenderer(valueToDisplay); + } } - this.actionStack.push(item); }; - UndoRedoStack.prototype.clear = function () { - this.actionStack = []; + CellComp.prototype.setEditDetails = function (compDetails, popup, position) { + if (compDetails) { + this.createCellEditorInstance(compDetails, popup, position); + } + else { + this.destroyEditor(); + } + }; + CellComp.prototype.removeControls = function () { + this.checkboxSelectionComp = this.beans.context.destroyBean(this.checkboxSelectionComp); + this.dndSourceComp = this.beans.context.destroyBean(this.dndSourceComp); + this.rowDraggingComp = this.beans.context.destroyBean(this.rowDraggingComp); + }; + // returns true if wrapper was changed + CellComp.prototype.refreshWrapper = function (editing) { + var providingControls = this.includeRowDrag || this.includeDndSource || this.includeSelection; + var usingWrapper = providingControls || this.forceWrapper; + var putWrapperIn = usingWrapper && this.eCellWrapper == null; + if (putWrapperIn) { + this.eCellWrapper = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["loadTemplate"])("
"); + this.getGui().appendChild(this.eCellWrapper); + } + var takeWrapperOut = !usingWrapper && this.eCellWrapper != null; + if (takeWrapperOut) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["removeFromParent"])(this.eCellWrapper); + this.eCellWrapper = undefined; + } + this.addOrRemoveCssClass('ag-cell-value', !usingWrapper); + var usingCellValue = !editing && usingWrapper; + var putCellValueIn = usingCellValue && this.eCellValue == null; + if (putCellValueIn) { + this.eCellValue = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["loadTemplate"])(""); + this.eCellWrapper.appendChild(this.eCellValue); + } + var takeCellValueOut = !usingCellValue && this.eCellValue != null; + if (takeCellValueOut) { + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["removeFromParent"])(this.eCellValue); + this.eCellValue = undefined; + } + var templateChanged = putWrapperIn || takeWrapperOut || putCellValueIn || takeCellValueOut; + if (templateChanged) { + this.removeControls(); + } + if (!editing && providingControls) { + this.addControls(); + } + return templateChanged; + }; + CellComp.prototype.addControls = function () { + var id = this.eCellValue.id = "cell-" + this.getCompId(); + var describedByIds = []; + if (this.includeRowDrag) { + if (this.rowDraggingComp == null) { + this.rowDraggingComp = this.cellCtrl.createRowDragComp(); + if (this.rowDraggingComp) { + // put the checkbox in before the value + this.eCellWrapper.insertBefore(this.rowDraggingComp.getGui(), this.eCellValue); + } + } + } + if (this.includeDndSource) { + if (this.dndSourceComp == null) { + this.dndSourceComp = this.cellCtrl.createDndSource(); + // put the checkbox in before the value + this.eCellWrapper.insertBefore(this.dndSourceComp.getGui(), this.eCellValue); + } + } + if (this.includeSelection) { + if (this.checkboxSelectionComp == null) { + this.checkboxSelectionComp = this.cellCtrl.createSelectionCheckbox(); + this.eCellWrapper.insertBefore(this.checkboxSelectionComp.getGui(), this.eCellValue); + } + describedByIds.push(this.checkboxSelectionComp.getCheckboxId()); + } + describedByIds.push(id); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_2__["setAriaDescribedBy"])(this.getGui(), describedByIds.join(' ')); }; - UndoRedoStack.DEFAULT_STACK_SIZE = 10; - return UndoRedoStack; -}()); + CellComp.prototype.createCellEditorInstance = function (compDetails, popup, position) { + var _this = this; + var versionCopy = this.editorVersion; + var cellEditorPromise = compDetails.newAgStackInstance(); + if (!cellEditorPromise) { + return; + } // if empty, userComponentFactory already did a console message + var params = compDetails.params; + cellEditorPromise.then(function (c) { return _this.afterCellEditorCreated(versionCopy, c, params, popup, position); }); + // if we don't do this, and editor component is async, then there will be a period + // when the component isn't present and keyboard navigation won't work - so example + // of user hitting tab quickly (more quickly than renderers getting created) won't work + var cellEditorAsync = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_4__["missing"])(this.cellEditor); + if (cellEditorAsync && params.cellStartedEdit) { + this.cellCtrl.focusCell(true); + } + }; + CellComp.prototype.insertValueWithoutCellRenderer = function (valueToDisplay) { + var eParent = this.getParentOfValue(); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["clearElement"])(eParent); + var escapedValue = valueToDisplay != null ? Object(_utils_string__WEBPACK_IMPORTED_MODULE_3__["escapeString"])(valueToDisplay) : null; + if (escapedValue != null) { + eParent.innerHTML = escapedValue; + } + }; + CellComp.prototype.insertValueUsingAngular1Template = function () { + var _this = this; + var _a = this.column.getColDef(), template = _a.template, templateUrl = _a.templateUrl; + var templateToInsert; + if (template != null) { + templateToInsert = template; + } + else if (templateUrl != null) { + // first time this happens it will return nothing, as the template will still be loading async, + // however once loaded it will refresh the cell and second time around it will be returned sync + // as in cache. + templateToInsert = this.beans.templateService.getTemplate(templateUrl, function () { return _this.cellCtrl.refreshCell({ forceRefresh: true }); }); + } + else { + // should never happen, as we only enter this method when template or templateUrl exist + } + if (templateToInsert != null) { + var eParent = this.getParentOfValue(); + eParent.innerHTML = templateToInsert; + this.updateAngular1ScopeAndCompile(); + } + }; + CellComp.prototype.destroyEditorAndRenderer = function () { + this.destroyRenderer(); + this.destroyEditor(); + }; + CellComp.prototype.destroyRenderer = function () { + var context = this.beans.context; + this.cellRenderer = context.destroyBean(this.cellRenderer); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["removeFromParent"])(this.cellRendererGui); + this.cellRendererGui = null; + this.rendererVersion++; + }; + CellComp.prototype.destroyEditor = function () { + var context = this.beans.context; + if (this.hideEditorPopup) { + this.hideEditorPopup(); + } + this.hideEditorPopup = undefined; + this.cellEditor = context.destroyBean(this.cellEditor); + this.cellEditorPopupWrapper = context.destroyBean(this.cellEditorPopupWrapper); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["removeFromParent"])(this.cellEditorGui); + this.cellEditorGui = null; + this.editorVersion++; + }; + CellComp.prototype.refreshCellRenderer = function (compClassAndParams) { + if (this.cellRenderer == null || this.cellRenderer.refresh == null) { + return false; + } + // if different Cell Renderer configured this time (eg user is using selector, and + // returns different component) then don't refresh, force recreate of Cell Renderer + if (this.cellRendererClass !== compClassAndParams.componentClass) { + return false; + } + // take any custom params off of the user + var result = this.cellRenderer.refresh(compClassAndParams.params); + // NOTE on undefined: previous version of the cellRenderer.refresh() interface + // returned nothing, if the method existed, we assumed it refreshed. so for + // backwards compatibility, we assume if method exists and returns nothing, + // that it was successful. + return result === true || result === undefined; + }; + CellComp.prototype.createCellRendererInstance = function (compDetails) { + var _this = this; + // never use task service if angularCompileRows=true, as that assume the cell renderers + // are finished when the row is created. also we never use it if animation frame service + // is turned off. + // and lastly we never use it if doing auto-height, as the auto-height service checks the + // row height directly after the cell is created, it doesn't wait around for the tasks to complete + var angularCompileRows = this.beans.gridOptionsWrapper.isAngularCompileRows(); + var suppressAnimationFrame = this.beans.gridOptionsWrapper.isSuppressAnimationFrame(); + var useTaskService = !angularCompileRows && !suppressAnimationFrame; + var displayComponentVersionCopy = this.rendererVersion; + var componentClass = compDetails.componentClass; + var createCellRendererFunc = function () { + var staleTask = _this.rendererVersion !== displayComponentVersionCopy || !_this.isAlive(); + if (staleTask) { + return; + } + // this can return null in the event that the user has switched from a renderer component to nothing, for example + // when using a cellRendererSelect to return a component or null depending on row data etc + var componentPromise = compDetails.newAgStackInstance(); + var callback = _this.afterCellRendererCreated.bind(_this, displayComponentVersionCopy, componentClass); + if (componentPromise) { + componentPromise.then(callback); + } + }; + // we only use task service when rendering for first time, which means it is not used when doing edits. + // if we changed this (always use task service) would make sense, however it would break tests, possibly + // test of users. + if (useTaskService && this.firstRender) { + this.beans.animationFrameService.createTask(createCellRendererFunc, this.rowNode.rowIndex, 'createTasksP2'); + } + else { + createCellRendererFunc(); + } + }; + CellComp.prototype.isUsingAngular1Template = function () { + var colDef = this.column.getColDef(); + var res = colDef.template != null || colDef.templateUrl != null; + return res; + }; + CellComp.prototype.getCtrl = function () { + return this.cellCtrl; + }; + CellComp.prototype.getRowCtrl = function () { + return this.rowCtrl; + }; + CellComp.prototype.getCellRenderer = function () { + return this.cellRenderer; + }; + CellComp.prototype.getCellEditor = function () { + return this.cellEditor; + }; + CellComp.prototype.afterCellRendererCreated = function (cellRendererVersion, cellRendererClass, cellRenderer) { + var staleTask = !this.isAlive() || cellRendererVersion !== this.rendererVersion; + if (staleTask) { + this.beans.context.destroyBean(cellRenderer); + return; + } + this.cellRenderer = cellRenderer; + this.cellRendererClass = cellRendererClass; + this.cellRendererGui = this.cellRenderer.getGui(); + if (this.cellRendererGui != null) { + var eParent = this.getParentOfValue(); + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["clearElement"])(eParent); + eParent.appendChild(this.cellRendererGui); + this.updateAngular1ScopeAndCompile(); + } + }; + CellComp.prototype.afterCellEditorCreated = function (requestVersion, cellEditor, params, popup, position) { + // if editingCell=false, means user cancelled the editor before component was ready. + // if versionMismatch, then user cancelled the edit, then started the edit again, and this + // is the first editor which is now stale. + var staleComp = requestVersion !== this.editorVersion; + if (staleComp) { + this.beans.context.destroyBean(cellEditor); + return; + } + var editingCancelledByUserComp = cellEditor.isCancelBeforeStart && cellEditor.isCancelBeforeStart(); + if (editingCancelledByUserComp) { + this.beans.context.destroyBean(cellEditor); + this.cellCtrl.stopEditing(); + return; + } + if (!cellEditor.getGui) { + console.warn("AG Grid: cellEditor for column " + this.column.getId() + " is missing getGui() method"); + this.beans.context.destroyBean(cellEditor); + return; + } + this.cellEditor = cellEditor; + this.cellEditorGui = cellEditor.getGui(); + var cellEditorInPopup = popup || (cellEditor.isPopup !== undefined && cellEditor.isPopup()); + if (cellEditorInPopup) { + if (!popup) { + this.cellCtrl.hackSayEditingInPopup(); + } + this.addPopupCellEditor(params, position); + } + else { + this.addInCellEditor(); + } + if (cellEditor.afterGuiAttached) { + cellEditor.afterGuiAttached(); + } + }; + CellComp.prototype.addInCellEditor = function () { + var eGui = this.getGui(); + // if focus is inside the cell, we move focus to the cell itself + // before removing it's contents, otherwise errors could be thrown. + var eDocument = this.beans.gridOptionsWrapper.getDocument(); + if (eGui.contains(eDocument.activeElement)) { + eGui.focus(); + } + this.destroyRenderer(); + this.refreshWrapper(true); + this.clearParentOfValue(); + if (this.cellEditorGui) { + var eParent = this.getParentOfValue(); + eParent.appendChild(this.cellEditorGui); + } + }; + CellComp.prototype.addPopupCellEditor = function (params, position) { + var _this = this; + if (this.beans.gridOptionsWrapper.isFullRowEdit()) { + console.warn('AG Grid: popup cellEditor does not work with fullRowEdit - you cannot use them both ' + + '- either turn off fullRowEdit, or stop using popup editors.'); + } + var cellEditor = this.cellEditor; + // if a popup, then we wrap in a popup editor and return the popup + this.cellEditorPopupWrapper = this.beans.context.createBean(new _cellEditors_popupEditorWrapper__WEBPACK_IMPORTED_MODULE_1__["PopupEditorWrapper"](params)); + var ePopupGui = this.cellEditorPopupWrapper.getGui(); + if (this.cellEditorGui) { + ePopupGui.appendChild(this.cellEditorGui); + } + var popupService = this.beans.popupService; + var useModelPopup = this.beans.gridOptionsWrapper.isStopEditingWhenCellsLoseFocus(); + // see if position provided by colDef, if not then check old way of method on cellComp + var positionToUse = position != null ? position : cellEditor.getPopupPosition ? cellEditor.getPopupPosition() : 'over'; + var positionParams = { + column: this.column, + rowNode: this.rowNode, + type: 'popupCellEditor', + eventSource: this.getGui(), + ePopup: ePopupGui, + keepWithinBounds: true + }; + var positionCallback = positionToUse === 'under' ? + popupService.positionPopupUnderComponent.bind(popupService, positionParams) + : popupService.positionPopupOverComponent.bind(popupService, positionParams); + var translate = this.beans.gridOptionsWrapper.getLocaleTextFunc(); + var addPopupRes = popupService.addPopup({ + modal: useModelPopup, + eChild: ePopupGui, + closeOnEsc: true, + closedCallback: function () { _this.cellCtrl.onPopupEditorClosed(); }, + anchorToElement: this.getGui(), + positionCallback: positionCallback, + ariaLabel: translate('ariaLabelCellEditor', 'Cell Editor') + }); + if (addPopupRes) { + this.hideEditorPopup = addPopupRes.hideFunc; + } + }; + CellComp.prototype.detach = function () { + this.eRow.removeChild(this.getGui()); + }; + // if the row is also getting destroyed, then we don't need to remove from dom, + // as the row will also get removed, so no need to take out the cells from the row + // if the row is going (removing is an expensive operation, so only need to remove + // the top part) + // + // note - this is NOT called by context, as we don't wire / unwire the CellComp for performance reasons. + CellComp.prototype.destroy = function () { + this.cellCtrl.stopEditing(); + this.destroyEditorAndRenderer(); + this.removeControls(); + if (this.angularCompiledElement) { + this.angularCompiledElement.remove(); + this.angularCompiledElement = undefined; + } + _super.prototype.destroy.call(this); + }; + CellComp.prototype.clearParentOfValue = function () { + var eGui = this.getGui(); + // if focus is inside the cell, we move focus to the cell itself + // before removing it's contents, otherwise errors could be thrown. + var eDocument = this.beans.gridOptionsWrapper.getDocument(); + if (eGui.contains(eDocument.activeElement)) { + eGui.focus({ + preventScroll: true + }); + } + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["clearElement"])(this.getParentOfValue()); + }; + CellComp.prototype.updateAngular1ScopeAndCompile = function () { + if (this.beans.gridOptionsWrapper.isAngularCompileRows() && this.scope) { + this.scope.data = __assign({}, this.rowNode.data); + if (this.angularCompiledElement) { + this.angularCompiledElement.remove(); + } + var eParent = this.getParentOfValue(); + this.angularCompiledElement = this.beans.$compile(eParent.children)(this.scope); + // because this.scope is set, we are guaranteed GridBodyComp is vanilla JS, ie it's GridBodyComp.ts from AG Stack and and not react + this.beans.ctrlsService.getGridBodyCtrl().requestAngularApply(); + } + }; + return CellComp; +}(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"])); /***/ }), -/* 191 */ +/* 240 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgStackComponentsRegistry", function() { return AgStackComponentsRegistry; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PopupEditorWrapper", function() { return PopupEditorWrapper; }); +/* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(85); +/* harmony import */ var _utils_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(49); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -42561,55 +51056,51 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta }; -var AgStackComponentsRegistry = /** @class */ (function (_super) { - __extends(AgStackComponentsRegistry, _super); - function AgStackComponentsRegistry() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.componentsMappedByName = {}; + +var PopupEditorWrapper = /** @class */ (function (_super) { + __extends(PopupEditorWrapper, _super); + function PopupEditorWrapper(params) { + var _this = _super.call(this, /* html */ "
") || this; + _this.params = params; return _this; } - AgStackComponentsRegistry.prototype.setupComponents = function (components) { - var _this = this; - if (components) { - components.forEach(function (componentMeta) { return _this.addComponent(componentMeta); }); - } - }; - AgStackComponentsRegistry.prototype.addComponent = function (componentMeta) { - // get name of the class as a string - // let className = _.getNameOfClass(ComponentClass); - // insert a dash after every capital letter - // let classEscaped = className.replace(/([A-Z])/g, "-$1").toLowerCase(); - var classEscaped = componentMeta.componentName.replace(/([a-z])([A-Z])/g, "$1-$2").toLowerCase(); - // put all to upper case - var classUpperCase = classEscaped.toUpperCase(); - // finally store - this.componentsMappedByName[classUpperCase] = componentMeta.componentClass; + PopupEditorWrapper.prototype.postConstruct = function () { + this.gridOptionsWrapper.setDomData(this.getGui(), PopupEditorWrapper.DOM_KEY_POPUP_EDITOR_WRAPPER, true); + this.addKeyDownListener(); }; - AgStackComponentsRegistry.prototype.getComponentClass = function (htmlTag) { - return this.componentsMappedByName[htmlTag]; + PopupEditorWrapper.prototype.addKeyDownListener = function () { + var _this = this; + var eGui = this.getGui(); + var params = this.params; + var listener = function (event) { + if (!Object(_utils_keyboard__WEBPACK_IMPORTED_MODULE_1__["isUserSuppressingKeyboardEvent"])(_this.gridOptionsWrapper, event, params.node, params.column, true)) { + params.onKeyDown(event); + } + }; + this.addManagedListener(eGui, 'keydown', listener); }; - AgStackComponentsRegistry = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('agStackComponentsRegistry') - ], AgStackComponentsRegistry); - return AgStackComponentsRegistry; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + PopupEditorWrapper.DOM_KEY_POPUP_EDITOR_WRAPPER = 'popupEditorWrapper'; + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] + ], PopupEditorWrapper.prototype, "postConstruct", null); + return PopupEditorWrapper; +}(_widgets_popupComponent__WEBPACK_IMPORTED_MODULE_0__["PopupComponent"])); /***/ }), -/* 192 */ +/* 241 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderPositionUtils", function() { return HeaderPositionUtils; }); -/* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(34); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(41); -/* harmony import */ var _headerRowComp__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(110); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowNodeEventThrottle", function() { return RowNodeEventThrottle; }); +/* harmony import */ var _constants_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(15); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -42635,204 +51126,241 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta - -var HeaderPositionUtils = /** @class */ (function (_super) { - __extends(HeaderPositionUtils, _super); - function HeaderPositionUtils() { - return _super !== null && _super.apply(this, arguments) || this; +var RowNodeEventThrottle = /** @class */ (function (_super) { + __extends(RowNodeEventThrottle, _super); + function RowNodeEventThrottle() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.events = []; + return _this; } - HeaderPositionUtils.prototype.findHeader = function (focusedHeader, direction) { - var nextColumn; - var getGroupMethod; - var getColMethod; - if (focusedHeader.column instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) { - getGroupMethod = "getDisplayedGroup" + direction; - nextColumn = this.columnController[getGroupMethod](focusedHeader.column); - } - else { - getColMethod = "getDisplayedCol" + direction; - nextColumn = this.columnController[getColMethod](focusedHeader.column); - } - if (nextColumn) { - return { - column: nextColumn, - headerRowIndex: focusedHeader.headerRowIndex - }; + RowNodeEventThrottle.prototype.postConstruct = function () { + if (this.rowModel.getType() == _constants_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) { + this.clientSideRowModel = this.rowModel; } }; - HeaderPositionUtils.prototype.findColAtEdgeForHeaderRow = function (level, position) { - var displayedColumns = this.columnController.getAllDisplayedColumns(); - var column = displayedColumns[position === 'start' ? 0 : displayedColumns.length - 1]; - if (!column) { + // because the user can call rowNode.setExpanded() many times in one VM turn, + // we throttle the calls to ClientSideRowModel using animationFrameService. this means for 100 + // row nodes getting expanded, we only update the CSRM once, and then we fire all events after + // CSRM has updated. + // + // if we did not do this, then the user could call setExpanded on 100+ rows, causing the grid + // to re-render 100+ times, which would be a performance lag. + // + // we use animationFrameService + // rather than _.debounce() so this will get done if anyone flushes the animationFrameService + // (eg user calls api.ensureRowVisible(), which in turn flushes ). + RowNodeEventThrottle.prototype.dispatchExpanded = function (event) { + var _this = this; + // if not using CSRM, we don't debounce. otherwise this breaks the SSRM. + if (this.clientSideRowModel == null) { + this.eventService.dispatchEvent(event); return; } - var childContainer = this.headerNavigationService.getHeaderContainer(column.getPinned()); - var headerRowComp = childContainer.getRowComps()[level]; - var type = headerRowComp && headerRowComp.getType(); - if (type == _headerRowComp__WEBPACK_IMPORTED_MODULE_3__["HeaderRowType"].COLUMN_GROUP) { - var columnGroup = this.columnController.getColumnGroupAtLevel(column, level); - return { - headerRowIndex: level, - column: columnGroup - }; - } - return { - headerRowIndex: !headerRowComp ? -1 : level, - column: column + this.events.push(event); + var func = function () { + if (_this.clientSideRowModel) { + _this.clientSideRowModel.onRowGroupOpened(); + } + _this.events.forEach(function (e) { return _this.eventService.dispatchEvent(e); }); + _this.events = []; }; + if (this.dispatchExpandedDebounced == null) { + this.dispatchExpandedDebounced = this.animationFrameService.debounce(func); + } + this.dispatchExpandedDebounced(); }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController') - ], HeaderPositionUtils.prototype, "columnController", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('animationFrameService') + ], RowNodeEventThrottle.prototype, "animationFrameService", void 0); __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('headerNavigationService') - ], HeaderPositionUtils.prototype, "headerNavigationService", void 0); - HeaderPositionUtils = __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('headerPositionUtils') - ], HeaderPositionUtils); - return HeaderPositionUtils; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"])); + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('rowModel') + ], RowNodeEventThrottle.prototype, "rowModel", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"] + ], RowNodeEventThrottle.prototype, "postConstruct", null); + RowNodeEventThrottle = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Bean"])('rowNodeEventThrottle') + ], RowNodeEventThrottle); + return RowNodeEventThrottle; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); /***/ }), -/* 193 */ +/* 242 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "initialiseAgGridWithWebComponents", function() { return initialiseAgGridWithWebComponents; }); -/* harmony import */ var _componentUtil__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(48); -/* harmony import */ var _grid__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(95); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "StandardMenuFactory", function() { return StandardMenuFactory; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(42); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(65); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(44); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; -var registered = false; -function initialiseAgGridWithWebComponents() { - console.warn('ag-grid: initialiseAgGridWithWebComponents is deprecated. Please use the ag-grid-webcomponent dependency instead. '); - // only register to WebComponents once - if (registered) { - return; + + + +var StandardMenuFactory = /** @class */ (function (_super) { + __extends(StandardMenuFactory, _super); + function StandardMenuFactory() { + return _super !== null && _super.apply(this, arguments) || this; } - registered = true; - if (typeof document === 'undefined' || !document.registerElement) { - console.error('ag-Grid: unable to find document.registerElement() function, unable to initialise ag-Grid as a Web Component'); - } - // i don't think this type of extension is possible in TypeScript, so back to - // plain Javascript to create this object - var AgileGridProto = Object.create(HTMLElement.prototype); - // wrap each property with a get and set method, so we can track when changes are done - _componentUtil__WEBPACK_IMPORTED_MODULE_0__["ComponentUtil"].ALL_PROPERTIES.forEach(function (key) { - Object.defineProperty(AgileGridProto, key, { - set: function (v) { - this.__agGridSetProperty(key, v); - }, - get: function () { - return this.__agGridGetProperty(key); - }, - enumerable: true, - configurable: true + StandardMenuFactory.prototype.hideActiveMenu = function () { + if (this.hidePopup) { + this.hidePopup(); + } + }; + StandardMenuFactory.prototype.showMenuAfterMouseEvent = function (column, mouseEvent) { + var _this = this; + this.showPopup(column, function (eMenu) { + _this.popupService.positionPopupUnderMouseEvent({ + column: column, + type: 'columnMenu', + mouseEvent: mouseEvent, + ePopup: eMenu + }); + }, mouseEvent.target); + }; + StandardMenuFactory.prototype.showMenuAfterButtonClick = function (column, eventSource, containerType) { + var _this = this; + this.showPopup(column, function (eMenu) { + _this.popupService.positionPopupUnderComponent({ + type: containerType, + eventSource: eventSource, + ePopup: eMenu, + keepWithinBounds: true, + column: column + }); + }, eventSource); + }; + StandardMenuFactory.prototype.showPopup = function (column, positionCallback, eventSource) { + var _this = this; + var filterWrapper = this.filterManager.getOrCreateFilterWrapper(column, 'COLUMN_MENU'); + if (!filterWrapper) { + throw new Error('AG Grid - unable to show popup filter, filter instantiation failed'); + } + var eMenu = document.createElement('div'); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_4__["setAriaRole"])(eMenu, 'presentation'); + eMenu.classList.add('ag-menu'); + this.tabListener = this.addManagedListener(eMenu, 'keydown', function (e) { return _this.trapFocusWithin(e, eMenu); }); + filterWrapper.guiPromise.then(function (gui) { return eMenu.appendChild(gui); }); + var hidePopup; + var anchorToElement = eventSource || this.ctrlsService.getGridBodyCtrl().getGui(); + var closedCallback = function (e) { + column.setMenuVisible(false, 'contextMenu'); + var isKeyboardEvent = e instanceof KeyboardEvent; + if (_this.tabListener) { + _this.tabListener = _this.tabListener(); + } + if (isKeyboardEvent && eventSource && Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["isVisible"])(eventSource)) { + var focusableEl = _this.focusService.findTabbableParent(eventSource); + if (focusableEl) { + focusableEl.focus(); + } + } + }; + var translate = this.gridOptionsWrapper.getLocaleTextFunc(); + var addPopupRes = this.popupService.addPopup({ + modal: true, + eChild: eMenu, + closeOnEsc: true, + closedCallback: closedCallback, + positionCallback: function () { return positionCallback(eMenu); }, + anchorToElement: anchorToElement, + ariaLabel: translate('ariaLabelColumnMenu', 'Column Menu') }); - }); - var agGridProtoNoType = AgileGridProto; - agGridProtoNoType.__agGridSetProperty = function (key, value) { - if (!this.__attributes) { - this.__attributes = {}; - } - this.__attributes[key] = value; - // keeping this consistent with the ng2 onChange, so I can reuse the handling code - var changeObject = {}; - changeObject[key] = { currentValue: value }; - this.onChange(changeObject); - }; - agGridProtoNoType.onChange = function (changes) { - if (this._initialised) { - _componentUtil__WEBPACK_IMPORTED_MODULE_0__["ComponentUtil"].processOnChange(changes, this._gridOptions, this.api, this.columnApi); - } - }; - agGridProtoNoType.__agGridGetProperty = function (key) { - if (!this.__attributes) { - this.__attributes = {}; - } - return this.__attributes[key]; - }; - agGridProtoNoType.setGridOptions = function (options) { - var globalEventListener = this.globalEventListener.bind(this); - this._gridOptions = _componentUtil__WEBPACK_IMPORTED_MODULE_0__["ComponentUtil"].copyAttributesToGridOptions(options, this); - var gridParams = { - globalEventListener: globalEventListener - }; - this._agGrid = new _grid__WEBPACK_IMPORTED_MODULE_1__["Grid"](this, this._gridOptions, gridParams); - this.api = options.api; - this.columnApi = options.columnApi; - this._initialised = true; - }; - // copies all the attributes into this object - agGridProtoNoType.createdCallback = function () { - for (var i = 0; i < this.attributes.length; i++) { - var attribute = this.attributes[i]; - this.setPropertyFromAttribute(attribute); - } - }; - agGridProtoNoType.setPropertyFromAttribute = function (attribute) { - var name = toCamelCase(attribute.nodeName); - var value = attribute.nodeValue; - if (_componentUtil__WEBPACK_IMPORTED_MODULE_0__["ComponentUtil"].ALL_PROPERTIES.indexOf(name) >= 0) { - this[name] = value; - } - }; - agGridProtoNoType.attachedCallback = function (params) { }; - agGridProtoNoType.detachedCallback = function (params) { }; - agGridProtoNoType.attributeChangedCallback = function (attributeName) { - var attribute = this.attributes[attributeName]; - this.setPropertyFromAttribute(attribute); - }; - agGridProtoNoType.globalEventListener = function (eventType, event) { - var eventLowerCase = eventType.toLowerCase(); - var browserEvent = new Event(eventLowerCase); - var browserEventNoType = browserEvent; - browserEventNoType.agGridDetails = event; - this.dispatchEvent(browserEvent); - var callbackMethod = 'on' + eventLowerCase; - if (typeof this[callbackMethod] === 'function') { - this[callbackMethod](browserEvent); - } - }; - // finally, register - document.registerElement('ag-grid', { prototype: AgileGridProto }); -} -function toCamelCase(myString) { - if (typeof myString === 'string') { - var result = myString.replace(/-([a-z])/g, function (g) { - return g[1].toUpperCase(); + if (addPopupRes) { + this.hidePopup = hidePopup = addPopupRes.hideFunc; + } + filterWrapper.filterPromise.then(function (filter) { + // need to make sure the filter is present before positioning, as only + // after filter it is visible can we find out what the width of it is + positionCallback(eMenu); + if (filter.afterGuiAttached) { + filter.afterGuiAttached({ container: 'columnMenu', hidePopup: hidePopup }); + } }); - return result; - } - else { - return myString; - } -} + column.setMenuVisible(true, 'contextMenu'); + }; + StandardMenuFactory.prototype.trapFocusWithin = function (e, menu) { + if (e.key !== _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].TAB || + e.defaultPrevented || + this.focusService.findNextFocusableElement(menu, false, e.shiftKey)) { + return; + } + e.preventDefault(); + this.focusService.focusInto(menu, e.shiftKey); + }; + StandardMenuFactory.prototype.isMenuEnabled = function (column) { + // for standard, we show menu if filter is enabled, and the menu is not suppressed + return column.isFilterAllowed(); + }; + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager') + ], StandardMenuFactory.prototype, "filterManager", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('popupService') + ], StandardMenuFactory.prototype, "popupService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusService') + ], StandardMenuFactory.prototype, "focusService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('ctrlsService') + ], StandardMenuFactory.prototype, "ctrlsService", void 0); + StandardMenuFactory = __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('menuFactory') + ], StandardMenuFactory); + return StandardMenuFactory; +}(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"])); + /***/ }), -/* 194 */ +/* 243 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TabbedLayout", function() { return TabbedLayout; }); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7); -/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25); -/* harmony import */ var _widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(117); +/* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57); +/* harmony import */ var _widgets_managedFocusFeature__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(64); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(42); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(44); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(14); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(65); +/* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(36); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(12); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -42859,29 +51387,41 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta + + + + var TabbedLayout = /** @class */ (function (_super) { __extends(TabbedLayout, _super); function TabbedLayout(params) { var _this = _super.call(this, TabbedLayout.getTemplate(params.cssClass)) || this; _this.items = []; + _this.tabbedItemScrollMap = new Map(); _this.params = params; if (params.items) { params.items.forEach(function (item) { return _this.addItem(item); }); } return _this; } + TabbedLayout.prototype.postConstruct = function () { + this.createManagedBean(new _widgets_managedFocusFeature__WEBPACK_IMPORTED_MODULE_1__["ManagedFocusFeature"](this.getFocusableElement(), { + onTabKeyDown: this.onTabKeyDown.bind(this), + handleKeyDown: this.handleKeyDown.bind(this) + })); + }; TabbedLayout.getTemplate = function (cssClass) { - return /* html */ "
\n
\n
\n
"; + return /* html */ "
\n
\n
\n
"; }; TabbedLayout.prototype.handleKeyDown = function (e) { - switch (e.keyCode) { - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_RIGHT: - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_LEFT: - if (!this.eHeader.contains(document.activeElement)) { + var eDocument = this.gridOptionsWrapper.getDocument(); + switch (e.key) { + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_5__["KeyCode"].RIGHT: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_5__["KeyCode"].LEFT: + if (!this.eHeader.contains(eDocument.activeElement)) { return; } var currentPosition = this.items.indexOf(this.activeItem); - var nextPosition = e.keyCode === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_RIGHT ? Math.min(currentPosition + 1, this.items.length - 1) : Math.max(currentPosition - 1, 0); + var nextPosition = e.key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_5__["KeyCode"].RIGHT ? Math.min(currentPosition + 1, this.items.length - 1) : Math.max(currentPosition - 1, 0); if (currentPosition === nextPosition) { return; } @@ -42890,36 +51430,38 @@ var TabbedLayout = /** @class */ (function (_super) { this.showItemWrapper(nextItem); nextItem.eHeaderButton.focus(); break; - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_UP: - case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_DOWN: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_5__["KeyCode"].UP: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_5__["KeyCode"].DOWN: e.stopPropagation(); break; } }; TabbedLayout.prototype.onTabKeyDown = function (e) { - var _a = this, focusController = _a.focusController, eHeader = _a.eHeader, eBody = _a.eBody, activeItem = _a.activeItem; - var activeElement = document.activeElement; - var focusInHeader = eHeader.contains(activeElement); + if (e.defaultPrevented) { + return; + } + var _a = this, focusService = _a.focusService, eHeader = _a.eHeader, eBody = _a.eBody, activeItem = _a.activeItem; + var eDocument = this.gridOptionsWrapper.getDocument(); + var activeElement = eDocument.activeElement; e.preventDefault(); - if (focusInHeader) { - if (e.shiftKey) { - focusController.focusLastFocusableElement(eBody); - } - else { - focusController.focusFirstFocusableElement(eBody); - } + if (eHeader.contains(activeElement)) { + // focus is in header, move into body of popup + focusService.focusInto(eBody, e.shiftKey); } else { - var isFocusManaged = focusController.isFocusUnderManagedComponent(eBody); - if (isFocusManaged) { + // focus is in body, establish if it should return to header + if (focusService.isFocusUnderManagedComponent(eBody)) { + // focus was in a managed focus component and has now left, so we can return to the header activeItem.eHeaderButton.focus(); } else { - var nextEl = focusController.findNextFocusableElement(eBody, false, e.shiftKey); + var nextEl = focusService.findNextFocusableElement(eBody, false, e.shiftKey); if (nextEl) { + // if another element exists in the body that can be focussed, go to that nextEl.focus(); } else { + // otherwise return to the header activeItem.eHeaderButton.focus(); } } @@ -42928,33 +51470,6 @@ var TabbedLayout = /** @class */ (function (_super) { TabbedLayout.prototype.setAfterAttachedParams = function (params) { this.afterAttachedParams = params; }; - TabbedLayout.prototype.getMinDimensions = function () { - var eDummyContainer = this.getGui().cloneNode(true); - var eDummyBody = eDummyContainer.querySelector('[ref="eBody"]'); - // position fixed, so it isn't restricted to the boundaries of the parent - eDummyContainer.style.position = 'fixed'; - // we put the dummy into the body container, so it will inherit all the - // css styles that the real cells are inheriting - this.getGui().appendChild(eDummyContainer); - var minWidth = 0; - var minHeight = 0; - this.items.forEach(function (itemWrapper) { - _utils__WEBPACK_IMPORTED_MODULE_0__["_"].clearElement(eDummyBody); - var eClone = itemWrapper.tabbedItem.bodyPromise.resolveNow(null, function (body) { return body.cloneNode(true); }); - if (eClone == null) { - return; - } - eDummyBody.appendChild(eClone); - if (minWidth < eDummyContainer.offsetWidth) { - minWidth = eDummyContainer.offsetWidth; - } - if (minHeight < eDummyContainer.offsetHeight) { - minHeight = eDummyContainer.offsetHeight; - } - }); - this.getGui().removeChild(eDummyContainer); - return { height: minHeight, width: minWidth }; - }; TabbedLayout.prototype.showFirstItem = function () { if (this.items.length > 0) { this.showItemWrapper(this.items[0]); @@ -42962,11 +51477,12 @@ var TabbedLayout = /** @class */ (function (_super) { }; TabbedLayout.prototype.addItem = function (item) { var eHeaderButton = document.createElement('span'); - eHeaderButton.tabIndex = -1; + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_3__["setAriaRole"])(eHeaderButton, 'tab'); + eHeaderButton.setAttribute('tabIndex', '-1'); eHeaderButton.appendChild(item.title); - _utils__WEBPACK_IMPORTED_MODULE_0__["_"].addCssClass(eHeaderButton, 'ag-tab'); + eHeaderButton.classList.add('ag-tab'); this.eHeader.appendChild(eHeaderButton); - eHeaderButton.setAttribute('aria-label', item.titleLabel); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_3__["setAriaLabel"])(eHeaderButton, item.titleLabel); var wrapper = { tabbedItem: item, eHeaderButton: eHeaderButton @@ -42975,65 +51491,89 @@ var TabbedLayout = /** @class */ (function (_super) { eHeaderButton.addEventListener('click', this.showItemWrapper.bind(this, wrapper)); }; TabbedLayout.prototype.showItem = function (tabbedItem) { - var itemWrapper = _utils__WEBPACK_IMPORTED_MODULE_0__["_"].find(this.items, function (wrapper) { - return wrapper.tabbedItem === tabbedItem; - }); + var itemWrapper = this.items.find(function (wrapper) { return wrapper.tabbedItem === tabbedItem; }); if (itemWrapper) { this.showItemWrapper(itemWrapper); } }; TabbedLayout.prototype.showItemWrapper = function (wrapper) { var _this = this; + var tabbedItem = wrapper.tabbedItem, eHeaderButton = wrapper.eHeaderButton; if (this.params.onItemClicked) { - this.params.onItemClicked({ item: wrapper.tabbedItem }); + this.params.onItemClicked({ item: tabbedItem }); } if (this.activeItem === wrapper) { - _utils__WEBPACK_IMPORTED_MODULE_0__["_"].callIfPresent(this.params.onActiveItemClicked); + Object(_utils_function__WEBPACK_IMPORTED_MODULE_4__["callIfPresent"])(this.params.onActiveItemClicked); return; } - _utils__WEBPACK_IMPORTED_MODULE_0__["_"].clearElement(this.eBody); - wrapper.tabbedItem.bodyPromise.then(function (body) { + if (this.lastScrollListener) { + this.lastScrollListener = this.lastScrollListener(); + } + Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["clearElement"])(this.eBody); + tabbedItem.bodyPromise.then(function (body) { _this.eBody.appendChild(body); - var onlyUnmanaged = !_this.focusController.isKeyboardFocus(); - _this.focusController.focusFirstFocusableElement(_this.eBody, onlyUnmanaged); + var onlyUnmanaged = !_this.focusService.isKeyboardMode(); + _this.focusService.focusInto(_this.eBody, false, onlyUnmanaged); + if (tabbedItem.afterAttachedCallback) { + tabbedItem.afterAttachedCallback(_this.afterAttachedParams); + } + if (_this.params.keepScrollPosition) { + var scrollableContainer_1 = (tabbedItem.getScrollableContainer && tabbedItem.getScrollableContainer()) || body; + _this.lastScrollListener = _this.addManagedListener(scrollableContainer_1, 'scroll', function () { + _this.tabbedItemScrollMap.set(tabbedItem.name, scrollableContainer_1.scrollTop); + }); + var scrollPosition_1 = _this.tabbedItemScrollMap.get(tabbedItem.name); + if (scrollPosition_1 !== undefined) { + // Safari needs a small timeout or it will fire a scroll event to position 0 + setTimeout(function () { + scrollableContainer_1.scrollTop = scrollPosition_1; + }, 0); + } + } }); if (this.activeItem) { - _utils__WEBPACK_IMPORTED_MODULE_0__["_"].removeCssClass(this.activeItem.eHeaderButton, 'ag-tab-selected'); + this.activeItem.eHeaderButton.classList.remove('ag-tab-selected'); } - _utils__WEBPACK_IMPORTED_MODULE_0__["_"].addCssClass(wrapper.eHeaderButton, 'ag-tab-selected'); + eHeaderButton.classList.add('ag-tab-selected'); this.activeItem = wrapper; - if (wrapper.tabbedItem.afterAttachedCallback) { - wrapper.tabbedItem.afterAttachedCallback(this.afterAttachedParams); - } }; __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eHeader') + Object(_context_context__WEBPACK_IMPORTED_MODULE_7__["Autowired"])('focusService') + ], TabbedLayout.prototype, "focusService", void 0); + __decorate([ + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eHeader') ], TabbedLayout.prototype, "eHeader", void 0); __decorate([ - Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eBody') + Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eBody') ], TabbedLayout.prototype, "eBody", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_7__["PostConstruct"] + ], TabbedLayout.prototype, "postConstruct", null); return TabbedLayout; -}(_widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_3__["ManagedFocusComponent"])); +}(_widgets_component__WEBPACK_IMPORTED_MODULE_6__["Component"])); /***/ }), -/* 195 */ +/* 244 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "simpleHttpRequest", function() { return simpleHttpRequest; }); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ +/** + * @deprecated + */ function simpleHttpRequest(params) { - return new _utils__WEBPACK_IMPORTED_MODULE_0__["Promise"](function (resolve) { + return new _utils__WEBPACK_IMPORTED_MODULE_0__["AgPromise"](function (resolve) { var httpRequest = new XMLHttpRequest(); httpRequest.open('GET', params.url); httpRequest.send(); @@ -43047,19 +51587,70 @@ function simpleHttpRequest(params) { /***/ }), -/* 196 */ +/* 245 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowNodeBlock", function() { return RowNodeBlock; }); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7); -/* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(68); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ServerSideTransactionResultStatus", function() { return ServerSideTransactionResultStatus; }); +/** + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 + * @link http://www.ag-grid.com/ + * @license MIT + */ +var ServerSideTransactionResultStatus; +(function (ServerSideTransactionResultStatus) { + /** Transaction was successfully applied */ + ServerSideTransactionResultStatus["Applied"] = "Applied"; + /** + * Store was not found, transaction not applied. + * Either invalid route, or the parent row has not yet been expanded. + */ + ServerSideTransactionResultStatus["StoreNotFound"] = "StoreNotFound"; + /** + * Store is loading, transaction not applied. + */ + ServerSideTransactionResultStatus["StoreLoading"] = "StoreLoading"; + /** + * Store is loading (as max loads exceeded), transaction not applied. + */ + ServerSideTransactionResultStatus["StoreWaitingToLoad"] = "StoreWaitingToLoad"; + /** + * Store load attempt failed, transaction not applied. + */ + ServerSideTransactionResultStatus["StoreLoadingFailed"] = "StoreLoadingFailed"; + /** + * Store is type Partial, which doesn't accept transactions + */ + ServerSideTransactionResultStatus["StoreWrongType"] = "StoreWrongType"; + /** + * Transaction was cancelled, due to grid. + * Callback isApplyServerSideTransaction() returning false + */ + ServerSideTransactionResultStatus["Cancelled"] = "Cancelled"; +})(ServerSideTransactionResultStatus || (ServerSideTransactionResultStatus = {})); + + +/***/ }), +/* 246 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgMenuItemComponent", function() { return AgMenuItemComponent; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _agMenuList__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(247); +/* harmony import */ var _agMenuPanel__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(248); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(36); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(65); +/* harmony import */ var _utils_icon__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(48); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(42); +/* harmony import */ var _customTooltipFeature__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(56); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(44); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -43086,212 +51677,323 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta -var RowNodeBlock = /** @class */ (function (_super) { - __extends(RowNodeBlock, _super); - function RowNodeBlock(blockNumber, rowNodeCacheParams) { + + + + + + +var AgMenuItemComponent = /** @class */ (function (_super) { + __extends(AgMenuItemComponent, _super); + function AgMenuItemComponent(params) { var _this = _super.call(this) || this; - _this.version = 0; - _this.state = RowNodeBlock.STATE_DIRTY; - _this.rowNodeCacheParams = rowNodeCacheParams; - _this.blockNumber = blockNumber; - // we don't need to calculate these now, as the inputs don't change, - // however it makes the code easier to read if we work them out up front - _this.startRow = blockNumber * rowNodeCacheParams.blockSize; - _this.endRow = _this.startRow + rowNodeCacheParams.blockSize; + _this.params = params; + _this.isActive = false; + _this.subMenuIsOpen = false; + _this.setTemplate(/* html */ "
"); return _this; } - RowNodeBlock.prototype.isAnyNodeOpen = function (rowCount) { - var result = false; - this.forEachNodeCallback(function (rowNode) { - if (rowNode.expanded) { - result = true; - } - }, rowCount); - return result; + AgMenuItemComponent.prototype.init = function () { + var _this = this; + this.addIcon(); + this.addName(); + this.addShortcut(); + this.addSubMenu(); + this.addTooltip(); + var eGui = this.getGui(); + if (this.params.disabled) { + this.addCssClass(this.getClassName('disabled')); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_8__["setAriaDisabled"])(eGui, true); + } + else { + this.addGuiEventListener('click', function (e) { return _this.onItemSelected(e); }); + this.addGuiEventListener('keydown', function (e) { + if (e.key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].ENTER || e.key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_4__["KeyCode"].SPACE) { + e.preventDefault(); + _this.onItemSelected(e); + } + }); + this.addGuiEventListener('mousedown', function (e) { + // Prevent event bubbling to other event handlers such as PopupService triggering + // premature closing of any open sub-menu popup. + e.stopPropagation(); + e.preventDefault(); + }); + this.addGuiEventListener('mouseenter', function () { return _this.onMouseEnter(); }); + this.addGuiEventListener('mouseleave', function () { return _this.onMouseLeave(); }); + } + if (this.params.cssClasses) { + this.params.cssClasses.forEach(function (it) { return _this.addCssClass(it); }); + } }; - RowNodeBlock.prototype.forEachNodeCallback = function (callback, rowCount) { - for (var rowIndex = this.startRow; rowIndex < this.endRow; rowIndex++) { - // we check against rowCount as this page may be the last one, and if it is, then - // the last rows are not part of the set - if (rowIndex < rowCount) { - var rowNode = this.getRowUsingLocalIndex(rowIndex); - callback(rowNode, rowIndex); + AgMenuItemComponent.prototype.isDisabled = function () { + return !!this.params.disabled; + }; + AgMenuItemComponent.prototype.openSubMenu = function (activateFirstItem) { + var _this = this; + if (activateFirstItem === void 0) { activateFirstItem = false; } + this.closeSubMenu(); + if (!this.params.subMenu) { + return; + } + var ePopup = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["loadTemplate"])(/* html */ "
"); + var destroySubMenu; + if (this.params.subMenu instanceof Array) { + var currentLevel = Object(_utils_aria__WEBPACK_IMPORTED_MODULE_8__["getAriaLevel"])(this.getGui()); + var nextLevel = isNaN(currentLevel) ? 1 : (currentLevel + 1); + var childMenu_1 = this.createBean(new _agMenuList__WEBPACK_IMPORTED_MODULE_1__["AgMenuList"](nextLevel)); + childMenu_1.setParentComponent(this); + childMenu_1.addMenuItems(this.params.subMenu); + ePopup.appendChild(childMenu_1.getGui()); + // bubble menu item selected events + this.addManagedListener(childMenu_1, AgMenuItemComponent.EVENT_MENU_ITEM_SELECTED, function (e) { return _this.dispatchEvent(e); }); + childMenu_1.addGuiEventListener('mouseenter', function () { return _this.cancelDeactivate(); }); + destroySubMenu = function () { return _this.destroyBean(childMenu_1); }; + if (activateFirstItem) { + setTimeout(function () { return childMenu_1.activateFirstItem(); }, 0); } } - }; - RowNodeBlock.prototype.forEachNode = function (callback, sequence, rowCount, deep) { - this.forEachNodeCallback(function (rowNode) { - callback(rowNode, sequence.next()); - // this will only every happen for server side row model, as infinite - // row model doesn't have groups - if (deep && rowNode.childrenCache) { - rowNode.childrenCache.forEachNodeDeep(callback, sequence); + else { + var subMenu_1 = this.params.subMenu; + var menuPanel = this.createBean(new _agMenuPanel__WEBPACK_IMPORTED_MODULE_2__["AgMenuPanel"](subMenu_1)); + menuPanel.setParentComponent(this); + var subMenuGui_1 = menuPanel.getGui(); + var mouseEvent_1 = 'mouseenter'; + var mouseEnterListener_1 = function () { return _this.cancelDeactivate(); }; + subMenuGui_1.addEventListener(mouseEvent_1, mouseEnterListener_1); + destroySubMenu = function () { return subMenuGui_1.removeEventListener(mouseEvent_1, mouseEnterListener_1); }; + ePopup.appendChild(subMenuGui_1); + if (subMenu_1.afterGuiAttached) { + setTimeout(function () { return subMenu_1.afterGuiAttached(); }, 0); } - }, rowCount); - }; - RowNodeBlock.prototype.forEachNodeDeep = function (callback, sequence, rowCount) { - this.forEachNode(callback, sequence, rowCount, true); - }; - RowNodeBlock.prototype.forEachNodeShallow = function (callback, sequence, rowCount) { - this.forEachNode(callback, sequence, rowCount, false); - }; - RowNodeBlock.prototype.getVersion = function () { - return this.version; - }; - RowNodeBlock.prototype.getLastAccessed = function () { - return this.lastAccessed; - }; - RowNodeBlock.prototype.getRowUsingLocalIndex = function (rowIndex, dontTouchLastAccessed) { - if (dontTouchLastAccessed === void 0) { dontTouchLastAccessed = false; } - if (!dontTouchLastAccessed) { - this.lastAccessed = this.rowNodeCacheParams.lastAccessedSequence.next(); } - var localIndex = rowIndex - this.startRow; - return this.rowNodes[localIndex]; - }; - RowNodeBlock.prototype.init = function (beans) { - this.beans = beans; - this.createRowNodes(); - }; - RowNodeBlock.prototype.getStartRow = function () { - return this.startRow; + var eGui = this.getGui(); + var positionCallback = this.popupService.positionPopupForMenu.bind(this.popupService, { eventSource: eGui, ePopup: ePopup }); + var translate = this.gridOptionsWrapper.getLocaleTextFunc(); + var addPopupRes = this.popupService.addPopup({ + modal: true, + eChild: ePopup, + positionCallback: positionCallback, + anchorToElement: eGui, + ariaLabel: translate('ariaLabelSubMenu', 'SubMenu') + }); + this.subMenuIsOpen = true; + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_8__["setAriaExpanded"])(eGui, true); + this.hideSubMenu = function () { + if (addPopupRes) { + addPopupRes.hideFunc(); + } + _this.subMenuIsOpen = false; + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_8__["setAriaExpanded"])(eGui, false); + destroySubMenu(); + }; }; - RowNodeBlock.prototype.getEndRow = function () { - return this.endRow; + AgMenuItemComponent.prototype.closeSubMenu = function () { + if (!this.hideSubMenu) { + return; + } + this.hideSubMenu(); + this.hideSubMenu = null; + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_8__["setAriaExpanded"])(this.getGui(), false); }; - RowNodeBlock.prototype.getBlockNumber = function () { - return this.blockNumber; + AgMenuItemComponent.prototype.isSubMenuOpen = function () { + return this.subMenuIsOpen; }; - RowNodeBlock.prototype.setDirty = function () { - // in case any current loads in progress, this will have their results ignored - this.version++; - this.state = RowNodeBlock.STATE_DIRTY; + AgMenuItemComponent.prototype.activate = function (openSubMenu) { + var _this = this; + this.cancelActivate(); + if (this.params.disabled) { + return; + } + this.isActive = true; + this.addCssClass(this.getClassName('active')); + this.getGui().focus(); + if (openSubMenu && this.params.subMenu) { + window.setTimeout(function () { + if (_this.isAlive() && _this.isActive) { + _this.openSubMenu(); + } + }, 300); + } + this.onItemActivated(); }; - RowNodeBlock.prototype.setDirtyAndPurge = function () { - this.setDirty(); - this.rowNodes.forEach(function (rowNode) { - rowNode.setData(null); - }); + AgMenuItemComponent.prototype.deactivate = function () { + this.cancelDeactivate(); + this.removeCssClass(this.getClassName('active')); + this.isActive = false; + if (this.subMenuIsOpen) { + this.hideSubMenu(); + } }; - RowNodeBlock.prototype.getState = function () { - return this.state; + AgMenuItemComponent.prototype.addIcon = function () { + if (!this.params.checked && !this.params.icon && this.params.isCompact) { + return; + } + var icon = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["loadTemplate"])(/* html */ ""); + if (this.params.checked) { + icon.appendChild(Object(_utils_icon__WEBPACK_IMPORTED_MODULE_5__["createIconNoSpan"])('check', this.gridOptionsWrapper)); + } + else if (this.params.icon) { + if (Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["isNodeOrElement"])(this.params.icon)) { + icon.appendChild(this.params.icon); + } + else if (typeof this.params.icon === 'string') { + icon.innerHTML = this.params.icon; + } + else { + console.warn('AG Grid: menu item icon must be DOM node or string'); + } + } + this.getGui().appendChild(icon); }; - RowNodeBlock.prototype.setRowNode = function (rowIndex, rowNode) { - var localIndex = rowIndex - this.startRow; - this.rowNodes[localIndex] = rowNode; + AgMenuItemComponent.prototype.addName = function () { + if (!this.params.name && this.params.isCompact) { + return; + } + var name = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["loadTemplate"])(/* html */ "" + (this.params.name || '') + ""); + this.getGui().appendChild(name); }; - RowNodeBlock.prototype.setBlankRowNode = function (rowIndex) { - var localIndex = rowIndex - this.startRow; - var newRowNode = this.createBlankRowNode(rowIndex); - this.rowNodes[localIndex] = newRowNode; - return newRowNode; + AgMenuItemComponent.prototype.addTooltip = function () { + if (!this.params.tooltip) { + return; + } + this.tooltip = this.params.tooltip; + if (this.gridOptionsWrapper.isEnableBrowserTooltips()) { + this.getGui().setAttribute('title', this.tooltip); + } + else { + this.createManagedBean(new _customTooltipFeature__WEBPACK_IMPORTED_MODULE_7__["CustomTooltipFeature"](this)); + } }; - RowNodeBlock.prototype.setNewData = function (rowIndex, dataItem) { - var newRowNode = this.setBlankRowNode(rowIndex); - this.setDataAndId(newRowNode, dataItem, this.startRow + rowIndex); - return newRowNode; + AgMenuItemComponent.prototype.getTooltipParams = function () { + return { + location: 'menu', + value: this.tooltip + }; }; - RowNodeBlock.prototype.createBlankRowNode = function (rowIndex) { - var rowNode = new _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"](); - this.beans.context.createBean(rowNode); - rowNode.setRowHeight(this.rowNodeCacheParams.rowHeight); - return rowNode; + AgMenuItemComponent.prototype.addShortcut = function () { + if (!this.params.shortcut && this.params.isCompact) { + return; + } + var shortcut = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["loadTemplate"])(/* html */ "" + (this.params.shortcut || '') + ""); + this.getGui().appendChild(shortcut); }; - // creates empty row nodes, data is missing as not loaded yet - RowNodeBlock.prototype.createRowNodes = function () { - this.rowNodes = []; - for (var i = 0; i < this.rowNodeCacheParams.blockSize; i++) { - var rowIndex = this.startRow + i; - var rowNode = this.createBlankRowNode(rowIndex); - this.rowNodes.push(rowNode); + AgMenuItemComponent.prototype.addSubMenu = function () { + if (!this.params.subMenu && this.params.isCompact) { + return; + } + var pointer = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["loadTemplate"])(/* html */ ""); + var eGui = this.getGui(); + if (this.params.subMenu) { + var iconName = this.gridOptionsWrapper.isEnableRtl() ? 'smallLeft' : 'smallRight'; + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_8__["setAriaExpanded"])(eGui, false); + pointer.appendChild(Object(_utils_icon__WEBPACK_IMPORTED_MODULE_5__["createIconNoSpan"])(iconName, this.gridOptionsWrapper)); } + eGui.appendChild(pointer); }; - RowNodeBlock.prototype.load = function () { - this.state = RowNodeBlock.STATE_LOADING; - this.loadFromDatasource(); + AgMenuItemComponent.prototype.onItemSelected = function (event) { + if (this.params.action) { + this.params.action(); + } + else { + this.openSubMenu(event && event.type === 'keydown'); + } + if (this.params.subMenu && !this.params.action) { + return; + } + var e = { + type: AgMenuItemComponent.EVENT_MENU_ITEM_SELECTED, + action: this.params.action, + checked: this.params.checked, + cssClasses: this.params.cssClasses, + disabled: this.params.disabled, + icon: this.params.icon, + name: this.params.name, + shortcut: this.params.shortcut, + subMenu: this.params.subMenu, + tooltip: this.params.tooltip, + event: event + }; + this.dispatchEvent(e); }; - RowNodeBlock.prototype.pageLoadFailed = function () { - this.state = RowNodeBlock.STATE_FAILED; + AgMenuItemComponent.prototype.onItemActivated = function () { var event = { - type: RowNodeBlock.EVENT_LOAD_COMPLETE, - success: false, - page: this, - lastRow: null + type: AgMenuItemComponent.EVENT_MENU_ITEM_ACTIVATED, + menuItem: this, }; this.dispatchEvent(event); }; - RowNodeBlock.prototype.populateWithRowData = function (rows) { - var _this = this; - var rowNodesToRefresh = []; - this.rowNodes.forEach(function (rowNode, index) { - var data = rows[index]; - if (rowNode.stub) { - rowNodesToRefresh.push(rowNode); - } - _this.setDataAndId(rowNode, data, _this.startRow + index); - }); - if (rowNodesToRefresh.length > 0) { - this.beans.rowRenderer.redrawRows(rowNodesToRefresh); + AgMenuItemComponent.prototype.cancelActivate = function () { + if (this.activateTimeoutId) { + window.clearTimeout(this.activateTimeoutId); + this.activateTimeoutId = 0; + } + }; + AgMenuItemComponent.prototype.cancelDeactivate = function () { + if (this.deactivateTimeoutId) { + window.clearTimeout(this.deactivateTimeoutId); + this.deactivateTimeoutId = 0; } }; - RowNodeBlock.prototype.destroyRowNodes = function () { + AgMenuItemComponent.prototype.onMouseEnter = function () { var _this = this; - this.rowNodes.forEach(function (rowNode) { - if (rowNode.childrenCache) { - _this.destroyBean(rowNode.childrenCache); - rowNode.childrenCache = null; - } - // this is needed, so row render knows to fade out the row, otherwise it - // sees row top is present, and thinks the row should be shown. maybe - // rowNode should have a flag on whether it is visible??? - rowNode.clearRowTop(); - }); + this.cancelDeactivate(); + if (this.params.isAnotherSubMenuOpen()) { + // wait to see if the user enters the open sub-menu + this.activateTimeoutId = window.setTimeout(function () { return _this.activate(true); }, AgMenuItemComponent.ACTIVATION_DELAY); + } + else { + // activate immediately + this.activate(true); + } }; - RowNodeBlock.prototype.pageLoaded = function (version, rows, lastRow) { - // we need to check the version, in case there was an old request - // from the server that was sent before we refreshed the cache, - // if the load was done as a result of a cache refresh - if (version === this.version) { - this.state = RowNodeBlock.STATE_LOADED; - this.populateWithRowData(rows); + AgMenuItemComponent.prototype.onMouseLeave = function () { + var _this = this; + this.cancelActivate(); + if (this.isSubMenuOpen()) { + // wait to see if the user enters the sub-menu + this.deactivateTimeoutId = window.setTimeout(function () { return _this.deactivate(); }, AgMenuItemComponent.ACTIVATION_DELAY); + } + else { + // de-activate immediately + this.deactivate(); } - lastRow = _utils__WEBPACK_IMPORTED_MODULE_0__["_"].cleanNumber(lastRow); - // check here if lastRow should be set - var event = { - type: RowNodeBlock.EVENT_LOAD_COMPLETE, - success: true, - page: this, - lastRow: lastRow - }; - this.dispatchEvent(event); }; - RowNodeBlock.EVENT_LOAD_COMPLETE = 'loadComplete'; - RowNodeBlock.STATE_DIRTY = 'dirty'; - RowNodeBlock.STATE_LOADING = 'loading'; - RowNodeBlock.STATE_LOADED = 'loaded'; - RowNodeBlock.STATE_FAILED = 'failed'; + AgMenuItemComponent.prototype.getClassName = function (suffix) { + var prefix = this.params.isCompact ? 'ag-compact-menu-option' : 'ag-menu-option'; + return suffix ? prefix + "-" + suffix : prefix; + }; + AgMenuItemComponent.EVENT_MENU_ITEM_SELECTED = 'menuItemSelected'; + AgMenuItemComponent.EVENT_MENU_ITEM_ACTIVATED = 'menuItemActivated'; + AgMenuItemComponent.ACTIVATION_DELAY = 80; __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_2__["PreDestroy"] - ], RowNodeBlock.prototype, "destroyRowNodes", null); - return RowNodeBlock; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"])); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('popupService') + ], AgMenuItemComponent.prototype, "popupService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], AgMenuItemComponent.prototype, "init", null); + return AgMenuItemComponent; +}(_component__WEBPACK_IMPORTED_MODULE_3__["Component"])); /***/ }), -/* 197 */ +/* 247 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowNodeBlockLoader", function() { return RowNodeBlockLoader; }); -/* harmony import */ var _rowNodeBlock__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(196); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(41); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgMenuList", function() { return AgMenuList; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _agMenuItemComponent__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(246); +/* harmony import */ var _tabGuardComp__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(179); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(65); +/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(42); +/* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(18); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(44); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -43308,131 +52010,226 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); +var __assign = (undefined && undefined.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; -var __param = (undefined && undefined.__param) || function (paramIndex, decorator) { - return function (target, key) { decorator(target, key, paramIndex); } -}; -var RowNodeBlockLoader = /** @class */ (function (_super) { - __extends(RowNodeBlockLoader, _super); - function RowNodeBlockLoader(maxConcurrentRequests, blockLoadDebounceMillis) { - var _this = _super.call(this) || this; - _this.activeBlockLoadsCount = 0; - _this.blocks = []; - _this.active = true; - _this.maxConcurrentRequests = maxConcurrentRequests; - if (blockLoadDebounceMillis && blockLoadDebounceMillis > 0) { - _this.checkBlockToLoadDebounce = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].debounce(_this.performCheckBlocksToLoad.bind(_this), blockLoadDebounceMillis); - } + + + +var AgMenuList = /** @class */ (function (_super) { + __extends(AgMenuList, _super); + function AgMenuList(level) { + if (level === void 0) { level = 1; } + var _this = _super.call(this, /* html */ "
") || this; + _this.level = level; + _this.menuItems = []; return _this; } - RowNodeBlockLoader.prototype.setBeans = function (loggerFactory) { - this.logger = loggerFactory.create('RowNodeBlockLoader'); - }; - RowNodeBlockLoader.prototype.addBlock = function (block) { - this.blocks.push(block); - }; - RowNodeBlockLoader.prototype.removeBlock = function (block) { - _utils__WEBPACK_IMPORTED_MODULE_3__["_"].removeFromArray(this.blocks, block); - }; - RowNodeBlockLoader.prototype.destroy = function () { - _super.prototype.destroy.call(this); - this.active = false; + AgMenuList.prototype.postConstruct = function () { + var _this = this; + this.initialiseTabGuard({ + onTabKeyDown: function (e) { return _this.onTabKeyDown(e); }, + handleKeyDown: function (e) { return _this.handleKeyDown(e); } + }); }; - RowNodeBlockLoader.prototype.loadComplete = function () { - this.activeBlockLoadsCount--; + AgMenuList.prototype.onTabKeyDown = function (e) { + var parent = this.getParentComponent(); + var parentGui = parent && parent.getGui(); + var isManaged = parentGui && parentGui.classList.contains('ag-focus-managed'); + if (!isManaged) { + e.preventDefault(); + } + if (e.shiftKey) { + this.closeIfIsChild(e); + } }; - RowNodeBlockLoader.prototype.checkBlockToLoad = function () { - if (this.checkBlockToLoadDebounce) { - this.checkBlockToLoadDebounce(); + AgMenuList.prototype.handleKeyDown = function (e) { + switch (e.key) { + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].UP: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].RIGHT: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].DOWN: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].LEFT: + e.preventDefault(); + this.handleNavKey(e.key); + break; + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].ESCAPE: + var topMenu = this.findTopMenu(); + if (topMenu) { + this.focusService.focusInto(topMenu.getGui()); + } + break; } - else { - this.performCheckBlocksToLoad(); + }; + AgMenuList.prototype.clearActiveItem = function () { + if (this.activeMenuItem) { + this.activeMenuItem.deactivate(); + this.activeMenuItem = null; } }; - RowNodeBlockLoader.prototype.performCheckBlocksToLoad = function () { - if (!this.active) { + AgMenuList.prototype.addMenuItems = function (menuItems) { + var _this = this; + if (menuItems == null) { return; } - this.printCacheStatus(); - if (this.activeBlockLoadsCount >= this.maxConcurrentRequests) { - this.logger.log("checkBlockToLoad: max loads exceeded"); + menuItems.forEach(function (menuItemOrString) { + if (menuItemOrString === 'separator') { + _this.addSeparator(); + } + else if (typeof menuItemOrString === 'string') { + console.warn("AG Grid: unrecognised menu item " + menuItemOrString); + } + else { + _this.addItem(menuItemOrString); + } + }); + }; + AgMenuList.prototype.addItem = function (menuItemDef) { + var _this = this; + var menuItem = this.createManagedBean(new _agMenuItemComponent__WEBPACK_IMPORTED_MODULE_1__["AgMenuItemComponent"](__assign(__assign({}, menuItemDef), { isAnotherSubMenuOpen: function () { return _this.menuItems.some(function (m) { return m.isSubMenuOpen(); }); } }))); + menuItem.setParentComponent(this); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_6__["setAriaLevel"])(menuItem.getGui(), this.level); + this.menuItems.push(menuItem); + this.appendChild(menuItem.getGui()); + this.addManagedListener(menuItem, _agMenuItemComponent__WEBPACK_IMPORTED_MODULE_1__["AgMenuItemComponent"].EVENT_MENU_ITEM_SELECTED, function (event) { + _this.dispatchEvent(event); + }); + this.addManagedListener(menuItem, _agMenuItemComponent__WEBPACK_IMPORTED_MODULE_1__["AgMenuItemComponent"].EVENT_MENU_ITEM_ACTIVATED, function (event) { + if (_this.activeMenuItem && _this.activeMenuItem !== event.menuItem) { + _this.activeMenuItem.deactivate(); + } + _this.activeMenuItem = event.menuItem; + }); + }; + AgMenuList.prototype.activateFirstItem = function () { + var item = this.menuItems.filter(function (currentItem) { return !currentItem.isDisabled(); })[0]; + if (!item) { return; } - var blockToLoad = null; - this.blocks.forEach(function (block) { - if (block.getState() === _rowNodeBlock__WEBPACK_IMPORTED_MODULE_0__["RowNodeBlock"].STATE_DIRTY) { - blockToLoad = block; + item.activate(); + }; + AgMenuList.prototype.addSeparator = function () { + var separatorHtml = /* html */ "\n
\n
\n
\n
\n
\n
"; + this.appendChild(Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["loadTemplate"])(separatorHtml)); + }; + AgMenuList.prototype.findTopMenu = function () { + var parent = this.getParentComponent(); + if (!parent && this instanceof AgMenuList) { + return this; + } + while (true) { + var nextParent = parent && parent.getParentComponent && parent.getParentComponent(); + if (!nextParent || (!(nextParent instanceof AgMenuList || nextParent instanceof _agMenuItemComponent__WEBPACK_IMPORTED_MODULE_1__["AgMenuItemComponent"]))) { + break; } - }); - if (blockToLoad) { - blockToLoad.load(); - this.activeBlockLoadsCount++; - this.logger.log("checkBlockToLoad: loading page " + blockToLoad.getBlockNumber()); - this.printCacheStatus(); + parent = nextParent; + } + return parent instanceof AgMenuList ? parent : undefined; + }; + AgMenuList.prototype.handleNavKey = function (key) { + switch (key) { + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].UP: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].DOWN: + var nextItem = this.findNextItem(key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].UP); + if (nextItem && nextItem !== this.activeMenuItem) { + nextItem.activate(); + } + return; + } + var left = this.gridOptionsWrapper.isEnableRtl() ? _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].RIGHT : _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].LEFT; + if (key === left) { + this.closeIfIsChild(); } else { - this.logger.log("checkBlockToLoad: no pages to load"); + this.openChild(); } }; - RowNodeBlockLoader.prototype.getBlockState = function () { - var result = {}; - this.blocks.forEach(function (block) { - var nodeIdPrefix = block.getNodeIdPrefix(); - var stateItem = { - blockNumber: block.getBlockNumber(), - startRow: block.getStartRow(), - endRow: block.getEndRow(), - pageStatus: block.getState() - }; - if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(nodeIdPrefix)) { - result[nodeIdPrefix + block.getBlockNumber()] = stateItem; - } - else { - result[block.getBlockNumber()] = stateItem; + AgMenuList.prototype.closeIfIsChild = function (e) { + var parentItem = this.getParentComponent(); + if (parentItem && parentItem instanceof _agMenuItemComponent__WEBPACK_IMPORTED_MODULE_1__["AgMenuItemComponent"]) { + if (e) { + e.preventDefault(); } - }); - return result; + parentItem.closeSubMenu(); + parentItem.getGui().focus(); + } }; - RowNodeBlockLoader.prototype.printCacheStatus = function () { - if (this.logger.isLogging()) { - this.logger.log("printCacheStatus: activePageLoadsCount = " + this.activeBlockLoadsCount + "," - + (" blocks = " + JSON.stringify(this.getBlockState()))); + AgMenuList.prototype.openChild = function () { + if (this.activeMenuItem) { + this.activeMenuItem.openSubMenu(true); } }; - RowNodeBlockLoader.prototype.isLoading = function () { - return this.activeBlockLoadsCount > 0; + AgMenuList.prototype.findNextItem = function (up) { + var items = this.menuItems.filter(function (item) { return !item.isDisabled(); }); + if (!items.length) { + return; + } + if (!this.activeMenuItem) { + return up ? Object(_utils_array__WEBPACK_IMPORTED_MODULE_5__["last"])(items) : items[0]; + } + if (up) { + items.reverse(); + } + var nextItem; + var foundCurrent = false; + for (var i = 0; i < items.length; i++) { + var item = items[i]; + if (!foundCurrent) { + if (item === this.activeMenuItem) { + foundCurrent = true; + } + continue; + } + nextItem = item; + break; + } + return nextItem || this.activeMenuItem; + }; + AgMenuList.prototype.destroy = function () { + this.clearActiveItem(); + _super.prototype.destroy.call(this); }; __decorate([ - __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Qualifier"])('loggerFactory')) - ], RowNodeBlockLoader.prototype, "setBeans", null); - return RowNodeBlockLoader; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"])); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusService') + ], AgMenuList.prototype, "focusService", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], AgMenuList.prototype, "postConstruct", null); + return AgMenuList; +}(_tabGuardComp__WEBPACK_IMPORTED_MODULE_2__["TabGuardComp"])); /***/ }), -/* 198 */ +/* 248 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowNodeCache", function() { return RowNodeCache; }); -/* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(41); -/* harmony import */ var _rowNodeBlock__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(196); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgMenuPanel", function() { return AgMenuPanel; }); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(65); +/* harmony import */ var _tabGuardComp__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(179); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -43458,323 +52255,62 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta - -var RowNodeCache = /** @class */ (function (_super) { - __extends(RowNodeCache, _super); - function RowNodeCache(cacheParams) { +var AgMenuPanel = /** @class */ (function (_super) { + __extends(AgMenuPanel, _super); + function AgMenuPanel(wrappedComponent) { var _this = _super.call(this) || this; - _this.maxRowFound = false; - _this.blocks = {}; - _this.blockCount = 0; - _this.virtualRowCount = cacheParams.initialRowCount; - _this.cacheParams = cacheParams; + _this.wrappedComponent = wrappedComponent; + _this.setTemplateFromElement(wrappedComponent.getGui()); return _this; } - RowNodeCache.prototype.destroyAllBlocks = function () { + AgMenuPanel.prototype.postConstruct = function () { var _this = this; - this.forEachBlockInOrder(function (block) { return _this.destroyBlock(block); }); - }; - RowNodeCache.prototype.init = function () { - var _this = this; - this.active = true; - this.addDestroyFunc(function () { return _this.active = false; }); - }; - RowNodeCache.prototype.isActive = function () { - return this.active; - }; - RowNodeCache.prototype.getVirtualRowCount = function () { - return this.virtualRowCount; - }; - RowNodeCache.prototype.hack_setVirtualRowCount = function (virtualRowCount) { - this.virtualRowCount = virtualRowCount; - }; - RowNodeCache.prototype.isMaxRowFound = function () { - return this.maxRowFound; - }; - // listener on EVENT_LOAD_COMPLETE - RowNodeCache.prototype.onPageLoaded = function (event) { - this.cacheParams.rowNodeBlockLoader.loadComplete(); - this.checkBlockToLoad(); - // if we are not active, then we ignore all events, otherwise we could end up getting the - // grid to refresh even though we are no longer the active cache - if (!this.isActive()) { - return; - } - this.logger.log("onPageLoaded: page = " + event.page.getBlockNumber() + ", lastRow = " + event.lastRow); - if (event.success) { - this.checkVirtualRowCount(event.page, event.lastRow); - } - }; - RowNodeCache.prototype.purgeBlocksIfNeeded = function (blockToExclude) { - var _this = this; - // put all candidate blocks into a list for sorting - var blocksForPurging = []; - this.forEachBlockInOrder(function (block) { - // we exclude checking for the page just created, as this has yet to be accessed and hence - // the lastAccessed stamp will not be updated for the first time yet - if (block === blockToExclude) { - return; - } - blocksForPurging.push(block); - }); - // note: need to verify that this sorts items in the right order - blocksForPurging.sort(function (a, b) { return b.getLastAccessed() - a.getLastAccessed(); }); - // we remove (maxBlocksInCache - 1) as we already excluded the 'just created' page. - // in other words, after the splice operation below, we have taken out the blocks - // we want to keep, which means we are left with blocks that we can potentially purge - var maxBlocksProvided = this.cacheParams.maxBlocksInCache > 0; - var blocksToKeep = maxBlocksProvided ? this.cacheParams.maxBlocksInCache - 1 : null; - var emptyBlocksToKeep = RowNodeCache.MAX_EMPTY_BLOCKS_TO_KEEP - 1; - blocksForPurging.forEach(function (block, index) { - var purgeBecauseBlockEmpty = block.getState() === _rowNodeBlock__WEBPACK_IMPORTED_MODULE_1__["RowNodeBlock"].STATE_DIRTY && index >= emptyBlocksToKeep; - var purgeBecauseCacheFull = maxBlocksProvided ? index >= blocksToKeep : false; - if (purgeBecauseBlockEmpty || purgeBecauseCacheFull) { - // we never purge blocks if they are open, as purging them would mess up with - // our indexes, it would be very messy to restore the purged block to it's - // previous state if it had open children (and what if open children of open - // children, jeeeesus, just thinking about it freaks me out) so best is have a - // rule, if block is open, we never purge. - if (block.isAnyNodeOpen(_this.virtualRowCount)) { - return; - } - // if the block currently has rows been displayed, then don't remove it either. - // this can happen if user has maxBlocks=2, and blockSize=5 (thus 10 max rows in cache) - // but the screen is showing 20 rows, so at least 4 blocks are needed. - if (_this.isBlockCurrentlyDisplayed(block)) { - return; - } - // at this point, block is not needed, and no open nodes, so burn baby burn - _this.removeBlockFromCache(block); - } + this.initialiseTabGuard({ + onTabKeyDown: function (e) { return _this.onTabKeyDown(e); }, + handleKeyDown: function (e) { return _this.handleKeyDown(e); } }); }; - RowNodeCache.prototype.isBlockCurrentlyDisplayed = function (block) { - var firstViewportRow = this.rowRenderer.getFirstVirtualRenderedRow(); - var lastViewportRow = this.rowRenderer.getLastVirtualRenderedRow(); - var firstRowIndex = block.getDisplayIndexStart(); - var lastRowIndex = block.getDisplayIndexEnd() - 1; - // parent closed means the parent node is not expanded, thus these blocks are not visible - var parentClosed = firstRowIndex == null || lastRowIndex == null; - if (parentClosed) { - return false; + AgMenuPanel.prototype.handleKeyDown = function (e) { + if (e.key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_1__["KeyCode"].ESCAPE) { + this.closePanel(); } - var blockBeforeViewport = firstRowIndex > lastViewportRow; - var blockAfterViewport = lastRowIndex < firstViewportRow; - var blockInsideViewport = !blockBeforeViewport && !blockAfterViewport; - return blockInsideViewport; - }; - RowNodeCache.prototype.postCreateBlock = function (newBlock) { - newBlock.addEventListener(_rowNodeBlock__WEBPACK_IMPORTED_MODULE_1__["RowNodeBlock"].EVENT_LOAD_COMPLETE, this.onPageLoaded.bind(this)); - this.setBlock(newBlock.getBlockNumber(), newBlock); - this.purgeBlocksIfNeeded(newBlock); - this.checkBlockToLoad(); }; - RowNodeCache.prototype.removeBlockFromCache = function (blockToRemove) { - if (!blockToRemove) { + AgMenuPanel.prototype.onTabKeyDown = function (e) { + if (e.defaultPrevented) { return; } - this.destroyBlock(blockToRemove); - // we do not want to remove the 'loaded' event listener, as the - // concurrent loads count needs to be updated when the load is complete - // if the purged page is in loading state - }; - // gets called after: 1) block loaded 2) block created 3) cache refresh - RowNodeCache.prototype.checkBlockToLoad = function () { - this.cacheParams.rowNodeBlockLoader.checkBlockToLoad(); - }; - RowNodeCache.prototype.checkVirtualRowCount = function (block, lastRow) { - // if client provided a last row, we always use it, as it could change between server calls - // if user deleted data and then called refresh on the grid. - if (typeof lastRow === 'number' && lastRow >= 0) { - this.virtualRowCount = lastRow; - this.maxRowFound = true; - this.onCacheUpdated(); - } - else if (!this.maxRowFound) { - // otherwise, see if we need to add some virtual rows - var lastRowIndex = (block.getBlockNumber() + 1) * this.cacheParams.blockSize; - var lastRowIndexPlusOverflow = lastRowIndex + this.cacheParams.overflowSize; - if (this.virtualRowCount < lastRowIndexPlusOverflow) { - this.virtualRowCount = lastRowIndexPlusOverflow; - this.onCacheUpdated(); - } - else if (this.cacheParams.dynamicRowHeight) { - // the only other time is if dynamic row height, as loading rows - // will change the height of the block, given the height of the rows - // is only known after the row is loaded. - this.onCacheUpdated(); - } - } - }; - RowNodeCache.prototype.setVirtualRowCount = function (rowCount, maxRowFound) { - this.virtualRowCount = rowCount; - // if undefined is passed, we do not set this value, if one of {true,false} - // is passed, we do set the value. - if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(maxRowFound)) { - this.maxRowFound = maxRowFound; - } - // if we are still searching, then the row count must not end at the end - // of a particular page, otherwise the searching will not pop into the - // next page - if (!this.maxRowFound) { - if (this.virtualRowCount % this.cacheParams.blockSize === 0) { - this.virtualRowCount++; - } - } - this.onCacheUpdated(); - }; - RowNodeCache.prototype.forEachNodeDeep = function (callback, sequence) { - var _this = this; - if (sequence === void 0) { sequence = new _utils__WEBPACK_IMPORTED_MODULE_2__["NumberSequence"](); } - this.forEachBlockInOrder(function (block) { - block.forEachNodeDeep(callback, sequence, _this.virtualRowCount); - }); - }; - RowNodeCache.prototype.forEachBlockInOrder = function (callback) { - var ids = this.getBlockIdsSorted(); - this.forEachBlockId(ids, callback); - }; - RowNodeCache.prototype.forEachBlockInReverseOrder = function (callback) { - var ids = this.getBlockIdsSorted().reverse(); - this.forEachBlockId(ids, callback); - }; - RowNodeCache.prototype.forEachBlockId = function (ids, callback) { - var _this = this; - ids.forEach(function (id) { - var block = _this.blocks[id]; - callback(block, id); - }); - }; - RowNodeCache.prototype.getBlockIdsSorted = function () { - // get all page id's as NUMBERS (not strings, as we need to sort as numbers) and in descending order - var numberComparator = function (a, b) { return a - b; }; // default comparator for array is string comparison - var blockIds = Object.keys(this.blocks).map(function (idStr) { return parseInt(idStr, 10); }).sort(numberComparator); - return blockIds; - }; - RowNodeCache.prototype.getBlock = function (blockId) { - return this.blocks[blockId]; - }; - RowNodeCache.prototype.setBlock = function (id, block) { - this.blocks[id] = block; - this.blockCount++; - this.cacheParams.rowNodeBlockLoader.addBlock(block); - }; - RowNodeCache.prototype.destroyBlock = function (block) { - delete this.blocks[block.getBlockNumber()]; - this.destroyBean(block); - this.blockCount--; - this.cacheParams.rowNodeBlockLoader.removeBlock(block); - }; - // gets called 1) row count changed 2) cache purged 3) items inserted - RowNodeCache.prototype.onCacheUpdated = function () { - if (this.isActive()) { - // if the virtualRowCount is shortened, then it's possible blocks exist that are no longer - // in the valid range. so we must remove these. this can happen if user explicitly sets - // the virtual row count, or the datasource returns a result and sets lastRow to something - // less than virtualRowCount (can happen if user scrolls down, server reduces dataset size). - this.destroyAllBlocksPastVirtualRowCount(); - // this results in both row models (infinite and server side) firing ModelUpdated, - // however server side row model also updates the row indexes first - var event_1 = { - type: RowNodeCache.EVENT_CACHE_UPDATED - }; - this.dispatchEvent(event_1); - } - }; - RowNodeCache.prototype.destroyAllBlocksPastVirtualRowCount = function () { - var _this = this; - var blocksToDestroy = []; - this.forEachBlockInOrder(function (block, id) { - var startRow = id * _this.cacheParams.blockSize; - if (startRow >= _this.virtualRowCount) { - blocksToDestroy.push(block); - } - }); - if (blocksToDestroy.length > 0) { - blocksToDestroy.forEach(function (block) { return _this.destroyBlock(block); }); - } - }; - RowNodeCache.prototype.purgeCache = function () { - var _this = this; - this.forEachBlockInOrder(function (block) { return _this.removeBlockFromCache(block); }); - this.maxRowFound = false; - // if zero rows in the cache, we need to get the SSRM to start asking for rows again. - // otherwise if set to zero rows last time, and we don't update the row count, then after - // the purge there will still be zero rows, meaning the SRRM won't request any rows. - // to kick things off, at lest one row needs to be asked for. - if (this.virtualRowCount === 0) { - this.virtualRowCount = this.cacheParams.initialRowCount; - } - this.onCacheUpdated(); + this.closePanel(); + e.preventDefault(); }; - RowNodeCache.prototype.getRowNodesInRange = function (firstInRange, lastInRange) { - var _this = this; - var result = []; - var lastBlockId = -1; - var inActiveRange = false; - var numberSequence = new _utils__WEBPACK_IMPORTED_MODULE_2__["NumberSequence"](); - // if only one node passed, we start the selection at the top - if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].missing(firstInRange)) { - inActiveRange = true; - } - var foundGapInSelection = false; - this.forEachBlockInOrder(function (block, id) { - if (foundGapInSelection) { - return; - } - if (inActiveRange && (lastBlockId + 1 !== id)) { - foundGapInSelection = true; - return; - } - lastBlockId = id; - block.forEachNodeShallow(function (rowNode) { - var hitFirstOrLast = rowNode === firstInRange || rowNode === lastInRange; - if (inActiveRange || hitFirstOrLast) { - result.push(rowNode); - } - if (hitFirstOrLast) { - inActiveRange = !inActiveRange; - } - }, numberSequence, _this.virtualRowCount); - }); - // inActiveRange will be still true if we never hit the second rowNode - var invalidRange = foundGapInSelection || inActiveRange; - return invalidRange ? [] : result; + AgMenuPanel.prototype.closePanel = function () { + var menuItem = this.parentComponent; + menuItem.closeSubMenu(); + setTimeout(function () { return menuItem.getGui().focus(); }, 0); }; - RowNodeCache.EVENT_CACHE_UPDATED = 'cacheUpdated'; - // this property says how many empty blocks should be in a cache, eg if scrolls down fast and creates 10 - // blocks all for loading, the grid will only load the last 2 - it will assume the blocks the user quickly - // scrolled over are not needed to be loaded. - RowNodeCache.MAX_EMPTY_BLOCKS_TO_KEEP = 2; - __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('rowRenderer') - ], RowNodeCache.prototype, "rowRenderer", void 0); __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_3__["PreDestroy"] - ], RowNodeCache.prototype, "destroyAllBlocks", null); - __decorate([ - _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"] - ], RowNodeCache.prototype, "init", null); - return RowNodeCache; -}(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], AgMenuPanel.prototype, "postConstruct", null); + return AgMenuPanel; +}(_tabGuardComp__WEBPACK_IMPORTED_MODULE_2__["TabGuardComp"])); /***/ }), -/* 199 */ +/* 249 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "VirtualList", function() { return VirtualList; }); -/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37); +/* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12); /* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57); -/* harmony import */ var _managedFocusComponent__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(117); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7); +/* harmony import */ var _utils_aria__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(44); +/* harmony import */ var _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(65); +/* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(14); +/* harmony import */ var _tabGuardComp__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(179); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ @@ -43802,58 +52338,87 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta + var VirtualList = /** @class */ (function (_super) { __extends(VirtualList, _super); - function VirtualList(cssIdentifier) { + function VirtualList(cssIdentifier, ariaRole, listName) { if (cssIdentifier === void 0) { cssIdentifier = 'default'; } + if (ariaRole === void 0) { ariaRole = 'listbox'; } var _this = _super.call(this, VirtualList.getTemplate(cssIdentifier)) || this; _this.cssIdentifier = cssIdentifier; + _this.ariaRole = ariaRole; + _this.listName = listName; _this.renderedRows = new Map(); _this.rowHeight = 20; + _this.isDestroyed = false; return _this; } VirtualList.prototype.postConstruct = function () { + var _this = this; this.addScrollListener(); this.rowHeight = this.getItemHeight(); - _super.prototype.postConstruct.call(this); + this.addResizeObserver(); + this.initialiseTabGuard({ + onFocusIn: function (e) { return _this.onFocusIn(e); }, + onFocusOut: function (e) { return _this.onFocusOut(e); }, + focusInnerElement: function (fromBottom) { return _this.focusInnerElement(fromBottom); }, + onTabKeyDown: function (e) { return _this.onTabKeyDown(e); }, + handleKeyDown: function (e) { return _this.handleKeyDown(e); } + }); + this.setAriaProperties(); }; - VirtualList.prototype.isFocusableContainer = function () { - return true; + VirtualList.prototype.setAriaProperties = function () { + var translate = this.gridOptionsWrapper.getLocaleTextFunc(); + var listName = translate('ariaDefaultListName', this.listName || 'List'); + var ariaEl = this.eContainer; + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_2__["setAriaRole"])(ariaEl, this.ariaRole); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_2__["setAriaLabel"])(ariaEl, listName); + }; + VirtualList.prototype.addResizeObserver = function () { + var listener = this.drawVirtualRows.bind(this); + var destroyObserver = this.resizeObserverService.observeResize(this.getGui(), listener); + this.addDestroyFunc(destroyObserver); }; VirtualList.prototype.focusInnerElement = function (fromBottom) { - var rowCount = this.model.getRowCount(); - this.focusRow(fromBottom ? rowCount - 1 : 0); + this.focusRow(fromBottom ? this.model.getRowCount() - 1 : 0); }; VirtualList.prototype.onFocusIn = function (e) { - _super.prototype.onFocusIn.call(this, e); var target = e.target; - if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].containsClass(target, 'ag-virtual-list-item')) { - this.lastFocusedRow = parseInt(target.getAttribute('aria-rowindex'), 10) - 1; + if (target.classList.contains('ag-virtual-list-item')) { + this.lastFocusedRowIndex = Object(_utils_aria__WEBPACK_IMPORTED_MODULE_2__["getAriaPosInSet"])(target) - 1; } + return false; }; VirtualList.prototype.onFocusOut = function (e) { - _super.prototype.onFocusOut.call(this, e); if (!this.getFocusableElement().contains(e.relatedTarget)) { - this.lastFocusedRow = null; + this.lastFocusedRowIndex = null; } + return false; }; VirtualList.prototype.handleKeyDown = function (e) { - switch (e.keyCode) { - case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_UP: - case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_DOWN: - case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_TAB: - if (this.navigate(e.keyCode === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_UP || - (e.keyCode === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_TAB && e.shiftKey))) { + switch (e.key) { + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].UP: + case _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].DOWN: + if (this.navigate(e.key === _constants_keyCode__WEBPACK_IMPORTED_MODULE_3__["KeyCode"].UP)) { e.preventDefault(); } break; } }; + VirtualList.prototype.onTabKeyDown = function (e) { + if (this.navigate(e.shiftKey)) { + e.preventDefault(); + } + else { + // focus on the first or last focusable element to ensure that any other handlers start from there + this.focusService.focusInto(this.getGui(), !e.shiftKey); + } + }; VirtualList.prototype.navigate = function (up) { - if (!_utils__WEBPACK_IMPORTED_MODULE_4__["_"].exists(this.lastFocusedRow)) { + if (this.lastFocusedRowIndex == null) { return false; } - var nextRow = this.lastFocusedRow + (up ? -1 : 1); + var nextRow = this.lastFocusedRowIndex + (up ? -1 : 1); if (nextRow < 0 || nextRow >= this.model.getRowCount()) { return false; } @@ -43861,7 +52426,7 @@ var VirtualList = /** @class */ (function (_super) { return true; }; VirtualList.prototype.getLastFocusedRow = function () { - return this.lastFocusedRow; + return this.lastFocusedRowIndex; }; VirtualList.prototype.focusRow = function (rowNumber) { var _this = this; @@ -43878,7 +52443,7 @@ var VirtualList = /** @class */ (function (_super) { return comp && comp.rowComponent; }; VirtualList.getTemplate = function (cssIdentifier) { - return /* html */ "\n
\n
\n
"; + return /* html */ "\n
\n
\n
"; }; VirtualList.prototype.getItemHeight = function () { return this.gridOptionsWrapper.getListItemHeight(); @@ -43886,7 +52451,7 @@ var VirtualList = /** @class */ (function (_super) { VirtualList.prototype.ensureIndexVisible = function (index) { var lastRow = this.model.getRowCount(); if (typeof index !== 'number' || index < 0 || index >= lastRow) { - console.warn('invalid row index for ensureIndexVisible: ' + index); + console.warn('AG Grid: invalid row index for ensureIndexVisible: ' + index); return; } var rowTopPixel = index * this.rowHeight; @@ -43922,17 +52487,19 @@ var VirtualList = /** @class */ (function (_super) { }; VirtualList.prototype.refresh = function () { var _this = this; - if (this.model == null) { + if (this.model == null || this.isDestroyed) { return; } var rowCount = this.model.getRowCount(); this.eContainer.style.height = rowCount * this.rowHeight + "px"; - this.eContainer.setAttribute('aria-rowcount', rowCount.toString()); // ensure height is applied before attempting to redraw rows - setTimeout(function () { + Object(_utils_function__WEBPACK_IMPORTED_MODULE_4__["waitUntil"])(function () { return _this.eContainer.clientHeight >= rowCount * _this.rowHeight; }, function () { + if (_this.isDestroyed) { + return; + } _this.clearVirtualRows(); _this.drawVirtualRows(); - }, 0); + }); }; VirtualList.prototype.clearVirtualRows = function () { var _this = this; @@ -43950,7 +52517,7 @@ var VirtualList = /** @class */ (function (_super) { var _this = this; // remove any rows that are no longer required this.renderedRows.forEach(function (_, rowIndex) { - if ((rowIndex < start || rowIndex > finish) && rowIndex !== _this.lastFocusedRow) { + if ((rowIndex < start || rowIndex > finish) && rowIndex !== _this.lastFocusedRowIndex) { _this.removeRow(rowIndex); } }); @@ -43961,22 +52528,39 @@ var VirtualList = /** @class */ (function (_super) { } // check this row actually exists (in case overflow buffer window exceeds real data) if (rowIndex < this.model.getRowCount()) { - var value = this.model.getRow(rowIndex); - this.insertRow(value, rowIndex); + this.insertRow(rowIndex); } } }; - VirtualList.prototype.insertRow = function (value, rowIndex) { + VirtualList.prototype.insertRow = function (rowIndex) { + var _this = this; + var value = this.model.getRow(rowIndex); var eDiv = document.createElement('div'); - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(eDiv, 'ag-virtual-list-item'); - _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(eDiv, "ag-" + this.cssIdentifier + "-virtual-list-item"); - eDiv.setAttribute('aria-rowindex', (rowIndex + 1).toString()); + eDiv.classList.add('ag-virtual-list-item', "ag-" + this.cssIdentifier + "-virtual-list-item"); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_2__["setAriaRole"])(eDiv, this.ariaRole === 'tree' ? 'treeitem' : 'option'); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_2__["setAriaSetSize"])(eDiv, this.model.getRowCount()); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_2__["setAriaPosInSet"])(eDiv, rowIndex + 1); eDiv.setAttribute('tabindex', '-1'); + if (typeof this.model.isRowSelected === 'function') { + var isSelected = this.model.isRowSelected(rowIndex); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_2__["setAriaSelected"])(eDiv, !!isSelected); + Object(_utils_aria__WEBPACK_IMPORTED_MODULE_2__["setAriaChecked"])(eDiv, isSelected); + } eDiv.style.height = this.rowHeight + "px"; eDiv.style.top = this.rowHeight * rowIndex + "px"; - var rowComponent = this.componentCreator(value); + var rowComponent = this.componentCreator(value, eDiv); + rowComponent.addGuiEventListener('focusin', function () { return _this.lastFocusedRowIndex = rowIndex; }); eDiv.appendChild(rowComponent.getGui()); - this.eContainer.appendChild(eDiv); + // keep the DOM order consistent with the order of the rows + if (this.renderedRows.has(rowIndex - 1)) { + this.renderedRows.get(rowIndex - 1).eDiv.insertAdjacentElement('afterend', eDiv); + } + else if (this.renderedRows.has(rowIndex + 1)) { + this.renderedRows.get(rowIndex + 1).eDiv.insertAdjacentElement('beforebegin', eDiv); + } + else { + this.eContainer.appendChild(eDiv); + } this.renderedRows.set(rowIndex, { rowComponent: rowComponent, eDiv: eDiv }); }; VirtualList.prototype.removeRow = function (rowIndex) { @@ -43992,44 +52576,58 @@ var VirtualList = /** @class */ (function (_super) { VirtualList.prototype.setModel = function (model) { this.model = model; }; + VirtualList.prototype.destroy = function () { + if (this.isDestroyed) { + return; + } + this.clearVirtualRows(); + this.isDestroyed = true; + _super.prototype.destroy.call(this); + }; __decorate([ - Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], VirtualList.prototype, "gridOptionsWrapper", void 0); + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('resizeObserverService') + ], VirtualList.prototype, "resizeObserverService", void 0); + __decorate([ + Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusService') + ], VirtualList.prototype, "focusService", void 0); __decorate([ Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eContainer') ], VirtualList.prototype, "eContainer", void 0); + __decorate([ + _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], VirtualList.prototype, "postConstruct", null); return VirtualList; -}(_managedFocusComponent__WEBPACK_IMPORTED_MODULE_2__["ManagedFocusComponent"])); +}(_tabGuardComp__WEBPACK_IMPORTED_MODULE_5__["TabGuardComp"])); /***/ }), -/* 200 */ +/* 250 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "defaultGroupComparator", function() { return defaultGroupComparator; }); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7); +/* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ function defaultGroupComparator(valueA, valueB, nodeA, nodeB, accentedCompare) { if (accentedCompare === void 0) { accentedCompare = false; } - console.warn('ag-Grid: Since ag-grid 11.0.0 defaultGroupComparator is not necessary. You can remove this from your colDef'); - var nodeAIsGroup = _utils__WEBPACK_IMPORTED_MODULE_0__["_"].exists(nodeA) && nodeA.group; - var nodeBIsGroup = _utils__WEBPACK_IMPORTED_MODULE_0__["_"].exists(nodeB) && nodeB.group; + console.warn('AG Grid: Since ag-grid 11.0.0 defaultGroupComparator is not necessary. You can remove this from your colDef'); + var nodeAIsGroup = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_0__["exists"])(nodeA) && nodeA.group; + var nodeBIsGroup = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_0__["exists"])(nodeB) && nodeB.group; var bothAreGroups = nodeAIsGroup && nodeBIsGroup; var bothAreNormal = !nodeAIsGroup && !nodeBIsGroup; if (bothAreGroups) { - return _utils__WEBPACK_IMPORTED_MODULE_0__["_"].defaultComparator(nodeA.key, nodeB.key, accentedCompare); + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_0__["defaultComparator"])(nodeA.key, nodeB.key, accentedCompare); } if (bothAreNormal) { - return _utils__WEBPACK_IMPORTED_MODULE_0__["_"].defaultComparator(valueA, valueB, accentedCompare); + return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_0__["defaultComparator"])(valueA, valueB, accentedCompare); } if (nodeAIsGroup) { return 1; @@ -44039,25 +52637,25 @@ function defaultGroupComparator(valueA, valueB, nodeA, nodeB, accentedCompare) { /***/ }), -/* 201 */ +/* 251 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BaseComponentWrapper", function() { return BaseComponentWrapper; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ var BaseComponentWrapper = /** @class */ (function () { function BaseComponentWrapper() { } - BaseComponentWrapper.prototype.wrap = function (OriginalConstructor, mandatoryMethodList, optionalMethodList, componentType, componentName) { + BaseComponentWrapper.prototype.wrap = function (OriginalConstructor, mandatoryMethodList, optionalMethodList, componentType) { var _this = this; if (optionalMethodList === void 0) { optionalMethodList = []; } - var wrapper = this.createWrapper(OriginalConstructor, componentType, componentName); + var wrapper = this.createWrapper(OriginalConstructor, componentType); mandatoryMethodList.forEach((function (methodName) { _this.createMethod(wrapper, methodName, true); })); @@ -44066,6 +52664,9 @@ var BaseComponentWrapper = /** @class */ (function () { })); return wrapper; }; + BaseComponentWrapper.prototype.unwrap = function (comp) { + return comp; + }; BaseComponentWrapper.prototype.createMethod = function (wrapper, methodName, mandatory) { wrapper.addMethod(methodName, this.createMethodProxy(wrapper, methodName, mandatory)); }; @@ -44075,7 +52676,7 @@ var BaseComponentWrapper = /** @class */ (function () { return wrapper.callMethod(methodName, arguments); } if (mandatory) { - console.warn('ag-Grid: Framework component is missing the method ' + methodName + '()'); + console.warn('AG Grid: Framework component is missing the method ' + methodName + '()'); } return null; }; @@ -44086,55 +52687,36 @@ var BaseComponentWrapper = /** @class */ (function () { /***/ }), -/* 202 */ +/* 252 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ChartType", function() { return ChartType; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LegendPosition", function() { return LegendPosition; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BarColumnLabelPlacement", function() { return BarColumnLabelPlacement; }); /** - * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -var ChartType; -(function (ChartType) { - ChartType["GroupedColumn"] = "groupedColumn"; - ChartType["StackedColumn"] = "stackedColumn"; - ChartType["NormalizedColumn"] = "normalizedColumn"; - ChartType["GroupedBar"] = "groupedBar"; - ChartType["StackedBar"] = "stackedBar"; - ChartType["NormalizedBar"] = "normalizedBar"; - ChartType["Line"] = "line"; - ChartType["Scatter"] = "scatter"; - ChartType["Bubble"] = "bubble"; - ChartType["Pie"] = "pie"; - ChartType["Doughnut"] = "doughnut"; - ChartType["Area"] = "area"; - ChartType["StackedArea"] = "stackedArea"; - ChartType["NormalizedArea"] = "normalizedArea"; - ChartType["Histogram"] = "histogram"; -})(ChartType || (ChartType = {})); -var LegendPosition; -(function (LegendPosition) { - LegendPosition["Top"] = "top"; - LegendPosition["Right"] = "right"; - LegendPosition["Bottom"] = "bottom"; - LegendPosition["Left"] = "left"; -})(LegendPosition || (LegendPosition = {})); +var BarColumnLabelPlacement; +(function (BarColumnLabelPlacement) { + BarColumnLabelPlacement["InsideBase"] = "insideBase"; + BarColumnLabelPlacement["InsideEnd"] = "insideEnd"; + BarColumnLabelPlacement["Center"] = "center"; + BarColumnLabelPlacement["OutsideEnd"] = "outsideEnd"; +})(BarColumnLabelPlacement || (BarColumnLabelPlacement = {})); /***/ }), -/* 203 */ +/* 253 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ClientSideRowModel", function() { return ClientSideRowModel; }); /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3); -/* harmony import */ var _clientSideNodeManager__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(204); +/* harmony import */ var _clientSideNodeManager__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(254); var __extends = (undefined && undefined.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || @@ -44169,26 +52751,30 @@ var ClientSideRowModel = /** @class */ (function (_super) { return _super !== null && _super.apply(this, arguments) || this; } ClientSideRowModel.prototype.init = function () { - var refreshEverythingFunc = this.refreshModel.bind(this, { step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_EVERYTHING }); - var refreshEverythingAfterColsChangedFunc = this.refreshModel.bind(this, { step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_EVERYTHING, afterColumnsChanged: true, keepRenderedRows: true }); - this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_EVERYTHING_CHANGED, refreshEverythingAfterColsChangedFunc); + var refreshEverythingFunc = this.refreshModel.bind(this, { step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].EVERYTHING }); + var animate = !this.gridOptionsWrapper.isSuppressAnimationFrame(); + var refreshEverythingAfterColsChangedFunc = this.refreshModel.bind(this, { + step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].EVERYTHING, + afterColumnsChanged: true, + keepRenderedRows: true, + animate: animate + }); + this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_NEW_COLUMNS_LOADED, refreshEverythingAfterColsChangedFunc); this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, refreshEverythingFunc); this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_VALUE_CHANGED, this.onValueChanged.bind(this)); - this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PIVOT_CHANGED, this.refreshModel.bind(this, { step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_PIVOT })); - this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_ROW_GROUP_OPENED, this.onRowGroupOpened.bind(this)); + this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PIVOT_CHANGED, this.refreshModel.bind(this, { step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].PIVOT })); this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_FILTER_CHANGED, this.onFilterChanged.bind(this)); this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_SORT_CHANGED, this.onSortChanged.bind(this)); this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PIVOT_MODE_CHANGED, refreshEverythingFunc); var refreshMapListener = this.refreshModel.bind(this, { - step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_MAP, + step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].MAP, keepRenderedRows: true, - animate: true + animate: animate }); this.addManagedListener(this.gridOptionsWrapper, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GROUP_REMOVE_SINGLE_CHILDREN, refreshMapListener); this.addManagedListener(this.gridOptionsWrapper, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GROUP_REMOVE_LOWEST_SINGLE_CHILDREN, refreshMapListener); - this.rootNode = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNode"](); - this.nodeManager = new _clientSideNodeManager__WEBPACK_IMPORTED_MODULE_1__["ClientSideNodeManager"](this.rootNode, this.gridOptionsWrapper, this.getContext(), this.eventService, this.columnController, this.gridApi, this.columnApi, this.selectionController); - this.createBean(this.rootNode); + this.rootNode = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNode"](this.beans); + this.nodeManager = new _clientSideNodeManager__WEBPACK_IMPORTED_MODULE_1__["ClientSideNodeManager"](this.rootNode, this.gridOptionsWrapper, this.eventService, this.columnModel, this.gridApi, this.columnApi, this.selectionService, this.beans); }; ClientSideRowModel.prototype.start = function () { var rowData = this.gridOptionsWrapper.getRowData(); @@ -44219,50 +52805,65 @@ var ClientSideRowModel = /** @class */ (function (_super) { } } if (atLeastOneChange) { - this.setRowTops(); + this.setRowTopAndRowIndex(); } } while (atLeastOneChange); return res; }; - ClientSideRowModel.prototype.setRowTops = function () { + ClientSideRowModel.prototype.setRowTopAndRowIndex = function () { + var defaultRowHeight = this.gridOptionsWrapper.getDefaultRowHeight(); var nextRowTop = 0; + // mapping displayed rows is not needed for this method, however it's used in + // clearRowTopAndRowIndex(), and given we are looping through this.rowsToDisplay here, + // we create the map here for performance reasons, so we don't loop a second time + // in clearRowTopAndRowIndex() + var displayedRowsMapped = new Set(); + // we don't estimate if doing fullHeight or autoHeight, as all rows get rendered all the time + // with these two layouts. + var allowEstimate = this.gridOptionsWrapper.getDomLayout() === _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].DOM_LAYOUT_NORMAL; for (var i = 0; i < this.rowsToDisplay.length; i++) { - // we don't estimate if doing fullHeight or autoHeight, as all rows get rendered all the time - // with these two layouts. - var allowEstimate = this.gridOptionsWrapper.getDomLayout() === _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].DOM_LAYOUT_NORMAL; var rowNode = this.rowsToDisplay[i]; - if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(rowNode.rowHeight)) { - var rowHeight = this.gridOptionsWrapper.getRowHeightForNode(rowNode, allowEstimate); + if (rowNode.id != null) { + displayedRowsMapped.add(rowNode.id); + } + if (rowNode.rowHeight == null) { + var rowHeight = this.gridOptionsWrapper.getRowHeightForNode(rowNode, allowEstimate, defaultRowHeight); rowNode.setRowHeight(rowHeight.height, rowHeight.estimated); } rowNode.setRowTop(nextRowTop); rowNode.setRowIndex(i); nextRowTop += rowNode.rowHeight; } + return displayedRowsMapped; }; - ClientSideRowModel.prototype.resetRowTops = function (rowNode, changedPath) { - rowNode.clearRowTop(); - if (rowNode.hasChildren()) { - if (rowNode.childrenAfterGroup) { - // if a changedPath is active, it means we are here because of a transaction update or - // a change detection. neither of these impacts the open/closed state of groups. so if - // a group is not open this time, it was not open last time. so we know all closed groups - // already have their top positions cleared. so there is no need to traverse all the way - // when changedPath is active and the rowNode is not expanded. - var skipChildren = changedPath.isActive() && !rowNode.expanded; - if (!skipChildren) { - for (var i = 0; i < rowNode.childrenAfterGroup.length; i++) { - this.resetRowTops(rowNode.childrenAfterGroup[i], changedPath); + ClientSideRowModel.prototype.clearRowTopAndRowIndex = function (changedPath, displayedRowsMapped) { + var changedPathActive = changedPath.isActive(); + var clearIfNotDisplayed = function (rowNode) { + if (rowNode && rowNode.id != null && !displayedRowsMapped.has(rowNode.id)) { + rowNode.clearRowTopAndRowIndex(); + } + }; + var recurse = function (rowNode) { + clearIfNotDisplayed(rowNode); + clearIfNotDisplayed(rowNode.detailNode); + clearIfNotDisplayed(rowNode.sibling); + if (rowNode.hasChildren()) { + if (rowNode.childrenAfterGroup) { + // if a changedPath is active, it means we are here because of a transaction update or + // a change detection. neither of these impacts the open/closed state of groups. so if + // a group is not open this time, it was not open last time. so we know all closed groups + // already have their top positions cleared. so there is no need to traverse all the way + // when changedPath is active and the rowNode is not expanded. + var isRootNode = rowNode.level == -1; // we need to give special consideration for root node, + // as expanded=undefined for root node + var skipChildren = changedPathActive && !isRootNode && !rowNode.expanded; + if (!skipChildren) { + rowNode.childrenAfterGroup.forEach(recurse); } } } - if (rowNode.sibling) { - rowNode.sibling.clearRowTop(); - } - } - if (rowNode.detailNode) { - rowNode.detailNode.clearRowTop(); - } + }; + recurse(this.rootNode); }; // returns false if row was moved, otherwise true ClientSideRowModel.prototype.ensureRowsAtPixel = function (rowNodes, pixel, increment) { @@ -44270,6 +52871,7 @@ var ClientSideRowModel = /** @class */ (function (_super) { if (increment === void 0) { increment = 0; } var indexAtPixelNow = this.getRowIndexAtPixel(pixel); var rowNodeAtPixelNow = this.getRow(indexAtPixelNow); + var animate = !this.gridOptionsWrapper.isSuppressAnimationFrame(); if (rowNodeAtPixelNow === rowNodes[0]) { return false; } @@ -44277,13 +52879,13 @@ var ClientSideRowModel = /** @class */ (function (_super) { _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].removeFromArray(_this.rootNode.allLeafChildren, rowNode); }); rowNodes.forEach(function (rowNode, idx) { - _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].insertIntoArray(_this.rootNode.allLeafChildren, rowNode, indexAtPixelNow + increment + idx); + _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].insertIntoArray(_this.rootNode.allLeafChildren, rowNode, Math.max(indexAtPixelNow + increment, 0) + idx); }); this.refreshModel({ - step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_EVERYTHING, + step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].EVERYTHING, keepRenderedRows: true, - animate: true, - keepEditingRows: true + keepEditingRows: true, + animate: animate }); return true; }; @@ -44310,16 +52912,16 @@ var ClientSideRowModel = /** @class */ (function (_super) { var index = this.getRowIndexAtPixel(pixel); rowNode = this.getRow(index || 0); if (!rowNode) { - return 'below'; + return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowHighlightPosition"].Below; } } var rowTop = rowNode.rowTop, rowHeight = rowNode.rowHeight; - return pixel - rowTop < rowHeight / 2 ? 'above' : 'below'; + return pixel - rowTop < rowHeight / 2 ? _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowHighlightPosition"].Above : _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowHighlightPosition"].Below; }; ClientSideRowModel.prototype.getLastHighlightedRowNode = function () { return this.lastHighlightedRow; }; - ClientSideRowModel.prototype.isLastRowFound = function () { + ClientSideRowModel.prototype.isLastRowIndexKnown = function () { return true; }; ClientSideRowModel.prototype.getRowCount = function () { @@ -44364,28 +52966,28 @@ var ClientSideRowModel = /** @class */ (function (_super) { }; ClientSideRowModel.prototype.onRowGroupOpened = function () { var animate = this.gridOptionsWrapper.isAnimateRows(); - this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_MAP, keepRenderedRows: true, animate: animate }); + this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].MAP, keepRenderedRows: true, animate: animate }); }; ClientSideRowModel.prototype.onFilterChanged = function (event) { if (event.afterDataChange) { return; } var animate = this.gridOptionsWrapper.isAnimateRows(); - this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_FILTER, keepRenderedRows: true, animate: animate }); + this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].FILTER, keepRenderedRows: true, animate: animate }); }; ClientSideRowModel.prototype.onSortChanged = function () { var animate = this.gridOptionsWrapper.isAnimateRows(); - this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_SORT, keepRenderedRows: true, animate: animate, keepEditingRows: true }); + this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].SORT, keepRenderedRows: true, animate: animate, keepEditingRows: true }); }; ClientSideRowModel.prototype.getType = function () { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE; }; ClientSideRowModel.prototype.onValueChanged = function () { - if (this.columnController.isPivotActive()) { - this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_PIVOT }); + if (this.columnModel.isPivotActive()) { + this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].PIVOT }); } else { - this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_AGGREGATE }); + this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].AGGREGATE }); } }; ClientSideRowModel.prototype.createChangePath = function (rowNodeTransactions) { @@ -44403,13 +53005,30 @@ var ClientSideRowModel = /** @class */ (function (_super) { } return changedPath; }; + ClientSideRowModel.prototype.isSuppressModelUpdateAfterUpdateTransaction = function (params) { + if (!this.gridOptionsWrapper.isSuppressModelUpdateAfterUpdateTransaction()) { + return false; + } + // return true if we are only doing update transactions + if (params.rowNodeTransactions == null) { + return false; + } + var transWithAddsOrDeletes = params.rowNodeTransactions.filter(function (tx) { + return (tx.add != null && tx.add.length > 0) || (tx.remove != null && tx.remove.length > 0); + }); + var transactionsContainUpdatesOnly = transWithAddsOrDeletes == null || transWithAddsOrDeletes.length == 0; + return transactionsContainUpdatesOnly; + }; ClientSideRowModel.prototype.refreshModel = function (params) { + var _this = this; + if (this.isSuppressModelUpdateAfterUpdateTransaction(params)) { + return; + } // this goes through the pipeline of stages. what's in my head is similar // to the diagram on this page: // http://commons.apache.org/sandbox/commons-pipeline/pipeline_basics.html // however we want to keep the results of each stage, hence we manually call // each step rather than have them chain each other. - var _this = this; // fallthrough in below switch is on purpose, // eg if STEP_FILTER, then all steps below this // step get done @@ -44417,34 +53036,24 @@ var ClientSideRowModel = /** @class */ (function (_super) { // console.log('======= start ======='); var changedPath = this.createChangePath(params.rowNodeTransactions); switch (params.step) { - case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_EVERYTHING: - // start = new Date().getTime(); - this.doRowGrouping(params.groupState, params.rowNodeTransactions, params.rowNodeOrder, changedPath, params.afterColumnsChanged); - // console.log('rowGrouping = ' + (new Date().getTime() - start)); - case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_FILTER: - // start = new Date().getTime(); + case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].EVERYTHING: + this.doRowGrouping(params.groupState, params.rowNodeTransactions, params.rowNodeOrder, changedPath, !!params.afterColumnsChanged); + case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].FILTER: this.doFilter(changedPath); - // console.log('filter = ' + (new Date().getTime() - start)); - case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_PIVOT: + case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].PIVOT: this.doPivot(changedPath); - case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_AGGREGATE: // depends on agg fields - // start = new Date().getTime(); + case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].AGGREGATE: // depends on agg fields this.doAggregate(changedPath); - // console.log('aggregation = ' + (new Date().getTime() - start)); - case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_SORT: - // start = new Date().getTime(); + case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].SORT: this.doSort(params.rowNodeTransactions, changedPath); - // console.log('sort = ' + (new Date().getTime() - start)); - case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_MAP: - // start = new Date().getTime(); + case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].MAP: this.doRowsToDisplay(); - // console.log('rowsToDisplay = ' + (new Date().getTime() - start)); } // set all row tops to null, then set row tops on all visible rows. if we don't // do this, then the algorithm below only sets row tops, old row tops from old rows // will still lie around - this.resetRowTops(this.rootNode, changedPath); - this.setRowTops(); + var displayedNodesMapped = this.setRowTopAndRowIndex(); + this.clearRowTopAndRowIndex(changedPath, displayedNodesMapped); var event = { type: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_MODEL_UPDATED, api: this.gridApi, @@ -44462,16 +53071,8 @@ var ClientSideRowModel = /** @class */ (function (_super) { } }; ClientSideRowModel.prototype.isEmpty = function () { - var rowsMissing; - var doingLegacyTreeData = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(this.gridOptionsWrapper.getNodeChildDetailsFunc()); - if (doingLegacyTreeData) { - rowsMissing = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.rootNode.childrenAfterGroup) || this.rootNode.childrenAfterGroup.length === 0; - } - else { - rowsMissing = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.rootNode.allLeafChildren) || this.rootNode.allLeafChildren.length === 0; - } - var empty = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.rootNode) || rowsMissing || !this.columnController.isReady(); - return empty; + var rowsMissing = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.rootNode.allLeafChildren) || this.rootNode.allLeafChildren.length === 0; + return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.rootNode) || rowsMissing || !this.columnModel.isReady(); }; ClientSideRowModel.prototype.isRowsToRender = function () { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(this.rowsToDisplay) && this.rowsToDisplay.length > 0; @@ -44514,7 +53115,7 @@ var ClientSideRowModel = /** @class */ (function (_super) { return result; }; ClientSideRowModel.prototype.setDatasource = function (datasource) { - console.error('ag-Grid: should never call setDatasource on clientSideRowController'); + console.error('AG Grid: should never call setDatasource on clientSideRowController'); }; ClientSideRowModel.prototype.getTopLevelNodes = function () { return this.rootNode ? this.rootNode.childrenAfterGroup : null; @@ -44565,14 +53166,6 @@ var ClientSideRowModel = /** @class */ (function (_super) { var pixelInRow = topPixel <= pixelToMatch && bottomPixel > pixelToMatch; return pixelInRow; }; - ClientSideRowModel.prototype.getCurrentPageHeight = function () { - if (this.rowsToDisplay && this.rowsToDisplay.length > 0) { - var lastRow = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].last(this.rowsToDisplay); - var lastPixel = lastRow.rowTop + lastRow.rowHeight; - return lastPixel; - } - return 0; - }; ClientSideRowModel.prototype.forEachLeafNode = function (callback) { if (this.rootNode.allLeafChildren) { this.rootNode.allLeafChildren.forEach(function (rowNode, index) { return callback(rowNode, index); }); @@ -44654,7 +53247,7 @@ var ClientSideRowModel = /** @class */ (function (_super) { } }); } - this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_MAP }); + this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].MAP }); var eventSource = expand ? 'expandAll' : 'collapseAll'; var event = { api: this.gridApi, @@ -44672,11 +53265,6 @@ var ClientSideRowModel = /** @class */ (function (_super) { }); }; ClientSideRowModel.prototype.doRowGrouping = function (groupState, rowNodeTransactions, rowNodeOrder, changedPath, afterColumnsChanged) { - // grouping is enterprise only, so if service missing, skip the step - var doingLegacyTreeData = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(this.gridOptionsWrapper.getNodeChildDetailsFunc()); - if (doingLegacyTreeData) { - return; - } if (this.groupStage) { if (rowNodeTransactions) { this.groupStage.execute({ @@ -44687,8 +53275,6 @@ var ClientSideRowModel = /** @class */ (function (_super) { }); } else { - // groups are about to get disposed, so need to deselect any that are selected - this.selectionController.removeGroupsFromSelection(); this.groupStage.execute({ rowNode: this.rootNode, changedPath: changedPath, @@ -44698,11 +53284,15 @@ var ClientSideRowModel = /** @class */ (function (_super) { this.restoreGroupState(groupState); } if (this.gridOptionsWrapper.isGroupSelectsChildren()) { - this.selectionController.updateGroupsFromChildrenSelections(changedPath); + this.selectionService.updateGroupsFromChildrenSelections(changedPath); } } else { this.rootNode.childrenAfterGroup = this.rootNode.allLeafChildren; + if (this.rootNode.sibling) { + this.rootNode.sibling.childrenAfterGroup = this.rootNode.childrenAfterGroup; + } + this.rootNode.updateHasChildren(); } }; ClientSideRowModel.prototype.restoreGroupState = function (groupState) { @@ -44738,7 +53328,24 @@ var ClientSideRowModel = /** @class */ (function (_super) { return this.nodeManager.getCopyOfNodesMap(); }; ClientSideRowModel.prototype.getRowNode = function (id) { - return this.nodeManager.getRowNode(id); + // although id is typed a string, this could be called by the user, and they could have passed a number + var idIsGroup = typeof id == 'string' && id.indexOf(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNode"].ID_PREFIX_ROW_GROUP) == 0; + if (idIsGroup) { + // only one users complained about getRowNode not working for groups, after years of + // this working for normal rows. so have done quick implementation. if users complain + // about performance, then GroupStage should store / manage created groups in a map, + // which is a chunk of work. + var res_1 = undefined; + this.forEachNode(function (node) { + if (node.id === id) { + res_1 = node; + } + }); + return res_1; + } + else { + return this.nodeManager.getRowNode(id); + } }; // rows: the rows to put into the model ClientSideRowModel.prototype.setRowData = function (rowData) { @@ -44758,60 +53365,104 @@ var ClientSideRowModel = /** @class */ (function (_super) { }; this.eventService.dispatchEvent(rowDataChangedEvent); this.refreshModel({ - step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_EVERYTHING, + step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].EVERYTHING, groupState: groupState, newData: true }); }; ClientSideRowModel.prototype.batchUpdateRowData = function (rowDataTransaction, callback) { var _this = this; - if (!this.rowDataTransactionBatch) { + if (this.applyAsyncTransactionsTimeout == null) { this.rowDataTransactionBatch = []; var waitMillis = this.gridOptionsWrapper.getAsyncTransactionWaitMillis(); - window.setTimeout(function () { + this.applyAsyncTransactionsTimeout = window.setTimeout(function () { _this.executeBatchUpdateRowData(); - _this.rowDataTransactionBatch = null; }, waitMillis); } this.rowDataTransactionBatch.push({ rowDataTransaction: rowDataTransaction, callback: callback }); }; + ClientSideRowModel.prototype.flushAsyncTransactions = function () { + if (this.applyAsyncTransactionsTimeout != null) { + clearTimeout(this.applyAsyncTransactionsTimeout); + this.executeBatchUpdateRowData(); + } + }; ClientSideRowModel.prototype.executeBatchUpdateRowData = function () { var _this = this; this.valueCache.onDataChanged(); var callbackFuncsBound = []; var rowNodeTrans = []; + // The rowGroup stage uses rowNodeOrder if order was provided. if we didn't pass 'true' to + // commonUpdateRowData, using addIndex would have no effect when grouping. + var forceRowNodeOrder = false; if (this.rowDataTransactionBatch) { this.rowDataTransactionBatch.forEach(function (tranItem) { - var rowNodeTran = _this.nodeManager.updateRowData(tranItem.rowDataTransaction, null); + var rowNodeTran = _this.nodeManager.updateRowData(tranItem.rowDataTransaction, undefined); rowNodeTrans.push(rowNodeTran); if (tranItem.callback) { callbackFuncsBound.push(tranItem.callback.bind(null, rowNodeTran)); } + if (typeof tranItem.rowDataTransaction.addIndex === 'number') { + forceRowNodeOrder = true; + } }); } - this.commonUpdateRowData(rowNodeTrans); + this.commonUpdateRowData(rowNodeTrans, undefined, forceRowNodeOrder); // do callbacks in next VM turn so it's async if (callbackFuncsBound.length > 0) { window.setTimeout(function () { callbackFuncsBound.forEach(function (func) { return func(); }); }, 0); } + if (rowNodeTrans.length > 0) { + var event_1 = { + api: this.gridOptionsWrapper.getApi(), + columnApi: this.gridOptionsWrapper.getColumnApi(), + type: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_ASYNC_TRANSACTIONS_FLUSHED, + results: rowNodeTrans + }; + this.eventService.dispatchEvent(event_1); + } + this.rowDataTransactionBatch = null; + this.applyAsyncTransactionsTimeout = undefined; }; ClientSideRowModel.prototype.updateRowData = function (rowDataTran, rowNodeOrder) { this.valueCache.onDataChanged(); var rowNodeTran = this.nodeManager.updateRowData(rowDataTran, rowNodeOrder); - this.commonUpdateRowData([rowNodeTran], rowNodeOrder); + // if doing immutableData, addIndex is never present. however if doing standard transaction, and user + // provided addIndex, then this is used in updateRowData. However if doing Enterprise, then the rowGroup + // stage also uses the + var forceRowNodeOrder = typeof rowDataTran.addIndex === 'number'; + this.commonUpdateRowData([rowNodeTran], rowNodeOrder, forceRowNodeOrder); return rowNodeTran; }; + ClientSideRowModel.prototype.createRowNodeOrder = function () { + var suppressSortOrder = this.gridOptionsWrapper.isSuppressMaintainUnsortedOrder(); + if (suppressSortOrder) { + return; + } + var orderMap = {}; + if (this.rootNode && this.rootNode.allLeafChildren) { + for (var index = 0; index < this.rootNode.allLeafChildren.length; index++) { + var node = this.rootNode.allLeafChildren[index]; + orderMap[node.id] = index; + } + } + return orderMap; + }; // common to updateRowData and batchUpdateRowData - ClientSideRowModel.prototype.commonUpdateRowData = function (rowNodeTrans, rowNodeOrder) { + ClientSideRowModel.prototype.commonUpdateRowData = function (rowNodeTrans, rowNodeOrder, forceRowNodeOrder) { + var animate = !this.gridOptionsWrapper.isSuppressAnimationFrame(); + if (forceRowNodeOrder) { + rowNodeOrder = this.createRowNodeOrder(); + } this.refreshModel({ - step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_EVERYTHING, + step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].EVERYTHING, rowNodeTransactions: rowNodeTrans, rowNodeOrder: rowNodeOrder, keepRenderedRows: true, - animate: true, - keepEditingRows: true + keepEditingRows: true, + animate: animate }); var event = { type: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_ROW_DATA_UPDATED, @@ -44824,37 +53475,34 @@ var ClientSideRowModel = /** @class */ (function (_super) { this.rowsToDisplay = this.flattenStage.execute({ rowNode: this.rootNode }); }; ClientSideRowModel.prototype.onRowHeightChanged = function () { - this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_MAP, keepRenderedRows: true, keepEditingRows: true }); + this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelSteps"].MAP, keepRenderedRows: true, keepEditingRows: true }); }; ClientSideRowModel.prototype.resetRowHeights = function () { + var atLeastOne = false; this.forEachNode(function (rowNode) { - rowNode.setRowHeight(null); - // forEachNode doesn't go through detail rows, so need to check - // for detail nodes explicitly. - if (rowNode.detailNode) { - rowNode.detailNode.setRowHeight(null); + rowNode.setRowHeight(rowNode.rowHeight, true); + // we keep the height each row is at, however we set estimated=true rather than clear the height. + // this means the grid will not reset the row heights back to defaults, rather it will re-calc + // the height for each row as the row is displayed. otherwise the scroll will jump when heights are reset. + var detailNode = rowNode.detailNode; + if (detailNode) { + detailNode.setRowHeight(detailNode.rowHeight, true); } + atLeastOne = true; }); - this.onRowHeightChanged(); + if (atLeastOne) { + this.onRowHeightChanged(); + } }; __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], ClientSideRowModel.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], ClientSideRowModel.prototype, "columnController", void 0); - __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager') - ], ClientSideRowModel.prototype, "filterManager", void 0); + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], ClientSideRowModel.prototype, "columnModel", void 0); __decorate([ Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('$scope') ], ClientSideRowModel.prototype, "$scope", void 0); __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('selectionController') - ], ClientSideRowModel.prototype, "selectionController", void 0); - __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueService') - ], ClientSideRowModel.prototype, "valueService", void 0); + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('selectionService') + ], ClientSideRowModel.prototype, "selectionService", void 0); __decorate([ Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueCache') ], ClientSideRowModel.prototype, "valueCache", void 0); @@ -44864,6 +53512,12 @@ var ClientSideRowModel = /** @class */ (function (_super) { __decorate([ Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') ], ClientSideRowModel.prototype, "gridApi", void 0); + __decorate([ + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('animationFrameService') + ], ClientSideRowModel.prototype, "animationFrameService", void 0); + __decorate([ + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('beans') + ], ClientSideRowModel.prototype, "beans", void 0); __decorate([ Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterStage') ], ClientSideRowModel.prototype, "filterStage", void 0); @@ -44894,27 +53548,47 @@ var ClientSideRowModel = /** @class */ (function (_super) { /***/ }), -/* 204 */ +/* 254 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ClientSideNodeManager", function() { return ClientSideNodeManager; }); /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3); +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; +}; +var __spread = (undefined && undefined.__spread) || function () { + for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); + return ar; +}; var ClientSideNodeManager = /** @class */ (function () { - function ClientSideNodeManager(rootNode, gridOptionsWrapper, context, eventService, columnController, gridApi, columnApi, selectionController) { + function ClientSideNodeManager(rootNode, gridOptionsWrapper, eventService, columnModel, gridApi, columnApi, selectionService, beans) { this.nextId = 0; // when user is provide the id's, we also keep a map of ids to row nodes for convenience this.allNodesMap = {}; this.rootNode = rootNode; this.gridOptionsWrapper = gridOptionsWrapper; - this.context = context; this.eventService = eventService; - this.columnController = columnController; + this.columnModel = columnModel; this.gridApi = gridApi; this.columnApi = columnApi; - this.selectionController = selectionController; + this.beans = beans; + this.selectionService = selectionService; this.rootNode.group = true; this.rootNode.level = -1; this.rootNode.id = ClientSideNodeManager.ROOT_NODE_ID; @@ -44928,62 +53602,60 @@ var ClientSideNodeManager = /** @class */ (function () { // @PostConstruct - this is not a bean, so postConstruct called by constructor ClientSideNodeManager.prototype.postConstruct = function () { // func below doesn't have 'this' pointer, so need to pull out these bits - this.getNodeChildDetails = this.gridOptionsWrapper.getNodeChildDetailsFunc(); this.suppressParentsInRowNodes = this.gridOptionsWrapper.isSuppressParentsInRowNodes(); - this.doesDataFlower = this.gridOptionsWrapper.getDoesDataFlowerFunc(); this.isRowMasterFunc = this.gridOptionsWrapper.getIsRowMasterFunc(); this.doingTreeData = this.gridOptionsWrapper.isTreeData(); - this.doingLegacyTreeData = !this.doingTreeData && _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(this.getNodeChildDetails); this.doingMasterDetail = this.gridOptionsWrapper.isMasterDetail(); - if (this.getNodeChildDetails) { - console.warn("ag-Grid: the callback nodeChildDetailsFunc() is now deprecated. The new way of doing\n tree data in ag-Grid was introduced in v14 (released November 2017). In the next\n major release of ag-Grid we will be dropping support for the old version of\n tree data. If you are reading this message, please go to the docs to see how\n to implement Tree Data without using nodeChildDetailsFunc()."); - } }; ClientSideNodeManager.prototype.getCopyOfNodesMap = function () { - var result = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].cloneObject(this.allNodesMap); - return result; + return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].cloneObject(this.allNodesMap); }; ClientSideNodeManager.prototype.getRowNode = function (id) { return this.allNodesMap[id]; }; ClientSideNodeManager.prototype.setRowData = function (rowData) { - this.rootNode.childrenAfterFilter = null; - this.rootNode.childrenAfterGroup = null; - this.rootNode.childrenAfterSort = null; - this.rootNode.childrenMapped = null; - this.nextId = 0; - this.allNodesMap = {}; - if (!rowData) { - this.rootNode.allLeafChildren = []; - this.rootNode.childrenAfterGroup = []; + var _this = this; + if (typeof rowData === 'string') { + console.warn('AG Grid: rowData must be an array, however you passed in a string. If you are loading JSON, make sure you convert the JSON string to JavaScript objects first'); return; } - // kick off recursion - // we add rootNode as the parent, however if using ag-grid-enterprise, the grouping stage - // sets the parent node on each row (even if we are not grouping). so setting parent node - // here is for benefit of ag-grid-community users - var result = this.recursiveFunction(rowData, this.rootNode, ClientSideNodeManager.TOP_LEVEL); - if (this.doingLegacyTreeData) { - this.rootNode.childrenAfterGroup = result; - this.setLeafChildren(this.rootNode); + var rootNode = this.rootNode; + var sibling = this.rootNode.sibling; + rootNode.childrenAfterFilter = null; + rootNode.childrenAfterGroup = null; + rootNode.childrenAfterSort = null; + rootNode.childrenMapped = null; + rootNode.updateHasChildren(); + this.nextId = 0; + this.allNodesMap = {}; + if (rowData) { + // we use rootNode as the parent, however if using ag-grid-enterprise, the grouping stage + // sets the parent node on each row (even if we are not grouping). so setting parent node + // here is for benefit of ag-grid-community users + rootNode.allLeafChildren = rowData.map(function (dataItem) { return _this.createNode(dataItem, _this.rootNode, ClientSideNodeManager.TOP_LEVEL); }); } else { - this.rootNode.allLeafChildren = result; + rootNode.allLeafChildren = []; + rootNode.childrenAfterGroup = []; + } + if (sibling) { + sibling.childrenAfterFilter = rootNode.childrenAfterFilter; + sibling.childrenAfterGroup = rootNode.childrenAfterGroup; + sibling.childrenAfterSort = rootNode.childrenAfterSort; + sibling.childrenMapped = rootNode.childrenMapped; + sibling.allLeafChildren = rootNode.allLeafChildren; } }; ClientSideNodeManager.prototype.updateRowData = function (rowDataTran, rowNodeOrder) { - if (this.isLegacyTreeData()) { - return null; - } var rowNodeTransaction = { remove: [], update: [], add: [] }; var nodesToUnselect = []; - this.executeAdd(rowDataTran, rowNodeTransaction); this.executeRemove(rowDataTran, rowNodeTransaction, nodesToUnselect); this.executeUpdate(rowDataTran, rowNodeTransaction, nodesToUnselect); + this.executeAdd(rowDataTran, rowNodeTransaction); this.updateSelection(nodesToUnselect); if (rowNodeOrder) { _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].sortRowNodesByOrder(this.rootNode.allLeafChildren, rowNodeOrder); @@ -45001,7 +53673,7 @@ var ClientSideNodeManager = /** @class */ (function () { // a new node was inserted, so a parent that was previously selected (as all // children were selected) should not be tri-state (as new one unselected against // all other selected children). - this.selectionController.updateGroupsFromChildrenSelections(); + this.selectionService.updateGroupsFromChildrenSelections(); if (selectionChanged) { var event_1 = { type: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_SELECTION_CHANGED, @@ -45014,28 +53686,34 @@ var ClientSideNodeManager = /** @class */ (function () { ClientSideNodeManager.prototype.executeAdd = function (rowDataTran, rowNodeTransaction) { var _this = this; var add = rowDataTran.add, addIndex = rowDataTran.addIndex; - if (!add) { + if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missingOrEmpty(add)) { return; } + // create new row nodes for each data item + var newNodes = add.map(function (item) { return _this.createNode(item, _this.rootNode, ClientSideNodeManager.TOP_LEVEL); }); + // add new row nodes to the root nodes 'allLeafChildren' var useIndex = typeof addIndex === 'number' && addIndex >= 0; if (useIndex) { - // items get inserted in reverse order for index insertion - add.reverse().forEach(function (item) { - var newRowNode = _this.addRowNode(item, addIndex); - rowNodeTransaction.add.push(newRowNode); - }); + // new rows are inserted in one go by concatenating them in between the existing rows at the desired index. + // this is much faster than splicing them individually into 'allLeafChildren' when there are large inserts. + var existingLeafChildren = this.rootNode.allLeafChildren; + var nodesBeforeIndex = existingLeafChildren.slice(0, addIndex); + var nodesAfterIndex = existingLeafChildren.slice(addIndex, existingLeafChildren.length); + this.rootNode.allLeafChildren = __spread(nodesBeforeIndex, newNodes, nodesAfterIndex); } else { - add.forEach(function (item) { - var newRowNode = _this.addRowNode(item); - rowNodeTransaction.add.push(newRowNode); - }); + this.rootNode.allLeafChildren = __spread(this.rootNode.allLeafChildren, newNodes); + } + if (this.rootNode.sibling) { + this.rootNode.sibling.allLeafChildren = this.rootNode.allLeafChildren; } + // add new row nodes to the transaction add items + rowNodeTransaction.add = newNodes; }; ClientSideNodeManager.prototype.executeRemove = function (rowDataTran, rowNodeTransaction, nodesToUnselect) { var _this = this; var remove = rowDataTran.remove; - if (!remove) { + if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missingOrEmpty(remove)) { return; } var rowIdsRemoved = {}; @@ -45050,7 +53728,7 @@ var ClientSideNodeManager = /** @class */ (function () { nodesToUnselect.push(rowNode); } // so row renderer knows to fade row out (and not reposition it) - rowNode.clearRowTop(); + rowNode.clearRowTopAndRowIndex(); // NOTE: were we could remove from allLeaveChildren, however _.removeFromArray() is expensive, especially // if called multiple times (eg deleting lots of rows) and if allLeafChildren is a large list rowIdsRemoved[rowNode.id] = true; @@ -45059,11 +53737,14 @@ var ClientSideNodeManager = /** @class */ (function () { rowNodeTransaction.remove.push(rowNode); }); this.rootNode.allLeafChildren = this.rootNode.allLeafChildren.filter(function (rowNode) { return !rowIdsRemoved[rowNode.id]; }); + if (this.rootNode.sibling) { + this.rootNode.sibling.allLeafChildren = this.rootNode.allLeafChildren; + } }; ClientSideNodeManager.prototype.executeUpdate = function (rowDataTran, rowNodeTransaction, nodesToUnselect) { var _this = this; var update = rowDataTran.update; - if (!update) { + if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missingOrEmpty(update)) { return; } update.forEach(function (item) { @@ -45079,79 +53760,40 @@ var ClientSideNodeManager = /** @class */ (function () { rowNodeTransaction.update.push(rowNode); }); }; - ClientSideNodeManager.prototype.addRowNode = function (data, index) { - var newNode = this.createNode(data, this.rootNode, ClientSideNodeManager.TOP_LEVEL); - if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(index)) { - _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].insertIntoArray(this.rootNode.allLeafChildren, newNode, index); - } - else { - this.rootNode.allLeafChildren.push(newNode); - } - return newNode; - }; ClientSideNodeManager.prototype.lookupRowNode = function (data) { - var rowNodeIdFunc = this.gridOptionsWrapper.getRowNodeIdFunc(); + var getRowIdFunc = this.gridOptionsWrapper.getRowIdFunc(); var rowNode; - if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(rowNodeIdFunc)) { + if (getRowIdFunc) { // find rowNode using id - var id = rowNodeIdFunc(data); + var id = getRowIdFunc({ data: data, level: 0, api: this.gridApi, columnApi: this.columnApi }); rowNode = this.allNodesMap[id]; if (!rowNode) { - console.error("ag-Grid: could not find row id=" + id + ", data item was not found for this id"); + console.error("AG Grid: could not find row id=" + id + ", data item was not found for this id"); return null; } } else { // find rowNode using object references - rowNode = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].find(this.rootNode.allLeafChildren, function (rowNode) { return rowNode.data === data; }); + rowNode = this.rootNode.allLeafChildren.find(function (node) { return node.data === data; }); if (!rowNode) { - console.error("ag-Grid: could not find data item as object was not found", data); + console.error("AG Grid: could not find data item as object was not found", data); + console.error("Consider using getRowId to help the Grid find matching row data"); return null; } } - return rowNode; - }; - ClientSideNodeManager.prototype.recursiveFunction = function (rowData, parent, level) { - var _this = this; - // make sure the rowData is an array and not a string of json - this was a commonly reported problem on the forum - if (typeof rowData === 'string') { - console.warn('ag-Grid: rowData must be an array, however you passed in a string. If you are loading JSON, make sure you convert the JSON string to JavaScript objects first'); - return; - } - var rowNodes = []; - rowData.forEach(function (dataItem) { - var node = _this.createNode(dataItem, parent, level); - rowNodes.push(node); - }); - return rowNodes; + return rowNode || null; }; ClientSideNodeManager.prototype.createNode = function (dataItem, parent, level) { - var node = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNode"](); - this.context.createBean(node); - var nodeChildDetails = this.doingLegacyTreeData ? this.getNodeChildDetails(dataItem) : null; - if (nodeChildDetails && nodeChildDetails.group) { - node.group = true; - node.childrenAfterGroup = this.recursiveFunction(nodeChildDetails.children, node, level + 1); - node.expanded = nodeChildDetails.expanded === true; - node.field = nodeChildDetails.field; - node.key = nodeChildDetails.key; - // pull out all the leaf children and add to our node - this.setLeafChildren(node); - } - else { - node.group = false; - this.setMasterForRow(node, dataItem, level, true); - } - // support for backwards compatibility, canFlow is now called 'master' - /** @deprecated is now 'master' */ - node.canFlower = node.master; + var node = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNode"](this.beans); + node.group = false; + this.setMasterForRow(node, dataItem, level, true); if (parent && !this.suppressParentsInRowNodes) { node.parent = parent; } node.level = level; node.setDataAndId(dataItem, this.nextId.toString()); if (this.allNodesMap[node.id]) { - console.warn("ag-grid: duplicate node id '" + node.id + "' detected from getRowNodeId callback, this could cause issues in your grid."); + console.warn("AG Grid: duplicate node id '" + node.id + "' detected from getRowNodeId callback, this could cause issues in your grid."); } this.allNodesMap[node.id] = node; this.nextId++; @@ -45166,10 +53808,7 @@ var ClientSideNodeManager = /** @class */ (function () { } else { // this is the default, for when doing grid data - if (this.doesDataFlower) { - rowNode.setMaster(this.doesDataFlower(data)); - } - else if (this.doingMasterDetail) { + if (this.doingMasterDetail) { // if we are doing master detail, then the // default is that everything can be a Master Row. if (this.isRowMasterFunc) { @@ -45183,7 +53822,7 @@ var ClientSideNodeManager = /** @class */ (function () { rowNode.setMaster(false); } if (setExpanded) { - var rowGroupColumns = this.columnController.getRowGroupColumns(); + var rowGroupColumns = this.columnModel.getRowGroupColumns(); var numRowGroupColumns = rowGroupColumns ? rowGroupColumns.length : 0; // need to take row group into account when determining level var masterRowLevel = level + numRowGroupColumns; @@ -45196,36 +53835,7 @@ var ClientSideNodeManager = /** @class */ (function () { if (expandByDefault === -1) { return true; } - else { - return level < expandByDefault; - } - }; - // this is only used for doing legacy tree data - ClientSideNodeManager.prototype.setLeafChildren = function (node) { - node.allLeafChildren = []; - if (node.childrenAfterGroup) { - node.childrenAfterGroup.forEach(function (childAfterGroup) { - if (childAfterGroup.group) { - if (childAfterGroup.allLeafChildren) { - childAfterGroup.allLeafChildren.forEach(function (leafChild) { return node.allLeafChildren.push(leafChild); }); - } - } - else { - node.allLeafChildren.push(childAfterGroup); - } - }); - } - }; - ClientSideNodeManager.prototype.isLegacyTreeData = function () { - var rowsAlreadyGrouped = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(this.gridOptionsWrapper.getNodeChildDetailsFunc()); - if (rowsAlreadyGrouped) { - console.warn('ag-Grid: adding and removing rows is not supported when using nodeChildDetailsFunc, ie it is not ' + - 'supported for legacy tree data. Please see the docs on the new preferred way of providing tree data that works with delta updates.'); - return true; - } - else { - return false; - } + return level < expandByDefault; }; ClientSideNodeManager.TOP_LEVEL = 0; ClientSideNodeManager.ROOT_NODE_ID = 'ROOT_NODE_ID'; @@ -45235,7 +53845,7 @@ var ClientSideNodeManager = /** @class */ (function () { /***/ }), -/* 205 */ +/* 255 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -45272,9 +53882,6 @@ var FilterStage = /** @class */ (function (_super) { this.filterService.filter(changedPath); this.selectableService.updateSelectableAfterFiltering(rowNode); }; - __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], FilterStage.prototype, "gridOptionsWrapper", void 0); __decorate([ Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('selectableService') ], FilterStage.prototype, "selectableService", void 0); @@ -45290,7 +53897,7 @@ var FilterStage = /** @class */ (function (_super) { /***/ }), -/* 206 */ +/* 256 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -45323,7 +53930,7 @@ var SortStage = /** @class */ (function (_super) { return _super !== null && _super.apply(this, arguments) || this; } SortStage.prototype.execute = function (params) { - var sortOptions = this.sortController.getSortForRowController(); + var sortOptions = this.sortController.getSortOptions(); var sortActive = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(sortOptions) && sortOptions.length > 0; var deltaSort = sortActive && _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(params.rowNodeTransactions) @@ -45334,9 +53941,9 @@ var SortStage = /** @class */ (function (_super) { && this.gridOptionsWrapper.isDeltaSort(); // we only need dirty nodes if doing delta sort var dirtyLeafNodes = deltaSort ? this.calculateDirtyNodes(params.rowNodeTransactions) : null; - var valueColumns = this.columnController.getValueColumns(); - var noAggregations = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missingOrEmpty(valueColumns); - this.sortService.sort(sortOptions, sortActive, deltaSort, dirtyLeafNodes, params.changedPath, noAggregations); + var noAggregations = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missingOrEmpty(this.columnModel.getValueColumns()); + var sortContainsGroupColumns = sortOptions.some(function (opt) { return !!opt.column.getColDef().showRowGroup; }); + this.sortService.sort(sortOptions, sortActive, deltaSort, dirtyLeafNodes, params.changedPath, noAggregations, sortContainsGroupColumns); }; SortStage.prototype.calculateDirtyNodes = function (rowNodeTransactions) { var dirtyNodes = {}; @@ -45346,16 +53953,15 @@ var SortStage = /** @class */ (function (_super) { } }; // all leaf level nodes in the transaction were impacted - rowNodeTransactions.forEach(function (tran) { - addNodesFunc(tran.add); - addNodesFunc(tran.update); - addNodesFunc(tran.remove); - }); + if (rowNodeTransactions) { + rowNodeTransactions.forEach(function (tran) { + addNodesFunc(tran.add); + addNodesFunc(tran.update); + addNodesFunc(tran.remove); + }); + } return dirtyNodes; }; - __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], SortStage.prototype, "gridOptionsWrapper", void 0); __decorate([ Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('sortService') ], SortStage.prototype, "sortService", void 0); @@ -45363,8 +53969,8 @@ var SortStage = /** @class */ (function (_super) { Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('sortController') ], SortStage.prototype, "sortController", void 0); __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], SortStage.prototype, "columnController", void 0); + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], SortStage.prototype, "columnModel", void 0); SortStage = __decorate([ Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('sortStage') ], SortStage); @@ -45374,7 +53980,7 @@ var SortStage = /** @class */ (function (_super) { /***/ }), -/* 207 */ +/* 257 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -45413,7 +54019,7 @@ var FlattenStage = /** @class */ (function (_super) { var result = []; // putting value into a wrapper so it's passed by reference var nextRowTop = { value: 0 }; - var skipLeafNodes = this.columnController.isPivotMode(); + var skipLeafNodes = this.columnModel.isPivotMode(); // if we are reducing, and not grouping, then we want to show the root node, as that // is where the pivot values are var showRootNode = skipLeafNodes && rootNode.leafGroup; @@ -45435,7 +54041,6 @@ var FlattenStage = /** @class */ (function (_super) { if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missingOrEmpty(rowsToFlatten)) { return; } - var groupSuppressRow = this.gridOptionsWrapper.isGroupSuppressRow(); var hideOpenParents = this.gridOptionsWrapper.isGroupHideOpenParents(); // these two are mutually exclusive, so if first set, we don't set the second var groupRemoveSingleChildren = this.gridOptionsWrapper.isGroupRemoveSingleChildren(); @@ -45444,7 +54049,6 @@ var FlattenStage = /** @class */ (function (_super) { var rowNode = rowsToFlatten[i]; // check all these cases, for working out if this row should be included in the final mapped list var isParent = rowNode.hasChildren(); - var isGroupSuppressedNode = groupSuppressRow && isParent; var isSkippedLeafNode = skipLeafNodes && !isParent; var isRemovedSingleChildrenGroup = groupRemoveSingleChildren && isParent && @@ -45458,11 +54062,8 @@ var FlattenStage = /** @class */ (function (_super) { // the UI will never allow expanding leaf groups, however the user might via the API (or menu option 'expand all') var neverAllowToExpand = skipLeafNodes && rowNode.leafGroup; var isHiddenOpenParent = hideOpenParents && rowNode.expanded && (!neverAllowToExpand); - var thisRowShouldBeRendered = !isSkippedLeafNode && - !isGroupSuppressedNode && - !isHiddenOpenParent && - !isRemovedSingleChildrenGroup && - !isRemovedLowestSingleChildrenGroup; + var thisRowShouldBeRendered = !isSkippedLeafNode && !isHiddenOpenParent && + !isRemovedSingleChildrenGroup && !isRemovedLowestSingleChildrenGroup; if (thisRowShouldBeRendered) { this.addRowNodeToRowsToDisplay(rowNode, result, nextRowTop, uiLevel); } @@ -45503,13 +54104,15 @@ var FlattenStage = /** @class */ (function (_super) { if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(groupNode.sibling)) { return; } - var footerNode = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNode"](); - this.context.createBean(footerNode); + var footerNode = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNode"](this.beans); Object.keys(groupNode).forEach(function (key) { footerNode[key] = groupNode[key]; }); footerNode.footer = true; - footerNode.rowTop = null; + footerNode.setRowTop(null); + footerNode.setRowIndex(null); + // manually set oldRowTop to null so we discard any + // previous information about its position. footerNode.oldRowTop = null; if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(footerNode.id)) { footerNode.id = 'rowGroupFooter_' + footerNode.id; @@ -45524,12 +54127,9 @@ var FlattenStage = /** @class */ (function (_super) { if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(masterNode.detailNode)) { return masterNode.detailNode; } - var detailNode = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNode"](); - this.context.createBean(detailNode); + var detailNode = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNode"](this.beans); detailNode.detail = true; detailNode.selectable = false; - // flower was renamed to 'detail', but keeping for backwards compatibility - detailNode.flower = detailNode.detail; detailNode.parent = masterNode; if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(masterNode.id)) { detailNode.id = 'detail_' + masterNode.id; @@ -45537,18 +54137,14 @@ var FlattenStage = /** @class */ (function (_super) { detailNode.data = masterNode.data; detailNode.level = masterNode.level + 1; masterNode.detailNode = detailNode; - masterNode.childFlower = masterNode.detailNode; // for backwards compatibility return detailNode; }; __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], FlattenStage.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('selectionController') - ], FlattenStage.prototype, "selectionController", void 0); + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], FlattenStage.prototype, "columnModel", void 0); __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], FlattenStage.prototype, "columnController", void 0); + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('beans') + ], FlattenStage.prototype, "beans", void 0); FlattenStage = __decorate([ Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('flattenStage') ], FlattenStage); @@ -45558,7 +54154,7 @@ var FlattenStage = /** @class */ (function (_super) { /***/ }), -/* 208 */ +/* 258 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -45593,8 +54189,10 @@ var SortService = /** @class */ (function (_super) { SortService.prototype.init = function () { this.postSortFunc = this.gridOptionsWrapper.getPostSortFunc(); }; - SortService.prototype.sort = function (sortOptions, sortActive, deltaSort, dirtyLeafNodes, changedPath, noAggregations) { + SortService.prototype.sort = function (sortOptions, sortActive, deltaSort, dirtyLeafNodes, changedPath, noAggregations, sortContainsGroupColumns) { var _this = this; + var groupMaintainOrder = this.gridOptionsWrapper.isGroupMaintainOrder(); + var groupColumnsPresent = this.columnModel.getAllGridColumns().some(function (c) { return c.isRowGroupActive(); }); var callback = function (rowNode) { // we clear out the 'pull down open parents' first, as the values mix up the sorting _this.pullDownGroupDataForHideOpenParents(rowNode.childrenAfterFilter, true); @@ -45602,27 +54200,32 @@ var SortService = /** @class */ (function (_super) { // so to ensure the array keeps its order, add an additional sorting condition manually, in this case we // are going to inspect the original array position. This is what sortedRowNodes is for. if (sortActive) { - var sortedRowNodes = deltaSort ? - _this.doDeltaSort(rowNode, sortOptions, dirtyLeafNodes, changedPath, noAggregations) - : _this.doFullSort(rowNode, sortOptions); - rowNode.childrenAfterSort = sortedRowNodes.map(function (sorted) { return sorted.rowNode; }); + // when 'groupMaintainOrder' is enabled we skip sorting groups unless we are sorting on group columns + var skipSortingGroups = groupMaintainOrder && groupColumnsPresent && !rowNode.leafGroup && !sortContainsGroupColumns; + if (skipSortingGroups) { + rowNode.childrenAfterSort = rowNode.childrenAfterFilter.slice(0); + } + else { + rowNode.childrenAfterSort = deltaSort ? + _this.doDeltaSort(rowNode, sortOptions, dirtyLeafNodes, changedPath, noAggregations) + : _this.rowNodeSorter.doFullSort(rowNode.childrenAfterFilter, sortOptions); + } } else { rowNode.childrenAfterSort = rowNode.childrenAfterFilter.slice(0); } + if (rowNode.sibling) { + rowNode.sibling.childrenAfterSort = rowNode.childrenAfterSort; + } _this.updateChildIndexes(rowNode); if (_this.postSortFunc) { _this.postSortFunc(rowNode.childrenAfterSort); } }; - changedPath.forEachChangedNodeDepthFirst(callback); - this.updateGroupDataForHiddenOpenParents(changedPath); - }; - SortService.prototype.doFullSort = function (rowNode, sortOptions) { - var sortedRowNodes = rowNode.childrenAfterFilter - .map(this.mapNodeToSortedNode.bind(this)); - sortedRowNodes.sort(this.compareRowNodes.bind(this, sortOptions)); - return sortedRowNodes; + if (changedPath) { + changedPath.forEachChangedNodeDepthFirst(callback); + } + this.updateGroupDataForHideOpenParents(changedPath); }; SortService.prototype.mapNodeToSortedNode = function (rowNode, pos) { return { currentPos: pos, rowNode: rowNode }; @@ -45633,18 +54236,18 @@ var SortService = /** @class */ (function (_super) { // that were removed or changed (but not added, added doesn't make sense, // if a node was added, there is no way it could be here from last time). var cleanNodes = rowNode.childrenAfterSort - .filter(function (rowNode) { + .filter(function (node) { // take out all nodes that were changed as part of the current transaction. // a changed node could a) be in a different sort position or b) may // no longer be in this set as the changed node may not pass filtering, // or be in a different group. - var passesDirtyNodesCheck = !dirtyLeafNodes[rowNode.id]; + var passesDirtyNodesCheck = !dirtyLeafNodes[node.id]; // also remove group nodes in the changed path, as they can have different aggregate // values which could impact the sort order. // note: changed path is not active if a) no value columns or b) no transactions. it is never // (b) in deltaSort as we only do deltaSort for transactions. for (a) if no value columns, then // there is no value in the group that could of changed (ie no aggregate values) - var passesChangedPathCheck = noAggregations || changedPath.canSkip(rowNode); + var passesChangedPathCheck = noAggregations || (changedPath && changedPath.canSkip(node)); return passesDirtyNodesCheck && passesChangedPathCheck; }) .map(this.mapNodeToSortedNode.bind(this)); @@ -45654,20 +54257,22 @@ var SortService = /** @class */ (function (_super) { // these are all nodes that need to be placed var changedNodes = rowNode.childrenAfterFilter // ignore nodes in the clean list - .filter(function (rowNode) { return !cleanNodesMapped[rowNode.id]; }) + .filter(function (node) { return !cleanNodesMapped[node.id]; }) .map(this.mapNodeToSortedNode.bind(this)); // sort changed nodes. note that we don't need to sort cleanNodes as they are // already sorted from last time. - changedNodes.sort(this.compareRowNodes.bind(this, sortOptions)); + changedNodes.sort(this.rowNodeSorter.compareRowNodes.bind(this, sortOptions)); + var result; if (changedNodes.length === 0) { - return cleanNodes; + result = cleanNodes; } else if (cleanNodes.length === 0) { - return changedNodes; + result = changedNodes; } else { - return this.mergeSortedArrays(sortOptions, cleanNodes, changedNodes); + result = this.mergeSortedArrays(sortOptions, cleanNodes, changedNodes); } + return result.map(function (item) { return item.rowNode; }); }; // Merge two sorted arrays into each other SortService.prototype.mergeSortedArrays = function (sortOptions, arr1, arr2) { @@ -45681,7 +54286,7 @@ var SortService = /** @class */ (function (_super) { // of second array. If yes, store first // array element and increment first array // index. Otherwise do same with second array - var compareResult = this.compareRowNodes(sortOptions, arr1[i], arr2[j]); + var compareResult = this.rowNodeSorter.compareRowNodes(sortOptions, arr1[i], arr2[j]); if (compareResult < 0) { res.push(arr1[i++]); } @@ -45699,35 +54304,6 @@ var SortService = /** @class */ (function (_super) { } return res; }; - SortService.prototype.compareRowNodes = function (sortOptions, sortedNodeA, sortedNodeB) { - var nodeA = sortedNodeA.rowNode; - var nodeB = sortedNodeB.rowNode; - // Iterate columns, return the first that doesn't match - for (var i = 0, len = sortOptions.length; i < len; i++) { - var sortOption = sortOptions[i]; - // let compared = compare(nodeA, nodeB, sortOption.column, sortOption.inverter === -1); - var isInverted = sortOption.inverter === -1; - var valueA = this.getValue(nodeA, sortOption.column); - var valueB = this.getValue(nodeB, sortOption.column); - var comparatorResult = void 0; - if (sortOption.column.getColDef().comparator) { - //if comparator provided, use it - comparatorResult = sortOption.column.getColDef().comparator(valueA, valueB, nodeA, nodeB, isInverted); - } - else { - //otherwise do our own comparison - comparatorResult = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].defaultComparator(valueA, valueB, this.gridOptionsWrapper.isAccentedSort()); - } - if (comparatorResult !== 0) { - return comparatorResult * sortOption.inverter; - } - } - // All matched, we make is so that the original sort order is kept: - return sortedNodeA.currentPos - sortedNodeB.currentPos; - }; - SortService.prototype.getValue = function (nodeA, column) { - return this.valueService.getValue(column, nodeA); - }; SortService.prototype.updateChildIndexes = function (rowNode) { if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(rowNode.childrenAfterSort)) { return; @@ -45742,11 +54318,16 @@ var SortService = /** @class */ (function (_super) { child.setChildIndex(i); } }; - SortService.prototype.updateGroupDataForHiddenOpenParents = function (changedPath) { + SortService.prototype.updateGroupDataForHideOpenParents = function (changedPath) { var _this = this; if (!this.gridOptionsWrapper.isGroupHideOpenParents()) { return; } + if (this.gridOptionsWrapper.isTreeData()) { + var msg_1 = "AG Grid: The property hideOpenParents dose not work with Tree Data. This is because Tree Data has values at the group level, it doesn't make sense to hide them (as opposed to Row Grouping, which only has Aggregated Values at the group level)."; + _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].doOnce(function () { return console.warn(msg_1); }, 'sortService.hideOpenParentsWithTreeData'); + return false; + } // recurse breadth first over group nodes after sort to 'pull down' group data to child groups var callback = function (rowNode) { _this.pullDownGroupDataForHideOpenParents(rowNode.childrenAfterSort, false); @@ -45756,33 +54337,32 @@ var SortService = /** @class */ (function (_super) { } }); }; - changedPath.executeFromRootNode(function (rowNode) { return callback(rowNode); }); + if (changedPath) { + changedPath.executeFromRootNode(function (rowNode) { return callback(rowNode); }); + } }; SortService.prototype.pullDownGroupDataForHideOpenParents = function (rowNodes, clearOperation) { var _this = this; - if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(rowNodes)) { - return; - } - if (!this.gridOptionsWrapper.isGroupHideOpenParents()) { + if (!this.gridOptionsWrapper.isGroupHideOpenParents() || _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(rowNodes)) { return; } rowNodes.forEach(function (childRowNode) { - var groupDisplayCols = _this.columnController.getGroupDisplayColumns(); + var groupDisplayCols = _this.columnModel.getGroupDisplayColumns(); groupDisplayCols.forEach(function (groupDisplayCol) { var showRowGroup = groupDisplayCol.getColDef().showRowGroup; if (typeof showRowGroup !== 'string') { - console.error('ag-Grid: groupHideOpenParents only works when specifying specific columns for colDef.showRowGroup'); + console.error('AG Grid: groupHideOpenParents only works when specifying specific columns for colDef.showRowGroup'); return; } var displayingGroupKey = showRowGroup; - var rowGroupColumn = _this.columnController.getPrimaryColumn(displayingGroupKey); + var rowGroupColumn = _this.columnModel.getPrimaryColumn(displayingGroupKey); var thisRowNodeMatches = rowGroupColumn === childRowNode.rowGroupColumn; if (thisRowNodeMatches) { return; } if (clearOperation) { // if doing a clear operation, we clear down the value for every possible group column - childRowNode.setGroupValue(groupDisplayCol.getId(), null); + childRowNode.setGroupValue(groupDisplayCol.getId(), undefined); } else { // if doing a set operation, we set only where the pull down is to occur @@ -45795,17 +54375,11 @@ var SortService = /** @class */ (function (_super) { }); }; __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('sortController') - ], SortService.prototype, "sortController", void 0); - __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], SortService.prototype, "columnController", void 0); - __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueService') - ], SortService.prototype, "valueService", void 0); + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], SortService.prototype, "columnModel", void 0); __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], SortService.prototype, "gridOptionsWrapper", void 0); + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowNodeSorter') + ], SortService.prototype, "rowNodeSorter", void 0); __decorate([ _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] ], SortService.prototype, "init", null); @@ -45818,7 +54392,7 @@ var SortService = /** @class */ (function (_super) { /***/ }), -/* 209 */ +/* 259 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -45870,7 +54444,8 @@ var FilterService = /** @class */ (function (_super) { var passBecauseChildren = childNode.childrenAfterFilter && childNode.childrenAfterFilter.length > 0; // both leaf level nodes and tree data nodes have data. these get added if // the data passes the filter - var passBecauseDataPasses = childNode.data && _this.filterManager.doesRowPassFilter(childNode); + var passBecauseDataPasses = childNode.data + && _this.filterManager.doesRowPassFilter({ rowNode: childNode }); // note - tree data nodes pass either if a) they pass themselves or b) any children of that node pass return passBecauseChildren || passBecauseDataPasses; }); @@ -45885,6 +54460,9 @@ var FilterService = /** @class */ (function (_super) { rowNode.childrenAfterFilter = rowNode.childrenAfterGroup; rowNode.setAllChildrenCount(null); } + if (rowNode.sibling) { + rowNode.sibling.childrenAfterFilter = rowNode.childrenAfterFilter; + } }; if (this.doingTreeDataFiltering()) { var treeDataDepthFirstFilter_1 = function (rowNode, alreadyFoundInParent) { @@ -45894,7 +54472,8 @@ var FilterService = /** @class */ (function (_super) { for (var i = 0; i < rowNode.childrenAfterGroup.length; i++) { var childNode = rowNode.childrenAfterGroup[i]; // first check if current node passes filter before invoking child nodes - var foundInParent = alreadyFoundInParent || _this.filterManager.doesRowPassFilter(childNode); + var foundInParent = alreadyFoundInParent + || _this.filterManager.doesRowPassFilter({ rowNode: childNode }); if (childNode.childrenAfterGroup) { treeDataDepthFirstFilter_1(rowNode.childrenAfterGroup[i], foundInParent); } @@ -45951,9 +54530,6 @@ var FilterService = /** @class */ (function (_super) { __decorate([ Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager') ], FilterService.prototype, "filterManager", void 0); - __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], FilterService.prototype, "gridOptionsWrapper", void 0); __decorate([ _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] ], FilterService.prototype, "postConstruct", null); @@ -45966,7 +54542,7 @@ var FilterService = /** @class */ (function (_super) { /***/ }), -/* 210 */ +/* 260 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -45992,6 +54568,22 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; +var __read = (undefined && undefined.__read) || function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; +}; var ImmutableService = /** @class */ (function (_super) { __extends(ImmutableService, _super); @@ -46003,15 +54595,32 @@ var ImmutableService = /** @class */ (function (_super) { this.clientSideRowModel = this.rowModel; } }; + ImmutableService.prototype.isActive = function () { + return this.gridOptionsWrapper.isImmutableData(); + }; + ImmutableService.prototype.setRowData = function (rowData) { + var transactionAndMap = this.createTransactionForRowData(rowData); + if (!transactionAndMap) { + return; + } + var _a = __read(transactionAndMap, 2), transaction = _a[0], orderIdMap = _a[1]; + var nodeTransaction = this.clientSideRowModel.updateRowData(transaction, orderIdMap); + // need to force updating of full width rows - note this wouldn't be necessary the full width cell comp listened + // to the data change event on the row node and refreshed itself. + if (nodeTransaction) { + this.rowRenderer.refreshFullWidthRows(nodeTransaction.update); + } + }; // converts the setRowData() command to a transaction - ImmutableService.prototype.createTransactionForRowData = function (data) { + ImmutableService.prototype.createTransactionForRowData = function (rowData) { + var _this = this; if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.clientSideRowModel)) { - console.error('ag-Grid: ImmutableService only works with ClientSideRowModel'); + console.error('AG Grid: ImmutableService only works with ClientSideRowModel'); return; } - var getRowNodeIdFunc = this.gridOptionsWrapper.getRowNodeIdFunc(); - if (!getRowNodeIdFunc || _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(getRowNodeIdFunc)) { - console.error('ag-Grid: ImmutableService requires getRowNodeId() callback to be implemented, your row data need IDs!'); + var getRowIdFunc = this.gridOptionsWrapper.getRowIdFunc(); + if (getRowIdFunc == null) { + console.error('AG Grid: ImmutableService requires getRowId() callback to be implemented, your row data needs IDs!'); return; } // convert the data into a transaction object by working out adds, removes and updates @@ -46022,29 +54631,29 @@ var ImmutableService = /** @class */ (function (_super) { }; var existingNodesMap = this.clientSideRowModel.getCopyOfNodesMap(); var suppressSortOrder = this.gridOptionsWrapper.isSuppressMaintainUnsortedOrder(); - var orderMap = suppressSortOrder ? null : {}; - if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(data)) { + var orderMap = suppressSortOrder ? undefined : {}; + if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(rowData)) { // split all the new data in the following: // if new, push to 'add' // if update, push to 'update' // if not changed, do not include in the transaction - data.forEach(function (dataItem, index) { - var id = getRowNodeIdFunc(dataItem); + rowData.forEach(function (data, index) { + var id = getRowIdFunc({ data: data, level: 0, api: _this.gridApi, columnApi: _this.columnApi }); var existingNode = existingNodesMap[id]; if (orderMap) { orderMap[id] = index; } if (existingNode) { - var dataHasChanged = existingNode.data !== dataItem; + var dataHasChanged = existingNode.data !== data; if (dataHasChanged) { - transaction.update.push(dataItem); + transaction.update.push(data); } // otherwise, if data not changed, we just don't include it anywhere, as it's not a delta // remove from list, so we know the item is not to be removed existingNodesMap[id] = undefined; } else { - transaction.add.push(dataItem); + transaction.add.push(data); } }); } @@ -46054,99 +54663,361 @@ var ImmutableService = /** @class */ (function (_super) { transaction.remove.push(rowNode.data); } }); - return [transaction, orderMap]; + return [transaction, orderMap]; + }; + __decorate([ + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel') + ], ImmutableService.prototype, "rowModel", void 0); + __decorate([ + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer') + ], ImmutableService.prototype, "rowRenderer", void 0); + __decorate([ + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') + ], ImmutableService.prototype, "columnApi", void 0); + __decorate([ + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') + ], ImmutableService.prototype, "gridApi", void 0); + __decorate([ + _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] + ], ImmutableService.prototype, "postConstruct", null); + ImmutableService = __decorate([ + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('immutableService') + ], ImmutableService); + return ImmutableService; +}(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); + + + +/***/ }), +/* 261 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _csvExport_baseCreator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(262); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BaseCreator", function() { return _csvExport_baseCreator__WEBPACK_IMPORTED_MODULE_0__["BaseCreator"]; }); + +/* harmony import */ var _csvExport_sessions_baseGridSerializingSession__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(263); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BaseGridSerializingSession", function() { return _csvExport_sessions_baseGridSerializingSession__WEBPACK_IMPORTED_MODULE_1__["BaseGridSerializingSession"]; }); + +/* harmony import */ var _csvExport_csvCreator__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(264); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CsvCreator", function() { return _csvExport_csvCreator__WEBPACK_IMPORTED_MODULE_2__["CsvCreator"]; }); + +/* harmony import */ var _csvExportModule__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(267); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CsvExportModule", function() { return _csvExportModule__WEBPACK_IMPORTED_MODULE_3__["CsvExportModule"]; }); + +/* harmony import */ var _csvExport_downloader__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(265); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Downloader", function() { return _csvExport_downloader__WEBPACK_IMPORTED_MODULE_4__["Downloader"]; }); + +/* harmony import */ var _csvExport_gridSerializer__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(268); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridSerializer", function() { return _csvExport_gridSerializer__WEBPACK_IMPORTED_MODULE_5__["GridSerializer"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowType", function() { return _csvExport_gridSerializer__WEBPACK_IMPORTED_MODULE_5__["RowType"]; }); + +/* harmony import */ var _csvExport_xmlFactory__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(269); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "XmlFactory", function() { return _csvExport_xmlFactory__WEBPACK_IMPORTED_MODULE_6__["XmlFactory"]; }); + +/* harmony import */ var _csvExport_zipContainer__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(270); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ZipContainer", function() { return _csvExport_zipContainer__WEBPACK_IMPORTED_MODULE_7__["ZipContainer"]; }); + + + + + + + + + + + +/***/ }), +/* 262 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BaseCreator", function() { return BaseCreator; }); +var BaseCreator = /** @class */ (function () { + function BaseCreator() { + } + BaseCreator.prototype.setBeans = function (beans) { + this.beans = beans; + }; + BaseCreator.prototype.getFileName = function (fileName) { + var extension = this.getDefaultFileExtension(); + if (fileName == null || !fileName.length) { + fileName = this.getDefaultFileName(); + } + return fileName.indexOf('.') === -1 ? fileName + "." + extension : fileName; + }; + BaseCreator.prototype.getData = function (params) { + var serializingSession = this.createSerializingSession(params); + var data = this.beans.gridSerializer.serialize(serializingSession, params); + return data; + }; + return BaseCreator; +}()); + + + +/***/ }), +/* 263 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BaseGridSerializingSession", function() { return BaseGridSerializingSession; }); +var BaseGridSerializingSession = /** @class */ (function () { + function BaseGridSerializingSession(config) { + this.groupColumns = []; + var columnModel = config.columnModel, valueService = config.valueService, gridOptionsWrapper = config.gridOptionsWrapper, processCellCallback = config.processCellCallback, processHeaderCallback = config.processHeaderCallback, processGroupHeaderCallback = config.processGroupHeaderCallback, processRowGroupCallback = config.processRowGroupCallback; + this.columnModel = columnModel; + this.valueService = valueService; + this.gridOptionsWrapper = gridOptionsWrapper; + this.processCellCallback = processCellCallback; + this.processHeaderCallback = processHeaderCallback; + this.processGroupHeaderCallback = processGroupHeaderCallback; + this.processRowGroupCallback = processRowGroupCallback; + } + BaseGridSerializingSession.prototype.prepare = function (columnsToExport) { + this.groupColumns = columnsToExport.filter(function (col) { return !!col.getColDef().showRowGroup; }); + }; + BaseGridSerializingSession.prototype.extractHeaderValue = function (column) { + var value = this.getHeaderName(this.processHeaderCallback, column); + return value != null ? value : ''; + }; + BaseGridSerializingSession.prototype.extractRowCellValue = function (column, index, accumulatedRowIndex, type, node) { + // we render the group summary text e.g. "-> Parent -> Child"... + var groupIndex = this.gridOptionsWrapper.isGroupMultiAutoColumn() ? node.rowGroupIndex : 0; + var renderGroupSummaryCell = + // on group rows + node && node.group + && ( + // in the group column if groups appear in regular grid cells + index === groupIndex && this.groupColumns.indexOf(column) !== -1 + // or the first cell in the row, if we're doing full width rows + || (index === 0 && this.gridOptionsWrapper.isGroupUseEntireRow(this.columnModel.isPivotMode()))); + var valueForCell; + if (renderGroupSummaryCell) { + valueForCell = this.createValueForGroupNode(node); + } + else { + valueForCell = this.valueService.getValue(column, node); + } + var value = this.processCell(accumulatedRowIndex, node, column, valueForCell, this.processCellCallback, type); + return value != null ? value : ''; + }; + BaseGridSerializingSession.prototype.getHeaderName = function (callback, column) { + if (callback) { + return callback({ + column: column, + api: this.gridOptionsWrapper.getApi(), + columnApi: this.gridOptionsWrapper.getColumnApi(), + context: this.gridOptionsWrapper.getContext() + }); + } + return this.columnModel.getDisplayNameForColumn(column, 'csv', true); + }; + BaseGridSerializingSession.prototype.createValueForGroupNode = function (node) { + if (this.processRowGroupCallback) { + return this.processRowGroupCallback({ + node: node, + api: this.gridOptionsWrapper.getApi(), + columnApi: this.gridOptionsWrapper.getColumnApi(), + context: this.gridOptionsWrapper.getContext(), + }); + } + var keys = [node.key]; + if (!this.gridOptionsWrapper.isGroupMultiAutoColumn()) { + while (node.parent) { + node = node.parent; + keys.push(node.key); + } + } + return keys.reverse().join(' -> '); + }; + BaseGridSerializingSession.prototype.processCell = function (accumulatedRowIndex, rowNode, column, value, processCellCallback, type) { + if (processCellCallback) { + return processCellCallback({ + accumulatedRowIndex: accumulatedRowIndex, + column: column, + node: rowNode, + value: value, + api: this.gridOptionsWrapper.getApi(), + columnApi: this.gridOptionsWrapper.getColumnApi(), + context: this.gridOptionsWrapper.getContext(), + type: type + }); + } + return value != null ? value : ''; + }; + return BaseGridSerializingSession; +}()); + + + +/***/ }), +/* 264 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CsvCreator", function() { return CsvCreator; }); +/* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3); +/* harmony import */ var _baseCreator__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(262); +/* harmony import */ var _downloader__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(265); +/* harmony import */ var _sessions_csvSerializingSession__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(266); +var __extends = (undefined && undefined.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; + + + + +var CsvCreator = /** @class */ (function (_super) { + __extends(CsvCreator, _super); + function CsvCreator() { + return _super !== null && _super.apply(this, arguments) || this; + } + CsvCreator.prototype.postConstruct = function () { + this.setBeans({ + gridSerializer: this.gridSerializer, + gridOptionsWrapper: this.gridOptionsWrapper + }); + }; + CsvCreator.prototype.getMergedParams = function (params) { + var baseParams = this.gridOptionsWrapper.getDefaultExportParams('csv'); + return Object.assign({}, baseParams, params); + }; + CsvCreator.prototype.export = function (userParams) { + if (this.isExportSuppressed()) { + console.warn("AG Grid: Export cancelled. Export is not allowed as per your configuration."); + return ''; + } + var mergedParams = this.getMergedParams(userParams); + var data = this.getData(mergedParams); + var packagedFile = new Blob(["\ufeff", data], { type: 'text/plain' }); + _downloader__WEBPACK_IMPORTED_MODULE_2__["Downloader"].download(this.getFileName(mergedParams.fileName), packagedFile); + return data; + }; + CsvCreator.prototype.exportDataAsCsv = function (params) { + return this.export(params); + }; + CsvCreator.prototype.getDataAsCsv = function (params) { + var mergedParams = this.getMergedParams(params); + return this.getData(mergedParams); + }; + CsvCreator.prototype.getDefaultFileName = function () { + return 'export.csv'; + }; + CsvCreator.prototype.getDefaultFileExtension = function () { + return 'csv'; + }; + CsvCreator.prototype.createSerializingSession = function (params) { + var _a = this, columnModel = _a.columnModel, valueService = _a.valueService, gridOptionsWrapper = _a.gridOptionsWrapper; + var _b = params, processCellCallback = _b.processCellCallback, processHeaderCallback = _b.processHeaderCallback, processGroupHeaderCallback = _b.processGroupHeaderCallback, processRowGroupCallback = _b.processRowGroupCallback, suppressQuotes = _b.suppressQuotes, columnSeparator = _b.columnSeparator; + return new _sessions_csvSerializingSession__WEBPACK_IMPORTED_MODULE_3__["CsvSerializingSession"]({ + columnModel: columnModel, + valueService: valueService, + gridOptionsWrapper: gridOptionsWrapper, + processCellCallback: processCellCallback || undefined, + processHeaderCallback: processHeaderCallback || undefined, + processGroupHeaderCallback: processGroupHeaderCallback || undefined, + processRowGroupCallback: processRowGroupCallback || undefined, + suppressQuotes: suppressQuotes || false, + columnSeparator: columnSeparator || ',' + }); + }; + CsvCreator.prototype.isExportSuppressed = function () { + return this.gridOptionsWrapper.isSuppressCsvExport(); }; __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel') - ], ImmutableService.prototype, "rowModel", void 0); + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], CsvCreator.prototype, "columnModel", void 0); + __decorate([ + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueService') + ], CsvCreator.prototype, "valueService", void 0); + __decorate([ + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridSerializer') + ], CsvCreator.prototype, "gridSerializer", void 0); __decorate([ Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], ImmutableService.prototype, "gridOptionsWrapper", void 0); + ], CsvCreator.prototype, "gridOptionsWrapper", void 0); __decorate([ _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], ImmutableService.prototype, "postConstruct", null); - ImmutableService = __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('immutableService') - ], ImmutableService); - return ImmutableService; -}(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); - - - -/***/ }), -/* 211 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony import */ var _csvExportModule__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(212); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CsvExportModule", function() { return _csvExportModule__WEBPACK_IMPORTED_MODULE_0__["CsvExportModule"]; }); - -/* harmony import */ var _csvExport_csvCreator__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(213); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BaseCreator", function() { return _csvExport_csvCreator__WEBPACK_IMPORTED_MODULE_1__["BaseCreator"]; }); - -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CsvCreator", function() { return _csvExport_csvCreator__WEBPACK_IMPORTED_MODULE_1__["CsvCreator"]; }); - -/* harmony import */ var _csvExport_downloader__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(215); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Downloader", function() { return _csvExport_downloader__WEBPACK_IMPORTED_MODULE_2__["Downloader"]; }); - -/* harmony import */ var _csvExport_gridSerializer__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(214); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridSerializer", function() { return _csvExport_gridSerializer__WEBPACK_IMPORTED_MODULE_3__["GridSerializer"]; }); - -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowType", function() { return _csvExport_gridSerializer__WEBPACK_IMPORTED_MODULE_3__["RowType"]; }); - -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BaseGridSerializingSession", function() { return _csvExport_gridSerializer__WEBPACK_IMPORTED_MODULE_3__["BaseGridSerializingSession"]; }); - -/* harmony import */ var _csvExport_zipContainer__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(217); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ZipContainer", function() { return _csvExport_zipContainer__WEBPACK_IMPORTED_MODULE_4__["ZipContainer"]; }); - -/* harmony import */ var _csvExport_xmlFactory__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(216); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "XmlFactory", function() { return _csvExport_xmlFactory__WEBPACK_IMPORTED_MODULE_5__["XmlFactory"]; }); - - - - - - + ], CsvCreator.prototype, "postConstruct", null); + CsvCreator = __decorate([ + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('csvCreator') + ], CsvCreator); + return CsvCreator; +}(_baseCreator__WEBPACK_IMPORTED_MODULE_1__["BaseCreator"])); /***/ }), -/* 212 */ +/* 265 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CsvExportModule", function() { return CsvExportModule; }); -/* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3); -/* harmony import */ var _csvExport_csvCreator__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(213); -/* harmony import */ var _csvExport_downloader__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(215); -/* harmony import */ var _csvExport_xmlFactory__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(216); -/* harmony import */ var _csvExport_gridSerializer__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(214); -/* harmony import */ var _csvExport_zipContainer__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(217); - - - - - +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Downloader", function() { return Downloader; }); +var Downloader = /** @class */ (function () { + function Downloader() { + } + Downloader.download = function (fileName, content) { + var win = document.defaultView || window; + if (!win) { + console.warn('AG Grid: There is no `window` associated with the current `document`'); + return; + } + var element = document.createElement('a'); + // @ts-ignore + var url = win.URL.createObjectURL(content); + element.setAttribute('href', url); + element.setAttribute('download', fileName); + element.style.display = 'none'; + document.body.appendChild(element); + element.dispatchEvent(new MouseEvent('click', { + bubbles: false, + cancelable: true, + view: win + })); + document.body.removeChild(element); + win.setTimeout(function () { + // @ts-ignore + win.URL.revokeObjectURL(url); + }, 0); + }; + return Downloader; +}()); -var CsvExportModule = { - moduleName: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ModuleNames"].CsvExportModule, - beans: [_csvExport_csvCreator__WEBPACK_IMPORTED_MODULE_1__["CsvCreator"], _csvExport_downloader__WEBPACK_IMPORTED_MODULE_2__["Downloader"], _csvExport_xmlFactory__WEBPACK_IMPORTED_MODULE_3__["XmlFactory"], _csvExport_gridSerializer__WEBPACK_IMPORTED_MODULE_4__["GridSerializer"], _csvExport_zipContainer__WEBPACK_IMPORTED_MODULE_5__["ZipContainer"]] -}; /***/ }), -/* 213 */ +/* 266 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CsvSerializingSession", function() { return CsvSerializingSession; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BaseCreator", function() { return BaseCreator; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CsvCreator", function() { return CsvCreator; }); /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3); -/* harmony import */ var _gridSerializer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(214); +/* harmony import */ var _baseGridSerializingSession__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(263); var __extends = (undefined && undefined.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || @@ -46160,12 +55031,6 @@ var __extends = (undefined && undefined.__extends) || (function () { d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; var LINE_SEPARATOR = '\r\n'; @@ -46186,8 +55051,6 @@ var CsvSerializingSession = /** @class */ (function (_super) { return; } if (typeof content === 'string') { - // we used to require the customFooter to be prefixed with a newline but no longer do, - // so only add the newline if the user has not supplied one if (!/^\s*\n/.test(content)) { this.beginNewLine(); } @@ -46234,7 +55097,7 @@ var CsvSerializingSession = /** @class */ (function (_super) { onColumn: this.onNewHeaderRowColumn.bind(this) }; }; - CsvSerializingSession.prototype.onNewHeaderRowColumn = function (column, index, node) { + CsvSerializingSession.prototype.onNewHeaderRowColumn = function (column, index) { if (index != 0) { this.result += this.columnSeparator; } @@ -46250,7 +55113,7 @@ var CsvSerializingSession = /** @class */ (function (_super) { if (index != 0) { this.result += this.columnSeparator; } - this.result += this.putInQuotes(this.extractRowCellValue(column, index, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].EXPORT_TYPE_CSV, node)); + this.result += this.putInQuotes(this.extractRowCellValue(column, index, index, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].EXPORT_TYPE_CSV, node)); }; CsvSerializingSession.prototype.putInQuotes = function (value) { if (this.suppressQuotes) { @@ -46267,7 +55130,7 @@ var CsvSerializingSession = /** @class */ (function (_super) { stringValue = value.toString(); } else { - console.warn('unknown value type during csv conversion'); + console.warn('AG Grid: unknown value type during csv conversion'); stringValue = ''; } // replace each " with "" (ie two sets of double quotes is how to do double quotes in csv) @@ -46284,131 +55147,37 @@ var CsvSerializingSession = /** @class */ (function (_super) { this.isFirstLine = false; }; return CsvSerializingSession; -}(_gridSerializer__WEBPACK_IMPORTED_MODULE_1__["BaseGridSerializingSession"])); +}(_baseGridSerializingSession__WEBPACK_IMPORTED_MODULE_1__["BaseGridSerializingSession"])); + + + +/***/ }), +/* 267 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CsvExportModule", function() { return CsvExportModule; }); +/* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3); +/* harmony import */ var _csvExport_csvCreator__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(264); +/* harmony import */ var _csvExport_gridSerializer__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(268); -var BaseCreator = /** @class */ (function () { - function BaseCreator() { - } - BaseCreator.prototype.setBeans = function (beans) { - this.beans = beans; - }; - BaseCreator.prototype.export = function (userParams) { - if (this.isExportSuppressed()) { - console.warn("ag-grid: Export cancelled. Export is not allowed as per your configuration."); - return ''; - } - var _a = this.getMergedParamsAndData(userParams), mergedParams = _a.mergedParams, data = _a.data; - var fileNamePresent = mergedParams && mergedParams.fileName && mergedParams.fileName.length !== 0; - var fileName = fileNamePresent ? mergedParams.fileName : this.getDefaultFileName(); - if (fileName.indexOf(".") === -1) { - fileName = fileName + "." + this.getDefaultFileExtension(); - } - this.beans.downloader.download(fileName, this.packageFile(data)); - return data; - }; - BaseCreator.prototype.getData = function (params) { - return this.getMergedParamsAndData(params).data; - }; - BaseCreator.prototype.getMergedParamsAndData = function (userParams) { - var mergedParams = this.mergeDefaultParams(userParams); - var data = this.beans.gridSerializer.serialize(this.createSerializingSession(mergedParams), mergedParams); - return { mergedParams: mergedParams, data: data }; - }; - BaseCreator.prototype.mergeDefaultParams = function (userParams) { - var baseParams = this.beans.gridOptionsWrapper.getDefaultExportParams(); - var params = {}; - _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].assign(params, baseParams); - _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].assign(params, userParams); - return params; - }; - BaseCreator.prototype.packageFile = function (data) { - return new Blob(["\ufeff", data], { - type: window.navigator.msSaveOrOpenBlob ? this.getMimeType() : 'octet/stream' - }); - }; - return BaseCreator; -}()); -var CsvCreator = /** @class */ (function (_super) { - __extends(CsvCreator, _super); - function CsvCreator() { - return _super !== null && _super.apply(this, arguments) || this; - } - CsvCreator.prototype.postConstruct = function () { - this.setBeans({ - downloader: this.downloader, - gridSerializer: this.gridSerializer, - gridOptionsWrapper: this.gridOptionsWrapper - }); - }; - CsvCreator.prototype.exportDataAsCsv = function (params) { - return this.export(params); - }; - CsvCreator.prototype.getDataAsCsv = function (params) { - return this.getData(params); - }; - CsvCreator.prototype.getMimeType = function () { - return 'text/csv;charset=utf-8;'; - }; - CsvCreator.prototype.getDefaultFileName = function () { - return 'export.csv'; - }; - CsvCreator.prototype.getDefaultFileExtension = function () { - return 'csv'; - }; - CsvCreator.prototype.createSerializingSession = function (params) { - var _a = this, columnController = _a.columnController, valueService = _a.valueService, gridOptionsWrapper = _a.gridOptionsWrapper; - var processCellCallback = params.processCellCallback, processHeaderCallback = params.processHeaderCallback, processGroupHeaderCallback = params.processGroupHeaderCallback, processRowGroupCallback = params.processRowGroupCallback, suppressQuotes = params.suppressQuotes, columnSeparator = params.columnSeparator; - return new CsvSerializingSession({ - columnController: columnController, - valueService: valueService, - gridOptionsWrapper: gridOptionsWrapper, - processCellCallback: processCellCallback || undefined, - processHeaderCallback: processHeaderCallback || undefined, - processGroupHeaderCallback: processGroupHeaderCallback || undefined, - processRowGroupCallback: processRowGroupCallback || undefined, - suppressQuotes: suppressQuotes || false, - columnSeparator: columnSeparator || ',' - }); - }; - CsvCreator.prototype.isExportSuppressed = function () { - return this.gridOptionsWrapper.isSuppressCsvExport(); - }; - __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], CsvCreator.prototype, "columnController", void 0); - __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueService') - ], CsvCreator.prototype, "valueService", void 0); - __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('downloader') - ], CsvCreator.prototype, "downloader", void 0); - __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridSerializer') - ], CsvCreator.prototype, "gridSerializer", void 0); - __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], CsvCreator.prototype, "gridOptionsWrapper", void 0); - __decorate([ - _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], CsvCreator.prototype, "postConstruct", null); - CsvCreator = __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('csvCreator') - ], CsvCreator); - return CsvCreator; -}(BaseCreator)); +var CsvExportModule = { + moduleName: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ModuleNames"].CsvExportModule, + beans: [_csvExport_csvCreator__WEBPACK_IMPORTED_MODULE_1__["CsvCreator"], _csvExport_gridSerializer__WEBPACK_IMPORTED_MODULE_2__["GridSerializer"]] +}; /***/ }), -/* 214 */ +/* 268 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BaseGridSerializingSession", function() { return BaseGridSerializingSession; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridSerializer", function() { return GridSerializer; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowType", function() { return RowType; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridSerializer", function() { return GridSerializer; }); /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3); var __extends = (undefined && undefined.__extends) || (function () { var extendStatics = function (d, b) { @@ -46430,92 +55199,12 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta return c > 3 && r && Object.defineProperty(target, key, r), r; }; -var BaseGridSerializingSession = /** @class */ (function () { - function BaseGridSerializingSession(config) { - var columnController = config.columnController, valueService = config.valueService, gridOptionsWrapper = config.gridOptionsWrapper, processCellCallback = config.processCellCallback, processHeaderCallback = config.processHeaderCallback, processGroupHeaderCallback = config.processGroupHeaderCallback, processRowGroupCallback = config.processRowGroupCallback; - this.columnController = columnController; - this.valueService = valueService; - this.gridOptionsWrapper = gridOptionsWrapper; - this.processCellCallback = processCellCallback; - this.processHeaderCallback = processHeaderCallback; - this.processGroupHeaderCallback = processGroupHeaderCallback; - this.processRowGroupCallback = processRowGroupCallback; - } - BaseGridSerializingSession.prototype.prepare = function (columnsToExport) { - this.firstGroupColumn = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].find(columnsToExport, function (col) { return !!col.getColDef().showRowGroup; }); - }; - BaseGridSerializingSession.prototype.extractHeaderValue = function (column) { - var value = this.getHeaderName(this.processHeaderCallback, column); - return value != null ? value : ''; - }; - BaseGridSerializingSession.prototype.extractRowCellValue = function (column, index, type, node) { - // we render the group summary text e.g. "-> Parent -> Child"... - var renderGroupSummaryCell = - // on group rows - node && node.group - && ( - // in the first group column if groups appear in regular grid cells - column === this.firstGroupColumn - // or the first cell in the row, if we're doing full width rows - || (index === 0 && this.gridOptionsWrapper.isGroupUseEntireRow(this.columnController.isPivotMode()))); - var valueForCell; - if (renderGroupSummaryCell) { - valueForCell = this.createValueForGroupNode(node); - } - else { - valueForCell = this.valueService.getValue(column, node); - } - var value = this.processCell(node, column, valueForCell, this.processCellCallback, type); - return value != null ? value : ''; - }; - BaseGridSerializingSession.prototype.getHeaderName = function (callback, column) { - if (callback) { - return callback({ - column: column, - api: this.gridOptionsWrapper.getApi(), - columnApi: this.gridOptionsWrapper.getColumnApi(), - context: this.gridOptionsWrapper.getContext() - }); - } - else { - return this.columnController.getDisplayNameForColumn(column, 'csv', true); - } - }; - BaseGridSerializingSession.prototype.createValueForGroupNode = function (node) { - if (this.processRowGroupCallback) { - return this.processRowGroupCallback({ - node: node, - api: this.gridOptionsWrapper.getApi(), - columnApi: this.gridOptionsWrapper.getColumnApi(), - context: this.gridOptionsWrapper.getContext(), - }); - } - var keys = [node.key]; - while (node.parent) { - node = node.parent; - keys.push(node.key); - } - return keys.reverse().join(' -> '); - }; - BaseGridSerializingSession.prototype.processCell = function (rowNode, column, value, processCellCallback, type) { - if (processCellCallback) { - return processCellCallback({ - column: column, - node: rowNode, - value: value, - api: this.gridOptionsWrapper.getApi(), - columnApi: this.gridOptionsWrapper.getColumnApi(), - context: this.gridOptionsWrapper.getContext(), - type: type - }); - } - else { - return value; - } - }; - return BaseGridSerializingSession; -}()); - +var RowType; +(function (RowType) { + RowType[RowType["HEADER_GROUPING"] = 0] = "HEADER_GROUPING"; + RowType[RowType["HEADER"] = 1] = "HEADER"; + RowType[RowType["BODY"] = 2] = "BODY"; +})(RowType || (RowType = {})); var GridSerializer = /** @class */ (function (_super) { __extends(GridSerializer, _super); function GridSerializer() { @@ -46523,123 +55212,193 @@ var GridSerializer = /** @class */ (function (_super) { } GridSerializer.prototype.serialize = function (gridSerializingSession, params) { if (params === void 0) { params = {}; } - var rowSkipper = params.shouldRowBeSkipped || (function () { return false; }); - var api = this.gridOptionsWrapper.getApi(); - var columnApi = this.gridOptionsWrapper.getColumnApi(); - var skipSingleChildrenGroup = this.gridOptionsWrapper.isGroupRemoveSingleChildren(); - var skipLowestSingleChildrenGroup = this.gridOptionsWrapper.isGroupRemoveLowestSingleChildren(); - var context = this.gridOptionsWrapper.getContext(); - // when in pivot mode, we always render cols on screen, never 'all columns' - var isPivotMode = this.columnController.isPivotMode(); - var rowModelNormal = this.rowModel.getType() === _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE; - var onlySelectedNonStandardModel = !rowModelNormal && params.onlySelected; - var columnsToExport = []; - if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].existsAndNotEmpty(params.columnKeys)) { - columnsToExport = this.columnController.getGridColumns(params.columnKeys); - } - else if (params.allColumns && !isPivotMode) { - // add auto group column for tree data - columnsToExport = this.gridOptionsWrapper.isTreeData() ? - this.columnController.getGridColumns([_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].GROUP_AUTO_COLUMN_ID]) : []; - columnsToExport = columnsToExport.concat(this.columnController.getAllPrimaryColumns() || []); - } - else { - columnsToExport = this.columnController.getAllDisplayedColumns(); - } - if (params.customHeader) { - gridSerializingSession.addCustomContent(params.customHeader); - } - gridSerializingSession.prepare(columnsToExport); + var columnsToExport = this.getColumnsToExport(params.allColumns, params.columnKeys); + var serializeChain = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].compose( // first pass, put in the header names of the cols - if (params.columnGroups) { - var groupInstanceIdCreator = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["GroupInstanceIdCreator"](); - var displayedGroups = this.displayedGroupCreator.createDisplayedGroups(columnsToExport, this.columnController.getGridBalancedTree(), groupInstanceIdCreator, null); - this.recursivelyAddHeaderGroups(displayedGroups, gridSerializingSession, params.processGroupHeaderCallback); - } - if (!params.skipHeader) { - var gridRowIterator_1 = gridSerializingSession.onNewHeaderRow(); - columnsToExport.forEach(function (column, index) { - gridRowIterator_1.onColumn(column, index, undefined); - }); - } - this.pinnedRowModel.forEachPinnedTopRow(processRow); - if (isPivotMode) { - if (this.rowModel.forEachPivotNode) { - this.rowModel.forEachPivotNode(processRow); - } - else { - //Must be enterprise, so we can just loop through all the nodes - this.rowModel.forEachNode(processRow); - } - } - else { - // onlySelectedAllPages: user doing pagination and wants selected items from - // other pages, so cannot use the standard row model as it won't have rows from - // other pages. - // onlySelectedNonStandardModel: if user wants selected in non standard row model - // (eg viewport) then again rowmodel cannot be used, so need to use selected instead. - if (params.onlySelectedAllPages || onlySelectedNonStandardModel) { - var selectedNodes = this.selectionController.getSelectedNodes(); - selectedNodes.forEach(function (node) { - processRow(node); - }); - } - else { - // here is everything else - including standard row model and selected. we don't use - // the selection model even when just using selected, so that the result is the order - // of the rows appearing on the screen. - if (rowModelNormal) { - this.rowModel.forEachNodeAfterFilterAndSort(processRow); - } - else { - this.rowModel.forEachNode(processRow); + this.prepareSession(columnsToExport), this.prependContent(params), this.exportColumnGroups(params, columnsToExport), this.exportHeaders(params, columnsToExport), this.processPinnedTopRows(params, columnsToExport), this.processRows(params, columnsToExport), this.processPinnedBottomRows(params, columnsToExport), this.appendContent(params)); + return serializeChain(gridSerializingSession).parse(); + }; + GridSerializer.prototype.processRow = function (gridSerializingSession, params, columnsToExport, node) { + var _this = this; + var rowSkipper = params.shouldRowBeSkipped || (function () { return false; }); + var gridOptionsWrapper = this.gridOptionsWrapper; + var context = gridOptionsWrapper.getContext(); + var api = gridOptionsWrapper.getApi(); + var columnApi = gridOptionsWrapper.getColumnApi(); + var skipSingleChildrenGroup = gridOptionsWrapper.isGroupRemoveSingleChildren(); + var hideOpenParents = gridOptionsWrapper.isGroupHideOpenParents(); + var skipLowestSingleChildrenGroup = gridOptionsWrapper.isGroupRemoveLowestSingleChildren(); + var isLeafNode = this.columnModel.isPivotMode() ? node.leafGroup : !node.group; + var skipRowGroups = params.skipGroups || params.skipRowGroups; + var shouldSkipLowestGroup = skipLowestSingleChildrenGroup && node.leafGroup; + var shouldSkipCurrentGroup = node.allChildrenCount === 1 && (skipSingleChildrenGroup || shouldSkipLowestGroup); + if (skipRowGroups && params.skipGroups) { + _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].doOnce(function () { return console.warn('AG Grid: Since v25.2 `skipGroups` has been renamed to `skipRowGroups`.'); }, 'gridSerializer-skipGroups'); + } + var rowPosition = { rowIndex: node.rowIndex, rowPinned: node.rowPinned }; + if ((!isLeafNode && (params.skipRowGroups || shouldSkipCurrentGroup || hideOpenParents)) || + (params.onlySelected && !node.isSelected()) || + (params.rowNodes && !params.rowNodes.some(function (position) { return _this.rowPositionUtils.sameRow(position, rowPosition); })) || + (params.skipPinnedTop && node.rowPinned === 'top') || + (params.skipPinnedBottom && node.rowPinned === 'bottom')) { + return; + } + // if we are in pivotMode, then the grid will show the root node only + // if it's not a leaf group + var nodeIsRootNode = node.level === -1; + if (nodeIsRootNode && !node.leafGroup) { + return; + } + var shouldRowBeSkipped = rowSkipper({ node: node, api: api, context: context }); + if (shouldRowBeSkipped) { + return; + } + var rowAccumulator = gridSerializingSession.onNewBodyRow(); + columnsToExport.forEach(function (column, index) { + rowAccumulator.onColumn(column, index, node); + }); + if (params.getCustomContentBelowRow) { + var content = params.getCustomContentBelowRow({ node: node, api: api, columnApi: columnApi, context: context }); + if (content) { + gridSerializingSession.addCustomContent(content); + } + } + }; + GridSerializer.prototype.appendContent = function (params) { + return function (gridSerializingSession) { + var appendContent = params.customFooter || params.appendContent; + if (appendContent) { + if (params.customFooter) { + _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].doOnce(function () { return console.warn('AG Grid: Since version 25.2.0 the `customFooter` param has been deprecated. Use `appendContent` instead.'); }, 'gridSerializer-customFooter'); } + gridSerializingSession.addCustomContent(appendContent); } - } - this.pinnedRowModel.forEachPinnedBottomRow(processRow); - if (params.customFooter) { - gridSerializingSession.addCustomContent(params.customFooter); - } - function processRow(node) { - var shouldSkipLowestGroup = skipLowestSingleChildrenGroup && node.leafGroup; - var shouldSkipCurrentGroup = node.allChildrenCount === 1 && (skipSingleChildrenGroup || shouldSkipLowestGroup); - if (node.group && (params.skipGroups || shouldSkipCurrentGroup)) { - return; - } - if (params.skipFooters && node.footer) { - return; + return gridSerializingSession; + }; + }; + GridSerializer.prototype.prependContent = function (params) { + return function (gridSerializingSession) { + var prependContent = params.customHeader || params.prependContent; + if (prependContent) { + if (params.customHeader) { + _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].doOnce(function () { return console.warn('AG Grid: Since version 25.2.0 the `customHeader` param has been deprecated. Use `prependContent` instead.'); }, 'gridSerializer-customHeader'); + } + gridSerializingSession.addCustomContent(prependContent); } - if (params.onlySelected && !node.isSelected()) { - return; + return gridSerializingSession; + }; + }; + GridSerializer.prototype.prepareSession = function (columnsToExport) { + return function (gridSerializingSession) { + gridSerializingSession.prepare(columnsToExport); + return gridSerializingSession; + }; + }; + GridSerializer.prototype.exportColumnGroups = function (params, columnsToExport) { + var _this = this; + return function (gridSerializingSession) { + if (!params.skipColumnGroupHeaders) { + var groupInstanceIdCreator = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["GroupInstanceIdCreator"](); + var displayedGroups = _this.displayedGroupCreator.createDisplayedGroups(columnsToExport, _this.columnModel.getGridBalancedTree(), groupInstanceIdCreator, null); + _this.recursivelyAddHeaderGroups(displayedGroups, gridSerializingSession, params.processGroupHeaderCallback); } - if (params.skipPinnedTop && node.rowPinned === 'top') { - return; + else if (params.columnGroups) { + _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].doOnce(function () { return console.warn('AG Grid: Since v25.2 the `columnGroups` param has deprecated, and groups are exported by default.'); }, 'gridSerializer-columnGroups'); } - if (params.skipPinnedBottom && node.rowPinned === 'bottom') { - return; + return gridSerializingSession; + }; + }; + GridSerializer.prototype.exportHeaders = function (params, columnsToExport) { + return function (gridSerializingSession) { + if (!params.skipHeader && !params.skipColumnHeaders) { + var gridRowIterator_1 = gridSerializingSession.onNewHeaderRow(); + columnsToExport.forEach(function (column, index) { + gridRowIterator_1.onColumn(column, index, undefined); + }); } - // if we are in pivotMode, then the grid will show the root node only - // if it's not a leaf group - var nodeIsRootNode = node.level === -1; - if (nodeIsRootNode && !node.leafGroup) { - return; + else if (params.skipHeader) { + _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].doOnce(function () { return console.warn('AG Grid: Since v25.2 the `skipHeader` param has been renamed to `skipColumnHeaders`.'); }, 'gridSerializer-skipHeader'); } - var shouldRowBeSkipped = rowSkipper({ node: node, api: api, context: context }); - if (shouldRowBeSkipped) { - return; + return gridSerializingSession; + }; + }; + GridSerializer.prototype.processPinnedTopRows = function (params, columnsToExport) { + var _this = this; + return function (gridSerializingSession) { + var processRow = _this.processRow.bind(_this, gridSerializingSession, params, columnsToExport); + _this.pinnedRowModel.forEachPinnedTopRow(processRow); + return gridSerializingSession; + }; + }; + GridSerializer.prototype.processRows = function (params, columnsToExport) { + var _this = this; + return function (gridSerializingSession) { + // when in pivot mode, we always render cols on screen, never 'all columns' + var rowModel = _this.rowModel; + var rowModelType = rowModel.getType(); + var usingCsrm = rowModelType === _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE; + var usingSsrm = rowModelType === _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE; + var onlySelectedNonStandardModel = !usingCsrm && params.onlySelected; + var processRow = _this.processRow.bind(_this, gridSerializingSession, params, columnsToExport); + if (_this.columnModel.isPivotMode()) { + if (usingCsrm) { + rowModel.forEachPivotNode(processRow); + } + else { + // must be enterprise, so we can just loop through all the nodes + rowModel.forEachNode(processRow); + } } - var rowAccumulator = gridSerializingSession.onNewBodyRow(); - columnsToExport.forEach(function (column, index) { - rowAccumulator.onColumn(column, index, node); - }); - if (params.getCustomContentBelowRow) { - var content = params.getCustomContentBelowRow({ node: node, api: api, columnApi: columnApi, context: context }); - if (content) { - gridSerializingSession.addCustomContent(content); + else { + // onlySelectedAllPages: user doing pagination and wants selected items from + // other pages, so cannot use the standard row model as it won't have rows from + // other pages. + // onlySelectedNonStandardModel: if user wants selected in non standard row model + // (eg viewport) then again RowModel cannot be used, so need to use selected instead. + if (params.onlySelectedAllPages || onlySelectedNonStandardModel) { + var selectedNodes = _this.selectionService.getSelectedNodes(); + selectedNodes.forEach(processRow); + } + else { + // here is everything else - including standard row model and selected. we don't use + // the selection model even when just using selected, so that the result is the order + // of the rows appearing on the screen. + if (usingCsrm) { + rowModel.forEachNodeAfterFilterAndSort(processRow); + } + else if (usingSsrm) { + rowModel.forEachNodeAfterFilterAndSort(processRow); + } + else { + rowModel.forEachNode(processRow); + } } } + return gridSerializingSession; + }; + }; + GridSerializer.prototype.processPinnedBottomRows = function (params, columnsToExport) { + var _this = this; + return function (gridSerializingSession) { + var processRow = _this.processRow.bind(_this, gridSerializingSession, params, columnsToExport); + _this.pinnedRowModel.forEachPinnedBottomRow(processRow); + return gridSerializingSession; + }; + }; + GridSerializer.prototype.getColumnsToExport = function (allColumns, columnKeys) { + if (allColumns === void 0) { allColumns = false; } + var isPivotMode = this.columnModel.isPivotMode(); + if (columnKeys && columnKeys.length) { + return this.columnModel.getGridColumns(columnKeys); + } + if (allColumns && !isPivotMode) { + // add auto group column for tree data + var columns = this.gridOptionsWrapper.isTreeData() + ? this.columnModel.getGridColumns([_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].GROUP_AUTO_COLUMN_ID]) + : []; + return columns.concat(this.columnModel.getAllPrimaryColumns() || []); } - return gridSerializingSession.parse(); + return this.columnModel.getAllDisplayedColumns(); }; GridSerializer.prototype.recursivelyAddHeaderGroups = function (displayedGroups, gridSerializingSession, processGroupHeaderCallback) { var directChildrenHeaderGroups = []; @@ -46673,17 +55432,34 @@ var GridSerializer = /** @class */ (function (_super) { }); } else { - name = _this.columnController.getDisplayNameForColumnGroup(columnGroup, 'header'); - } - gridRowIterator.onColumn(name || '', columnIndex++, columnGroup.getLeafColumns().length - 1); + name = _this.columnModel.getDisplayNameForColumnGroup(columnGroup, 'header'); + } + var collapsibleGroupRanges = columnGroup.getLeafColumns().reduce(function (collapsibleGroups, currentColumn, currentIdx, arr) { + var lastGroup = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].last(collapsibleGroups); + var groupShow = currentColumn.getColumnGroupShow() === 'open'; + if (!groupShow) { + if (lastGroup && lastGroup[1] == null) { + lastGroup[1] = currentIdx - 1; + } + } + else if (!lastGroup || lastGroup[1] != null) { + lastGroup = [currentIdx]; + collapsibleGroups.push(lastGroup); + } + if (currentIdx === arr.length - 1 && lastGroup && lastGroup[1] == null) { + lastGroup[1] = currentIdx; + } + return collapsibleGroups; + }, []); + gridRowIterator.onColumn(name || '', columnIndex++, columnGroup.getLeafColumns().length - 1, collapsibleGroupRanges); }); }; __decorate([ Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('displayedGroupCreator') ], GridSerializer.prototype, "displayedGroupCreator", void 0); __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController') - ], GridSerializer.prototype, "columnController", void 0); + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnModel') + ], GridSerializer.prototype, "columnModel", void 0); __decorate([ Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel') ], GridSerializer.prototype, "rowModel", void 0); @@ -46691,113 +55467,31 @@ var GridSerializer = /** @class */ (function (_super) { Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('pinnedRowModel') ], GridSerializer.prototype, "pinnedRowModel", void 0); __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('selectionController') - ], GridSerializer.prototype, "selectionController", void 0); - __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnFactory') - ], GridSerializer.prototype, "columnFactory", void 0); + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('selectionService') + ], GridSerializer.prototype, "selectionService", void 0); __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], GridSerializer.prototype, "gridOptionsWrapper", void 0); + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowPositionUtils') + ], GridSerializer.prototype, "rowPositionUtils", void 0); GridSerializer = __decorate([ Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])("gridSerializer") ], GridSerializer); return GridSerializer; }(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); -var RowType; -(function (RowType) { - RowType[RowType["HEADER_GROUPING"] = 0] = "HEADER_GROUPING"; - RowType[RowType["HEADER"] = 1] = "HEADER"; - RowType[RowType["BODY"] = 2] = "BODY"; -})(RowType || (RowType = {})); - - -/***/ }), -/* 215 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Downloader", function() { return Downloader; }); -/* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - -var Downloader = /** @class */ (function () { - function Downloader() { - } - Downloader.prototype.download = function (fileName, content) { - // Internet Explorer - if (window.navigator.msSaveOrOpenBlob) { - window.navigator.msSaveOrOpenBlob(content, fileName); - } - else { - // Other Browsers - var element = document.createElement("a"); - var url_1 = window.URL.createObjectURL(content); - element.setAttribute("href", url_1); - element.setAttribute("download", fileName); - element.style.display = "none"; - document.body.appendChild(element); - element.dispatchEvent(new MouseEvent('click', { - bubbles: false, - cancelable: true, - view: window - })); - document.body.removeChild(element); - window.setTimeout(function () { - window.URL.revokeObjectURL(url_1); - }, 0); - } - }; - Downloader = __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])("downloader") - ], Downloader); - return Downloader; -}()); - /***/ }), -/* 216 */ +/* 269 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "XmlFactory", function() { return XmlFactory; }); -/* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3); -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; - var LINE_SEPARATOR = '\r\n'; -var XmlFactory = /** @class */ (function (_super) { - __extends(XmlFactory, _super); +var XmlFactory = /** @class */ (function () { function XmlFactory() { - return _super !== null && _super.apply(this, arguments) || this; } - XmlFactory.prototype.createHeader = function (headerElement) { + XmlFactory.createHeader = function (headerElement) { if (headerElement === void 0) { headerElement = {}; } var headerStart = ''; @@ -46814,7 +55508,7 @@ var XmlFactory = /** @class */ (function (_super) { var att = keys.map(function (key) { return key + "=\"" + headerElement[key] + "\""; }).join(' '); return headerStart + "xml " + att + " " + headerEnd; }; - XmlFactory.prototype.createXml = function (xmlElement, booleanTransformer) { + XmlFactory.createXml = function (xmlElement, booleanTransformer) { var _this = this; var props = ''; if (xmlElement.properties) { @@ -46846,7 +55540,7 @@ var XmlFactory = /** @class */ (function (_super) { } return result + '' + LINE_SEPARATOR; }; - XmlFactory.prototype.returnAttributeIfPopulated = function (key, value, booleanTransformer) { + XmlFactory.returnAttributeIfPopulated = function (key, value, booleanTransformer) { if (!value && value !== '' && value !== 0) { return ''; } @@ -46858,133 +55552,141 @@ var XmlFactory = /** @class */ (function (_super) { } return " " + key + "=\"" + xmlValue + "\""; }; - XmlFactory = __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('xmlFactory') - ], XmlFactory); return XmlFactory; -}(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); +}()); /***/ }), -/* 217 */ +/* 270 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ZipContainer", function() { return ZipContainer; }); /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3); -var __extends = (undefined && undefined.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); +var __values = (undefined && undefined.__values) || function(o) { + var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0; + if (m) return m.call(o); + if (o && typeof o.length === "number") return { + next: function () { + if (o && i >= o.length) o = void 0; + return { value: o && o[i++], done: !o }; + } }; -})(); -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; + throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined."); }; // table for crc calculation // from: https://referencesource.microsoft.com/#System/sys/System/IO/compression/Crc32Helper.cs,3b31978c7d7f7246,references -var crcTable = [ - 0, 1996959894, -301047508, -1727442502, 124634137, 1886057615, -379345611, -1637575261, 249268274, - 2044508324, -522852066, -1747789432, 162941995, 2125561021, -407360249, -1866523247, 498536548, - 1789927666, -205950648, -2067906082, 450548861, 1843258603, -187386543, -2083289657, 325883990, - 1684777152, -43845254, -1973040660, 335633487, 1661365465, -99664541, -1928851979, 997073096, - 1281953886, -715111964, -1570279054, 1006888145, 1258607687, -770865667, -1526024853, 901097722, - 1119000684, -608450090, -1396901568, 853044451, 1172266101, -589951537, -1412350631, 651767980, - 1373503546, -925412992, -1076862698, 565507253, 1454621731, -809855591, -1195530993, 671266974, - 1594198024, -972236366, -1324619484, 795835527, 1483230225, -1050600021, -1234817731, 1994146192, - 31158534, -1731059524, -271249366, 1907459465, 112637215, -1614814043, -390540237, 2013776290, - 251722036, -1777751922, -519137256, 2137656763, 141376813, -1855689577, -429695999, 1802195444, - 476864866, -2056965928, -228458418, 1812370925, 453092731, -2113342271, -183516073, 1706088902, - 314042704, -1950435094, -54949764, 1658658271, 366619977, -1932296973, -69972891, 1303535960, - 984961486, -1547960204, -725929758, 1256170817, 1037604311, -1529756563, -740887301, 1131014506, - 879679996, -1385723834, -631195440, 1141124467, 855842277, -1442165665, -586318647, 1342533948, - 654459306, -1106571248, -921952122, 1466479909, 544179635, -1184443383, -832445281, 1591671054, - 702138776, -1328506846, -942167884, 1504918807, 783551873, -1212326853, -1061524307, -306674912, - -1698712650, 62317068, 1957810842, -355121351, -1647151185, 81470997, 1943803523, -480048366, - -1805370492, 225274430, 2053790376, -468791541, -1828061283, 167816743, 2097651377, -267414716, - -2029476910, 503444072, 1762050814, -144550051, -2140837941, 426522225, 1852507879, -19653770, - -1982649376, 282753626, 1742555852, -105259153, -1900089351, 397917763, 1622183637, -690576408, - -1580100738, 953729732, 1340076626, -776247311, -1497606297, 1068828381, 1219638859, -670225446, - -1358292148, 906185462, 1090812512, -547295293, -1469587627, 829329135, 1181335161, -882789492, - -1134132454, 628085408, 1382605366, -871598187, -1156888829, 570562233, 1426400815, -977650754, - -1296233688, 733239954, 1555261956, -1026031705, -1244606671, 752459403, 1541320221, -1687895376, - -328994266, 1969922972, 40735498, -1677130071, -351390145, 1913087877, 83908371, -1782625662, - -491226604, 2075208622, 213261112, -1831694693, -438977011, 2094854071, 198958881, -2032938284, - -237706686, 1759359992, 534414190, -2118248755, -155638181, 1873836001, 414664567, -2012718362, - -15766928, 1711684554, 285281116, -1889165569, -127750551, 1634467795, 376229701, -1609899400, - -686959890, 1308918612, 956543938, -1486412191, -799009033, 1231636301, 1047427035, -1362007478, - -640263460, 1088359270, 936918000, -1447252397, -558129467, 1202900863, 817233897, -1111625188, - -893730166, 1404277552, 615818150, -1160759803, -841546093, 1423857449, 601450431, -1285129682, - -1000256840, 1567103746, 711928724, -1274298825, -1022587231, 1510334235, 755167117 -]; -var ZipContainer = /** @class */ (function (_super) { - __extends(ZipContainer, _super); +var crcTable = new Uint32Array([ + 0x00000000, 0x77073096, 0xee0e612c, 0x990951ba, 0x076dc419, 0x706af48f, + 0xe963a535, 0x9e6495a3, 0x0edb8832, 0x79dcb8a4, 0xe0d5e91e, 0x97d2d988, + 0x09b64c2b, 0x7eb17cbd, 0xe7b82d07, 0x90bf1d91, 0x1db71064, 0x6ab020f2, + 0xf3b97148, 0x84be41de, 0x1adad47d, 0x6ddde4eb, 0xf4d4b551, 0x83d385c7, + 0x136c9856, 0x646ba8c0, 0xfd62f97a, 0x8a65c9ec, 0x14015c4f, 0x63066cd9, + 0xfa0f3d63, 0x8d080df5, 0x3b6e20c8, 0x4c69105e, 0xd56041e4, 0xa2677172, + 0x3c03e4d1, 0x4b04d447, 0xd20d85fd, 0xa50ab56b, 0x35b5a8fa, 0x42b2986c, + 0xdbbbc9d6, 0xacbcf940, 0x32d86ce3, 0x45df5c75, 0xdcd60dcf, 0xabd13d59, + 0x26d930ac, 0x51de003a, 0xc8d75180, 0xbfd06116, 0x21b4f4b5, 0x56b3c423, + 0xcfba9599, 0xb8bda50f, 0x2802b89e, 0x5f058808, 0xc60cd9b2, 0xb10be924, + 0x2f6f7c87, 0x58684c11, 0xc1611dab, 0xb6662d3d, 0x76dc4190, 0x01db7106, + 0x98d220bc, 0xefd5102a, 0x71b18589, 0x06b6b51f, 0x9fbfe4a5, 0xe8b8d433, + 0x7807c9a2, 0x0f00f934, 0x9609a88e, 0xe10e9818, 0x7f6a0dbb, 0x086d3d2d, + 0x91646c97, 0xe6635c01, 0x6b6b51f4, 0x1c6c6162, 0x856530d8, 0xf262004e, + 0x6c0695ed, 0x1b01a57b, 0x8208f4c1, 0xf50fc457, 0x65b0d9c6, 0x12b7e950, + 0x8bbeb8ea, 0xfcb9887c, 0x62dd1ddf, 0x15da2d49, 0x8cd37cf3, 0xfbd44c65, + 0x4db26158, 0x3ab551ce, 0xa3bc0074, 0xd4bb30e2, 0x4adfa541, 0x3dd895d7, + 0xa4d1c46d, 0xd3d6f4fb, 0x4369e96a, 0x346ed9fc, 0xad678846, 0xda60b8d0, + 0x44042d73, 0x33031de5, 0xaa0a4c5f, 0xdd0d7cc9, 0x5005713c, 0x270241aa, + 0xbe0b1010, 0xc90c2086, 0x5768b525, 0x206f85b3, 0xb966d409, 0xce61e49f, + 0x5edef90e, 0x29d9c998, 0xb0d09822, 0xc7d7a8b4, 0x59b33d17, 0x2eb40d81, + 0xb7bd5c3b, 0xc0ba6cad, 0xedb88320, 0x9abfb3b6, 0x03b6e20c, 0x74b1d29a, + 0xead54739, 0x9dd277af, 0x04db2615, 0x73dc1683, 0xe3630b12, 0x94643b84, + 0x0d6d6a3e, 0x7a6a5aa8, 0xe40ecf0b, 0x9309ff9d, 0x0a00ae27, 0x7d079eb1, + 0xf00f9344, 0x8708a3d2, 0x1e01f268, 0x6906c2fe, 0xf762575d, 0x806567cb, + 0x196c3671, 0x6e6b06e7, 0xfed41b76, 0x89d32be0, 0x10da7a5a, 0x67dd4acc, + 0xf9b9df6f, 0x8ebeeff9, 0x17b7be43, 0x60b08ed5, 0xd6d6a3e8, 0xa1d1937e, + 0x38d8c2c4, 0x4fdff252, 0xd1bb67f1, 0xa6bc5767, 0x3fb506dd, 0x48b2364b, + 0xd80d2bda, 0xaf0a1b4c, 0x36034af6, 0x41047a60, 0xdf60efc3, 0xa867df55, + 0x316e8eef, 0x4669be79, 0xcb61b38c, 0xbc66831a, 0x256fd2a0, 0x5268e236, + 0xcc0c7795, 0xbb0b4703, 0x220216b9, 0x5505262f, 0xc5ba3bbe, 0xb2bd0b28, + 0x2bb45a92, 0x5cb36a04, 0xc2d7ffa7, 0xb5d0cf31, 0x2cd99e8b, 0x5bdeae1d, + 0x9b64c2b0, 0xec63f226, 0x756aa39c, 0x026d930a, 0x9c0906a9, 0xeb0e363f, + 0x72076785, 0x05005713, 0x95bf4a82, 0xe2b87a14, 0x7bb12bae, 0x0cb61b38, + 0x92d28e9b, 0xe5d5be0d, 0x7cdcefb7, 0x0bdbdf21, 0x86d3d2d4, 0xf1d4e242, + 0x68ddb3f8, 0x1fda836e, 0x81be16cd, 0xf6b9265b, 0x6fb077e1, 0x18b74777, + 0x88085ae6, 0xff0f6a70, 0x66063bca, 0x11010b5c, 0x8f659eff, 0xf862ae69, + 0x616bffd3, 0x166ccf45, 0xa00ae278, 0xd70dd2ee, 0x4e048354, 0x3903b3c2, + 0xa7672661, 0xd06016f7, 0x4969474d, 0x3e6e77db, 0xaed16a4a, 0xd9d65adc, + 0x40df0b66, 0x37d83bf0, 0xa9bcae53, 0xdebb9ec5, 0x47b2cf7f, 0x30b5ffe9, + 0xbdbdf21c, 0xcabac28a, 0x53b39330, 0x24b4a3a6, 0xbad03605, 0xcdd70693, + 0x54de5729, 0x23d967bf, 0xb3667a2e, 0xc4614ab8, 0x5d681b02, 0x2a6f2b94, + 0xb40bbe37, 0xc30c8ea1, 0x5a05df1b, 0x2d02ef8d +]); +var ZipContainer = /** @class */ (function () { function ZipContainer() { - var _this = _super !== null && _super.apply(this, arguments) || this; - _this.folders = []; - _this.files = []; - _this.addFolder = function (path) { - _this.folders.push({ - path: path, - created: new Date() - }); - }; - return _this; } - ZipContainer.prototype.addFolders = function (paths) { - paths.forEach(this.addFolder); + ZipContainer.addFolders = function (paths) { + paths.forEach(this.addFolder.bind(this)); }; - ZipContainer.prototype.addFile = function (path, content) { - this.files.push({ + ZipContainer.addFolder = function (path) { + this.folders.push({ path: path, created: new Date(), - content: content + isBase64: false }); }; - ZipContainer.prototype.clearStream = function () { - this.folders = []; - this.files = []; + ZipContainer.addFile = function (path, content, isBase64) { + if (isBase64 === void 0) { isBase64 = false; } + this.files.push({ + path: path, + created: new Date(), + content: content, + isBase64: isBase64 + }); }; - ZipContainer.prototype.getContent = function (mimeType) { + ZipContainer.getContent = function (mimeType) { if (mimeType === void 0) { mimeType = 'application/zip'; } var textOutput = this.buildFileStream(); var uInt8Output = this.buildUint8Array(textOutput); this.clearStream(); return new Blob([uInt8Output], { type: mimeType }); }; - ZipContainer.prototype.buildFileStream = function (fData) { + ZipContainer.clearStream = function () { + this.folders = []; + this.files = []; + }; + ZipContainer.buildFileStream = function (fData) { + var e_1, _a; if (fData === void 0) { fData = ''; } var totalFiles = this.folders.concat(this.files); var len = totalFiles.length; var foData = ''; var lL = 0; var cL = 0; - for (var _i = 0, totalFiles_1 = totalFiles; _i < totalFiles_1.length; _i++) { - var currentFile = totalFiles_1[_i]; - var _a = this.getHeader(currentFile, lL), fileHeader = _a.fileHeader, folderHeader = _a.folderHeader, content = _a.content; - lL += fileHeader.length + content.length; - cL += folderHeader.length; - fData += fileHeader + content; - foData += folderHeader; + try { + for (var totalFiles_1 = __values(totalFiles), totalFiles_1_1 = totalFiles_1.next(); !totalFiles_1_1.done; totalFiles_1_1 = totalFiles_1.next()) { + var currentFile = totalFiles_1_1.value; + var _b = this.getHeader(currentFile, lL), fileHeader = _b.fileHeader, folderHeader = _b.folderHeader, content = _b.content; + lL += fileHeader.length + content.length; + cL += folderHeader.length; + fData += fileHeader + content; + foData += folderHeader; + } + } + catch (e_1_1) { e_1 = { error: e_1_1 }; } + finally { + try { + if (totalFiles_1_1 && !totalFiles_1_1.done && (_a = totalFiles_1.return)) _a.call(totalFiles_1); + } + finally { if (e_1) throw e_1.error; } } var foEnd = this.buildFolderEnd(len, cL, lL); return fData + foData + foEnd; }; - ZipContainer.prototype.getHeader = function (currentFile, offset) { - var content = currentFile.content, path = currentFile.path, created = currentFile.created; + ZipContainer.getHeader = function (currentFile, offset) { + var content = currentFile.content, path = currentFile.path, created = currentFile.created, isBase64 = currentFile.isBase64; var utf8_encode = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].utf8_encode, decToHex = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].decToHex; var utfPath = utf8_encode(path); var isUTF8 = utfPath !== path; @@ -46995,14 +55697,15 @@ var ZipContainer = /** @class */ (function (_super) { var uExtraFieldPath = decToHex(1, 1) + decToHex(this.getFromCrc32Table(utfPath), 4) + utfPath; extraFields = "\x75\x70" + decToHex(uExtraFieldPath.length, 2) + uExtraFieldPath; } + var _a = !content ? { size: 0, content: '' } : this.getConvertedContent(content, isBase64), size = _a.size, convertedContent = _a.content; var header = '\x0A\x00' + (isUTF8 ? '\x00\x08' : '\x00\x00') + '\x00\x00' + decToHex(time, 2) + // last modified time decToHex(dt, 2) + // last modified date - decToHex(content ? this.getFromCrc32Table(content) : 0, 4) + - decToHex(content ? content.length : 0, 4) + // compressed size - decToHex(content ? content.length : 0, 4) + // uncompressed size + decToHex(size ? this.getFromCrc32Table(convertedContent) : 0, 4) + + decToHex(size, 4) + // compressed size + decToHex(size, 4) + // uncompressed size decToHex(utfPath.length, 2) + // file name length decToHex(extraFields.length, 2); // extra field length var fileHeader = 'PK\x03\x04' + header + utfPath + extraFields; @@ -47016,9 +55719,20 @@ var ZipContainer = /** @class */ (function (_super) { decToHex(offset, 4) + // relative offset of local header utfPath + // file name extraFields; // extra field - return { fileHeader: fileHeader, folderHeader: folderHeader, content: content || '' }; + return { fileHeader: fileHeader, folderHeader: folderHeader, content: convertedContent || '' }; + }; + ZipContainer.getConvertedContent = function (content, isBase64) { + if (isBase64 === void 0) { isBase64 = false; } + if (isBase64) { + content = content.split(';base64,')[1]; + } + content = isBase64 ? atob(content) : content; + return { + size: content.length, + content: content + }; }; - ZipContainer.prototype.buildFolderEnd = function (tLen, cLen, lLen) { + ZipContainer.buildFolderEnd = function (tLen, cLen, lLen) { var decToHex = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].decToHex; return 'PK\x05\x06' + // central folder end '\x00\x00' + @@ -47029,31 +55743,35 @@ var ZipContainer = /** @class */ (function (_super) { decToHex(lLen, 4) + // central folder start offset '\x00\x00'; }; - ZipContainer.prototype.buildUint8Array = function (content) { + ZipContainer.buildUint8Array = function (content) { var uint8 = new Uint8Array(content.length); for (var i = 0; i < uint8.length; i++) { uint8[i] = content.charCodeAt(i); } return uint8; }; - ZipContainer.prototype.getFromCrc32Table = function (content, crc) { - if (crc === void 0) { crc = 0; } + ZipContainer.getFromCrc32Table = function (content) { if (!content.length) { return 0; } - crc ^= (-1); + var size = content.length; + var iterable = new Uint8Array(size); + for (var i = 0; i < size; i++) { + iterable[i] = content.charCodeAt(i); + } + var crc = 0 ^ (-1); var j = 0; var k = 0; var l = 0; - for (var i = 0; i < content.length; i++) { - j = content.charCodeAt(i); + for (var i = 0; i < size; i++) { + j = iterable[i]; k = (crc ^ j) & 0xFF; l = crcTable[k]; crc = (crc >>> 8) ^ l; } return crc ^ (-1); }; - ZipContainer.prototype.convertTime = function (date) { + ZipContainer.convertTime = function (date) { var time = date.getHours(); time <<= 6; time = time | date.getMinutes(); @@ -47061,7 +55779,7 @@ var ZipContainer = /** @class */ (function (_super) { time = time | date.getSeconds() / 2; return time; }; - ZipContainer.prototype.convertDate = function (date) { + ZipContainer.convertDate = function (date) { var dt = date.getFullYear() - 1980; dt <<= 4; dt = dt | (date.getMonth() + 1); @@ -47069,52 +55787,51 @@ var ZipContainer = /** @class */ (function (_super) { dt = dt | date.getDate(); return dt; }; - ZipContainer = __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('zipContainer') - ], ZipContainer); + ZipContainer.folders = []; + ZipContainer.files = []; return ZipContainer; -}(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); +}()); /***/ }), -/* 218 */ +/* 271 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony import */ var _infiniteRowModelModule__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(219); +/* harmony import */ var _infiniteRowModelModule__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(272); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "InfiniteRowModelModule", function() { return _infiniteRowModelModule__WEBPACK_IMPORTED_MODULE_0__["InfiniteRowModelModule"]; }); /***/ }), -/* 219 */ +/* 272 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "InfiniteRowModelModule", function() { return InfiniteRowModelModule; }); /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3); -/* harmony import */ var _infiniteRowModel_infiniteRowModel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(220); +/* harmony import */ var _infiniteRowModel_infiniteRowModel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(273); var InfiniteRowModelModule = { moduleName: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ModuleNames"].InfiniteRowModelModule, - rowModels: { 'infinite': _infiniteRowModel_infiniteRowModel__WEBPACK_IMPORTED_MODULE_1__["InfiniteRowModel"] } + rowModels: { infinite: _infiniteRowModel_infiniteRowModel__WEBPACK_IMPORTED_MODULE_1__["InfiniteRowModel"] } }; /***/ }), -/* 220 */ +/* 273 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "InfiniteRowModel", function() { return InfiniteRowModel; }); /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3); -/* harmony import */ var _infiniteCache__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(221); +/* harmony import */ var _infiniteCache__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(274); var __extends = (undefined && undefined.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || @@ -47159,6 +55876,13 @@ var InfiniteRowModel = /** @class */ (function (_super) { this.rowHeight = this.gridOptionsWrapper.getRowHeightAsNumber(); this.addEventListeners(); this.addDestroyFunc(function () { return _this.destroyCache(); }); + this.verifyProps(); + }; + InfiniteRowModel.prototype.verifyProps = function () { + if (this.gridOptionsWrapper.getDefaultGroupOrderComparator() != null) { + var message_1 = "AG Grid: defaultGroupOrderComparator cannot be used with Infinite Row Model. If using Infinite Row Model, then sorting is done on the server side, nothing to do with the client."; + _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].doOnce(function () { return console.warn(message_1); }, 'IRM.DefaultGroupOrderComparator'); + } }; InfiniteRowModel.prototype.start = function () { this.setDatasource(this.gridOptionsWrapper.getDatasource()); @@ -47170,13 +55894,11 @@ var InfiniteRowModel = /** @class */ (function (_super) { this.datasource = null; } }; - InfiniteRowModel.prototype.isLastRowFound = function () { - return this.infiniteCache ? this.infiniteCache.isMaxRowFound() : false; - }; InfiniteRowModel.prototype.addEventListeners = function () { this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_FILTER_CHANGED, this.onFilterChanged.bind(this)); this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_SORT_CHANGED, this.onSortChanged.bind(this)); - this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_EVERYTHING_CHANGED, this.onColumnEverything.bind(this)); + this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_NEW_COLUMNS_LOADED, this.onColumnEverything.bind(this)); + this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_STORE_UPDATED, this.onCacheUpdated.bind(this)); }; InfiniteRowModel.prototype.onFilterChanged = function () { this.reset(); @@ -47211,31 +55933,14 @@ var InfiniteRowModel = /** @class */ (function (_super) { this.datasource = datasource; // only reset if we have a valid datasource to working with if (datasource) { - this.checkForDeprecated(); this.reset(); } }; - InfiniteRowModel.prototype.checkForDeprecated = function () { - var ds = this.datasource; - // the number of concurrent loads we are allowed to the server - if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(ds.maxConcurrentRequests)) { - console.error('ag-Grid: since version 5.1.x, maxConcurrentRequests is replaced with grid property maxConcurrentDatasourceRequests'); - } - if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(ds.maxPagesInCache)) { - console.error('ag-Grid: since version 5.1.x, maxPagesInCache is replaced with grid property maxPagesInPaginationCache'); - } - if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(ds.overflowSize)) { - console.error('ag-Grid: since version 5.1.x, overflowSize is replaced with grid property paginationOverflowSize'); - } - if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(ds.blockSize)) { - console.error('ag-Grid: since version 5.1.x, pageSize/blockSize is replaced with grid property infinitePageSize'); - } - }; InfiniteRowModel.prototype.isEmpty = function () { - return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.infiniteCache); + return !this.infiniteCache; }; InfiniteRowModel.prototype.isRowsToRender = function () { - return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(this.infiniteCache); + return !!this.infiniteCache; }; InfiniteRowModel.prototype.getNodesInRangeForSelection = function (firstInRange, lastInRange) { return this.infiniteCache ? this.infiniteCache.getRowNodesInRange(firstInRange, lastInRange) : []; @@ -47243,15 +55948,16 @@ var InfiniteRowModel = /** @class */ (function (_super) { InfiniteRowModel.prototype.reset = function () { // important to return here, as the user could be setting filter or sort before // data-source is set - if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.datasource)) { + if (!this.datasource) { return; } // if user is providing id's, then this means we can keep the selection between datasource hits, // as the rows will keep their unique id's even if, for example, server side sorting or filtering // is done. - var userGeneratingIds = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(this.gridOptionsWrapper.getRowNodeIdFunc()); + var getRowIdFunc = this.gridOptionsWrapper.getRowIdFunc(); + var userGeneratingIds = getRowIdFunc != null; if (!userGeneratingIds) { - this.selectionController.reset(); + this.selectionService.reset(); } this.resetCache(); var event = this.createModelUpdatedEvent(); @@ -47266,19 +55972,13 @@ var InfiniteRowModel = /** @class */ (function (_super) { // maybe they should be true? newPage: false, newData: false, - keepRenderedRows: false, + keepRenderedRows: true, animate: false }; }; InfiniteRowModel.prototype.resetCache = function () { // if not first time creating a cache, need to destroy the old one this.destroyCache(); - var maxConcurrentRequests = this.gridOptionsWrapper.getMaxConcurrentDatasourceRequests(); - var blockLoadDebounceMillis = this.gridOptionsWrapper.getBlockLoadDebounceMillis(); - // there is a bi-directional dependency between the loader and the cache, - // so we create loader here, and then pass dependencies in setDependencies() method later - this.rowNodeBlockLoader = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNodeBlockLoader"](maxConcurrentRequests, blockLoadDebounceMillis); - this.getContext().createBean(this.rowNodeBlockLoader); this.cacheParams = { // the user provided datasource datasource: this.datasource, @@ -47289,55 +55989,44 @@ var InfiniteRowModel = /** @class */ (function (_super) { // properties - this way we take a snapshot of them, so if user changes any, they will be // used next time we create a new cache, which is generally after a filter or sort change, // or a new datasource is set - maxConcurrentRequests: maxConcurrentRequests, - overflowSize: this.gridOptionsWrapper.getCacheOverflowSize(), - initialRowCount: this.gridOptionsWrapper.getInfiniteInitialRowCount(), + initialRowCount: this.defaultIfInvalid(this.gridOptionsWrapper.getInfiniteInitialRowCount(), 1), maxBlocksInCache: this.gridOptionsWrapper.getMaxBlocksInCache(), - blockSize: this.gridOptionsWrapper.getCacheBlockSize(), rowHeight: this.gridOptionsWrapper.getRowHeightAsNumber(), + // if user doesn't provide overflow, we use default overflow of 1, so user can scroll past + // the current page and request first row of next page + overflowSize: this.defaultIfInvalid(this.gridOptionsWrapper.getCacheOverflowSize(), 1), + // page size needs to be 1 or greater. having it at 1 would be silly, as you would be hitting the + // server for one page at a time. so the default if not specified is 100. + blockSize: this.defaultIfInvalid(this.gridOptionsWrapper.getCacheBlockSize(), 100), // the cache could create this, however it is also used by the pages, so handy to create it // here as the settings are also passed to the pages lastAccessedSequence: new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["NumberSequence"]() }; - // set defaults - if (!this.cacheParams.maxConcurrentRequests || !(this.cacheParams.maxConcurrentRequests >= 1)) { - this.cacheParams.maxConcurrentRequests = 2; - } - // page size needs to be 1 or greater. having it at 1 would be silly, as you would be hitting the - // server for one page at a time. so the default if not specified is 100. - if (!this.cacheParams.blockSize || !(this.cacheParams.blockSize >= 1)) { - this.cacheParams.blockSize = 100; - } - // if user doesn't give initial rows to display, we assume one - if (!(this.cacheParams.initialRowCount >= 1)) { - this.cacheParams.initialRowCount = 1; - } - // if user doesn't provide overflow, we use default overflow of 1, so user can scroll past - // the current page and request first row of next page - if (!(this.cacheParams.overflowSize >= 1)) { - this.cacheParams.overflowSize = 1; - } - this.infiniteCache = new _infiniteCache__WEBPACK_IMPORTED_MODULE_1__["InfiniteCache"](this.cacheParams); - this.getContext().createBean(this.infiniteCache); - this.infiniteCache.addEventListener(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNodeCache"].EVENT_CACHE_UPDATED, this.onCacheUpdated.bind(this)); + this.infiniteCache = this.createBean(new _infiniteCache__WEBPACK_IMPORTED_MODULE_1__["InfiniteCache"](this.cacheParams)); + }; + InfiniteRowModel.prototype.defaultIfInvalid = function (value, defaultValue) { + return value > 0 ? value : defaultValue; }; InfiniteRowModel.prototype.destroyCache = function () { if (this.infiniteCache) { this.infiniteCache = this.destroyBean(this.infiniteCache); } - if (this.rowNodeBlockLoader) { - this.rowNodeBlockLoader = this.destroyBean(this.rowNodeBlockLoader); - } }; InfiniteRowModel.prototype.onCacheUpdated = function () { var event = this.createModelUpdatedEvent(); this.eventService.dispatchEvent(event); }; InfiniteRowModel.prototype.getRow = function (rowIndex) { - return this.infiniteCache ? this.infiniteCache.getRow(rowIndex) : null; + if (!this.infiniteCache) { + return undefined; + } + if (rowIndex >= this.infiniteCache.getRowCount()) { + return undefined; + } + return this.infiniteCache.getRow(rowIndex); }; InfiniteRowModel.prototype.getRowNode = function (id) { - var result = null; + var result; this.forEachNode(function (rowNode) { if (rowNode.id === id) { result = rowNode; @@ -47347,12 +56036,9 @@ var InfiniteRowModel = /** @class */ (function (_super) { }; InfiniteRowModel.prototype.forEachNode = function (callback) { if (this.infiniteCache) { - this.infiniteCache.forEachNodeDeep(callback, new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["NumberSequence"]()); + this.infiniteCache.forEachNodeDeep(callback); } }; - InfiniteRowModel.prototype.getCurrentPageHeight = function () { - return this.getRowCount() * this.rowHeight; - }; InfiniteRowModel.prototype.getTopLevelRowCount = function () { return this.getRowCount(); }; @@ -47366,32 +56052,16 @@ var InfiniteRowModel = /** @class */ (function (_super) { if (rowIndexForPixel > lastRowIndex) { return lastRowIndex; } - else { - return rowIndexForPixel; - } - } - else { - return 0; + return rowIndexForPixel; } + return 0; }; InfiniteRowModel.prototype.getRowCount = function () { - return this.infiniteCache ? this.infiniteCache.getVirtualRowCount() : 0; - }; - InfiniteRowModel.prototype.updateRowData = function (transaction) { - if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(transaction.remove) || _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(transaction.update)) { - console.warn('ag-Grid: updateRowData for InfiniteRowModel does not support remove or update, only add'); - return; - } - if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(transaction.addIndex)) { - console.warn('ag-Grid: updateRowData for InfiniteRowModel requires add and addIndex to be set'); - return; - } - if (this.infiniteCache) { - this.infiniteCache.insertItemsAtIndex(transaction.addIndex, transaction.add); - } + return this.infiniteCache ? this.infiniteCache.getRowCount() : 0; }; InfiniteRowModel.prototype.isRowPresent = function (rowNode) { - return false; + var foundRowNode = this.getRowNode(rowNode.id); + return !!foundRowNode; }; InfiniteRowModel.prototype.refreshCache = function () { if (this.infiniteCache) { @@ -47403,35 +56073,18 @@ var InfiniteRowModel = /** @class */ (function (_super) { this.infiniteCache.purgeCache(); } }; - InfiniteRowModel.prototype.getVirtualRowCount = function () { + // for iRowModel + InfiniteRowModel.prototype.isLastRowIndexKnown = function () { if (this.infiniteCache) { - return this.infiniteCache.getVirtualRowCount(); - } - else { - return null; - } - }; - InfiniteRowModel.prototype.isMaxRowFound = function () { - if (this.infiniteCache) { - return this.infiniteCache.isMaxRowFound(); + return this.infiniteCache.isLastRowIndexKnown(); } + return false; }; - InfiniteRowModel.prototype.setVirtualRowCount = function (rowCount, maxRowFound) { + InfiniteRowModel.prototype.setRowCount = function (rowCount, lastRowIndexKnown) { if (this.infiniteCache) { - this.infiniteCache.setVirtualRowCount(rowCount, maxRowFound); - } - }; - InfiniteRowModel.prototype.getBlockState = function () { - if (this.rowNodeBlockLoader) { - return this.rowNodeBlockLoader.getBlockState(); - } - else { - return null; + this.infiniteCache.setRowCount(rowCount, lastRowIndexKnown); } }; - __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], InfiniteRowModel.prototype, "gridOptionsWrapper", void 0); __decorate([ Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager') ], InfiniteRowModel.prototype, "filterManager", void 0); @@ -47439,8 +56092,8 @@ var InfiniteRowModel = /** @class */ (function (_super) { Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('sortController') ], InfiniteRowModel.prototype, "sortController", void 0); __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('selectionController') - ], InfiniteRowModel.prototype, "selectionController", void 0); + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('selectionService') + ], InfiniteRowModel.prototype, "selectionService", void 0); __decorate([ Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') ], InfiniteRowModel.prototype, "gridApi", void 0); @@ -47450,6 +56103,9 @@ var InfiniteRowModel = /** @class */ (function (_super) { __decorate([ Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer') ], InfiniteRowModel.prototype, "rowRenderer", void 0); + __decorate([ + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowNodeBlockLoader') + ], InfiniteRowModel.prototype, "rowNodeBlockLoader", void 0); __decorate([ _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] ], InfiniteRowModel.prototype, "init", null); @@ -47465,14 +56121,14 @@ var InfiniteRowModel = /** @class */ (function (_super) { /***/ }), -/* 221 */ +/* 274 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "InfiniteCache", function() { return InfiniteCache; }); /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3); -/* harmony import */ var _infiniteBlock__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(222); +/* harmony import */ var _infiniteBlock__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(275); var __extends = (undefined && undefined.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || @@ -47500,94 +56156,38 @@ var __param = (undefined && undefined.__param) || function (paramIndex, decorato var InfiniteCache = /** @class */ (function (_super) { __extends(InfiniteCache, _super); function InfiniteCache(params) { - return _super.call(this, params) || this; + var _this = _super.call(this) || this; + _this.lastRowIndexKnown = false; + _this.blocks = {}; + _this.blockCount = 0; + _this.rowCount = params.initialRowCount; + _this.params = params; + return _this; } InfiniteCache.prototype.setBeans = function (loggerFactory) { this.logger = loggerFactory.create('InfiniteCache'); }; - InfiniteCache.prototype.moveItemsDown = function (block, moveFromIndex, moveCount) { - var startRow = block.getStartRow(); - var endRow = block.getEndRow(); - var indexOfLastRowToMove = moveFromIndex + moveCount; - // all rows need to be moved down below the insertion index - for (var currentRowIndex = endRow - 1; currentRowIndex >= startRow; currentRowIndex--) { - // don't move rows at or before the insertion index - if (currentRowIndex < indexOfLastRowToMove) { - continue; - } - var indexOfNodeWeWant = currentRowIndex - moveCount; - var nodeForThisIndex = this.getRow(indexOfNodeWeWant, true); - if (nodeForThisIndex) { - block.setRowNode(currentRowIndex, nodeForThisIndex); - } - else { - block.setBlankRowNode(currentRowIndex); - block.setDirty(); - } - } - }; - InfiniteCache.prototype.insertItems = function (block, indexToInsert, items) { - var pageStartRow = block.getStartRow(); - var pageEndRow = block.getEndRow(); - var newRowNodes = []; - // next stage is insert the rows into this page, if applicable - for (var index = 0; index < items.length; index++) { - var rowIndex = indexToInsert + index; - var currentRowInThisPage = rowIndex >= pageStartRow && rowIndex < pageEndRow; - if (currentRowInThisPage) { - var dataItem = items[index]; - var newRowNode = block.setNewData(rowIndex, dataItem); - newRowNodes.push(newRowNode); - } - } - return newRowNodes; - }; - InfiniteCache.prototype.insertItemsAtIndex = function (indexToInsert, items) { - // get all page id's as NUMBERS (not strings, as we need to sort as numbers) and in descending order - var _this = this; - var newNodes = []; - this.forEachBlockInReverseOrder(function (block) { - var pageEndRow = block.getEndRow(); - // if the insertion is after this page, then this page is not impacted - if (pageEndRow <= indexToInsert) { - return; - } - _this.moveItemsDown(block, indexToInsert, items.length); - var newNodesThisPage = _this.insertItems(block, indexToInsert, items); - newNodesThisPage.forEach(function (rowNode) { return newNodes.push(rowNode); }); - }); - if (this.isMaxRowFound()) { - this.hack_setVirtualRowCount(this.getVirtualRowCount() + items.length); - } - this.onCacheUpdated(); - var event = { - type: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_ROW_DATA_UPDATED, - api: this.gridApi, - columnApi: this.columnApi - }; - this.eventService.dispatchEvent(event); - }; // the rowRenderer will not pass dontCreatePage, meaning when rendering the grid, // it will want new pages in the cache as it asks for rows. only when we are inserting / // removing rows via the api is dontCreatePage set, where we move rows between the pages. InfiniteCache.prototype.getRow = function (rowIndex, dontCreatePage) { if (dontCreatePage === void 0) { dontCreatePage = false; } - var blockId = Math.floor(rowIndex / this.cacheParams.blockSize); - var block = this.getBlock(blockId); + var blockId = Math.floor(rowIndex / this.params.blockSize); + var block = this.blocks[blockId]; if (!block) { if (dontCreatePage) { - return null; - } - else { - block = this.createBlock(blockId); + return undefined; } + block = this.createBlock(blockId); } return block.getRow(rowIndex); }; InfiniteCache.prototype.createBlock = function (blockNumber) { - var newBlock = new _infiniteBlock__WEBPACK_IMPORTED_MODULE_1__["InfiniteBlock"](blockNumber, this.cacheParams); - this.getContext().createBean(newBlock); - this.postCreateBlock(newBlock); + var newBlock = this.createBean(new _infiniteBlock__WEBPACK_IMPORTED_MODULE_1__["InfiniteBlock"](blockNumber, this, this.params)); + this.blocks[newBlock.getId()] = newBlock; + this.blockCount++; + this.purgeBlocksIfNeeded(newBlock); + this.params.rowNodeBlockLoader.addBlock(newBlock); return newBlock; }; // we have this on infinite row model only, not server side row model, @@ -47595,25 +56195,246 @@ var InfiniteCache = /** @class */ (function (_super) { // state - eg if a node had children, but after the refresh it had data // for a different row, then the children would be with the wrong row node. InfiniteCache.prototype.refreshCache = function () { - this.forEachBlockInOrder(function (block) { return block.setDirty(); }); - this.checkBlockToLoad(); + var nothingToRefresh = this.blockCount == 0; + if (nothingToRefresh) { + this.purgeCache(); + return; + } + this.getBlocksInOrder().forEach(function (block) { return block.setStateWaitingToLoad(); }); + this.params.rowNodeBlockLoader.checkBlockToLoad(); + }; + InfiniteCache.prototype.destroyAllBlocks = function () { + var _this = this; + this.getBlocksInOrder().forEach(function (block) { return _this.destroyBlock(block); }); + }; + InfiniteCache.prototype.getRowCount = function () { + return this.rowCount; + }; + InfiniteCache.prototype.isLastRowIndexKnown = function () { + return this.lastRowIndexKnown; + }; + // block calls this, when page loaded + InfiniteCache.prototype.pageLoaded = function (block, lastRow) { + // if we are not active, then we ignore all events, otherwise we could end up getting the + // grid to refresh even though we are no longer the active cache + if (!this.isAlive()) { + return; + } + this.logger.log("onPageLoaded: page = " + block.getId() + ", lastRow = " + lastRow); + this.checkRowCount(block, lastRow); + // we fire cacheUpdated even if the row count has not changed, as some items need updating even + // if no new rows to render. for example the pagination panel has '?' as the total rows when loading + // is underway, which would need to get updated when loading finishes. + this.onCacheUpdated(); + }; + InfiniteCache.prototype.purgeBlocksIfNeeded = function (blockToExclude) { + var _this = this; + // we exclude checking for the page just created, as this has yet to be accessed and hence + // the lastAccessed stamp will not be updated for the first time yet + var blocksForPurging = this.getBlocksInOrder().filter(function (b) { return b != blockToExclude; }); + var lastAccessedComparator = function (a, b) { return b.getLastAccessed() - a.getLastAccessed(); }; + blocksForPurging.sort(lastAccessedComparator); + // we remove (maxBlocksInCache - 1) as we already excluded the 'just created' page. + // in other words, after the splice operation below, we have taken out the blocks + // we want to keep, which means we are left with blocks that we can potentially purge + var maxBlocksProvided = this.params.maxBlocksInCache > 0; + var blocksToKeep = maxBlocksProvided ? this.params.maxBlocksInCache - 1 : null; + var emptyBlocksToKeep = InfiniteCache.MAX_EMPTY_BLOCKS_TO_KEEP - 1; + blocksForPurging.forEach(function (block, index) { + var purgeBecauseBlockEmpty = block.getState() === _infiniteBlock__WEBPACK_IMPORTED_MODULE_1__["InfiniteBlock"].STATE_WAITING_TO_LOAD && index >= emptyBlocksToKeep; + var purgeBecauseCacheFull = maxBlocksProvided ? index >= blocksToKeep : false; + if (purgeBecauseBlockEmpty || purgeBecauseCacheFull) { + // if the block currently has rows been displayed, then don't remove it either. + // this can happen if user has maxBlocks=2, and blockSize=5 (thus 10 max rows in cache) + // but the screen is showing 20 rows, so at least 4 blocks are needed. + if (_this.isBlockCurrentlyDisplayed(block)) { + return; + } + // don't want to loose keyboard focus, so keyboard navigation can continue. so keep focused blocks. + if (_this.isBlockFocused(block)) { + return; + } + // at this point, block is not needed, so burn baby burn + _this.removeBlockFromCache(block); + } + }); + }; + InfiniteCache.prototype.isBlockFocused = function (block) { + var focusedCell = this.focusService.getFocusCellToUseAfterRefresh(); + if (!focusedCell) { + return false; + } + if (focusedCell.rowPinned != null) { + return false; + } + var blockIndexStart = block.getStartRow(); + var blockIndexEnd = block.getEndRow(); + var hasFocus = focusedCell.rowIndex >= blockIndexStart && focusedCell.rowIndex < blockIndexEnd; + return hasFocus; + }; + InfiniteCache.prototype.isBlockCurrentlyDisplayed = function (block) { + var startIndex = block.getStartRow(); + var endIndex = block.getEndRow() - 1; + return this.rowRenderer.isRangeInRenderedViewport(startIndex, endIndex); + }; + InfiniteCache.prototype.removeBlockFromCache = function (blockToRemove) { + if (!blockToRemove) { + return; + } + this.destroyBlock(blockToRemove); + // we do not want to remove the 'loaded' event listener, as the + // concurrent loads count needs to be updated when the load is complete + // if the purged page is in loading state }; + InfiniteCache.prototype.checkRowCount = function (block, lastRow) { + // if client provided a last row, we always use it, as it could change between server calls + // if user deleted data and then called refresh on the grid. + if (typeof lastRow === 'number' && lastRow >= 0) { + this.rowCount = lastRow; + this.lastRowIndexKnown = true; + } + else if (!this.lastRowIndexKnown) { + // otherwise, see if we need to add some virtual rows + var lastRowIndex = (block.getId() + 1) * this.params.blockSize; + var lastRowIndexPlusOverflow = lastRowIndex + this.params.overflowSize; + if (this.rowCount < lastRowIndexPlusOverflow) { + this.rowCount = lastRowIndexPlusOverflow; + } + } + }; + InfiniteCache.prototype.setRowCount = function (rowCount, lastRowIndexKnown) { + this.rowCount = rowCount; + // if undefined is passed, we do not set this value, if one of {true,false} + // is passed, we do set the value. + if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(lastRowIndexKnown)) { + this.lastRowIndexKnown = lastRowIndexKnown; + } + // if we are still searching, then the row count must not end at the end + // of a particular page, otherwise the searching will not pop into the + // next page + if (!this.lastRowIndexKnown) { + if (this.rowCount % this.params.blockSize === 0) { + this.rowCount++; + } + } + this.onCacheUpdated(); + }; + InfiniteCache.prototype.forEachNodeDeep = function (callback) { + var _this = this; + var sequence = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["NumberSequence"](); + this.getBlocksInOrder().forEach(function (block) { return block.forEachNode(callback, sequence, _this.rowCount); }); + }; + InfiniteCache.prototype.getBlocksInOrder = function () { + // get all page id's as NUMBERS (not strings, as we need to sort as numbers) and in descending order + var blockComparator = function (a, b) { return a.getId() - b.getId(); }; + var blocks = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].getAllValuesInObject(this.blocks).sort(blockComparator); + return blocks; + }; + InfiniteCache.prototype.destroyBlock = function (block) { + delete this.blocks[block.getId()]; + this.destroyBean(block); + this.blockCount--; + this.params.rowNodeBlockLoader.removeBlock(block); + }; + // gets called 1) row count changed 2) cache purged 3) items inserted + InfiniteCache.prototype.onCacheUpdated = function () { + if (this.isAlive()) { + // if the virtualRowCount is shortened, then it's possible blocks exist that are no longer + // in the valid range. so we must remove these. this can happen if user explicitly sets + // the virtual row count, or the datasource returns a result and sets lastRow to something + // less than virtualRowCount (can happen if user scrolls down, server reduces dataset size). + this.destroyAllBlocksPastVirtualRowCount(); + // this results in both row models (infinite and server side) firing ModelUpdated, + // however server side row model also updates the row indexes first + var event_1 = { + type: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_STORE_UPDATED + }; + this.eventService.dispatchEvent(event_1); + } + }; + InfiniteCache.prototype.destroyAllBlocksPastVirtualRowCount = function () { + var _this = this; + var blocksToDestroy = []; + this.getBlocksInOrder().forEach(function (block) { + var startRow = block.getId() * _this.params.blockSize; + if (startRow >= _this.rowCount) { + blocksToDestroy.push(block); + } + }); + if (blocksToDestroy.length > 0) { + blocksToDestroy.forEach(function (block) { return _this.destroyBlock(block); }); + } + }; + InfiniteCache.prototype.purgeCache = function () { + var _this = this; + this.getBlocksInOrder().forEach(function (block) { return _this.removeBlockFromCache(block); }); + this.lastRowIndexKnown = false; + // if zero rows in the cache, we need to get the SSRM to start asking for rows again. + // otherwise if set to zero rows last time, and we don't update the row count, then after + // the purge there will still be zero rows, meaning the SSRM won't request any rows. + // to kick things off, at least one row needs to be asked for. + if (this.rowCount === 0) { + this.rowCount = this.params.initialRowCount; + } + this.onCacheUpdated(); + }; + InfiniteCache.prototype.getRowNodesInRange = function (firstInRange, lastInRange) { + var _this = this; + var result = []; + var lastBlockId = -1; + var inActiveRange = false; + var numberSequence = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["NumberSequence"](); + // if only one node passed, we start the selection at the top + if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(firstInRange)) { + inActiveRange = true; + } + var foundGapInSelection = false; + this.getBlocksInOrder().forEach(function (block) { + if (foundGapInSelection) { + return; + } + if (inActiveRange && (lastBlockId + 1 !== block.getId())) { + foundGapInSelection = true; + return; + } + lastBlockId = block.getId(); + block.forEachNode(function (rowNode) { + var hitFirstOrLast = rowNode === firstInRange || rowNode === lastInRange; + if (inActiveRange || hitFirstOrLast) { + result.push(rowNode); + } + if (hitFirstOrLast) { + inActiveRange = !inActiveRange; + } + }, numberSequence, _this.rowCount); + }); + // inActiveRange will be still true if we never hit the second rowNode + var invalidRange = foundGapInSelection || inActiveRange; + return invalidRange ? [] : result; + }; + // this property says how many empty blocks should be in a cache, eg if scrolls down fast and creates 10 + // blocks all for loading, the grid will only load the last 2 - it will assume the blocks the user quickly + // scrolled over are not needed to be loaded. + InfiniteCache.MAX_EMPTY_BLOCKS_TO_KEEP = 2; __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi') - ], InfiniteCache.prototype, "columnApi", void 0); + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer') + ], InfiniteCache.prototype, "rowRenderer", void 0); __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi') - ], InfiniteCache.prototype, "gridApi", void 0); + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("focusService") + ], InfiniteCache.prototype, "focusService", void 0); __decorate([ __param(0, Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('loggerFactory')) ], InfiniteCache.prototype, "setBeans", null); + __decorate([ + _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["PreDestroy"] + ], InfiniteCache.prototype, "destroyAllBlocks", null); return InfiniteCache; -}(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNodeCache"])); +}(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["BeanStub"])); /***/ }), -/* 222 */ +/* 275 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -47642,27 +56463,37 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta var InfiniteBlock = /** @class */ (function (_super) { __extends(InfiniteBlock, _super); - function InfiniteBlock(pageNumber, params) { - var _this = _super.call(this, pageNumber, params) || this; - _this.cacheParams = params; + function InfiniteBlock(id, parentCache, params) { + var _this = _super.call(this, id) || this; + _this.parentCache = parentCache; + _this.params = params; + // we don't need to calculate these now, as the inputs don't change, + // however it makes the code easier to read if we work them out up front + _this.startRow = id * params.blockSize; + _this.endRow = _this.startRow + params.blockSize; return _this; } - InfiniteBlock.prototype.getDisplayIndexStart = function () { - return this.getBlockNumber() * this.cacheParams.blockSize; - }; - // this is an estimate, as the last block will probably only be partially full. however - // this method is used to know if this block is been rendered, before destroying, so - // and this estimate works in that use case. - InfiniteBlock.prototype.getDisplayIndexEnd = function () { - return this.getDisplayIndexStart() + this.cacheParams.blockSize; + InfiniteBlock.prototype.postConstruct = function () { + this.createRowNodes(); }; - InfiniteBlock.prototype.createBlankRowNode = function (rowIndex) { - var rowNode = _super.prototype.createBlankRowNode.call(this, rowIndex); - rowNode.uiLevel = 0; - this.setIndexAndTopOnRowNode(rowNode, rowIndex); - return rowNode; + InfiniteBlock.prototype.getBlockStateJson = function () { + return { + id: '' + this.getId(), + state: { + blockNumber: this.getId(), + startRow: this.getStartRow(), + endRow: this.getEndRow(), + pageStatus: this.getState() + } + }; }; InfiniteBlock.prototype.setDataAndId = function (rowNode, data, index) { + // if there's no id and the rowNode was rendered before, it means this + // was a placeholder rowNode and should not be recycled. Setting + // `alreadyRendered` to `false` forces the rowRenderer to flush it. + if (!rowNode.id && rowNode.alreadyRendered) { + rowNode.alreadyRendered = false; + } if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(data)) { // this means if the user is not providing id's we just use the // index for the row. this will allow selection to work (that is based @@ -47674,28 +56505,22 @@ var InfiniteBlock = /** @class */ (function (_super) { rowNode.setDataAndId(undefined, undefined); } }; - InfiniteBlock.prototype.setRowNode = function (rowIndex, rowNode) { - _super.prototype.setRowNode.call(this, rowIndex, rowNode); - this.setIndexAndTopOnRowNode(rowNode, rowIndex); - }; - InfiniteBlock.prototype.init = function () { - _super.prototype.init.call(this, { - context: this.getContext(), - rowRenderer: this.rowRenderer - }); - }; - InfiniteBlock.prototype.getNodeIdPrefix = function () { - return null; - }; - InfiniteBlock.prototype.getRow = function (displayIndex) { - return this.getRowUsingLocalIndex(displayIndex); - }; - InfiniteBlock.prototype.setIndexAndTopOnRowNode = function (rowNode, rowIndex) { - rowNode.setRowIndex(rowIndex); - rowNode.rowTop = this.cacheParams.rowHeight * rowIndex; - }; InfiniteBlock.prototype.loadFromDatasource = function () { var _this = this; + var params = this.createLoadParams(); + if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.params.datasource.getRows)) { + console.warn("AG Grid: datasource is missing getRows method"); + return; + } + // put in timeout, to force result to be async + window.setTimeout(function () { + _this.params.datasource.getRows(params); + }, 0); + }; + InfiniteBlock.prototype.processServerFail = function () { + // todo - this method has better handling in SSRM + }; + InfiniteBlock.prototype.createLoadParams = function () { // PROBLEM . . . . when the user sets sort via colDef.sort, then this code // is executing before the sort is set up, so server is not getting the sort // model. need to change with regards order - so the server side request is @@ -47704,70 +56529,118 @@ var InfiniteBlock = /** @class */ (function (_super) { startRow: this.getStartRow(), endRow: this.getEndRow(), successCallback: this.pageLoaded.bind(this, this.getVersion()), - failCallback: this.pageLoadFailed.bind(this), - sortModel: this.cacheParams.sortModel, - filterModel: this.cacheParams.filterModel, + failCallback: this.pageLoadFailed.bind(this, this.getVersion()), + sortModel: this.params.sortModel, + filterModel: this.params.filterModel, context: this.gridOptionsWrapper.getContext() }; - if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.cacheParams.datasource.getRows)) { - console.warn("ag-Grid: datasource is missing getRows method"); - return; + return params; + }; + InfiniteBlock.prototype.forEachNode = function (callback, sequence, rowCount) { + var _this = this; + this.rowNodes.forEach(function (rowNode, index) { + var rowIndex = _this.startRow + index; + if (rowIndex < rowCount) { + callback(rowNode, sequence.next()); + } + }); + }; + InfiniteBlock.prototype.getLastAccessed = function () { + return this.lastAccessed; + }; + InfiniteBlock.prototype.getRow = function (rowIndex, dontTouchLastAccessed) { + if (dontTouchLastAccessed === void 0) { dontTouchLastAccessed = false; } + if (!dontTouchLastAccessed) { + this.lastAccessed = this.params.lastAccessedSequence.next(); } - // put in timeout, to force result to be async - window.setTimeout(function () { - _this.cacheParams.datasource.getRows(params); - }, 0); + var localIndex = rowIndex - this.startRow; + return this.rowNodes[localIndex]; + }; + InfiniteBlock.prototype.getStartRow = function () { + return this.startRow; + }; + InfiniteBlock.prototype.getEndRow = function () { + return this.endRow; + }; + // creates empty row nodes, data is missing as not loaded yet + InfiniteBlock.prototype.createRowNodes = function () { + this.rowNodes = []; + for (var i = 0; i < this.params.blockSize; i++) { + var rowIndex = this.startRow + i; + var rowNode = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNode"](this.beans); + rowNode.setRowHeight(this.params.rowHeight); + rowNode.uiLevel = 0; + rowNode.setRowIndex(rowIndex); + rowNode.setRowTop(this.params.rowHeight * rowIndex); + this.rowNodes.push(rowNode); + } + }; + InfiniteBlock.prototype.processServerResult = function (params) { + var _this = this; + this.rowNodes.forEach(function (rowNode, index) { + var data = params.rowData ? params.rowData[index] : undefined; + _this.setDataAndId(rowNode, data, _this.startRow + index); + }); + var finalRowCount = params.rowCount != null && params.rowCount >= 0 ? params.rowCount : undefined; + this.parentCache.pageLoaded(this, finalRowCount); + }; + InfiniteBlock.prototype.destroyRowNodes = function () { + this.rowNodes.forEach(function (rowNode) { + // this is needed, so row render knows to fade out the row, otherwise it + // sees row top is present, and thinks the row should be shown. + rowNode.clearRowTopAndRowIndex(); + }); }; __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper') - ], InfiniteBlock.prototype, "gridOptionsWrapper", void 0); - __decorate([ - Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer') - ], InfiniteBlock.prototype, "rowRenderer", void 0); + Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('beans') + ], InfiniteBlock.prototype, "beans", void 0); __decorate([ _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"] - ], InfiniteBlock.prototype, "init", null); + ], InfiniteBlock.prototype, "postConstruct", null); + __decorate([ + _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["PreDestroy"] + ], InfiniteBlock.prototype, "destroyRowNodes", null); return InfiniteBlock; }(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNodeBlock"])); /***/ }), -/* 223 */ +/* 276 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AllCommunityModules", function() { return AllCommunityModules; }); /* harmony import */ var _ag_grid_community_client_side_row_model__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1); -/* harmony import */ var _ag_grid_community_infinite_row_model__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(218); -/* harmony import */ var _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(211); +/* harmony import */ var _ag_grid_community_infinite_row_model__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(271); +/* harmony import */ var _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(261); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ClientSideRowModelModule", function() { return _ag_grid_community_client_side_row_model__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelModule"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CsvExportModule", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["CsvExportModule"]; }); - /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BaseCreator", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["BaseCreator"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BaseGridSerializingSession", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["BaseGridSerializingSession"]; }); + /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CsvCreator", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["CsvCreator"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CsvExportModule", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["CsvExportModule"]; }); + /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Downloader", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["Downloader"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridSerializer", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["GridSerializer"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowType", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["RowType"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BaseGridSerializingSession", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["BaseGridSerializingSession"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "XmlFactory", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["XmlFactory"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ZipContainer", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["ZipContainer"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "XmlFactory", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["XmlFactory"]; }); - /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "InfiniteRowModelModule", function() { return _ag_grid_community_infinite_row_model__WEBPACK_IMPORTED_MODULE_1__["InfiniteRowModelModule"]; }); /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(3); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnFactory", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ColumnFactory"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnController", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ColumnController"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnModel", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ColumnModel"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnKeyCreator", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ColumnKeyCreator"]; }); @@ -47779,6 +56652,8 @@ __webpack_require__.r(__webpack_exports__); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ComponentUtil", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ComponentUtil"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgStackComponentsRegistry", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgStackComponentsRegistry"]; }); + /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColDefUtil", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ColDefUtil"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "UserComponentRegistry", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["UserComponentRegistry"]; }); @@ -47787,8 +56662,6 @@ __webpack_require__.r(__webpack_exports__); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "initialiseAgGridWithAngular1", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["initialiseAgGridWithAngular1"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "initialiseAgGridWithWebComponents", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["initialiseAgGridWithWebComponents"]; }); - /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BeanStub", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["BeanStub"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Context", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Context"]; }); @@ -47809,11 +56682,9 @@ __webpack_require__.r(__webpack_exports__); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "QuerySelector", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["QuerySelector"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GuiListener", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GuiListener"]; }); - /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RefSelector", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RefSelector"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridListener", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GridListener"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ExcelFactoryMode", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ExcelFactoryMode"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DragAndDropService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["DragAndDropService"]; }); @@ -47829,10 +56700,12 @@ __webpack_require__.r(__webpack_exports__); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnGroup", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ColumnGroup"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "OriginalColumnGroup", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["OriginalColumnGroup"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ProvidedColumnGroup", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ProvidedColumnGroup"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNode", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowNode"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowHighlightPosition", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowHighlightPosition"]; }); + /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "FilterManager", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["FilterManager"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ProvidedFilter", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ProvidedFilter"]; }); @@ -47847,27 +56720,65 @@ __webpack_require__.r(__webpack_exports__); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DateFilter", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["DateFilter"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridPanel", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GridPanel"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TextFloatingFilter", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["TextFloatingFilter"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderFilterCellComp", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HeaderFilterCellComp"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "FloatingFilterMapper", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["FloatingFilterMapper"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridBodyComp", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GridBodyComp"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridBodyCtrl", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GridBodyCtrl"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowAnimationCssClasses", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowAnimationCssClasses"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ScrollVisibleService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ScrollVisibleService"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MouseEventService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["MouseEventService"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "NavigationService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["NavigationService"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowContainerComp", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowContainerComp"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowContainerName", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowContainerName"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowContainerCtrl", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowContainerCtrl"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowContainerType", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowContainerType"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "getRowContainerTypeForName", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["getRowContainerTypeForName"]; }); + /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BodyDropPivotTarget", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["BodyDropPivotTarget"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BodyDropTarget", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["BodyDropTarget"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CssClassApplier", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["CssClassApplier"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderContainer", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HeaderContainer"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderRowContainerComp", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HeaderRowContainerComp"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridHeaderComp", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GridHeaderComp"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderRootComp", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HeaderRootComp"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridHeaderCtrl", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GridHeaderCtrl"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderRowComp", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HeaderRowComp"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderRowType", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HeaderRowType"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderRowCtrl", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HeaderRowCtrl"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderCellCtrl", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HeaderCellCtrl"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderFilterCellCtrl", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HeaderFilterCellCtrl"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderGroupCellCtrl", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HeaderGroupCellCtrl"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AbstractHeaderCellCtrl", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AbstractHeaderCellCtrl"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderRowContainerCtrl", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HeaderRowContainerCtrl"]; }); + /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HorizontalResizeService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HorizontalResizeService"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MoveColumnController", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["MoveColumnController"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MoveColumnFeature", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["MoveColumnFeature"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "StandardMenuFactory", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["StandardMenuFactory"]; }); @@ -47877,6 +56788,8 @@ __webpack_require__.r(__webpack_exports__); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ResizeObserverService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ResizeObserverService"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AnimationFrameService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AnimationFrameService"]; }); + /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "LargeTextCellEditor", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["LargeTextCellEditor"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupEditorWrapper", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PopupEditorWrapper"]; }); @@ -47889,23 +56802,29 @@ __webpack_require__.r(__webpack_exports__); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TextCellEditor", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["TextCellEditor"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Beans", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Beans"]; }); + /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AnimateShowChangeCellRenderer", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AnimateShowChangeCellRenderer"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AnimateSlideCellRenderer", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AnimateSlideCellRenderer"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GroupCellRenderer", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GroupCellRenderer"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GroupCellRendererCtrl", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GroupCellRendererCtrl"]; }); + /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SetLeftFeature", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["SetLeftFeature"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AutoWidthCalculator", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AutoWidthCalculator"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PositionableFeature", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PositionableFeature"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellRendererFactory", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["CellRendererFactory"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AutoWidthCalculator", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AutoWidthCalculator"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CheckboxSelectionComponent", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["CheckboxSelectionComponent"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellComp", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["CellComp"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowComp", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowComp"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellCtrl", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["CellCtrl"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowCtrl", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowCtrl"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowRenderer", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowRenderer"]; }); @@ -47913,18 +56832,22 @@ __webpack_require__.r(__webpack_exports__); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PinnedRowModel", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PinnedRowModel"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ServerSideTransactionResultStatus", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ServerSideTransactionResultStatus"]; }); + /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ChangedPath", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ChangedPath"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNodeBlock", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowNodeBlock"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNodeBlockLoader", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowNodeBlockLoader"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNodeCache", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowNodeCache"]; }); - /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PaginationProxy", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PaginationProxy"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ClientSideRowModelSteps", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ClientSideRowModelSteps"]; }); + /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "StylingService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["StylingService"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "LayoutCssClasses", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["LayoutCssClasses"]; }); + /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgAbstractField", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgAbstractField"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgCheckbox", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgCheckbox"]; }); @@ -47951,13 +56874,25 @@ __webpack_require__.r(__webpack_exports__); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgGroupComponent", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgGroupComponent"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgMenuItemComponent", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgMenuItemComponent"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgMenuList", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgMenuList"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgMenuPanel", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgMenuPanel"]; }); + /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgDialog", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgDialog"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgPanel", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgPanel"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Component", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Component"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ManagedFocusComponent", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ManagedFocusComponent"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CssClassManager", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["CssClassManager"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ManagedFocusFeature", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ManagedFocusFeature"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TabGuardComp", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["TabGuardComp"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TabGuardCtrl", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["TabGuardCtrl"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupComponent", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PopupComponent"]; }); @@ -47971,6 +56906,8 @@ __webpack_require__.r(__webpack_exports__); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectionHandleType", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["SelectionHandleType"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AutoScrollService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AutoScrollService"]; }); + /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "VanillaFrameworkOverrides", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["VanillaFrameworkOverrides"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellNavigationService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["CellNavigationService"]; }); @@ -47979,13 +56916,17 @@ __webpack_require__.r(__webpack_exports__); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Constants", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Constants"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "KeyCode", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["KeyCode"]; }); + /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Grid", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Grid"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridCoreCreator", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GridCoreCreator"]; }); + /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridApi", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GridApi"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Events", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Events"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "FocusController", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["FocusController"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "FocusService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["FocusService"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "defaultGroupComparator", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["defaultGroupComparator"]; }); @@ -47995,13 +56936,19 @@ __webpack_require__.r(__webpack_exports__); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectableService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["SelectableService"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridCore", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GridCore"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNodeSorter", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowNodeSorter"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CtrlsService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["CtrlsService"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridComp", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GridComp"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridCtrl", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GridCtrl"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Logger", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Logger"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "LoggerFactory", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["LoggerFactory"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectionController", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["SelectionController"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectionService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["SelectionService"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SortController", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["SortController"]; }); @@ -48015,9 +56962,9 @@ __webpack_require__.r(__webpack_exports__); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "NumberSequence", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["NumberSequence"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PromiseStatus", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PromiseStatus"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgPromiseStatus", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgPromiseStatus"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Promise", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Promise"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgPromise", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgPromise"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Timer", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Timer"]; }); @@ -48045,11 +56992,9 @@ __webpack_require__.r(__webpack_exports__); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Environment", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Environment"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TooltipFeature", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["TooltipFeature"]; }); - -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ChartType", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ChartType"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CustomTooltipFeature", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["CustomTooltipFeature"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "LegendPosition", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["LegendPosition"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BarColumnLabelPlacement", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["BarColumnLabelPlacement"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ModuleNames", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"]; }); @@ -48066,11 +57011,11 @@ var AllCommunityModules = [_ag_grid_community_client_side_row_model__WEBPACK_IMP /***/ }), -/* 224 */ +/* 277 */ /***/ (function(module, exports, __webpack_require__) { -var api = __webpack_require__(225); - var content = __webpack_require__(226); +var api = __webpack_require__(278); + var content = __webpack_require__(279); content = content.__esModule ? content.default : content; @@ -48090,7 +57035,7 @@ var update = api(content, options); module.exports = content.locals || {}; /***/ }), -/* 225 */ +/* 278 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; @@ -48269,7 +57214,7 @@ function applyToTag(style, options, obj) { style.removeAttribute('media'); } - if (sourceMap && btoa) { + if (sourceMap && typeof btoa !== 'undefined') { css += "\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))), " */"); } // For old IE @@ -48365,20 +57310,20 @@ module.exports = function (list, options) { }; /***/ }), -/* 226 */ +/* 279 */ /***/ (function(module, exports, __webpack_require__) { // Imports -var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227); +var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(280); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, "/**\n ****************************\n * Generic Styles\n ****************************\n*/\nag-grid, ag-grid-angular, ag-grid-ng2, ag-grid-polymer, ag-grid-aurelia {\n display: block; }\n\n.ag-hidden {\n display: none !important; }\n\n.ag-invisible {\n visibility: hidden !important; }\n\n.ag-drag-handle {\n cursor: move;\n cursor: -webkit-grab;\n cursor: grab; }\n\n.ag-column-drop-wrapper {\n display: flex; }\n\n.ag-column-drop-horizontal-half-width {\n display: inline-block;\n width: 50% !important; }\n\n.ag-unselectable {\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n\n.ag-selectable {\n -moz-user-select: text;\n -webkit-user-select: text;\n -ms-user-select: text;\n user-select: text; }\n\n.ag-tab {\n position: relative; }\n\n.ag-tab-guard {\n position: absolute;\n width: 0;\n height: 0;\n display: block; }\n\n.ag-select-agg-func-popup {\n position: absolute; }\n\n.ag-input-wrapper, .ag-picker-field-wrapper {\n display: flex;\n flex: 1 1 auto;\n align-items: center;\n line-height: normal;\n position: relative; }\n\n.ag-shake-left-to-right {\n -webkit-animation-direction: alternate;\n animation-direction: alternate;\n -webkit-animation-duration: 0.2s;\n animation-duration: 0.2s;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-name: ag-shake-left-to-right;\n animation-name: ag-shake-left-to-right; }\n\n@-webkit-keyframes ag-shake-left-to-right {\n from {\n padding-left: 6px;\n padding-right: 2px; }\n to {\n padding-left: 2px;\n padding-right: 6px; } }\n\n@keyframes ag-shake-left-to-right {\n from {\n padding-left: 6px;\n padding-right: 2px; }\n to {\n padding-left: 2px;\n padding-right: 6px; } }\n\n.ag-root-wrapper {\n cursor: default;\n position: relative;\n display: flex;\n flex-direction: column;\n overflow: hidden; }\n .ag-root-wrapper.ag-layout-normal {\n height: 100%; }\n\n.ag-watermark {\n position: absolute;\n bottom: 10px;\n right: 25px;\n opacity: 0.5;\n transition: opacity 1s ease-out 3s; }\n .ag-watermark:before {\n content: '';\n background-image: url();\n -webkit-filter: invert(50%);\n filter: invert(50%);\n background-repeat: no-repeat;\n background-size: 110px 60px;\n display: block;\n height: 60px;\n width: 110px; }\n\n.ag-watermark-text {\n opacity: 0.5;\n font-weight: bold;\n font-family: Impact, sans-serif;\n font-size: 19px; }\n\n.ag-root-wrapper-body {\n display: flex;\n flex-direction: row; }\n .ag-root-wrapper-body.ag-layout-normal {\n flex: 1 1 auto;\n height: 0;\n min-height: 0; }\n\n.ag-root {\n position: relative;\n display: flex;\n flex-direction: column; }\n .ag-root.ag-layout-normal, .ag-root.ag-layout-auto-height {\n overflow: hidden;\n flex: 1 1 auto;\n width: 0; }\n .ag-root.ag-layout-normal {\n height: 100%; }\n\n/**\n ****************************\n * Viewports\n ****************************\n*/\n.ag-header-viewport,\n.ag-floating-top-viewport,\n.ag-body-viewport,\n.ag-center-cols-viewport,\n.ag-floating-bottom-viewport,\n.ag-body-horizontal-scroll-viewport,\n.ag-virtual-list-viewport {\n position: relative;\n height: 100%;\n min-width: 0px;\n overflow: hidden;\n flex: 1 1 auto; }\n\n.ag-body-viewport.ag-layout-print {\n flex: none; }\n\n@media print {\n .ag-layout-normal {\n display: none; }\n .ag-root-wrapper,\n .ag-root-wrapper-body,\n .ag-root,\n .ag-body-viewport,\n .ag-center-cols-container,\n .ag-center-cols-viewport,\n .ag-center-cols-clipper,\n .ag-body-horizontal-scroll-viewport,\n .ag-virtual-list-viewport {\n height: auto !important;\n overflow: hidden !important;\n display: block !important; }\n .ag-row {\n page-break-inside: avoid; } }\n\n.ag-body-viewport {\n display: flex; }\n .ag-body-viewport.ag-layout-normal {\n overflow-y: auto;\n -webkit-overflow-scrolling: touch; }\n\n.ag-center-cols-viewport {\n width: 100%;\n overflow-x: auto; }\n\n.ag-body-horizontal-scroll-viewport {\n overflow-x: scroll; }\n\n.ag-virtual-list-viewport {\n overflow: auto;\n width: 100%; }\n\n/**\n ****************************\n * Containers\n ****************************\n*/\n.ag-header-container,\n.ag-floating-top-container,\n.ag-body-container,\n.ag-pinned-right-cols-container,\n.ag-center-cols-container,\n.ag-pinned-left-cols-container,\n.ag-floating-bottom-container,\n.ag-body-horizontal-scroll-container,\n.ag-full-width-container,\n.ag-floating-bottom-full-width-container,\n.ag-virtual-list-container {\n position: relative; }\n\n.ag-header-container, .ag-floating-top-container, .ag-floating-bottom-container {\n height: 100%;\n white-space: nowrap; }\n\n.ag-center-cols-clipper {\n min-height: 100%; }\n\n.ag-center-cols-container {\n display: block; }\n\n.ag-layout-print .ag-center-cols-clipper {\n min-width: 100%; }\n\n.ag-layout-auto-height .ag-center-cols-clipper,\n.ag-layout-auto-height .ag-center-cols-container {\n min-height: 50px; }\n\n.ag-pinned-right-cols-container {\n display: block; }\n\n.ag-body-horizontal-scroll-container {\n height: 100%; }\n\n.ag-full-width-container,\n.ag-floating-top-full-width-container,\n.ag-floating-bottom-full-width-container {\n position: absolute;\n top: 0px;\n left: 0px;\n pointer-events: none; }\n\n.ag-full-width-container {\n width: 100%; }\n\n.ag-floating-bottom-full-width-container, .ag-floating-top-full-width-container {\n display: inline-block;\n overflow: hidden;\n height: 100%;\n width: 100%; }\n\n.ag-virtual-list-container {\n overflow: hidden; }\n\n/**\n ****************************\n * Scrollers\n ****************************\n*/\n.ag-center-cols-clipper {\n flex: 1;\n min-width: 0;\n overflow: hidden; }\n\n.ag-body-horizontal-scroll {\n min-height: 0;\n min-width: 0;\n width: 100%;\n display: flex;\n position: relative; }\n\n.ag-layout-print .ag-body-horizontal-scroll {\n display: none; }\n\n.ag-force-vertical-scroll {\n overflow-y: scroll !important; }\n .ag-force-vertical-scroll.ag-layout-print {\n overflow-y: visible !important; }\n\n.ag-horizontal-left-spacer, .ag-horizontal-right-spacer {\n height: 100%;\n min-width: 0;\n overflow-x: scroll; }\n .ag-horizontal-left-spacer.ag-scroller-corner, .ag-horizontal-right-spacer.ag-scroller-corner {\n overflow-x: hidden; }\n\n/**\n ****************************\n * Headers\n ****************************\n*/\n.ag-header, .ag-pinned-left-header, .ag-pinned-right-header {\n display: inline-block;\n overflow: hidden;\n position: relative; }\n\n.ag-header-cell-sortable {\n cursor: pointer; }\n\n.ag-header {\n display: flex;\n width: 100%;\n white-space: nowrap; }\n\n.ag-pinned-left-header {\n height: 100%; }\n\n.ag-pinned-right-header {\n height: 100%; }\n\n.ag-header-row {\n position: absolute;\n overflow: hidden; }\n\n.ag-header-cell {\n display: inline-flex;\n align-items: center;\n position: absolute;\n height: 100%; }\n\n.ag-header-group-cell-label, .ag-header-cell-label {\n display: flex;\n flex: 1 1 auto;\n overflow: hidden;\n align-items: center;\n text-overflow: ellipsis;\n align-self: stretch; }\n\n.ag-header-cell-text {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap; }\n\n.ag-right-aligned-header .ag-header-cell-label {\n flex-direction: row-reverse; }\n\n.ag-header-group-text {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap; }\n\n.ag-header-cell-resize {\n position: absolute;\n z-index: 2;\n height: 100%;\n width: 8px;\n top: 0;\n cursor: ew-resize; }\n .ag-ltr .ag-header-cell-resize {\n right: -4px; }\n .ag-rtl .ag-header-cell-resize {\n left: -4px; }\n\n.ag-pinned-left-header .ag-header-cell-resize {\n right: -4px; }\n\n.ag-pinned-right-header .ag-header-cell-resize {\n left: -4px; }\n\n.ag-header-select-all {\n display: flex; }\n\n/**\n ****************************\n * Columns\n ****************************\n*/\n.ag-column-moving .ag-cell {\n transition: left 0.2s; }\n\n.ag-column-moving .ag-header-cell {\n transition: left 0.2s; }\n\n.ag-column-moving .ag-header-group-cell {\n transition: left 0.2s, width 0.2s; }\n\n/**\n ****************************\n * Column Panel\n ****************************\n*/\n.ag-column-panel {\n display: flex;\n flex-direction: column;\n overflow: hidden;\n flex: 1 1 auto; }\n\n.ag-column-select {\n display: flex;\n flex-direction: column;\n overflow: hidden;\n flex-grow: 3;\n flex-shrink: 1;\n flex-basis: 0; }\n\n.ag-column-select-header {\n position: relative;\n display: flex;\n flex: none; }\n\n.ag-column-select-header-icon {\n position: relative; }\n\n.ag-column-select-header-filter-wrapper {\n flex: 1 1 auto; }\n\n.ag-column-select-header-filter {\n width: 100%; }\n\n.ag-column-select-list {\n flex: 1 1 auto;\n overflow: auto; }\n\n.ag-column-drop {\n display: inline-flex;\n align-items: center;\n overflow: auto;\n width: 100%; }\n\n.ag-column-drop-list {\n display: flex;\n align-items: center; }\n\n.ag-column-drop-cell {\n display: flex;\n align-items: center; }\n\n.ag-column-drop-cell-text {\n overflow: hidden;\n flex: 1 1 auto;\n text-overflow: ellipsis;\n white-space: nowrap; }\n\n.ag-column-drop-vertical {\n display: flex;\n flex-direction: column;\n overflow: hidden;\n flex: 1 1 0;\n align-items: stretch; }\n\n.ag-column-drop-vertical-title-bar {\n display: flex;\n align-items: center; }\n\n.ag-column-drop-vertical-list {\n align-items: stretch;\n flex-grow: 1;\n flex-direction: column;\n overflow-x: auto; }\n .ag-column-drop-vertical-list > * {\n flex: none; }\n\n.ag-column-drop-empty .ag-column-drop-vertical-list {\n overflow: hidden; }\n\n.ag-column-drop-vertical-empty-message {\n display: block; }\n\n.ag-column-drop.ag-column-drop-horizontal {\n white-space: nowrap;\n overflow: hidden; }\n\n.ag-column-drop-cell-button {\n cursor: pointer; }\n\n.ag-filter-toolpanel {\n flex: 1 1 0px;\n min-width: 0; }\n\n.ag-filter-toolpanel-header {\n position: relative; }\n\n.ag-filter-toolpanel-header, .ag-filter-toolpanel-search {\n display: flex;\n align-items: center; }\n .ag-filter-toolpanel-header > *, .ag-filter-toolpanel-search > * {\n display: flex;\n align-items: center; }\n\n.ag-filter-apply-panel {\n display: flex;\n justify-content: flex-end;\n overflow: hidden; }\n\n/**\n ****************************\n * Rows\n ****************************\n*/\n.ag-row-animation .ag-row {\n transition: top 0.4s, height 0.4s, background-color 0.1s, opacity 0.2s, -webkit-transform 0.4s;\n transition: transform 0.4s, top 0.4s, height 0.4s, background-color 0.1s, opacity 0.2s;\n transition: transform 0.4s, top 0.4s, height 0.4s, background-color 0.1s, opacity 0.2s, -webkit-transform 0.4s; }\n\n.ag-row-no-animation .ag-row {\n transition: background-color 0.1s; }\n\n.ag-row {\n white-space: nowrap;\n width: 100%; }\n\n.ag-row-loading {\n display: flex;\n align-items: center; }\n\n.ag-row-position-absolute {\n position: absolute; }\n\n.ag-row-position-relative {\n position: relative; }\n\n.ag-full-width-row {\n overflow: hidden;\n pointer-events: all; }\n\n.ag-row-inline-editing {\n z-index: 1; }\n\n.ag-row-dragging {\n z-index: 2; }\n\n.ag-stub-cell {\n display: flex;\n align-items: center; }\n\n/**\n ****************************\n * Cells\n ****************************\n*/\n.ag-cell {\n display: inline-block;\n position: absolute;\n white-space: nowrap; }\n\n.ag-cell-value, .ag-group-value {\n overflow: hidden;\n text-overflow: ellipsis; }\n\n.ag-cell-wrapper {\n display: flex;\n align-items: center;\n height: 100%; }\n .ag-cell-wrapper.ag-row-group {\n align-items: flex-start; }\n\n.ag-full-width-row .ag-cell-wrapper.ag-row-group {\n align-items: center; }\n\n.ag-cell-auto-height {\n height: 100%; }\n\n.ag-cell-inline-editing {\n z-index: 1; }\n .ag-cell-inline-editing .ag-cell-edit-wrapper,\n .ag-cell-inline-editing .ag-cell-editor,\n .ag-cell-inline-editing .ag-cell-editor .ag-wrapper,\n .ag-cell-inline-editing .ag-cell-editor input {\n height: 100%;\n width: 100%;\n line-height: normal; }\n\n.ag-cell .ag-icon {\n display: inline-block;\n vertical-align: middle; }\n\n/**\n ****************************\n * Filters\n ****************************\n*/\n.ag-set-filter-item {\n display: flex;\n align-items: center;\n height: 100%; }\n\n.ag-set-filter-item-value {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap; }\n\n.ag-set-filter-item-checkbox {\n display: flex;\n pointer-events: none; }\n\n.ag-filter-body-wrapper {\n display: flex;\n flex-direction: column; }\n\n.ag-filter-filter {\n flex: 1 1 auto;\n overflow: hidden; }\n\n.ag-filter-condition {\n display: flex; }\n\n/**\n ****************************\n * Floating Filter\n ****************************\n*/\n.ag-floating-filter-body {\n position: relative;\n display: flex;\n flex: 1 1 auto;\n height: 100%; }\n\n.ag-floating-filter-full-body {\n display: flex;\n flex: 1 1 auto;\n height: 100%;\n width: 100%;\n align-items: center;\n overflow: hidden; }\n\n.ag-floating-filter-full-body > div {\n flex: 1 1 auto; }\n\n.ag-floating-filter {\n display: inline-block;\n position: absolute; }\n\n.ag-floating-filter-input {\n align-items: center;\n display: flex;\n width: 100%; }\n .ag-floating-filter-input > * {\n flex: 1 1 auto; }\n\n.ag-floating-filter-button {\n display: flex;\n flex: none; }\n\n/**\n ****************************\n * Drag & Drop\n ****************************\n*/\n.ag-dnd-ghost {\n position: absolute;\n display: inline-flex;\n align-items: center;\n cursor: move;\n white-space: nowrap; }\n\n/**\n ****************************\n * Overlay\n ****************************\n*/\n.ag-overlay {\n height: 100%;\n left: 0;\n pointer-events: none;\n position: absolute;\n top: 0;\n width: 100%; }\n\n.ag-overlay-panel {\n display: flex;\n height: 100%;\n width: 100%; }\n\n.ag-overlay-wrapper {\n display: flex;\n flex: none;\n width: 100%;\n height: 100%;\n align-items: center;\n justify-content: center;\n text-align: center; }\n\n.ag-overlay-loading-wrapper {\n pointer-events: all; }\n\n/**\n ****************************\n * Popup\n ****************************\n*/\n.ag-popup-child {\n z-index: 5; }\n\n.ag-popup-editor {\n position: absolute;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n z-index: 1; }\n\n.ag-large-text-input {\n display: block; }\n\n/**\n ****************************\n * Virtual Lists\n ****************************\n*/\n.ag-virtual-list-item {\n position: absolute;\n width: 100%; }\n\n/**\n ****************************\n * Floating Top and Bottom\n ****************************\n*/\n.ag-floating-top {\n overflow: hidden;\n white-space: nowrap;\n width: 100%;\n position: relative;\n display: flex; }\n\n.ag-pinned-left-floating-top {\n display: inline-block;\n overflow: hidden;\n position: relative;\n min-width: 0px; }\n\n.ag-pinned-right-floating-top {\n display: inline-block;\n overflow: hidden;\n position: relative;\n min-width: 0px; }\n\n.ag-floating-bottom {\n overflow: hidden;\n white-space: nowrap;\n width: 100%;\n position: relative;\n display: flex; }\n\n.ag-pinned-left-floating-bottom {\n display: inline-block;\n overflow: hidden;\n position: relative;\n min-width: 0px; }\n\n.ag-pinned-right-floating-bottom {\n display: inline-block;\n overflow: hidden;\n position: relative;\n min-width: 0px; }\n\n/**\n ****************************\n * Dialog\n ****************************\n*/\n.ag-dialog, .ag-panel {\n display: flex;\n flex-direction: column;\n position: relative;\n overflow: hidden; }\n\n.ag-panel-title-bar {\n display: flex;\n flex: none;\n align-items: center;\n cursor: default; }\n\n.ag-panel-title-bar-title {\n flex: 1 1 auto; }\n\n.ag-panel-title-bar-buttons {\n display: flex; }\n\n.ag-panel-title-bar-button {\n cursor: pointer; }\n\n.ag-panel-content-wrapper {\n display: flex;\n flex: 1 1 auto;\n position: relative;\n overflow: hidden; }\n\n.ag-dialog {\n position: absolute; }\n\n.ag-resizer {\n position: absolute;\n pointer-events: none;\n z-index: 1; }\n .ag-resizer.ag-resizer-topLeft {\n top: 0;\n left: 0;\n height: 5px;\n width: 5px;\n cursor: nwse-resize; }\n .ag-resizer.ag-resizer-top {\n top: 0;\n left: 5px;\n right: 5px;\n height: 5px;\n cursor: ns-resize; }\n .ag-resizer.ag-resizer-topRight {\n top: 0;\n right: 0;\n height: 5px;\n width: 5px;\n cursor: nesw-resize; }\n .ag-resizer.ag-resizer-right {\n top: 5px;\n right: 0;\n bottom: 5px;\n width: 5px;\n cursor: ew-resize; }\n .ag-resizer.ag-resizer-bottomRight {\n bottom: 0;\n right: 0;\n height: 5px;\n width: 5px;\n cursor: nwse-resize; }\n .ag-resizer.ag-resizer-bottom {\n bottom: 0;\n left: 5px;\n right: 5px;\n height: 5px;\n cursor: ns-resize; }\n .ag-resizer.ag-resizer-bottomLeft {\n bottom: 0;\n left: 0;\n height: 5px;\n width: 5px;\n cursor: nesw-resize; }\n .ag-resizer.ag-resizer-left {\n left: 0;\n top: 5px;\n bottom: 5px;\n width: 5px;\n cursor: ew-resize; }\n\n/**\n ****************************\n * Tooltip\n ****************************\n*/\n.ag-tooltip {\n position: absolute;\n pointer-events: none;\n z-index: 99999; }\n\n/**\n ****************************\n * Animations\n ****************************\n*/\n.ag-value-slide-out {\n margin-right: 5px;\n opacity: 1;\n transition: opacity 3s, margin-right 3s;\n transition-timing-function: linear; }\n\n.ag-value-slide-out-end {\n margin-right: 10px;\n opacity: 0; }\n\n.ag-opacity-zero {\n opacity: 0 !important; }\n\n/**\n ****************************\n * Menu\n ****************************\n*/\n.ag-menu {\n max-height: 100%;\n overflow-y: auto;\n position: absolute;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n\n.ag-menu-column-select-wrapper {\n height: 265px;\n overflow: auto; }\n\n.ag-menu-list {\n display: table; }\n\n.ag-menu-option, .ag-menu-separator {\n display: table-row; }\n\n.ag-menu-separator-cell, .ag-menu-option-part {\n display: table-cell;\n vertical-align: middle; }\n\n.ag-menu-option-text {\n white-space: nowrap; }\n\n.ag-menu-column-select-wrapper .ag-column-select {\n height: 100%; }\n\n/**\n ****************************\n * Rich Select\n ****************************\n*/\n.ag-rich-select {\n cursor: default;\n outline: none; }\n\n.ag-rich-select-value {\n display: flex;\n align-items: center; }\n\n.ag-rich-select-value-icon {\n flex: 1 1 auto;\n order: 1; }\n .ag-ltr .ag-rich-select-value-icon {\n text-align: right; }\n .ag-rtl .ag-rich-select-value-icon {\n text-align: left; }\n\n.ag-rich-select-list {\n position: relative; }\n\n.ag-rich-select-virtual-list-item {\n display: flex; }\n\n.ag-rich-select-row {\n display: flex;\n flex: 1 1 auto;\n align-items: center;\n white-space: nowrap; }\n\n/**\n ****************************\n * Pagination\n ****************************\n*/\n.ag-paging-panel {\n align-items: center;\n display: flex;\n justify-content: flex-end; }\n\n.ag-paging-page-summary-panel {\n display: flex;\n align-items: center; }\n\n.ag-paging-button-wrapper {\n position: relative;\n overflow: hidden; }\n\n.ag-paging-button {\n position: absolute; }\n\n.ag-disabled .ag-paging-page-summary-panel {\n pointer-events: none; }\n\n/**\n ****************************\n * Tool Panel\n ****************************\n*/\n.ag-tool-panel-wrapper {\n display: flex;\n overflow-y: auto;\n overflow-x: hidden;\n cursor: default;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n width: 200px; }\n\n.ag-column-select-column,\n.ag-column-select-column-group {\n position: relative;\n align-items: center;\n display: flex;\n flex-direction: row;\n flex-wrap: nowrap;\n text-overflow: ellipsis;\n white-space: nowrap; }\n .ag-column-select-column > *,\n .ag-column-select-column-group > * {\n flex: none; }\n\n.ag-column-select-checkbox {\n display: flex; }\n\n.ag-tool-panel-horizontal-resize {\n cursor: ew-resize;\n height: 100%;\n position: absolute;\n top: 0;\n width: 5px;\n z-index: 1; }\n\n.ag-ltr .ag-side-bar-left .ag-tool-panel-horizontal-resize {\n right: -3px; }\n\n.ag-rtl .ag-side-bar-left .ag-tool-panel-horizontal-resize {\n left: -3px; }\n\n.ag-ltr .ag-side-bar-right .ag-tool-panel-horizontal-resize {\n left: -3px; }\n\n.ag-rtl .ag-side-bar-right .ag-tool-panel-horizontal-resize {\n right: -3px; }\n\n.ag-details-row {\n width: 100%; }\n\n.ag-details-row-fixed-height {\n height: 100%; }\n\n.ag-details-grid {\n width: 100%; }\n\n.ag-details-grid-fixed-height {\n height: 100%; }\n\n.ag-header-group-cell {\n display: flex;\n align-items: center;\n height: 100%;\n position: absolute; }\n\n.ag-cell-label-container {\n display: flex;\n justify-content: space-between;\n flex-direction: row-reverse;\n align-items: center;\n width: 100%;\n height: 100%; }\n\n.ag-right-aligned-header .ag-cell-label-container {\n flex-direction: row; }\n\n/**\n ****************************\n * Side Bar\n ****************************\n*/\n.ag-side-bar {\n display: flex;\n flex-direction: row-reverse; }\n\n.ag-side-bar-left {\n order: -1;\n flex-direction: row; }\n\n.ag-side-button-button {\n position: relative;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n flex-wrap: nowrap;\n white-space: nowrap;\n outline: none;\n cursor: pointer; }\n\n.ag-side-button-label {\n -webkit-writing-mode: vertical-lr;\n -ms-writing-mode: tb-lr;\n writing-mode: vertical-lr; }\n\n/**\n ****************************\n * Status Bar\n ****************************\n*/\n.ag-status-bar {\n display: flex;\n justify-content: space-between;\n overflow: hidden; }\n\n.ag-status-panel {\n display: inline-flex; }\n\n.ag-status-name-value {\n white-space: nowrap; }\n\n.ag-status-bar-left {\n display: inline-flex; }\n\n.ag-status-bar-center {\n display: inline-flex; }\n\n.ag-status-bar-right {\n display: inline-flex; }\n\n/**\n ****************************\n * Widgets\n ****************************\n*/\n.ag-icon {\n display: block;\n speak: none; }\n\n.ag-group {\n position: relative;\n width: 100%; }\n\n.ag-group-title-bar {\n display: flex;\n align-items: center; }\n\n.ag-group-title {\n display: block;\n flex: 1 1 auto;\n min-width: 0;\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis; }\n\n.ag-group-title-bar\n.ag-group-title {\n cursor: default; }\n\n.ag-group-toolbar {\n display: flex;\n align-items: center; }\n\n.ag-group-container {\n display: flex; }\n\n.ag-disabled .ag-group-container {\n pointer-events: none; }\n\n.ag-group-container-horizontal {\n flex-direction: row;\n flex-wrap: wrap; }\n\n.ag-group-container-vertical {\n flex-direction: column; }\n\n.ag-charts-font-size-color {\n display: flex;\n align-self: stretch;\n justify-content: space-between; }\n\n.ag-column-group-icons {\n display: block; }\n .ag-column-group-icons > * {\n cursor: pointer; }\n\n.ag-group-item-alignment-stretch .ag-group-item {\n align-items: stretch; }\n\n.ag-group-item-alignment-start .ag-group-item {\n align-items: flex-start; }\n\n.ag-group-item-alignment-end .ag-group-item {\n align-items: flex-end; }\n\n.ag-toggle-button-icon {\n transition: right 0.3s;\n position: absolute;\n top: -1px; }\n\n.ag-input-field, .ag-select {\n display: flex;\n flex-direction: row;\n align-items: center; }\n\n.ag-input-field-input {\n flex: 1 1 auto;\n width: 100%;\n min-width: 0; }\n\n.ag-floating-filter-input .ag-input-field-input[type='date'] {\n width: 1px; }\n\n.ag-range-field {\n display: flex;\n align-items: center; }\n\n.ag-angle-select {\n display: flex;\n align-items: center; }\n\n.ag-angle-select-wrapper {\n display: flex; }\n\n.ag-angle-select-parent-circle {\n display: block;\n position: relative; }\n\n.ag-angle-select-child-circle {\n position: absolute; }\n\n.ag-slider-wrapper {\n display: flex; }\n\n.ag-slider-wrapper .ag-input-field {\n flex: 1 1 auto; }\n\n.ag-picker-field-display {\n flex: 1 1 auto; }\n\n.ag-picker-field {\n display: flex;\n align-items: center; }\n\n.ag-picker-field-icon {\n display: flex;\n border: 0;\n padding: 0;\n margin: 0;\n cursor: pointer; }\n\n.ag-picker-field-wrapper {\n overflow: hidden; }\n\n.ag-label-align-right .ag-label {\n order: 1; }\n\n.ag-label-align-right > * {\n flex: none; }\n\n.ag-label-align-top {\n flex-direction: column;\n align-items: flex-start; }\n .ag-label-align-top > * {\n align-self: stretch; }\n\n.ag-color-panel {\n width: 100%;\n display: flex;\n flex-direction: column;\n text-align: center; }\n\n.ag-spectrum-color {\n flex: 1 1 auto;\n position: relative;\n overflow: hidden;\n cursor: default; }\n\n.ag-spectrum-fill {\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0; }\n\n.ag-spectrum-val {\n cursor: pointer; }\n\n.ag-spectrum-dragger {\n position: absolute;\n pointer-events: none;\n cursor: pointer; }\n\n.ag-spectrum-hue {\n cursor: default;\n background: linear-gradient(to left, #ff0000 3%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%); }\n\n.ag-spectrum-alpha {\n cursor: default; }\n\n.ag-spectrum-hue-background {\n width: 100%;\n height: 100%; }\n\n.ag-spectrum-alpha-background {\n background-image: linear-gradient(to right, rgba(0, 0, 0, 0), black);\n width: 100%;\n height: 100%; }\n\n.ag-spectrum-tool {\n cursor: pointer; }\n\n.ag-spectrum-slider {\n position: absolute;\n pointer-events: none; }\n\n.ag-recent-colors {\n display: flex; }\n\n.ag-recent-color {\n cursor: pointer; }\n\n.ag-ltr .ag-column-select-indent-1 {\n padding-left: 20px; }\n\n.ag-rtl .ag-column-select-indent-1 {\n padding-right: 20px; }\n\n.ag-ltr .ag-row-group-indent-1 {\n padding-left: 20px; }\n\n.ag-rtl .ag-row-group-indent-1 {\n padding-right: 20px; }\n\n.ag-ltr .ag-column-select-indent-2 {\n padding-left: 40px; }\n\n.ag-rtl .ag-column-select-indent-2 {\n padding-right: 40px; }\n\n.ag-ltr .ag-row-group-indent-2 {\n padding-left: 40px; }\n\n.ag-rtl .ag-row-group-indent-2 {\n padding-right: 40px; }\n\n.ag-ltr .ag-column-select-indent-3 {\n padding-left: 60px; }\n\n.ag-rtl .ag-column-select-indent-3 {\n padding-right: 60px; }\n\n.ag-ltr .ag-row-group-indent-3 {\n padding-left: 60px; }\n\n.ag-rtl .ag-row-group-indent-3 {\n padding-right: 60px; }\n\n.ag-ltr .ag-column-select-indent-4 {\n padding-left: 80px; }\n\n.ag-rtl .ag-column-select-indent-4 {\n padding-right: 80px; }\n\n.ag-ltr .ag-row-group-indent-4 {\n padding-left: 80px; }\n\n.ag-rtl .ag-row-group-indent-4 {\n padding-right: 80px; }\n\n.ag-ltr .ag-column-select-indent-5 {\n padding-left: 100px; }\n\n.ag-rtl .ag-column-select-indent-5 {\n padding-right: 100px; }\n\n.ag-ltr .ag-row-group-indent-5 {\n padding-left: 100px; }\n\n.ag-rtl .ag-row-group-indent-5 {\n padding-right: 100px; }\n\n.ag-ltr .ag-column-select-indent-6 {\n padding-left: 120px; }\n\n.ag-rtl .ag-column-select-indent-6 {\n padding-right: 120px; }\n\n.ag-ltr .ag-row-group-indent-6 {\n padding-left: 120px; }\n\n.ag-rtl .ag-row-group-indent-6 {\n padding-right: 120px; }\n\n.ag-ltr .ag-column-select-indent-7 {\n padding-left: 140px; }\n\n.ag-rtl .ag-column-select-indent-7 {\n padding-right: 140px; }\n\n.ag-ltr .ag-row-group-indent-7 {\n padding-left: 140px; }\n\n.ag-rtl .ag-row-group-indent-7 {\n padding-right: 140px; }\n\n.ag-ltr .ag-column-select-indent-8 {\n padding-left: 160px; }\n\n.ag-rtl .ag-column-select-indent-8 {\n padding-right: 160px; }\n\n.ag-ltr .ag-row-group-indent-8 {\n padding-left: 160px; }\n\n.ag-rtl .ag-row-group-indent-8 {\n padding-right: 160px; }\n\n.ag-ltr .ag-column-select-indent-9 {\n padding-left: 180px; }\n\n.ag-rtl .ag-column-select-indent-9 {\n padding-right: 180px; }\n\n.ag-ltr .ag-row-group-indent-9 {\n padding-left: 180px; }\n\n.ag-rtl .ag-row-group-indent-9 {\n padding-right: 180px; }\n\n.ag-ltr {\n direction: ltr; }\n .ag-ltr .ag-body, .ag-ltr .ag-floating-top, .ag-ltr .ag-floating-bottom, .ag-ltr .ag-header, .ag-ltr .ag-body-viewport, .ag-ltr .ag-body-horizontal-scroll {\n flex-direction: row; }\n\n.ag-rtl {\n direction: rtl; }\n .ag-rtl .ag-body, .ag-rtl .ag-floating-top, .ag-rtl .ag-floating-bottom, .ag-rtl .ag-header, .ag-rtl .ag-body-viewport, .ag-rtl .ag-body-horizontal-scroll {\n flex-direction: row-reverse; }\n .ag-rtl .ag-icon-contracted,\n .ag-rtl .ag-icon-tree-closed {\n display: block;\n -webkit-transform: rotate(180deg);\n transform: rotate(180deg); }\n\n.ag-body .ag-body-viewport {\n -webkit-overflow-scrolling: touch; }\n\n.ag-chart {\n position: relative;\n display: flex;\n overflow: hidden;\n width: 100%;\n height: 100%; }\n\n.ag-chart-components-wrapper {\n position: relative;\n display: flex;\n flex: 1 1 auto;\n overflow: hidden; }\n\n.ag-chart-title-edit {\n position: absolute;\n display: none;\n top: 0;\n left: 0;\n text-align: center; }\n\n.ag-chart-title-edit.currently-editing {\n display: inline-block; }\n\n.ag-chart-canvas-wrapper {\n position: relative;\n flex: 1 1 auto;\n overflow: hidden; }\n\n.ag-charts-canvas {\n display: block; }\n\n.ag-chart-menu {\n position: absolute;\n top: 10px;\n width: 24px;\n overflow: hidden;\n display: flex;\n flex-direction: column; }\n .ag-ltr .ag-chart-menu {\n right: 20px; }\n .ag-rtl .ag-chart-menu {\n left: 20px; }\n\n.ag-chart-docked-container {\n position: relative;\n width: 0;\n min-width: 0;\n transition: min-width 0.4s; }\n\n.ag-chart-menu-hidden ~ .ag-chart-docked-container {\n max-width: 0;\n overflow: hidden; }\n\n.ag-chart-tabbed-menu {\n width: 100%;\n height: 100%;\n display: flex;\n flex-direction: column;\n overflow: hidden; }\n\n.ag-chart-tabbed-menu-header {\n flex: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n cursor: default; }\n\n.ag-chart-tabbed-menu-body {\n display: flex;\n flex: 1 1 auto;\n align-items: stretch;\n overflow: hidden; }\n\n.ag-chart-tab {\n width: 100%;\n overflow: hidden;\n overflow-y: auto; }\n\n.ag-chart-settings {\n overflow-x: hidden; }\n\n.ag-chart-settings-wrapper {\n position: relative;\n flex-direction: column;\n width: 100%;\n height: 100%;\n display: flex;\n overflow: hidden; }\n\n.ag-chart-settings-nav-bar {\n width: 100%;\n display: flex;\n height: 30px;\n align-items: center; }\n\n.ag-chart-settings-card-selector {\n display: flex;\n align-items: center;\n justify-content: space-around;\n flex: 1 1 auto;\n height: 100%;\n padding: 0 10px; }\n\n.ag-chart-settings-card-item {\n cursor: pointer;\n width: 10px;\n height: 10px;\n background-color: #000;\n position: relative; }\n .ag-chart-settings-card-item.ag-not-selected {\n opacity: 0.2; }\n .ag-chart-settings-card-item:before {\n content: \" \";\n display: block;\n position: absolute;\n background-color: transparent;\n left: 50%;\n top: 50%;\n margin-left: -10px;\n margin-top: -10px;\n width: 20px;\n height: 20px; }\n\n.ag-chart-settings-prev,\n.ag-chart-settings-next {\n position: relative;\n flex: none; }\n\n.ag-chart-settings-prev-button,\n.ag-chart-settings-next-button {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n cursor: pointer;\n opacity: 0; }\n\n.ag-chart-settings-mini-charts-container {\n position: relative;\n flex: 1 1 auto;\n overflow-x: hidden;\n overflow-y: auto; }\n\n.ag-chart-settings-mini-wrapper {\n position: absolute;\n top: 0;\n left: 0;\n display: flex;\n flex-direction: column;\n width: 100%;\n min-height: 100%;\n overflow: hidden; }\n .ag-chart-settings-mini-wrapper.ag-animating {\n transition: left 0.3s;\n transition-timing-function: ease-in-out; }\n\n.ag-chart-mini-thumbnail {\n cursor: pointer; }\n\n.ag-chart-mini-thumbnail-canvas {\n display: block; }\n\n.ag-chart-data-wrapper,\n.ag-chart-format-wrapper {\n display: flex;\n flex-direction: column;\n position: relative;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n\n.ag-chart-data-section,\n.ag-chart-format-section {\n display: flex;\n margin: 0; }\n\n.ag-charts-font-panel-controls {\n justify-content: space-between; }\n\n.ag-chart-empty-text {\n display: flex;\n top: 0;\n width: 100%;\n height: 100%;\n align-items: center;\n justify-content: center; }\n\n.ag-chart .ag-chart-menu {\n opacity: 0;\n pointer-events: none; }\n\n.ag-chart-menu-hidden:hover .ag-chart-menu {\n opacity: 1;\n pointer-events: all; }\n\n.ag-chart-settings-nav-bar {\n padding: 0 10px;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n\n.ag-date-time-list-page-title-bar {\n display: flex; }\n\n.ag-date-time-list-page-column-labels-row,\n.ag-date-time-list-page-entries-row {\n display: flex; }\n\n.ag-date-time-list-page-column-label,\n.ag-date-time-list-page-entry {\n flex-basis: 0;\n flex-grow: 1; }\n\n.ag-date-time-list-page-entry {\n cursor: pointer; }\n\n", ""]); +exports.push([module.i, "/**\n ****************************\n * Generic Styles\n ****************************\n*/\nag-grid, ag-grid-angular, ag-grid-ng2, ag-grid-polymer, ag-grid-aurelia {\n display: block;\n}\n\n.ag-hidden {\n display: none !important;\n}\n\n.ag-invisible {\n visibility: hidden !important;\n}\n\n.ag-drag-handle {\n cursor: -webkit-grab;\n cursor: grab;\n}\n\n.ag-column-drop-wrapper {\n display: -webkit-box;\n display: flex;\n}\n\n.ag-column-drop-horizontal-half-width {\n display: inline-block;\n width: 50% !important;\n}\n\n.ag-unselectable {\n -moz-user-select: none;\n -webkit-user-select: none;\n user-select: none;\n}\n\n.ag-selectable {\n -moz-user-select: text;\n -webkit-user-select: text;\n user-select: text;\n}\n\n.ag-tab {\n position: relative;\n}\n\n.ag-tab-guard {\n position: absolute;\n width: 0;\n height: 0;\n display: block;\n}\n\n.ag-select-agg-func-popup {\n position: absolute;\n}\n\n.ag-input-wrapper, .ag-picker-field-wrapper {\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n -webkit-box-align: center;\n align-items: center;\n line-height: normal;\n position: relative;\n}\n\n.ag-shake-left-to-right {\n -webkit-animation-direction: alternate;\n animation-direction: alternate;\n -webkit-animation-duration: 0.2s;\n animation-duration: 0.2s;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-name: ag-shake-left-to-right;\n animation-name: ag-shake-left-to-right;\n}\n\n@-webkit-keyframes ag-shake-left-to-right {\n from {\n padding-left: 6px;\n padding-right: 2px;\n }\n to {\n padding-left: 2px;\n padding-right: 6px;\n }\n}\n\n@keyframes ag-shake-left-to-right {\n from {\n padding-left: 6px;\n padding-right: 2px;\n }\n to {\n padding-left: 2px;\n padding-right: 6px;\n }\n}\n.ag-root-wrapper {\n cursor: default;\n position: relative;\n display: -webkit-box;\n display: flex;\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n flex-direction: column;\n overflow: hidden;\n}\n.ag-root-wrapper.ag-layout-normal {\n height: 100%;\n}\n\n.ag-watermark {\n position: absolute;\n bottom: 20px;\n right: 25px;\n opacity: 0.5;\n -webkit-transition: opacity 1s ease-out 3s;\n transition: opacity 1s ease-out 3s;\n}\n.ag-watermark::before {\n content: \"\";\n background-image: url();\n background-repeat: no-repeat;\n background-size: 170px 40px;\n display: block;\n height: 40px;\n width: 170px;\n opacity: 0.5;\n}\n\n.ag-watermark-text {\n opacity: 0.5;\n font-weight: bold;\n font-family: Impact, sans-serif;\n font-size: 19px;\n padding-left: 0.7rem;\n}\n\n.ag-root-wrapper-body {\n display: -webkit-box;\n display: flex;\n -webkit-box-orient: horizontal;\n -webkit-box-direction: normal;\n flex-direction: row;\n}\n.ag-root-wrapper-body.ag-layout-normal {\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n height: 0;\n min-height: 0;\n}\n\n.ag-root {\n position: relative;\n display: -webkit-box;\n display: flex;\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n flex-direction: column;\n}\n.ag-root.ag-layout-normal, .ag-root.ag-layout-auto-height {\n overflow: hidden;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n width: 0;\n}\n.ag-root.ag-layout-normal {\n height: 100%;\n}\n\n/**\n ****************************\n * Viewports\n ****************************\n*/\n.ag-header-viewport,\n.ag-floating-top-viewport,\n.ag-body-viewport,\n.ag-center-cols-viewport,\n.ag-floating-bottom-viewport,\n.ag-body-horizontal-scroll-viewport,\n.ag-virtual-list-viewport {\n position: relative;\n height: 100%;\n min-width: 0px;\n overflow: hidden;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n}\n\n.ag-body-viewport {\n display: -webkit-box;\n display: flex;\n}\n.ag-body-viewport.ag-layout-normal {\n overflow-y: auto;\n -webkit-overflow-scrolling: touch;\n}\n\n.ag-center-cols-viewport {\n width: 100%;\n overflow-x: auto;\n}\n\n.ag-body-horizontal-scroll-viewport {\n overflow-x: scroll;\n}\n\n.ag-virtual-list-viewport {\n overflow: auto;\n width: 100%;\n}\n\n/**\n ****************************\n * Containers\n ****************************\n*/\n.ag-header-container,\n.ag-floating-top-container,\n.ag-body-container,\n.ag-pinned-right-cols-container,\n.ag-center-cols-container,\n.ag-pinned-left-cols-container,\n.ag-floating-bottom-container,\n.ag-body-horizontal-scroll-container,\n.ag-full-width-container,\n.ag-floating-bottom-full-width-container,\n.ag-virtual-list-container {\n position: relative;\n}\n\n.ag-header-container, .ag-floating-top-container, .ag-floating-bottom-container {\n height: 100%;\n white-space: nowrap;\n}\n\n.ag-center-cols-container {\n display: block;\n}\n\n.ag-pinned-right-cols-container {\n display: block;\n}\n\n.ag-body-horizontal-scroll-container {\n height: 100%;\n}\n\n.ag-full-width-container,\n.ag-floating-top-full-width-container,\n.ag-floating-bottom-full-width-container {\n position: absolute;\n top: 0px;\n left: 0px;\n pointer-events: none;\n}\n\n.ag-full-width-container {\n width: 100%;\n}\n\n.ag-floating-bottom-full-width-container, .ag-floating-top-full-width-container {\n display: inline-block;\n overflow: hidden;\n height: 100%;\n width: 100%;\n}\n\n.ag-virtual-list-container {\n overflow: hidden;\n}\n\n/**\n ****************************\n * Scrollers\n ****************************\n*/\n.ag-center-cols-clipper {\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n min-width: 0;\n overflow: hidden;\n min-height: 100%;\n -webkit-transform: translate3d(0, 0, 0);\n transform: translate3d(0, 0, 0);\n}\n\n.ag-body-horizontal-scroll {\n min-height: 0;\n min-width: 0;\n width: 100%;\n display: -webkit-box;\n display: flex;\n position: relative;\n}\n.ag-body-horizontal-scroll.ag-scrollbar-invisible {\n position: absolute;\n bottom: 0;\n left: 0;\n right: 0;\n pointer-events: none;\n}\n.ag-body-horizontal-scroll.ag-scrollbar-invisible.ag-scrollbar-scrolling, .ag-body-horizontal-scroll.ag-scrollbar-invisible.ag-scrollbar-active {\n pointer-events: all;\n}\n\n.ag-force-vertical-scroll {\n overflow-y: scroll !important;\n}\n\n.ag-horizontal-left-spacer, .ag-horizontal-right-spacer {\n height: 100%;\n min-width: 0;\n overflow-x: scroll;\n}\n.ag-horizontal-left-spacer.ag-scroller-corner, .ag-horizontal-right-spacer.ag-scroller-corner {\n overflow-x: hidden;\n}\n\n/**\n ****************************\n * Headers\n ****************************\n*/\n.ag-header, .ag-pinned-left-header, .ag-pinned-right-header {\n display: inline-block;\n overflow: hidden;\n position: relative;\n}\n\n.ag-header-cell-sortable {\n cursor: pointer;\n}\n\n.ag-header {\n display: -webkit-box;\n display: flex;\n width: 100%;\n white-space: nowrap;\n}\n\n.ag-pinned-left-header {\n height: 100%;\n}\n\n.ag-pinned-right-header {\n height: 100%;\n}\n\n.ag-header-row {\n position: absolute;\n overflow: hidden;\n}\n\n.ag-header-cell {\n display: -webkit-inline-box;\n display: inline-flex;\n -webkit-box-align: center;\n align-items: center;\n position: absolute;\n height: 100%;\n overflow: hidden;\n}\n\n.ag-header-cell.ag-header-active .ag-header-cell-menu-button {\n opacity: 1;\n}\n\n.ag-header-cell-menu-button:not(.ag-header-menu-always-show) {\n -webkit-transition: opacity 0.2s;\n transition: opacity 0.2s;\n opacity: 0;\n}\n\n.ag-header-group-cell-label, .ag-header-cell-label {\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n overflow: hidden;\n -webkit-box-align: center;\n align-items: center;\n text-overflow: ellipsis;\n align-self: stretch;\n}\n\n.ag-header-cell-text {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n.ag-right-aligned-header .ag-header-cell-label {\n -webkit-box-orient: horizontal;\n -webkit-box-direction: reverse;\n flex-direction: row-reverse;\n}\n\n.ag-header-group-text {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n.ag-header-cell-resize {\n position: absolute;\n z-index: 2;\n height: 100%;\n width: 8px;\n top: 0;\n cursor: ew-resize;\n}\n.ag-ltr .ag-header-cell-resize {\n right: -4px;\n}\n.ag-rtl .ag-header-cell-resize {\n left: -4px;\n}\n\n.ag-pinned-left-header .ag-header-cell-resize {\n right: -4px;\n}\n\n.ag-pinned-right-header .ag-header-cell-resize {\n left: -4px;\n}\n\n.ag-header-select-all {\n display: -webkit-box;\n display: flex;\n}\n\n/**\n ****************************\n * Columns\n ****************************\n*/\n.ag-column-moving .ag-cell {\n -webkit-transition: left 0.2s;\n transition: left 0.2s;\n}\n.ag-column-moving .ag-header-cell {\n -webkit-transition: left 0.2s;\n transition: left 0.2s;\n}\n.ag-column-moving .ag-header-group-cell {\n -webkit-transition: left 0.2s, width 0.2s;\n transition: left 0.2s, width 0.2s;\n}\n\n/**\n ****************************\n * Column Panel\n ****************************\n*/\n.ag-column-panel {\n display: -webkit-box;\n display: flex;\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n flex-direction: column;\n overflow: hidden;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n}\n\n.ag-column-select {\n position: relative;\n display: -webkit-box;\n display: flex;\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n flex-direction: column;\n overflow: hidden;\n -webkit-box-flex: 3;\n flex: 3 1 0px;\n}\n\n.ag-column-select-header {\n position: relative;\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 0;\n flex: none;\n}\n\n.ag-column-select-header-icon {\n position: relative;\n}\n\n.ag-column-select-header-filter-wrapper {\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n}\n\n.ag-column-select-header-filter {\n width: 100%;\n}\n\n.ag-column-select-list {\n -webkit-box-flex: 1;\n flex: 1 1 0px;\n overflow: hidden;\n}\n\n.ag-column-drop {\n position: relative;\n display: -webkit-inline-box;\n display: inline-flex;\n -webkit-box-align: center;\n align-items: center;\n overflow: auto;\n width: 100%;\n}\n\n.ag-column-drop-list {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n\n.ag-column-drop-cell {\n position: relative;\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n\n.ag-column-drop-cell-text {\n overflow: hidden;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n.ag-column-drop-vertical {\n display: -webkit-box;\n display: flex;\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n flex-direction: column;\n overflow: hidden;\n -webkit-box-align: stretch;\n align-items: stretch;\n -webkit-box-flex: 1;\n flex: 1 1 0px;\n}\n\n.ag-column-drop-vertical-title-bar {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-flex: 0;\n flex: none;\n}\n\n.ag-column-drop-vertical-list {\n position: relative;\n -webkit-box-align: stretch;\n align-items: stretch;\n -webkit-box-flex: 1;\n flex-grow: 1;\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n flex-direction: column;\n overflow-x: auto;\n}\n.ag-column-drop-vertical-list > * {\n -webkit-box-flex: 0;\n flex: none;\n}\n\n.ag-column-drop-empty .ag-column-drop-vertical-list {\n overflow: hidden;\n}\n\n.ag-column-drop-vertical-empty-message {\n display: block;\n}\n\n.ag-column-drop.ag-column-drop-horizontal {\n white-space: nowrap;\n overflow: hidden;\n}\n\n.ag-column-drop-cell-button {\n cursor: pointer;\n}\n\n.ag-filter-toolpanel {\n -webkit-box-flex: 1;\n flex: 1 1 0px;\n min-width: 0;\n}\n\n.ag-filter-toolpanel-header {\n position: relative;\n}\n\n.ag-filter-toolpanel-header, .ag-filter-toolpanel-search {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-filter-toolpanel-header > *, .ag-filter-toolpanel-search > * {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n\n.ag-filter-apply-panel {\n display: -webkit-box;\n display: flex;\n -webkit-box-pack: end;\n justify-content: flex-end;\n overflow: hidden;\n}\n\n/**\n ****************************\n * Rows\n ****************************\n*/\n.ag-row-animation .ag-row {\n -webkit-transition: top 0.4s, background-color 0.1s, opacity 0.2s, -webkit-transform 0.4s;\n transition: top 0.4s, background-color 0.1s, opacity 0.2s, -webkit-transform 0.4s;\n transition: transform 0.4s, top 0.4s, background-color 0.1s, opacity 0.2s;\n transition: transform 0.4s, top 0.4s, background-color 0.1s, opacity 0.2s, -webkit-transform 0.4s;\n}\n\n.ag-row-animation .ag-row.ag-after-created {\n -webkit-transition: top 0.4s, height 0.4s, background-color 0.1s, opacity 0.2s, -webkit-transform 0.4s;\n transition: top 0.4s, height 0.4s, background-color 0.1s, opacity 0.2s, -webkit-transform 0.4s;\n transition: transform 0.4s, top 0.4s, height 0.4s, background-color 0.1s, opacity 0.2s;\n transition: transform 0.4s, top 0.4s, height 0.4s, background-color 0.1s, opacity 0.2s, -webkit-transform 0.4s;\n}\n\n.ag-row-no-animation .ag-row {\n -webkit-transition: background-color 0.1s;\n transition: background-color 0.1s;\n}\n\n.ag-row {\n white-space: nowrap;\n width: 100%;\n}\n\n.ag-row-loading {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n\n.ag-row-position-absolute {\n position: absolute;\n}\n\n.ag-row-position-relative {\n position: relative;\n}\n\n.ag-full-width-row {\n overflow: hidden;\n pointer-events: all;\n}\n\n.ag-row-inline-editing {\n z-index: 1;\n}\n\n.ag-row-dragging {\n z-index: 2;\n}\n\n.ag-stub-cell {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n\n/**\n ****************************\n * Cells\n ****************************\n*/\n.ag-cell {\n display: inline-block;\n position: absolute;\n white-space: nowrap;\n height: 100%;\n}\n\n.ag-cell-value, .ag-group-value {\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.ag-cell-wrap-text {\n white-space: normal;\n word-break: break-all;\n}\n\n.ag-cell-wrapper {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-cell-wrapper.ag-row-group {\n -webkit-box-align: start;\n align-items: flex-start;\n}\n\n.ag-sparkline-wrapper {\n position: absolute;\n height: 100%;\n width: 100%;\n left: 0;\n top: 0;\n}\n\n.ag-full-width-row .ag-cell-wrapper.ag-row-group {\n height: 100%;\n -webkit-box-align: center;\n align-items: center;\n}\n\n.ag-cell-inline-editing {\n z-index: 1;\n}\n.ag-cell-inline-editing .ag-cell-wrapper,\n.ag-cell-inline-editing .ag-cell-edit-wrapper,\n.ag-cell-inline-editing .ag-cell-editor,\n.ag-cell-inline-editing .ag-cell-editor .ag-wrapper,\n.ag-cell-inline-editing .ag-cell-editor input {\n height: 100%;\n width: 100%;\n line-height: normal;\n}\n\n.ag-cell .ag-icon {\n display: inline-block;\n vertical-align: middle;\n}\n\n/**\n ****************************\n * Filters\n ****************************\n*/\n.ag-set-filter-item {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n height: 100%;\n}\n\n.ag-set-filter-item-value {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n.ag-set-filter-item-checkbox {\n display: -webkit-box;\n display: flex;\n}\n\n.ag-filter-body-wrapper {\n display: -webkit-box;\n display: flex;\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n flex-direction: column;\n}\n\n.ag-filter-filter {\n -webkit-box-flex: 1;\n flex: 1 1 0px;\n}\n\n.ag-filter-condition {\n display: -webkit-box;\n display: flex;\n -webkit-box-pack: center;\n justify-content: center;\n}\n\n/**\n ****************************\n * Floating Filter\n ****************************\n*/\n.ag-floating-filter-body {\n position: relative;\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n height: 100%;\n}\n\n.ag-floating-filter-full-body {\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n height: 100%;\n width: 100%;\n -webkit-box-align: center;\n align-items: center;\n overflow: hidden;\n}\n\n.ag-floating-filter-full-body > div {\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n}\n\n.ag-floating-filter-input {\n -webkit-box-align: center;\n align-items: center;\n display: -webkit-box;\n display: flex;\n width: 100%;\n}\n.ag-floating-filter-input > * {\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n}\n\n.ag-floating-filter-button {\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 0;\n flex: none;\n}\n\n/**\n ****************************\n * Drag & Drop\n ****************************\n*/\n.ag-dnd-ghost {\n position: absolute;\n display: -webkit-inline-box;\n display: inline-flex;\n -webkit-box-align: center;\n align-items: center;\n cursor: move;\n white-space: nowrap;\n z-index: 9999;\n}\n\n/**\n ****************************\n * Overlay\n ****************************\n*/\n.ag-overlay {\n height: 100%;\n left: 0;\n pointer-events: none;\n position: absolute;\n top: 0;\n width: 100%;\n}\n\n.ag-overlay-panel {\n display: -webkit-box;\n display: flex;\n height: 100%;\n width: 100%;\n}\n\n.ag-overlay-wrapper {\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 0;\n flex: none;\n width: 100%;\n height: 100%;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-pack: center;\n justify-content: center;\n text-align: center;\n}\n\n.ag-overlay-loading-wrapper {\n pointer-events: all;\n}\n\n/**\n ****************************\n * Popup\n ****************************\n*/\n.ag-popup-child {\n z-index: 5;\n top: 0;\n}\n\n.ag-popup-editor {\n position: absolute;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n z-index: 1;\n}\n\n.ag-large-text-input {\n display: block;\n}\n\n/**\n ****************************\n * Virtual Lists\n ****************************\n*/\n.ag-virtual-list-item {\n position: absolute;\n width: 100%;\n}\n\n/**\n ****************************\n * Floating Top and Bottom\n ****************************\n*/\n.ag-floating-top {\n overflow: hidden;\n white-space: nowrap;\n width: 100%;\n position: relative;\n display: -webkit-box;\n display: flex;\n}\n\n.ag-pinned-left-floating-top {\n display: inline-block;\n overflow: hidden;\n position: relative;\n min-width: 0px;\n}\n\n.ag-pinned-right-floating-top {\n display: inline-block;\n overflow: hidden;\n position: relative;\n min-width: 0px;\n}\n\n.ag-floating-bottom {\n overflow: hidden;\n white-space: nowrap;\n width: 100%;\n position: relative;\n display: -webkit-box;\n display: flex;\n}\n\n.ag-pinned-left-floating-bottom {\n display: inline-block;\n overflow: hidden;\n position: relative;\n min-width: 0px;\n}\n\n.ag-pinned-right-floating-bottom {\n display: inline-block;\n overflow: hidden;\n position: relative;\n min-width: 0px;\n}\n\n/**\n ****************************\n * Dialog\n ****************************\n*/\n.ag-dialog, .ag-panel {\n display: -webkit-box;\n display: flex;\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n flex-direction: column;\n position: relative;\n overflow: hidden;\n}\n\n.ag-panel-title-bar {\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 0;\n flex: none;\n -webkit-box-align: center;\n align-items: center;\n cursor: default;\n}\n\n.ag-panel-title-bar-title {\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n}\n\n.ag-panel-title-bar-buttons {\n display: -webkit-box;\n display: flex;\n}\n\n.ag-panel-title-bar-button {\n cursor: pointer;\n}\n\n.ag-panel-content-wrapper {\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n position: relative;\n overflow: hidden;\n}\n\n.ag-dialog {\n position: absolute;\n}\n\n.ag-resizer {\n position: absolute;\n pointer-events: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n z-index: 1;\n}\n.ag-resizer.ag-resizer-topLeft {\n top: 0;\n left: 0;\n height: 5px;\n width: 5px;\n cursor: nwse-resize;\n}\n.ag-resizer.ag-resizer-top {\n top: 0;\n left: 5px;\n right: 5px;\n height: 5px;\n cursor: ns-resize;\n}\n.ag-resizer.ag-resizer-topRight {\n top: 0;\n right: 0;\n height: 5px;\n width: 5px;\n cursor: nesw-resize;\n}\n.ag-resizer.ag-resizer-right {\n top: 5px;\n right: 0;\n bottom: 5px;\n width: 5px;\n cursor: ew-resize;\n}\n.ag-resizer.ag-resizer-bottomRight {\n bottom: 0;\n right: 0;\n height: 5px;\n width: 5px;\n cursor: nwse-resize;\n}\n.ag-resizer.ag-resizer-bottom {\n bottom: 0;\n left: 5px;\n right: 5px;\n height: 5px;\n cursor: ns-resize;\n}\n.ag-resizer.ag-resizer-bottomLeft {\n bottom: 0;\n left: 0;\n height: 5px;\n width: 5px;\n cursor: nesw-resize;\n}\n.ag-resizer.ag-resizer-left {\n left: 0;\n top: 5px;\n bottom: 5px;\n width: 5px;\n cursor: ew-resize;\n}\n\n/**\n ****************************\n * Tooltip\n ****************************\n*/\n.ag-tooltip {\n position: absolute;\n pointer-events: none;\n z-index: 99999;\n}\n\n.ag-tooltip-custom {\n position: absolute;\n pointer-events: none;\n z-index: 99999;\n}\n\n/**\n ****************************\n * Animations\n ****************************\n*/\n.ag-value-slide-out {\n margin-right: 5px;\n opacity: 1;\n -webkit-transition: opacity 3s, margin-right 3s;\n transition: opacity 3s, margin-right 3s;\n -webkit-transition-timing-function: linear;\n transition-timing-function: linear;\n}\n\n.ag-value-slide-out-end {\n margin-right: 10px;\n opacity: 0;\n}\n\n.ag-opacity-zero {\n opacity: 0 !important;\n}\n\n/**\n ****************************\n * Menu\n ****************************\n*/\n.ag-menu {\n max-height: 100%;\n overflow-y: auto;\n position: absolute;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n}\n\n.ag-menu-column-select-wrapper {\n height: 265px;\n overflow: auto;\n}\n.ag-menu-column-select-wrapper .ag-column-select {\n height: 100%;\n}\n\n.ag-menu-list {\n display: table;\n width: 100%;\n}\n\n.ag-menu-option, .ag-menu-separator {\n display: table-row;\n}\n\n.ag-menu-option-part, .ag-menu-separator-part {\n display: table-cell;\n vertical-align: middle;\n}\n\n.ag-menu-option-text {\n white-space: nowrap;\n}\n\n.ag-compact-menu-option {\n width: 100%;\n display: -webkit-box;\n display: flex;\n flex-wrap: nowrap;\n}\n\n.ag-compact-menu-option-text {\n white-space: nowrap;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n}\n\n/**\n ****************************\n * Rich Select\n ****************************\n*/\n.ag-rich-select {\n cursor: default;\n outline: none;\n}\n\n.ag-rich-select-value {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n\n.ag-rich-select-value-icon {\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n -webkit-box-ordinal-group: 2;\n order: 1;\n}\n.ag-ltr .ag-rich-select-value-icon {\n text-align: right;\n}\n.ag-rtl .ag-rich-select-value-icon {\n text-align: left;\n}\n\n.ag-rich-select-list {\n position: relative;\n}\n\n.ag-rich-select-virtual-list-item {\n display: -webkit-box;\n display: flex;\n}\n\n.ag-rich-select-row {\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n -webkit-box-align: center;\n align-items: center;\n white-space: nowrap;\n}\n\n/**\n ****************************\n * Pagination\n ****************************\n*/\n.ag-paging-panel {\n -webkit-box-align: center;\n align-items: center;\n display: -webkit-box;\n display: flex;\n -webkit-box-pack: end;\n justify-content: flex-end;\n}\n\n.ag-paging-page-summary-panel {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n\n.ag-paging-button {\n position: relative;\n}\n\n.ag-disabled .ag-paging-page-summary-panel {\n pointer-events: none;\n}\n\n/**\n ****************************\n * Tool Panel\n ****************************\n*/\n.ag-tool-panel-wrapper {\n display: -webkit-box;\n display: flex;\n overflow-y: auto;\n overflow-x: hidden;\n cursor: default;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n}\n\n.ag-column-select-column,\n.ag-column-select-column-group,\n.ag-select-agg-func-item {\n position: relative;\n -webkit-box-align: center;\n align-items: center;\n display: -webkit-box;\n display: flex;\n -webkit-box-orient: horizontal;\n -webkit-box-direction: normal;\n flex-direction: row;\n flex-wrap: nowrap;\n text-overflow: ellipsis;\n white-space: nowrap;\n height: 100%;\n}\n.ag-column-select-column > *,\n.ag-column-select-column-group > *,\n.ag-select-agg-func-item > * {\n -webkit-box-flex: 0;\n flex: none;\n}\n\n.ag-column-select-checkbox {\n display: -webkit-box;\n display: flex;\n}\n\n.ag-tool-panel-horizontal-resize {\n cursor: ew-resize;\n height: 100%;\n position: absolute;\n top: 0;\n width: 5px;\n z-index: 1;\n}\n\n.ag-ltr .ag-side-bar-left .ag-tool-panel-horizontal-resize {\n right: -3px;\n}\n.ag-rtl .ag-side-bar-left .ag-tool-panel-horizontal-resize {\n left: -3px;\n}\n\n.ag-ltr .ag-side-bar-right .ag-tool-panel-horizontal-resize {\n left: -3px;\n}\n.ag-rtl .ag-side-bar-right .ag-tool-panel-horizontal-resize {\n right: -3px;\n}\n\n.ag-details-row {\n width: 100%;\n}\n\n.ag-details-row-fixed-height {\n height: 100%;\n}\n\n.ag-details-grid {\n width: 100%;\n}\n\n.ag-details-grid-fixed-height {\n height: 100%;\n}\n\n.ag-header-group-cell {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n height: 100%;\n position: absolute;\n}\n\n.ag-cell-label-container {\n display: -webkit-box;\n display: flex;\n -webkit-box-pack: justify;\n justify-content: space-between;\n -webkit-box-orient: horizontal;\n -webkit-box-direction: reverse;\n flex-direction: row-reverse;\n -webkit-box-align: center;\n align-items: center;\n width: 100%;\n height: 100%;\n overflow: hidden;\n}\n\n.ag-right-aligned-header .ag-cell-label-container {\n -webkit-box-orient: horizontal;\n -webkit-box-direction: normal;\n flex-direction: row;\n}\n\n/**\n ****************************\n * Side Bar\n ****************************\n*/\n.ag-side-bar {\n display: -webkit-box;\n display: flex;\n -webkit-box-orient: horizontal;\n -webkit-box-direction: reverse;\n flex-direction: row-reverse;\n}\n\n.ag-side-bar-left {\n -webkit-box-ordinal-group: 0;\n order: -1;\n -webkit-box-orient: horizontal;\n -webkit-box-direction: normal;\n flex-direction: row;\n}\n\n.ag-side-button-button {\n position: relative;\n display: -webkit-box;\n display: flex;\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n flex-direction: column;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-pack: center;\n justify-content: center;\n flex-wrap: nowrap;\n white-space: nowrap;\n outline: none;\n cursor: pointer;\n}\n\n.ag-side-button-label {\n -webkit-writing-mode: vertical-lr;\n writing-mode: vertical-lr;\n}\n\n/**\n ****************************\n * Status Bar\n ****************************\n*/\n.ag-status-bar {\n display: -webkit-box;\n display: flex;\n -webkit-box-pack: justify;\n justify-content: space-between;\n overflow: hidden;\n}\n\n.ag-status-panel {\n display: -webkit-inline-box;\n display: inline-flex;\n}\n\n.ag-status-name-value {\n white-space: nowrap;\n}\n\n.ag-status-bar-left {\n display: -webkit-inline-box;\n display: inline-flex;\n}\n\n.ag-status-bar-center {\n display: -webkit-inline-box;\n display: inline-flex;\n}\n\n.ag-status-bar-right {\n display: -webkit-inline-box;\n display: inline-flex;\n}\n\n/**\n ****************************\n * Widgets\n ****************************\n*/\n.ag-icon {\n display: block;\n speak: none;\n}\n\n.ag-group {\n position: relative;\n width: 100%;\n}\n\n.ag-group-title-bar {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n\n.ag-group-title {\n display: block;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n min-width: 0;\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n}\n\n.ag-group-title-bar .ag-group-title {\n cursor: default;\n}\n\n.ag-group-toolbar {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n\n.ag-group-container {\n display: -webkit-box;\n display: flex;\n}\n\n.ag-disabled .ag-group-container {\n pointer-events: none;\n}\n\n.ag-group-container-horizontal {\n -webkit-box-orient: horizontal;\n -webkit-box-direction: normal;\n flex-direction: row;\n flex-wrap: wrap;\n}\n\n.ag-group-container-vertical {\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n flex-direction: column;\n}\n\n.ag-column-group-icons {\n display: block;\n}\n.ag-column-group-icons > * {\n cursor: pointer;\n}\n\n.ag-group-item-alignment-stretch .ag-group-item {\n -webkit-box-align: stretch;\n align-items: stretch;\n}\n\n.ag-group-item-alignment-start .ag-group-item {\n -webkit-box-align: start;\n align-items: flex-start;\n}\n\n.ag-group-item-alignment-end .ag-group-item {\n -webkit-box-align: end;\n align-items: flex-end;\n}\n\n.ag-toggle-button-icon {\n -webkit-transition: right 0.3s;\n transition: right 0.3s;\n position: absolute;\n top: -1px;\n}\n\n.ag-input-field, .ag-select {\n display: -webkit-box;\n display: flex;\n -webkit-box-orient: horizontal;\n -webkit-box-direction: normal;\n flex-direction: row;\n -webkit-box-align: center;\n align-items: center;\n}\n\n.ag-input-field-input {\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n width: 100%;\n min-width: 0;\n}\n\n.ag-floating-filter-input .ag-input-field-input[type=date] {\n width: 1px;\n}\n\n.ag-range-field {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n\n.ag-angle-select {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n\n.ag-angle-select-wrapper {\n display: -webkit-box;\n display: flex;\n}\n\n.ag-angle-select-parent-circle {\n display: block;\n position: relative;\n}\n\n.ag-angle-select-child-circle {\n position: absolute;\n}\n\n.ag-slider-wrapper {\n display: -webkit-box;\n display: flex;\n}\n.ag-slider-wrapper .ag-input-field {\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n}\n\n.ag-picker-field-display {\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n}\n\n.ag-picker-field {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n\n.ag-picker-field-icon {\n display: -webkit-box;\n display: flex;\n border: 0;\n padding: 0;\n margin: 0;\n cursor: pointer;\n}\n\n.ag-picker-field-wrapper {\n overflow: hidden;\n}\n\n.ag-label-align-right .ag-label {\n -webkit-box-ordinal-group: 2;\n order: 1;\n}\n.ag-label-align-right > * {\n -webkit-box-flex: 0;\n flex: none;\n}\n\n.ag-label-align-top {\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n flex-direction: column;\n -webkit-box-align: start;\n align-items: flex-start;\n}\n.ag-label-align-top > * {\n align-self: stretch;\n}\n\n.ag-color-panel {\n width: 100%;\n display: -webkit-box;\n display: flex;\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n flex-direction: column;\n text-align: center;\n}\n\n.ag-spectrum-color {\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n position: relative;\n overflow: hidden;\n cursor: default;\n}\n\n.ag-spectrum-fill {\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n}\n\n.ag-spectrum-val {\n cursor: pointer;\n}\n\n.ag-spectrum-dragger {\n position: absolute;\n pointer-events: none;\n cursor: pointer;\n}\n\n.ag-spectrum-hue {\n cursor: default;\n background: -webkit-gradient(linear, right top, left top, color-stop(3%, #ff0000), color-stop(17%, #ffff00), color-stop(33%, #00ff00), color-stop(50%, #00ffff), color-stop(67%, #0000ff), color-stop(83%, #ff00ff), to(#ff0000));\n background: linear-gradient(to left, #ff0000 3%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%);\n}\n\n.ag-spectrum-alpha {\n cursor: default;\n}\n\n.ag-spectrum-hue-background {\n width: 100%;\n height: 100%;\n}\n\n.ag-spectrum-alpha-background {\n background-image: -webkit-gradient(linear, left top, right top, from(rgba(0, 0, 0, 0)), to(black));\n background-image: linear-gradient(to right, rgba(0, 0, 0, 0), black);\n width: 100%;\n height: 100%;\n}\n\n.ag-spectrum-tool {\n cursor: pointer;\n}\n\n.ag-spectrum-slider {\n position: absolute;\n pointer-events: none;\n}\n\n.ag-recent-colors {\n display: -webkit-box;\n display: flex;\n}\n\n.ag-recent-color {\n cursor: pointer;\n}\n\n.ag-ltr .ag-column-select-indent-1 {\n padding-left: 20px;\n}\n.ag-rtl .ag-column-select-indent-1 {\n padding-right: 20px;\n}\n\n.ag-ltr .ag-row-group-indent-1 {\n padding-left: 20px;\n}\n.ag-rtl .ag-row-group-indent-1 {\n padding-right: 20px;\n}\n\n.ag-ltr .ag-column-select-indent-2 {\n padding-left: 40px;\n}\n.ag-rtl .ag-column-select-indent-2 {\n padding-right: 40px;\n}\n\n.ag-ltr .ag-row-group-indent-2 {\n padding-left: 40px;\n}\n.ag-rtl .ag-row-group-indent-2 {\n padding-right: 40px;\n}\n\n.ag-ltr .ag-column-select-indent-3 {\n padding-left: 60px;\n}\n.ag-rtl .ag-column-select-indent-3 {\n padding-right: 60px;\n}\n\n.ag-ltr .ag-row-group-indent-3 {\n padding-left: 60px;\n}\n.ag-rtl .ag-row-group-indent-3 {\n padding-right: 60px;\n}\n\n.ag-ltr .ag-column-select-indent-4 {\n padding-left: 80px;\n}\n.ag-rtl .ag-column-select-indent-4 {\n padding-right: 80px;\n}\n\n.ag-ltr .ag-row-group-indent-4 {\n padding-left: 80px;\n}\n.ag-rtl .ag-row-group-indent-4 {\n padding-right: 80px;\n}\n\n.ag-ltr .ag-column-select-indent-5 {\n padding-left: 100px;\n}\n.ag-rtl .ag-column-select-indent-5 {\n padding-right: 100px;\n}\n\n.ag-ltr .ag-row-group-indent-5 {\n padding-left: 100px;\n}\n.ag-rtl .ag-row-group-indent-5 {\n padding-right: 100px;\n}\n\n.ag-ltr .ag-column-select-indent-6 {\n padding-left: 120px;\n}\n.ag-rtl .ag-column-select-indent-6 {\n padding-right: 120px;\n}\n\n.ag-ltr .ag-row-group-indent-6 {\n padding-left: 120px;\n}\n.ag-rtl .ag-row-group-indent-6 {\n padding-right: 120px;\n}\n\n.ag-ltr .ag-column-select-indent-7 {\n padding-left: 140px;\n}\n.ag-rtl .ag-column-select-indent-7 {\n padding-right: 140px;\n}\n\n.ag-ltr .ag-row-group-indent-7 {\n padding-left: 140px;\n}\n.ag-rtl .ag-row-group-indent-7 {\n padding-right: 140px;\n}\n\n.ag-ltr .ag-column-select-indent-8 {\n padding-left: 160px;\n}\n.ag-rtl .ag-column-select-indent-8 {\n padding-right: 160px;\n}\n\n.ag-ltr .ag-row-group-indent-8 {\n padding-left: 160px;\n}\n.ag-rtl .ag-row-group-indent-8 {\n padding-right: 160px;\n}\n\n.ag-ltr .ag-column-select-indent-9 {\n padding-left: 180px;\n}\n.ag-rtl .ag-column-select-indent-9 {\n padding-right: 180px;\n}\n\n.ag-ltr .ag-row-group-indent-9 {\n padding-left: 180px;\n}\n.ag-rtl .ag-row-group-indent-9 {\n padding-right: 180px;\n}\n\n.ag-ltr .ag-column-select-indent-10 {\n padding-left: 200px;\n}\n.ag-rtl .ag-column-select-indent-10 {\n padding-right: 200px;\n}\n\n.ag-ltr .ag-row-group-indent-10 {\n padding-left: 200px;\n}\n.ag-rtl .ag-row-group-indent-10 {\n padding-right: 200px;\n}\n\n.ag-ltr .ag-column-select-indent-11 {\n padding-left: 220px;\n}\n.ag-rtl .ag-column-select-indent-11 {\n padding-right: 220px;\n}\n\n.ag-ltr .ag-row-group-indent-11 {\n padding-left: 220px;\n}\n.ag-rtl .ag-row-group-indent-11 {\n padding-right: 220px;\n}\n\n.ag-ltr .ag-column-select-indent-12 {\n padding-left: 240px;\n}\n.ag-rtl .ag-column-select-indent-12 {\n padding-right: 240px;\n}\n\n.ag-ltr .ag-row-group-indent-12 {\n padding-left: 240px;\n}\n.ag-rtl .ag-row-group-indent-12 {\n padding-right: 240px;\n}\n\n.ag-ltr .ag-column-select-indent-13 {\n padding-left: 260px;\n}\n.ag-rtl .ag-column-select-indent-13 {\n padding-right: 260px;\n}\n\n.ag-ltr .ag-row-group-indent-13 {\n padding-left: 260px;\n}\n.ag-rtl .ag-row-group-indent-13 {\n padding-right: 260px;\n}\n\n.ag-ltr .ag-column-select-indent-14 {\n padding-left: 280px;\n}\n.ag-rtl .ag-column-select-indent-14 {\n padding-right: 280px;\n}\n\n.ag-ltr .ag-row-group-indent-14 {\n padding-left: 280px;\n}\n.ag-rtl .ag-row-group-indent-14 {\n padding-right: 280px;\n}\n\n.ag-ltr .ag-column-select-indent-15 {\n padding-left: 300px;\n}\n.ag-rtl .ag-column-select-indent-15 {\n padding-right: 300px;\n}\n\n.ag-ltr .ag-row-group-indent-15 {\n padding-left: 300px;\n}\n.ag-rtl .ag-row-group-indent-15 {\n padding-right: 300px;\n}\n\n.ag-ltr .ag-column-select-indent-16 {\n padding-left: 320px;\n}\n.ag-rtl .ag-column-select-indent-16 {\n padding-right: 320px;\n}\n\n.ag-ltr .ag-row-group-indent-16 {\n padding-left: 320px;\n}\n.ag-rtl .ag-row-group-indent-16 {\n padding-right: 320px;\n}\n\n.ag-ltr .ag-column-select-indent-17 {\n padding-left: 340px;\n}\n.ag-rtl .ag-column-select-indent-17 {\n padding-right: 340px;\n}\n\n.ag-ltr .ag-row-group-indent-17 {\n padding-left: 340px;\n}\n.ag-rtl .ag-row-group-indent-17 {\n padding-right: 340px;\n}\n\n.ag-ltr .ag-column-select-indent-18 {\n padding-left: 360px;\n}\n.ag-rtl .ag-column-select-indent-18 {\n padding-right: 360px;\n}\n\n.ag-ltr .ag-row-group-indent-18 {\n padding-left: 360px;\n}\n.ag-rtl .ag-row-group-indent-18 {\n padding-right: 360px;\n}\n\n.ag-ltr .ag-column-select-indent-19 {\n padding-left: 380px;\n}\n.ag-rtl .ag-column-select-indent-19 {\n padding-right: 380px;\n}\n\n.ag-ltr .ag-row-group-indent-19 {\n padding-left: 380px;\n}\n.ag-rtl .ag-row-group-indent-19 {\n padding-right: 380px;\n}\n\n.ag-ltr .ag-column-select-indent-20 {\n padding-left: 400px;\n}\n.ag-rtl .ag-column-select-indent-20 {\n padding-right: 400px;\n}\n\n.ag-ltr .ag-row-group-indent-20 {\n padding-left: 400px;\n}\n.ag-rtl .ag-row-group-indent-20 {\n padding-right: 400px;\n}\n\n.ag-ltr .ag-column-select-indent-21 {\n padding-left: 420px;\n}\n.ag-rtl .ag-column-select-indent-21 {\n padding-right: 420px;\n}\n\n.ag-ltr .ag-row-group-indent-21 {\n padding-left: 420px;\n}\n.ag-rtl .ag-row-group-indent-21 {\n padding-right: 420px;\n}\n\n.ag-ltr .ag-column-select-indent-22 {\n padding-left: 440px;\n}\n.ag-rtl .ag-column-select-indent-22 {\n padding-right: 440px;\n}\n\n.ag-ltr .ag-row-group-indent-22 {\n padding-left: 440px;\n}\n.ag-rtl .ag-row-group-indent-22 {\n padding-right: 440px;\n}\n\n.ag-ltr .ag-column-select-indent-23 {\n padding-left: 460px;\n}\n.ag-rtl .ag-column-select-indent-23 {\n padding-right: 460px;\n}\n\n.ag-ltr .ag-row-group-indent-23 {\n padding-left: 460px;\n}\n.ag-rtl .ag-row-group-indent-23 {\n padding-right: 460px;\n}\n\n.ag-ltr .ag-column-select-indent-24 {\n padding-left: 480px;\n}\n.ag-rtl .ag-column-select-indent-24 {\n padding-right: 480px;\n}\n\n.ag-ltr .ag-row-group-indent-24 {\n padding-left: 480px;\n}\n.ag-rtl .ag-row-group-indent-24 {\n padding-right: 480px;\n}\n\n.ag-ltr .ag-column-select-indent-25 {\n padding-left: 500px;\n}\n.ag-rtl .ag-column-select-indent-25 {\n padding-right: 500px;\n}\n\n.ag-ltr .ag-row-group-indent-25 {\n padding-left: 500px;\n}\n.ag-rtl .ag-row-group-indent-25 {\n padding-right: 500px;\n}\n\n.ag-ltr .ag-column-select-indent-26 {\n padding-left: 520px;\n}\n.ag-rtl .ag-column-select-indent-26 {\n padding-right: 520px;\n}\n\n.ag-ltr .ag-row-group-indent-26 {\n padding-left: 520px;\n}\n.ag-rtl .ag-row-group-indent-26 {\n padding-right: 520px;\n}\n\n.ag-ltr .ag-column-select-indent-27 {\n padding-left: 540px;\n}\n.ag-rtl .ag-column-select-indent-27 {\n padding-right: 540px;\n}\n\n.ag-ltr .ag-row-group-indent-27 {\n padding-left: 540px;\n}\n.ag-rtl .ag-row-group-indent-27 {\n padding-right: 540px;\n}\n\n.ag-ltr .ag-column-select-indent-28 {\n padding-left: 560px;\n}\n.ag-rtl .ag-column-select-indent-28 {\n padding-right: 560px;\n}\n\n.ag-ltr .ag-row-group-indent-28 {\n padding-left: 560px;\n}\n.ag-rtl .ag-row-group-indent-28 {\n padding-right: 560px;\n}\n\n.ag-ltr .ag-column-select-indent-29 {\n padding-left: 580px;\n}\n.ag-rtl .ag-column-select-indent-29 {\n padding-right: 580px;\n}\n\n.ag-ltr .ag-row-group-indent-29 {\n padding-left: 580px;\n}\n.ag-rtl .ag-row-group-indent-29 {\n padding-right: 580px;\n}\n\n.ag-ltr .ag-column-select-indent-30 {\n padding-left: 600px;\n}\n.ag-rtl .ag-column-select-indent-30 {\n padding-right: 600px;\n}\n\n.ag-ltr .ag-row-group-indent-30 {\n padding-left: 600px;\n}\n.ag-rtl .ag-row-group-indent-30 {\n padding-right: 600px;\n}\n\n.ag-ltr .ag-column-select-indent-31 {\n padding-left: 620px;\n}\n.ag-rtl .ag-column-select-indent-31 {\n padding-right: 620px;\n}\n\n.ag-ltr .ag-row-group-indent-31 {\n padding-left: 620px;\n}\n.ag-rtl .ag-row-group-indent-31 {\n padding-right: 620px;\n}\n\n.ag-ltr .ag-column-select-indent-32 {\n padding-left: 640px;\n}\n.ag-rtl .ag-column-select-indent-32 {\n padding-right: 640px;\n}\n\n.ag-ltr .ag-row-group-indent-32 {\n padding-left: 640px;\n}\n.ag-rtl .ag-row-group-indent-32 {\n padding-right: 640px;\n}\n\n.ag-ltr .ag-column-select-indent-33 {\n padding-left: 660px;\n}\n.ag-rtl .ag-column-select-indent-33 {\n padding-right: 660px;\n}\n\n.ag-ltr .ag-row-group-indent-33 {\n padding-left: 660px;\n}\n.ag-rtl .ag-row-group-indent-33 {\n padding-right: 660px;\n}\n\n.ag-ltr .ag-column-select-indent-34 {\n padding-left: 680px;\n}\n.ag-rtl .ag-column-select-indent-34 {\n padding-right: 680px;\n}\n\n.ag-ltr .ag-row-group-indent-34 {\n padding-left: 680px;\n}\n.ag-rtl .ag-row-group-indent-34 {\n padding-right: 680px;\n}\n\n.ag-ltr .ag-column-select-indent-35 {\n padding-left: 700px;\n}\n.ag-rtl .ag-column-select-indent-35 {\n padding-right: 700px;\n}\n\n.ag-ltr .ag-row-group-indent-35 {\n padding-left: 700px;\n}\n.ag-rtl .ag-row-group-indent-35 {\n padding-right: 700px;\n}\n\n.ag-ltr .ag-column-select-indent-36 {\n padding-left: 720px;\n}\n.ag-rtl .ag-column-select-indent-36 {\n padding-right: 720px;\n}\n\n.ag-ltr .ag-row-group-indent-36 {\n padding-left: 720px;\n}\n.ag-rtl .ag-row-group-indent-36 {\n padding-right: 720px;\n}\n\n.ag-ltr .ag-column-select-indent-37 {\n padding-left: 740px;\n}\n.ag-rtl .ag-column-select-indent-37 {\n padding-right: 740px;\n}\n\n.ag-ltr .ag-row-group-indent-37 {\n padding-left: 740px;\n}\n.ag-rtl .ag-row-group-indent-37 {\n padding-right: 740px;\n}\n\n.ag-ltr .ag-column-select-indent-38 {\n padding-left: 760px;\n}\n.ag-rtl .ag-column-select-indent-38 {\n padding-right: 760px;\n}\n\n.ag-ltr .ag-row-group-indent-38 {\n padding-left: 760px;\n}\n.ag-rtl .ag-row-group-indent-38 {\n padding-right: 760px;\n}\n\n.ag-ltr .ag-column-select-indent-39 {\n padding-left: 780px;\n}\n.ag-rtl .ag-column-select-indent-39 {\n padding-right: 780px;\n}\n\n.ag-ltr .ag-row-group-indent-39 {\n padding-left: 780px;\n}\n.ag-rtl .ag-row-group-indent-39 {\n padding-right: 780px;\n}\n\n.ag-ltr .ag-column-select-indent-40 {\n padding-left: 800px;\n}\n.ag-rtl .ag-column-select-indent-40 {\n padding-right: 800px;\n}\n\n.ag-ltr .ag-row-group-indent-40 {\n padding-left: 800px;\n}\n.ag-rtl .ag-row-group-indent-40 {\n padding-right: 800px;\n}\n\n.ag-ltr .ag-column-select-indent-41 {\n padding-left: 820px;\n}\n.ag-rtl .ag-column-select-indent-41 {\n padding-right: 820px;\n}\n\n.ag-ltr .ag-row-group-indent-41 {\n padding-left: 820px;\n}\n.ag-rtl .ag-row-group-indent-41 {\n padding-right: 820px;\n}\n\n.ag-ltr .ag-column-select-indent-42 {\n padding-left: 840px;\n}\n.ag-rtl .ag-column-select-indent-42 {\n padding-right: 840px;\n}\n\n.ag-ltr .ag-row-group-indent-42 {\n padding-left: 840px;\n}\n.ag-rtl .ag-row-group-indent-42 {\n padding-right: 840px;\n}\n\n.ag-ltr .ag-column-select-indent-43 {\n padding-left: 860px;\n}\n.ag-rtl .ag-column-select-indent-43 {\n padding-right: 860px;\n}\n\n.ag-ltr .ag-row-group-indent-43 {\n padding-left: 860px;\n}\n.ag-rtl .ag-row-group-indent-43 {\n padding-right: 860px;\n}\n\n.ag-ltr .ag-column-select-indent-44 {\n padding-left: 880px;\n}\n.ag-rtl .ag-column-select-indent-44 {\n padding-right: 880px;\n}\n\n.ag-ltr .ag-row-group-indent-44 {\n padding-left: 880px;\n}\n.ag-rtl .ag-row-group-indent-44 {\n padding-right: 880px;\n}\n\n.ag-ltr .ag-column-select-indent-45 {\n padding-left: 900px;\n}\n.ag-rtl .ag-column-select-indent-45 {\n padding-right: 900px;\n}\n\n.ag-ltr .ag-row-group-indent-45 {\n padding-left: 900px;\n}\n.ag-rtl .ag-row-group-indent-45 {\n padding-right: 900px;\n}\n\n.ag-ltr .ag-column-select-indent-46 {\n padding-left: 920px;\n}\n.ag-rtl .ag-column-select-indent-46 {\n padding-right: 920px;\n}\n\n.ag-ltr .ag-row-group-indent-46 {\n padding-left: 920px;\n}\n.ag-rtl .ag-row-group-indent-46 {\n padding-right: 920px;\n}\n\n.ag-ltr .ag-column-select-indent-47 {\n padding-left: 940px;\n}\n.ag-rtl .ag-column-select-indent-47 {\n padding-right: 940px;\n}\n\n.ag-ltr .ag-row-group-indent-47 {\n padding-left: 940px;\n}\n.ag-rtl .ag-row-group-indent-47 {\n padding-right: 940px;\n}\n\n.ag-ltr .ag-column-select-indent-48 {\n padding-left: 960px;\n}\n.ag-rtl .ag-column-select-indent-48 {\n padding-right: 960px;\n}\n\n.ag-ltr .ag-row-group-indent-48 {\n padding-left: 960px;\n}\n.ag-rtl .ag-row-group-indent-48 {\n padding-right: 960px;\n}\n\n.ag-ltr .ag-column-select-indent-49 {\n padding-left: 980px;\n}\n.ag-rtl .ag-column-select-indent-49 {\n padding-right: 980px;\n}\n\n.ag-ltr .ag-row-group-indent-49 {\n padding-left: 980px;\n}\n.ag-rtl .ag-row-group-indent-49 {\n padding-right: 980px;\n}\n\n.ag-ltr .ag-column-select-indent-50 {\n padding-left: 1000px;\n}\n.ag-rtl .ag-column-select-indent-50 {\n padding-right: 1000px;\n}\n\n.ag-ltr .ag-row-group-indent-50 {\n padding-left: 1000px;\n}\n.ag-rtl .ag-row-group-indent-50 {\n padding-right: 1000px;\n}\n\n.ag-ltr .ag-column-select-indent-51 {\n padding-left: 1020px;\n}\n.ag-rtl .ag-column-select-indent-51 {\n padding-right: 1020px;\n}\n\n.ag-ltr .ag-row-group-indent-51 {\n padding-left: 1020px;\n}\n.ag-rtl .ag-row-group-indent-51 {\n padding-right: 1020px;\n}\n\n.ag-ltr .ag-column-select-indent-52 {\n padding-left: 1040px;\n}\n.ag-rtl .ag-column-select-indent-52 {\n padding-right: 1040px;\n}\n\n.ag-ltr .ag-row-group-indent-52 {\n padding-left: 1040px;\n}\n.ag-rtl .ag-row-group-indent-52 {\n padding-right: 1040px;\n}\n\n.ag-ltr .ag-column-select-indent-53 {\n padding-left: 1060px;\n}\n.ag-rtl .ag-column-select-indent-53 {\n padding-right: 1060px;\n}\n\n.ag-ltr .ag-row-group-indent-53 {\n padding-left: 1060px;\n}\n.ag-rtl .ag-row-group-indent-53 {\n padding-right: 1060px;\n}\n\n.ag-ltr .ag-column-select-indent-54 {\n padding-left: 1080px;\n}\n.ag-rtl .ag-column-select-indent-54 {\n padding-right: 1080px;\n}\n\n.ag-ltr .ag-row-group-indent-54 {\n padding-left: 1080px;\n}\n.ag-rtl .ag-row-group-indent-54 {\n padding-right: 1080px;\n}\n\n.ag-ltr .ag-column-select-indent-55 {\n padding-left: 1100px;\n}\n.ag-rtl .ag-column-select-indent-55 {\n padding-right: 1100px;\n}\n\n.ag-ltr .ag-row-group-indent-55 {\n padding-left: 1100px;\n}\n.ag-rtl .ag-row-group-indent-55 {\n padding-right: 1100px;\n}\n\n.ag-ltr .ag-column-select-indent-56 {\n padding-left: 1120px;\n}\n.ag-rtl .ag-column-select-indent-56 {\n padding-right: 1120px;\n}\n\n.ag-ltr .ag-row-group-indent-56 {\n padding-left: 1120px;\n}\n.ag-rtl .ag-row-group-indent-56 {\n padding-right: 1120px;\n}\n\n.ag-ltr .ag-column-select-indent-57 {\n padding-left: 1140px;\n}\n.ag-rtl .ag-column-select-indent-57 {\n padding-right: 1140px;\n}\n\n.ag-ltr .ag-row-group-indent-57 {\n padding-left: 1140px;\n}\n.ag-rtl .ag-row-group-indent-57 {\n padding-right: 1140px;\n}\n\n.ag-ltr .ag-column-select-indent-58 {\n padding-left: 1160px;\n}\n.ag-rtl .ag-column-select-indent-58 {\n padding-right: 1160px;\n}\n\n.ag-ltr .ag-row-group-indent-58 {\n padding-left: 1160px;\n}\n.ag-rtl .ag-row-group-indent-58 {\n padding-right: 1160px;\n}\n\n.ag-ltr .ag-column-select-indent-59 {\n padding-left: 1180px;\n}\n.ag-rtl .ag-column-select-indent-59 {\n padding-right: 1180px;\n}\n\n.ag-ltr .ag-row-group-indent-59 {\n padding-left: 1180px;\n}\n.ag-rtl .ag-row-group-indent-59 {\n padding-right: 1180px;\n}\n\n.ag-ltr .ag-column-select-indent-60 {\n padding-left: 1200px;\n}\n.ag-rtl .ag-column-select-indent-60 {\n padding-right: 1200px;\n}\n\n.ag-ltr .ag-row-group-indent-60 {\n padding-left: 1200px;\n}\n.ag-rtl .ag-row-group-indent-60 {\n padding-right: 1200px;\n}\n\n.ag-ltr .ag-column-select-indent-61 {\n padding-left: 1220px;\n}\n.ag-rtl .ag-column-select-indent-61 {\n padding-right: 1220px;\n}\n\n.ag-ltr .ag-row-group-indent-61 {\n padding-left: 1220px;\n}\n.ag-rtl .ag-row-group-indent-61 {\n padding-right: 1220px;\n}\n\n.ag-ltr .ag-column-select-indent-62 {\n padding-left: 1240px;\n}\n.ag-rtl .ag-column-select-indent-62 {\n padding-right: 1240px;\n}\n\n.ag-ltr .ag-row-group-indent-62 {\n padding-left: 1240px;\n}\n.ag-rtl .ag-row-group-indent-62 {\n padding-right: 1240px;\n}\n\n.ag-ltr .ag-column-select-indent-63 {\n padding-left: 1260px;\n}\n.ag-rtl .ag-column-select-indent-63 {\n padding-right: 1260px;\n}\n\n.ag-ltr .ag-row-group-indent-63 {\n padding-left: 1260px;\n}\n.ag-rtl .ag-row-group-indent-63 {\n padding-right: 1260px;\n}\n\n.ag-ltr .ag-column-select-indent-64 {\n padding-left: 1280px;\n}\n.ag-rtl .ag-column-select-indent-64 {\n padding-right: 1280px;\n}\n\n.ag-ltr .ag-row-group-indent-64 {\n padding-left: 1280px;\n}\n.ag-rtl .ag-row-group-indent-64 {\n padding-right: 1280px;\n}\n\n.ag-ltr .ag-column-select-indent-65 {\n padding-left: 1300px;\n}\n.ag-rtl .ag-column-select-indent-65 {\n padding-right: 1300px;\n}\n\n.ag-ltr .ag-row-group-indent-65 {\n padding-left: 1300px;\n}\n.ag-rtl .ag-row-group-indent-65 {\n padding-right: 1300px;\n}\n\n.ag-ltr .ag-column-select-indent-66 {\n padding-left: 1320px;\n}\n.ag-rtl .ag-column-select-indent-66 {\n padding-right: 1320px;\n}\n\n.ag-ltr .ag-row-group-indent-66 {\n padding-left: 1320px;\n}\n.ag-rtl .ag-row-group-indent-66 {\n padding-right: 1320px;\n}\n\n.ag-ltr .ag-column-select-indent-67 {\n padding-left: 1340px;\n}\n.ag-rtl .ag-column-select-indent-67 {\n padding-right: 1340px;\n}\n\n.ag-ltr .ag-row-group-indent-67 {\n padding-left: 1340px;\n}\n.ag-rtl .ag-row-group-indent-67 {\n padding-right: 1340px;\n}\n\n.ag-ltr .ag-column-select-indent-68 {\n padding-left: 1360px;\n}\n.ag-rtl .ag-column-select-indent-68 {\n padding-right: 1360px;\n}\n\n.ag-ltr .ag-row-group-indent-68 {\n padding-left: 1360px;\n}\n.ag-rtl .ag-row-group-indent-68 {\n padding-right: 1360px;\n}\n\n.ag-ltr .ag-column-select-indent-69 {\n padding-left: 1380px;\n}\n.ag-rtl .ag-column-select-indent-69 {\n padding-right: 1380px;\n}\n\n.ag-ltr .ag-row-group-indent-69 {\n padding-left: 1380px;\n}\n.ag-rtl .ag-row-group-indent-69 {\n padding-right: 1380px;\n}\n\n.ag-ltr .ag-column-select-indent-70 {\n padding-left: 1400px;\n}\n.ag-rtl .ag-column-select-indent-70 {\n padding-right: 1400px;\n}\n\n.ag-ltr .ag-row-group-indent-70 {\n padding-left: 1400px;\n}\n.ag-rtl .ag-row-group-indent-70 {\n padding-right: 1400px;\n}\n\n.ag-ltr .ag-column-select-indent-71 {\n padding-left: 1420px;\n}\n.ag-rtl .ag-column-select-indent-71 {\n padding-right: 1420px;\n}\n\n.ag-ltr .ag-row-group-indent-71 {\n padding-left: 1420px;\n}\n.ag-rtl .ag-row-group-indent-71 {\n padding-right: 1420px;\n}\n\n.ag-ltr .ag-column-select-indent-72 {\n padding-left: 1440px;\n}\n.ag-rtl .ag-column-select-indent-72 {\n padding-right: 1440px;\n}\n\n.ag-ltr .ag-row-group-indent-72 {\n padding-left: 1440px;\n}\n.ag-rtl .ag-row-group-indent-72 {\n padding-right: 1440px;\n}\n\n.ag-ltr .ag-column-select-indent-73 {\n padding-left: 1460px;\n}\n.ag-rtl .ag-column-select-indent-73 {\n padding-right: 1460px;\n}\n\n.ag-ltr .ag-row-group-indent-73 {\n padding-left: 1460px;\n}\n.ag-rtl .ag-row-group-indent-73 {\n padding-right: 1460px;\n}\n\n.ag-ltr .ag-column-select-indent-74 {\n padding-left: 1480px;\n}\n.ag-rtl .ag-column-select-indent-74 {\n padding-right: 1480px;\n}\n\n.ag-ltr .ag-row-group-indent-74 {\n padding-left: 1480px;\n}\n.ag-rtl .ag-row-group-indent-74 {\n padding-right: 1480px;\n}\n\n.ag-ltr .ag-column-select-indent-75 {\n padding-left: 1500px;\n}\n.ag-rtl .ag-column-select-indent-75 {\n padding-right: 1500px;\n}\n\n.ag-ltr .ag-row-group-indent-75 {\n padding-left: 1500px;\n}\n.ag-rtl .ag-row-group-indent-75 {\n padding-right: 1500px;\n}\n\n.ag-ltr .ag-column-select-indent-76 {\n padding-left: 1520px;\n}\n.ag-rtl .ag-column-select-indent-76 {\n padding-right: 1520px;\n}\n\n.ag-ltr .ag-row-group-indent-76 {\n padding-left: 1520px;\n}\n.ag-rtl .ag-row-group-indent-76 {\n padding-right: 1520px;\n}\n\n.ag-ltr .ag-column-select-indent-77 {\n padding-left: 1540px;\n}\n.ag-rtl .ag-column-select-indent-77 {\n padding-right: 1540px;\n}\n\n.ag-ltr .ag-row-group-indent-77 {\n padding-left: 1540px;\n}\n.ag-rtl .ag-row-group-indent-77 {\n padding-right: 1540px;\n}\n\n.ag-ltr .ag-column-select-indent-78 {\n padding-left: 1560px;\n}\n.ag-rtl .ag-column-select-indent-78 {\n padding-right: 1560px;\n}\n\n.ag-ltr .ag-row-group-indent-78 {\n padding-left: 1560px;\n}\n.ag-rtl .ag-row-group-indent-78 {\n padding-right: 1560px;\n}\n\n.ag-ltr .ag-column-select-indent-79 {\n padding-left: 1580px;\n}\n.ag-rtl .ag-column-select-indent-79 {\n padding-right: 1580px;\n}\n\n.ag-ltr .ag-row-group-indent-79 {\n padding-left: 1580px;\n}\n.ag-rtl .ag-row-group-indent-79 {\n padding-right: 1580px;\n}\n\n.ag-ltr .ag-column-select-indent-80 {\n padding-left: 1600px;\n}\n.ag-rtl .ag-column-select-indent-80 {\n padding-right: 1600px;\n}\n\n.ag-ltr .ag-row-group-indent-80 {\n padding-left: 1600px;\n}\n.ag-rtl .ag-row-group-indent-80 {\n padding-right: 1600px;\n}\n\n.ag-ltr .ag-column-select-indent-81 {\n padding-left: 1620px;\n}\n.ag-rtl .ag-column-select-indent-81 {\n padding-right: 1620px;\n}\n\n.ag-ltr .ag-row-group-indent-81 {\n padding-left: 1620px;\n}\n.ag-rtl .ag-row-group-indent-81 {\n padding-right: 1620px;\n}\n\n.ag-ltr .ag-column-select-indent-82 {\n padding-left: 1640px;\n}\n.ag-rtl .ag-column-select-indent-82 {\n padding-right: 1640px;\n}\n\n.ag-ltr .ag-row-group-indent-82 {\n padding-left: 1640px;\n}\n.ag-rtl .ag-row-group-indent-82 {\n padding-right: 1640px;\n}\n\n.ag-ltr .ag-column-select-indent-83 {\n padding-left: 1660px;\n}\n.ag-rtl .ag-column-select-indent-83 {\n padding-right: 1660px;\n}\n\n.ag-ltr .ag-row-group-indent-83 {\n padding-left: 1660px;\n}\n.ag-rtl .ag-row-group-indent-83 {\n padding-right: 1660px;\n}\n\n.ag-ltr .ag-column-select-indent-84 {\n padding-left: 1680px;\n}\n.ag-rtl .ag-column-select-indent-84 {\n padding-right: 1680px;\n}\n\n.ag-ltr .ag-row-group-indent-84 {\n padding-left: 1680px;\n}\n.ag-rtl .ag-row-group-indent-84 {\n padding-right: 1680px;\n}\n\n.ag-ltr .ag-column-select-indent-85 {\n padding-left: 1700px;\n}\n.ag-rtl .ag-column-select-indent-85 {\n padding-right: 1700px;\n}\n\n.ag-ltr .ag-row-group-indent-85 {\n padding-left: 1700px;\n}\n.ag-rtl .ag-row-group-indent-85 {\n padding-right: 1700px;\n}\n\n.ag-ltr .ag-column-select-indent-86 {\n padding-left: 1720px;\n}\n.ag-rtl .ag-column-select-indent-86 {\n padding-right: 1720px;\n}\n\n.ag-ltr .ag-row-group-indent-86 {\n padding-left: 1720px;\n}\n.ag-rtl .ag-row-group-indent-86 {\n padding-right: 1720px;\n}\n\n.ag-ltr .ag-column-select-indent-87 {\n padding-left: 1740px;\n}\n.ag-rtl .ag-column-select-indent-87 {\n padding-right: 1740px;\n}\n\n.ag-ltr .ag-row-group-indent-87 {\n padding-left: 1740px;\n}\n.ag-rtl .ag-row-group-indent-87 {\n padding-right: 1740px;\n}\n\n.ag-ltr .ag-column-select-indent-88 {\n padding-left: 1760px;\n}\n.ag-rtl .ag-column-select-indent-88 {\n padding-right: 1760px;\n}\n\n.ag-ltr .ag-row-group-indent-88 {\n padding-left: 1760px;\n}\n.ag-rtl .ag-row-group-indent-88 {\n padding-right: 1760px;\n}\n\n.ag-ltr .ag-column-select-indent-89 {\n padding-left: 1780px;\n}\n.ag-rtl .ag-column-select-indent-89 {\n padding-right: 1780px;\n}\n\n.ag-ltr .ag-row-group-indent-89 {\n padding-left: 1780px;\n}\n.ag-rtl .ag-row-group-indent-89 {\n padding-right: 1780px;\n}\n\n.ag-ltr .ag-column-select-indent-90 {\n padding-left: 1800px;\n}\n.ag-rtl .ag-column-select-indent-90 {\n padding-right: 1800px;\n}\n\n.ag-ltr .ag-row-group-indent-90 {\n padding-left: 1800px;\n}\n.ag-rtl .ag-row-group-indent-90 {\n padding-right: 1800px;\n}\n\n.ag-ltr .ag-column-select-indent-91 {\n padding-left: 1820px;\n}\n.ag-rtl .ag-column-select-indent-91 {\n padding-right: 1820px;\n}\n\n.ag-ltr .ag-row-group-indent-91 {\n padding-left: 1820px;\n}\n.ag-rtl .ag-row-group-indent-91 {\n padding-right: 1820px;\n}\n\n.ag-ltr .ag-column-select-indent-92 {\n padding-left: 1840px;\n}\n.ag-rtl .ag-column-select-indent-92 {\n padding-right: 1840px;\n}\n\n.ag-ltr .ag-row-group-indent-92 {\n padding-left: 1840px;\n}\n.ag-rtl .ag-row-group-indent-92 {\n padding-right: 1840px;\n}\n\n.ag-ltr .ag-column-select-indent-93 {\n padding-left: 1860px;\n}\n.ag-rtl .ag-column-select-indent-93 {\n padding-right: 1860px;\n}\n\n.ag-ltr .ag-row-group-indent-93 {\n padding-left: 1860px;\n}\n.ag-rtl .ag-row-group-indent-93 {\n padding-right: 1860px;\n}\n\n.ag-ltr .ag-column-select-indent-94 {\n padding-left: 1880px;\n}\n.ag-rtl .ag-column-select-indent-94 {\n padding-right: 1880px;\n}\n\n.ag-ltr .ag-row-group-indent-94 {\n padding-left: 1880px;\n}\n.ag-rtl .ag-row-group-indent-94 {\n padding-right: 1880px;\n}\n\n.ag-ltr .ag-column-select-indent-95 {\n padding-left: 1900px;\n}\n.ag-rtl .ag-column-select-indent-95 {\n padding-right: 1900px;\n}\n\n.ag-ltr .ag-row-group-indent-95 {\n padding-left: 1900px;\n}\n.ag-rtl .ag-row-group-indent-95 {\n padding-right: 1900px;\n}\n\n.ag-ltr .ag-column-select-indent-96 {\n padding-left: 1920px;\n}\n.ag-rtl .ag-column-select-indent-96 {\n padding-right: 1920px;\n}\n\n.ag-ltr .ag-row-group-indent-96 {\n padding-left: 1920px;\n}\n.ag-rtl .ag-row-group-indent-96 {\n padding-right: 1920px;\n}\n\n.ag-ltr .ag-column-select-indent-97 {\n padding-left: 1940px;\n}\n.ag-rtl .ag-column-select-indent-97 {\n padding-right: 1940px;\n}\n\n.ag-ltr .ag-row-group-indent-97 {\n padding-left: 1940px;\n}\n.ag-rtl .ag-row-group-indent-97 {\n padding-right: 1940px;\n}\n\n.ag-ltr .ag-column-select-indent-98 {\n padding-left: 1960px;\n}\n.ag-rtl .ag-column-select-indent-98 {\n padding-right: 1960px;\n}\n\n.ag-ltr .ag-row-group-indent-98 {\n padding-left: 1960px;\n}\n.ag-rtl .ag-row-group-indent-98 {\n padding-right: 1960px;\n}\n\n.ag-ltr .ag-column-select-indent-99 {\n padding-left: 1980px;\n}\n.ag-rtl .ag-column-select-indent-99 {\n padding-right: 1980px;\n}\n\n.ag-ltr .ag-row-group-indent-99 {\n padding-left: 1980px;\n}\n.ag-rtl .ag-row-group-indent-99 {\n padding-right: 1980px;\n}\n\n.ag-ltr {\n direction: ltr;\n}\n.ag-ltr .ag-body, .ag-ltr .ag-floating-top, .ag-ltr .ag-floating-bottom, .ag-ltr .ag-header, .ag-ltr .ag-body-viewport, .ag-ltr .ag-body-horizontal-scroll {\n -webkit-box-orient: horizontal;\n -webkit-box-direction: normal;\n flex-direction: row;\n}\n\n.ag-rtl {\n direction: rtl;\n}\n.ag-rtl .ag-body, .ag-rtl .ag-floating-top, .ag-rtl .ag-floating-bottom, .ag-rtl .ag-header, .ag-rtl .ag-body-viewport, .ag-rtl .ag-body-horizontal-scroll {\n -webkit-box-orient: horizontal;\n -webkit-box-direction: reverse;\n flex-direction: row-reverse;\n}\n.ag-rtl .ag-icon-contracted,\n.ag-rtl .ag-icon-tree-closed {\n display: block;\n -webkit-transform: rotate(180deg);\n transform: rotate(180deg);\n}\n\n.ag-layout-print.ag-body-viewport {\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-layout-print.ag-root-wrapper {\n display: -webkit-inline-box;\n display: inline-flex;\n}\n.ag-layout-print .ag-center-cols-clipper {\n min-width: 100%;\n}\n.ag-layout-print .ag-body-horizontal-scroll {\n display: none;\n}\n.ag-layout-print.ag-force-vertical-scroll {\n overflow-y: visible !important;\n}\n\n@media print {\n .ag-root-wrapper.ag-layout-print,\n.ag-root-wrapper.ag-layout-print .ag-root-wrapper-body,\n.ag-root-wrapper.ag-layout-print .ag-root,\n.ag-root-wrapper.ag-layout-print .ag-body-viewport,\n.ag-root-wrapper.ag-layout-print .ag-center-cols-container,\n.ag-root-wrapper.ag-layout-print .ag-center-cols-viewport,\n.ag-root-wrapper.ag-layout-print .ag-center-cols-clipper,\n.ag-root-wrapper.ag-layout-print .ag-body-horizontal-scroll-viewport,\n.ag-root-wrapper.ag-layout-print .ag-virtual-list-viewport {\n height: auto !important;\n overflow: hidden !important;\n display: block !important;\n }\n .ag-root-wrapper.ag-layout-print .ag-row {\n page-break-inside: avoid;\n }\n}\n.ag-body .ag-body-viewport {\n -webkit-overflow-scrolling: touch;\n}\n\n.ag-chart {\n position: relative;\n display: -webkit-box;\n display: flex;\n overflow: hidden;\n width: 100%;\n height: 100%;\n}\n\n.ag-chart-components-wrapper {\n position: relative;\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n overflow: hidden;\n}\n\n.ag-chart-title-edit {\n position: absolute;\n display: none;\n top: 0;\n left: 0;\n text-align: center;\n}\n\n.ag-chart-title-edit.currently-editing {\n display: inline-block;\n}\n\n.ag-chart-canvas-wrapper {\n position: relative;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n overflow: hidden;\n}\n\n.ag-charts-canvas {\n display: block;\n}\n\n.ag-chart-menu {\n position: absolute;\n top: 10px;\n width: 24px;\n overflow: hidden;\n display: -webkit-box;\n display: flex;\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n flex-direction: column;\n}\n.ag-ltr .ag-chart-menu {\n right: 20px;\n}\n.ag-rtl .ag-chart-menu {\n left: 20px;\n}\n\n.ag-chart-docked-container {\n position: relative;\n width: 0;\n min-width: 0;\n -webkit-transition: min-width 0.4s;\n transition: min-width 0.4s;\n}\n\n.ag-chart-menu-hidden ~ .ag-chart-docked-container {\n max-width: 0;\n overflow: hidden;\n}\n\n.ag-chart-tabbed-menu {\n width: 100%;\n height: 100%;\n display: -webkit-box;\n display: flex;\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n flex-direction: column;\n overflow: hidden;\n}\n\n.ag-chart-tabbed-menu-header {\n -webkit-box-flex: 0;\n flex: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n cursor: default;\n}\n\n.ag-chart-tabbed-menu-body {\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n -webkit-box-align: stretch;\n align-items: stretch;\n overflow: hidden;\n}\n\n.ag-chart-tab {\n width: 100%;\n overflow: hidden;\n overflow-y: auto;\n}\n\n.ag-chart-settings {\n overflow-x: hidden;\n}\n\n.ag-chart-settings-wrapper {\n position: relative;\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n flex-direction: column;\n width: 100%;\n height: 100%;\n display: -webkit-box;\n display: flex;\n overflow: hidden;\n}\n\n.ag-chart-settings-nav-bar {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n width: 100%;\n height: 30px;\n padding: 0 10px;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n}\n\n.ag-chart-settings-card-selector {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n justify-content: space-around;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n height: 100%;\n padding: 0 10px;\n}\n\n.ag-chart-settings-card-item {\n cursor: pointer;\n width: 10px;\n height: 10px;\n background-color: #000;\n position: relative;\n}\n.ag-chart-settings-card-item.ag-not-selected {\n opacity: 0.2;\n}\n.ag-chart-settings-card-item::before {\n content: \" \";\n display: block;\n position: absolute;\n background-color: transparent;\n left: 50%;\n top: 50%;\n margin-left: -10px;\n margin-top: -10px;\n width: 20px;\n height: 20px;\n}\n\n.ag-chart-settings-prev,\n.ag-chart-settings-next {\n position: relative;\n -webkit-box-flex: 0;\n flex: none;\n}\n\n.ag-chart-settings-prev-button,\n.ag-chart-settings-next-button {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n cursor: pointer;\n opacity: 0;\n}\n\n.ag-chart-settings-mini-charts-container {\n position: relative;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n overflow-x: hidden;\n overflow-y: auto;\n}\n\n.ag-chart-settings-mini-wrapper {\n position: absolute;\n top: 0;\n left: 0;\n display: -webkit-box;\n display: flex;\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n flex-direction: column;\n width: 100%;\n min-height: 100%;\n overflow: hidden;\n}\n.ag-chart-settings-mini-wrapper.ag-animating {\n -webkit-transition: left 0.3s;\n transition: left 0.3s;\n -webkit-transition-timing-function: ease-in-out;\n transition-timing-function: ease-in-out;\n}\n\n.ag-chart-mini-thumbnail {\n cursor: pointer;\n}\n\n.ag-chart-mini-thumbnail-canvas {\n display: block;\n}\n\n.ag-chart-data-wrapper,\n.ag-chart-format-wrapper {\n display: -webkit-box;\n display: flex;\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n flex-direction: column;\n position: relative;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n}\n\n.ag-chart-data-wrapper {\n height: 100%;\n overflow-y: auto;\n}\n\n.ag-chart-data-section,\n.ag-chart-format-section {\n display: -webkit-box;\n display: flex;\n margin: 0;\n}\n\n.ag-chart-empty-text {\n display: -webkit-box;\n display: flex;\n top: 0;\n width: 100%;\n height: 100%;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-pack: center;\n justify-content: center;\n}\n\n.ag-chart .ag-chart-menu {\n opacity: 0;\n pointer-events: none;\n}\n\n.ag-chart-menu-hidden:hover .ag-chart-menu {\n opacity: 1;\n pointer-events: all;\n}\n\n.ag-charts-font-size-color {\n display: -webkit-box;\n display: flex;\n align-self: stretch;\n -webkit-box-pack: justify;\n justify-content: space-between;\n}\n\n.ag-charts-data-group-item {\n position: relative;\n}\n\n.ag-date-time-list-page-title-bar {\n display: -webkit-box;\n display: flex;\n}\n\n.ag-date-time-list-page-column-labels-row,\n.ag-date-time-list-page-entries-row {\n display: -webkit-box;\n display: flex;\n}\n\n.ag-date-time-list-page-column-label,\n.ag-date-time-list-page-entry {\n flex-basis: 0;\n -webkit-box-flex: 1;\n flex-grow: 1;\n}\n\n.ag-date-time-list-page-entry {\n cursor: pointer;\n}\n", ""]); // Exports module.exports = exports; /***/ }), -/* 227 */ +/* 280 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; @@ -48478,11 +57423,11 @@ function toComment(sourceMap) { } /***/ }), -/* 228 */ +/* 281 */ /***/ (function(module, exports, __webpack_require__) { -var api = __webpack_require__(225); - var content = __webpack_require__(229); +var api = __webpack_require__(278); + var content = __webpack_require__(282); content = content.__esModule ? content.default : content; @@ -48502,24 +57447,24 @@ var update = api(content, options); module.exports = content.locals || {}; /***/ }), -/* 229 */ +/* 282 */ /***/ (function(module, exports, __webpack_require__) { // Imports -var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227); +var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(280); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, ".ag-theme-alpine-dark {\n -webkit-font-smoothing: antialiased;\n color: #fff;\n color: var(--ag-foreground-color, #fff);\n font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n font-size: 13px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridAlpine\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABNkAAsAAAAAIqAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlMAAAReYc5joU9TLzIAAANcAAAAQAAAAFZWUVJ5Y21hcAAAA5wAAAHqAAAFgHCsDfxnbHlmAAAFiAAACesAABCUC9Ir6mhlYWQAAA90AAAANAAAADZ2zsSBaGhlYQAAD6gAAAAeAAAAJAfSBC5obXR4AAAPyAAAABcAAAEou4D/+2xvY2EAAA/gAAAAbwAAAJbPsst2bWF4cAAAEFAAAAAfAAAAIAFgAHNuYW1lAAAQcAAAATUAAAJG5xgJvXBvc3QAABGoAAABuQAAApPSPvKNeJx9k81SE1EQhc9kQgwJBkREjREU//GPYX4yJiGQMAFisXDhwoUbXGhpUa54Atc+gOUD+BQ+geXSlQ/gA1g+gN/tTAyyIFOZubf79Onuc/vKk1TRmroqZDv7z1U7PDh6r7qKGv2c//jaO3z75kDl8Q5f0b5lef4f1bSiFzrSN0/ea+9zoeQX/K6/73/wP/k/5IO6pkegq1rnCRXxDhQrUVOpCiphC1k/UQu0z7tt1nktaso8mQa6QM6QmIExruqpbmkOnr7x9LQJKuZxnD3euzy3NXsKItUd+BOq2cDqWBvUeU7T2qHGHnV0iG7hncO3ReaAmD6+PrX5hiqajnt6SeS89eYikxwX8w+1bfvAdkuoMEa14W/C7/gek3Vsb5IpIuIh7Amobq7hKv8q3hhMQGzHNHPRSyAjKoy1zMp1FtHZjG7C/kyvdJ+47TymZyqOer5H9RN73/hS8hy3duDaBfuAGiZWdyJ3yRVoiL/CSWV6p4/6oq/6rp/6pd/gF8kSWQebcG+dqsw0+p1EZ3jb/6yu0zOcxUnU/4gKfTdNmxDfIFfQZZvB57SJWQdYY8NX4XT4jGpS9Jpi8gLLG2Etsd9gH4Ku5dPY4jlrOg+YATcBdbRY5+2YRvOWsr9MtFuN6rpoarXguWSn5TR1N2nWdm7m3SnX0fkK34DOEtNnD+9VLI5pYmlYVErVjmMNf0q1k2yuqgZVRcxA2SZraLcgI9N1+hhVEumG3YChTdUKFST5jVzQeau+k5/UguFCi/JQIshvcmyauUnuU5ubit2/LKNqzAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMb0GmMDCC5ADUogpqeJy11IdSWkEYxfE/RdNM79X0jgJiQIogIMhjmO6Y4pju5CnzJt8LxJzlnjyAmcnO/Fh2udy9O3fPB8wABXkqRcgXyZHab83mpvMFjk7ni/zSeI7D5PW9xBY77EV5f1+zJTbZZjdy09HfltPVc1zjPs80WqNClxZ9aoyp0tHsKm0GNKizzhJNlhkyYYUeIzb0/7xWLzLLIa16RM9xTPc7zglOcorTnOEs5zjPBS5yictc4apWu84N5rnJLW5zh7vc0/oPeMgjHvNE+ynp9wUWKesBZzlYWzvg9alVuq1+bVztaLftQaOujTaXh5OV3mjjH272H9pc+ij89GhCepuZtNtNq8hz68oLa8lL68srq8lrG8sbq8pb68iWpROybavyztry3gbywRry0eqyY+uya0vyyZry2Zbliw3lq6W9f7MV+W49+WEj2TO9wMhlUlYinyH1hUzKVhQzKV8xk9GZJkynmzCdc8J04glLGQxTCghLby9MySBMGSFMaSFMuSFMCSJMWSJMqSJM+SJMSSNMmSNM6SNMOSRMiSRM2SRMKSVMeSVMySVMGSVMaSZMuSZMCSdMWSdMqSdM+SdMlYAw1QTCVB0IU50gTBWDMNUOwlRFCEt1MyxlJmz6/AsZUr+YIfXlDOU/rrOgigAAeJzFF21sU9f1nntjvzgJSRx/vJgQg/3ivNSxwxL7+dkx2JAEEmhIqWpYCqMhMCbWdFppM7EBbsd+dEVV1apS6A/yY9O2oFVaQEOb+sFKtZaRqh/qVLQf/fixdkxkXbNRodIZ3mXnXttpApnW/Zr93rnn3nt8zrnnni8TIPihcyxKqgmBgEdVPAEjYOoBOsdrCgW4yu9HeJxFs4VCJlMoCHLbzes3r7NP2afEhr+qIx7SRIhLURXdtJkChhAwVaAuXcBPnn028uqrNIMg8iwfHR4eXidXInKBPrFgMnzv8DD/YiE9qiWEsh7WQypRjmo6Y07VhJPds7nLaX4GrqZnuQ2uz6ZhCx5F0k6wCeImq/CnQcWu2N2qV/V2mQkzEddb9VaXoqOSqBnqBlcPjI6YqZQ5MvpRGRnpPn68e2JCQjaxaEsi1uvlXYTk/yOTle6tFjFF3l3MqekxjyZG+G0+fzafh4P5PFtmvY0XeJAfK+t5mV0mLuITtx2sBY/T7YdYoCsDhjPeAQ4wVVDZD2587o/58WFVcrTm+N+GZmBqiF3G+aLNG5+Dd+gCTN21mL+6NH+GznUb9yetizRyO2fr4oMLeTLJ0xlwhpbiizxZ1S18i4vfvZVv0Xbs++yb6L+VpJEQByiqA5i5Euzi6jxub1fCENdGP+Ej3Xu5BZmZmQunq6t9dd7ODZ3eOh/8Hn6axg3+KqydmcksW+ZvavUFOzuDvtAKv2BfIWVEMa6K91NHSCjgDNg0Z8ylOdPg1Jwsaj1FD/DN8q5eyhdoLM+PiZsq3lbJ7+lp5GFDHSm6DxyEFL+AYcii/AKfKcVj8Tw/ZOfwND7SLC1v92CUBFSJuL1oqATaqVVzoQ70NK/ROnNwNc8NoTK8gVADbsAb7OXOoPUC7b+nU7NeEHu0X+u09tH+Ugw+zZ4WvuYANJfiAB3dBa7Cvb18Cnb08pN8qhd2IKCJRVPYgSTkljgGXUEb6Aqw9TKQYYsIZLjObbMY1IvPHkKBioq2moEk5qGzkIRUduHZn8A4aCIdZK3ga6qJWJcfVoJSCyIp2ZUOuhrMDKg499NYl6nbtWAHGHFTVxNI6VbUhNlBg9C4NjKwfWT75HgzY+6+aDRi7hr7+uT4iooKz9BotM+9fPTowN2b0mGjfVM4UJlsuWdT2D0w1OLbc/RJ+nP87R19h7dWVZu7tI5IIgbQd2hrddWafY7me7rW7zVbuleG+9uN9t1Jd3gg1zKQ3omLC/SvxdwRRf3RpYUyUtdQhpZOQlHh1WDDTfR23ETvpxX9R/f4UPhTR0eXo2r8/IrxyV9J5ZslsqICfhzeFA5v2iYA+My961FkEV7aerhPaFtVGidRp4GwBKWYG0PbK2QZaqR4FKduBGyqxzRMNlZ4qUBPWdPvZ9+jc4XJszBcyGbffy8z+T4p50J6jc7hvTnkbeiKKnISvfbKK+lCgRu5HBjnzqVlbakhNcU4QfpynIjc0URWEo3opJ2sJsTUjJi64A39lznWqbPZ7EsSWm/9p0khX/xkS2OmNKI6lfPnv1UnAlgdQ/i6UI6Br46vWFNwDODIxoSPWm9LViiCnuIziMFv+Aw9IOXyzVmUleXHUIVMJrOEzVzo61iA0WZXpMngYC5Hz0iT8RpyWxxhscYw1ANsfTF0YIsII+qf7eZn+Jnu2XKMTNDzWJ8aSQQlxDOQBkMr+pHEOkDF1BzSPBg6tBbaARHpaz8LrtGmplK7k8ndqakpbU3wORjiv4aDEgdtfhOuamntruTIQyPJu7S0kptCuFGs7D4wkpQ2vXmTzco8fotNA5gTRXG0ic4BlbCJBqQ0F/mSLh8cPHbNvEbbzWsmJpQ3IW4NCrgL5/QT3OFvDg5CvBUxfMy1g4OD4zjic+2PEC/XkOfYc6iFU+bhmAfQKTEZagbogPWSHxsG2sP5h1g07+W8B+gHWTj4oVxjLn7sA7k2n2++9Fe0vzH/LWb08gspvOd8piz/HfZOUf682HlFsvNC0X/KmgilimL/VNZkviZMF/OiSG8qwPfSnKchxaI4dkOy5E+XWL3sz0SmVbG0KaL5oJeuXImcPx+RkPrl8JiE82cr9jEBzKZLdzIQF2isy6tCB0CwVQc/eNyCcKm+hvdEI4Nbdqb2t/NosAW2IALvBlvE4lJtDh/ZuWUwEm0J8mj7fv73liC8274/JdfK+j2Adc6LfqOjfhrmQrui3VLkAl1etz3YGk+AMHDAiLHGU8vWbV237JQsaQMC8g+cPl/Q5wPDej4HP8mxsVBHRwir3z5JcyLY2ag14mM10BMiKRTv8Ag7TIKlKpMoflWzVQxZAMWOhkZTKfY6NLkuegm0eitaBgQFliDVG/MiqsPdz2D2tjmau1ebeyvranwNqhv8nnUb9gNQ5vZE1eN/icAll6Omsn4y0dblhOWVKoVKOlFZVV1X21B/ER55xlFdXVfTVu2oHl3ub2xyNdTyj1Zsq9lnt/mM9q+p1ciBPlVf76r1TtYy1sT/anfrjfGG4xUVoFQ2XBTHqZJnmmbTGImrSBtZTzaSO0mO7CSj5Ft4Rj9VG1gtVSpCHVSnrgw1W2wBpxcrqZmwuVVRmAzpVorucWO90lQ58UrDhNxqzMDaGzPMMKBFYpioPTG9A/SQXVM8MbMVcw1ztm0IA6oU3tDGP+YffzmDZjhkXfjHnBanDqsSaFxbBS9WRbblIo7wxrZxR2TbtkjVupau5X6wXocjhwHy2fidSYBDWfjdIUGP5kiFHz2X7H+U/XJJ/s1ydsN63e5A8rm3nPUoDA5DnWTueLCtv506IjmUAzbF5Q37NyYfeXmz8ei/EqGR7JEjQaRmAEfy8MhtcSkzMp1O8wuQSnP6WVp0a92cLOxn3eSOcoTVC7dZJcxWLyKMBQWUYdYldkrB9fj4gd6+vt4D41Bfxh7/zq4dhmkaO3a9V0bYZbHB/7mY+MaRRUQSKcWT0KUG4z0htJEFoZj49f9Btb6He3sfflyAvq+mJZ0r0SMofGWFb6t9iopFV6TABf8BZT85241/BovnG2Rjsq7KTkbkQPyXG5AdSTEXWh/T09ZWTNYZmJUL/GSWzllvl2UxekLcmssBl6AO6ugJrH5Dpfs+wZjYc9DiKmP8Cr+yeA97V2xtsWTKXy/Ns0hQ2vsFc8l+X/TYJtwPX/Ra5/mfe6BJYH+AlT0luijtFSd04WnOyoLTc9+8faJ0ulgfdOzS6WeyLECKTmOdEC65INePYUXykC6RS0XpB4/Xrqj4pwodAOM5Jnpmz5c9ghFPmCoSqviYQF8rNgFmeG08m9y95xu5Suv5H3UPlDuFns7tKx8aGTgZt/rpa9gOaJEN1Wub9qxJjSSncvDA0cZvr0vJbkHr3GzbnrsPKemLhPwbDwYCEQB4nGNgZGBgAOLsD0FR8fw2Xxm4mV8ABaI4H+9rgNH/f///zfyW+S1QJQcDE5BkAACRug+HeJxjYGRgYH7BwAAi///+/5v5LQMjAyrwAgCe2QcHAAB4nGNgYGBgfgHC/39D6KGH6QEAIHUuCwB4nGNgAAIphiCGDIZFDHcYvjGqMQYwVjGuYTzH+IhJhMmMyYcpgekAMxezBrMDcxfzIeZbzJ9YTFiKWGawbGK5wfKKlY01jHUK6z+2JWw72P6xR7Dnsfexz2Ffxb6D/Rj7LfYX7H84vEiHANyaI6IAeJxjYGRgYPBiSGfgYQABJiDmAkIGhv9gPgMAGzsB1AB4nHWRPU7DQBCFnxMniBghJCREx1Y0SM5PQZEuFHGfIgWdE68dR7bXWm8ipeMYnIBjUHIETsEheDFTREjZ1a6/+fbNNAZwgy94OC4PV+19XB1csPrjLulW2Cc/CPcQ4Em4T/8sPKB9EQ7YWXKC51/S3ONNuINrvAt36T+EffKncA93+Bbu0/8ID7D0fOEAj95rnEU2T2ZFnVd6obNdEdtTdcpLbZvcVGocjk51pCttY6cTtTqoZp9NnEtVak2p5qZyuiiMqq3Z6rULN87V0+EwFR+uTYkYGSJY5EgwQ4GaVEFjwZNhRxPz9VzqnF/yWDSsDGuFMUKMzqYjnqrtiOH4TdixwoF3gz17JrQOKeuUGcO/ojBvJx/TBbehqdu3Lc2aPsSm7aoxxZA7/ZcPmeKkXwK+aWkAAAB4nG2S6W7bMBCE/cWSI9tpk7ptet/3obbpfaf3kT4FQ9EyEYkUSMp28vRl4yBAgO4fzgwWs7MLdpY6ixp0/l9bLNElIaXHMhl9BgxZ4RjHWWWNE4w4ySlOs84ZznKO81zgIpe4zBWuco3r3OAmt7jNHe5yj/s84CE5j3jMEzZ4yjOe84KXvOI1b3jLO97zgY9s8onPfOEr3/jOD37yi99s8aczFGXpVCmCtqYnnLMz3xVe9qQwUlXZ4sk3UjkRLqzJiZI723ae7wNVrB8K2hQqKFdrI4IaHcqtOehckbayLm90JG45krY2fiCtCU7IoIpE2mY3lc56nxTKy0zNGxE9i77aVbmvhJ90I+qNdRXHpGPtfEhKp5u0dLZtktgQkkqNQ6/SJs5brqwotCmzWsx1rfdUUivTZjHfghk1D4mxRg2NDbmoKjtTRdpEF9VttEkbPbUha5yaatv6NRfNbL7dhmBNbsfj1aOCSZ0uJyHxYqoGvo52eWFn5gD+izVcwP22bIFj6hDPMQpOqaP36+9LtlEma81iHwQlDkVAYzHM8EgqJuywzTx+g4KaloZdxuwx7XT+AvL3sQsAAAA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-alpine-dark .ag-icon {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-alpine-dark .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-alpine-dark .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-alpine-dark .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-alpine-dark .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-alpine-dark .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-alpine-dark .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-alpine-dark .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-alpine-dark .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-alpine-dark .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-alpine-dark .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-alpine-dark .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-alpine-dark .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-alpine-dark .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-alpine-dark .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-alpine-dark .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-alpine-dark .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-alpine-dark .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-alpine-dark .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-alpine-dark .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-alpine-dark .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-alpine-dark .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-alpine-dark .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-alpine-dark .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-alpine-dark .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-alpine-dark .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-alpine-dark .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-alpine-dark .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-alpine-dark .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-alpine-dark .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-alpine-dark .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-alpine-dark .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-alpine-dark .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-alpine-dark .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-alpine-dark .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-alpine-dark .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-alpine-dark .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-alpine-dark .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-alpine-dark .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-alpine-dark .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-alpine-dark .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-alpine-dark .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-alpine-dark .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-alpine-dark .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-alpine-dark .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-alpine-dark .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-alpine-dark .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-alpine-dark .ag-root-wrapper {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark [class^='ag-'], .ag-theme-alpine-dark [class^='ag-']:focus, .ag-theme-alpine-dark [class^='ag-']:after, .ag-theme-alpine-dark [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-alpine-dark [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-alpine-dark .ag-checkbox .ag-input-wrapper,\n .ag-theme-alpine-dark .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-alpine-dark .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-alpine-dark .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-alpine-dark .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 6px; }\n .ag-theme-alpine-dark input[class^='ag-'] {\n margin: 0;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark textarea[class^='ag-'],\n .ag-theme-alpine-dark select[class^='ag-'] {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark input[class^='ag-']:not([type]),\n .ag-theme-alpine-dark input[class^='ag-'][type='text'],\n .ag-theme-alpine-dark input[class^='ag-'][type='number'],\n .ag-theme-alpine-dark input[class^='ag-'][type='tel'],\n .ag-theme-alpine-dark input[class^='ag-'][type='date'],\n .ag-theme-alpine-dark input[class^='ag-'][type='datetime-local'],\n .ag-theme-alpine-dark textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #68686e;\n border-color: var(--ag-input-border-color, var(--ag-border-color, #68686e)); }\n .ag-theme-alpine-dark input[class^='ag-']:not([type]):disabled,\n .ag-theme-alpine-dark input[class^='ag-'][type='text']:disabled,\n .ag-theme-alpine-dark input[class^='ag-'][type='number']:disabled,\n .ag-theme-alpine-dark input[class^='ag-'][type='tel']:disabled,\n .ag-theme-alpine-dark input[class^='ag-'][type='date']:disabled,\n .ag-theme-alpine-dark input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-alpine-dark textarea[class^='ag-']:disabled {\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n background-color: #282c2f;\n background-color: var(--ag-input-disabled-background-color, #282c2f);\n border-color: rgba(104, 104, 110, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(104, 104, 110, 0.3)); }\n .ag-theme-alpine-dark input[class^='ag-']:not([type]):focus,\n .ag-theme-alpine-dark input[class^='ag-'][type='text']:focus,\n .ag-theme-alpine-dark input[class^='ag-'][type='number']:focus,\n .ag-theme-alpine-dark input[class^='ag-'][type='tel']:focus,\n .ag-theme-alpine-dark input[class^='ag-'][type='date']:focus,\n .ag-theme-alpine-dark input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-alpine-dark textarea[class^='ag-']:focus {\n outline: none;\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-alpine-dark input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-alpine-dark input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-alpine-dark input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-alpine-dark input[class^='ag-'][type='button']:focus, .ag-theme-alpine-dark button[class^='ag-']:focus {\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6); }\n .ag-theme-alpine-dark .ag-drag-handle {\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-list-item, .ag-theme-alpine-dark .ag-virtual-list-item {\n height: 30px; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-select-list {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-alpine-dark .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-alpine-dark .ag-list-item.ag-active-item {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine-dark .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-alpine-dark .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-alpine-dark .ag-select .ag-picker-field-wrapper {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n min-height: 30px;\n cursor: default; }\n .ag-theme-alpine-dark .ag-select:not(.ag-cell-editor) {\n height: 30px; }\n .ag-theme-alpine-dark .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-alpine-dark .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-alpine-dark .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-rich-select {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628); }\n .ag-theme-alpine-dark .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 273px; }\n .ag-theme-alpine-dark .ag-rich-select-value {\n padding: 0 6px 0 18px;\n height: 42px;\n border-bottom: solid 1px;\n border-bottom-color: rgba(88, 86, 82, 0.5);\n border-bottom-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 30px; }\n .ag-theme-alpine-dark .ag-rich-select-virtual-list-item:hover {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine-dark .ag-rich-select-row {\n padding-left: 18px; }\n .ag-theme-alpine-dark .ag-rich-select-row-selected {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3)); }\n .ag-theme-alpine-dark .ag-row-drag,\n .ag-theme-alpine-dark .ag-selection-checkbox,\n .ag-theme-alpine-dark .ag-group-expanded,\n .ag-theme-alpine-dark .ag-group-contracted {\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-ltr .ag-row-drag, .ag-theme-alpine-dark .ag-ltr .ag-selection-checkbox, .ag-theme-alpine-dark .ag-ltr .ag-group-expanded, .ag-theme-alpine-dark .ag-ltr .ag-group-contracted {\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-drag, .ag-theme-alpine-dark .ag-rtl .ag-selection-checkbox, .ag-theme-alpine-dark .ag-rtl .ag-group-expanded, .ag-theme-alpine-dark .ag-rtl .ag-group-contracted {\n margin-left: 12px; }\n .ag-theme-alpine-dark .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 40px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-alpine-dark .ag-group-expanded,\n .ag-theme-alpine-dark .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-alpine-dark .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-alpine-dark .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-alpine-dark .ag-group-title-bar {\n background-color: #000;\n background-color: var(--ag-subheader-background-color, #000);\n padding: 6px; }\n .ag-theme-alpine-dark .ag-group-toolbar {\n padding: 6px; }\n .ag-theme-alpine-dark .ag-disabled-group-title-bar, .ag-theme-alpine-dark .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-alpine-dark .group-item {\n margin: 3px 0; }\n .ag-theme-alpine-dark .ag-label {\n white-space: nowrap; }\n .ag-theme-alpine-dark .ag-ltr .ag-label {\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-label {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-label-align-top .ag-label {\n margin-bottom: 3px; }\n .ag-theme-alpine-dark .ag-ltr .ag-slider-field, .ag-theme-alpine-dark .ag-ltr .ag-angle-select-field {\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-rtl .ag-slider-field, .ag-theme-alpine-dark .ag-rtl .ag-angle-select-field {\n margin-left: 12px; }\n .ag-theme-alpine-dark .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #fff;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n border-radius: 5px; }\n .ag-theme-alpine-dark .ag-picker-field-wrapper:focus {\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6); }\n .ag-theme-alpine-dark .ag-picker-field-button {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-alpine-dark .ag-color-picker .ag-picker-field-display {\n height: 16px; }\n .ag-theme-alpine-dark .ag-color-panel {\n padding: 6px; }\n .ag-theme-alpine-dark .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-alpine-dark .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-alpine-dark .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-alpine-dark .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-alpine-dark .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-alpine-dark .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-alpine-dark .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-alpine-dark .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-alpine-dark .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-alpine-dark .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-alpine-dark .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-alpine-dark .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-alpine-dark.ag-dnd-ghost {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n border: solid 1px;\n border-color: rgba(88, 86, 82, 0.5);\n border-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5));\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n height: 48px !important;\n line-height: 48px;\n margin: 0;\n padding: 0 12px;\n -webkit-transform: translateY(12px);\n transform: translateY(12px); }\n .ag-theme-alpine-dark .ag-dnd-ghost-icon {\n margin-right: 6px;\n color: #fff;\n color: var(--ag-foreground-color, #fff); }\n .ag-theme-alpine-dark .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 0 1px 20px 1px black; }\n .ag-dragging-range-handle .ag-theme-alpine-dark .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-alpine-dark .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-alpine-dark .ag-dialog {\n border-radius: 3px;\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-panel {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark .ag-panel-title-bar {\n background-color: #222628;\n background-color: var(--ag-header-background-color, #222628);\n color: #fff;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)));\n height: 48px;\n padding: 6px 18px;\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-ltr .ag-panel-title-bar-button {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-panel-title-bar-button {\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-tooltip {\n background-color: #222628;\n background-color: var(--ag-header-background-color, #222628);\n color: #fff;\n color: var(--ag-foreground-color, #fff);\n padding: 6px;\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n border-radius: 3px;\n transition: opacity 1s; }\n .ag-theme-alpine-dark .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px; }\n .ag-theme-alpine-dark .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 12px; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -3px;\n left: -3px;\n display: block;\n width: calc(100% - -6px);\n height: calc(100% - -6px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -3px;\n left: -3px;\n display: block;\n width: calc(100% - -6px);\n height: calc(100% - -6px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-column-select-column-group:not(:last-child),\n .ag-theme-alpine-dark .ag-column-select-column:not(:last-child) {\n margin-bottom: 9px; }\n .ag-theme-alpine-dark .ag-column-select-column-readonly,\n .ag-theme-alpine-dark .ag-column-select-column-group-readonly {\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n pointer-events: none; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-column-select-list {\n padding: 12px 12px; }\n .ag-theme-alpine-dark .ag-rtl {\n text-align: right; }\n .ag-theme-alpine-dark .ag-root-wrapper {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n border-radius: 3px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 46px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 46px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-1 {\n padding-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-1 {\n padding-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 74px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 74px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-2 {\n padding-left: 56px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-2 {\n padding-right: 56px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 102px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 102px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-3 {\n padding-left: 84px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-3 {\n padding-right: 84px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 130px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 130px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-4 {\n padding-left: 112px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-4 {\n padding-right: 112px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 158px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 158px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-5 {\n padding-left: 140px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-5 {\n padding-right: 140px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 186px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 186px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-6 {\n padding-left: 168px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-6 {\n padding-right: 168px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 214px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 214px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-7 {\n padding-left: 196px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-7 {\n padding-right: 196px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 242px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 242px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-8 {\n padding-left: 224px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-8 {\n padding-right: 224px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 270px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 270px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-9 {\n padding-left: 252px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-9 {\n padding-right: 252px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 298px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 298px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-10 {\n padding-left: 280px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-10 {\n padding-right: 280px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 326px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 326px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-11 {\n padding-left: 308px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-11 {\n padding-right: 308px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 354px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 354px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-12 {\n padding-left: 336px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-12 {\n padding-right: 336px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 382px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 382px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-13 {\n padding-left: 364px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-13 {\n padding-right: 364px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 410px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 410px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-14 {\n padding-left: 392px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-14 {\n padding-right: 392px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 438px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 438px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-15 {\n padding-left: 420px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-15 {\n padding-right: 420px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 466px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 466px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-16 {\n padding-left: 448px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-16 {\n padding-right: 448px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 494px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 494px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-17 {\n padding-left: 476px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-17 {\n padding-right: 476px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 522px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 522px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-18 {\n padding-left: 504px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-18 {\n padding-right: 504px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 550px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 550px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-19 {\n padding-left: 532px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-19 {\n padding-right: 532px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-alpine-dark .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-alpine-dark .ag-value-change-delta-up {\n color: #43a047;\n color: var(--ag-value-change-delta-up-color, #43a047); }\n .ag-theme-alpine-dark .ag-value-change-delta-down {\n color: #e53935;\n color: var(--ag-value-change-delta-down-color, #e53935); }\n .ag-theme-alpine-dark .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-alpine-dark .ag-value-change-value-highlight {\n background-color: rgba(22, 160, 133, 0.5);\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5));\n transition: background-color 0.1s; }\n .ag-theme-alpine-dark .ag-cell-data-changed {\n background-color: rgba(22, 160, 133, 0.5) !important;\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5)) !important; }\n .ag-theme-alpine-dark .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-cell-highlight {\n background-color: #2196f3 !important;\n background-color: var(--ag-range-selection-highlight-color, var(--ag-range-selection-border-color, #2196f3)) !important; }\n .ag-theme-alpine-dark .ag-row {\n height: 42px;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n color: #fff;\n color: var(--ag-data-color, var(--ag-foreground-color, #fff));\n border-width: 1px;\n border-color: rgba(88, 86, 82, 0.5);\n border-color: var(--ag-row-border-color, var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5))); }\n .ag-theme-alpine-dark .ag-row:not(.ag-row-first) {\n border-top-style: solid; }\n .ag-theme-alpine-dark .ag-row.ag-row-last {\n border-bottom-style: solid; }\n .ag-theme-alpine-dark .ag-row-highlight-above::after, .ag-theme-alpine-dark .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #2196f3;\n background-color: var(--ag-range-selection-border-color, #2196f3);\n left: 1px; }\n .ag-theme-alpine-dark .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-alpine-dark .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-alpine-dark .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-alpine-dark .ag-row-odd {\n background-color: #222628;\n background-color: var(--ag-odd-row-background-color, #222628); }\n .ag-theme-alpine-dark .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-row-hover {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine-dark .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-alpine-dark .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-alpine-dark .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-alpine-dark .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-alpine-dark .ag-cell {\n border: 1px solid transparent;\n line-height: 40px;\n padding-left: 17px;\n padding-right: 17px; }\n .ag-theme-alpine-dark .ag-row > .ag-cell-wrapper {\n padding-left: 17px;\n padding-right: 17px; }\n .ag-theme-alpine-dark .ag-row-dragging {\n cursor: move; }\n .ag-theme-alpine-dark .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-cell-inline-editing {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px;\n padding: 0;\n height: 42px;\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628); }\n .ag-theme-alpine-dark .ag-popup-editor {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px;\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n padding: 0; }\n .ag-theme-alpine-dark .ag-large-text-input {\n height: auto;\n padding: 18px; }\n .ag-theme-alpine-dark .ag-details-row {\n padding: 30px;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark .ag-overlay-loading-wrapper {\n background-color: rgba(24, 29, 31, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(24, 29, 31, 0.66)); }\n .ag-theme-alpine-dark .ag-overlay-loading-center {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px; }\n .ag-theme-alpine-dark .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-alpine-dark .ag-loading {\n padding-left: 18px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-alpine-dark .ag-loading-icon {\n padding-right: 12px; }\n .ag-theme-alpine-dark .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-alpine-dark .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-ltr .ag-cell {\n border-right: solid transparent; }\n .ag-theme-alpine-dark .ag-rtl .ag-cell {\n border-left: solid transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-alpine-dark .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-alpine-dark .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-row-selected {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3)); }\n .ag-theme-alpine-dark .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(33, 150, 243, 0.2)); }\n .ag-theme-alpine-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1);\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)); }\n .ag-theme-alpine-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)); }\n .ag-theme-alpine-dark .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(33, 150, 243, 0.2))); }\n .ag-theme-alpine-dark .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(33, 150, 243, 0.36)); }\n .ag-theme-alpine-dark .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(33, 150, 243, 0.488)); }\n .ag-theme-alpine-dark .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(33, 150, 243, 0.5904)); }\n .ag-theme-alpine-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #2196f3;\n border-top-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-alpine-dark .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-alpine-dark .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-alpine-dark .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-alpine-dark .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-alpine-dark .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #2196f3;\n border-color: var(--ag-range-selection-border-color, #2196f3);\n outline: initial; }\n .ag-theme-alpine-dark .ag-cell.ag-selection-fill-top,\n .ag-theme-alpine-dark .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #2196f3;\n border-top-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-alpine-dark .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-alpine-dark .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-cell.ag-selection-fill-bottom,\n .ag-theme-alpine-dark .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-alpine-dark .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-alpine-dark .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-fill-handle, .ag-theme-alpine-dark .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #2196f3;\n background-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-ltr .ag-fill-handle, .ag-theme-alpine-dark .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-alpine-dark .ag-rtl .ag-fill-handle, .ag-theme-alpine-dark .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-alpine-dark .ag-fill-handle {\n cursor: cell; }\n .ag-theme-alpine-dark .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-alpine-dark .ag-cell-inline-editing {\n border-color: rgba(33, 150, 243, 0.4) !important;\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)) !important; }\n .ag-theme-alpine-dark .ag-menu {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px;\n padding: 0; }\n .ag-theme-alpine-dark .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 6px;\n padding-bottom: 6px; }\n .ag-theme-alpine-dark .ag-menu-option-part {\n padding-top: 8px;\n padding-bottom: 8px;\n line-height: 16px; }\n .ag-theme-alpine-dark .ag-menu-option-active {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine-dark .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-menu-option-text {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-menu-option-icon {\n padding-left: 12px;\n padding-right: 6px;\n min-width: 28px; }\n .ag-theme-alpine-dark .ag-menu-option-shortcut {\n padding-left: 12px; }\n .ag-theme-alpine-dark .ag-menu-separator {\n height: 12px; }\n .ag-theme-alpine-dark .ag-menu-separator-cell:after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-menu-option-popup-pointer {\n width: 28px;\n text-align: center; }\n .ag-theme-alpine-dark .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-alpine-dark .ag-tab {\n border-bottom: 2px solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n flex: 1 1 auto;\n transition: border-bottom 0.3s; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-tab-selected {\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine-dark .ag-menu-header {\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 12px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-set-filter-select-all {\n padding-top: 12px; }\n .ag-theme-alpine-dark .ag-set-filter-list {\n height: 180px; }\n .ag-theme-alpine-dark .ag-set-filter-filter {\n margin-top: 12px;\n margin-left: 12px;\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-filter-to {\n margin-top: 9px; }\n .ag-theme-alpine-dark .ag-mini-filter {\n margin: 12px 12px;\n margin-bottom: 0; }\n .ag-theme-alpine-dark .ag-set-filter-item {\n margin: 0px 12px; }\n .ag-theme-alpine-dark .ag-ltr .ag-set-filter-item-value {\n margin-left: 12px; }\n .ag-theme-alpine-dark .ag-rtl .ag-set-filter-item-value {\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-filter-header-container {\n padding-bottom: 12px;\n border-bottom: solid 1px;\n border-bottom-color: rgba(88, 86, 82, 0.5);\n border-bottom-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-filter-apply-panel {\n padding: 12px 12px;\n border-top: solid 1px;\n border-top-color: rgba(88, 86, 82, 0.5);\n border-top-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 12px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-simple-filter-body-wrapper {\n padding: 12px 12px;\n padding-bottom: 3px; }\n .ag-theme-alpine-dark .ag-simple-filter-body-wrapper > * {\n margin-bottom: 9px; }\n .ag-theme-alpine-dark .ag-filter-no-matches {\n margin: 12px 12px; }\n .ag-theme-alpine-dark .ag-side-bar {\n position: relative; }\n .ag-theme-alpine-dark .ag-tool-panel-wrapper {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628); }\n .ag-theme-alpine-dark .ag-side-buttons {\n padding-top: 24px;\n width: 20px;\n position: relative;\n color: #fff;\n color: var(--ag-foreground-color, #fff);\n overflow: hidden; }\n .ag-theme-alpine-dark button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 12px 0 12px 0;\n width: 100%;\n margin: 0;\n min-height: 108px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none; }\n .ag-theme-alpine-dark button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-alpine-dark .ag-ltr .ag-side-bar-left,\n .ag-theme-alpine-dark .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-alpine-dark .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-alpine-dark .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 2px solid transparent;\n transition: border-right 0.3s; }\n .ag-theme-alpine-dark .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-alpine-dark .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #2196f3;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine-dark .ag-rtl .ag-side-bar-left,\n .ag-theme-alpine-dark .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-alpine-dark .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-alpine-dark .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 2px solid transparent;\n transition: border-left 0.3s; }\n .ag-theme-alpine-dark .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-alpine-dark .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #2196f3;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine-dark .ag-filter-toolpanel-header {\n height: 36px; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-header, .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-header, .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 6px; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 6px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-0-header {\n height: 48px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-item {\n margin-top: 3px;\n margin-bottom: 3px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-search {\n height: 48px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 24px; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: rgba(88, 86, 82, 0.5);\n border-top-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 22px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 22px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 38px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 38px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 54px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 54px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 70px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 70px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 86px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 86px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 102px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 102px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 118px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 118px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 134px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 134px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 150px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 150px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 166px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 166px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 6px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e);\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e);\n padding-top: 6px; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-pivot-mode-panel {\n height: 48px;\n display: flex; }\n .ag-theme-alpine-dark .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-alpine-dark .ag-ltr .ag-pivot-mode-select {\n margin-left: 12px; }\n .ag-theme-alpine-dark .ag-rtl .ag-pivot-mode-select {\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-column-select-header {\n height: 48px;\n align-items: center;\n padding: 0 12px;\n border-bottom: solid 1px;\n border-bottom-color: rgba(88, 86, 82, 0.5);\n border-bottom-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: rgba(88, 86, 82, 0.5);\n border-bottom-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5));\n border-top: solid 1px;\n border-top-color: rgba(88, 86, 82, 0.5);\n border-top-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-column-group-icons,\n .ag-theme-alpine-dark .ag-column-select-header-icon {\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-header {\n background-color: #222628;\n background-color: var(--ag-header-background-color, #222628);\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-header-row {\n color: #fff;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff))); }\n .ag-theme-alpine-dark .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-header-row {\n height: 48px; }\n .ag-theme-alpine-dark .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-header-cell,\n .ag-theme-alpine-dark .ag-header-group-cell {\n padding-left: 18px;\n padding-right: 18px; }\n .ag-theme-alpine-dark .ag-header-cell.ag-header-cell-moving,\n .ag-theme-alpine-dark .ag-header-group-cell.ag-header-cell-moving {\n background-color: #181d1f;\n background-color: var(--ag-header-cell-moving-background-color, var(--ag-background-color, #181d1f)); }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-header-icon {\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-alpine-dark .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-alpine-dark .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-alpine-dark .ag-header-row:not(:first-child) .ag-header-cell,\n .ag-theme-alpine-dark .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-header-cell-resize {\n display: flex;\n align-items: center; }\n .ag-theme-alpine-dark .ag-header-cell-resize::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n left: calc(50% - 1px);\n width: 2px;\n height: 30%;\n top: calc(50% - 15%);\n background-color: rgba(104, 104, 110, 0.5);\n background-color: var(--ag-header-column-resize-handle-color, rgba(104, 104, 110, 0.5)); }\n .ag-theme-alpine-dark .ag-pinned-right-header .ag-header-cell-resize::after {\n left: calc(50% - 2px); }\n .ag-theme-alpine-dark .ag-ltr .ag-header-select-all {\n margin-right: 18px; }\n .ag-theme-alpine-dark .ag-rtl .ag-header-select-all {\n margin-left: 18px; }\n .ag-theme-alpine-dark .ag-ltr .ag-floating-filter-button {\n margin-left: 18px; }\n .ag-theme-alpine-dark .ag-rtl .ag-floating-filter-button {\n margin-right: 18px; }\n .ag-theme-alpine-dark .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 16px;\n padding: 0;\n width: 16px; }\n .ag-theme-alpine-dark .ag-filter-loading {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n height: 100%;\n padding: 12px 12px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-alpine-dark .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e);\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n height: 48px; }\n .ag-theme-alpine-dark .ag-paging-panel > * {\n margin: 0 18px; }\n .ag-theme-alpine-dark .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 16px; }\n .ag-theme-alpine-dark .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-alpine-dark .ag-paging-button-wrapper.ag-disabled {\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n cursor: default; }\n .ag-theme-alpine-dark .ag-paging-button-wrapper, .ag-theme-alpine-dark .ag-paging-description {\n margin: 0 6px; }\n .ag-theme-alpine-dark .ag-status-bar {\n border-top: solid 1px;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e);\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n padding-right: 24px;\n padding-left: 24px;\n line-height: 1.5; }\n .ag-theme-alpine-dark .ag-status-name-value-value {\n color: #fff;\n color: var(--ag-foreground-color, #fff); }\n .ag-theme-alpine-dark .ag-status-bar-center {\n text-align: center; }\n .ag-theme-alpine-dark .ag-status-name-value {\n margin-left: 6px;\n margin-right: 6px;\n padding-top: 12px;\n padding-bottom: 12px; }\n .ag-theme-alpine-dark .ag-column-drop-cell {\n background: rgba(255, 255, 255, 0.07);\n background: var(--ag-chip-background-color, rgba(255, 255, 255, 0.07));\n border-radius: 24px;\n height: 24px;\n padding: 0 3px; }\n .ag-theme-alpine-dark .ag-column-drop-cell-text {\n margin: 0 6px; }\n .ag-theme-alpine-dark .ag-column-drop-cell-button {\n min-width: 24px;\n margin: 0 3px;\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-column-drop-cell-drag-handle {\n margin-left: 12px; }\n .ag-theme-alpine-dark .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-column-drop-horizontal {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n height: 42px;\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-ltr .ag-column-drop-horizontal {\n padding-left: 18px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-drop-horizontal {\n padding-right: 18px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-column-drop-horizontal-cell-separator {\n margin: 0 6px;\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-column-drop-horizontal-empty-message {\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5)); }\n .ag-theme-alpine-dark .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 18px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 18px; }\n .ag-theme-alpine-dark .ag-column-drop-vertical-list {\n padding-bottom: 6px;\n padding-right: 6px;\n padding-left: 6px; }\n .ag-theme-alpine-dark .ag-column-drop-vertical-cell {\n margin-top: 6px; }\n .ag-theme-alpine-dark .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px;\n border-bottom: solid 1px;\n border-bottom-color: rgba(88, 86, 82, 0.5);\n border-bottom-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none; }\n .ag-theme-alpine-dark .ag-column-drop-vertical-icon {\n margin-left: 6px;\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-alpine-dark .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n margin-top: 6px; }\n .ag-theme-alpine-dark .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px;\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n height: 105px;\n padding: 0; }\n .ag-theme-alpine-dark .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 30px;\n padding-left: 12px; }\n .ag-theme-alpine-dark .ag-select-agg-func-virtual-list-item:hover {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3)); }\n .ag-theme-alpine-dark .ag-chart-menu {\n border-radius: 3px;\n background: #181d1f;\n background: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 3px;\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-alpine-dark .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: rgba(88, 86, 82, 0.5);\n border-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5));\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-alpine-dark .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-alpine-dark .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-alpine-dark .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-alpine-dark .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-alpine-dark .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-alpine-dark .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-alpine-dark .ag-chart-mini-thumbnail.ag-selected {\n border-color: #2196f3;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3))); }\n .ag-theme-alpine-dark .ag-chart-settings-card-item {\n background: #fff;\n background: var(--ag-foreground-color, #fff);\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-alpine-dark .ag-chart-settings-card-item.ag-selected {\n background-color: #2196f3;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3))); }\n .ag-theme-alpine-dark .ag-chart-data-column-drag-handle {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-charts-settings-group-title-bar,\n .ag-theme-alpine-dark .ag-charts-data-group-title-bar,\n .ag-theme-alpine-dark .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: rgba(88, 86, 82, 0.5);\n border-top-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-charts-settings-group-container {\n padding: 6px; }\n .ag-theme-alpine-dark .ag-charts-data-group-container {\n padding: 12px 12px;\n padding-bottom: 3px; }\n .ag-theme-alpine-dark .ag-charts-data-group-container > * {\n margin-bottom: 9px; }\n .ag-theme-alpine-dark .ag-charts-format-top-level-group-container {\n margin-left: 12px;\n padding: 6px; }\n .ag-theme-alpine-dark .ag-charts-format-top-level-group-item {\n margin: 6px 0; }\n .ag-theme-alpine-dark .ag-charts-format-sub-level-group-container {\n padding: 12px 12px;\n padding-bottom: 3px; }\n .ag-theme-alpine-dark .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 9px; }\n .ag-theme-alpine-dark .ag-charts-group-container.ag-group-container-horizontal {\n padding: 6px; }\n .ag-theme-alpine-dark .ag-chart-data-section,\n .ag-theme-alpine-dark .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-alpine-dark .ag-chart-menu-panel {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628); }\n .ag-theme-alpine-dark .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-alpine-dark .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-alpine-dark .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-alpine-dark .ag-checkbox-input-wrapper {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #181d1f;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #181d1f));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-alpine-dark .ag-checkbox-input-wrapper input, .ag-theme-alpine-dark .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-alpine-dark .ag-checkbox-input-wrapper:focus-within, .ag-theme-alpine-dark .ag-checkbox-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6); }\n .ag-theme-alpine-dark .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #999;\n color: var(--ag-checkbox-unchecked-color, #999);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine-dark .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #2196f3;\n color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine-dark .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #999;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, #999));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine-dark .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 28px;\n height: 18px;\n background-color: #999;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, #999));\n border-radius: 9px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #999)); }\n .ag-theme-alpine-dark .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-alpine-dark .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6); }\n .ag-theme-alpine-dark .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #2196f3;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)));\n border-color: #2196f3;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3))); }\n .ag-theme-alpine-dark .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 18px;\n width: 18px;\n background-color: #181d1f;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #181d1f));\n border-radius: 9px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #999))); }\n .ag-theme-alpine-dark .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 18px);\n border-color: #2196f3;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3))); }\n .ag-theme-alpine-dark .ag-radio-button-input-wrapper {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #181d1f;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #181d1f));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 16px; }\n .ag-theme-alpine-dark .ag-radio-button-input-wrapper input, .ag-theme-alpine-dark .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-alpine-dark .ag-radio-button-input-wrapper:focus-within, .ag-theme-alpine-dark .ag-radio-button-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6); }\n .ag-theme-alpine-dark .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #999;\n color: var(--ag-checkbox-unchecked-color, #999);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine-dark .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #2196f3;\n color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine-dark input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #68686e;\n background-color: var(--ag-border-color, #68686e);\n border-radius: 3px;\n border-radius: 3px; }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #68686e;\n background-color: var(--ag-border-color, #68686e);\n border-radius: 3px;\n border-radius: 3px; }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #68686e;\n background-color: var(--ag-border-color, #68686e);\n border-radius: 3px;\n border-radius: 3px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px;\n -webkit-transform: translateY(-6.5px);\n transform: translateY(-6.5px); }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px; }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px; }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']:focus::-ms-thumb {\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']:active::-ms-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-header,\n .ag-theme-alpine-dark .ag-filter-toolpanel-search,\n .ag-theme-alpine-dark .ag-status-bar,\n .ag-theme-alpine-dark .ag-header-row,\n .ag-theme-alpine-dark .ag-panel-title-bar-title {\n font-weight: 700;\n color: #fff;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff))); }\n .ag-theme-alpine-dark .ag-ltr .ag-pinned-right-header .ag-header-row:after, .ag-theme-alpine-dark .ag-rtl .ag-pinned-left-header .ag-header-row:before {\n content: '';\n position: absolute;\n height: calc(100% - 20px);\n top: 10px;\n width: 1px;\n background-color: #68686e;\n background-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-ltr .ag-pinned-right-header .ag-header-row:after {\n right: 0; }\n .ag-theme-alpine-dark .ag-rtl .ag-pinned-left-header .ag-header-row:before {\n left: 0; }\n .ag-theme-alpine-dark .ag-row {\n font-size: 14px; }\n .ag-theme-alpine-dark input[class^='ag-']:not([type]),\n .ag-theme-alpine-dark input[class^='ag-'][type='text'],\n .ag-theme-alpine-dark input[class^='ag-'][type='number'],\n .ag-theme-alpine-dark input[class^='ag-'][type='tel'],\n .ag-theme-alpine-dark input[class^='ag-'][type='date'],\n .ag-theme-alpine-dark input[class^='ag-'][type='datetime-local'],\n .ag-theme-alpine-dark textarea[class^='ag-'] {\n min-height: 24px;\n border-radius: 3px; }\n .ag-theme-alpine-dark .ag-ltr input[class^='ag-']:not([type]),\n .ag-theme-alpine-dark .ag-ltr input[class^='ag-'][type='text'],\n .ag-theme-alpine-dark .ag-ltr input[class^='ag-'][type='number'],\n .ag-theme-alpine-dark .ag-ltr input[class^='ag-'][type='tel'],\n .ag-theme-alpine-dark .ag-ltr input[class^='ag-'][type='date'],\n .ag-theme-alpine-dark .ag-ltr input[class^='ag-'][type='datetime-local'],\n .ag-theme-alpine-dark .ag-ltr textarea[class^='ag-'] {\n padding-left: 6px; }\n .ag-theme-alpine-dark .ag-rtl input[class^='ag-']:not([type]),\n .ag-theme-alpine-dark .ag-rtl input[class^='ag-'][type='text'],\n .ag-theme-alpine-dark .ag-rtl input[class^='ag-'][type='number'],\n .ag-theme-alpine-dark .ag-rtl input[class^='ag-'][type='tel'],\n .ag-theme-alpine-dark .ag-rtl input[class^='ag-'][type='date'],\n .ag-theme-alpine-dark .ag-rtl input[class^='ag-'][type='datetime-local'],\n .ag-theme-alpine-dark .ag-rtl textarea[class^='ag-'] {\n padding-right: 6px; }\n .ag-theme-alpine-dark .ag-tab {\n padding: 9px;\n transition: color 0.4s; }\n .ag-theme-alpine-dark .ag-tab-selected {\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3); }\n .ag-theme-alpine-dark .ag-menu {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628); }\n .ag-theme-alpine-dark .ag-menu-header {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n padding-top: 1px; }\n .ag-theme-alpine-dark .ag-tabs-header {\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-charts-settings-group-title-bar,\n .ag-theme-alpine-dark .ag-charts-data-group-title-bar,\n .ag-theme-alpine-dark .ag-charts-format-top-level-group-title-bar {\n padding: 6px 12px;\n line-height: 20px; }\n .ag-theme-alpine-dark .ag-chart-mini-thumbnail {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark .ag-chart-settings-nav-bar {\n border-top: solid 1px;\n border-top-color: rgba(88, 86, 82, 0.5);\n border-top-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-ltr .ag-group-title-bar-icon {\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-group-title-bar-icon {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-charts-format-top-level-group-toolbar {\n margin-top: 6px; }\n .ag-theme-alpine-dark .ag-ltr .ag-charts-format-top-level-group-toolbar {\n padding-left: 20px; }\n .ag-theme-alpine-dark .ag-rtl .ag-charts-format-top-level-group-toolbar {\n padding-right: 20px; }\n .ag-theme-alpine-dark .ag-charts-format-sub-level-group {\n border-left: dashed 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e);\n padding-left: 6px;\n margin-bottom: 12px; }\n .ag-theme-alpine-dark .ag-charts-format-sub-level-group-title-bar {\n padding-top: 0;\n padding-bottom: 0;\n background: none;\n font-weight: 700; }\n .ag-theme-alpine-dark .ag-charts-format-sub-level-group-container {\n padding-bottom: 0; }\n .ag-theme-alpine-dark .ag-charts-format-sub-level-group-item:last-child {\n margin-bottom: 0; }\n .ag-theme-alpine-dark .ag-dnd-ghost {\n font-size: 12px;\n font-weight: 700; }\n .ag-theme-alpine-dark .ag-side-buttons {\n width: 30px; }\n .ag-theme-alpine-dark .ag-standard-button {\n -moz-appearance: none;\n appearance: none;\n -webkit-appearance: none;\n border-radius: 3px;\n border: 1px solid;\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3);\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n font-weight: 600;\n padding: 6px 12px; }\n .ag-theme-alpine-dark .ag-standard-button:hover {\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine-dark .ag-standard-button:active {\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n background-color: #2196f3;\n background-color: var(--ag-alpine-active-color, #2196f3);\n color: #181d1f;\n color: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark .ag-standard-button:disabled {\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n background-color: #282c2f;\n background-color: var(--ag-input-disabled-background-color, #282c2f);\n border-color: rgba(104, 104, 110, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(104, 104, 110, 0.3)); }\n .ag-theme-alpine-dark .ag-menu-header {\n min-width: 240px; }\n .ag-theme-alpine-dark .ag-column-drop-vertical {\n min-height: 75px;\n max-height: 175px; }\n .ag-theme-alpine-dark .ag-tool-panel-wrapper {\n width: 250px; }\n .ag-theme-alpine-dark .ag-column-drop-vertical-title-bar {\n padding: 12px;\n padding-bottom: 0px; }\n .ag-theme-alpine-dark .ag-column-drop-vertical-empty-message {\n display: flex;\n align-items: center;\n border: dashed 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n margin: 12px;\n padding: 12px; }\n .ag-theme-alpine-dark .ag-column-drop-empty-message {\n color: #fff;\n color: var(--ag-foreground-color, #fff);\n opacity: 0.75; }\n .ag-theme-alpine-dark .ag-status-bar {\n font-weight: normal; }\n .ag-theme-alpine-dark .ag-status-name-value-value {\n font-weight: 700; }\n .ag-theme-alpine-dark .ag-paging-number, .ag-theme-alpine-dark .ag-paging-row-summary-panel-number {\n font-weight: 700; }\n .ag-theme-alpine-dark .ag-column-drop-cell-button {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-column-drop-cell-button:hover {\n opacity: 0.75; }\n .ag-theme-alpine-dark .ag-header-cell-menu-button:hover,\n .ag-theme-alpine-dark .ag-side-button-button:hover,\n .ag-theme-alpine-dark .ag-tab:hover,\n .ag-theme-alpine-dark .ag-panel-title-bar-button:hover,\n .ag-theme-alpine-dark .ag-header-expand-icon:hover,\n .ag-theme-alpine-dark .ag-column-group-icons:hover,\n .ag-theme-alpine-dark .ag-group-expanded .ag-icon:hover,\n .ag-theme-alpine-dark .ag-group-contracted .ag-icon:hover,\n .ag-theme-alpine-dark .ag-chart-settings-prev:hover,\n .ag-theme-alpine-dark .ag-chart-settings-next:hover,\n .ag-theme-alpine-dark .ag-group-title-bar-icon:hover,\n .ag-theme-alpine-dark .ag-column-select-header-icon:hover,\n .ag-theme-alpine-dark .ag-floating-filter-button-button:hover,\n .ag-theme-alpine-dark .ag-filter-toolpanel-expand:hover,\n .ag-theme-alpine-dark .ag-chart-menu-icon:hover {\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3); }\n .ag-theme-alpine-dark .ag-chart-settings-card-item.ag-not-selected:hover {\n opacity: 0.35; }\n .ag-theme-alpine-dark .ag-ltr .ag-panel-title-bar-button {\n margin-left: 12px;\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-panel-title-bar-button {\n margin-right: 12px;\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-container {\n padding-left: 6px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-instance-filter {\n border: none;\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n border-left: dashed 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e);\n margin-left: 13px;\n padding-left: 8px;\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-set-filter-list {\n padding-top: 3px;\n padding-bottom: 3px; }\n .ag-theme-alpine-dark .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 60px; }\n .ag-theme-alpine-dark .ag-date-time-list-page-entry-is-current {\n background-color: #2196f3;\n background-color: var(--ag-alpine-active-color, #2196f3); }\n\n", ""]); +exports.push([module.i, ".ag-theme-alpine-dark {\n color-scheme: dark;\n -webkit-font-smoothing: antialiased;\n color: #fff;\n color: var(--ag-foreground-color, #fff);\n font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n font-size: 13px;\n line-height: normal;\n}\n@font-face {\n font-family: \"agGridAlpine\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABWoAAsAAAAAJ9AAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAmYAAAR2ZcBn9U9TLzIAAANwAAAAQQAAAFZWUVMIY21hcAAAA7QAAAIcAAAFnIMq5ipnbHlmAAAF0AAAC80AABVszjC1ZWhlYWQAABGgAAAANAAAADZ2zsSBaGhlYQAAEdQAAAAeAAAAJAfSBDFobXR4AAAR9AAAABcAAAE0xzj/+2xvY2EAABIMAAAAdQAAAJwYJx3EbWF4cAAAEoQAAAAfAAAAIAFjAKpuYW1lAAASpAAAATUAAAJG5xgJvXBvc3QAABPcAAAByQAAAqgIzxhUeJx9lEtyElEUhv+mm0gCJilFjRhjovEVXzF2uhuaRx4QEDJwYFkOnMSyyrKKcsQ6XIAryNAVuAAHrsAFOHDo2PK7h0ZMBuEWze3z+M9//3Mu8iTNaVNN5doHhy81PzwafVRFgcYf5/9/7w0/vD9SYfKGL7DfgrygpHnd1GuN9M2b90beca7sV/xX/jv/s//F/yWfqFU9JrqobVakmGeoRFXVlCqnGWwR+7oaRPs8m2a9oKvKm6ernpaoGZHTM8QN9XVPi+B0DKetPaISlsNs8xyw7mvhjIgUlDy+be1gDVBkBU3qKmtWz2HZhkmL/Ab+i9Tcp3ZIVgdfB3Z5LE32LV2Ck8sITNWe3ugpfndSh1LNchK+kQ7sPbS3NTSZRDXBqVHLYW/BYGKvgReTsQl6lajdTNEN3SK7Bk4btJZl1y17jcgYbgl9CeycMVxLWmf/Qm/pRREW45y2aTpW4CHsp/aO4aV6dMLaAmtA7BM4TK2uPw+oFdKVGPQlfEN90rG+6rt+6Kd+64/O6TJ1YjvDHuj7Z2pTQMHT0V28zX9Wd9YZZuB01MmIWU5eM3UifL1MQ1etyMmcOgn7EGti8XPwdPFd2KT0I6BGaHVdp/OsHd4jos9n09lglUzpHlOwYBPct1moMKNbum6I4zlM0XoZRLcb86uYbg3wrlnfnLruhi3am7sLrt8VurPCb8gJq6bTId5VLA5parlhWSnsHcYz/Cmsp9Ucq2VYhbqLz81Y325Hl0rrnGfMJNYduxl9m6/bMKhmN7VMDx37VtaxKxYXWZbHP0GY3fDEtHMz3YGbm4/BX0ArchMAAHicY2BkmsY4gYGVgYGpimkPAwNDD4RmfMBgyMgEFGVgZWbACgLSXFMYDjDofjRifgHkRjG/BZnCwAiSAwDkfwr5AAAAeJy11AdSG0EQheFfgSxwIOecEWCCySCiEHAJnCkcKJw5h8/me/QJ8Bt1+wC4ylv1qXdGq92ZWr0GaoCczEkesvVkdEYmq9lMdT5HY3U+z2+NC9ST1XmRK264s6X7e80WueSaW8tUR3+PjK4u0McEzzU6YoUDdjlmjXNWKbHBPnucsMUmp7pmh3XKnLHNIRUu9Pu0irzWWEudntuglTTpjs208JgntNJGOx100kU3PfTqWf0MMMgQw4wwyhjjevokU0wzw6x2U2SeBRb1/TOWWNYia3nYcfTA69OxcrB7vHa+WtKO9062NrXZnfXy2fZh5eIfbvYfjkL6yP2K0Tnpjbq028uwIi/CgbwMu/IqHMvrsCZvQrrn27Aq70JJrsKGXId9eR/25EM4kY9hSz6FTbkJp3Ib0j/vc9iRL2FdvoayfAtn8j1sy49wKD9DRe6CXqBlXMqLZR2p5lzKl+VdypjVuJQ9q3WkWudItd6RaoMj1UaXMmlNjlQLLr1Ja3ak2uJI9ZFTdrCgFGFBecKeOiULa3XKGNbmlDas3Sl3WIdTArFOpyxiXU6pxLqd8on1OCUV63XKLNbnlF6s3ynH2IBTorFBp+xiQ04px4ad8o6NOCUfG3XqAdiYUzfAxp36Ajbh1CGwSadegU05dQ1s2ql/YDMu9UubdSknNufUXbCiU5/B5p06DrbgqutfdOpCWFA/wgLLfwB3H6YceJztWHtwVNUZv9852b179/2+WUI22b3ZXNjshib7uEkWdkMSSMAQcVwwQDFEikONtqK0KBAR/2hNHavjDPgH6Uw7bcPUmUZaph0VKk6VEkeldqTtDOof1dKSqmlxGLGBvfQ7Z3dDAqnaPzttsnvej+98z9+3Agj4R6ZoXLAIAoR8sugLpUKaGiJTunV6Gi7qd2F5kMZz09PZ7PQ0W264evnqZfoR/Ugw4C6H4BOqBMEjyqKqGTRWRrCgMmt6VFZ+8PTTsZdfJlksYk/rg/39/e18JMYHyGOzOv0b+vv1T2evR7LYpbSDdggS3iNrroRL1iQ43DaZP5/Rj+pH4WJmUjfA5ckMrNGPCoSvP0APCF6hFreHRaNo9Mp+2d+spbV0Uq1X6z2iioQidUgfXNwxOKC1tmoDg++VGwNtBw+2HTjAS3pgzhRvFF4tz2LJrivx0Y4tkfMy4VLUhE9hNfxyePj48DDsGh6mtsJpZOgufUQo0Xmenhc8QoBxP2wHn8sbhESoOQspV7IRJNBkkOmDVz4JJoL4oWZeF6b0v/VNwFgfPY/9OZNXPgF/3ykYu3nu+fL851MU9g2nP144Q2I3nlw4c+/sMyk/0xVyReY7F8+k5uvOLQ5+/fpzi7yjD9CvoD6ZhEpBkECUJaBaDRiZ6Hxef3M6xcRGPtAH2rbqBchOTJw6YrEEHP6mFU1+RwB+DT/I4IT+MiybmMjabMGq+kC4qSkciCwMsuMr+B1x1POifByCEAm5QgbFlfAorgy4FBeNF54gO/TVXFbHhqdJYlgfYZIqSqukh+QInmFAGgmqD+yCVv0UmgWN66f0iZJ9FN/zMD2BrwkI1ZzzRh9qbUjmDa8fGZVGPtUrHqSBHNGtSlMeLg7rKUYyvIalAnoKXqMvNoULz5PuW5uUwvNsjnQrTYVtpLtkE0/SJ5muSYDsEiVQUV3gImzo1MdgY6d+WB/rhI1YkPScLmzEJbjdKAhXr9Cv0Q8FJ2pItdAjPCx8D6lF81ANswilSgrlLBtlfwY8Ea+dKOHGilQySxLNQfB5jeF6tREU3IAq0JzWstDsl712HMHhVDLdHKQJJr9GUBtJMgu4i5Q2FffUgF8OEjTFtNaEm4Pg9TnATsKNsITidj+9R7zzXoPep2qaStKqtvKo3gEjBKjBeZboA5I76HXKXqfZYKsMeeQ6j9lmqjB5HfJCq1zrNxKT3fwzd9hf7bI5JbtJNDmsLr/F7fRWudw1fnely2S2iRUGR9BttBjcbovNbV7aECWUmCwmA0kR0eywGkmCgtltIn81ffMRA2lRr/yWEzPy5pXv0Ad+H5BchSf/aK0JekzuqtqIL5yq9y5U3ZLDbPN5k821Df7KSrPD7ggs9jssEbfFbgm4rLLb7jIZRU+oMeKx+Sp9TrPF4fbYJItERdEgeqq/e+y4ZDGaRZvZIJ2RHCbJLp12SGanW/i/7P6rZTcnnoEqou9R0Xrpch7QYA3+Y0CDy7phEsMbrCn5rznyXvW5stZYmEumE83+GsgRJjq/z+sAGUVkh3D9EhCZMtSnkp8toviGmyTR4HW4PM6l7Wa70WZyeHx9eatZcnvdFf23VUguHPks5k48OGS3WfxOT+XGjQ63weC0uqrvedDhc9slybhvt9FkdDnc/ytvnBNDIui4RRljzgS0IL46Di3QmpsdQx5DPFElNArLmJ5ocpoZbQ0+ChjYMipGtDJAm5VxIIgWreFYmNmtpsppZouinNYaSRgql8V61g+sH91ZTam3Kx6PaZuHbhvdubCiwtc3GO/yLhjc33PLqkw01bAqGjK11N26Kurt6asL3LH/cfIj3Lu4a89as0XbrDTG0glYsXutxbx0m1R9a/PyrVpdW020uyHVsKXFG+3J1/VkNuHgLPrtiMHiSD9CA0YLJzWSJaWXcE8BBpxEH4OT6FJIRff+OwJ49xP7BxcgZfrJhTtHf8ppr+aNhRXw7eiqaHTVOlZAQNu6HK8slufW7ulixJpL9SjS1BPlRQm7DCHvRcGGFIk+0aWmQgbZp6U0OjR9bJo8Wxh/O3eWTE2PHof+6Vzu7bPZ0be5yHhxiUyh3LjVaqooM2xHLr30UmZ6Wk/l85A6cSLDMbNVsBbxBq4v4w2GwaqEGkERVKFBWCIImpJKyLO+kc/pI/4+nssd42XhjX/XmR4u/uVKdbZUIzmmmfdfT5MAiPoj+PXgPSn8qvhlYyLWIazpENPRwml+FF5BntUnsAW/0CfIDn6vvjqHd+X0ESQhm83OwzMP6jomFsizC5xlsCufJ0c5y3TrXL9oYphJY3BGDdHlZT/IfCIJTrYxyN82WbaRA+QkZiABtBLBgxEqAymlqEe8hdYgI8aNKD4WuuzQANjgyqb8MLxUGRtr3dLSsqV1bExZGn4G+vSfwy7eBuXaJFxUMsrNLQP3DbTcjK1ofgyrlWxoy46BFs7Xq1fpJMfE1/E1hPiSJRoGlhUhHQaWXJX6DHuSBb29I5e0S6RBu6QhOHsdkoVeVm7GPvkAZ/TXe3shWY8t/GjLent7d2KNn0u/g2QZjz9Dn0EqXBzTJnyAionAEj2lCph76CP9QDp0/V1MQDbo6PfIOznY9S4fox595B0+NuNzruksyiA1819Ex+UvtKKsh7Pl+9+kbxbvn7l2hpDczKWoQ2VKGFHFa/9QpmTGN44XfSNzcTLANzK6noFWGse6DVpKOnWOOnnuyaKnjGmCyBI5cu7ChdjJkzFekiCvvsXLmbcVc8IQ05V5s0JIsiZGERkaAQOICgwksYXz5Yh6RzzWu2ZT6/YGPR6ugzXYgLfCdWxwvpRRH9i0pjcWrwvr8Ybt+od1YXirYXsrHyvTdzfmDD4hKNQjfQqDWKIyN2EINfsZ/EqmgfE3lErQynF7+9p227M8O+jBUn/BFQiEAwFIFZ7Lw/fzdCjS2BjBPGIbX3Io3FSpVOKn4CaHuFsoyXAv3YMa28Z9W7r4L2v1WIFoRC4jn0SjA/mtsqQMWV6PbAG2CkOQ7E/4sanCLU+h+zZI1W1LtK32tupaCPraV2wHINTri8sH/xyDcx7JanKOphc1u2CBSSZgIgdMCJ/sbucZeOgpyWJxWBdZJMtg47KgT39v4TrrNqMhkGr4kmzB7eQJp9Nj94/aKa3S/2L0qpVJ98GKChBN7jOCmb9jnI6j9dUKi4TlwkrhJiEvbBIGhTvxXUEiu6mdiBWRRqIST5ZodYaQy48BVEsbvDILSCmuSqLqQ/wgKjLv+DkzIl45kVKNYiKlRQEZkUAH7UsgDlYjRkX0JbR6dDHUtWhFFJCe6IpF+vv6+9d6UA27C6f+PqUkiVQwAUkqtfCCObYuH5OiKxftlGLr1sXM7XXNC4JQeBX27gEYziVvagHYnYNf7WbrkRet0X0nWrr30Z/Me341710pvGqUcPnUGy4nXgZ7wMEPl+5d1N1ApFge7wGEqP5ocGXLQy+uTu37ZzoykNu7N4yrKcDeYXjoBlvknpiMZ/RT0JrRyccZlu226cLs3wO8wuKyVTmZttQytjmZVdEwh2ms38xmSgb16M4dnV1dnTt2grPcevSezRtTmpbauPlsuUHPswn9H3MXX9k7ZxFvlGyI0WJFG08zanggKPp79T8grev+zs77H2VF1xejkkyV1mMx/YUJviEXEGUMtuy3j7m/aPHMYLKNZQbXsGEvHeJxlSMZ5v8A93JEUvSDhffJkcJadNRZmOQD+uEcmSqcLt9JySEmPY8E58ABDnIIY19fSe6HKGVzEimOUqpf0C/MnUPsivRgwOS75z+zuKA092Pq4b+bsN8qNLgLPu0snNT/1AFVrPUbqOkorYuTTvZCD77mOA82HbfP8ClOxouxgeVL5GMeEqCVjGOMYKo5y88PCW7BLySYH/XxVNdvFOUssExWQcNOMMzsmwUSkmlNxpUyfjQgrxQxgBZdlswhAFj85byp8NwjbT1lpNDRtL7mvoGew8lCN3mFYYLYCsuyqjuWtg60jOXh7v2VX21vLYKFptWG9fnbcSV54V8PFbSvAAAAeJxjYGRgYADiJZeya+P5bb4ycDO/AApEcT7e1wCj///+/5v5LfNboEoOBiYgyQAAoN8P3nicY2BkYGB+wcAAIv///v+b+S0DIwMq8AUAntwHCgAAeJxjYGBgYH4Bwv9/Q+ihjekBAG/aMMwAeJxjYAACKYYghiyGJQz7GN4xSjA6MZYwTmNcxXiH8R/THeZdzFdY3Fh2sJxh1WEtY53Cuob1G5semxtbHNsitgfsbOwK7G7sEewl7Ec4mDjSOHk4FTjTOA9w3uL8xcXBJcalwmXE5cYVwpXBtY10CAAggCv3AAAAeJxjYGRgYPBlmMfAwwACTEDMBYQMDP/BfAYAIOsCDgB4nHWRPU7DQBCFnxMniBghJCREx1Y0SM5PQZEuFHGfIgWdE68dR7bXWm8ipeMYnIBjUHIETsEheDFTREjZ1a6/+fbNNAZwgy94OC4PV+19XB1csPrjLulW2Cc/CPcQ4Em4T/8sPKB9EQ7YWXKC51/S3ONNuINrvAt36T+EffKncA93+Bbu0/8ID7D0fOEAj95rnEU2T2ZFnVd6obNdEdtTdcpLbZvcVGocjk51pCttY6cTtTqoZp9NnEtVak2p5qZyuiiMqq3Z6rULN87V0+EwFR+uTYkYGSJY5EgwQ4GaVEFjwZNhRxPz9VzqnF/yWDSsDGuFMUKMzqYjnqrtiOH4TdixwoF3gz17JrQOKeuUGcO/ojBvJx/TBbehqdu3Lc2aPsSm7aoxxZA7/ZcPmeKkXwK+aWkAAAB4nG2SB2/bMBSE/cWS7dhp46ZtuvceapvuvXeb/geGomUiEimQlO3k15e1gwAB+gASd4eHe8cHtpZai+q3/l+bLNEmIaVDlx7L9BmwwiEOs8qQI6xxlGMcZ50TnOQUpznDWc5xngtc5BKXucJVrnGdG9zkFre5w10y7nGfB2zwkEc85glPecZzXvCSV7zmDW95x3s+8JFPfOYLX/nGd37wk1/8ZpM/rYEoCqcKEbQ1HeGcnfq28LIjhZGqTOVYuDCUYyW3t+wsmwOVr+8L2uQqKFdpI4Ja25cbs9e5Im1pXVbrSFw3kqYyvi+tCU7IoPJE2nonlc5635Z+ksaTbSS58jJVsxigO7+zjZ6a1SLOypfVjsp8Kfy4HVFnpMs4Ph1p50NSOF2nhbNNncSGkJRqFDqlNjFHt7Qi16boVWKmK72rkkqZphdzL5hRs5AYa9TA2JCJsrRTlad1dFHtWpu01hMberVTE20bP3TRzGZbTQjWZHY0Wj0omNTpYhwSLyaq76tol+V2avbgv1iDBZy39RY4pg5xTWvBKXVwr8tzydbK9BqzeA+CAocioLEYpngkJWO22WIW/0ZORUPNDhNG7LZafwFegLa2AAAA\") format(\"woff\");\n font-weight: normal;\n font-style: normal;\n}\n.ag-theme-alpine-dark .ag-icon {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n.ag-theme-alpine-dark .ag-icon-aggregation::before {\n content: \"\\f101\";\n}\n.ag-theme-alpine-dark .ag-icon-arrows::before {\n content: \"\\f102\";\n}\n.ag-theme-alpine-dark .ag-icon-asc::before {\n content: \"\\f103\";\n}\n.ag-theme-alpine-dark .ag-icon-cancel::before {\n content: \"\\f104\";\n}\n.ag-theme-alpine-dark .ag-icon-chart::before {\n content: \"\\f105\";\n}\n.ag-theme-alpine-dark .ag-icon-color-picker::before {\n content: \"\\f109\";\n}\n.ag-theme-alpine-dark .ag-icon-columns::before {\n content: \"\\f10a\";\n}\n.ag-theme-alpine-dark .ag-icon-contracted::before {\n content: \"\\f10b\";\n}\n.ag-theme-alpine-dark .ag-icon-copy::before {\n content: \"\\f10c\";\n}\n.ag-theme-alpine-dark .ag-icon-cross::before {\n content: \"\\f10d\";\n}\n.ag-theme-alpine-dark .ag-icon-csv::before {\n content: \"\\f10e\";\n}\n.ag-theme-alpine-dark .ag-icon-desc::before {\n content: \"\\f10f\";\n}\n.ag-theme-alpine-dark .ag-icon-excel::before {\n content: \"\\f110\";\n}\n.ag-theme-alpine-dark .ag-icon-expanded::before {\n content: \"\\f111\";\n}\n.ag-theme-alpine-dark .ag-icon-eye-slash::before {\n content: \"\\f112\";\n}\n.ag-theme-alpine-dark .ag-icon-eye::before {\n content: \"\\f113\";\n}\n.ag-theme-alpine-dark .ag-icon-filter::before {\n content: \"\\f114\";\n}\n.ag-theme-alpine-dark .ag-icon-first::before {\n content: \"\\f115\";\n}\n.ag-theme-alpine-dark .ag-icon-grip::before {\n content: \"\\f116\";\n}\n.ag-theme-alpine-dark .ag-icon-group::before {\n content: \"\\f117\";\n}\n.ag-theme-alpine-dark .ag-icon-last::before {\n content: \"\\f118\";\n}\n.ag-theme-alpine-dark .ag-icon-left::before {\n content: \"\\f119\";\n}\n.ag-theme-alpine-dark .ag-icon-linked::before {\n content: \"\\f11a\";\n}\n.ag-theme-alpine-dark .ag-icon-loading::before {\n content: \"\\f11b\";\n}\n.ag-theme-alpine-dark .ag-icon-maximize::before {\n content: \"\\f11c\";\n}\n.ag-theme-alpine-dark .ag-icon-menu::before {\n content: \"\\f11d\";\n}\n.ag-theme-alpine-dark .ag-icon-minimize::before {\n content: \"\\f11e\";\n}\n.ag-theme-alpine-dark .ag-icon-next::before {\n content: \"\\f11f\";\n}\n.ag-theme-alpine-dark .ag-icon-none::before {\n content: \"\\f120\";\n}\n.ag-theme-alpine-dark .ag-icon-not-allowed::before {\n content: \"\\f121\";\n}\n.ag-theme-alpine-dark .ag-icon-paste::before {\n content: \"\\f122\";\n}\n.ag-theme-alpine-dark .ag-icon-pin::before {\n content: \"\\f123\";\n}\n.ag-theme-alpine-dark .ag-icon-pivot::before {\n content: \"\\f124\";\n}\n.ag-theme-alpine-dark .ag-icon-previous::before {\n content: \"\\f125\";\n}\n.ag-theme-alpine-dark .ag-icon-right::before {\n content: \"\\f128\";\n}\n.ag-theme-alpine-dark .ag-icon-save::before {\n content: \"\\f129\";\n}\n.ag-theme-alpine-dark .ag-icon-small-down::before {\n content: \"\\f12a\";\n}\n.ag-theme-alpine-dark .ag-icon-small-left::before {\n content: \"\\f12b\";\n}\n.ag-theme-alpine-dark .ag-icon-small-right::before {\n content: \"\\f12c\";\n}\n.ag-theme-alpine-dark .ag-icon-small-up::before {\n content: \"\\f12d\";\n}\n.ag-theme-alpine-dark .ag-icon-tick::before {\n content: \"\\f12e\";\n}\n.ag-theme-alpine-dark .ag-icon-tree-closed::before {\n content: \"\\f12f\";\n}\n.ag-theme-alpine-dark .ag-icon-tree-indeterminate::before {\n content: \"\\f130\";\n}\n.ag-theme-alpine-dark .ag-icon-tree-open::before {\n content: \"\\f131\";\n}\n.ag-theme-alpine-dark .ag-icon-unlinked::before {\n content: \"\\f132\";\n}\n.ag-theme-alpine-dark .ag-icon-row-drag::before {\n content: \"\\f116\";\n}\n.ag-theme-alpine-dark .ag-left-arrow::before {\n content: \"\\f119\";\n}\n.ag-theme-alpine-dark .ag-right-arrow::before {\n content: \"\\f128\";\n}\n.ag-theme-alpine-dark .ag-root-wrapper {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n}\n.ag-theme-alpine-dark [class^=ag-], .ag-theme-alpine-dark [class^=ag-]:focus, .ag-theme-alpine-dark [class^=ag-]:after, .ag-theme-alpine-dark [class^=ag-]:before {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n outline: none;\n}\n.ag-theme-alpine-dark [class^=ag-]::-ms-clear {\n display: none;\n}\n.ag-theme-alpine-dark .ag-checkbox .ag-input-wrapper,\n.ag-theme-alpine-dark .ag-radio-button .ag-input-wrapper {\n overflow: visible;\n}\n.ag-theme-alpine-dark .ag-range-field .ag-input-wrapper {\n height: 100%;\n}\n.ag-theme-alpine-dark .ag-toggle-button {\n -webkit-box-flex: 0;\n flex: none;\n width: unset;\n min-width: unset;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 6px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 6px;\n}\n\n.ag-theme-alpine-dark input[class^=ag-] {\n margin: 0;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n}\n.ag-theme-alpine-dark textarea[class^=ag-],\n.ag-theme-alpine-dark select[class^=ag-] {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n}\n.ag-theme-alpine-dark input[class^=ag-]:not([type]),\n.ag-theme-alpine-dark input[class^=ag-][type=text],\n.ag-theme-alpine-dark input[class^=ag-][type=number],\n.ag-theme-alpine-dark input[class^=ag-][type=tel],\n.ag-theme-alpine-dark input[class^=ag-][type=date],\n.ag-theme-alpine-dark input[class^=ag-][type=datetime-local],\n.ag-theme-alpine-dark textarea[class^=ag-] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #68686e;\n border-color: var(--ag-input-border-color, var(--ag-border-color, #68686e));\n}\n.ag-theme-alpine-dark input[class^=ag-]:not([type]):disabled,\n.ag-theme-alpine-dark input[class^=ag-][type=text]:disabled,\n.ag-theme-alpine-dark input[class^=ag-][type=number]:disabled,\n.ag-theme-alpine-dark input[class^=ag-][type=tel]:disabled,\n.ag-theme-alpine-dark input[class^=ag-][type=date]:disabled,\n.ag-theme-alpine-dark input[class^=ag-][type=datetime-local]:disabled,\n.ag-theme-alpine-dark textarea[class^=ag-]:disabled {\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n background-color: #282c2f;\n background-color: var(--ag-input-disabled-background-color, #282c2f);\n border-color: rgba(104, 104, 110, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(104, 104, 110, 0.3));\n}\n.ag-theme-alpine-dark input[class^=ag-]:not([type]):focus,\n.ag-theme-alpine-dark input[class^=ag-][type=text]:focus,\n.ag-theme-alpine-dark input[class^=ag-][type=number]:focus,\n.ag-theme-alpine-dark input[class^=ag-][type=tel]:focus,\n.ag-theme-alpine-dark input[class^=ag-][type=date]:focus,\n.ag-theme-alpine-dark input[class^=ag-][type=datetime-local]:focus,\n.ag-theme-alpine-dark textarea[class^=ag-]:focus {\n outline: none;\n -webkit-box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine-dark input[class^=ag-]:not([type]):invalid,\n.ag-theme-alpine-dark input[class^=ag-][type=text]:invalid,\n.ag-theme-alpine-dark input[class^=ag-][type=number]:invalid,\n.ag-theme-alpine-dark input[class^=ag-][type=tel]:invalid,\n.ag-theme-alpine-dark input[class^=ag-][type=date]:invalid,\n.ag-theme-alpine-dark input[class^=ag-][type=datetime-local]:invalid,\n.ag-theme-alpine-dark textarea[class^=ag-]:invalid {\n border-width: 2px;\n border-style: solid;\n border-color: #e02525;\n border-color: var(--ag-input-border-color-invalid, var(--ag-invalid-color, #e02525));\n}\n.ag-theme-alpine-dark input[class^=ag-][type=number] {\n -moz-appearance: textfield;\n}\n.ag-theme-alpine-dark input[class^=ag-][type=number]::-webkit-outer-spin-button, .ag-theme-alpine-dark input[class^=ag-][type=number]::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n}\n.ag-theme-alpine-dark input[class^=ag-][type=range] {\n padding: 0;\n}\n.ag-theme-alpine-dark input[class^=ag-][type=button]:focus, .ag-theme-alpine-dark button[class^=ag-]:focus {\n -webkit-box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n}\n.ag-theme-alpine-dark .ag-drag-handle {\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n}\n.ag-theme-alpine-dark .ag-list-item, .ag-theme-alpine-dark .ag-virtual-list-item {\n height: 24px;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine-dark .ag-select-list {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n overflow-y: auto;\n overflow-x: hidden;\n}\n.ag-theme-alpine-dark .ag-list-item {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-alpine-dark .ag-list-item.ag-active-item {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1));\n}\n.ag-theme-alpine-dark .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n user-select: none;\n}\n.ag-theme-alpine-dark .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n.ag-theme-alpine-dark .ag-select .ag-picker-field-wrapper {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n min-height: 24px;\n cursor: default;\n}\n.ag-theme-alpine-dark .ag-select.ag-disabled .ag-picker-field-wrapper:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-alpine-dark .ag-select:not(.ag-cell-editor) {\n height: 24px;\n}\n.ag-theme-alpine-dark .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-alpine-dark .ag-select .ag-picker-field-icon {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-alpine-dark .ag-select.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-alpine-dark .ag-rich-select {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n}\n.ag-theme-alpine-dark .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 273px;\n}\n.ag-theme-alpine-dark .ag-rich-select-value {\n padding: 0 6px 0 18px;\n height: 42px;\n border-bottom: solid 1px;\n border-bottom-color: rgba(88, 86, 82, 0.5);\n border-bottom-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5));\n}\n.ag-theme-alpine-dark .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 24px;\n}\n.ag-theme-alpine-dark .ag-rich-select-virtual-list-item:hover {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1));\n}\n.ag-theme-alpine-dark .ag-rich-select-row {\n padding-left: 18px;\n}\n.ag-theme-alpine-dark .ag-rich-select-row-selected {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3));\n}\n.ag-theme-alpine-dark .ag-row-drag,\n.ag-theme-alpine-dark .ag-selection-checkbox,\n.ag-theme-alpine-dark .ag-group-expanded,\n.ag-theme-alpine-dark .ag-group-contracted {\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n}\n.ag-theme-alpine-dark .ag-ltr .ag-row-drag, .ag-theme-alpine-dark .ag-ltr .ag-selection-checkbox, .ag-theme-alpine-dark .ag-ltr .ag-group-expanded, .ag-theme-alpine-dark .ag-ltr .ag-group-contracted {\n margin-right: 12px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-drag, .ag-theme-alpine-dark .ag-rtl .ag-selection-checkbox, .ag-theme-alpine-dark .ag-rtl .ag-group-expanded, .ag-theme-alpine-dark .ag-rtl .ag-group-contracted {\n margin-left: 12px;\n}\n\n.ag-theme-alpine-dark .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: min(var(--ag-row-height, 40px), 40px);\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-alpine-dark .ag-group-expanded,\n.ag-theme-alpine-dark .ag-group-contracted {\n cursor: pointer;\n}\n.ag-theme-alpine-dark .ag-group-title-bar-icon {\n cursor: pointer;\n -webkit-box-flex: 0;\n flex: none;\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n}\n.ag-theme-alpine-dark .ag-ltr .ag-group-child-count {\n margin-left: 2px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-group-child-count {\n margin-right: 2px;\n}\n\n.ag-theme-alpine-dark .ag-group-title-bar {\n background-color: #000;\n background-color: var(--ag-subheader-background-color, #000);\n padding: 6px;\n}\n.ag-theme-alpine-dark .ag-group-toolbar {\n padding: 6px;\n}\n.ag-theme-alpine-dark .ag-disabled-group-title-bar, .ag-theme-alpine-dark .ag-disabled-group-container {\n opacity: 0.5;\n}\n.ag-theme-alpine-dark .group-item {\n margin: 3px 0;\n}\n.ag-theme-alpine-dark .ag-label {\n white-space: nowrap;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-label {\n margin-right: 6px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-label {\n margin-left: 6px;\n}\n\n.ag-theme-alpine-dark .ag-label-align-top .ag-label {\n margin-bottom: 3px;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-slider-field, .ag-theme-alpine-dark .ag-ltr .ag-angle-select-field {\n margin-right: 12px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-slider-field, .ag-theme-alpine-dark .ag-rtl .ag-angle-select-field {\n margin-left: 12px;\n}\n\n.ag-theme-alpine-dark .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n}\n.ag-theme-alpine-dark .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #fff;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n}\n.ag-theme-alpine-dark .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n border-radius: 5px;\n}\n.ag-theme-alpine-dark .ag-picker-field-wrapper:focus {\n -webkit-box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n}\n.ag-theme-alpine-dark .ag-picker-field-button {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n}\n.ag-theme-alpine-dark .ag-dialog.ag-color-dialog {\n border-radius: 5px;\n}\n.ag-theme-alpine-dark .ag-color-picker .ag-picker-field-display {\n height: 16px;\n}\n.ag-theme-alpine-dark .ag-color-panel {\n padding: 6px;\n}\n.ag-theme-alpine-dark .ag-spectrum-color {\n background-color: red;\n border-radius: 2px;\n}\n.ag-theme-alpine-dark .ag-spectrum-tools {\n padding: 10px;\n}\n.ag-theme-alpine-dark .ag-spectrum-sat {\n background-image: -webkit-gradient(linear, left top, right top, from(white), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0));\n}\n.ag-theme-alpine-dark .ag-spectrum-val {\n background-image: -webkit-gradient(linear, left bottom, left top, from(black), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0));\n}\n.ag-theme-alpine-dark .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n -webkit-box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n}\n.ag-theme-alpine-dark .ag-spectrum-hue-background {\n border-radius: 2px;\n}\n.ag-theme-alpine-dark .ag-spectrum-alpha-background {\n border-radius: 2px;\n}\n.ag-theme-alpine-dark .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px;\n}\n.ag-theme-alpine-dark .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n -webkit-box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n}\n.ag-theme-alpine-dark .ag-recent-color {\n margin: 0 3px;\n}\n.ag-theme-alpine-dark .ag-recent-color:first-child {\n margin-left: 0;\n}\n.ag-theme-alpine-dark .ag-recent-color:last-child {\n margin-right: 0;\n}\n.ag-theme-alpine-dark.ag-dnd-ghost {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n -webkit-box-shadow: 0 1px 20px 1px black;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px;\n overflow: hidden;\n text-overflow: ellipsis;\n border: solid 1px;\n border-color: rgba(88, 86, 82, 0.5);\n border-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5));\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n height: 48px !important;\n line-height: 48px;\n margin: 0;\n padding: 0 12px;\n -webkit-transform: translateY(12px);\n transform: translateY(12px);\n}\n.ag-theme-alpine-dark .ag-dnd-ghost-icon {\n margin-right: 6px;\n color: #fff;\n color: var(--ag-foreground-color, #fff);\n}\n.ag-theme-alpine-dark .ag-popup-child:not(.ag-tooltip-custom) {\n -webkit-box-shadow: 0 1px 20px 1px black;\n box-shadow: 0 1px 20px 1px black;\n}\n.ag-dragging-range-handle .ag-theme-alpine-dark .ag-dialog, .ag-dragging-fill-handle .ag-theme-alpine-dark .ag-dialog {\n opacity: 0.7;\n pointer-events: none;\n}\n.ag-theme-alpine-dark .ag-dialog {\n border-radius: 3px;\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-panel {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n}\n.ag-theme-alpine-dark .ag-panel-title-bar {\n background-color: #222628;\n background-color: var(--ag-header-background-color, #222628);\n color: #fff;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)));\n height: 48px;\n padding: 6px 18px;\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-ltr .ag-panel-title-bar-button {\n margin-left: 6px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-panel-title-bar-button {\n margin-right: 6px;\n}\n\n.ag-theme-alpine-dark .ag-tooltip {\n background-color: #222628;\n background-color: var(--ag-header-background-color, #222628);\n color: #fff;\n color: var(--ag-foreground-color, #fff);\n padding: 6px;\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n border-radius: 3px;\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n white-space: normal;\n}\n.ag-theme-alpine-dark .ag-tooltip.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-alpine-dark .ag-tooltip-custom {\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n}\n.ag-theme-alpine-dark .ag-tooltip-custom.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px;\n}\n\n.ag-theme-alpine-dark .ag-column-select-header-icon {\n cursor: pointer;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-header-icon:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine-dark .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 12px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 12px;\n}\n\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine-dark .ag-column-select-column-group:not(:last-child),\n.ag-theme-alpine-dark .ag-column-select-column:not(:last-child) {\n margin-bottom: 9px;\n}\n.ag-theme-alpine-dark .ag-column-select-column-readonly,\n.ag-theme-alpine-dark .ag-column-select-column-group-readonly {\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n pointer-events: none;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-column-select-virtual-list-viewport {\n padding: 6px 0px;\n}\n.ag-theme-alpine-dark .ag-column-select-virtual-list-item {\n padding: 0 12px;\n}\n.ag-theme-alpine-dark .ag-rtl {\n text-align: right;\n}\n.ag-theme-alpine-dark .ag-root-wrapper {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 46px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 46px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-1 {\n padding-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-1 {\n padding-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-1 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-1 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 74px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 74px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-2 {\n padding-left: 56px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-2 {\n padding-right: 56px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-2 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-2 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 102px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 102px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-3 {\n padding-left: 84px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-3 {\n padding-right: 84px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-3 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-3 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 130px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 130px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-4 {\n padding-left: 112px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-4 {\n padding-right: 112px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-4 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-4 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 158px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 158px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-5 {\n padding-left: 140px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-5 {\n padding-right: 140px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-5 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-5 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 186px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 186px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-6 {\n padding-left: 168px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-6 {\n padding-right: 168px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-6 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-6 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 214px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 214px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-7 {\n padding-left: 196px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-7 {\n padding-right: 196px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-7 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-7 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 242px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 242px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-8 {\n padding-left: 224px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-8 {\n padding-right: 224px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-8 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-8 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 270px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 270px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-9 {\n padding-left: 252px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-9 {\n padding-right: 252px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-9 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-9 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 298px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 298px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-10 {\n padding-left: 280px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-10 {\n padding-right: 280px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-10 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-10 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 326px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 326px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-11 {\n padding-left: 308px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-11 {\n padding-right: 308px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-11 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-11 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 354px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 354px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-12 {\n padding-left: 336px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-12 {\n padding-right: 336px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-12 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-12 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 382px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 382px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-13 {\n padding-left: 364px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-13 {\n padding-right: 364px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-13 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-13 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 410px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 410px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-14 {\n padding-left: 392px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-14 {\n padding-right: 392px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-14 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-14 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 438px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 438px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-15 {\n padding-left: 420px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-15 {\n padding-right: 420px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-15 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-15 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 466px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 466px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-16 {\n padding-left: 448px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-16 {\n padding-right: 448px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-16 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-16 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 494px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 494px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-17 {\n padding-left: 476px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-17 {\n padding-right: 476px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-17 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-17 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 522px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 522px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-18 {\n padding-left: 504px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-18 {\n padding-right: 504px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-18 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-18 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 550px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 550px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-19 {\n padding-left: 532px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-19 {\n padding-right: 532px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-19 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-19 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-left: 578px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-right: 578px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-20 {\n padding-left: 560px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-20 {\n padding-right: 560px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-20 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-20 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-left: 606px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-right: 606px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-21 {\n padding-left: 588px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-21 {\n padding-right: 588px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-21 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-21 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-left: 634px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-right: 634px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-22 {\n padding-left: 616px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-22 {\n padding-right: 616px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-22 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-22 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-left: 662px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-right: 662px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-23 {\n padding-left: 644px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-23 {\n padding-right: 644px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-23 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-23 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-left: 690px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-right: 690px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-24 {\n padding-left: 672px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-24 {\n padding-right: 672px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-24 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-24 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-left: 718px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-right: 718px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-25 {\n padding-left: 700px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-25 {\n padding-right: 700px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-25 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-25 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-left: 746px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-right: 746px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-26 {\n padding-left: 728px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-26 {\n padding-right: 728px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-26 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-26 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-left: 774px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-right: 774px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-27 {\n padding-left: 756px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-27 {\n padding-right: 756px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-27 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-27 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-left: 802px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-right: 802px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-28 {\n padding-left: 784px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-28 {\n padding-right: 784px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-28 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-28 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-left: 830px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-right: 830px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-29 {\n padding-left: 812px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-29 {\n padding-right: 812px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-29 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-29 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-left: 858px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-right: 858px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-30 {\n padding-left: 840px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-30 {\n padding-right: 840px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-30 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-30 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-left: 886px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-right: 886px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-31 {\n padding-left: 868px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-31 {\n padding-right: 868px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-31 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-31 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-left: 914px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-right: 914px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-32 {\n padding-left: 896px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-32 {\n padding-right: 896px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-32 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-32 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-left: 942px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-right: 942px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-33 {\n padding-left: 924px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-33 {\n padding-right: 924px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-33 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-33 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-left: 970px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-right: 970px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-34 {\n padding-left: 952px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-34 {\n padding-right: 952px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-34 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-34 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-left: 998px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-right: 998px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-35 {\n padding-left: 980px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-35 {\n padding-right: 980px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-35 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-35 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-left: 1026px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-right: 1026px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-36 {\n padding-left: 1008px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-36 {\n padding-right: 1008px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-36 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-36 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-left: 1054px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-right: 1054px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-37 {\n padding-left: 1036px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-37 {\n padding-right: 1036px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-37 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-37 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-left: 1082px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-right: 1082px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-38 {\n padding-left: 1064px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-38 {\n padding-right: 1064px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-38 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-38 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-left: 1110px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-right: 1110px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-39 {\n padding-left: 1092px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-39 {\n padding-right: 1092px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-39 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-39 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-left: 1138px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-right: 1138px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-40 {\n padding-left: 1120px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-40 {\n padding-right: 1120px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-40 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-40 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-left: 1166px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-right: 1166px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-41 {\n padding-left: 1148px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-41 {\n padding-right: 1148px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-41 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-41 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-left: 1194px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-right: 1194px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-42 {\n padding-left: 1176px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-42 {\n padding-right: 1176px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-42 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-42 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-left: 1222px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-right: 1222px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-43 {\n padding-left: 1204px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-43 {\n padding-right: 1204px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-43 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-43 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-left: 1250px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-right: 1250px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-44 {\n padding-left: 1232px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-44 {\n padding-right: 1232px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-44 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-44 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-left: 1278px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-right: 1278px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-45 {\n padding-left: 1260px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-45 {\n padding-right: 1260px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-45 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-45 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-left: 1306px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-right: 1306px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-46 {\n padding-left: 1288px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-46 {\n padding-right: 1288px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-46 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-46 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-left: 1334px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-right: 1334px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-47 {\n padding-left: 1316px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-47 {\n padding-right: 1316px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-47 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-47 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-left: 1362px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-right: 1362px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-48 {\n padding-left: 1344px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-48 {\n padding-right: 1344px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-48 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-48 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-left: 1390px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-right: 1390px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-49 {\n padding-left: 1372px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-49 {\n padding-right: 1372px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-49 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-49 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-left: 1418px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-right: 1418px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-50 {\n padding-left: 1400px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-50 {\n padding-right: 1400px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-50 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-50 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-left: 1446px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-right: 1446px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-51 {\n padding-left: 1428px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-51 {\n padding-right: 1428px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-51 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-51 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-left: 1474px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-right: 1474px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-52 {\n padding-left: 1456px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-52 {\n padding-right: 1456px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-52 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-52 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-left: 1502px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-right: 1502px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-53 {\n padding-left: 1484px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-53 {\n padding-right: 1484px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-53 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-53 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-left: 1530px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-right: 1530px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-54 {\n padding-left: 1512px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-54 {\n padding-right: 1512px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-54 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-54 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-left: 1558px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-right: 1558px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-55 {\n padding-left: 1540px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-55 {\n padding-right: 1540px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-55 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-55 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-left: 1586px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-right: 1586px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-56 {\n padding-left: 1568px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-56 {\n padding-right: 1568px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-56 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-56 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-left: 1614px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-right: 1614px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-57 {\n padding-left: 1596px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-57 {\n padding-right: 1596px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-57 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-57 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-left: 1642px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-right: 1642px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-58 {\n padding-left: 1624px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-58 {\n padding-right: 1624px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-58 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-58 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-left: 1670px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-right: 1670px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-59 {\n padding-left: 1652px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-59 {\n padding-right: 1652px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-59 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-59 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-left: 1698px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-right: 1698px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-60 {\n padding-left: 1680px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-60 {\n padding-right: 1680px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-60 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-60 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-left: 1726px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-right: 1726px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-61 {\n padding-left: 1708px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-61 {\n padding-right: 1708px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-61 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-61 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-left: 1754px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-right: 1754px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-62 {\n padding-left: 1736px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-62 {\n padding-right: 1736px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-62 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-62 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-left: 1782px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-right: 1782px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-63 {\n padding-left: 1764px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-63 {\n padding-right: 1764px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-63 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-63 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-left: 1810px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-right: 1810px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-64 {\n padding-left: 1792px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-64 {\n padding-right: 1792px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-64 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-64 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-left: 1838px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-right: 1838px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-65 {\n padding-left: 1820px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-65 {\n padding-right: 1820px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-65 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-65 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-left: 1866px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-right: 1866px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-66 {\n padding-left: 1848px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-66 {\n padding-right: 1848px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-66 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-66 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-left: 1894px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-right: 1894px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-67 {\n padding-left: 1876px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-67 {\n padding-right: 1876px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-67 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-67 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-left: 1922px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-right: 1922px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-68 {\n padding-left: 1904px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-68 {\n padding-right: 1904px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-68 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-68 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-left: 1950px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-right: 1950px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-69 {\n padding-left: 1932px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-69 {\n padding-right: 1932px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-69 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-69 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-left: 1978px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-right: 1978px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-70 {\n padding-left: 1960px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-70 {\n padding-right: 1960px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-70 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-70 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-left: 2006px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-right: 2006px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-71 {\n padding-left: 1988px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-71 {\n padding-right: 1988px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-71 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-71 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-left: 2034px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-right: 2034px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-72 {\n padding-left: 2016px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-72 {\n padding-right: 2016px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-72 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-72 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-left: 2062px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-right: 2062px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-73 {\n padding-left: 2044px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-73 {\n padding-right: 2044px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-73 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-73 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-left: 2090px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-right: 2090px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-74 {\n padding-left: 2072px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-74 {\n padding-right: 2072px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-74 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-74 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-left: 2118px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-right: 2118px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-75 {\n padding-left: 2100px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-75 {\n padding-right: 2100px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-75 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-75 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-left: 2146px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-right: 2146px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-76 {\n padding-left: 2128px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-76 {\n padding-right: 2128px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-76 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-76 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-left: 2174px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-right: 2174px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-77 {\n padding-left: 2156px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-77 {\n padding-right: 2156px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-77 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-77 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-left: 2202px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-right: 2202px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-78 {\n padding-left: 2184px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-78 {\n padding-right: 2184px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-78 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-78 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-left: 2230px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-right: 2230px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-79 {\n padding-left: 2212px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-79 {\n padding-right: 2212px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-79 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-79 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-left: 2258px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-right: 2258px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-80 {\n padding-left: 2240px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-80 {\n padding-right: 2240px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-80 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-80 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-left: 2286px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-right: 2286px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-81 {\n padding-left: 2268px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-81 {\n padding-right: 2268px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-81 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-81 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-left: 2314px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-right: 2314px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-82 {\n padding-left: 2296px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-82 {\n padding-right: 2296px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-82 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-82 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-left: 2342px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-right: 2342px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-83 {\n padding-left: 2324px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-83 {\n padding-right: 2324px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-83 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-83 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-left: 2370px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-right: 2370px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-84 {\n padding-left: 2352px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-84 {\n padding-right: 2352px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-84 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-84 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-left: 2398px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-right: 2398px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-85 {\n padding-left: 2380px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-85 {\n padding-right: 2380px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-85 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-85 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-left: 2426px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-right: 2426px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-86 {\n padding-left: 2408px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-86 {\n padding-right: 2408px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-86 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-86 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-left: 2454px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-right: 2454px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-87 {\n padding-left: 2436px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-87 {\n padding-right: 2436px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-87 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-87 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-left: 2482px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-right: 2482px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-88 {\n padding-left: 2464px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-88 {\n padding-right: 2464px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-88 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-88 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-left: 2510px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-right: 2510px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-89 {\n padding-left: 2492px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-89 {\n padding-right: 2492px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-89 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-89 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-left: 2538px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-right: 2538px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-90 {\n padding-left: 2520px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-90 {\n padding-right: 2520px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-90 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-90 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-left: 2566px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-right: 2566px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-91 {\n padding-left: 2548px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-91 {\n padding-right: 2548px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-91 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-91 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-left: 2594px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-right: 2594px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-92 {\n padding-left: 2576px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-92 {\n padding-right: 2576px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-92 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-92 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-left: 2622px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-right: 2622px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-93 {\n padding-left: 2604px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-93 {\n padding-right: 2604px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-93 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-93 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-left: 2650px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-right: 2650px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-94 {\n padding-left: 2632px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-94 {\n padding-right: 2632px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-94 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-94 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-left: 2678px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-right: 2678px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-95 {\n padding-left: 2660px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-95 {\n padding-right: 2660px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-95 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-95 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-left: 2706px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-right: 2706px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-96 {\n padding-left: 2688px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-96 {\n padding-right: 2688px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-96 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-96 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-left: 2734px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-right: 2734px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-97 {\n padding-left: 2716px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-97 {\n padding-right: 2716px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-97 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-97 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-left: 2762px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-right: 2762px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-98 {\n padding-left: 2744px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-98 {\n padding-right: 2744px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-98 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-98 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-left: 2790px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-right: 2790px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-99 {\n padding-left: 2772px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-99 {\n padding-right: 2772px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-level-99 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-level-99 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-row-group-leaf-indent {\n margin-left: 28px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-row-group-leaf-indent {\n margin-right: 28px;\n}\n\n.ag-theme-alpine-dark .ag-value-change-delta {\n padding-right: 2px;\n}\n.ag-theme-alpine-dark .ag-value-change-delta-up {\n color: #43a047;\n color: var(--ag-value-change-delta-up-color, #43a047);\n}\n.ag-theme-alpine-dark .ag-value-change-delta-down {\n color: #e53935;\n color: var(--ag-value-change-delta-down-color, #e53935);\n}\n.ag-theme-alpine-dark .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n -webkit-transition: background-color 1s;\n transition: background-color 1s;\n}\n.ag-theme-alpine-dark .ag-value-change-value-highlight {\n background-color: rgba(22, 160, 133, 0.5);\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5));\n -webkit-transition: background-color 0.1s;\n transition: background-color 0.1s;\n}\n.ag-theme-alpine-dark .ag-cell-data-changed {\n background-color: rgba(22, 160, 133, 0.5) !important;\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5)) !important;\n}\n.ag-theme-alpine-dark .ag-cell-data-changed-animation {\n background-color: transparent;\n}\n.ag-theme-alpine-dark .ag-cell-highlight {\n background-color: #2196f3 !important;\n background-color: var(--ag-range-selection-highlight-color, var(--ag-range-selection-border-color, #2196f3)) !important;\n}\n.ag-theme-alpine-dark .ag-row {\n height: 42px;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n color: #fff;\n color: var(--ag-data-color, var(--ag-foreground-color, #fff));\n border-width: 1px;\n border-color: rgba(88, 86, 82, 0.5);\n border-color: var(--ag-row-border-color, var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)));\n border-bottom-style: solid;\n}\n.ag-theme-alpine-dark .ag-row-highlight-above::after, .ag-theme-alpine-dark .ag-row-highlight-below::after {\n content: \"\";\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #2196f3;\n background-color: var(--ag-range-selection-border-color, #2196f3);\n left: 1px;\n}\n.ag-theme-alpine-dark .ag-row-highlight-above::after {\n top: -1px;\n}\n.ag-theme-alpine-dark .ag-row-highlight-above.ag-row-first::after {\n top: 0;\n}\n.ag-theme-alpine-dark .ag-row-highlight-below::after {\n bottom: 0px;\n}\n.ag-theme-alpine-dark .ag-row-odd {\n background-color: #222628;\n background-color: var(--ag-odd-row-background-color, #222628);\n}\n.ag-theme-alpine-dark .ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-row-hover {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1));\n}\n.ag-theme-alpine-dark .ag-column-hover {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-column-hover-color, rgba(33, 150, 243, 0.1));\n}\n.ag-theme-alpine-dark .ag-ltr .ag-right-aligned-cell {\n text-align: right;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-right-aligned-cell {\n text-align: left;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-right-aligned-cell .ag-cell-value, .ag-theme-alpine-dark .ag-ltr .ag-right-aligned-cell .ag-group-value {\n margin-left: auto;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-right-aligned-cell .ag-cell-value, .ag-theme-alpine-dark .ag-rtl .ag-right-aligned-cell .ag-group-value {\n margin-right: auto;\n}\n\n.ag-theme-alpine-dark .ag-cell, .ag-theme-alpine-dark .ag-full-width-row .ag-cell-wrapper.ag-row-group {\n border: 1px solid transparent;\n line-height: min(var(--ag-row-height, 40px), 40px);\n padding-left: 17px;\n padding-right: 17px;\n -webkit-font-smoothing: subpixel-antialiased;\n}\n.ag-theme-alpine-dark .ag-row > .ag-cell-wrapper {\n padding-left: 17px;\n padding-right: 17px;\n}\n.ag-theme-alpine-dark .ag-row-dragging {\n cursor: move;\n opacity: 0.5;\n}\n.ag-theme-alpine-dark .ag-cell-inline-editing {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n -webkit-box-shadow: 0 1px 20px 1px black;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px;\n padding: 0;\n height: 42px;\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n}\n.ag-theme-alpine-dark .ag-popup-editor {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n -webkit-box-shadow: 0 1px 20px 1px black;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px;\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n padding: 0;\n}\n.ag-theme-alpine-dark .ag-large-text-input {\n height: auto;\n padding: 18px;\n}\n.ag-theme-alpine-dark .ag-details-row {\n padding: 30px;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n}\n.ag-theme-alpine-dark .ag-layout-auto-height .ag-center-cols-clipper, .ag-theme-alpine-dark .ag-layout-auto-height .ag-center-cols-container, .ag-theme-alpine-dark .ag-layout-print .ag-center-cols-clipper, .ag-theme-alpine-dark .ag-layout-print .ag-center-cols-container {\n min-height: 50px;\n}\n.ag-theme-alpine-dark .ag-overlay-loading-wrapper {\n background-color: rgba(24, 29, 31, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(24, 29, 31, 0.66));\n}\n.ag-theme-alpine-dark .ag-overlay-loading-center {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n -webkit-box-shadow: 0 1px 20px 1px black;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px;\n}\n.ag-theme-alpine-dark .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px;\n}\n.ag-theme-alpine-dark .ag-loading {\n padding-left: 18px;\n display: -webkit-box;\n display: flex;\n height: 100%;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-alpine-dark .ag-loading-icon {\n padding-right: 12px;\n}\n.ag-theme-alpine-dark .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear;\n}\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n.ag-theme-alpine-dark .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-ltr .ag-cell {\n border-right: solid transparent;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-cell {\n border-left: solid transparent;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-cell {\n border-right-width: 1px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-cell {\n border-left-width: 1px;\n}\n\n.ag-theme-alpine-dark .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-row-selected {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3));\n}\n.ag-theme-alpine-dark .ag-cell-range-selected:not(.ag-cell-focus),\n.ag-theme-alpine-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing) {\n background-color: rgba(33, 150, 243, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(33, 150, 243, 0.2));\n}\n.ag-theme-alpine-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart,\n.ag-theme-alpine-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1) !important;\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)) !important;\n}\n.ag-theme-alpine-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category,\n.ag-theme-alpine-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1) !important;\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)) !important;\n}\n.ag-theme-alpine-dark .ag-cell-range-selected-1:not(.ag-cell-focus),\n.ag-theme-alpine-dark .ag-root:not(.ag-context-menu-open) .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-1:not(.ag-cell-inline-editing) {\n background-color: rgba(33, 150, 243, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(33, 150, 243, 0.2)));\n}\n.ag-theme-alpine-dark .ag-cell-range-selected-2:not(.ag-cell-focus),\n.ag-theme-alpine-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-2 {\n background-color: rgba(33, 150, 243, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(33, 150, 243, 0.36));\n}\n.ag-theme-alpine-dark .ag-cell-range-selected-3:not(.ag-cell-focus),\n.ag-theme-alpine-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-3 {\n background-color: rgba(33, 150, 243, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(33, 150, 243, 0.488));\n}\n.ag-theme-alpine-dark .ag-cell-range-selected-4:not(.ag-cell-focus),\n.ag-theme-alpine-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-4 {\n background-color: rgba(33, 150, 243, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(33, 150, 243, 0.5904));\n}\n.ag-theme-alpine-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #2196f3;\n border-top-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine-dark .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-alpine-dark .ag-ltr .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-alpine-dark .ag-ltr .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-alpine-dark .ag-ltr .ag-cell-range-single-cell,\n.ag-theme-alpine-dark .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-alpine-dark .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-alpine-dark .ag-rtl .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-alpine-dark .ag-rtl .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-alpine-dark .ag-rtl .ag-cell-range-single-cell,\n.ag-theme-alpine-dark .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #2196f3;\n border-color: var(--ag-range-selection-border-color, #2196f3);\n outline: initial;\n}\n.ag-theme-alpine-dark .ag-cell.ag-selection-fill-top,\n.ag-theme-alpine-dark .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #2196f3;\n border-top-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine-dark .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-alpine-dark .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3);\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-alpine-dark .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3);\n}\n\n.ag-theme-alpine-dark .ag-cell.ag-selection-fill-bottom,\n.ag-theme-alpine-dark .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine-dark .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-alpine-dark .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3);\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-alpine-dark .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3);\n}\n\n.ag-theme-alpine-dark .ag-range-handle, .ag-theme-alpine-dark .ag-fill-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #2196f3;\n background-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine-dark .ag-ltr .ag-range-handle, .ag-theme-alpine-dark .ag-ltr .ag-fill-handle {\n right: -1px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-range-handle, .ag-theme-alpine-dark .ag-rtl .ag-fill-handle {\n left: -1px;\n}\n\n.ag-theme-alpine-dark .ag-fill-handle {\n cursor: cell;\n}\n.ag-theme-alpine-dark .ag-range-handle {\n cursor: nwse-resize;\n}\n.ag-theme-alpine-dark .ag-cell-inline-editing {\n border-color: rgba(33, 150, 243, 0.4) !important;\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)) !important;\n}\n.ag-theme-alpine-dark .ag-menu {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n -webkit-box-shadow: 0 1px 20px 1px black;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px;\n padding: 0;\n}\n.ag-theme-alpine-dark .ag-menu-list {\n cursor: default;\n padding: 6px 0;\n}\n.ag-theme-alpine-dark .ag-menu-separator {\n height: 13px;\n}\n.ag-theme-alpine-dark .ag-menu-separator-part::after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-menu-option-active, .ag-theme-alpine-dark .ag-compact-menu-option-active {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1));\n}\n.ag-theme-alpine-dark .ag-menu-option-part, .ag-theme-alpine-dark .ag-compact-menu-option-part {\n line-height: 16px;\n padding: 8px 0;\n}\n.ag-theme-alpine-dark .ag-menu-option-disabled, .ag-theme-alpine-dark .ag-compact-menu-option-disabled {\n opacity: 0.5;\n}\n.ag-theme-alpine-dark .ag-menu-option-icon, .ag-theme-alpine-dark .ag-compact-menu-option-icon {\n width: 16px;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-menu-option-icon, .ag-theme-alpine-dark .ag-ltr .ag-compact-menu-option-icon {\n padding-left: 12px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-menu-option-icon, .ag-theme-alpine-dark .ag-rtl .ag-compact-menu-option-icon {\n padding-right: 12px;\n}\n\n.ag-theme-alpine-dark .ag-menu-option-text, .ag-theme-alpine-dark .ag-compact-menu-option-text {\n padding-left: 12px;\n padding-right: 12px;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-menu-option-shortcut, .ag-theme-alpine-dark .ag-ltr .ag-compact-menu-option-shortcut {\n padding-right: 6px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-menu-option-shortcut, .ag-theme-alpine-dark .ag-rtl .ag-compact-menu-option-shortcut {\n padding-left: 6px;\n}\n\n.ag-theme-alpine-dark .ag-menu-option-popup-pointer, .ag-theme-alpine-dark .ag-compact-menu-option-popup-pointer {\n padding-right: 6px;\n}\n.ag-theme-alpine-dark .ag-tabs {\n min-width: 240px;\n}\n.ag-theme-alpine-dark .ag-tabs-header {\n width: 100%;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-alpine-dark .ag-tab {\n border-bottom: 2px solid transparent;\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 0;\n flex: none;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-pack: center;\n justify-content: center;\n cursor: pointer;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n -webkit-transition: border-bottom 0.3s;\n transition: border-bottom 0.3s;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-tab:focus {\n outline: none;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-tab:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine-dark .ag-tab-selected {\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3));\n}\n.ag-theme-alpine-dark .ag-menu-header {\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n}\n.ag-theme-alpine-dark .ag-filter-separator {\n border-top: solid 1px;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-menu:not(.ag-tabs) .ag-filter-select {\n min-width: 155px;\n}\n.ag-theme-alpine-dark .ag-tabs .ag-filter-select {\n min-width: 214px;\n}\n.ag-theme-alpine-dark .ag-filter-select .ag-picker-field-wrapper {\n width: 0;\n}\n.ag-theme-alpine-dark .ag-filter-condition-operator {\n height: 17px;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 12px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 12px;\n}\n\n.ag-theme-alpine-dark .ag-set-filter-select-all {\n padding-top: 12px;\n}\n.ag-theme-alpine-dark .ag-set-filter-list, .ag-theme-alpine-dark .ag-filter-no-matches {\n height: 144px;\n}\n.ag-theme-alpine-dark .ag-set-filter-filter {\n margin-top: 12px;\n margin-left: 12px;\n margin-right: 12px;\n}\n.ag-theme-alpine-dark .ag-filter-to {\n margin-top: 9px;\n}\n.ag-theme-alpine-dark .ag-mini-filter {\n margin: 12px 12px;\n}\n.ag-theme-alpine-dark .ag-set-filter-item {\n margin: 0px 12px;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-set-filter-item-value {\n margin-left: 12px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-set-filter-item-value {\n margin-right: 12px;\n}\n\n.ag-theme-alpine-dark .ag-filter-apply-panel {\n padding: 12px 12px;\n border-top: solid 1px;\n border-top-color: rgba(88, 86, 82, 0.5);\n border-top-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5));\n}\n.ag-theme-alpine-dark .ag-filter-apply-panel-button {\n line-height: 1.5;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 12px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 12px;\n}\n\n.ag-theme-alpine-dark .ag-simple-filter-body-wrapper {\n padding: 12px 12px;\n padding-bottom: 3px;\n}\n.ag-theme-alpine-dark .ag-simple-filter-body-wrapper > * {\n margin-bottom: 9px;\n}\n.ag-theme-alpine-dark .ag-filter-no-matches {\n padding: 12px 12px;\n}\n.ag-theme-alpine-dark .ag-multi-filter-menu-item {\n margin: 6px 0;\n}\n.ag-theme-alpine-dark .ag-multi-filter-group-title-bar {\n padding: 12px 6px;\n background-color: transparent;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus {\n outline: none;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine-dark .ag-side-bar {\n position: relative;\n}\n.ag-theme-alpine-dark .ag-tool-panel-wrapper {\n width: 250px;\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n}\n.ag-theme-alpine-dark .ag-side-buttons {\n padding-top: 24px;\n width: 20px;\n position: relative;\n color: #fff;\n color: var(--ag-foreground-color, #fff);\n overflow: hidden;\n}\n.ag-theme-alpine-dark button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 12px 0 12px 0;\n width: 100%;\n margin: 0;\n min-height: 108px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n}\n.ag-theme-alpine-dark button.ag-side-button-button:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-side-button-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine-dark .ag-side-button-icon-wrapper {\n margin-bottom: 3px;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-side-bar-left,\n.ag-theme-alpine-dark .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n.ag-theme-alpine-dark .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-ltr .ag-side-bar-left .ag-side-button-button,\n.ag-theme-alpine-dark .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 2px solid transparent;\n -webkit-transition: border-right 0.3s;\n transition: border-right 0.3s;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-alpine-dark .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #2196f3;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3));\n}\n.ag-theme-alpine-dark .ag-rtl .ag-side-bar-left,\n.ag-theme-alpine-dark .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n.ag-theme-alpine-dark .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-rtl .ag-side-bar-left .ag-side-button-button,\n.ag-theme-alpine-dark .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 2px solid transparent;\n -webkit-transition: border-left 0.3s;\n transition: border-left 0.3s;\n}\n.ag-theme-alpine-dark .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-alpine-dark .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #2196f3;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3));\n}\n.ag-theme-alpine-dark .ag-filter-toolpanel-header {\n height: 36px;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-header, .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 6px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-header, .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 6px;\n}\n\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine-dark .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f114\";\n position: absolute;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-left: 6px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-right: 6px;\n}\n\n.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-0-header {\n height: 48px;\n}\n.ag-theme-alpine-dark .ag-filter-toolpanel-group-item {\n margin-top: 3px;\n margin-bottom: 3px;\n}\n.ag-theme-alpine-dark .ag-filter-toolpanel-search {\n height: 48px;\n}\n.ag-theme-alpine-dark .ag-filter-toolpanel-search-input {\n -webkit-box-flex: 1;\n flex-grow: 1;\n height: 24px;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 6px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 6px;\n}\n\n.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: rgba(88, 86, 82, 0.5);\n border-top-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5));\n}\n.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 6px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 6px;\n}\n\n.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 22px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 22px;\n}\n\n.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 38px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 38px;\n}\n\n.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 54px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 54px;\n}\n\n.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 70px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 70px;\n}\n\n.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 86px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 86px;\n}\n\n.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 102px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 102px;\n}\n\n.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 118px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 118px;\n}\n\n.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 134px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 134px;\n}\n\n.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 150px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 150px;\n}\n\n.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 166px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 166px;\n}\n\n.ag-theme-alpine-dark .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 6px;\n}\n.ag-theme-alpine-dark .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e);\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e);\n margin-top: 6px;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 6px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 6px;\n}\n\n.ag-theme-alpine-dark .ag-pivot-mode-panel {\n min-height: 48px;\n height: 48px;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-alpine-dark .ag-pivot-mode-select {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-pivot-mode-select {\n margin-left: 12px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-pivot-mode-select {\n margin-right: 12px;\n}\n\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine-dark .ag-column-select-header {\n height: 48px;\n -webkit-box-align: center;\n align-items: center;\n padding: 0 12px;\n border-bottom: solid 1px;\n border-bottom-color: rgba(88, 86, 82, 0.5);\n border-bottom-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5));\n}\n.ag-theme-alpine-dark .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: rgba(88, 86, 82, 0.5);\n border-bottom-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5));\n border-top: solid 1px;\n border-top-color: rgba(88, 86, 82, 0.5);\n border-top-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5));\n}\n.ag-theme-alpine-dark .ag-column-group-icons,\n.ag-theme-alpine-dark .ag-column-select-header-icon {\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n}\n.ag-theme-alpine-dark .ag-column-select-list .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #2196f3;\n background-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine-dark .ag-column-select-list .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-alpine-dark .ag-column-select-list .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-alpine-dark .ag-header {\n background-color: #222628;\n background-color: var(--ag-header-background-color, #222628);\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-header-row {\n color: #fff;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)));\n height: 48px;\n}\n.ag-theme-alpine-dark .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 6px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 6px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 6px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 6px;\n}\n\n.ag-theme-alpine-dark .ag-header-cell,\n.ag-theme-alpine-dark .ag-header-group-cell {\n padding-left: 18px;\n padding-right: 18px;\n}\n.ag-theme-alpine-dark .ag-header-cell.ag-header-cell-moving,\n.ag-theme-alpine-dark .ag-header-group-cell.ag-header-cell-moving {\n background-color: #181d1f;\n background-color: var(--ag-header-cell-moving-background-color, var(--ag-background-color, #181d1f));\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-header-cell:focus {\n outline: none;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-header-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-header-group-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine-dark .ag-header-icon {\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n}\n.ag-theme-alpine-dark .ag-header-expand-icon {\n cursor: pointer;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-header-expand-icon {\n padding-left: 4px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-header-expand-icon {\n padding-right: 4px;\n}\n\n.ag-theme-alpine-dark .ag-header-row:not(:first-child) .ag-header-cell,\n.ag-theme-alpine-dark .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-header-cell-resize {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-alpine-dark .ag-header-cell-resize::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n left: calc(50% - 1px);\n width: 2px;\n height: 30%;\n top: calc(50% - 15%);\n background-color: rgba(104, 104, 110, 0.5);\n background-color: var(--ag-header-column-resize-handle-color, rgba(104, 104, 110, 0.5));\n}\n.ag-theme-alpine-dark .ag-pinned-right-header .ag-header-cell-resize::after {\n left: calc(50% - 2px);\n}\n.ag-theme-alpine-dark .ag-ltr .ag-header-select-all {\n margin-right: 18px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-header-select-all {\n margin-left: 18px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-floating-filter-button {\n margin-left: 18px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-floating-filter-button {\n margin-right: 18px;\n}\n\n.ag-theme-alpine-dark .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 16px;\n padding: 0;\n width: 16px;\n}\n.ag-theme-alpine-dark .ag-filter-loading {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n height: 100%;\n padding: 12px 12px;\n position: absolute;\n width: 100%;\n z-index: 1;\n}\n.ag-theme-alpine-dark .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e);\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n height: 48px;\n}\n.ag-theme-alpine-dark .ag-paging-panel > * {\n margin: 0 18px;\n}\n.ag-theme-alpine-dark .ag-paging-button {\n cursor: pointer;\n}\n.ag-theme-alpine-dark .ag-paging-button.ag-disabled {\n cursor: default;\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-paging-button:focus {\n outline: none;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-paging-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine-dark .ag-paging-button, .ag-theme-alpine-dark .ag-paging-description {\n margin: 0 6px;\n}\n.ag-theme-alpine-dark .ag-status-bar {\n border-top: solid 1px;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e);\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n padding-right: 24px;\n padding-left: 24px;\n line-height: 1.5;\n}\n.ag-theme-alpine-dark .ag-status-name-value-value {\n color: #fff;\n color: var(--ag-foreground-color, #fff);\n}\n.ag-theme-alpine-dark .ag-status-bar-center {\n text-align: center;\n}\n.ag-theme-alpine-dark .ag-status-name-value {\n margin-left: 6px;\n margin-right: 6px;\n padding-top: 12px;\n padding-bottom: 12px;\n}\n.ag-theme-alpine-dark .ag-column-drop-cell {\n background: rgba(255, 255, 255, 0.07);\n background: var(--ag-chip-background-color, rgba(255, 255, 255, 0.07));\n border-radius: 24px;\n height: 24px;\n padding: 0 3px;\n border: 1px solid transparent;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-column-drop-cell:focus {\n outline: none;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-column-drop-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 2px;\n left: 2px;\n display: block;\n width: calc(100% - 4px);\n height: calc(100% - 4px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine-dark .ag-column-drop-cell-text {\n margin: 0 6px;\n}\n.ag-theme-alpine-dark .ag-column-drop-cell-button {\n min-width: 24px;\n margin: 0 3px;\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n}\n.ag-theme-alpine-dark .ag-column-drop-cell-drag-handle {\n margin-left: 12px;\n}\n.ag-theme-alpine-dark .ag-column-drop-cell-ghost {\n opacity: 0.5;\n}\n.ag-theme-alpine-dark .ag-column-drop-horizontal {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n height: 42px;\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-ltr .ag-column-drop-horizontal {\n padding-left: 18px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-column-drop-horizontal {\n padding-right: 18px;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e);\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e);\n}\n\n.ag-theme-alpine-dark .ag-column-drop-horizontal-cell-separator {\n margin: 0 6px;\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n}\n.ag-theme-alpine-dark .ag-column-drop-horizontal-empty-message {\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n}\n.ag-theme-alpine-dark .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 18px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 18px;\n}\n\n.ag-theme-alpine-dark .ag-column-drop-vertical-list {\n padding-bottom: 6px;\n padding-right: 6px;\n padding-left: 6px;\n}\n.ag-theme-alpine-dark .ag-column-drop-vertical-cell {\n margin-top: 6px;\n}\n.ag-theme-alpine-dark .ag-column-drop-vertical {\n min-height: 50px;\n border-bottom: solid 1px;\n border-bottom-color: rgba(88, 86, 82, 0.5);\n border-bottom-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5));\n}\n.ag-theme-alpine-dark .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none;\n}\n.ag-theme-alpine-dark .ag-column-drop-vertical-icon {\n margin-left: 6px;\n margin-right: 6px;\n}\n.ag-theme-alpine-dark .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n margin-top: 6px;\n}\n.ag-theme-alpine-dark .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n -webkit-box-shadow: 0 1px 20px 1px black;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px;\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n height: 105px;\n padding: 0;\n}\n.ag-theme-alpine-dark .ag-select-agg-func-virtual-list-item {\n cursor: default;\n padding-left: 12px;\n}\n.ag-theme-alpine-dark .ag-select-agg-func-virtual-list-item:hover {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3));\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-alpine-dark .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine-dark .ag-chart-menu {\n border-radius: 3px;\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n}\n.ag-theme-alpine-dark .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 3px;\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n}\n.ag-theme-alpine-dark .ag-chart-menu-icon:hover {\n opacity: 1;\n}\n.ag-theme-alpine-dark .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: rgba(88, 86, 82, 0.5);\n border-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5));\n border-radius: 5px;\n margin: 5px;\n}\n.ag-theme-alpine-dark .ag-chart-mini-thumbnail:nth-last-child(3), .ag-theme-alpine-dark .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0;\n}\n\n.ag-theme-alpine-dark .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0;\n}\n\n.ag-theme-alpine-dark .ag-chart-mini-thumbnail.ag-selected {\n border-color: #2196f3;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)));\n}\n.ag-theme-alpine-dark .ag-chart-settings-card-item {\n background: #fff;\n background: var(--ag-foreground-color, #fff);\n width: 8px;\n height: 8px;\n border-radius: 4px;\n}\n.ag-theme-alpine-dark .ag-chart-settings-card-item.ag-selected {\n background-color: #2196f3;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)));\n}\n.ag-theme-alpine-dark .ag-chart-data-column-drag-handle {\n margin-left: 6px;\n}\n.ag-theme-alpine-dark .ag-charts-settings-group-title-bar,\n.ag-theme-alpine-dark .ag-charts-data-group-title-bar,\n.ag-theme-alpine-dark .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: rgba(88, 86, 82, 0.5);\n border-top-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5));\n}\n.ag-theme-alpine-dark .ag-charts-settings-group-container {\n padding: 6px;\n}\n.ag-theme-alpine-dark .ag-charts-data-group-container {\n padding: 6px 12px;\n}\n.ag-theme-alpine-dark .ag-charts-data-group-container .ag-charts-data-group-item:not(.ag-charts-format-sub-level-group) {\n height: 24px;\n}\n.ag-theme-alpine-dark .ag-charts-data-group-container .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #2196f3;\n background-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine-dark .ag-charts-data-group-container .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-alpine-dark .ag-charts-data-group-container .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-alpine-dark .ag-charts-format-top-level-group-container {\n margin-left: 12px;\n padding: 6px;\n}\n.ag-theme-alpine-dark .ag-charts-format-top-level-group-item {\n margin: 6px 0;\n}\n.ag-theme-alpine-dark .ag-charts-format-sub-level-group-container {\n padding: 12px 12px;\n padding-bottom: 3px;\n}\n.ag-theme-alpine-dark .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 9px;\n}\n.ag-theme-alpine-dark .ag-charts-group-container.ag-group-container-horizontal {\n padding: 6px;\n}\n.ag-theme-alpine-dark .ag-chart-data-section,\n.ag-theme-alpine-dark .ag-chart-format-section {\n display: -webkit-box;\n display: flex;\n margin: 0;\n}\n.ag-theme-alpine-dark .ag-chart-menu-panel {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n}\n.ag-theme-alpine-dark .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e);\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e);\n}\n\n.ag-theme-alpine-dark .ag-date-time-list-page-title {\n -webkit-box-flex: 1;\n flex-grow: 1;\n text-align: center;\n}\n.ag-theme-alpine-dark .ag-date-time-list-page-column-label {\n text-align: center;\n}\n.ag-theme-alpine-dark .ag-date-time-list-page-entry {\n text-align: center;\n}\n.ag-theme-alpine-dark .ag-checkbox-input-wrapper {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #181d1f;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #181d1f));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-alpine-dark .ag-checkbox-input-wrapper input, .ag-theme-alpine-dark .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-alpine-dark .ag-checkbox-input-wrapper:focus-within, .ag-theme-alpine-dark .ag-checkbox-input-wrapper:active {\n outline: none;\n -webkit-box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n}\n.ag-theme-alpine-dark .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-alpine-dark .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #999;\n color: var(--ag-checkbox-unchecked-color, #999);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-alpine-dark .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #2196f3;\n color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-alpine-dark .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #999;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, #999));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-alpine-dark .ag-toggle-button-input-wrapper {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n width: 28px;\n height: 18px;\n background-color: #999;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, #999));\n border-radius: 9px;\n position: relative;\n -webkit-box-flex: 0;\n flex: none;\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #999));\n}\n.ag-theme-alpine-dark .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%;\n}\n.ag-theme-alpine-dark .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n -webkit-box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n}\n.ag-theme-alpine-dark .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-alpine-dark .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #2196f3;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)));\n border-color: #2196f3;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)));\n}\n.ag-theme-alpine-dark .ag-toggle-button-input-wrapper::before {\n content: \" \";\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n height: 18px;\n width: 18px;\n background-color: #181d1f;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #181d1f));\n border-radius: 9px;\n -webkit-transition: left 100ms;\n transition: left 100ms;\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #999)));\n}\n.ag-theme-alpine-dark .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 18px );\n border-color: #2196f3;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)));\n}\n.ag-theme-alpine-dark .ag-radio-button-input-wrapper {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #181d1f;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #181d1f));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n border-radius: 16px;\n}\n.ag-theme-alpine-dark .ag-radio-button-input-wrapper input, .ag-theme-alpine-dark .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-alpine-dark .ag-radio-button-input-wrapper:focus-within, .ag-theme-alpine-dark .ag-radio-button-input-wrapper:active {\n outline: none;\n -webkit-box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n}\n.ag-theme-alpine-dark .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-alpine-dark .ag-radio-button-input-wrapper::after {\n content: \"\\f126\";\n color: #999;\n color: var(--ag-checkbox-unchecked-color, #999);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-alpine-dark .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f127\";\n color: #2196f3;\n color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-alpine-dark input[class^=ag-][type=range] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible;\n}\n.ag-theme-alpine-dark input[class^=ag-][type=range]::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #68686e;\n background-color: var(--ag-border-color, #68686e);\n border-radius: 3px;\n border-radius: 3px;\n}\n.ag-theme-alpine-dark input[class^=ag-][type=range]::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #68686e;\n background-color: var(--ag-border-color, #68686e);\n border-radius: 3px;\n border-radius: 3px;\n}\n.ag-theme-alpine-dark input[class^=ag-][type=range]::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #68686e;\n background-color: var(--ag-border-color, #68686e);\n border-radius: 3px;\n border-radius: 3px;\n color: transparent;\n width: calc(100% - 2px);\n}\n.ag-theme-alpine-dark input[class^=ag-][type=range]::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px;\n -webkit-transform: translateY(-6.5px);\n transform: translateY(-6.5px);\n}\n.ag-theme-alpine-dark input[class^=ag-][type=range]::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px;\n}\n.ag-theme-alpine-dark input[class^=ag-][type=range]::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px;\n}\n.ag-theme-alpine-dark input[class^=ag-][type=range]:focus {\n outline: none;\n}\n.ag-theme-alpine-dark input[class^=ag-][type=range]:focus::-webkit-slider-thumb {\n -webkit-box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n}\n.ag-theme-alpine-dark input[class^=ag-][type=range]:focus::-ms-thumb {\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n}\n.ag-theme-alpine-dark input[class^=ag-][type=range]:focus::-moz-ag-range-thumb {\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n}\n.ag-theme-alpine-dark input[class^=ag-][type=range]:active::-webkit-slider-runnable-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine-dark input[class^=ag-][type=range]:active::-moz-ag-range-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine-dark input[class^=ag-][type=range]:active::-ms-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine-dark input[class^=ag-][type=range]:disabled {\n opacity: 0.5;\n}\n.ag-theme-alpine-dark .ag-filter-toolpanel-header,\n.ag-theme-alpine-dark .ag-filter-toolpanel-search,\n.ag-theme-alpine-dark .ag-status-bar,\n.ag-theme-alpine-dark .ag-header-row,\n.ag-theme-alpine-dark .ag-panel-title-bar-title,\n.ag-theme-alpine-dark .ag-multi-filter-group-title-bar {\n font-weight: 700;\n color: #fff;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)));\n}\n.ag-theme-alpine-dark .ag-rtl .ag-pinned-left-header .ag-header-row::before, .ag-theme-alpine-dark .ag-ltr .ag-pinned-right-header .ag-header-row::after {\n content: \"\";\n position: absolute;\n height: calc(100% - 20px);\n top: 10px;\n width: 1px;\n background-color: #68686e;\n background-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-ltr .ag-pinned-right-header .ag-header-row::after {\n right: 0;\n}\n.ag-theme-alpine-dark .ag-rtl .ag-pinned-left-header .ag-header-row::before {\n left: 0;\n}\n.ag-theme-alpine-dark .ag-row {\n font-size: 14px;\n}\n.ag-theme-alpine-dark input[class^=ag-]:not([type]),\n.ag-theme-alpine-dark input[class^=ag-][type=text],\n.ag-theme-alpine-dark input[class^=ag-][type=number],\n.ag-theme-alpine-dark input[class^=ag-][type=tel],\n.ag-theme-alpine-dark input[class^=ag-][type=date],\n.ag-theme-alpine-dark input[class^=ag-][type=datetime-local],\n.ag-theme-alpine-dark textarea[class^=ag-] {\n min-height: 24px;\n border-radius: 3px;\n}\n.ag-theme-alpine-dark .ag-ltr input[class^=ag-]:not([type]),\n.ag-theme-alpine-dark .ag-ltr input[class^=ag-][type=text],\n.ag-theme-alpine-dark .ag-ltr input[class^=ag-][type=number],\n.ag-theme-alpine-dark .ag-ltr input[class^=ag-][type=tel],\n.ag-theme-alpine-dark .ag-ltr input[class^=ag-][type=date],\n.ag-theme-alpine-dark .ag-ltr input[class^=ag-][type=datetime-local],\n.ag-theme-alpine-dark .ag-ltr textarea[class^=ag-] {\n padding-left: 6px;\n}\n\n.ag-theme-alpine-dark .ag-rtl input[class^=ag-]:not([type]),\n.ag-theme-alpine-dark .ag-rtl input[class^=ag-][type=text],\n.ag-theme-alpine-dark .ag-rtl input[class^=ag-][type=number],\n.ag-theme-alpine-dark .ag-rtl input[class^=ag-][type=tel],\n.ag-theme-alpine-dark .ag-rtl input[class^=ag-][type=date],\n.ag-theme-alpine-dark .ag-rtl input[class^=ag-][type=datetime-local],\n.ag-theme-alpine-dark .ag-rtl textarea[class^=ag-] {\n padding-right: 6px;\n}\n\n.ag-theme-alpine-dark .ag-tab {\n padding: 9px;\n -webkit-transition: color 0.4s;\n transition: color 0.4s;\n}\n.ag-theme-alpine-dark .ag-tab-selected {\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3);\n}\n.ag-theme-alpine-dark .ag-menu {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n}\n.ag-theme-alpine-dark .ag-menu-header {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n padding-top: 1px;\n}\n.ag-theme-alpine-dark .ag-tabs-header {\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e);\n}\n.ag-theme-alpine-dark .ag-charts-settings-group-title-bar,\n.ag-theme-alpine-dark .ag-charts-data-group-title-bar,\n.ag-theme-alpine-dark .ag-charts-format-top-level-group-title-bar {\n padding: 6px 12px;\n line-height: 20px;\n}\n.ag-theme-alpine-dark .ag-chart-mini-thumbnail {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n}\n.ag-theme-alpine-dark .ag-chart-settings-nav-bar {\n border-top: solid 1px;\n border-top-color: rgba(88, 86, 82, 0.5);\n border-top-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5));\n}\n.ag-theme-alpine-dark .ag-ltr .ag-group-title-bar-icon {\n margin-right: 6px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-group-title-bar-icon {\n margin-left: 6px;\n}\n\n.ag-theme-alpine-dark .ag-charts-format-top-level-group-toolbar {\n margin-top: 6px;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-charts-format-top-level-group-toolbar {\n padding-left: 20px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-charts-format-top-level-group-toolbar {\n padding-right: 20px;\n}\n\n.ag-theme-alpine-dark .ag-charts-format-sub-level-group {\n border-left: dashed 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e);\n padding-left: 6px;\n margin-bottom: 12px;\n}\n.ag-theme-alpine-dark .ag-charts-format-sub-level-group-title-bar {\n padding-top: 0;\n padding-bottom: 0;\n background: none;\n font-weight: 700;\n}\n.ag-theme-alpine-dark .ag-charts-format-sub-level-group-container {\n padding-bottom: 0;\n}\n.ag-theme-alpine-dark .ag-charts-format-sub-level-group-item:last-child {\n margin-bottom: 0;\n}\n.ag-theme-alpine-dark .ag-dnd-ghost {\n font-size: 12px;\n font-weight: 700;\n}\n.ag-theme-alpine-dark .ag-side-buttons {\n width: 30px;\n}\n.ag-theme-alpine-dark .ag-standard-button {\n -moz-appearance: none;\n appearance: none;\n -webkit-appearance: none;\n border-radius: 3px;\n border: 1px solid;\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3);\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n font-weight: 600;\n padding: 6px 12px;\n}\n.ag-theme-alpine-dark .ag-standard-button:hover {\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1));\n}\n.ag-theme-alpine-dark .ag-standard-button:active {\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n background-color: #2196f3;\n background-color: var(--ag-alpine-active-color, #2196f3);\n color: #181d1f;\n color: var(--ag-background-color, #181d1f);\n}\n.ag-theme-alpine-dark .ag-standard-button:disabled {\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n background-color: #282c2f;\n background-color: var(--ag-input-disabled-background-color, #282c2f);\n border-color: rgba(104, 104, 110, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(104, 104, 110, 0.3));\n}\n.ag-theme-alpine-dark .ag-column-drop-vertical {\n min-height: 75px;\n}\n.ag-theme-alpine-dark .ag-column-drop-vertical-title-bar {\n padding: 12px;\n padding-bottom: 0px;\n}\n.ag-theme-alpine-dark .ag-column-drop-vertical-empty-message {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n border: dashed 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n margin: 12px;\n padding: 12px;\n}\n.ag-theme-alpine-dark .ag-column-drop-empty-message {\n color: #fff;\n color: var(--ag-foreground-color, #fff);\n opacity: 0.75;\n}\n.ag-theme-alpine-dark .ag-status-bar {\n font-weight: normal;\n}\n.ag-theme-alpine-dark .ag-status-name-value-value {\n font-weight: 700;\n}\n.ag-theme-alpine-dark .ag-paging-number, .ag-theme-alpine-dark .ag-paging-row-summary-panel-number {\n font-weight: 700;\n}\n.ag-theme-alpine-dark .ag-column-drop-cell-button {\n opacity: 0.5;\n}\n.ag-theme-alpine-dark .ag-column-drop-cell-button:hover {\n opacity: 0.75;\n}\n.ag-theme-alpine-dark .ag-header-cell-menu-button:hover,\n.ag-theme-alpine-dark .ag-side-button-button:hover,\n.ag-theme-alpine-dark .ag-tab:hover,\n.ag-theme-alpine-dark .ag-panel-title-bar-button:hover,\n.ag-theme-alpine-dark .ag-header-expand-icon:hover,\n.ag-theme-alpine-dark .ag-column-group-icons:hover,\n.ag-theme-alpine-dark .ag-group-expanded .ag-icon:hover,\n.ag-theme-alpine-dark .ag-group-contracted .ag-icon:hover,\n.ag-theme-alpine-dark .ag-chart-settings-prev:hover,\n.ag-theme-alpine-dark .ag-chart-settings-next:hover,\n.ag-theme-alpine-dark .ag-group-title-bar-icon:hover,\n.ag-theme-alpine-dark .ag-column-select-header-icon:hover,\n.ag-theme-alpine-dark .ag-floating-filter-button-button:hover,\n.ag-theme-alpine-dark .ag-filter-toolpanel-expand:hover,\n.ag-theme-alpine-dark .ag-chart-menu-icon:hover {\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3);\n}\n.ag-theme-alpine-dark .ag-chart-settings-card-item.ag-not-selected:hover {\n opacity: 0.35;\n}\n.ag-theme-alpine-dark .ag-ltr .ag-panel-title-bar-button {\n margin-left: 12px;\n margin-right: 6px;\n}\n\n.ag-theme-alpine-dark .ag-rtl .ag-panel-title-bar-button {\n margin-right: 12px;\n margin-left: 6px;\n}\n\n.ag-theme-alpine-dark .ag-filter-toolpanel-group-container {\n padding-left: 6px;\n}\n.ag-theme-alpine-dark .ag-filter-toolpanel-instance-filter {\n border: none;\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n border-left: dashed 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e);\n margin-left: 8px;\n padding-left: 8px;\n margin-right: 12px;\n}\n.ag-theme-alpine-dark .ag-set-filter-list {\n padding-top: 3px;\n padding-bottom: 3px;\n}\n.ag-theme-alpine-dark .ag-layout-auto-height .ag-center-cols-clipper, .ag-theme-alpine-dark .ag-layout-auto-height .ag-center-cols-container, .ag-theme-alpine-dark .ag-layout-print .ag-center-cols-clipper, .ag-theme-alpine-dark .ag-layout-print .ag-center-cols-container {\n min-height: 150px;\n}\n.ag-theme-alpine-dark .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 60px;\n}\n.ag-theme-alpine-dark .ag-date-time-list-page-entry-is-current {\n background-color: #2196f3;\n background-color: var(--ag-alpine-active-color, #2196f3);\n}\n", ""]); // Exports module.exports = exports; /***/ }), -/* 230 */ +/* 283 */ /***/ (function(module, exports, __webpack_require__) { -var api = __webpack_require__(225); - var content = __webpack_require__(231); +var api = __webpack_require__(278); + var content = __webpack_require__(284); content = content.__esModule ? content.default : content; @@ -48539,24 +57484,24 @@ var update = api(content, options); module.exports = content.locals || {}; /***/ }), -/* 231 */ +/* 284 */ /***/ (function(module, exports, __webpack_require__) { // Imports -var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227); +var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(280); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, ".ag-theme-alpine {\n -webkit-font-smoothing: antialiased;\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f);\n font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n font-size: 13px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridAlpine\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABNkAAsAAAAAIqAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlMAAAReYc5joU9TLzIAAANcAAAAQAAAAFZWUVJ5Y21hcAAAA5wAAAHqAAAFgHCsDfxnbHlmAAAFiAAACesAABCUC9Ir6mhlYWQAAA90AAAANAAAADZ2zsSBaGhlYQAAD6gAAAAeAAAAJAfSBC5obXR4AAAPyAAAABcAAAEou4D/+2xvY2EAAA/gAAAAbwAAAJbPsst2bWF4cAAAEFAAAAAfAAAAIAFgAHNuYW1lAAAQcAAAATUAAAJG5xgJvXBvc3QAABGoAAABuQAAApPSPvKNeJx9k81SE1EQhc9kQgwJBkREjREU//GPYX4yJiGQMAFisXDhwoUbXGhpUa54Atc+gOUD+BQ+geXSlQ/gA1g+gN/tTAyyIFOZubf79Onuc/vKk1TRmroqZDv7z1U7PDh6r7qKGv2c//jaO3z75kDl8Q5f0b5lef4f1bSiFzrSN0/ea+9zoeQX/K6/73/wP/k/5IO6pkegq1rnCRXxDhQrUVOpCiphC1k/UQu0z7tt1nktaso8mQa6QM6QmIExruqpbmkOnr7x9LQJKuZxnD3euzy3NXsKItUd+BOq2cDqWBvUeU7T2qHGHnV0iG7hncO3ReaAmD6+PrX5hiqajnt6SeS89eYikxwX8w+1bfvAdkuoMEa14W/C7/gek3Vsb5IpIuIh7Amobq7hKv8q3hhMQGzHNHPRSyAjKoy1zMp1FtHZjG7C/kyvdJ+47TymZyqOer5H9RN73/hS8hy3duDaBfuAGiZWdyJ3yRVoiL/CSWV6p4/6oq/6rp/6pd/gF8kSWQebcG+dqsw0+p1EZ3jb/6yu0zOcxUnU/4gKfTdNmxDfIFfQZZvB57SJWQdYY8NX4XT4jGpS9Jpi8gLLG2Etsd9gH4Ku5dPY4jlrOg+YATcBdbRY5+2YRvOWsr9MtFuN6rpoarXguWSn5TR1N2nWdm7m3SnX0fkK34DOEtNnD+9VLI5pYmlYVErVjmMNf0q1k2yuqgZVRcxA2SZraLcgI9N1+hhVEumG3YChTdUKFST5jVzQeau+k5/UguFCi/JQIshvcmyauUnuU5ubit2/LKNqzAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMb0GmMDCC5ADUogpqeJy11IdSWkEYxfE/RdNM79X0jgJiQIogIMhjmO6Y4pju5CnzJt8LxJzlnjyAmcnO/Fh2udy9O3fPB8wABXkqRcgXyZHab83mpvMFjk7ni/zSeI7D5PW9xBY77EV5f1+zJTbZZjdy09HfltPVc1zjPs80WqNClxZ9aoyp0tHsKm0GNKizzhJNlhkyYYUeIzb0/7xWLzLLIa16RM9xTPc7zglOcorTnOEs5zjPBS5yictc4apWu84N5rnJLW5zh7vc0/oPeMgjHvNE+ynp9wUWKesBZzlYWzvg9alVuq1+bVztaLftQaOujTaXh5OV3mjjH272H9pc+ij89GhCepuZtNtNq8hz68oLa8lL68srq8lrG8sbq8pb68iWpROybavyztry3gbywRry0eqyY+uya0vyyZry2Zbliw3lq6W9f7MV+W49+WEj2TO9wMhlUlYinyH1hUzKVhQzKV8xk9GZJkynmzCdc8J04glLGQxTCghLby9MySBMGSFMaSFMuSFMCSJMWSJMqSJM+SJMSSNMmSNM6SNMOSRMiSRM2SRMKSVMeSVMySVMGSVMaSZMuSZMCSdMWSdMqSdM+SdMlYAw1QTCVB0IU50gTBWDMNUOwlRFCEt1MyxlJmz6/AsZUr+YIfXlDOU/rrOgigAAeJzFF21sU9f1nntjvzgJSRx/vJgQg/3ivNSxwxL7+dkx2JAEEmhIqWpYCqMhMCbWdFppM7EBbsd+dEVV1apS6A/yY9O2oFVaQEOb+sFKtZaRqh/qVLQf/fixdkxkXbNRodIZ3mXnXttpApnW/Zr93rnn3nt8zrnnni8TIPihcyxKqgmBgEdVPAEjYOoBOsdrCgW4yu9HeJxFs4VCJlMoCHLbzes3r7NP2afEhr+qIx7SRIhLURXdtJkChhAwVaAuXcBPnn028uqrNIMg8iwfHR4eXidXInKBPrFgMnzv8DD/YiE9qiWEsh7WQypRjmo6Y07VhJPds7nLaX4GrqZnuQ2uz6ZhCx5F0k6wCeImq/CnQcWu2N2qV/V2mQkzEddb9VaXoqOSqBnqBlcPjI6YqZQ5MvpRGRnpPn68e2JCQjaxaEsi1uvlXYTk/yOTle6tFjFF3l3MqekxjyZG+G0+fzafh4P5PFtmvY0XeJAfK+t5mV0mLuITtx2sBY/T7YdYoCsDhjPeAQ4wVVDZD2587o/58WFVcrTm+N+GZmBqiF3G+aLNG5+Dd+gCTN21mL+6NH+GznUb9yetizRyO2fr4oMLeTLJ0xlwhpbiizxZ1S18i4vfvZVv0Xbs++yb6L+VpJEQByiqA5i5Euzi6jxub1fCENdGP+Ej3Xu5BZmZmQunq6t9dd7ODZ3eOh/8Hn6axg3+KqydmcksW+ZvavUFOzuDvtAKv2BfIWVEMa6K91NHSCjgDNg0Z8ylOdPg1Jwsaj1FD/DN8q5eyhdoLM+PiZsq3lbJ7+lp5GFDHSm6DxyEFL+AYcii/AKfKcVj8Tw/ZOfwND7SLC1v92CUBFSJuL1oqATaqVVzoQ70NK/ROnNwNc8NoTK8gVADbsAb7OXOoPUC7b+nU7NeEHu0X+u09tH+Ugw+zZ4WvuYANJfiAB3dBa7Cvb18Cnb08pN8qhd2IKCJRVPYgSTkljgGXUEb6Aqw9TKQYYsIZLjObbMY1IvPHkKBioq2moEk5qGzkIRUduHZn8A4aCIdZK3ga6qJWJcfVoJSCyIp2ZUOuhrMDKg499NYl6nbtWAHGHFTVxNI6VbUhNlBg9C4NjKwfWT75HgzY+6+aDRi7hr7+uT4iooKz9BotM+9fPTowN2b0mGjfVM4UJlsuWdT2D0w1OLbc/RJ+nP87R19h7dWVZu7tI5IIgbQd2hrddWafY7me7rW7zVbuleG+9uN9t1Jd3gg1zKQ3omLC/SvxdwRRf3RpYUyUtdQhpZOQlHh1WDDTfR23ETvpxX9R/f4UPhTR0eXo2r8/IrxyV9J5ZslsqICfhzeFA5v2iYA+My961FkEV7aerhPaFtVGidRp4GwBKWYG0PbK2QZaqR4FKduBGyqxzRMNlZ4qUBPWdPvZ9+jc4XJszBcyGbffy8z+T4p50J6jc7hvTnkbeiKKnISvfbKK+lCgRu5HBjnzqVlbakhNcU4QfpynIjc0URWEo3opJ2sJsTUjJi64A39lznWqbPZ7EsSWm/9p0khX/xkS2OmNKI6lfPnv1UnAlgdQ/i6UI6Br46vWFNwDODIxoSPWm9LViiCnuIziMFv+Aw9IOXyzVmUleXHUIVMJrOEzVzo61iA0WZXpMngYC5Hz0iT8RpyWxxhscYw1ANsfTF0YIsII+qf7eZn+Jnu2XKMTNDzWJ8aSQQlxDOQBkMr+pHEOkDF1BzSPBg6tBbaARHpaz8LrtGmplK7k8ndqakpbU3wORjiv4aDEgdtfhOuamntruTIQyPJu7S0kptCuFGs7D4wkpQ2vXmTzco8fotNA5gTRXG0ic4BlbCJBqQ0F/mSLh8cPHbNvEbbzWsmJpQ3IW4NCrgL5/QT3OFvDg5CvBUxfMy1g4OD4zjic+2PEC/XkOfYc6iFU+bhmAfQKTEZagbogPWSHxsG2sP5h1g07+W8B+gHWTj4oVxjLn7sA7k2n2++9Fe0vzH/LWb08gspvOd8piz/HfZOUf682HlFsvNC0X/KmgilimL/VNZkviZMF/OiSG8qwPfSnKchxaI4dkOy5E+XWL3sz0SmVbG0KaL5oJeuXImcPx+RkPrl8JiE82cr9jEBzKZLdzIQF2isy6tCB0CwVQc/eNyCcKm+hvdEI4Nbdqb2t/NosAW2IALvBlvE4lJtDh/ZuWUwEm0J8mj7fv73liC8274/JdfK+j2Adc6LfqOjfhrmQrui3VLkAl1etz3YGk+AMHDAiLHGU8vWbV237JQsaQMC8g+cPl/Q5wPDej4HP8mxsVBHRwir3z5JcyLY2ag14mM10BMiKRTv8Ag7TIKlKpMoflWzVQxZAMWOhkZTKfY6NLkuegm0eitaBgQFliDVG/MiqsPdz2D2tjmau1ebeyvranwNqhv8nnUb9gNQ5vZE1eN/icAll6Omsn4y0dblhOWVKoVKOlFZVV1X21B/ER55xlFdXVfTVu2oHl3ub2xyNdTyj1Zsq9lnt/mM9q+p1ciBPlVf76r1TtYy1sT/anfrjfGG4xUVoFQ2XBTHqZJnmmbTGImrSBtZTzaSO0mO7CSj5Ft4Rj9VG1gtVSpCHVSnrgw1W2wBpxcrqZmwuVVRmAzpVorucWO90lQ58UrDhNxqzMDaGzPMMKBFYpioPTG9A/SQXVM8MbMVcw1ztm0IA6oU3tDGP+YffzmDZjhkXfjHnBanDqsSaFxbBS9WRbblIo7wxrZxR2TbtkjVupau5X6wXocjhwHy2fidSYBDWfjdIUGP5kiFHz2X7H+U/XJJ/s1ydsN63e5A8rm3nPUoDA5DnWTueLCtv506IjmUAzbF5Q37NyYfeXmz8ei/EqGR7JEjQaRmAEfy8MhtcSkzMp1O8wuQSnP6WVp0a92cLOxn3eSOcoTVC7dZJcxWLyKMBQWUYdYldkrB9fj4gd6+vt4D41Bfxh7/zq4dhmkaO3a9V0bYZbHB/7mY+MaRRUQSKcWT0KUG4z0htJEFoZj49f9Btb6He3sfflyAvq+mJZ0r0SMofGWFb6t9iopFV6TABf8BZT85241/BovnG2Rjsq7KTkbkQPyXG5AdSTEXWh/T09ZWTNYZmJUL/GSWzllvl2UxekLcmssBl6AO6ugJrH5Dpfs+wZjYc9DiKmP8Cr+yeA97V2xtsWTKXy/Ns0hQ2vsFc8l+X/TYJtwPX/Ra5/mfe6BJYH+AlT0luijtFSd04WnOyoLTc9+8faJ0ulgfdOzS6WeyLECKTmOdEC65INePYUXykC6RS0XpB4/Xrqj4pwodAOM5Jnpmz5c9ghFPmCoSqviYQF8rNgFmeG08m9y95xu5Suv5H3UPlDuFns7tKx8aGTgZt/rpa9gOaJEN1Wub9qxJjSSncvDA0cZvr0vJbkHr3GzbnrsPKemLhPwbDwYCEQB4nGNgZGBgAOLsD0FR8fw2Xxm4mV8ABaI4H+9rgNH/f///zfyW+S1QJQcDE5BkAACRug+HeJxjYGRgYH7BwAAi///+/5v5LQMjAyrwAgCe2QcHAAB4nGNgYGBgfgHC/39D6KGH6QEAIHUuCwB4nGNgAAIphiCGDIZFDHcYvjGqMQYwVjGuYTzH+IhJhMmMyYcpgekAMxezBrMDcxfzIeZbzJ9YTFiKWGawbGK5wfKKlY01jHUK6z+2JWw72P6xR7Dnsfexz2Ffxb6D/Rj7LfYX7H84vEiHANyaI6IAeJxjYGRgYPBiSGfgYQABJiDmAkIGhv9gPgMAGzsB1AB4nHWRPU7DQBCFnxMniBghJCREx1Y0SM5PQZEuFHGfIgWdE68dR7bXWm8ipeMYnIBjUHIETsEheDFTREjZ1a6/+fbNNAZwgy94OC4PV+19XB1csPrjLulW2Cc/CPcQ4Em4T/8sPKB9EQ7YWXKC51/S3ONNuINrvAt36T+EffKncA93+Bbu0/8ID7D0fOEAj95rnEU2T2ZFnVd6obNdEdtTdcpLbZvcVGocjk51pCttY6cTtTqoZp9NnEtVak2p5qZyuiiMqq3Z6rULN87V0+EwFR+uTYkYGSJY5EgwQ4GaVEFjwZNhRxPz9VzqnF/yWDSsDGuFMUKMzqYjnqrtiOH4TdixwoF3gz17JrQOKeuUGcO/ojBvJx/TBbehqdu3Lc2aPsSm7aoxxZA7/ZcPmeKkXwK+aWkAAAB4nG2S6W7bMBCE/cWSI9tpk7ptet/3obbpfaf3kT4FQ9EyEYkUSMp28vRl4yBAgO4fzgwWs7MLdpY6ixp0/l9bLNElIaXHMhl9BgxZ4RjHWWWNE4w4ySlOs84ZznKO81zgIpe4zBWuco3r3OAmt7jNHe5yj/s84CE5j3jMEzZ4yjOe84KXvOI1b3jLO97zgY9s8onPfOEr3/jOD37yi99s8aczFGXpVCmCtqYnnLMz3xVe9qQwUlXZ4sk3UjkRLqzJiZI723ae7wNVrB8K2hQqKFdrI4IaHcqtOehckbayLm90JG45krY2fiCtCU7IoIpE2mY3lc56nxTKy0zNGxE9i77aVbmvhJ90I+qNdRXHpGPtfEhKp5u0dLZtktgQkkqNQ6/SJs5brqwotCmzWsx1rfdUUivTZjHfghk1D4mxRg2NDbmoKjtTRdpEF9VttEkbPbUha5yaatv6NRfNbL7dhmBNbsfj1aOCSZ0uJyHxYqoGvo52eWFn5gD+izVcwP22bIFj6hDPMQpOqaP36+9LtlEma81iHwQlDkVAYzHM8EgqJuywzTx+g4KaloZdxuwx7XT+AvL3sQsAAAA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-alpine .ag-icon {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-alpine .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-alpine .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-alpine .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-alpine .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-alpine .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-alpine .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-alpine .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-alpine .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-alpine .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-alpine .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-alpine .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-alpine .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-alpine .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-alpine .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-alpine .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-alpine .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-alpine .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-alpine .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-alpine .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-alpine .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-alpine .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-alpine .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-alpine .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-alpine .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-alpine .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-alpine .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-alpine .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-alpine .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-alpine .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-alpine .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-alpine .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-alpine .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-alpine .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-alpine .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-alpine .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-alpine .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-alpine .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-alpine .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-alpine .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-alpine .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-alpine .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-alpine .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-alpine .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-alpine .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-alpine .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-alpine .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-alpine .ag-root-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-alpine [class^='ag-'], .ag-theme-alpine [class^='ag-']:focus, .ag-theme-alpine [class^='ag-']:after, .ag-theme-alpine [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-alpine [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-alpine .ag-checkbox .ag-input-wrapper,\n .ag-theme-alpine .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-alpine .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-alpine .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-alpine .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 6px; }\n .ag-theme-alpine .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 6px; }\n .ag-theme-alpine input[class^='ag-'] {\n margin: 0;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-alpine textarea[class^='ag-'],\n .ag-theme-alpine select[class^='ag-'] {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-alpine input[class^='ag-']:not([type]),\n .ag-theme-alpine input[class^='ag-'][type='text'],\n .ag-theme-alpine input[class^='ag-'][type='number'],\n .ag-theme-alpine input[class^='ag-'][type='tel'],\n .ag-theme-alpine input[class^='ag-'][type='date'],\n .ag-theme-alpine input[class^='ag-'][type='datetime-local'],\n .ag-theme-alpine textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #babfc7;\n border-color: var(--ag-input-border-color, var(--ag-border-color, #babfc7)); }\n .ag-theme-alpine input[class^='ag-']:not([type]):disabled,\n .ag-theme-alpine input[class^='ag-'][type='text']:disabled,\n .ag-theme-alpine input[class^='ag-'][type='number']:disabled,\n .ag-theme-alpine input[class^='ag-'][type='tel']:disabled,\n .ag-theme-alpine input[class^='ag-'][type='date']:disabled,\n .ag-theme-alpine input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-alpine textarea[class^='ag-']:disabled {\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n background-color: #f1f2f4;\n background-color: var(--ag-input-disabled-background-color, #f1f2f4);\n border-color: rgba(186, 191, 199, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(186, 191, 199, 0.3)); }\n .ag-theme-alpine input[class^='ag-']:not([type]):focus,\n .ag-theme-alpine input[class^='ag-'][type='text']:focus,\n .ag-theme-alpine input[class^='ag-'][type='number']:focus,\n .ag-theme-alpine input[class^='ag-'][type='tel']:focus,\n .ag-theme-alpine input[class^='ag-'][type='date']:focus,\n .ag-theme-alpine input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-alpine textarea[class^='ag-']:focus {\n outline: none;\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-alpine input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-alpine input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-alpine input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-alpine input[class^='ag-'][type='button']:focus, .ag-theme-alpine button[class^='ag-']:focus {\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4); }\n .ag-theme-alpine .ag-drag-handle {\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-list-item, .ag-theme-alpine .ag-virtual-list-item {\n height: 30px; }\n .ag-theme-alpine .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-select-list {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-alpine .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-alpine .ag-list-item.ag-active-item {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-alpine .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-alpine .ag-select .ag-picker-field-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n min-height: 30px;\n cursor: default; }\n .ag-theme-alpine .ag-select:not(.ag-cell-editor) {\n height: 30px; }\n .ag-theme-alpine .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-alpine .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-alpine .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-alpine .ag-rich-select {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8); }\n .ag-theme-alpine .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 273px; }\n .ag-theme-alpine .ag-rich-select-value {\n padding: 0 6px 0 18px;\n height: 42px;\n border-bottom: solid 1px;\n border-bottom-color: #dde2eb;\n border-bottom-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 30px; }\n .ag-theme-alpine .ag-rich-select-virtual-list-item:hover {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine .ag-rich-select-row {\n padding-left: 18px; }\n .ag-theme-alpine .ag-rich-select-row-selected {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3)); }\n .ag-theme-alpine .ag-row-drag,\n .ag-theme-alpine .ag-selection-checkbox,\n .ag-theme-alpine .ag-group-expanded,\n .ag-theme-alpine .ag-group-contracted {\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-ltr .ag-row-drag, .ag-theme-alpine .ag-ltr .ag-selection-checkbox, .ag-theme-alpine .ag-ltr .ag-group-expanded, .ag-theme-alpine .ag-ltr .ag-group-contracted {\n margin-right: 12px; }\n .ag-theme-alpine .ag-rtl .ag-row-drag, .ag-theme-alpine .ag-rtl .ag-selection-checkbox, .ag-theme-alpine .ag-rtl .ag-group-expanded, .ag-theme-alpine .ag-rtl .ag-group-contracted {\n margin-left: 12px; }\n .ag-theme-alpine .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 40px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-alpine .ag-group-expanded,\n .ag-theme-alpine .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-alpine .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-alpine .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-alpine .ag-group-title-bar {\n background-color: #fff;\n background-color: var(--ag-subheader-background-color, #fff);\n padding: 6px; }\n .ag-theme-alpine .ag-group-toolbar {\n padding: 6px; }\n .ag-theme-alpine .ag-disabled-group-title-bar, .ag-theme-alpine .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-alpine .group-item {\n margin: 3px 0; }\n .ag-theme-alpine .ag-label {\n white-space: nowrap; }\n .ag-theme-alpine .ag-ltr .ag-label {\n margin-right: 6px; }\n .ag-theme-alpine .ag-rtl .ag-label {\n margin-left: 6px; }\n .ag-theme-alpine .ag-label-align-top .ag-label {\n margin-bottom: 3px; }\n .ag-theme-alpine .ag-ltr .ag-slider-field, .ag-theme-alpine .ag-ltr .ag-angle-select-field {\n margin-right: 12px; }\n .ag-theme-alpine .ag-rtl .ag-slider-field, .ag-theme-alpine .ag-rtl .ag-angle-select-field {\n margin-left: 12px; }\n .ag-theme-alpine .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-alpine .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #181d1f;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n border-radius: 5px; }\n .ag-theme-alpine .ag-picker-field-wrapper:focus {\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4); }\n .ag-theme-alpine .ag-picker-field-button {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-alpine .ag-color-picker .ag-picker-field-display {\n height: 16px; }\n .ag-theme-alpine .ag-color-panel {\n padding: 6px; }\n .ag-theme-alpine .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-alpine .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-alpine .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-alpine .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-alpine .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-alpine .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-alpine .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-alpine .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-alpine .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-alpine .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-alpine .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-alpine .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-alpine.ag-dnd-ghost {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n border: solid 1px;\n border-color: #dde2eb;\n border-color: var(--ag-secondary-border-color, #dde2eb);\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n height: 48px !important;\n line-height: 48px;\n margin: 0;\n padding: 0 12px;\n -webkit-transform: translateY(12px);\n transform: translateY(12px); }\n .ag-theme-alpine .ag-dnd-ghost-icon {\n margin-right: 6px;\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f); }\n .ag-theme-alpine .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4); }\n .ag-dragging-range-handle .ag-theme-alpine .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-alpine .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-alpine .ag-dialog {\n border-radius: 3px;\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-panel {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-alpine .ag-panel-title-bar {\n background-color: #f8f8f8;\n background-color: var(--ag-header-background-color, #f8f8f8);\n color: #181d1f;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)));\n height: 48px;\n padding: 6px 18px;\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-ltr .ag-panel-title-bar-button {\n margin-left: 6px; }\n .ag-theme-alpine .ag-rtl .ag-panel-title-bar-button {\n margin-right: 6px; }\n .ag-theme-alpine .ag-tooltip {\n background-color: #f8f8f8;\n background-color: var(--ag-header-background-color, #f8f8f8);\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f);\n padding: 6px;\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n border-radius: 3px;\n transition: opacity 1s; }\n .ag-theme-alpine .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px; }\n .ag-theme-alpine .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-alpine .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 12px; }\n .ag-theme-alpine .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 12px; }\n .ag-theme-alpine .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -3px;\n left: -3px;\n display: block;\n width: calc(100% - -6px);\n height: calc(100% - -6px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -3px;\n left: -3px;\n display: block;\n width: calc(100% - -6px);\n height: calc(100% - -6px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-column-select-column-group:not(:last-child),\n .ag-theme-alpine .ag-column-select-column:not(:last-child) {\n margin-bottom: 9px; }\n .ag-theme-alpine .ag-column-select-column-readonly,\n .ag-theme-alpine .ag-column-select-column-group-readonly {\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n pointer-events: none; }\n .ag-theme-alpine .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-column-select-list {\n padding: 12px 12px; }\n .ag-theme-alpine .ag-rtl {\n text-align: right; }\n .ag-theme-alpine .ag-root-wrapper {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n border-radius: 3px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 46px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 46px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-1 {\n padding-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-1 {\n padding-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 74px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 74px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-2 {\n padding-left: 56px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-2 {\n padding-right: 56px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 102px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 102px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-3 {\n padding-left: 84px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-3 {\n padding-right: 84px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 130px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 130px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-4 {\n padding-left: 112px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-4 {\n padding-right: 112px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 158px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 158px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-5 {\n padding-left: 140px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-5 {\n padding-right: 140px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 186px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 186px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-6 {\n padding-left: 168px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-6 {\n padding-right: 168px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 214px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 214px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-7 {\n padding-left: 196px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-7 {\n padding-right: 196px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 242px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 242px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-8 {\n padding-left: 224px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-8 {\n padding-right: 224px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 270px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 270px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-9 {\n padding-left: 252px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-9 {\n padding-right: 252px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 298px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 298px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-10 {\n padding-left: 280px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-10 {\n padding-right: 280px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 326px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 326px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-11 {\n padding-left: 308px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-11 {\n padding-right: 308px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 354px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 354px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-12 {\n padding-left: 336px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-12 {\n padding-right: 336px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 382px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 382px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-13 {\n padding-left: 364px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-13 {\n padding-right: 364px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 410px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 410px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-14 {\n padding-left: 392px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-14 {\n padding-right: 392px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 438px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 438px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-15 {\n padding-left: 420px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-15 {\n padding-right: 420px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 466px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 466px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-16 {\n padding-left: 448px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-16 {\n padding-right: 448px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 494px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 494px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-17 {\n padding-left: 476px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-17 {\n padding-right: 476px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 522px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 522px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-18 {\n padding-left: 504px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-18 {\n padding-right: 504px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 550px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 550px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-19 {\n padding-left: 532px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-19 {\n padding-right: 532px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-alpine .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-alpine .ag-value-change-delta-up {\n color: #43a047;\n color: var(--ag-value-change-delta-up-color, #43a047); }\n .ag-theme-alpine .ag-value-change-delta-down {\n color: #e53935;\n color: var(--ag-value-change-delta-down-color, #e53935); }\n .ag-theme-alpine .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-alpine .ag-value-change-value-highlight {\n background-color: rgba(22, 160, 133, 0.5);\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5));\n transition: background-color 0.1s; }\n .ag-theme-alpine .ag-cell-data-changed {\n background-color: rgba(22, 160, 133, 0.5) !important;\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5)) !important; }\n .ag-theme-alpine .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-alpine .ag-cell-highlight {\n background-color: #2196f3 !important;\n background-color: var(--ag-range-selection-highlight-color, var(--ag-range-selection-border-color, #2196f3)) !important; }\n .ag-theme-alpine .ag-row {\n height: 42px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: #181d1f;\n color: var(--ag-data-color, var(--ag-foreground-color, #181d1f));\n border-width: 1px;\n border-color: #dde2eb;\n border-color: var(--ag-row-border-color, var(--ag-secondary-border-color, #dde2eb)); }\n .ag-theme-alpine .ag-row:not(.ag-row-first) {\n border-top-style: solid; }\n .ag-theme-alpine .ag-row.ag-row-last {\n border-bottom-style: solid; }\n .ag-theme-alpine .ag-row-highlight-above::after, .ag-theme-alpine .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #2196f3;\n background-color: var(--ag-range-selection-border-color, #2196f3);\n left: 1px; }\n .ag-theme-alpine .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-alpine .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-alpine .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-alpine .ag-row-odd {\n background-color: #fcfcfc;\n background-color: var(--ag-odd-row-background-color, #fcfcfc); }\n .ag-theme-alpine .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-row-hover {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-alpine .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-alpine .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-alpine .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-alpine .ag-cell {\n border: 1px solid transparent;\n line-height: 40px;\n padding-left: 17px;\n padding-right: 17px; }\n .ag-theme-alpine .ag-row > .ag-cell-wrapper {\n padding-left: 17px;\n padding-right: 17px; }\n .ag-theme-alpine .ag-row-dragging {\n cursor: move; }\n .ag-theme-alpine .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-alpine .ag-cell-inline-editing {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px;\n padding: 0;\n height: 42px;\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8); }\n .ag-theme-alpine .ag-popup-editor {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px;\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n padding: 0; }\n .ag-theme-alpine .ag-large-text-input {\n height: auto;\n padding: 18px; }\n .ag-theme-alpine .ag-details-row {\n padding: 30px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-alpine .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66)); }\n .ag-theme-alpine .ag-overlay-loading-center {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px; }\n .ag-theme-alpine .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-alpine .ag-loading {\n padding-left: 18px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-alpine .ag-loading-icon {\n padding-right: 12px; }\n .ag-theme-alpine .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-alpine .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-ltr .ag-cell {\n border-right: solid transparent; }\n .ag-theme-alpine .ag-rtl .ag-cell {\n border-left: solid transparent; }\n .ag-theme-alpine .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-alpine .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-alpine .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-row-selected {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3)); }\n .ag-theme-alpine .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(33, 150, 243, 0.2)); }\n .ag-theme-alpine .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1);\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)); }\n .ag-theme-alpine .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)); }\n .ag-theme-alpine .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(33, 150, 243, 0.2))); }\n .ag-theme-alpine .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(33, 150, 243, 0.36)); }\n .ag-theme-alpine .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(33, 150, 243, 0.488)); }\n .ag-theme-alpine .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(33, 150, 243, 0.5904)); }\n .ag-theme-alpine .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #2196f3;\n border-top-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-alpine .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-alpine .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-alpine .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-alpine .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-alpine .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #2196f3;\n border-color: var(--ag-range-selection-border-color, #2196f3);\n outline: initial; }\n .ag-theme-alpine .ag-cell.ag-selection-fill-top,\n .ag-theme-alpine .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #2196f3;\n border-top-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-alpine .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-alpine .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-cell.ag-selection-fill-bottom,\n .ag-theme-alpine .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-alpine .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-alpine .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-fill-handle, .ag-theme-alpine .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #2196f3;\n background-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-ltr .ag-fill-handle, .ag-theme-alpine .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-alpine .ag-rtl .ag-fill-handle, .ag-theme-alpine .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-alpine .ag-fill-handle {\n cursor: cell; }\n .ag-theme-alpine .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-alpine .ag-cell-inline-editing {\n border-color: rgba(33, 150, 243, 0.4) !important;\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)) !important; }\n .ag-theme-alpine .ag-menu {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px;\n padding: 0; }\n .ag-theme-alpine .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 6px;\n padding-bottom: 6px; }\n .ag-theme-alpine .ag-menu-option-part {\n padding-top: 8px;\n padding-bottom: 8px;\n line-height: 16px; }\n .ag-theme-alpine .ag-menu-option-active {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-alpine .ag-menu-option-text {\n margin-left: 6px; }\n .ag-theme-alpine .ag-menu-option-icon {\n padding-left: 12px;\n padding-right: 6px;\n min-width: 28px; }\n .ag-theme-alpine .ag-menu-option-shortcut {\n padding-left: 12px; }\n .ag-theme-alpine .ag-menu-separator {\n height: 12px; }\n .ag-theme-alpine .ag-menu-separator-cell:after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-menu-option-popup-pointer {\n width: 28px;\n text-align: center; }\n .ag-theme-alpine .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-alpine .ag-tab {\n border-bottom: 2px solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n flex: 1 1 auto;\n transition: border-bottom 0.3s; }\n .ag-theme-alpine .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-tab-selected {\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine .ag-menu-header {\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-alpine .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 12px; }\n .ag-theme-alpine .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 12px; }\n .ag-theme-alpine .ag-set-filter-select-all {\n padding-top: 12px; }\n .ag-theme-alpine .ag-set-filter-list {\n height: 180px; }\n .ag-theme-alpine .ag-set-filter-filter {\n margin-top: 12px;\n margin-left: 12px;\n margin-right: 12px; }\n .ag-theme-alpine .ag-filter-to {\n margin-top: 9px; }\n .ag-theme-alpine .ag-mini-filter {\n margin: 12px 12px;\n margin-bottom: 0; }\n .ag-theme-alpine .ag-set-filter-item {\n margin: 0px 12px; }\n .ag-theme-alpine .ag-ltr .ag-set-filter-item-value {\n margin-left: 12px; }\n .ag-theme-alpine .ag-rtl .ag-set-filter-item-value {\n margin-right: 12px; }\n .ag-theme-alpine .ag-filter-header-container {\n padding-bottom: 12px;\n border-bottom: solid 1px;\n border-bottom-color: #dde2eb;\n border-bottom-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-filter-apply-panel {\n padding: 12px 12px;\n border-top: solid 1px;\n border-top-color: #dde2eb;\n border-top-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-alpine .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 12px; }\n .ag-theme-alpine .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 12px; }\n .ag-theme-alpine .ag-simple-filter-body-wrapper {\n padding: 12px 12px;\n padding-bottom: 3px; }\n .ag-theme-alpine .ag-simple-filter-body-wrapper > * {\n margin-bottom: 9px; }\n .ag-theme-alpine .ag-filter-no-matches {\n margin: 12px 12px; }\n .ag-theme-alpine .ag-side-bar {\n position: relative; }\n .ag-theme-alpine .ag-tool-panel-wrapper {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8); }\n .ag-theme-alpine .ag-side-buttons {\n padding-top: 24px;\n width: 20px;\n position: relative;\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f);\n overflow: hidden; }\n .ag-theme-alpine button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 12px 0 12px 0;\n width: 100%;\n margin: 0;\n min-height: 108px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none; }\n .ag-theme-alpine button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-alpine .ag-ltr .ag-side-bar-left,\n .ag-theme-alpine .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-alpine .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-alpine .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 2px solid transparent;\n transition: border-right 0.3s; }\n .ag-theme-alpine .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-alpine .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #2196f3;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine .ag-rtl .ag-side-bar-left,\n .ag-theme-alpine .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-alpine .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-alpine .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 2px solid transparent;\n transition: border-left 0.3s; }\n .ag-theme-alpine .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-alpine .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #2196f3;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine .ag-filter-toolpanel-header {\n height: 36px; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-header, .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 6px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-header, .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 6px; }\n .ag-theme-alpine .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 6px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 6px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-0-header {\n height: 48px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-item {\n margin-top: 3px;\n margin-bottom: 3px; }\n .ag-theme-alpine .ag-filter-toolpanel-search {\n height: 48px; }\n .ag-theme-alpine .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 24px; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 6px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 6px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: #dde2eb;\n border-top-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 6px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 6px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 22px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 22px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 38px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 38px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 54px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 54px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 70px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 70px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 86px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 86px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 102px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 102px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 118px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 118px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 134px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 134px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 150px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 150px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 166px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 166px; }\n .ag-theme-alpine .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 6px; }\n .ag-theme-alpine .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7);\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7);\n padding-top: 6px; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 6px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 6px; }\n .ag-theme-alpine .ag-pivot-mode-panel {\n height: 48px;\n display: flex; }\n .ag-theme-alpine .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-alpine .ag-ltr .ag-pivot-mode-select {\n margin-left: 12px; }\n .ag-theme-alpine .ag-rtl .ag-pivot-mode-select {\n margin-right: 12px; }\n .ag-theme-alpine .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-column-select-header {\n height: 48px;\n align-items: center;\n padding: 0 12px;\n border-bottom: solid 1px;\n border-bottom-color: #dde2eb;\n border-bottom-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: #dde2eb;\n border-bottom-color: var(--ag-secondary-border-color, #dde2eb);\n border-top: solid 1px;\n border-top-color: #dde2eb;\n border-top-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-column-group-icons,\n .ag-theme-alpine .ag-column-select-header-icon {\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-header {\n background-color: #f8f8f8;\n background-color: var(--ag-header-background-color, #f8f8f8);\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-header-row {\n color: #181d1f;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f))); }\n .ag-theme-alpine .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-header-row {\n height: 48px; }\n .ag-theme-alpine .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 6px; }\n .ag-theme-alpine .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 6px; }\n .ag-theme-alpine .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 6px; }\n .ag-theme-alpine .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 6px; }\n .ag-theme-alpine .ag-header-cell,\n .ag-theme-alpine .ag-header-group-cell {\n padding-left: 18px;\n padding-right: 18px; }\n .ag-theme-alpine .ag-header-cell.ag-header-cell-moving,\n .ag-theme-alpine .ag-header-group-cell.ag-header-cell-moving {\n background-color: #fff;\n background-color: var(--ag-header-cell-moving-background-color, var(--ag-background-color, #fff)); }\n .ag-theme-alpine .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-header-icon {\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-alpine .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-alpine .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-alpine .ag-header-row:not(:first-child) .ag-header-cell,\n .ag-theme-alpine .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-header-cell-resize {\n display: flex;\n align-items: center; }\n .ag-theme-alpine .ag-header-cell-resize::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n left: calc(50% - 1px);\n width: 2px;\n height: 30%;\n top: calc(50% - 15%);\n background-color: rgba(186, 191, 199, 0.5);\n background-color: var(--ag-header-column-resize-handle-color, rgba(186, 191, 199, 0.5)); }\n .ag-theme-alpine .ag-pinned-right-header .ag-header-cell-resize::after {\n left: calc(50% - 2px); }\n .ag-theme-alpine .ag-ltr .ag-header-select-all {\n margin-right: 18px; }\n .ag-theme-alpine .ag-rtl .ag-header-select-all {\n margin-left: 18px; }\n .ag-theme-alpine .ag-ltr .ag-floating-filter-button {\n margin-left: 18px; }\n .ag-theme-alpine .ag-rtl .ag-floating-filter-button {\n margin-right: 18px; }\n .ag-theme-alpine .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 16px;\n padding: 0;\n width: 16px; }\n .ag-theme-alpine .ag-filter-loading {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n height: 100%;\n padding: 12px 12px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-alpine .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7);\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n height: 48px; }\n .ag-theme-alpine .ag-paging-panel > * {\n margin: 0 18px; }\n .ag-theme-alpine .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 16px; }\n .ag-theme-alpine .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-alpine .ag-paging-button-wrapper.ag-disabled {\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n cursor: default; }\n .ag-theme-alpine .ag-paging-button-wrapper, .ag-theme-alpine .ag-paging-description {\n margin: 0 6px; }\n .ag-theme-alpine .ag-status-bar {\n border-top: solid 1px;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7);\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n padding-right: 24px;\n padding-left: 24px;\n line-height: 1.5; }\n .ag-theme-alpine .ag-status-name-value-value {\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f); }\n .ag-theme-alpine .ag-status-bar-center {\n text-align: center; }\n .ag-theme-alpine .ag-status-name-value {\n margin-left: 6px;\n margin-right: 6px;\n padding-top: 12px;\n padding-bottom: 12px; }\n .ag-theme-alpine .ag-column-drop-cell {\n background: rgba(24, 29, 31, 0.07);\n background: var(--ag-chip-background-color, rgba(24, 29, 31, 0.07));\n border-radius: 24px;\n height: 24px;\n padding: 0 3px; }\n .ag-theme-alpine .ag-column-drop-cell-text {\n margin: 0 6px; }\n .ag-theme-alpine .ag-column-drop-cell-button {\n min-width: 24px;\n margin: 0 3px;\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-column-drop-cell-drag-handle {\n margin-left: 12px; }\n .ag-theme-alpine .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-alpine .ag-column-drop-horizontal {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n height: 42px;\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-ltr .ag-column-drop-horizontal {\n padding-left: 18px; }\n .ag-theme-alpine .ag-rtl .ag-column-drop-horizontal {\n padding-right: 18px; }\n .ag-theme-alpine .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-column-drop-horizontal-cell-separator {\n margin: 0 6px;\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-column-drop-horizontal-empty-message {\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5)); }\n .ag-theme-alpine .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 18px; }\n .ag-theme-alpine .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 18px; }\n .ag-theme-alpine .ag-column-drop-vertical-list {\n padding-bottom: 6px;\n padding-right: 6px;\n padding-left: 6px; }\n .ag-theme-alpine .ag-column-drop-vertical-cell {\n margin-top: 6px; }\n .ag-theme-alpine .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px;\n border-bottom: solid 1px;\n border-bottom-color: #dde2eb;\n border-bottom-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none; }\n .ag-theme-alpine .ag-column-drop-vertical-icon {\n margin-left: 6px;\n margin-right: 6px; }\n .ag-theme-alpine .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-alpine .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n margin-top: 6px; }\n .ag-theme-alpine .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px;\n background: #fff;\n background: var(--ag-background-color, #fff);\n height: 105px;\n padding: 0; }\n .ag-theme-alpine .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 30px;\n padding-left: 12px; }\n .ag-theme-alpine .ag-select-agg-func-virtual-list-item:hover {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3)); }\n .ag-theme-alpine .ag-chart-menu {\n border-radius: 3px;\n background: #fff;\n background: var(--ag-background-color, #fff); }\n .ag-theme-alpine .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 3px;\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-alpine .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: #dde2eb;\n border-color: var(--ag-secondary-border-color, #dde2eb);\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-alpine .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-alpine .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-alpine .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-alpine .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-alpine .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-alpine .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-alpine .ag-chart-mini-thumbnail.ag-selected {\n border-color: #2196f3;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3))); }\n .ag-theme-alpine .ag-chart-settings-card-item {\n background: #181d1f;\n background: var(--ag-foreground-color, #181d1f);\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-alpine .ag-chart-settings-card-item.ag-selected {\n background-color: #2196f3;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3))); }\n .ag-theme-alpine .ag-chart-data-column-drag-handle {\n margin-left: 6px; }\n .ag-theme-alpine .ag-charts-settings-group-title-bar,\n .ag-theme-alpine .ag-charts-data-group-title-bar,\n .ag-theme-alpine .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: #dde2eb;\n border-top-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-charts-settings-group-container {\n padding: 6px; }\n .ag-theme-alpine .ag-charts-data-group-container {\n padding: 12px 12px;\n padding-bottom: 3px; }\n .ag-theme-alpine .ag-charts-data-group-container > * {\n margin-bottom: 9px; }\n .ag-theme-alpine .ag-charts-format-top-level-group-container {\n margin-left: 12px;\n padding: 6px; }\n .ag-theme-alpine .ag-charts-format-top-level-group-item {\n margin: 6px 0; }\n .ag-theme-alpine .ag-charts-format-sub-level-group-container {\n padding: 12px 12px;\n padding-bottom: 3px; }\n .ag-theme-alpine .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 9px; }\n .ag-theme-alpine .ag-charts-group-container.ag-group-container-horizontal {\n padding: 6px; }\n .ag-theme-alpine .ag-chart-data-section,\n .ag-theme-alpine .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-alpine .ag-chart-menu-panel {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8); }\n .ag-theme-alpine .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-alpine .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-alpine .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-alpine .ag-checkbox-input-wrapper {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #fff;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #fff));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-alpine .ag-checkbox-input-wrapper input, .ag-theme-alpine .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-alpine .ag-checkbox-input-wrapper:focus-within, .ag-theme-alpine .ag-checkbox-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4); }\n .ag-theme-alpine .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-alpine .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #999;\n color: var(--ag-checkbox-unchecked-color, #999);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #2196f3;\n color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #999;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, #999));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 28px;\n height: 18px;\n background-color: #999;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, #999));\n border-radius: 9px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #999)); }\n .ag-theme-alpine .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-alpine .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4); }\n .ag-theme-alpine .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-alpine .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #2196f3;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)));\n border-color: #2196f3;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3))); }\n .ag-theme-alpine .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 18px;\n width: 18px;\n background-color: #fff;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #fff));\n border-radius: 9px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #999))); }\n .ag-theme-alpine .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 18px);\n border-color: #2196f3;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3))); }\n .ag-theme-alpine .ag-radio-button-input-wrapper {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #fff;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #fff));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 16px; }\n .ag-theme-alpine .ag-radio-button-input-wrapper input, .ag-theme-alpine .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-alpine .ag-radio-button-input-wrapper:focus-within, .ag-theme-alpine .ag-radio-button-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4); }\n .ag-theme-alpine .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-alpine .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #999;\n color: var(--ag-checkbox-unchecked-color, #999);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #2196f3;\n color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-alpine input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #babfc7;\n background-color: var(--ag-border-color, #babfc7);\n border-radius: 3px;\n border-radius: 3px; }\n .ag-theme-alpine input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #babfc7;\n background-color: var(--ag-border-color, #babfc7);\n border-radius: 3px;\n border-radius: 3px; }\n .ag-theme-alpine input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #babfc7;\n background-color: var(--ag-border-color, #babfc7);\n border-radius: 3px;\n border-radius: 3px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-alpine input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px;\n -webkit-transform: translateY(-6.5px);\n transform: translateY(-6.5px); }\n .ag-theme-alpine input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px; }\n .ag-theme-alpine input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px; }\n .ag-theme-alpine input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-alpine input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine input[class^='ag-'][type='range']:focus::-ms-thumb {\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine input[class^='ag-'][type='range']:active::-ms-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-alpine .ag-filter-toolpanel-header,\n .ag-theme-alpine .ag-filter-toolpanel-search,\n .ag-theme-alpine .ag-status-bar,\n .ag-theme-alpine .ag-header-row,\n .ag-theme-alpine .ag-panel-title-bar-title {\n font-weight: 700;\n color: #181d1f;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f))); }\n .ag-theme-alpine .ag-ltr .ag-pinned-right-header .ag-header-row:after, .ag-theme-alpine .ag-rtl .ag-pinned-left-header .ag-header-row:before {\n content: '';\n position: absolute;\n height: calc(100% - 20px);\n top: 10px;\n width: 1px;\n background-color: #babfc7;\n background-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-ltr .ag-pinned-right-header .ag-header-row:after {\n right: 0; }\n .ag-theme-alpine .ag-rtl .ag-pinned-left-header .ag-header-row:before {\n left: 0; }\n .ag-theme-alpine .ag-row {\n font-size: 14px; }\n .ag-theme-alpine input[class^='ag-']:not([type]),\n .ag-theme-alpine input[class^='ag-'][type='text'],\n .ag-theme-alpine input[class^='ag-'][type='number'],\n .ag-theme-alpine input[class^='ag-'][type='tel'],\n .ag-theme-alpine input[class^='ag-'][type='date'],\n .ag-theme-alpine input[class^='ag-'][type='datetime-local'],\n .ag-theme-alpine textarea[class^='ag-'] {\n min-height: 24px;\n border-radius: 3px; }\n .ag-theme-alpine .ag-ltr input[class^='ag-']:not([type]),\n .ag-theme-alpine .ag-ltr input[class^='ag-'][type='text'],\n .ag-theme-alpine .ag-ltr input[class^='ag-'][type='number'],\n .ag-theme-alpine .ag-ltr input[class^='ag-'][type='tel'],\n .ag-theme-alpine .ag-ltr input[class^='ag-'][type='date'],\n .ag-theme-alpine .ag-ltr input[class^='ag-'][type='datetime-local'],\n .ag-theme-alpine .ag-ltr textarea[class^='ag-'] {\n padding-left: 6px; }\n .ag-theme-alpine .ag-rtl input[class^='ag-']:not([type]),\n .ag-theme-alpine .ag-rtl input[class^='ag-'][type='text'],\n .ag-theme-alpine .ag-rtl input[class^='ag-'][type='number'],\n .ag-theme-alpine .ag-rtl input[class^='ag-'][type='tel'],\n .ag-theme-alpine .ag-rtl input[class^='ag-'][type='date'],\n .ag-theme-alpine .ag-rtl input[class^='ag-'][type='datetime-local'],\n .ag-theme-alpine .ag-rtl textarea[class^='ag-'] {\n padding-right: 6px; }\n .ag-theme-alpine .ag-tab {\n padding: 9px;\n transition: color 0.4s; }\n .ag-theme-alpine .ag-tab-selected {\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3); }\n .ag-theme-alpine .ag-menu {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8); }\n .ag-theme-alpine .ag-menu-header {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n padding-top: 1px; }\n .ag-theme-alpine .ag-tabs-header {\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-charts-settings-group-title-bar,\n .ag-theme-alpine .ag-charts-data-group-title-bar,\n .ag-theme-alpine .ag-charts-format-top-level-group-title-bar {\n padding: 6px 12px;\n line-height: 20px; }\n .ag-theme-alpine .ag-chart-mini-thumbnail {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-alpine .ag-chart-settings-nav-bar {\n border-top: solid 1px;\n border-top-color: #dde2eb;\n border-top-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-ltr .ag-group-title-bar-icon {\n margin-right: 6px; }\n .ag-theme-alpine .ag-rtl .ag-group-title-bar-icon {\n margin-left: 6px; }\n .ag-theme-alpine .ag-charts-format-top-level-group-toolbar {\n margin-top: 6px; }\n .ag-theme-alpine .ag-ltr .ag-charts-format-top-level-group-toolbar {\n padding-left: 20px; }\n .ag-theme-alpine .ag-rtl .ag-charts-format-top-level-group-toolbar {\n padding-right: 20px; }\n .ag-theme-alpine .ag-charts-format-sub-level-group {\n border-left: dashed 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7);\n padding-left: 6px;\n margin-bottom: 12px; }\n .ag-theme-alpine .ag-charts-format-sub-level-group-title-bar {\n padding-top: 0;\n padding-bottom: 0;\n background: none;\n font-weight: 700; }\n .ag-theme-alpine .ag-charts-format-sub-level-group-container {\n padding-bottom: 0; }\n .ag-theme-alpine .ag-charts-format-sub-level-group-item:last-child {\n margin-bottom: 0; }\n .ag-theme-alpine .ag-dnd-ghost {\n font-size: 12px;\n font-weight: 700; }\n .ag-theme-alpine .ag-side-buttons {\n width: 30px; }\n .ag-theme-alpine .ag-standard-button {\n -moz-appearance: none;\n appearance: none;\n -webkit-appearance: none;\n border-radius: 3px;\n border: 1px solid;\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3);\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n font-weight: 600;\n padding: 6px 12px; }\n .ag-theme-alpine .ag-standard-button:hover {\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine .ag-standard-button:active {\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n background-color: #2196f3;\n background-color: var(--ag-alpine-active-color, #2196f3);\n color: #fff;\n color: var(--ag-background-color, #fff); }\n .ag-theme-alpine .ag-standard-button:disabled {\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n background-color: #f1f2f4;\n background-color: var(--ag-input-disabled-background-color, #f1f2f4);\n border-color: rgba(186, 191, 199, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(186, 191, 199, 0.3)); }\n .ag-theme-alpine .ag-menu-header {\n min-width: 240px; }\n .ag-theme-alpine .ag-column-drop-vertical {\n min-height: 75px;\n max-height: 175px; }\n .ag-theme-alpine .ag-tool-panel-wrapper {\n width: 250px; }\n .ag-theme-alpine .ag-column-drop-vertical-title-bar {\n padding: 12px;\n padding-bottom: 0px; }\n .ag-theme-alpine .ag-column-drop-vertical-empty-message {\n display: flex;\n align-items: center;\n border: dashed 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n margin: 12px;\n padding: 12px; }\n .ag-theme-alpine .ag-column-drop-empty-message {\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f);\n opacity: 0.75; }\n .ag-theme-alpine .ag-status-bar {\n font-weight: normal; }\n .ag-theme-alpine .ag-status-name-value-value {\n font-weight: 700; }\n .ag-theme-alpine .ag-paging-number, .ag-theme-alpine .ag-paging-row-summary-panel-number {\n font-weight: 700; }\n .ag-theme-alpine .ag-column-drop-cell-button {\n opacity: 0.5; }\n .ag-theme-alpine .ag-column-drop-cell-button:hover {\n opacity: 0.75; }\n .ag-theme-alpine .ag-header-cell-menu-button:hover,\n .ag-theme-alpine .ag-side-button-button:hover,\n .ag-theme-alpine .ag-tab:hover,\n .ag-theme-alpine .ag-panel-title-bar-button:hover,\n .ag-theme-alpine .ag-header-expand-icon:hover,\n .ag-theme-alpine .ag-column-group-icons:hover,\n .ag-theme-alpine .ag-group-expanded .ag-icon:hover,\n .ag-theme-alpine .ag-group-contracted .ag-icon:hover,\n .ag-theme-alpine .ag-chart-settings-prev:hover,\n .ag-theme-alpine .ag-chart-settings-next:hover,\n .ag-theme-alpine .ag-group-title-bar-icon:hover,\n .ag-theme-alpine .ag-column-select-header-icon:hover,\n .ag-theme-alpine .ag-floating-filter-button-button:hover,\n .ag-theme-alpine .ag-filter-toolpanel-expand:hover,\n .ag-theme-alpine .ag-chart-menu-icon:hover {\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3); }\n .ag-theme-alpine .ag-chart-settings-card-item.ag-not-selected:hover {\n opacity: 0.35; }\n .ag-theme-alpine .ag-ltr .ag-panel-title-bar-button {\n margin-left: 12px;\n margin-right: 6px; }\n .ag-theme-alpine .ag-rtl .ag-panel-title-bar-button {\n margin-right: 12px;\n margin-left: 6px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-container {\n padding-left: 6px; }\n .ag-theme-alpine .ag-filter-toolpanel-instance-filter {\n border: none;\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n border-left: dashed 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7);\n margin-left: 13px;\n padding-left: 8px;\n margin-right: 12px; }\n .ag-theme-alpine .ag-set-filter-list {\n padding-top: 3px;\n padding-bottom: 3px; }\n .ag-theme-alpine .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 60px; }\n .ag-theme-alpine .ag-date-time-list-page-entry-is-current {\n background-color: #2196f3;\n background-color: var(--ag-alpine-active-color, #2196f3); }\n\n", ""]); +exports.push([module.i, ".ag-theme-alpine {\n -webkit-font-smoothing: antialiased;\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f);\n font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n font-size: 13px;\n line-height: normal;\n}\n@font-face {\n font-family: \"agGridAlpine\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABWoAAsAAAAAJ9AAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAmYAAAR2ZcBn9U9TLzIAAANwAAAAQQAAAFZWUVMIY21hcAAAA7QAAAIcAAAFnIMq5ipnbHlmAAAF0AAAC80AABVszjC1ZWhlYWQAABGgAAAANAAAADZ2zsSBaGhlYQAAEdQAAAAeAAAAJAfSBDFobXR4AAAR9AAAABcAAAE0xzj/+2xvY2EAABIMAAAAdQAAAJwYJx3EbWF4cAAAEoQAAAAfAAAAIAFjAKpuYW1lAAASpAAAATUAAAJG5xgJvXBvc3QAABPcAAAByQAAAqgIzxhUeJx9lEtyElEUhv+mm0gCJilFjRhjovEVXzF2uhuaRx4QEDJwYFkOnMSyyrKKcsQ6XIAryNAVuAAHrsAFOHDo2PK7h0ZMBuEWze3z+M9//3Mu8iTNaVNN5doHhy81PzwafVRFgcYf5/9/7w0/vD9SYfKGL7DfgrygpHnd1GuN9M2b90beca7sV/xX/jv/s//F/yWfqFU9JrqobVakmGeoRFXVlCqnGWwR+7oaRPs8m2a9oKvKm6ernpaoGZHTM8QN9XVPi+B0DKetPaISlsNs8xyw7mvhjIgUlDy+be1gDVBkBU3qKmtWz2HZhkmL/Ab+i9Tcp3ZIVgdfB3Z5LE32LV2Ck8sITNWe3ugpfndSh1LNchK+kQ7sPbS3NTSZRDXBqVHLYW/BYGKvgReTsQl6lajdTNEN3SK7Bk4btJZl1y17jcgYbgl9CeycMVxLWmf/Qm/pRREW45y2aTpW4CHsp/aO4aV6dMLaAmtA7BM4TK2uPw+oFdKVGPQlfEN90rG+6rt+6Kd+64/O6TJ1YjvDHuj7Z2pTQMHT0V28zX9Wd9YZZuB01MmIWU5eM3UifL1MQ1etyMmcOgn7EGti8XPwdPFd2KT0I6BGaHVdp/OsHd4jos9n09lglUzpHlOwYBPct1moMKNbum6I4zlM0XoZRLcb86uYbg3wrlnfnLruhi3am7sLrt8VurPCb8gJq6bTId5VLA5parlhWSnsHcYz/Cmsp9Ucq2VYhbqLz81Y325Hl0rrnGfMJNYduxl9m6/bMKhmN7VMDx37VtaxKxYXWZbHP0GY3fDEtHMz3YGbm4/BX0ArchMAAHicY2BkmsY4gYGVgYGpimkPAwNDD4RmfMBgyMgEFGVgZWbACgLSXFMYDjDofjRifgHkRjG/BZnCwAiSAwDkfwr5AAAAeJy11AdSG0EQheFfgSxwIOecEWCCySCiEHAJnCkcKJw5h8/me/QJ8Bt1+wC4ylv1qXdGq92ZWr0GaoCczEkesvVkdEYmq9lMdT5HY3U+z2+NC9ST1XmRK264s6X7e80WueSaW8tUR3+PjK4u0McEzzU6YoUDdjlmjXNWKbHBPnucsMUmp7pmh3XKnLHNIRUu9Pu0irzWWEudntuglTTpjs208JgntNJGOx100kU3PfTqWf0MMMgQw4wwyhjjevokU0wzw6x2U2SeBRb1/TOWWNYia3nYcfTA69OxcrB7vHa+WtKO9062NrXZnfXy2fZh5eIfbvYfjkL6yP2K0Tnpjbq028uwIi/CgbwMu/IqHMvrsCZvQrrn27Aq70JJrsKGXId9eR/25EM4kY9hSz6FTbkJp3Ib0j/vc9iRL2FdvoayfAtn8j1sy49wKD9DRe6CXqBlXMqLZR2p5lzKl+VdypjVuJQ9q3WkWudItd6RaoMj1UaXMmlNjlQLLr1Ja3ak2uJI9ZFTdrCgFGFBecKeOiULa3XKGNbmlDas3Sl3WIdTArFOpyxiXU6pxLqd8on1OCUV63XKLNbnlF6s3ynH2IBTorFBp+xiQ04px4ad8o6NOCUfG3XqAdiYUzfAxp36Ajbh1CGwSadegU05dQ1s2ql/YDMu9UubdSknNufUXbCiU5/B5p06DrbgqutfdOpCWFA/wgLLfwB3H6YceJztWHtwVNUZv9852b179/2+WUI22b3ZXNjshib7uEkWdkMSSMAQcVwwQDFEikONtqK0KBAR/2hNHavjDPgH6Uw7bcPUmUZaph0VKk6VEkeldqTtDOof1dKSqmlxGLGBvfQ7Z3dDAqnaPzttsnvej+98z9+3Agj4R6ZoXLAIAoR8sugLpUKaGiJTunV6Gi7qd2F5kMZz09PZ7PQ0W264evnqZfoR/Ugw4C6H4BOqBMEjyqKqGTRWRrCgMmt6VFZ+8PTTsZdfJlksYk/rg/39/e18JMYHyGOzOv0b+vv1T2evR7LYpbSDdggS3iNrroRL1iQ43DaZP5/Rj+pH4WJmUjfA5ckMrNGPCoSvP0APCF6hFreHRaNo9Mp+2d+spbV0Uq1X6z2iioQidUgfXNwxOKC1tmoDg++VGwNtBw+2HTjAS3pgzhRvFF4tz2LJrivx0Y4tkfMy4VLUhE9hNfxyePj48DDsGh6mtsJpZOgufUQo0Xmenhc8QoBxP2wHn8sbhESoOQspV7IRJNBkkOmDVz4JJoL4oWZeF6b0v/VNwFgfPY/9OZNXPgF/3ykYu3nu+fL851MU9g2nP144Q2I3nlw4c+/sMyk/0xVyReY7F8+k5uvOLQ5+/fpzi7yjD9CvoD6ZhEpBkECUJaBaDRiZ6Hxef3M6xcRGPtAH2rbqBchOTJw6YrEEHP6mFU1+RwB+DT/I4IT+MiybmMjabMGq+kC4qSkciCwMsuMr+B1x1POifByCEAm5QgbFlfAorgy4FBeNF54gO/TVXFbHhqdJYlgfYZIqSqukh+QInmFAGgmqD+yCVv0UmgWN66f0iZJ9FN/zMD2BrwkI1ZzzRh9qbUjmDa8fGZVGPtUrHqSBHNGtSlMeLg7rKUYyvIalAnoKXqMvNoULz5PuW5uUwvNsjnQrTYVtpLtkE0/SJ5muSYDsEiVQUV3gImzo1MdgY6d+WB/rhI1YkPScLmzEJbjdKAhXr9Cv0Q8FJ2pItdAjPCx8D6lF81ANswilSgrlLBtlfwY8Ea+dKOHGilQySxLNQfB5jeF6tREU3IAq0JzWstDsl712HMHhVDLdHKQJJr9GUBtJMgu4i5Q2FffUgF8OEjTFtNaEm4Pg9TnATsKNsITidj+9R7zzXoPep2qaStKqtvKo3gEjBKjBeZboA5I76HXKXqfZYKsMeeQ6j9lmqjB5HfJCq1zrNxKT3fwzd9hf7bI5JbtJNDmsLr/F7fRWudw1fnely2S2iRUGR9BttBjcbovNbV7aECWUmCwmA0kR0eywGkmCgtltIn81ffMRA2lRr/yWEzPy5pXv0Ad+H5BchSf/aK0JekzuqtqIL5yq9y5U3ZLDbPN5k821Df7KSrPD7ggs9jssEbfFbgm4rLLb7jIZRU+oMeKx+Sp9TrPF4fbYJItERdEgeqq/e+y4ZDGaRZvZIJ2RHCbJLp12SGanW/i/7P6rZTcnnoEqou9R0Xrpch7QYA3+Y0CDy7phEsMbrCn5rznyXvW5stZYmEumE83+GsgRJjq/z+sAGUVkh3D9EhCZMtSnkp8toviGmyTR4HW4PM6l7Wa70WZyeHx9eatZcnvdFf23VUguHPks5k48OGS3WfxOT+XGjQ63weC0uqrvedDhc9slybhvt9FkdDnc/ytvnBNDIui4RRljzgS0IL46Di3QmpsdQx5DPFElNArLmJ5ocpoZbQ0+ChjYMipGtDJAm5VxIIgWreFYmNmtpsppZouinNYaSRgql8V61g+sH91ZTam3Kx6PaZuHbhvdubCiwtc3GO/yLhjc33PLqkw01bAqGjK11N26Kurt6asL3LH/cfIj3Lu4a89as0XbrDTG0glYsXutxbx0m1R9a/PyrVpdW020uyHVsKXFG+3J1/VkNuHgLPrtiMHiSD9CA0YLJzWSJaWXcE8BBpxEH4OT6FJIRff+OwJ49xP7BxcgZfrJhTtHf8ppr+aNhRXw7eiqaHTVOlZAQNu6HK8slufW7ulixJpL9SjS1BPlRQm7DCHvRcGGFIk+0aWmQgbZp6U0OjR9bJo8Wxh/O3eWTE2PHof+6Vzu7bPZ0be5yHhxiUyh3LjVaqooM2xHLr30UmZ6Wk/l85A6cSLDMbNVsBbxBq4v4w2GwaqEGkERVKFBWCIImpJKyLO+kc/pI/4+nssd42XhjX/XmR4u/uVKdbZUIzmmmfdfT5MAiPoj+PXgPSn8qvhlYyLWIazpENPRwml+FF5BntUnsAW/0CfIDn6vvjqHd+X0ESQhm83OwzMP6jomFsizC5xlsCufJ0c5y3TrXL9oYphJY3BGDdHlZT/IfCIJTrYxyN82WbaRA+QkZiABtBLBgxEqAymlqEe8hdYgI8aNKD4WuuzQANjgyqb8MLxUGRtr3dLSsqV1bExZGn4G+vSfwy7eBuXaJFxUMsrNLQP3DbTcjK1ofgyrlWxoy46BFs7Xq1fpJMfE1/E1hPiSJRoGlhUhHQaWXJX6DHuSBb29I5e0S6RBu6QhOHsdkoVeVm7GPvkAZ/TXe3shWY8t/GjLent7d2KNn0u/g2QZjz9Dn0EqXBzTJnyAionAEj2lCph76CP9QDp0/V1MQDbo6PfIOznY9S4fox595B0+NuNzruksyiA1819Ex+UvtKKsh7Pl+9+kbxbvn7l2hpDczKWoQ2VKGFHFa/9QpmTGN44XfSNzcTLANzK6noFWGse6DVpKOnWOOnnuyaKnjGmCyBI5cu7ChdjJkzFekiCvvsXLmbcVc8IQ05V5s0JIsiZGERkaAQOICgwksYXz5Yh6RzzWu2ZT6/YGPR6ugzXYgLfCdWxwvpRRH9i0pjcWrwvr8Ybt+od1YXirYXsrHyvTdzfmDD4hKNQjfQqDWKIyN2EINfsZ/EqmgfE3lErQynF7+9p227M8O+jBUn/BFQiEAwFIFZ7Lw/fzdCjS2BjBPGIbX3Io3FSpVOKn4CaHuFsoyXAv3YMa28Z9W7r4L2v1WIFoRC4jn0SjA/mtsqQMWV6PbAG2CkOQ7E/4sanCLU+h+zZI1W1LtK32tupaCPraV2wHINTri8sH/xyDcx7JanKOphc1u2CBSSZgIgdMCJ/sbucZeOgpyWJxWBdZJMtg47KgT39v4TrrNqMhkGr4kmzB7eQJp9Nj94/aKa3S/2L0qpVJ98GKChBN7jOCmb9jnI6j9dUKi4TlwkrhJiEvbBIGhTvxXUEiu6mdiBWRRqIST5ZodYaQy48BVEsbvDILSCmuSqLqQ/wgKjLv+DkzIl45kVKNYiKlRQEZkUAH7UsgDlYjRkX0JbR6dDHUtWhFFJCe6IpF+vv6+9d6UA27C6f+PqUkiVQwAUkqtfCCObYuH5OiKxftlGLr1sXM7XXNC4JQeBX27gEYziVvagHYnYNf7WbrkRet0X0nWrr30Z/Me341710pvGqUcPnUGy4nXgZ7wMEPl+5d1N1ApFge7wGEqP5ocGXLQy+uTu37ZzoykNu7N4yrKcDeYXjoBlvknpiMZ/RT0JrRyccZlu226cLs3wO8wuKyVTmZttQytjmZVdEwh2ms38xmSgb16M4dnV1dnTt2grPcevSezRtTmpbauPlsuUHPswn9H3MXX9k7ZxFvlGyI0WJFG08zanggKPp79T8grev+zs77H2VF1xejkkyV1mMx/YUJviEXEGUMtuy3j7m/aPHMYLKNZQbXsGEvHeJxlSMZ5v8A93JEUvSDhffJkcJadNRZmOQD+uEcmSqcLt9JySEmPY8E58ABDnIIY19fSe6HKGVzEimOUqpf0C/MnUPsivRgwOS75z+zuKA092Pq4b+bsN8qNLgLPu0snNT/1AFVrPUbqOkorYuTTvZCD77mOA82HbfP8ClOxouxgeVL5GMeEqCVjGOMYKo5y88PCW7BLySYH/XxVNdvFOUssExWQcNOMMzsmwUSkmlNxpUyfjQgrxQxgBZdlswhAFj85byp8NwjbT1lpNDRtL7mvoGew8lCN3mFYYLYCsuyqjuWtg60jOXh7v2VX21vLYKFptWG9fnbcSV54V8PFbSvAAAAeJxjYGRgYADiJZeya+P5bb4ycDO/AApEcT7e1wCj///+/5v5LfNboEoOBiYgyQAAoN8P3nicY2BkYGB+wcAAIv///v+b+S0DIwMq8AUAntwHCgAAeJxjYGBgYH4Bwv9/Q+ihjekBAG/aMMwAeJxjYAACKYYghiyGJQz7GN4xSjA6MZYwTmNcxXiH8R/THeZdzFdY3Fh2sJxh1WEtY53Cuob1G5semxtbHNsitgfsbOwK7G7sEewl7Ec4mDjSOHk4FTjTOA9w3uL8xcXBJcalwmXE5cYVwpXBtY10CAAggCv3AAAAeJxjYGRgYPBlmMfAwwACTEDMBYQMDP/BfAYAIOsCDgB4nHWRPU7DQBCFnxMniBghJCREx1Y0SM5PQZEuFHGfIgWdE68dR7bXWm8ipeMYnIBjUHIETsEheDFTREjZ1a6/+fbNNAZwgy94OC4PV+19XB1csPrjLulW2Cc/CPcQ4Em4T/8sPKB9EQ7YWXKC51/S3ONNuINrvAt36T+EffKncA93+Bbu0/8ID7D0fOEAj95rnEU2T2ZFnVd6obNdEdtTdcpLbZvcVGocjk51pCttY6cTtTqoZp9NnEtVak2p5qZyuiiMqq3Z6rULN87V0+EwFR+uTYkYGSJY5EgwQ4GaVEFjwZNhRxPz9VzqnF/yWDSsDGuFMUKMzqYjnqrtiOH4TdixwoF3gz17JrQOKeuUGcO/ojBvJx/TBbehqdu3Lc2aPsSm7aoxxZA7/ZcPmeKkXwK+aWkAAAB4nG2SB2/bMBSE/cWS7dhp46ZtuvceapvuvXeb/geGomUiEimQlO3k15e1gwAB+gASd4eHe8cHtpZai+q3/l+bLNEmIaVDlx7L9BmwwiEOs8qQI6xxlGMcZ50TnOQUpznDWc5xngtc5BKXucJVrnGdG9zkFre5w10y7nGfB2zwkEc85glPecZzXvCSV7zmDW95x3s+8JFPfOYLX/nGd37wk1/8ZpM/rYEoCqcKEbQ1HeGcnfq28LIjhZGqTOVYuDCUYyW3t+wsmwOVr+8L2uQqKFdpI4Ja25cbs9e5Im1pXVbrSFw3kqYyvi+tCU7IoPJE2nonlc5635Z+ksaTbSS58jJVsxigO7+zjZ6a1SLOypfVjsp8Kfy4HVFnpMs4Ph1p50NSOF2nhbNNncSGkJRqFDqlNjFHt7Qi16boVWKmK72rkkqZphdzL5hRs5AYa9TA2JCJsrRTlad1dFHtWpu01hMberVTE20bP3TRzGZbTQjWZHY0Wj0omNTpYhwSLyaq76tol+V2avbgv1iDBZy39RY4pg5xTWvBKXVwr8tzydbK9BqzeA+CAocioLEYpngkJWO22WIW/0ZORUPNDhNG7LZafwFegLa2AAAA\") format(\"woff\");\n font-weight: normal;\n font-style: normal;\n}\n.ag-theme-alpine .ag-icon {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n.ag-theme-alpine .ag-icon-aggregation::before {\n content: \"\\f101\";\n}\n.ag-theme-alpine .ag-icon-arrows::before {\n content: \"\\f102\";\n}\n.ag-theme-alpine .ag-icon-asc::before {\n content: \"\\f103\";\n}\n.ag-theme-alpine .ag-icon-cancel::before {\n content: \"\\f104\";\n}\n.ag-theme-alpine .ag-icon-chart::before {\n content: \"\\f105\";\n}\n.ag-theme-alpine .ag-icon-color-picker::before {\n content: \"\\f109\";\n}\n.ag-theme-alpine .ag-icon-columns::before {\n content: \"\\f10a\";\n}\n.ag-theme-alpine .ag-icon-contracted::before {\n content: \"\\f10b\";\n}\n.ag-theme-alpine .ag-icon-copy::before {\n content: \"\\f10c\";\n}\n.ag-theme-alpine .ag-icon-cross::before {\n content: \"\\f10d\";\n}\n.ag-theme-alpine .ag-icon-csv::before {\n content: \"\\f10e\";\n}\n.ag-theme-alpine .ag-icon-desc::before {\n content: \"\\f10f\";\n}\n.ag-theme-alpine .ag-icon-excel::before {\n content: \"\\f110\";\n}\n.ag-theme-alpine .ag-icon-expanded::before {\n content: \"\\f111\";\n}\n.ag-theme-alpine .ag-icon-eye-slash::before {\n content: \"\\f112\";\n}\n.ag-theme-alpine .ag-icon-eye::before {\n content: \"\\f113\";\n}\n.ag-theme-alpine .ag-icon-filter::before {\n content: \"\\f114\";\n}\n.ag-theme-alpine .ag-icon-first::before {\n content: \"\\f115\";\n}\n.ag-theme-alpine .ag-icon-grip::before {\n content: \"\\f116\";\n}\n.ag-theme-alpine .ag-icon-group::before {\n content: \"\\f117\";\n}\n.ag-theme-alpine .ag-icon-last::before {\n content: \"\\f118\";\n}\n.ag-theme-alpine .ag-icon-left::before {\n content: \"\\f119\";\n}\n.ag-theme-alpine .ag-icon-linked::before {\n content: \"\\f11a\";\n}\n.ag-theme-alpine .ag-icon-loading::before {\n content: \"\\f11b\";\n}\n.ag-theme-alpine .ag-icon-maximize::before {\n content: \"\\f11c\";\n}\n.ag-theme-alpine .ag-icon-menu::before {\n content: \"\\f11d\";\n}\n.ag-theme-alpine .ag-icon-minimize::before {\n content: \"\\f11e\";\n}\n.ag-theme-alpine .ag-icon-next::before {\n content: \"\\f11f\";\n}\n.ag-theme-alpine .ag-icon-none::before {\n content: \"\\f120\";\n}\n.ag-theme-alpine .ag-icon-not-allowed::before {\n content: \"\\f121\";\n}\n.ag-theme-alpine .ag-icon-paste::before {\n content: \"\\f122\";\n}\n.ag-theme-alpine .ag-icon-pin::before {\n content: \"\\f123\";\n}\n.ag-theme-alpine .ag-icon-pivot::before {\n content: \"\\f124\";\n}\n.ag-theme-alpine .ag-icon-previous::before {\n content: \"\\f125\";\n}\n.ag-theme-alpine .ag-icon-right::before {\n content: \"\\f128\";\n}\n.ag-theme-alpine .ag-icon-save::before {\n content: \"\\f129\";\n}\n.ag-theme-alpine .ag-icon-small-down::before {\n content: \"\\f12a\";\n}\n.ag-theme-alpine .ag-icon-small-left::before {\n content: \"\\f12b\";\n}\n.ag-theme-alpine .ag-icon-small-right::before {\n content: \"\\f12c\";\n}\n.ag-theme-alpine .ag-icon-small-up::before {\n content: \"\\f12d\";\n}\n.ag-theme-alpine .ag-icon-tick::before {\n content: \"\\f12e\";\n}\n.ag-theme-alpine .ag-icon-tree-closed::before {\n content: \"\\f12f\";\n}\n.ag-theme-alpine .ag-icon-tree-indeterminate::before {\n content: \"\\f130\";\n}\n.ag-theme-alpine .ag-icon-tree-open::before {\n content: \"\\f131\";\n}\n.ag-theme-alpine .ag-icon-unlinked::before {\n content: \"\\f132\";\n}\n.ag-theme-alpine .ag-icon-row-drag::before {\n content: \"\\f116\";\n}\n.ag-theme-alpine .ag-left-arrow::before {\n content: \"\\f119\";\n}\n.ag-theme-alpine .ag-right-arrow::before {\n content: \"\\f128\";\n}\n.ag-theme-alpine .ag-root-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-alpine [class^=ag-], .ag-theme-alpine [class^=ag-]:focus, .ag-theme-alpine [class^=ag-]:after, .ag-theme-alpine [class^=ag-]:before {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n outline: none;\n}\n.ag-theme-alpine [class^=ag-]::-ms-clear {\n display: none;\n}\n.ag-theme-alpine .ag-checkbox .ag-input-wrapper,\n.ag-theme-alpine .ag-radio-button .ag-input-wrapper {\n overflow: visible;\n}\n.ag-theme-alpine .ag-range-field .ag-input-wrapper {\n height: 100%;\n}\n.ag-theme-alpine .ag-toggle-button {\n -webkit-box-flex: 0;\n flex: none;\n width: unset;\n min-width: unset;\n}\n.ag-theme-alpine .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 6px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 6px;\n}\n\n.ag-theme-alpine input[class^=ag-] {\n margin: 0;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-alpine textarea[class^=ag-],\n.ag-theme-alpine select[class^=ag-] {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-alpine input[class^=ag-]:not([type]),\n.ag-theme-alpine input[class^=ag-][type=text],\n.ag-theme-alpine input[class^=ag-][type=number],\n.ag-theme-alpine input[class^=ag-][type=tel],\n.ag-theme-alpine input[class^=ag-][type=date],\n.ag-theme-alpine input[class^=ag-][type=datetime-local],\n.ag-theme-alpine textarea[class^=ag-] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #babfc7;\n border-color: var(--ag-input-border-color, var(--ag-border-color, #babfc7));\n}\n.ag-theme-alpine input[class^=ag-]:not([type]):disabled,\n.ag-theme-alpine input[class^=ag-][type=text]:disabled,\n.ag-theme-alpine input[class^=ag-][type=number]:disabled,\n.ag-theme-alpine input[class^=ag-][type=tel]:disabled,\n.ag-theme-alpine input[class^=ag-][type=date]:disabled,\n.ag-theme-alpine input[class^=ag-][type=datetime-local]:disabled,\n.ag-theme-alpine textarea[class^=ag-]:disabled {\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n background-color: #f1f2f4;\n background-color: var(--ag-input-disabled-background-color, #f1f2f4);\n border-color: rgba(186, 191, 199, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(186, 191, 199, 0.3));\n}\n.ag-theme-alpine input[class^=ag-]:not([type]):focus,\n.ag-theme-alpine input[class^=ag-][type=text]:focus,\n.ag-theme-alpine input[class^=ag-][type=number]:focus,\n.ag-theme-alpine input[class^=ag-][type=tel]:focus,\n.ag-theme-alpine input[class^=ag-][type=date]:focus,\n.ag-theme-alpine input[class^=ag-][type=datetime-local]:focus,\n.ag-theme-alpine textarea[class^=ag-]:focus {\n outline: none;\n -webkit-box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine input[class^=ag-]:not([type]):invalid,\n.ag-theme-alpine input[class^=ag-][type=text]:invalid,\n.ag-theme-alpine input[class^=ag-][type=number]:invalid,\n.ag-theme-alpine input[class^=ag-][type=tel]:invalid,\n.ag-theme-alpine input[class^=ag-][type=date]:invalid,\n.ag-theme-alpine input[class^=ag-][type=datetime-local]:invalid,\n.ag-theme-alpine textarea[class^=ag-]:invalid {\n border-width: 2px;\n border-style: solid;\n border-color: #e02525;\n border-color: var(--ag-input-border-color-invalid, var(--ag-invalid-color, #e02525));\n}\n.ag-theme-alpine input[class^=ag-][type=number] {\n -moz-appearance: textfield;\n}\n.ag-theme-alpine input[class^=ag-][type=number]::-webkit-outer-spin-button, .ag-theme-alpine input[class^=ag-][type=number]::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n}\n.ag-theme-alpine input[class^=ag-][type=range] {\n padding: 0;\n}\n.ag-theme-alpine input[class^=ag-][type=button]:focus, .ag-theme-alpine button[class^=ag-]:focus {\n -webkit-box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n}\n.ag-theme-alpine .ag-drag-handle {\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n}\n.ag-theme-alpine .ag-list-item, .ag-theme-alpine .ag-virtual-list-item {\n height: 24px;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine .ag-select-list {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n overflow-y: auto;\n overflow-x: hidden;\n}\n.ag-theme-alpine .ag-list-item {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-alpine .ag-list-item.ag-active-item {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1));\n}\n.ag-theme-alpine .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n user-select: none;\n}\n.ag-theme-alpine .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n.ag-theme-alpine .ag-select .ag-picker-field-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n min-height: 24px;\n cursor: default;\n}\n.ag-theme-alpine .ag-select.ag-disabled .ag-picker-field-wrapper:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-alpine .ag-select:not(.ag-cell-editor) {\n height: 24px;\n}\n.ag-theme-alpine .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-alpine .ag-select .ag-picker-field-icon {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-alpine .ag-select.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-alpine .ag-rich-select {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n}\n.ag-theme-alpine .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 273px;\n}\n.ag-theme-alpine .ag-rich-select-value {\n padding: 0 6px 0 18px;\n height: 42px;\n border-bottom: solid 1px;\n border-bottom-color: #dde2eb;\n border-bottom-color: var(--ag-secondary-border-color, #dde2eb);\n}\n.ag-theme-alpine .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 24px;\n}\n.ag-theme-alpine .ag-rich-select-virtual-list-item:hover {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1));\n}\n.ag-theme-alpine .ag-rich-select-row {\n padding-left: 18px;\n}\n.ag-theme-alpine .ag-rich-select-row-selected {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3));\n}\n.ag-theme-alpine .ag-row-drag,\n.ag-theme-alpine .ag-selection-checkbox,\n.ag-theme-alpine .ag-group-expanded,\n.ag-theme-alpine .ag-group-contracted {\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n}\n.ag-theme-alpine .ag-ltr .ag-row-drag, .ag-theme-alpine .ag-ltr .ag-selection-checkbox, .ag-theme-alpine .ag-ltr .ag-group-expanded, .ag-theme-alpine .ag-ltr .ag-group-contracted {\n margin-right: 12px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-drag, .ag-theme-alpine .ag-rtl .ag-selection-checkbox, .ag-theme-alpine .ag-rtl .ag-group-expanded, .ag-theme-alpine .ag-rtl .ag-group-contracted {\n margin-left: 12px;\n}\n\n.ag-theme-alpine .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: min(var(--ag-row-height, 40px), 40px);\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-alpine .ag-group-expanded,\n.ag-theme-alpine .ag-group-contracted {\n cursor: pointer;\n}\n.ag-theme-alpine .ag-group-title-bar-icon {\n cursor: pointer;\n -webkit-box-flex: 0;\n flex: none;\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n}\n.ag-theme-alpine .ag-ltr .ag-group-child-count {\n margin-left: 2px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-group-child-count {\n margin-right: 2px;\n}\n\n.ag-theme-alpine .ag-group-title-bar {\n background-color: #fff;\n background-color: var(--ag-subheader-background-color, #fff);\n padding: 6px;\n}\n.ag-theme-alpine .ag-group-toolbar {\n padding: 6px;\n}\n.ag-theme-alpine .ag-disabled-group-title-bar, .ag-theme-alpine .ag-disabled-group-container {\n opacity: 0.5;\n}\n.ag-theme-alpine .group-item {\n margin: 3px 0;\n}\n.ag-theme-alpine .ag-label {\n white-space: nowrap;\n}\n.ag-theme-alpine .ag-ltr .ag-label {\n margin-right: 6px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-label {\n margin-left: 6px;\n}\n\n.ag-theme-alpine .ag-label-align-top .ag-label {\n margin-bottom: 3px;\n}\n.ag-theme-alpine .ag-ltr .ag-slider-field, .ag-theme-alpine .ag-ltr .ag-angle-select-field {\n margin-right: 12px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-slider-field, .ag-theme-alpine .ag-rtl .ag-angle-select-field {\n margin-left: 12px;\n}\n\n.ag-theme-alpine .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-alpine .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #181d1f;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n}\n.ag-theme-alpine .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n border-radius: 5px;\n}\n.ag-theme-alpine .ag-picker-field-wrapper:focus {\n -webkit-box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n}\n.ag-theme-alpine .ag-picker-field-button {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n}\n.ag-theme-alpine .ag-dialog.ag-color-dialog {\n border-radius: 5px;\n}\n.ag-theme-alpine .ag-color-picker .ag-picker-field-display {\n height: 16px;\n}\n.ag-theme-alpine .ag-color-panel {\n padding: 6px;\n}\n.ag-theme-alpine .ag-spectrum-color {\n background-color: red;\n border-radius: 2px;\n}\n.ag-theme-alpine .ag-spectrum-tools {\n padding: 10px;\n}\n.ag-theme-alpine .ag-spectrum-sat {\n background-image: -webkit-gradient(linear, left top, right top, from(white), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0));\n}\n.ag-theme-alpine .ag-spectrum-val {\n background-image: -webkit-gradient(linear, left bottom, left top, from(black), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0));\n}\n.ag-theme-alpine .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n -webkit-box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n}\n.ag-theme-alpine .ag-spectrum-hue-background {\n border-radius: 2px;\n}\n.ag-theme-alpine .ag-spectrum-alpha-background {\n border-radius: 2px;\n}\n.ag-theme-alpine .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px;\n}\n.ag-theme-alpine .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n -webkit-box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n}\n.ag-theme-alpine .ag-recent-color {\n margin: 0 3px;\n}\n.ag-theme-alpine .ag-recent-color:first-child {\n margin-left: 0;\n}\n.ag-theme-alpine .ag-recent-color:last-child {\n margin-right: 0;\n}\n.ag-theme-alpine.ag-dnd-ghost {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n -webkit-box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px;\n overflow: hidden;\n text-overflow: ellipsis;\n border: solid 1px;\n border-color: #dde2eb;\n border-color: var(--ag-secondary-border-color, #dde2eb);\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n height: 48px !important;\n line-height: 48px;\n margin: 0;\n padding: 0 12px;\n -webkit-transform: translateY(12px);\n transform: translateY(12px);\n}\n.ag-theme-alpine .ag-dnd-ghost-icon {\n margin-right: 6px;\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f);\n}\n.ag-theme-alpine .ag-popup-child:not(.ag-tooltip-custom) {\n -webkit-box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n}\n.ag-dragging-range-handle .ag-theme-alpine .ag-dialog, .ag-dragging-fill-handle .ag-theme-alpine .ag-dialog {\n opacity: 0.7;\n pointer-events: none;\n}\n.ag-theme-alpine .ag-dialog {\n border-radius: 3px;\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-panel {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-alpine .ag-panel-title-bar {\n background-color: #f8f8f8;\n background-color: var(--ag-header-background-color, #f8f8f8);\n color: #181d1f;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)));\n height: 48px;\n padding: 6px 18px;\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-ltr .ag-panel-title-bar-button {\n margin-left: 6px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-panel-title-bar-button {\n margin-right: 6px;\n}\n\n.ag-theme-alpine .ag-tooltip {\n background-color: #f8f8f8;\n background-color: var(--ag-header-background-color, #f8f8f8);\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f);\n padding: 6px;\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n border-radius: 3px;\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n white-space: normal;\n}\n.ag-theme-alpine .ag-tooltip.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-alpine .ag-tooltip-custom {\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n}\n.ag-theme-alpine .ag-tooltip-custom.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-alpine .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px;\n}\n\n.ag-theme-alpine .ag-column-select-header-icon {\n cursor: pointer;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-column-select-header-icon:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 12px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 12px;\n}\n\n.ag-theme-alpine .ag-keyboard-focus .ag-column-select-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-column-select-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine .ag-column-select-column-group:not(:last-child),\n.ag-theme-alpine .ag-column-select-column:not(:last-child) {\n margin-bottom: 9px;\n}\n.ag-theme-alpine .ag-column-select-column-readonly,\n.ag-theme-alpine .ag-column-select-column-group-readonly {\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n pointer-events: none;\n}\n.ag-theme-alpine .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-column-select-virtual-list-viewport {\n padding: 6px 0px;\n}\n.ag-theme-alpine .ag-column-select-virtual-list-item {\n padding: 0 12px;\n}\n.ag-theme-alpine .ag-rtl {\n text-align: right;\n}\n.ag-theme-alpine .ag-root-wrapper {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 46px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 46px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-1 {\n padding-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-1 {\n padding-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-1 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-1 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 74px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 74px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-2 {\n padding-left: 56px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-2 {\n padding-right: 56px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-2 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-2 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 102px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 102px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-3 {\n padding-left: 84px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-3 {\n padding-right: 84px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-3 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-3 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 130px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 130px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-4 {\n padding-left: 112px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-4 {\n padding-right: 112px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-4 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-4 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 158px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 158px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-5 {\n padding-left: 140px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-5 {\n padding-right: 140px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-5 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-5 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 186px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 186px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-6 {\n padding-left: 168px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-6 {\n padding-right: 168px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-6 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-6 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 214px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 214px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-7 {\n padding-left: 196px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-7 {\n padding-right: 196px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-7 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-7 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 242px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 242px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-8 {\n padding-left: 224px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-8 {\n padding-right: 224px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-8 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-8 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 270px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 270px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-9 {\n padding-left: 252px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-9 {\n padding-right: 252px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-9 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-9 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 298px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 298px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-10 {\n padding-left: 280px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-10 {\n padding-right: 280px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-10 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-10 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 326px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 326px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-11 {\n padding-left: 308px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-11 {\n padding-right: 308px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-11 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-11 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 354px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 354px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-12 {\n padding-left: 336px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-12 {\n padding-right: 336px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-12 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-12 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 382px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 382px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-13 {\n padding-left: 364px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-13 {\n padding-right: 364px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-13 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-13 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 410px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 410px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-14 {\n padding-left: 392px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-14 {\n padding-right: 392px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-14 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-14 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 438px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 438px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-15 {\n padding-left: 420px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-15 {\n padding-right: 420px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-15 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-15 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 466px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 466px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-16 {\n padding-left: 448px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-16 {\n padding-right: 448px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-16 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-16 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 494px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 494px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-17 {\n padding-left: 476px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-17 {\n padding-right: 476px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-17 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-17 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 522px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 522px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-18 {\n padding-left: 504px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-18 {\n padding-right: 504px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-18 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-18 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 550px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 550px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-19 {\n padding-left: 532px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-19 {\n padding-right: 532px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-19 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-19 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-left: 578px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-right: 578px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-20 {\n padding-left: 560px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-20 {\n padding-right: 560px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-20 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-20 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-left: 606px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-right: 606px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-21 {\n padding-left: 588px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-21 {\n padding-right: 588px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-21 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-21 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-left: 634px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-right: 634px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-22 {\n padding-left: 616px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-22 {\n padding-right: 616px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-22 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-22 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-left: 662px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-right: 662px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-23 {\n padding-left: 644px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-23 {\n padding-right: 644px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-23 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-23 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-left: 690px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-right: 690px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-24 {\n padding-left: 672px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-24 {\n padding-right: 672px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-24 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-24 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-left: 718px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-right: 718px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-25 {\n padding-left: 700px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-25 {\n padding-right: 700px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-25 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-25 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-left: 746px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-right: 746px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-26 {\n padding-left: 728px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-26 {\n padding-right: 728px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-26 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-26 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-left: 774px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-right: 774px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-27 {\n padding-left: 756px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-27 {\n padding-right: 756px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-27 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-27 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-left: 802px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-right: 802px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-28 {\n padding-left: 784px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-28 {\n padding-right: 784px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-28 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-28 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-left: 830px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-right: 830px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-29 {\n padding-left: 812px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-29 {\n padding-right: 812px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-29 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-29 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-left: 858px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-right: 858px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-30 {\n padding-left: 840px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-30 {\n padding-right: 840px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-30 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-30 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-left: 886px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-right: 886px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-31 {\n padding-left: 868px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-31 {\n padding-right: 868px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-31 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-31 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-left: 914px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-right: 914px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-32 {\n padding-left: 896px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-32 {\n padding-right: 896px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-32 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-32 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-left: 942px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-right: 942px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-33 {\n padding-left: 924px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-33 {\n padding-right: 924px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-33 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-33 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-left: 970px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-right: 970px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-34 {\n padding-left: 952px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-34 {\n padding-right: 952px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-34 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-34 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-left: 998px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-right: 998px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-35 {\n padding-left: 980px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-35 {\n padding-right: 980px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-35 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-35 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-left: 1026px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-right: 1026px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-36 {\n padding-left: 1008px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-36 {\n padding-right: 1008px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-36 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-36 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-left: 1054px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-right: 1054px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-37 {\n padding-left: 1036px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-37 {\n padding-right: 1036px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-37 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-37 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-left: 1082px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-right: 1082px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-38 {\n padding-left: 1064px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-38 {\n padding-right: 1064px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-38 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-38 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-left: 1110px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-right: 1110px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-39 {\n padding-left: 1092px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-39 {\n padding-right: 1092px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-39 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-39 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-left: 1138px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-right: 1138px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-40 {\n padding-left: 1120px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-40 {\n padding-right: 1120px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-40 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-40 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-left: 1166px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-right: 1166px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-41 {\n padding-left: 1148px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-41 {\n padding-right: 1148px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-41 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-41 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-left: 1194px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-right: 1194px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-42 {\n padding-left: 1176px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-42 {\n padding-right: 1176px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-42 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-42 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-left: 1222px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-right: 1222px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-43 {\n padding-left: 1204px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-43 {\n padding-right: 1204px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-43 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-43 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-left: 1250px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-right: 1250px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-44 {\n padding-left: 1232px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-44 {\n padding-right: 1232px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-44 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-44 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-left: 1278px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-right: 1278px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-45 {\n padding-left: 1260px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-45 {\n padding-right: 1260px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-45 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-45 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-left: 1306px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-right: 1306px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-46 {\n padding-left: 1288px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-46 {\n padding-right: 1288px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-46 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-46 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-left: 1334px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-right: 1334px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-47 {\n padding-left: 1316px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-47 {\n padding-right: 1316px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-47 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-47 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-left: 1362px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-right: 1362px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-48 {\n padding-left: 1344px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-48 {\n padding-right: 1344px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-48 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-48 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-left: 1390px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-right: 1390px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-49 {\n padding-left: 1372px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-49 {\n padding-right: 1372px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-49 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-49 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-left: 1418px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-right: 1418px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-50 {\n padding-left: 1400px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-50 {\n padding-right: 1400px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-50 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-50 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-left: 1446px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-right: 1446px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-51 {\n padding-left: 1428px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-51 {\n padding-right: 1428px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-51 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-51 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-left: 1474px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-right: 1474px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-52 {\n padding-left: 1456px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-52 {\n padding-right: 1456px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-52 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-52 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-left: 1502px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-right: 1502px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-53 {\n padding-left: 1484px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-53 {\n padding-right: 1484px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-53 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-53 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-left: 1530px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-right: 1530px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-54 {\n padding-left: 1512px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-54 {\n padding-right: 1512px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-54 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-54 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-left: 1558px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-right: 1558px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-55 {\n padding-left: 1540px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-55 {\n padding-right: 1540px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-55 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-55 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-left: 1586px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-right: 1586px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-56 {\n padding-left: 1568px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-56 {\n padding-right: 1568px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-56 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-56 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-left: 1614px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-right: 1614px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-57 {\n padding-left: 1596px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-57 {\n padding-right: 1596px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-57 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-57 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-left: 1642px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-right: 1642px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-58 {\n padding-left: 1624px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-58 {\n padding-right: 1624px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-58 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-58 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-left: 1670px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-right: 1670px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-59 {\n padding-left: 1652px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-59 {\n padding-right: 1652px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-59 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-59 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-left: 1698px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-right: 1698px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-60 {\n padding-left: 1680px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-60 {\n padding-right: 1680px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-60 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-60 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-left: 1726px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-right: 1726px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-61 {\n padding-left: 1708px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-61 {\n padding-right: 1708px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-61 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-61 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-left: 1754px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-right: 1754px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-62 {\n padding-left: 1736px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-62 {\n padding-right: 1736px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-62 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-62 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-left: 1782px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-right: 1782px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-63 {\n padding-left: 1764px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-63 {\n padding-right: 1764px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-63 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-63 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-left: 1810px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-right: 1810px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-64 {\n padding-left: 1792px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-64 {\n padding-right: 1792px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-64 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-64 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-left: 1838px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-right: 1838px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-65 {\n padding-left: 1820px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-65 {\n padding-right: 1820px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-65 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-65 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-left: 1866px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-right: 1866px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-66 {\n padding-left: 1848px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-66 {\n padding-right: 1848px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-66 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-66 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-left: 1894px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-right: 1894px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-67 {\n padding-left: 1876px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-67 {\n padding-right: 1876px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-67 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-67 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-left: 1922px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-right: 1922px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-68 {\n padding-left: 1904px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-68 {\n padding-right: 1904px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-68 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-68 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-left: 1950px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-right: 1950px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-69 {\n padding-left: 1932px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-69 {\n padding-right: 1932px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-69 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-69 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-left: 1978px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-right: 1978px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-70 {\n padding-left: 1960px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-70 {\n padding-right: 1960px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-70 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-70 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-left: 2006px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-right: 2006px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-71 {\n padding-left: 1988px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-71 {\n padding-right: 1988px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-71 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-71 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-left: 2034px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-right: 2034px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-72 {\n padding-left: 2016px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-72 {\n padding-right: 2016px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-72 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-72 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-left: 2062px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-right: 2062px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-73 {\n padding-left: 2044px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-73 {\n padding-right: 2044px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-73 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-73 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-left: 2090px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-right: 2090px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-74 {\n padding-left: 2072px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-74 {\n padding-right: 2072px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-74 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-74 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-left: 2118px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-right: 2118px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-75 {\n padding-left: 2100px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-75 {\n padding-right: 2100px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-75 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-75 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-left: 2146px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-right: 2146px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-76 {\n padding-left: 2128px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-76 {\n padding-right: 2128px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-76 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-76 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-left: 2174px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-right: 2174px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-77 {\n padding-left: 2156px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-77 {\n padding-right: 2156px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-77 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-77 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-left: 2202px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-right: 2202px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-78 {\n padding-left: 2184px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-78 {\n padding-right: 2184px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-78 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-78 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-left: 2230px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-right: 2230px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-79 {\n padding-left: 2212px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-79 {\n padding-right: 2212px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-79 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-79 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-left: 2258px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-right: 2258px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-80 {\n padding-left: 2240px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-80 {\n padding-right: 2240px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-80 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-80 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-left: 2286px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-right: 2286px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-81 {\n padding-left: 2268px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-81 {\n padding-right: 2268px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-81 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-81 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-left: 2314px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-right: 2314px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-82 {\n padding-left: 2296px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-82 {\n padding-right: 2296px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-82 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-82 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-left: 2342px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-right: 2342px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-83 {\n padding-left: 2324px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-83 {\n padding-right: 2324px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-83 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-83 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-left: 2370px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-right: 2370px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-84 {\n padding-left: 2352px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-84 {\n padding-right: 2352px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-84 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-84 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-left: 2398px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-right: 2398px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-85 {\n padding-left: 2380px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-85 {\n padding-right: 2380px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-85 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-85 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-left: 2426px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-right: 2426px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-86 {\n padding-left: 2408px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-86 {\n padding-right: 2408px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-86 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-86 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-left: 2454px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-right: 2454px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-87 {\n padding-left: 2436px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-87 {\n padding-right: 2436px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-87 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-87 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-left: 2482px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-right: 2482px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-88 {\n padding-left: 2464px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-88 {\n padding-right: 2464px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-88 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-88 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-left: 2510px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-right: 2510px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-89 {\n padding-left: 2492px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-89 {\n padding-right: 2492px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-89 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-89 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-left: 2538px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-right: 2538px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-90 {\n padding-left: 2520px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-90 {\n padding-right: 2520px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-90 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-90 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-left: 2566px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-right: 2566px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-91 {\n padding-left: 2548px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-91 {\n padding-right: 2548px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-91 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-91 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-left: 2594px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-right: 2594px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-92 {\n padding-left: 2576px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-92 {\n padding-right: 2576px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-92 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-92 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-left: 2622px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-right: 2622px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-93 {\n padding-left: 2604px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-93 {\n padding-right: 2604px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-93 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-93 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-left: 2650px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-right: 2650px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-94 {\n padding-left: 2632px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-94 {\n padding-right: 2632px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-94 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-94 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-left: 2678px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-right: 2678px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-95 {\n padding-left: 2660px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-95 {\n padding-right: 2660px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-95 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-95 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-left: 2706px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-right: 2706px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-96 {\n padding-left: 2688px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-96 {\n padding-right: 2688px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-96 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-96 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-left: 2734px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-right: 2734px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-97 {\n padding-left: 2716px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-97 {\n padding-right: 2716px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-97 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-97 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-left: 2762px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-right: 2762px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-98 {\n padding-left: 2744px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-98 {\n padding-right: 2744px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-98 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-98 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-left: 2790px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-right: 2790px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-indent-99 {\n padding-left: 2772px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-indent-99 {\n padding-right: 2772px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-level-99 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-level-99 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-row-group-leaf-indent {\n margin-left: 28px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-row-group-leaf-indent {\n margin-right: 28px;\n}\n\n.ag-theme-alpine .ag-value-change-delta {\n padding-right: 2px;\n}\n.ag-theme-alpine .ag-value-change-delta-up {\n color: #43a047;\n color: var(--ag-value-change-delta-up-color, #43a047);\n}\n.ag-theme-alpine .ag-value-change-delta-down {\n color: #e53935;\n color: var(--ag-value-change-delta-down-color, #e53935);\n}\n.ag-theme-alpine .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n -webkit-transition: background-color 1s;\n transition: background-color 1s;\n}\n.ag-theme-alpine .ag-value-change-value-highlight {\n background-color: rgba(22, 160, 133, 0.5);\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5));\n -webkit-transition: background-color 0.1s;\n transition: background-color 0.1s;\n}\n.ag-theme-alpine .ag-cell-data-changed {\n background-color: rgba(22, 160, 133, 0.5) !important;\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5)) !important;\n}\n.ag-theme-alpine .ag-cell-data-changed-animation {\n background-color: transparent;\n}\n.ag-theme-alpine .ag-cell-highlight {\n background-color: #2196f3 !important;\n background-color: var(--ag-range-selection-highlight-color, var(--ag-range-selection-border-color, #2196f3)) !important;\n}\n.ag-theme-alpine .ag-row {\n height: 42px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: #181d1f;\n color: var(--ag-data-color, var(--ag-foreground-color, #181d1f));\n border-width: 1px;\n border-color: #dde2eb;\n border-color: var(--ag-row-border-color, var(--ag-secondary-border-color, #dde2eb));\n border-bottom-style: solid;\n}\n.ag-theme-alpine .ag-row-highlight-above::after, .ag-theme-alpine .ag-row-highlight-below::after {\n content: \"\";\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #2196f3;\n background-color: var(--ag-range-selection-border-color, #2196f3);\n left: 1px;\n}\n.ag-theme-alpine .ag-row-highlight-above::after {\n top: -1px;\n}\n.ag-theme-alpine .ag-row-highlight-above.ag-row-first::after {\n top: 0;\n}\n.ag-theme-alpine .ag-row-highlight-below::after {\n bottom: 0px;\n}\n.ag-theme-alpine .ag-row-odd {\n background-color: #fcfcfc;\n background-color: var(--ag-odd-row-background-color, #fcfcfc);\n}\n.ag-theme-alpine .ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-row-hover {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1));\n}\n.ag-theme-alpine .ag-column-hover {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-column-hover-color, rgba(33, 150, 243, 0.1));\n}\n.ag-theme-alpine .ag-ltr .ag-right-aligned-cell {\n text-align: right;\n}\n\n.ag-theme-alpine .ag-rtl .ag-right-aligned-cell {\n text-align: left;\n}\n\n.ag-theme-alpine .ag-ltr .ag-right-aligned-cell .ag-cell-value, .ag-theme-alpine .ag-ltr .ag-right-aligned-cell .ag-group-value {\n margin-left: auto;\n}\n\n.ag-theme-alpine .ag-rtl .ag-right-aligned-cell .ag-cell-value, .ag-theme-alpine .ag-rtl .ag-right-aligned-cell .ag-group-value {\n margin-right: auto;\n}\n\n.ag-theme-alpine .ag-cell, .ag-theme-alpine .ag-full-width-row .ag-cell-wrapper.ag-row-group {\n border: 1px solid transparent;\n line-height: min(var(--ag-row-height, 40px), 40px);\n padding-left: 17px;\n padding-right: 17px;\n -webkit-font-smoothing: subpixel-antialiased;\n}\n.ag-theme-alpine .ag-row > .ag-cell-wrapper {\n padding-left: 17px;\n padding-right: 17px;\n}\n.ag-theme-alpine .ag-row-dragging {\n cursor: move;\n opacity: 0.5;\n}\n.ag-theme-alpine .ag-cell-inline-editing {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n -webkit-box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px;\n padding: 0;\n height: 42px;\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n}\n.ag-theme-alpine .ag-popup-editor {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n -webkit-box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px;\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n padding: 0;\n}\n.ag-theme-alpine .ag-large-text-input {\n height: auto;\n padding: 18px;\n}\n.ag-theme-alpine .ag-details-row {\n padding: 30px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-alpine .ag-layout-auto-height .ag-center-cols-clipper, .ag-theme-alpine .ag-layout-auto-height .ag-center-cols-container, .ag-theme-alpine .ag-layout-print .ag-center-cols-clipper, .ag-theme-alpine .ag-layout-print .ag-center-cols-container {\n min-height: 50px;\n}\n.ag-theme-alpine .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66));\n}\n.ag-theme-alpine .ag-overlay-loading-center {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n -webkit-box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px;\n}\n.ag-theme-alpine .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px;\n}\n.ag-theme-alpine .ag-loading {\n padding-left: 18px;\n display: -webkit-box;\n display: flex;\n height: 100%;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-alpine .ag-loading-icon {\n padding-right: 12px;\n}\n.ag-theme-alpine .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear;\n}\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n.ag-theme-alpine .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-ltr .ag-cell {\n border-right: solid transparent;\n}\n\n.ag-theme-alpine .ag-rtl .ag-cell {\n border-left: solid transparent;\n}\n\n.ag-theme-alpine .ag-ltr .ag-cell {\n border-right-width: 1px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-cell {\n border-left-width: 1px;\n}\n\n.ag-theme-alpine .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-row-selected {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3));\n}\n.ag-theme-alpine .ag-cell-range-selected:not(.ag-cell-focus),\n.ag-theme-alpine .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing) {\n background-color: rgba(33, 150, 243, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(33, 150, 243, 0.2));\n}\n.ag-theme-alpine .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart,\n.ag-theme-alpine .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1) !important;\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)) !important;\n}\n.ag-theme-alpine .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category,\n.ag-theme-alpine .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1) !important;\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)) !important;\n}\n.ag-theme-alpine .ag-cell-range-selected-1:not(.ag-cell-focus),\n.ag-theme-alpine .ag-root:not(.ag-context-menu-open) .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-1:not(.ag-cell-inline-editing) {\n background-color: rgba(33, 150, 243, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(33, 150, 243, 0.2)));\n}\n.ag-theme-alpine .ag-cell-range-selected-2:not(.ag-cell-focus),\n.ag-theme-alpine .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-2 {\n background-color: rgba(33, 150, 243, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(33, 150, 243, 0.36));\n}\n.ag-theme-alpine .ag-cell-range-selected-3:not(.ag-cell-focus),\n.ag-theme-alpine .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-3 {\n background-color: rgba(33, 150, 243, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(33, 150, 243, 0.488));\n}\n.ag-theme-alpine .ag-cell-range-selected-4:not(.ag-cell-focus),\n.ag-theme-alpine .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-4 {\n background-color: rgba(33, 150, 243, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(33, 150, 243, 0.5904));\n}\n.ag-theme-alpine .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #2196f3;\n border-top-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-alpine .ag-ltr .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-alpine .ag-ltr .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-alpine .ag-ltr .ag-cell-range-single-cell,\n.ag-theme-alpine .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-alpine .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-alpine .ag-rtl .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-alpine .ag-rtl .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-alpine .ag-rtl .ag-cell-range-single-cell,\n.ag-theme-alpine .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #2196f3;\n border-color: var(--ag-range-selection-border-color, #2196f3);\n outline: initial;\n}\n.ag-theme-alpine .ag-cell.ag-selection-fill-top,\n.ag-theme-alpine .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #2196f3;\n border-top-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-alpine .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3);\n}\n\n.ag-theme-alpine .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-alpine .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3);\n}\n\n.ag-theme-alpine .ag-cell.ag-selection-fill-bottom,\n.ag-theme-alpine .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-alpine .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3);\n}\n\n.ag-theme-alpine .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-alpine .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3);\n}\n\n.ag-theme-alpine .ag-range-handle, .ag-theme-alpine .ag-fill-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #2196f3;\n background-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine .ag-ltr .ag-range-handle, .ag-theme-alpine .ag-ltr .ag-fill-handle {\n right: -1px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-range-handle, .ag-theme-alpine .ag-rtl .ag-fill-handle {\n left: -1px;\n}\n\n.ag-theme-alpine .ag-fill-handle {\n cursor: cell;\n}\n.ag-theme-alpine .ag-range-handle {\n cursor: nwse-resize;\n}\n.ag-theme-alpine .ag-cell-inline-editing {\n border-color: rgba(33, 150, 243, 0.4) !important;\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)) !important;\n}\n.ag-theme-alpine .ag-menu {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n -webkit-box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px;\n padding: 0;\n}\n.ag-theme-alpine .ag-menu-list {\n cursor: default;\n padding: 6px 0;\n}\n.ag-theme-alpine .ag-menu-separator {\n height: 13px;\n}\n.ag-theme-alpine .ag-menu-separator-part::after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-menu-option-active, .ag-theme-alpine .ag-compact-menu-option-active {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1));\n}\n.ag-theme-alpine .ag-menu-option-part, .ag-theme-alpine .ag-compact-menu-option-part {\n line-height: 16px;\n padding: 8px 0;\n}\n.ag-theme-alpine .ag-menu-option-disabled, .ag-theme-alpine .ag-compact-menu-option-disabled {\n opacity: 0.5;\n}\n.ag-theme-alpine .ag-menu-option-icon, .ag-theme-alpine .ag-compact-menu-option-icon {\n width: 16px;\n}\n.ag-theme-alpine .ag-ltr .ag-menu-option-icon, .ag-theme-alpine .ag-ltr .ag-compact-menu-option-icon {\n padding-left: 12px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-menu-option-icon, .ag-theme-alpine .ag-rtl .ag-compact-menu-option-icon {\n padding-right: 12px;\n}\n\n.ag-theme-alpine .ag-menu-option-text, .ag-theme-alpine .ag-compact-menu-option-text {\n padding-left: 12px;\n padding-right: 12px;\n}\n.ag-theme-alpine .ag-ltr .ag-menu-option-shortcut, .ag-theme-alpine .ag-ltr .ag-compact-menu-option-shortcut {\n padding-right: 6px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-menu-option-shortcut, .ag-theme-alpine .ag-rtl .ag-compact-menu-option-shortcut {\n padding-left: 6px;\n}\n\n.ag-theme-alpine .ag-menu-option-popup-pointer, .ag-theme-alpine .ag-compact-menu-option-popup-pointer {\n padding-right: 6px;\n}\n.ag-theme-alpine .ag-tabs {\n min-width: 240px;\n}\n.ag-theme-alpine .ag-tabs-header {\n width: 100%;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-alpine .ag-tab {\n border-bottom: 2px solid transparent;\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 0;\n flex: none;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-pack: center;\n justify-content: center;\n cursor: pointer;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n -webkit-transition: border-bottom 0.3s;\n transition: border-bottom 0.3s;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-tab:focus {\n outline: none;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-tab:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine .ag-tab-selected {\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3));\n}\n.ag-theme-alpine .ag-menu-header {\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n}\n.ag-theme-alpine .ag-filter-separator {\n border-top: solid 1px;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-menu:not(.ag-tabs) .ag-filter-select {\n min-width: 155px;\n}\n.ag-theme-alpine .ag-tabs .ag-filter-select {\n min-width: 214px;\n}\n.ag-theme-alpine .ag-filter-select .ag-picker-field-wrapper {\n width: 0;\n}\n.ag-theme-alpine .ag-filter-condition-operator {\n height: 17px;\n}\n.ag-theme-alpine .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 12px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 12px;\n}\n\n.ag-theme-alpine .ag-set-filter-select-all {\n padding-top: 12px;\n}\n.ag-theme-alpine .ag-set-filter-list, .ag-theme-alpine .ag-filter-no-matches {\n height: 144px;\n}\n.ag-theme-alpine .ag-set-filter-filter {\n margin-top: 12px;\n margin-left: 12px;\n margin-right: 12px;\n}\n.ag-theme-alpine .ag-filter-to {\n margin-top: 9px;\n}\n.ag-theme-alpine .ag-mini-filter {\n margin: 12px 12px;\n}\n.ag-theme-alpine .ag-set-filter-item {\n margin: 0px 12px;\n}\n.ag-theme-alpine .ag-ltr .ag-set-filter-item-value {\n margin-left: 12px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-set-filter-item-value {\n margin-right: 12px;\n}\n\n.ag-theme-alpine .ag-filter-apply-panel {\n padding: 12px 12px;\n border-top: solid 1px;\n border-top-color: #dde2eb;\n border-top-color: var(--ag-secondary-border-color, #dde2eb);\n}\n.ag-theme-alpine .ag-filter-apply-panel-button {\n line-height: 1.5;\n}\n.ag-theme-alpine .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 12px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 12px;\n}\n\n.ag-theme-alpine .ag-simple-filter-body-wrapper {\n padding: 12px 12px;\n padding-bottom: 3px;\n}\n.ag-theme-alpine .ag-simple-filter-body-wrapper > * {\n margin-bottom: 9px;\n}\n.ag-theme-alpine .ag-filter-no-matches {\n padding: 12px 12px;\n}\n.ag-theme-alpine .ag-multi-filter-menu-item {\n margin: 6px 0;\n}\n.ag-theme-alpine .ag-multi-filter-group-title-bar {\n padding: 12px 6px;\n background-color: transparent;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus {\n outline: none;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine .ag-side-bar {\n position: relative;\n}\n.ag-theme-alpine .ag-tool-panel-wrapper {\n width: 250px;\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n}\n.ag-theme-alpine .ag-side-buttons {\n padding-top: 24px;\n width: 20px;\n position: relative;\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f);\n overflow: hidden;\n}\n.ag-theme-alpine button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 12px 0 12px 0;\n width: 100%;\n margin: 0;\n min-height: 108px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n}\n.ag-theme-alpine button.ag-side-button-button:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-side-button-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine .ag-side-button-icon-wrapper {\n margin-bottom: 3px;\n}\n.ag-theme-alpine .ag-ltr .ag-side-bar-left,\n.ag-theme-alpine .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n.ag-theme-alpine .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-ltr .ag-side-bar-left .ag-side-button-button,\n.ag-theme-alpine .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 2px solid transparent;\n -webkit-transition: border-right 0.3s;\n transition: border-right 0.3s;\n}\n.ag-theme-alpine .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-alpine .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #2196f3;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3));\n}\n.ag-theme-alpine .ag-rtl .ag-side-bar-left,\n.ag-theme-alpine .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n.ag-theme-alpine .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-rtl .ag-side-bar-left .ag-side-button-button,\n.ag-theme-alpine .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 2px solid transparent;\n -webkit-transition: border-left 0.3s;\n transition: border-left 0.3s;\n}\n.ag-theme-alpine .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-alpine .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #2196f3;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3));\n}\n.ag-theme-alpine .ag-filter-toolpanel-header {\n height: 36px;\n}\n.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-header, .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 6px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-header, .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 6px;\n}\n\n.ag-theme-alpine .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-filter-toolpanel-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f114\";\n position: absolute;\n}\n.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-left: 6px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-right: 6px;\n}\n\n.ag-theme-alpine .ag-filter-toolpanel-group-level-0-header {\n height: 48px;\n}\n.ag-theme-alpine .ag-filter-toolpanel-group-item {\n margin-top: 3px;\n margin-bottom: 3px;\n}\n.ag-theme-alpine .ag-filter-toolpanel-search {\n height: 48px;\n}\n.ag-theme-alpine .ag-filter-toolpanel-search-input {\n -webkit-box-flex: 1;\n flex-grow: 1;\n height: 24px;\n}\n.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 6px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 6px;\n}\n\n.ag-theme-alpine .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: #dde2eb;\n border-top-color: var(--ag-secondary-border-color, #dde2eb);\n}\n.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 6px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 6px;\n}\n\n.ag-theme-alpine .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 22px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 22px;\n}\n\n.ag-theme-alpine .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 38px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 38px;\n}\n\n.ag-theme-alpine .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 54px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 54px;\n}\n\n.ag-theme-alpine .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 70px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 70px;\n}\n\n.ag-theme-alpine .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 86px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 86px;\n}\n\n.ag-theme-alpine .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 102px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 102px;\n}\n\n.ag-theme-alpine .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 118px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 118px;\n}\n\n.ag-theme-alpine .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 134px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 134px;\n}\n\n.ag-theme-alpine .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 150px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 150px;\n}\n\n.ag-theme-alpine .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 166px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 166px;\n}\n\n.ag-theme-alpine .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 6px;\n}\n.ag-theme-alpine .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7);\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7);\n margin-top: 6px;\n}\n.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 6px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 6px;\n}\n\n.ag-theme-alpine .ag-pivot-mode-panel {\n min-height: 48px;\n height: 48px;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-alpine .ag-pivot-mode-select {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-alpine .ag-ltr .ag-pivot-mode-select {\n margin-left: 12px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-pivot-mode-select {\n margin-right: 12px;\n}\n\n.ag-theme-alpine .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-column-select-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine .ag-column-select-header {\n height: 48px;\n -webkit-box-align: center;\n align-items: center;\n padding: 0 12px;\n border-bottom: solid 1px;\n border-bottom-color: #dde2eb;\n border-bottom-color: var(--ag-secondary-border-color, #dde2eb);\n}\n.ag-theme-alpine .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: #dde2eb;\n border-bottom-color: var(--ag-secondary-border-color, #dde2eb);\n border-top: solid 1px;\n border-top-color: #dde2eb;\n border-top-color: var(--ag-secondary-border-color, #dde2eb);\n}\n.ag-theme-alpine .ag-column-group-icons,\n.ag-theme-alpine .ag-column-select-header-icon {\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n}\n.ag-theme-alpine .ag-column-select-list .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #2196f3;\n background-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine .ag-column-select-list .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-alpine .ag-column-select-list .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-alpine .ag-header {\n background-color: #f8f8f8;\n background-color: var(--ag-header-background-color, #f8f8f8);\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-header-row {\n color: #181d1f;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)));\n height: 48px;\n}\n.ag-theme-alpine .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 6px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 6px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 6px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 6px;\n}\n\n.ag-theme-alpine .ag-header-cell,\n.ag-theme-alpine .ag-header-group-cell {\n padding-left: 18px;\n padding-right: 18px;\n}\n.ag-theme-alpine .ag-header-cell.ag-header-cell-moving,\n.ag-theme-alpine .ag-header-group-cell.ag-header-cell-moving {\n background-color: #fff;\n background-color: var(--ag-header-cell-moving-background-color, var(--ag-background-color, #fff));\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-header-cell:focus {\n outline: none;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-header-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-header-group-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine .ag-header-icon {\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n}\n.ag-theme-alpine .ag-header-expand-icon {\n cursor: pointer;\n}\n.ag-theme-alpine .ag-ltr .ag-header-expand-icon {\n padding-left: 4px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-header-expand-icon {\n padding-right: 4px;\n}\n\n.ag-theme-alpine .ag-header-row:not(:first-child) .ag-header-cell,\n.ag-theme-alpine .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-header-cell-resize {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-alpine .ag-header-cell-resize::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n left: calc(50% - 1px);\n width: 2px;\n height: 30%;\n top: calc(50% - 15%);\n background-color: rgba(186, 191, 199, 0.5);\n background-color: var(--ag-header-column-resize-handle-color, rgba(186, 191, 199, 0.5));\n}\n.ag-theme-alpine .ag-pinned-right-header .ag-header-cell-resize::after {\n left: calc(50% - 2px);\n}\n.ag-theme-alpine .ag-ltr .ag-header-select-all {\n margin-right: 18px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-header-select-all {\n margin-left: 18px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-floating-filter-button {\n margin-left: 18px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-floating-filter-button {\n margin-right: 18px;\n}\n\n.ag-theme-alpine .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 16px;\n padding: 0;\n width: 16px;\n}\n.ag-theme-alpine .ag-filter-loading {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n height: 100%;\n padding: 12px 12px;\n position: absolute;\n width: 100%;\n z-index: 1;\n}\n.ag-theme-alpine .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7);\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n height: 48px;\n}\n.ag-theme-alpine .ag-paging-panel > * {\n margin: 0 18px;\n}\n.ag-theme-alpine .ag-paging-button {\n cursor: pointer;\n}\n.ag-theme-alpine .ag-paging-button.ag-disabled {\n cursor: default;\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-paging-button:focus {\n outline: none;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-paging-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine .ag-paging-button, .ag-theme-alpine .ag-paging-description {\n margin: 0 6px;\n}\n.ag-theme-alpine .ag-status-bar {\n border-top: solid 1px;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7);\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n padding-right: 24px;\n padding-left: 24px;\n line-height: 1.5;\n}\n.ag-theme-alpine .ag-status-name-value-value {\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f);\n}\n.ag-theme-alpine .ag-status-bar-center {\n text-align: center;\n}\n.ag-theme-alpine .ag-status-name-value {\n margin-left: 6px;\n margin-right: 6px;\n padding-top: 12px;\n padding-bottom: 12px;\n}\n.ag-theme-alpine .ag-column-drop-cell {\n background: rgba(24, 29, 31, 0.07);\n background: var(--ag-chip-background-color, rgba(24, 29, 31, 0.07));\n border-radius: 24px;\n height: 24px;\n padding: 0 3px;\n border: 1px solid transparent;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-column-drop-cell:focus {\n outline: none;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-column-drop-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 2px;\n left: 2px;\n display: block;\n width: calc(100% - 4px);\n height: calc(100% - 4px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine .ag-column-drop-cell-text {\n margin: 0 6px;\n}\n.ag-theme-alpine .ag-column-drop-cell-button {\n min-width: 24px;\n margin: 0 3px;\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n}\n.ag-theme-alpine .ag-column-drop-cell-drag-handle {\n margin-left: 12px;\n}\n.ag-theme-alpine .ag-column-drop-cell-ghost {\n opacity: 0.5;\n}\n.ag-theme-alpine .ag-column-drop-horizontal {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n height: 42px;\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-ltr .ag-column-drop-horizontal {\n padding-left: 18px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-column-drop-horizontal {\n padding-right: 18px;\n}\n\n.ag-theme-alpine .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7);\n}\n\n.ag-theme-alpine .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7);\n}\n\n.ag-theme-alpine .ag-column-drop-horizontal-cell-separator {\n margin: 0 6px;\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n}\n.ag-theme-alpine .ag-column-drop-horizontal-empty-message {\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n}\n.ag-theme-alpine .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 18px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 18px;\n}\n\n.ag-theme-alpine .ag-column-drop-vertical-list {\n padding-bottom: 6px;\n padding-right: 6px;\n padding-left: 6px;\n}\n.ag-theme-alpine .ag-column-drop-vertical-cell {\n margin-top: 6px;\n}\n.ag-theme-alpine .ag-column-drop-vertical {\n min-height: 50px;\n border-bottom: solid 1px;\n border-bottom-color: #dde2eb;\n border-bottom-color: var(--ag-secondary-border-color, #dde2eb);\n}\n.ag-theme-alpine .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none;\n}\n.ag-theme-alpine .ag-column-drop-vertical-icon {\n margin-left: 6px;\n margin-right: 6px;\n}\n.ag-theme-alpine .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n margin-top: 6px;\n}\n.ag-theme-alpine .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n -webkit-box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px;\n background: #fff;\n background: var(--ag-background-color, #fff);\n height: 105px;\n padding: 0;\n}\n.ag-theme-alpine .ag-select-agg-func-virtual-list-item {\n cursor: default;\n padding-left: 12px;\n}\n.ag-theme-alpine .ag-select-agg-func-virtual-list-item:hover {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3));\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-alpine .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine .ag-chart-menu {\n border-radius: 3px;\n background: #fff;\n background: var(--ag-background-color, #fff);\n}\n.ag-theme-alpine .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 3px;\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n}\n.ag-theme-alpine .ag-chart-menu-icon:hover {\n opacity: 1;\n}\n.ag-theme-alpine .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: #dde2eb;\n border-color: var(--ag-secondary-border-color, #dde2eb);\n border-radius: 5px;\n margin: 5px;\n}\n.ag-theme-alpine .ag-chart-mini-thumbnail:nth-last-child(3), .ag-theme-alpine .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto;\n}\n.ag-theme-alpine .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0;\n}\n\n.ag-theme-alpine .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0;\n}\n\n.ag-theme-alpine .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0;\n}\n\n.ag-theme-alpine .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0;\n}\n\n.ag-theme-alpine .ag-chart-mini-thumbnail.ag-selected {\n border-color: #2196f3;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)));\n}\n.ag-theme-alpine .ag-chart-settings-card-item {\n background: #181d1f;\n background: var(--ag-foreground-color, #181d1f);\n width: 8px;\n height: 8px;\n border-radius: 4px;\n}\n.ag-theme-alpine .ag-chart-settings-card-item.ag-selected {\n background-color: #2196f3;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)));\n}\n.ag-theme-alpine .ag-chart-data-column-drag-handle {\n margin-left: 6px;\n}\n.ag-theme-alpine .ag-charts-settings-group-title-bar,\n.ag-theme-alpine .ag-charts-data-group-title-bar,\n.ag-theme-alpine .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: #dde2eb;\n border-top-color: var(--ag-secondary-border-color, #dde2eb);\n}\n.ag-theme-alpine .ag-charts-settings-group-container {\n padding: 6px;\n}\n.ag-theme-alpine .ag-charts-data-group-container {\n padding: 6px 12px;\n}\n.ag-theme-alpine .ag-charts-data-group-container .ag-charts-data-group-item:not(.ag-charts-format-sub-level-group) {\n height: 24px;\n}\n.ag-theme-alpine .ag-charts-data-group-container .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #2196f3;\n background-color: var(--ag-range-selection-border-color, #2196f3);\n}\n.ag-theme-alpine .ag-charts-data-group-container .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-alpine .ag-charts-data-group-container .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-alpine .ag-charts-format-top-level-group-container {\n margin-left: 12px;\n padding: 6px;\n}\n.ag-theme-alpine .ag-charts-format-top-level-group-item {\n margin: 6px 0;\n}\n.ag-theme-alpine .ag-charts-format-sub-level-group-container {\n padding: 12px 12px;\n padding-bottom: 3px;\n}\n.ag-theme-alpine .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 9px;\n}\n.ag-theme-alpine .ag-charts-group-container.ag-group-container-horizontal {\n padding: 6px;\n}\n.ag-theme-alpine .ag-chart-data-section,\n.ag-theme-alpine .ag-chart-format-section {\n display: -webkit-box;\n display: flex;\n margin: 0;\n}\n.ag-theme-alpine .ag-chart-menu-panel {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n}\n.ag-theme-alpine .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7);\n}\n\n.ag-theme-alpine .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7);\n}\n\n.ag-theme-alpine .ag-date-time-list-page-title {\n -webkit-box-flex: 1;\n flex-grow: 1;\n text-align: center;\n}\n.ag-theme-alpine .ag-date-time-list-page-column-label {\n text-align: center;\n}\n.ag-theme-alpine .ag-date-time-list-page-entry {\n text-align: center;\n}\n.ag-theme-alpine .ag-checkbox-input-wrapper {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #fff;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #fff));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-alpine .ag-checkbox-input-wrapper input, .ag-theme-alpine .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-alpine .ag-checkbox-input-wrapper:focus-within, .ag-theme-alpine .ag-checkbox-input-wrapper:active {\n outline: none;\n -webkit-box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n}\n.ag-theme-alpine .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-alpine .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #999;\n color: var(--ag-checkbox-unchecked-color, #999);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-alpine .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #2196f3;\n color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-alpine .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #999;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, #999));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-alpine .ag-toggle-button-input-wrapper {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n width: 28px;\n height: 18px;\n background-color: #999;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, #999));\n border-radius: 9px;\n position: relative;\n -webkit-box-flex: 0;\n flex: none;\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #999));\n}\n.ag-theme-alpine .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%;\n}\n.ag-theme-alpine .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n -webkit-box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n}\n.ag-theme-alpine .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-alpine .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #2196f3;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)));\n border-color: #2196f3;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)));\n}\n.ag-theme-alpine .ag-toggle-button-input-wrapper::before {\n content: \" \";\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n height: 18px;\n width: 18px;\n background-color: #fff;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #fff));\n border-radius: 9px;\n -webkit-transition: left 100ms;\n transition: left 100ms;\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #999)));\n}\n.ag-theme-alpine .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 18px );\n border-color: #2196f3;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)));\n}\n.ag-theme-alpine .ag-radio-button-input-wrapper {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #fff;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #fff));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n border-radius: 16px;\n}\n.ag-theme-alpine .ag-radio-button-input-wrapper input, .ag-theme-alpine .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-alpine .ag-radio-button-input-wrapper:focus-within, .ag-theme-alpine .ag-radio-button-input-wrapper:active {\n outline: none;\n -webkit-box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n}\n.ag-theme-alpine .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-alpine .ag-radio-button-input-wrapper::after {\n content: \"\\f126\";\n color: #999;\n color: var(--ag-checkbox-unchecked-color, #999);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-alpine .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f127\";\n color: #2196f3;\n color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-alpine input[class^=ag-][type=range] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible;\n}\n.ag-theme-alpine input[class^=ag-][type=range]::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #babfc7;\n background-color: var(--ag-border-color, #babfc7);\n border-radius: 3px;\n border-radius: 3px;\n}\n.ag-theme-alpine input[class^=ag-][type=range]::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #babfc7;\n background-color: var(--ag-border-color, #babfc7);\n border-radius: 3px;\n border-radius: 3px;\n}\n.ag-theme-alpine input[class^=ag-][type=range]::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #babfc7;\n background-color: var(--ag-border-color, #babfc7);\n border-radius: 3px;\n border-radius: 3px;\n color: transparent;\n width: calc(100% - 2px);\n}\n.ag-theme-alpine input[class^=ag-][type=range]::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px;\n -webkit-transform: translateY(-6.5px);\n transform: translateY(-6.5px);\n}\n.ag-theme-alpine input[class^=ag-][type=range]::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px;\n}\n.ag-theme-alpine input[class^=ag-][type=range]::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px;\n}\n.ag-theme-alpine input[class^=ag-][type=range]:focus {\n outline: none;\n}\n.ag-theme-alpine input[class^=ag-][type=range]:focus::-webkit-slider-thumb {\n -webkit-box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n}\n.ag-theme-alpine input[class^=ag-][type=range]:focus::-ms-thumb {\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n}\n.ag-theme-alpine input[class^=ag-][type=range]:focus::-moz-ag-range-thumb {\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n}\n.ag-theme-alpine input[class^=ag-][type=range]:active::-webkit-slider-runnable-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine input[class^=ag-][type=range]:active::-moz-ag-range-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine input[class^=ag-][type=range]:active::-ms-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4));\n}\n.ag-theme-alpine input[class^=ag-][type=range]:disabled {\n opacity: 0.5;\n}\n.ag-theme-alpine .ag-filter-toolpanel-header,\n.ag-theme-alpine .ag-filter-toolpanel-search,\n.ag-theme-alpine .ag-status-bar,\n.ag-theme-alpine .ag-header-row,\n.ag-theme-alpine .ag-panel-title-bar-title,\n.ag-theme-alpine .ag-multi-filter-group-title-bar {\n font-weight: 700;\n color: #181d1f;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)));\n}\n.ag-theme-alpine .ag-rtl .ag-pinned-left-header .ag-header-row::before, .ag-theme-alpine .ag-ltr .ag-pinned-right-header .ag-header-row::after {\n content: \"\";\n position: absolute;\n height: calc(100% - 20px);\n top: 10px;\n width: 1px;\n background-color: #babfc7;\n background-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-ltr .ag-pinned-right-header .ag-header-row::after {\n right: 0;\n}\n.ag-theme-alpine .ag-rtl .ag-pinned-left-header .ag-header-row::before {\n left: 0;\n}\n.ag-theme-alpine .ag-row {\n font-size: 14px;\n}\n.ag-theme-alpine input[class^=ag-]:not([type]),\n.ag-theme-alpine input[class^=ag-][type=text],\n.ag-theme-alpine input[class^=ag-][type=number],\n.ag-theme-alpine input[class^=ag-][type=tel],\n.ag-theme-alpine input[class^=ag-][type=date],\n.ag-theme-alpine input[class^=ag-][type=datetime-local],\n.ag-theme-alpine textarea[class^=ag-] {\n min-height: 24px;\n border-radius: 3px;\n}\n.ag-theme-alpine .ag-ltr input[class^=ag-]:not([type]),\n.ag-theme-alpine .ag-ltr input[class^=ag-][type=text],\n.ag-theme-alpine .ag-ltr input[class^=ag-][type=number],\n.ag-theme-alpine .ag-ltr input[class^=ag-][type=tel],\n.ag-theme-alpine .ag-ltr input[class^=ag-][type=date],\n.ag-theme-alpine .ag-ltr input[class^=ag-][type=datetime-local],\n.ag-theme-alpine .ag-ltr textarea[class^=ag-] {\n padding-left: 6px;\n}\n\n.ag-theme-alpine .ag-rtl input[class^=ag-]:not([type]),\n.ag-theme-alpine .ag-rtl input[class^=ag-][type=text],\n.ag-theme-alpine .ag-rtl input[class^=ag-][type=number],\n.ag-theme-alpine .ag-rtl input[class^=ag-][type=tel],\n.ag-theme-alpine .ag-rtl input[class^=ag-][type=date],\n.ag-theme-alpine .ag-rtl input[class^=ag-][type=datetime-local],\n.ag-theme-alpine .ag-rtl textarea[class^=ag-] {\n padding-right: 6px;\n}\n\n.ag-theme-alpine .ag-tab {\n padding: 9px;\n -webkit-transition: color 0.4s;\n transition: color 0.4s;\n}\n.ag-theme-alpine .ag-tab-selected {\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3);\n}\n.ag-theme-alpine .ag-menu {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n}\n.ag-theme-alpine .ag-menu-header {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n padding-top: 1px;\n}\n.ag-theme-alpine .ag-tabs-header {\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7);\n}\n.ag-theme-alpine .ag-charts-settings-group-title-bar,\n.ag-theme-alpine .ag-charts-data-group-title-bar,\n.ag-theme-alpine .ag-charts-format-top-level-group-title-bar {\n padding: 6px 12px;\n line-height: 20px;\n}\n.ag-theme-alpine .ag-chart-mini-thumbnail {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-alpine .ag-chart-settings-nav-bar {\n border-top: solid 1px;\n border-top-color: #dde2eb;\n border-top-color: var(--ag-secondary-border-color, #dde2eb);\n}\n.ag-theme-alpine .ag-ltr .ag-group-title-bar-icon {\n margin-right: 6px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-group-title-bar-icon {\n margin-left: 6px;\n}\n\n.ag-theme-alpine .ag-charts-format-top-level-group-toolbar {\n margin-top: 6px;\n}\n.ag-theme-alpine .ag-ltr .ag-charts-format-top-level-group-toolbar {\n padding-left: 20px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-charts-format-top-level-group-toolbar {\n padding-right: 20px;\n}\n\n.ag-theme-alpine .ag-charts-format-sub-level-group {\n border-left: dashed 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7);\n padding-left: 6px;\n margin-bottom: 12px;\n}\n.ag-theme-alpine .ag-charts-format-sub-level-group-title-bar {\n padding-top: 0;\n padding-bottom: 0;\n background: none;\n font-weight: 700;\n}\n.ag-theme-alpine .ag-charts-format-sub-level-group-container {\n padding-bottom: 0;\n}\n.ag-theme-alpine .ag-charts-format-sub-level-group-item:last-child {\n margin-bottom: 0;\n}\n.ag-theme-alpine .ag-dnd-ghost {\n font-size: 12px;\n font-weight: 700;\n}\n.ag-theme-alpine .ag-side-buttons {\n width: 30px;\n}\n.ag-theme-alpine .ag-standard-button {\n -moz-appearance: none;\n appearance: none;\n -webkit-appearance: none;\n border-radius: 3px;\n border: 1px solid;\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3);\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n font-weight: 600;\n padding: 6px 12px;\n}\n.ag-theme-alpine .ag-standard-button:hover {\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1));\n}\n.ag-theme-alpine .ag-standard-button:active {\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n background-color: #2196f3;\n background-color: var(--ag-alpine-active-color, #2196f3);\n color: #fff;\n color: var(--ag-background-color, #fff);\n}\n.ag-theme-alpine .ag-standard-button:disabled {\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n background-color: #f1f2f4;\n background-color: var(--ag-input-disabled-background-color, #f1f2f4);\n border-color: rgba(186, 191, 199, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(186, 191, 199, 0.3));\n}\n.ag-theme-alpine .ag-column-drop-vertical {\n min-height: 75px;\n}\n.ag-theme-alpine .ag-column-drop-vertical-title-bar {\n padding: 12px;\n padding-bottom: 0px;\n}\n.ag-theme-alpine .ag-column-drop-vertical-empty-message {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n border: dashed 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n margin: 12px;\n padding: 12px;\n}\n.ag-theme-alpine .ag-column-drop-empty-message {\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f);\n opacity: 0.75;\n}\n.ag-theme-alpine .ag-status-bar {\n font-weight: normal;\n}\n.ag-theme-alpine .ag-status-name-value-value {\n font-weight: 700;\n}\n.ag-theme-alpine .ag-paging-number, .ag-theme-alpine .ag-paging-row-summary-panel-number {\n font-weight: 700;\n}\n.ag-theme-alpine .ag-column-drop-cell-button {\n opacity: 0.5;\n}\n.ag-theme-alpine .ag-column-drop-cell-button:hover {\n opacity: 0.75;\n}\n.ag-theme-alpine .ag-header-cell-menu-button:hover,\n.ag-theme-alpine .ag-side-button-button:hover,\n.ag-theme-alpine .ag-tab:hover,\n.ag-theme-alpine .ag-panel-title-bar-button:hover,\n.ag-theme-alpine .ag-header-expand-icon:hover,\n.ag-theme-alpine .ag-column-group-icons:hover,\n.ag-theme-alpine .ag-group-expanded .ag-icon:hover,\n.ag-theme-alpine .ag-group-contracted .ag-icon:hover,\n.ag-theme-alpine .ag-chart-settings-prev:hover,\n.ag-theme-alpine .ag-chart-settings-next:hover,\n.ag-theme-alpine .ag-group-title-bar-icon:hover,\n.ag-theme-alpine .ag-column-select-header-icon:hover,\n.ag-theme-alpine .ag-floating-filter-button-button:hover,\n.ag-theme-alpine .ag-filter-toolpanel-expand:hover,\n.ag-theme-alpine .ag-chart-menu-icon:hover {\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3);\n}\n.ag-theme-alpine .ag-chart-settings-card-item.ag-not-selected:hover {\n opacity: 0.35;\n}\n.ag-theme-alpine .ag-ltr .ag-panel-title-bar-button {\n margin-left: 12px;\n margin-right: 6px;\n}\n\n.ag-theme-alpine .ag-rtl .ag-panel-title-bar-button {\n margin-right: 12px;\n margin-left: 6px;\n}\n\n.ag-theme-alpine .ag-filter-toolpanel-group-container {\n padding-left: 6px;\n}\n.ag-theme-alpine .ag-filter-toolpanel-instance-filter {\n border: none;\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n border-left: dashed 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7);\n margin-left: 8px;\n padding-left: 8px;\n margin-right: 12px;\n}\n.ag-theme-alpine .ag-set-filter-list {\n padding-top: 3px;\n padding-bottom: 3px;\n}\n.ag-theme-alpine .ag-layout-auto-height .ag-center-cols-clipper, .ag-theme-alpine .ag-layout-auto-height .ag-center-cols-container, .ag-theme-alpine .ag-layout-print .ag-center-cols-clipper, .ag-theme-alpine .ag-layout-print .ag-center-cols-container {\n min-height: 150px;\n}\n.ag-theme-alpine .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 60px;\n}\n.ag-theme-alpine .ag-date-time-list-page-entry-is-current {\n background-color: #2196f3;\n background-color: var(--ag-alpine-active-color, #2196f3);\n}\n", ""]); // Exports module.exports = exports; /***/ }), -/* 232 */ +/* 285 */ /***/ (function(module, exports, __webpack_require__) { -var api = __webpack_require__(225); - var content = __webpack_require__(233); +var api = __webpack_require__(278); + var content = __webpack_require__(286); content = content.__esModule ? content.default : content; @@ -48576,24 +57521,24 @@ var update = api(content, options); module.exports = content.locals || {}; /***/ }), -/* 233 */ +/* 286 */ /***/ (function(module, exports, __webpack_require__) { // Imports -var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227); +var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(280); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, ".ag-theme-balham-dark {\n -webkit-font-smoothing: antialiased;\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5);\n font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n font-size: 12px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridBalham\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABX4AAsAAAAAJ8wAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlEAAAReXgFf/09TLzIAAANcAAAAPgAAAFZWTFJaY21hcAAAA5wAAAHtAAAFgFIH7gFnbHlmAAAFjAAADLgAABYYNphscGhlYWQAABJEAAAALwAAADZ2zsSBaGhlYQAAEnQAAAAbAAAAJAfTBC1obXR4AAASkAAAABIAAAEUp/gAAGxvY2EAABKkAAAAZAAAAIwBFQakbWF4cAAAEwgAAAAfAAAAIAFbAHNuYW1lAAATKAAAATUAAAJG0OP3eXBvc3QAABRgAAABlwAAAlqez14KeJx9k09yElEQxr9hCBKISYwxloga/0bjOAwM/yQQCFKWZWXhwoULN3GhpZVylRO49gCWB/AUnsBy6coDeADLA/jrZpCYRXjFzJvur7/+ul8/BZJKSrSr3OTx/nMtHx4cvVdFeU1/5j++Dw7fvjlQcfaFL+/vooLwj5Z1Qy90pG+BgtfB51whzIW74X74IfwU/lAIalMx6LIesGLVeEZkr6uhVDkVsMXsm2qBDnm23bqmC1pwz1AjrZMzJmbkjNt6qptahWfgPH31QCUs4+zzHLNuaeUURKrb8NdR08VqrFUyrGpRe2jso6NDdAvvCr4dMkfEDPANdA68ofLexyd6iaI1r80i6xku4R/TZfuO/KvMmqHa8DfgN74tss7sDTLViLgHex3Uw6yH27pGdAOePmwdj256dBlkDYWJrrKzympUtkT9PT3TK8+6m8X0vYvTmrdQP7cPnC+l2uPWDlxjsHfRMLfaidwhV6QJ/pI2eL/TR33RV33XT/3Sb53B2sVrFfTg3jm1M0X6dxI9xNv+Z7VKC5zPSdT/iEXqbnhvYnyjrIOWrYxO603CPsKaOL6ETsMPUZNyGnlyRJ63hnWB1eU7Bn02m8YWa8n7PGIGbAIqdKfB05im85bS4Usw2W6qa8O71YLnop+W9dRu0rJ/2czbKVfAXOYdUVnd+/MI7xUsxjS3VD0qRbVx3MefonaezVRVUdX02bXJmvgtGJJpkzqmSmrcXLsBE5+q6yioZzdyndMw9Z3spM47LvaoAM1RdpMT75lN8gBtNhXjv2nbY10AAAB4nGNgZMpnnMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVFgEqgRRAAAy9AKRgAAeJy102dSWzEUhuHXhW56TaN3Y2wwvRkb/rAM0hlSGNKZrDI70QZCvnPPyQLITDTz+Ls6o6srjSygDSjImhQhXySHtd+q5rJ6ge6sXuSX+iU6yeu5whU33KXa/b2qFS655jblst7fltPoEk9ZZEe9I811oKdjqrT0xh4b7LPLCXU2OWWdbWo0OGeLQ5qc6f28vl7UGtvp0He7tJIezdhLH/0MMMgQw4wwyhjjTPCYJ/raM42ZZIppZpjVuDnmWdAalvTcwzIr+l1Vr6wFtvOwdvTA8dbWDnaOq63Knna7e1Lf1Ea3a43zrcPm2T9M9h9ayX4KP6N3gZ2ms91eBvt/PA8H8iLYyb4Mx/IqVOV1aMmbYPO+DXtyFTbkOuzLu7Ar78OJfAh1+Rg25Sacym1Yl09hWz6HmnwJDfkazuVb2JLv4VB+hKbcBR1gyjm7KynvsCw4u1up6Ox+pTZn9y61Oyw7HJadDssuh2W3s/uYehyWJWcnmXodln0Oy36H5YDDctBhOeSwHHZYjjgsRx2WYw7LcYflhMPykdPdJAXdUlLQfSUF3VxSyPY16bCcclhOOyxnHJazDss5l+133mG1BYfVFh1WW3JYbdlhtRWXzbPqsrWVHTZ2zWFjKy4bs+6w96oum7PmKP8BU32drwAAAHic7RhpcBvVeb+3lmRZsm5pJdk6V4ety9YdS/Zu7MTGdu7DCRlC0jQHDTFH0tAwIYJCaCAhDDSZcEwzFDoDGZgpw7TTDNMmpUMZMFNi0hQ6JTD9AbQNaRtCyXQGFy393molxybl+l1pd9/33vve9773ve96j2EZ/LHPss8yHJNm1jMMeAlnYQ1E0xROkSixCqQYUgXVRlDbbZwXuKawAEULm4JohA+qVXyetzs45a/WyH97Np+1B6K5YqGIuIViIRKl/3yANXcMxqCpCWKDHdJ70nvTNfBIfwvPAWCbSI4HL3j5HNHpEF65de5/4CFxCqw6v9fg0JlanEZ/xMBNidJ+aNLYDf0Gu1rt9XVbPAC72KevRBo8cm2gEF77+JIfXF8nrUzDslMia7ToHQ691dI+4Gh1egycSazouuwhm75bbzWa250hm5+fR0UFsrweYR9hfAxj5TTRIqcJmOUiag7IRTFglgvOPDGcOHw4MQytM0vpY6X+5pXbG/2tynzkZdbGNGNFmYeHN/clz5xJ7hPI0X2JM2cS+6Q5lC2Zt23sNsbGdDJ5xA/S7bDRrcnQfcjRfdBkaN1Ge+R9KdAeK9JFykg/WoRLW1aPZbLZzNjq1+rAlrGRoVg8HhsaeYYCEENo7MnkU08ln5S/7LYZ6DIgzESXIenj+gj8Mg2enawTIQ2jQ5lmzTx9i1k7f7pSOb9z5we33EK2SteR4erzU1PTYz5gzzFWJsogmU4IpiBvzgmQDWS8YDfbDMAGggYKeWmbQHtToAGUH7C56vfTK7q7V6RJreyqVjwZDz5kr1x2SOteyz4KN01jpOUR7E88aU91D37wIXfj5yPEzDwKN8/mKf7VeWIDaBdfxlF/9SXS++XsSKlhWV1m8MJAfXo+0GBJdSVOcpcRp5PdNYsL9tzlvbQcms2BIodb2U2MCjXWyTBa0HBaYIs+qPkGmyNTyFNFJH+X1pc2SlUQJiZeeU6ncxkd6cG0w+iCF+GJMnZIv4W+iQmhtdXbFnEF0+mgK9zupeSb5DmSrEHRGSPDhHlz1qq8QN/jovgrQTghitVTgvA2yVQnp9+GHZPDrAr5RB6p3pND0sXE++8n4FKtVNayCO3JyvBMN52lLsByQ6gsekEEHNhSwK4Izi7vuT2A7eSnl+Ij8dhIghbxkcinkUJB/khNc2MjcTgiXRfOV7APsjJCXDqFH5IpRKSXKCr0RgqSnljiw3ExH57m+2XyMrUVmGG1l5kj8V9uZjN9iOKbssSq+BBYWPMhMDFbLrh1Gi2QQygM6SKYyJ+odExgQhSVLJtjbAkl08MsZMaYdYhfKGYxfNSiAOXMANGa7y/KXgbZ5AxgBDlY0KpaFmiuCAKIkCI4ppClgrVpwqgpqJwZEVBbUsAHNcCv32pZ+/SdoVazpc3tj/QlRhY8s2zl/GVpk1Wr05lMCbE3IXQv5CCybMmGzWsdtvbSSO+mcgLu6V7AgXfnkR8v4Esj5c2luDTpjl8V74om3LHhWFeUfJRm2cX3Xt0e9MbaAy4kHLbY7N3lVW0pm9PutffF+xIP+67OkzVCn83uVbe0x8ubyiMl6ff+NXkyfGMfGwxiS+9I6WxHF1J0J6JdcSymdfUYyzNtTIopo6TkCKuISH25eDBWcgZSl05NIhqUBioZSgmViqOSQLv1AIqGWi1UG/JYcMP1N+1YszSjyEL8zTgsvP9GnyKLZXfyVADDpQ2l0oadG3p6NvwxNrxyOCZ/WL6x+MUh3mCcW1qtLHxsU5NI+sYHawv3uG9ZQlfr60ESNTp/gBglEiO1ouF7kmwS8wn0gqCs0wOaYkFZbKQPAiqbkjPYi/maahTybBI6nQNFZ/MJAAIaZ2HA1Um2V081yxCqSK2XnIt2e8rdbq3+uwfHdpR0za50n7c7NCiate50n6c7tLdrRUe3p5R2a80KP2RK1mdtXaNVZt5MPlG0WvqW0FBsh6SHS4y+tgZyoeFfrLiaNoz4vOzbuximyOez3GVv+EvqU7IvmvZIV65MVWo/USkFpUR2mmfkaXm0uT6mnxlkRr5uxmZFblQYc8Kzym+Ymx2tVGCX9Ar0SPsbkB6hS9IoHP9m6Vj1n4IgiMrbiGfTe1jz1tTLk7jisf8sCHWvXf037mBdD3ewbSg5M913dMh061muGMXVFqMkKsJ+aZd4QDoLkcnJdAXelbyVNHlQOCEcgAhEpLOTGdyBTJ3WdowDMWa1rNMoVg0KGN0blWpBhHwkmkY9NwCqtBdzXhHVFVXdGpSxsJF6u5TSQUfbsAOb07Ldy1R44sRYGWhraWkf96zoCOU0aofLomctYVO70WDi43t6Yr7xpNPDxTbFFnm2dXHtXNzbDJqwy66z0CHxInA2C+hYC29ot7Xo5qUinWRQq1e1Le+MeLZ5rK2tfRF+yG1h+bAlZI9u7E6H4m2c0b8tdU855QOtH6neXe72e7U6lW9TkkOqVoNxScqTt8ljAtbQtcn0Eqvp/zK5kkxqNnofe9/n/AZDrYzGaRW+ssXhW1TqGoTRaoWbJxIT8GJiIgGuqanq5NTUAoTJOmxF77FuyocAPokMWsU6LPGZeHpq2j6qpMqoGTwyWH3UQDThLsDsoPgP9q2hHct2wO+UcuIsS8vHaoWS4yTJ6/X8G9A66n82WX0APbDygktEexDrex/EmCbPp0ykTAuvN8kT/bA237/easJiO7zwFju0ffkOZewzmLvV7LKejaA51w43UDqYevts6mA//KIfobe7DsLSvfFTp+J74WR1Ek7WYJyZ0rmL3cU4mAQzh5kr5yAMUFXjHLLaoa5R7SoKhKNVjVrRQwxEsm4hGm2NRrpACw45BnWBwwcgjyoUOTlyccUITF27atkNLfpYZNHI81dfO69vLiFh/4339S8dnn+NVhuOLF98cvFYjG9uXjM0uvqCX61e0jcwmktHYbf0YXa8M2Y0W08O9HRI+0I6p7tQWq4Vchm7w/KZj/0eyaWPrdt8zdI5+bDdIfQ8tnL1aP/GgkgSsfuXji1akoqrYslVI2PLHownX+0bGaoEQxqV2wG3SQ+b2sKRXKn8GvE6pH3iof55nUmVwHZ29Arlz1qUfR1nb0Pt62B6UTLy4U8+ENr5zyf/vCbjsKmDkVwBAsEINhXKYA/ksxkHIqrJdr3B5Vvlcxn0lWBPEB+4VCunzC5X0OUCnaR3h0JuEXYJ7nCY9VhsToPFYnDaLIgkjSqDjuPH7PQ78ak+HnbBcXeoUgm5pVFXuOGz9yDPQYxuDNSzxgLuAS1EoNuloXkD9TRoTzS98IEmgquC2v4VOUdWTi1h2SEgTSqtp9RV3Nhs1LssnA289rmD38HsgrXZk9xDGDj+YtXqm01HCx0ZM7ibOQLN5Ehzi85osJjegNsPYS5l1HfotLoNbq+zzWoxSO+2j+k3q1WufLyb0yEF8oDJZDU4jhpYtk36q9oWdeYsD2Gk0zRb3qDLabksbvtxJ/qZIWYBs5K5htnAbPkfsTtgdsgXJyoavn2Y5tUsw46JoIavXTk4ZMGEbVw2H1VrsvliDFAiWUw87Fmq3WE1r7FnixHenv2iwA67q698eAGjrrbaDBiD/fDLlsTYyoQ2NtSxU5sYG0u0zA1l3F6ovgp7bgOoiLkFmAnsFuHkboqP4uiJ3fHCnKvu+MJQ/2n1VbUW0S+cMptwMrgNjDJx7c0dV8WJNrES5wGVxuqIeYfm3P7r0fwdnxTC68U9e4I0IQDYU4HbG/pxDs+19H5Dud0wUXXwU3GYZt1uBGmdXkIV4NK9O7fPmz9/3vadYKpD9+7asrHU21vauOUCAuUyAuw52iFdnIkszMChQG/9vF/nRfha3My6e5FxviqL8NwVblW+Mt/S6NjMkZTY7FyJ5lfo/DEwcZg0oWePstulswdEaRfsFw+kK5IX3q2kJycx4zp7gGZLB2iaNDmp0BnHnKAVvTID5gDm2TYHOhk8Gavqnp51Vp9fkQ6S4WBa+vl46fTp0vhKJPUOhKR36CkfQu3j5dOny+NwuHHfpiKH5XM6KXJFtkm6KKd6ZAtN3xFgZuMBPRNjvpqopfV31coGzov1Mz+HONKhn+HRd4AcQSB5Dww0aCWJje6yFWVwQg6AVqFx93QDO477Hsf8m7EGMdHG0wxGHXpYRS+LscWK+Y2XoMOKaqbzoSjQzIeTTZteltZgGqT4Y4SECPkRzDlPVDIkTZwnphTncSz/9saQkBT4rTFnQNNsdwtJeKJzsQebzElX1yqL2exD2OdXO9o2zmG34WAVOSpNfIAEQU2OQvE8kW7FVAbxfTIhfZsp1R4abUNCo36ZjoNVZRIda5CO6Fu1tiNdxhX+FyXYf3Z4nGNgZGBgAOJNb47Mjue3+crAzfwCKBDF+XhfA4JmYGB+CRJn4GBgAvEAeqIMgAB4nGNgZGBgfsHAACH//2d+ycDIgApcAXBnBQgAeJxjYGBgYH4xdDA9AADYnCd6AAB4nGNgAIIZDBcYnjE6MEYxLmF8xaTBFMVUw9THdIPpEzMHswzzBhYNlgKWLpYrrEGsOayT2GTYlrE9Ymdgl2K3YI9hf8PhxrGBM4xzDhcTlxpXAFcKVxlXF9cMbh7SIQDoHxaseJxjYGRgYHBlSGfgYQABJiDmAkIGhv9gPgMAGrQBzwB4nHWPP07DMBjFX2haRIsQEhJiwxMLUvpnYOjYodk7dGBzGydtlcSR41bqxjE4Acdg5AicgkPwEr6hQqotOT///N4nBcAtvhCgWQGu27NZF7jk7Y87pDvhkPwo3MUAz8I9+hfhPu1MeMBmwQlBeEXzgDfhC9zgXbhD/yEckj+Fu7jHt3CP/ke4j2UQCg/wFLzqLHbbZKbzjS4WJtvn2p2qU14aV29tqcbR6FTHpjROe5Oo1VHVh2zifapSZws1t6U3eW5V5ezOrH208b6aDoep+GhtC2hkiOGwRcI/18ix4VlgAcOXPe+ar+dS5/ySbYea3qKEwhgRRmfTMdNl29Dw/CZsrHDkWePAzoTWI+U9ZcayoTBvJzfpnNvSVO3bjmZNH3F206owxZA7/ZePmOKkX1qXaMkAAAB4nG2R6W7bMBCE/cWSrThp47ptet/3obbpfadX+h40RclEJFIgKR95+hJ1ESBA9w9nBsvZWbK30VvXqPf/OmCDPgkpA4ZkbDJii21OcZodxpxhwlnOcZ5dLnCRS1zmCle5xnVucJNb3OYOd7nHfR7wkEc85glPyXnGc16wx0te8Zo3vOUd7/nARz7xmS98ZZ9vfOcHP/nFAb97W6KqnKpE0NYMhHN24fvCy4EURqo6lTPhwljOlDyc2mX+F6hi91jQplBBuUYbEdTkWO7Mv85taWvr8lZH4oaRdI3xI2lNcEIGVSTStqtUOut9UigvM7VsRfQsNtVK5b4WftaPaFDqOo5JS+18SCqn27RytmuT2BCSWpVhUGsT52XrI98b1lYU2lRZI5a60UcqaZTpshh0zYw1asvYkIu6tgtVpG10Uv1Wm7TVcxvGLl63+bQLwZrcluXOScGkTlezkHgxVyPfRJe8sAuTrWFMFuLKk+CUOvlGWWfWERFUOBQBjcWwwCOpmXHIlGX8zYKGjpYVJUfMe70/6zKeWwA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-balham-dark .ag-icon {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-balham-dark .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-balham-dark .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-balham-dark .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-balham-dark .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-balham-dark .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-balham-dark .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-balham-dark .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-balham-dark .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-balham-dark .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-balham-dark .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-balham-dark .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-balham-dark .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-balham-dark .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-balham-dark .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-balham-dark .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-balham-dark .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-balham-dark .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-balham-dark .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-balham-dark .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-balham-dark .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-balham-dark .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-balham-dark .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-balham-dark .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-balham-dark .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-balham-dark .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-balham-dark .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-balham-dark .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-balham-dark .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-balham-dark .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-balham-dark .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-balham-dark .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-balham-dark .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-balham-dark .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-balham-dark .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-balham-dark .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-balham-dark .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-balham-dark .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-balham-dark .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-balham-dark .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-balham-dark .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-balham-dark .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-balham-dark .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-balham-dark .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-balham-dark .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-balham-dark .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-balham-dark .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-balham-dark .ag-root-wrapper {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436); }\n .ag-theme-balham-dark [class^='ag-'], .ag-theme-balham-dark [class^='ag-']:focus, .ag-theme-balham-dark [class^='ag-']:after, .ag-theme-balham-dark [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-balham-dark [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-balham-dark .ag-checkbox .ag-input-wrapper,\n .ag-theme-balham-dark .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-balham-dark .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-balham-dark .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-balham-dark .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px; }\n .ag-theme-balham-dark input[class^='ag-'] {\n margin: 0;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436); }\n .ag-theme-balham-dark textarea[class^='ag-'],\n .ag-theme-balham-dark select[class^='ag-'] {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436); }\n .ag-theme-balham-dark input[class^='ag-']:not([type]),\n .ag-theme-balham-dark input[class^='ag-'][type='text'],\n .ag-theme-balham-dark input[class^='ag-'][type='number'],\n .ag-theme-balham-dark input[class^='ag-'][type='tel'],\n .ag-theme-balham-dark input[class^='ag-'][type='date'],\n .ag-theme-balham-dark input[class^='ag-'][type='datetime-local'],\n .ag-theme-balham-dark textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #f0f0f0;\n border-color: var(--ag-input-border-color, #f0f0f0); }\n .ag-theme-balham-dark input[class^='ag-']:not([type]):disabled,\n .ag-theme-balham-dark input[class^='ag-'][type='text']:disabled,\n .ag-theme-balham-dark input[class^='ag-'][type='number']:disabled,\n .ag-theme-balham-dark input[class^='ag-'][type='tel']:disabled,\n .ag-theme-balham-dark input[class^='ag-'][type='date']:disabled,\n .ag-theme-balham-dark input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-balham-dark textarea[class^='ag-']:disabled {\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n background-color: rgba(48, 46, 46, 0.3);\n background-color: var(--ag-input-disabled-background-color, rgba(48, 46, 46, 0.3));\n border-color: rgba(240, 240, 240, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(240, 240, 240, 0.3)); }\n .ag-theme-balham-dark input[class^='ag-']:not([type]):focus,\n .ag-theme-balham-dark input[class^='ag-'][type='text']:focus,\n .ag-theme-balham-dark input[class^='ag-'][type='number']:focus,\n .ag-theme-balham-dark input[class^='ag-'][type='tel']:focus,\n .ag-theme-balham-dark input[class^='ag-'][type='date']:focus,\n .ag-theme-balham-dark input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-balham-dark textarea[class^='ag-']:focus {\n outline: none;\n box-shadow: 0 0 4px 1.5px #719ECE;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-balham-dark input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-balham-dark input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-balham-dark input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-balham-dark input[class^='ag-'][type='button']:focus, .ag-theme-balham-dark button[class^='ag-']:focus {\n box-shadow: 0 0 4px 1.5px #719ECE; }\n .ag-theme-balham-dark .ag-drag-handle {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-list-item, .ag-theme-balham-dark .ag-virtual-list-item {\n height: 28px; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-select-list {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-balham-dark .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-balham-dark .ag-list-item.ag-active-item {\n background-color: #3d4749;\n background-color: var(--ag-row-hover-color, #3d4749); }\n .ag-theme-balham-dark .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-balham-dark .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-balham-dark .ag-select .ag-picker-field-wrapper {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n min-height: 28px;\n cursor: default; }\n .ag-theme-balham-dark .ag-select:not(.ag-cell-editor) {\n height: 28px; }\n .ag-theme-balham-dark .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-balham-dark .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-balham-dark .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-balham-dark .ag-rich-select {\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020); }\n .ag-theme-balham-dark .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 182px; }\n .ag-theme-balham-dark .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 28px;\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242)); }\n .ag-theme-balham-dark .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 28px; }\n .ag-theme-balham-dark .ag-rich-select-virtual-list-item:hover {\n background-color: #3d4749;\n background-color: var(--ag-row-hover-color, #3d4749); }\n .ag-theme-balham-dark .ag-rich-select-row {\n padding-left: 12px; }\n .ag-theme-balham-dark .ag-rich-select-row-selected {\n background-color: #005880;\n background-color: var(--ag-selected-row-background-color, #005880); }\n .ag-theme-balham-dark .ag-row-drag,\n .ag-theme-balham-dark .ag-selection-checkbox,\n .ag-theme-balham-dark .ag-group-expanded,\n .ag-theme-balham-dark .ag-group-contracted {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-ltr .ag-row-drag, .ag-theme-balham-dark .ag-ltr .ag-selection-checkbox, .ag-theme-balham-dark .ag-ltr .ag-group-expanded, .ag-theme-balham-dark .ag-ltr .ag-group-contracted {\n margin-right: 12px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-drag, .ag-theme-balham-dark .ag-rtl .ag-selection-checkbox, .ag-theme-balham-dark .ag-rtl .ag-group-expanded, .ag-theme-balham-dark .ag-rtl .ag-group-contracted {\n margin-left: 12px; }\n .ag-theme-balham-dark .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 26px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-balham-dark .ag-group-expanded,\n .ag-theme-balham-dark .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-balham-dark .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-balham-dark .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-balham-dark .ag-group-title-bar {\n background-color: #111;\n background-color: var(--ag-subheader-background-color, #111);\n padding: 4px; }\n .ag-theme-balham-dark .ag-group-toolbar {\n padding: 4px; }\n .ag-theme-balham-dark .ag-disabled-group-title-bar, .ag-theme-balham-dark .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-balham-dark .group-item {\n margin: 2px 0; }\n .ag-theme-balham-dark .ag-label {\n white-space: nowrap; }\n .ag-theme-balham-dark .ag-ltr .ag-label {\n margin-right: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-label {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-label-align-top .ag-label {\n margin-bottom: 2px; }\n .ag-theme-balham-dark .ag-ltr .ag-slider-field, .ag-theme-balham-dark .ag-ltr .ag-angle-select-field {\n margin-right: 8px; }\n .ag-theme-balham-dark .ag-rtl .ag-slider-field, .ag-theme-balham-dark .ag-rtl .ag-angle-select-field {\n margin-left: 8px; }\n .ag-theme-balham-dark .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436); }\n .ag-theme-balham-dark .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #F5F5F5;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n border-radius: 5px; }\n .ag-theme-balham-dark .ag-picker-field-wrapper:focus {\n box-shadow: 0 0 4px 1.5px #719ECE; }\n .ag-theme-balham-dark .ag-picker-field-button {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-balham-dark .ag-color-picker .ag-picker-field-display {\n height: 16px; }\n .ag-theme-balham-dark .ag-color-panel {\n padding: 4px; }\n .ag-theme-balham-dark .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-balham-dark .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-balham-dark .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-balham-dark .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-balham-dark .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-balham-dark .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-balham-dark .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-balham-dark .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-balham-dark .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-balham-dark .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-balham-dark .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-balham-dark .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-balham-dark.ag-dnd-ghost {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242));\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n height: 32px !important;\n line-height: 32px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px); }\n .ag-theme-balham-dark .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5); }\n .ag-theme-balham-dark .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3); }\n .ag-dragging-range-handle .ag-theme-balham-dark .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-balham-dark .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-balham-dark .ag-dialog {\n border-radius: 2px;\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-panel {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436); }\n .ag-theme-balham-dark .ag-panel-title-bar {\n background-color: #1c1c1c;\n background-color: var(--ag-header-background-color, #1c1c1c);\n color: rgba(245, 245, 245, 0.64);\n color: var(--ag-header-foreground-color, rgba(245, 245, 245, 0.64));\n height: 32px;\n padding: 4px 12px;\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px; }\n .ag-theme-balham-dark .ag-tooltip {\n background-color: #1c1c1c;\n background-color: var(--ag-header-background-color, #1c1c1c);\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5);\n padding: 4px;\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n border-radius: 2px;\n transition: opacity 1s; }\n .ag-theme-balham-dark .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-1 {\n padding-left: 20px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-1 {\n padding-right: 20px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-2 {\n padding-left: 40px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-2 {\n padding-right: 40px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-3 {\n padding-left: 60px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-3 {\n padding-right: 60px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-4 {\n padding-left: 80px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-4 {\n padding-right: 80px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-5 {\n padding-left: 100px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-5 {\n padding-right: 100px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-6 {\n padding-left: 120px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-6 {\n padding-right: 120px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-7 {\n padding-left: 140px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-7 {\n padding-right: 140px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-8 {\n padding-left: 160px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-8 {\n padding-right: 160px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-9 {\n padding-left: 180px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-9 {\n padding-right: 180px; }\n .ag-theme-balham-dark .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 6px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 6px; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-column-select-column-group:not(:last-child),\n .ag-theme-balham-dark .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px; }\n .ag-theme-balham-dark .ag-column-select-column-readonly,\n .ag-theme-balham-dark .ag-column-select-column-group-readonly {\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n pointer-events: none; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 24px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 24px; }\n .ag-theme-balham-dark .ag-column-select-list {\n padding: 6px 6px; }\n .ag-theme-balham-dark .ag-rtl {\n text-align: right; }\n .ag-theme-balham-dark .ag-root-wrapper {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n border-radius: 2px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 40px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 40px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-1 {\n padding-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-1 {\n padding-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 68px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 68px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-2 {\n padding-left: 56px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-2 {\n padding-right: 56px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 96px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 96px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-3 {\n padding-left: 84px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-3 {\n padding-right: 84px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 124px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 124px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-4 {\n padding-left: 112px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-4 {\n padding-right: 112px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 152px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 152px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-5 {\n padding-left: 140px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-5 {\n padding-right: 140px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 180px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 180px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-6 {\n padding-left: 168px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-6 {\n padding-right: 168px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 208px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 208px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-7 {\n padding-left: 196px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-7 {\n padding-right: 196px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 236px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 236px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-8 {\n padding-left: 224px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-8 {\n padding-right: 224px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 264px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 264px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-9 {\n padding-left: 252px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-9 {\n padding-right: 252px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 292px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 292px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-10 {\n padding-left: 280px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-10 {\n padding-right: 280px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 320px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 320px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-11 {\n padding-left: 308px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-11 {\n padding-right: 308px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 348px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 348px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-12 {\n padding-left: 336px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-12 {\n padding-right: 336px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 376px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 376px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-13 {\n padding-left: 364px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-13 {\n padding-right: 364px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 404px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 404px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-14 {\n padding-left: 392px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-14 {\n padding-right: 392px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 432px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 432px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-15 {\n padding-left: 420px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-15 {\n padding-right: 420px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 460px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 460px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-16 {\n padding-left: 448px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-16 {\n padding-right: 448px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 488px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 488px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-17 {\n padding-left: 476px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-17 {\n padding-right: 476px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 516px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 516px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-18 {\n padding-left: 504px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-18 {\n padding-right: 504px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 544px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 544px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-19 {\n padding-left: 532px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-19 {\n padding-right: 532px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-balham-dark .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-balham-dark .ag-value-change-delta-up {\n color: #43a047;\n color: var(--ag-value-change-delta-up-color, #43a047); }\n .ag-theme-balham-dark .ag-value-change-delta-down {\n color: #e53935;\n color: var(--ag-value-change-delta-down-color, #e53935); }\n .ag-theme-balham-dark .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-balham-dark .ag-value-change-value-highlight {\n background-color: rgba(22, 160, 133, 0.5);\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5));\n transition: background-color 0.1s; }\n .ag-theme-balham-dark .ag-cell-data-changed {\n background-color: rgba(22, 160, 133, 0.5) !important;\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5)) !important; }\n .ag-theme-balham-dark .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-cell-highlight {\n background-color: #00B0FF !important;\n background-color: var(--ag-range-selection-highlight-color, var(--ag-balham-active-color, #00B0FF)) !important; }\n .ag-theme-balham-dark .ag-row {\n height: 28px;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n color: #F5F5F5;\n color: var(--ag-data-color, var(--ag-foreground-color, #F5F5F5));\n border-width: 1px;\n border-color: #5c5c5c;\n border-color: var(--ag-row-border-color, #5c5c5c); }\n .ag-theme-balham-dark .ag-row:not(.ag-row-first) {\n border-top-style: solid; }\n .ag-theme-balham-dark .ag-row.ag-row-last {\n border-bottom-style: solid; }\n .ag-theme-balham-dark .ag-row-highlight-above::after, .ag-theme-balham-dark .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #00B0FF;\n background-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n left: 1px; }\n .ag-theme-balham-dark .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-balham-dark .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-balham-dark .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-balham-dark .ag-row-odd {\n background-color: #262c2e;\n background-color: var(--ag-odd-row-background-color, #262c2e); }\n .ag-theme-balham-dark .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-row-hover {\n background-color: #3d4749;\n background-color: var(--ag-row-hover-color, #3d4749); }\n .ag-theme-balham-dark .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-balham-dark .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-balham-dark .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-balham-dark .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-balham-dark .ag-cell {\n border: 1px solid transparent;\n line-height: 26px;\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-balham-dark .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-balham-dark .ag-row-dragging {\n cursor: move; }\n .ag-theme-balham-dark .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-balham-dark .ag-cell-inline-editing {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 28px;\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020); }\n .ag-theme-balham-dark .ag-popup-editor {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020);\n padding: 0; }\n .ag-theme-balham-dark .ag-large-text-input {\n height: auto;\n padding: 12px; }\n .ag-theme-balham-dark .ag-details-row {\n padding: 20px;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436); }\n .ag-theme-balham-dark .ag-overlay-loading-wrapper {\n background-color: rgba(45, 52, 54, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(45, 52, 54, 0.66)); }\n .ag-theme-balham-dark .ag-overlay-loading-center {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px; }\n .ag-theme-balham-dark .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-balham-dark .ag-loading {\n padding-left: 12px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-balham-dark .ag-loading-icon {\n padding-right: 12px; }\n .ag-theme-balham-dark .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-balham-dark .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-ltr .ag-cell {\n border-right: solid transparent; }\n .ag-theme-balham-dark .ag-rtl .ag-cell {\n border-left: solid transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-balham-dark .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-balham-dark .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-row-selected {\n background-color: #005880;\n background-color: var(--ag-selected-row-background-color, #005880); }\n .ag-theme-balham-dark .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(0, 176, 255, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(0, 176, 255, 0.2)); }\n .ag-theme-balham-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(45, 166, 255, 0.5);\n background-color: var(--ag-range-selection-chart-background-color, rgba(45, 166, 255, 0.5)); }\n .ag-theme-balham-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(26, 177, 74, 0.5);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(26, 177, 74, 0.5)); }\n .ag-theme-balham-dark .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(0, 176, 255, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(0, 176, 255, 0.2))); }\n .ag-theme-balham-dark .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(0, 176, 255, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(0, 176, 255, 0.36)); }\n .ag-theme-balham-dark .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(0, 176, 255, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(0, 176, 255, 0.488)); }\n .ag-theme-balham-dark .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(0, 176, 255, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(0, 176, 255, 0.5904)); }\n .ag-theme-balham-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #00B0FF;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #00B0FF;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #00B0FF;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #00B0FF;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-balham-dark .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-balham-dark .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-balham-dark .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-balham-dark .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-balham-dark .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #00B0FF;\n border-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n outline: initial; }\n .ag-theme-balham-dark .ag-cell.ag-selection-fill-top,\n .ag-theme-balham-dark .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #00B0FF;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-balham-dark .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #00B0FF;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-balham-dark .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #00B0FF;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-cell.ag-selection-fill-bottom,\n .ag-theme-balham-dark .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #00B0FF;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-balham-dark .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #00B0FF;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-balham-dark .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #00B0FF;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-fill-handle, .ag-theme-balham-dark .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #00B0FF;\n background-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-ltr .ag-fill-handle, .ag-theme-balham-dark .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-balham-dark .ag-rtl .ag-fill-handle, .ag-theme-balham-dark .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-balham-dark .ag-fill-handle {\n cursor: cell; }\n .ag-theme-balham-dark .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-balham-dark .ag-cell-inline-editing {\n border-color: #719ECE !important;\n border-color: var(--ag-input-focus-border-color, #719ECE) !important; }\n .ag-theme-balham-dark .ag-menu {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n padding: 0; }\n .ag-theme-balham-dark .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-balham-dark .ag-menu-option-part {\n padding-top: 6px;\n padding-bottom: 6px;\n line-height: 16px; }\n .ag-theme-balham-dark .ag-menu-option-active {\n background-color: #3d4749;\n background-color: var(--ag-row-hover-color, #3d4749); }\n .ag-theme-balham-dark .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-balham-dark .ag-menu-option-text {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-menu-option-icon {\n padding-left: 8px;\n padding-right: 4px;\n min-width: 24px; }\n .ag-theme-balham-dark .ag-menu-option-shortcut {\n padding-left: 8px; }\n .ag-theme-balham-dark .ag-menu-separator {\n height: 8px; }\n .ag-theme-balham-dark .ag-menu-separator-cell:after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-menu-option-popup-pointer {\n width: 24px;\n text-align: center; }\n .ag-theme-balham-dark .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-balham-dark .ag-tab {\n border-bottom: 0 solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-tab-selected {\n border-bottom-color: #00B0FF;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF))); }\n .ag-theme-balham-dark .ag-menu-header {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px; }\n .ag-theme-balham-dark .ag-set-filter-select-all {\n padding-top: 6px; }\n .ag-theme-balham-dark .ag-set-filter-list {\n height: 168px; }\n .ag-theme-balham-dark .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px; }\n .ag-theme-balham-dark .ag-filter-to {\n margin-top: 4px; }\n .ag-theme-balham-dark .ag-mini-filter {\n margin: 6px 6px;\n margin-bottom: 0; }\n .ag-theme-balham-dark .ag-set-filter-item {\n margin: 0px 6px; }\n .ag-theme-balham-dark .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px; }\n .ag-theme-balham-dark .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px; }\n .ag-theme-balham-dark .ag-filter-header-container {\n padding-bottom: 6px;\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242)); }\n .ag-theme-balham-dark .ag-filter-apply-panel {\n padding: 6px 6px;\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242)); }\n .ag-theme-balham-dark .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px; }\n .ag-theme-balham-dark .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-balham-dark .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px; }\n .ag-theme-balham-dark .ag-filter-no-matches {\n margin: 6px 6px; }\n .ag-theme-balham-dark .ag-side-bar {\n position: relative; }\n .ag-theme-balham-dark .ag-tool-panel-wrapper {\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020); }\n .ag-theme-balham-dark .ag-side-buttons {\n padding-top: 16px;\n width: 20px;\n position: relative;\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5);\n overflow: hidden; }\n .ag-theme-balham-dark button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: calc(100% + 1px);\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-selected .ag-side-button-button {\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020);\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-balham-dark .ag-ltr .ag-side-bar-left,\n .ag-theme-balham-dark .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-balham-dark .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-balham-dark .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent;\n margin-right: -1px;\n padding-right: 1px; }\n .ag-theme-balham-dark .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-balham-dark .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #00B0FF;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF))); }\n .ag-theme-balham-dark .ag-rtl .ag-side-bar-left,\n .ag-theme-balham-dark .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-balham-dark .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-balham-dark .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent;\n margin-left: -1px;\n padding-left: 1px; }\n .ag-theme-balham-dark .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-balham-dark .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #00B0FF;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF))); }\n .ag-theme-balham-dark .ag-filter-toolpanel-header {\n height: 24px; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-header, .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-header, .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 4px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-0-header {\n height: 32px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-search {\n height: 32px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 16px; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242)); }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242);\n padding-top: 4px; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px; }\n .ag-theme-balham-dark .ag-pivot-mode-panel {\n height: 32px;\n display: flex; }\n .ag-theme-balham-dark .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-balham-dark .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px; }\n .ag-theme-balham-dark .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-column-select-header {\n height: 32px;\n align-items: center;\n padding: 0 6px;\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242)); }\n .ag-theme-balham-dark .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242));\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242)); }\n .ag-theme-balham-dark .ag-column-group-icons,\n .ag-theme-balham-dark .ag-column-select-header-icon {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-header {\n background-color: #1c1c1c;\n background-color: var(--ag-header-background-color, #1c1c1c);\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-header-row {\n color: rgba(245, 245, 245, 0.64);\n color: var(--ag-header-foreground-color, rgba(245, 245, 245, 0.64)); }\n .ag-theme-balham-dark .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-header-row {\n height: 32px; }\n .ag-theme-balham-dark .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-balham-dark .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-header-cell,\n .ag-theme-balham-dark .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px; }\n .ag-theme-balham-dark .ag-header-cell.ag-header-cell-moving,\n .ag-theme-balham-dark .ag-header-group-cell.ag-header-cell-moving {\n background-color: #2d3436;\n background-color: var(--ag-header-cell-moving-background-color, var(--ag-background-color, #2d3436)); }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-header-icon {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-balham-dark .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-balham-dark .ag-header-row:not(:first-child) .ag-header-cell,\n .ag-theme-balham-dark .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-header-cell::after,\n .ag-theme-balham-dark .ag-header-group-cell::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n width: 1px;\n height: 50%;\n top: calc(50% - 25%);\n background-color: rgba(66, 66, 66, 0.5);\n background-color: var(--ag-header-column-separator-color, rgba(66, 66, 66, 0.5)); }\n .ag-theme-balham-dark .ag-ltr .ag-header-cell::after, .ag-theme-balham-dark .ag-ltr .ag-header-group-cell::after {\n right: 0; }\n .ag-theme-balham-dark .ag-rtl .ag-header-cell::after, .ag-theme-balham-dark .ag-rtl .ag-header-group-cell::after {\n left: 0; }\n .ag-theme-balham-dark .ag-ltr .ag-header-select-all {\n margin-right: 12px; }\n .ag-theme-balham-dark .ag-rtl .ag-header-select-all {\n margin-left: 12px; }\n .ag-theme-balham-dark .ag-ltr .ag-floating-filter-button {\n margin-left: 12px; }\n .ag-theme-balham-dark .ag-rtl .ag-floating-filter-button {\n margin-right: 12px; }\n .ag-theme-balham-dark .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 16px;\n padding: 0;\n width: 16px; }\n .ag-theme-balham-dark .ag-filter-loading {\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-balham-dark .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n height: 32px; }\n .ag-theme-balham-dark .ag-paging-panel > * {\n margin: 0 12px; }\n .ag-theme-balham-dark .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 16px; }\n .ag-theme-balham-dark .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-balham-dark .ag-paging-button-wrapper.ag-disabled {\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n cursor: default; }\n .ag-theme-balham-dark .ag-paging-button-wrapper, .ag-theme-balham-dark .ag-paging-description {\n margin: 0 4px; }\n .ag-theme-balham-dark .ag-status-bar {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5; }\n .ag-theme-balham-dark .ag-status-name-value-value {\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5); }\n .ag-theme-balham-dark .ag-status-bar-center {\n text-align: center; }\n .ag-theme-balham-dark .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px; }\n .ag-theme-balham-dark .ag-column-drop-cell {\n background: #353535;\n background: var(--ag-chip-background-color, #353535);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px; }\n .ag-theme-balham-dark .ag-column-drop-cell-text {\n margin: 0 4px; }\n .ag-theme-balham-dark .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-column-drop-cell-drag-handle {\n margin-left: 8px; }\n .ag-theme-balham-dark .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-balham-dark .ag-column-drop-horizontal {\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020);\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n height: 28px;\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-column-drop-horizontal-empty-message {\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38)); }\n .ag-theme-balham-dark .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px; }\n .ag-theme-balham-dark .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px; }\n .ag-theme-balham-dark .ag-column-drop-vertical-cell {\n margin-top: 4px; }\n .ag-theme-balham-dark .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px;\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242)); }\n .ag-theme-balham-dark .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none; }\n .ag-theme-balham-dark .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px; }\n .ag-theme-balham-dark .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-balham-dark .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n margin-top: 4px; }\n .ag-theme-balham-dark .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n height: 70px;\n padding: 0; }\n .ag-theme-balham-dark .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 20px;\n padding-left: 8px; }\n .ag-theme-balham-dark .ag-select-agg-func-virtual-list-item:hover {\n background-color: #005880;\n background-color: var(--ag-selected-row-background-color, #005880); }\n .ag-theme-balham-dark .ag-chart-menu {\n border-radius: 2px;\n background: #2d3436;\n background: var(--ag-background-color, #2d3436); }\n .ag-theme-balham-dark .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 2px;\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-balham-dark .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: #424242;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242));\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-balham-dark .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-balham-dark .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-balham-dark .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-balham-dark .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-balham-dark .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-balham-dark .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-balham-dark .ag-chart-mini-thumbnail.ag-selected {\n border-color: #00B0FF;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF))); }\n .ag-theme-balham-dark .ag-chart-settings-card-item {\n background: #F5F5F5;\n background: var(--ag-foreground-color, #F5F5F5);\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-balham-dark .ag-chart-settings-card-item.ag-selected {\n background-color: #00B0FF;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF))); }\n .ag-theme-balham-dark .ag-chart-data-column-drag-handle {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-charts-settings-group-title-bar,\n .ag-theme-balham-dark .ag-charts-data-group-title-bar,\n .ag-theme-balham-dark .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242)); }\n .ag-theme-balham-dark .ag-charts-settings-group-container {\n padding: 4px; }\n .ag-theme-balham-dark .ag-charts-data-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-balham-dark .ag-charts-data-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-balham-dark .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px; }\n .ag-theme-balham-dark .ag-charts-format-top-level-group-item {\n margin: 4px 0; }\n .ag-theme-balham-dark .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-balham-dark .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-balham-dark .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px; }\n .ag-theme-balham-dark .ag-chart-data-section,\n .ag-theme-balham-dark .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-balham-dark .ag-chart-menu-panel {\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020); }\n .ag-theme-balham-dark .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-balham-dark .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-balham-dark .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-balham-dark .ag-checkbox-input-wrapper {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #2d3436;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #2d3436));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-balham-dark .ag-checkbox-input-wrapper input, .ag-theme-balham-dark .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-balham-dark .ag-checkbox-input-wrapper:focus-within, .ag-theme-balham-dark .ag-checkbox-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 4px 1.5px #719ECE; }\n .ag-theme-balham-dark .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-balham-dark .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #ecf0f1;\n color: var(--ag-checkbox-unchecked-color, #ecf0f1);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham-dark .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #00B0FF;\n color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham-dark .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #ecf0f1;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, #ecf0f1));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham-dark .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 32px;\n height: 16px;\n background-color: transparent;\n background-color: var(--ag-toggle-button-off-background-color, transparent);\n border-radius: 8px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #F5F5F5;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-balham-dark .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n box-shadow: 0 0 4px 1.5px #719ECE; }\n .ag-theme-balham-dark .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-balham-dark .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #00B0FF;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF)));\n border-color: #00B0FF;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF))); }\n .ag-theme-balham-dark .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 16px;\n width: 16px;\n background-color: #2d3436;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #2d3436));\n border-radius: 8px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #F5F5F5;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-foreground-color, #F5F5F5))); }\n .ag-theme-balham-dark .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 16px);\n border-color: #00B0FF;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF))); }\n .ag-theme-balham-dark .ag-radio-button-input-wrapper {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #2d3436;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #2d3436));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 16px; }\n .ag-theme-balham-dark .ag-radio-button-input-wrapper input, .ag-theme-balham-dark .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-balham-dark .ag-radio-button-input-wrapper:focus-within, .ag-theme-balham-dark .ag-radio-button-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 4px 1.5px #719ECE; }\n .ag-theme-balham-dark .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-balham-dark .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #ecf0f1;\n color: var(--ag-checkbox-unchecked-color, #ecf0f1);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham-dark .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #00B0FF;\n color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham-dark input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-balham-dark input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #424242;\n background-color: var(--ag-border-color, #424242);\n border-radius: 2px;\n border-radius: 3px; }\n .ag-theme-balham-dark input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #424242;\n background-color: var(--ag-border-color, #424242);\n border-radius: 2px;\n border-radius: 3px; }\n .ag-theme-balham-dark input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #424242;\n background-color: var(--ag-border-color, #424242);\n border-radius: 2px;\n border-radius: 3px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-balham-dark input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n border: 1px solid;\n border-color: #ecf0f1;\n border-color: var(--ag-checkbox-unchecked-color, #ecf0f1);\n border-radius: 16px;\n -webkit-transform: translateY(-6.5px);\n transform: translateY(-6.5px); }\n .ag-theme-balham-dark input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n border: 1px solid;\n border-color: #ecf0f1;\n border-color: var(--ag-checkbox-unchecked-color, #ecf0f1);\n border-radius: 16px; }\n .ag-theme-balham-dark input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n border: 1px solid;\n border-color: #ecf0f1;\n border-color: var(--ag-checkbox-unchecked-color, #ecf0f1);\n border-radius: 16px; }\n .ag-theme-balham-dark input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-balham-dark input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n box-shadow: 0 0 4px 1.5px #719ECE;\n border-color: #00B0FF;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark input[class^='ag-'][type='range']:focus::-ms-thumb {\n box-shadow: 0 0 4px 1.5px #719ECE;\n border-color: #00B0FF;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n box-shadow: 0 0 4px 1.5px #719ECE;\n border-color: #00B0FF;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark input[class^='ag-'][type='range']:active::-ms-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-balham-dark .ag-filter-toolpanel-header,\n .ag-theme-balham-dark .ag-filter-toolpanel-search,\n .ag-theme-balham-dark .ag-status-bar,\n .ag-theme-balham-dark .ag-header-row {\n font-weight: 600;\n color: rgba(245, 245, 245, 0.64);\n color: var(--ag-header-foreground-color, rgba(245, 245, 245, 0.64)); }\n .ag-theme-balham-dark .ag-ltr input[class^='ag-']:not([type]),\n .ag-theme-balham-dark .ag-ltr input[class^='ag-'][type='text'],\n .ag-theme-balham-dark .ag-ltr input[class^='ag-'][type='number'],\n .ag-theme-balham-dark .ag-ltr input[class^='ag-'][type='tel'],\n .ag-theme-balham-dark .ag-ltr input[class^='ag-'][type='date'],\n .ag-theme-balham-dark .ag-ltr input[class^='ag-'][type='datetime-local'],\n .ag-theme-balham-dark .ag-ltr textarea[class^='ag-'] {\n padding-left: 4px; }\n .ag-theme-balham-dark .ag-rtl input[class^='ag-']:not([type]),\n .ag-theme-balham-dark .ag-rtl input[class^='ag-'][type='text'],\n .ag-theme-balham-dark .ag-rtl input[class^='ag-'][type='number'],\n .ag-theme-balham-dark .ag-rtl input[class^='ag-'][type='tel'],\n .ag-theme-balham-dark .ag-rtl input[class^='ag-'][type='date'],\n .ag-theme-balham-dark .ag-rtl input[class^='ag-'][type='datetime-local'],\n .ag-theme-balham-dark .ag-rtl textarea[class^='ag-'] {\n padding-right: 4px; }\n .ag-theme-balham-dark .ag-column-drop-vertical-empty-message, .ag-theme-balham-dark .ag-status-bar {\n font-weight: 600;\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38)); }\n .ag-theme-balham-dark .ag-dnd-ghost {\n font-weight: 600; }\n .ag-theme-balham-dark .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px; }\n .ag-theme-balham-dark .ag-tab-selected {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n border-bottom-color: transparent; }\n .ag-theme-balham-dark .ag-tabs-header {\n border-bottom: 1px solid;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-column-drop-cell {\n height: 24px; }\n .ag-theme-balham-dark .ag-column-drop-vertical-title {\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5); }\n .ag-theme-balham-dark .ag-column-drop-vertical-cell {\n margin-left: 8px;\n margin-right: 8px; }\n .ag-theme-balham-dark .ag-column-drop-vertical-cell-text {\n margin-left: 8px; }\n .ag-theme-balham-dark .ag-column-drop-vertical-icon {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-ltr .ag-column-drop-vertical-empty-message {\n padding-left: 24px;\n padding-right: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-drop-vertical-empty-message {\n padding-right: 24px;\n padding-left: 4px; }\n .ag-theme-balham-dark .ag-column-drop-horizontal {\n height: 32px; }\n .ag-theme-balham-dark .ag-column-drop-empty {\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38)); }\n .ag-theme-balham-dark .ag-column-drop-horizontal-cell-text {\n margin-left: 8px; }\n .ag-theme-balham-dark .ag-column-drop-vertical {\n padding-top: 8px; }\n .ag-theme-balham-dark .ag-menu-header {\n background-color: #1c1c1c;\n background-color: var(--ag-header-background-color, #1c1c1c); }\n .ag-theme-balham-dark .ag-overlay-loading-center {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n border: 1px solid;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5);\n padding: 16px; }\n .ag-theme-balham-dark .ag-tooltip {\n border: none;\n background-color: #cbd0d3; }\n .ag-theme-balham-dark .ag-panel-title-bar-button-icon {\n font-size: 20px; }\n .ag-theme-balham-dark .ag-chart-data-section,\n .ag-theme-balham-dark .ag-chart-format-section {\n padding-bottom: 2px; }\n .ag-theme-balham-dark .ag-group-toolbar {\n background-color: rgba(17, 17, 17, 0.5);\n background-color: var(--ag-subheader-toolbar-background-color, rgba(17, 17, 17, 0.5)); }\n .ag-theme-balham-dark .ag-chart-tab {\n padding-top: 2px; }\n .ag-theme-balham-dark .ag-charts-format-sub-level-group-item {\n margin-bottom: 6px; }\n .ag-theme-balham-dark .ag-tooltip {\n background-color: #1c1f20; }\n\n", ""]); +exports.push([module.i, ".ag-theme-balham-dark {\n color-scheme: dark;\n -webkit-font-smoothing: antialiased;\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5);\n font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n font-size: 12px;\n line-height: normal;\n}\n@font-face {\n font-family: \"agGridBalham\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABgoAAsAAAAALEgAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAmMAAAR2YfRkQU9TLzIAAANsAAAAQQAAAFZWUFLwY21hcAAAA7AAAAIMAAAFnGSNxkJnbHlmAAAFvAAADpIAABo4y6JNTGhlYWQAABRQAAAANAAAADZ2zcSBaGhlYQAAFIQAAAAaAAAAJAfQBDFobXR4AAAUoAAAABoAAAEgs7L//WxvY2EAABS8AAAAawAAAJJHu0GKbWF4cAAAFSgAAAAfAAAAIAFeAKpuYW1lAAAVSAAAATUAAAJG0OP3eXBvc3QAABaAAAABqAAAAm9qOX49eJx9lM1SE1EQhc8wAYFEoDQqRkRQ/IvKMD8Zk/CTkJBoWS5cWJYLN1hWWVZRrngOH8AnYOkT+AAufAIfwIVL15ZfdwaDLMitTO50n+4+fW7fKJA0qw3taGJv+Pyl5g72Dz+qppJGH/Of3AcHH97va/r4DV/Jf6cVlCqa00291qG+BXPBYXA0UQ1r4avwXfg5/BL+UghqReugy1TcUKyEZ6RUmRrKNaEpbDH7x2qCDnm23HpBVzXpnp76WqRmTEzfM9b1THe0QJ6u5+loG1TKspwdnkPWXc2fgch1j/wZbDaxllBkmf2WqprRHiw7MGkT38R/kZo71I6I6uLrwm4SS4t9W5fgZBElV/Wp3ugRfuvUsmRFTMo31q6/R/5WZh2jWuRpUMty12FwbG9QNSHiIdkzUFuFonVUL+NNwUTEtl1Biy6DTOCWapWd9ZnAtaI1MC/01qvuFjEd13SkQB32Y3vX8+V0ftLaJtcQ7AM4jK12PvepFWngXS2COdAnHemrvuuHfuq3/uicLlMn8R62yb5zpjbTKHga3cPb+me1XqeYgdOo/xEzdN5wdWJ8/UJDq1amM1MnZR9hTR0/C0/D92CTcx4lakRe1056krXJewz6fDGdTVbFle4zBfM+wQOfhRoTlui6ZxzNYY7WS2S03YhfzXVrku+an5upazdswd/sLth51zj/ZX4jOsxcpyd4V7BYprHlhkflsLcc6/hzWI+rGaslWGU+0TZjA78dPSrdop8Rk0S3/WYMfL7WYJAVN7XKGRr7dnFiVxwXe1TAP0FU3PDUtbOZ7sLN5mP4F/iHapMAeJxjYGSqZ5zAwMrAwFTFtIeBgaEHQjM+YDBkZAKKMrAyM2AFAWmuKQwHGHQ/GjG/AHKjmN8wsABpRpAcANz2CuAAAAB4nLXUZ1IbQRCG4VeBKIEDOeNEVkAgssjhh0+BM4UDhTPn8Nl8jz4B/ma7fQBc5al61Duzo9FMrb4F2oCCLEkR8p3kdEUur9FcNl6gOxsv8lv9Mp3kdV3hgiturHF7q9EK51xybbms97flNLvMODOsqbdHjRab7NPglDrbrLLDFge62+SIZTZY4ZAT1tnlmDN9P+2iqD2206Hf7dJOSlqxh17u84A++hlgkCGGGWGUMf3WBJNMMa15j3jME57yTPNmmGWOeRZ0XWJRpyppzwtUtcl27tb27jg/tVprc79xWt/WibcO1po67MbK4cn67vHZPyz2H1o5fRR+Re856Ym6dNrzUJMXoSUvw6a8CvvyOjTkTTiVt6Eu78K2XIRVuQw78j5syYdwIB9D+ld9Ck25CkdyHZblc9iQL2FFvoZD+RZO5HtYlx9hV36GY7kJeoCWcykvlnekWnApX1Z0KWPW5lL2rN2Raocj1U5Hql2OVLtdyqSVHKmWXXqS1uNItdeR6j2n7GBBKcKCsoE9dEoW1ueUMazfKW3YgFPusEGnBGJDTlnEhp1SiY045RMbdUoqNuaUWWzcKb3YhFOOsUmnRGNTLjvvtFPKsaC8Y0HJx4LeAVjQ2wAL2XlnHKnOOlKdc6Q670h1wZHqosvWWXLZ3iqOdL/q0vvVai6bU3cpY7bssjUbjuofQy2jW3ic7VlrkBzVde5ze2d6et7d04+Z2Z33a3deu/OWZnd79EDL7gr0YldCBqQoEnKwVhgpwsJCC7ZwBBI4JlIBdkXxq8qmoCouJ65QlC3ZKeKCpYIWhUAShCs/sBML4mAcq1LljaaVc3t6VlqhAPa/VLLT3ff07XvPPfecc8/57l2GZfCP/Q77HUZlSsx2hoEwUUXWTbieVJFkiE8jjaQlbvWAVZbUMKg9KQ0aIluETDoRt1oStYSsqObPyhk/uVKryLFMtVFvYNt6o57O0F8txgr9a7LQ0wPZNf36T/WfXnmDkP7z1DIAtodUExCGcKJKHA6kp+5a8V/wZGsBfI5o2K04vHa/J5p2qwst/Rj0cLJ7pVu2WsORITEEcJB95nqsIWS8raqnbv/6+j/6VJe1OQzLLrRYj+hUFKdP7FuluPwht+ptzToG5aTkHHL6PEKfPylFE6upqsDQ15fZLzMRhvGpXKahcjHBKDJCzCgaMcEoVGFuPH/yZH4cXEtL/dfm+xvXr1/87jLHIy+yEmPDF3OcBLxxtPDaa4WjGjl1NP/aa/mj+jIqliHbHnYPIzEDTA3bx6k5JGqaMrVDldqBK9N3iX4x7FKnX3zIFzkj/0wDLu7eMl2uVMrTW17pErunJ8ayuVx2bOJZSkAWqelvFb797cK3jCe7Z0lzg9CWNjco/dfdHvhkFmX2s36kOMaBOq0ICXo3KnLi3OzsuwcOvHPvveQu/ZNkvP38woLR/PJlfFxg32F8TIZBNgMQL0JNqGpQiZXDIAuSG9hY3E2pMK3T6NcicID6A7ba/lzplqGhW0qkUw62Z0PlEF7kIaPs17e9UvkKfPpKi5LRg/1mqBRqH8YHXuQL+PgVtix/Be65Vqbcx5eJjeG6+CiJVrZ/TEY+Why9OG64y2X8Q1kuGLIw0B0+EVsUyXI9SapXMaeDHblGCvbC1V9pOXatBKY972N3MRb0WD/D8MCpPLCNCHRig6SU6zXqiOTf9O3NnXobtLm5l77rcAQ8SmlNSfEE4AX4xjB+0P8GRufmNJcr3JsOxEuleCDVF6bse4wxCqzb9BkPw6QSQsVn3kDv51qtH2ja6VarfVbT3iLl9vyVe3Edk5OsBeVEGanfkxP6+/mf/SwPFzulOZebcT35mAQzREfpKnB4UaksRkEkFKyp46c0jm7YXI5hPfnzi7mJXHYiT4vcRPpSul43HnrPiuxEDp7QP5mqzeI3qBgNcvpZfJByPa3/mDaFkXRddxIxN55r1VJX5H6RvEjXCixZtVctRxK9eplZGebyJfZu9heMF2cSYsaZzzF/hr3p8rd0pEcvqNfYRA2EmGpVcTK+lOQmON2eWlUjFTpZyRpPZ4pAp4tuU6axvayo1K3iWF2r1sthtkJti6mhSKgOymFidur0iYCihklDxYBT0qgCJdkDboI6HWSxu8Lu5XbfY9HXZRqNDKlnGmPf01fBMQKsxXue6Nt5MSx5Vclrt7j8MZ+a9Nldth6b5FH7nGpUsRKb2/4XYlwJCS4v77ZxNo9TUByiV+oVxIgi+gWb3cX1WDxh0eqwiKLDJdpHclnCEpvDZiE1wtk9TiupsGAXbeTnts8csZBlmUuvGsIcO3fpOHvfGwFeaD/+j85I2GcTe6MpOV5LS30ZkffYXbJULUdzit9v97g9gQHF40iJDrcjIDhV0S3YrJwvVkz5XLJf9todHtHn4h08y3EWzhf64x+c5h1WO+eyW/jXeY+Nd/PzHt7uFamp/992/3tttzR3m5igQnxm7oabOrkb5joxbYmdJz7Sxg2avKv1SlmJQItQkymy5AHEaGjXeHoQOOoE6Vr1w01T2LqW5yySR/B5R1bY3VaXzeOT10057bwoiT23bunhBaz5MKXOfXaP2+VQvD7/Jz7hES0Wr1MI7f2sRxbdPG998JDVZhU8IvN/ZI5L8gqmPo4HcgKTif4+eMk/0eziBS82sRi55Wm2iZllOXMTM81sw/b1RgXhdwdF08juhkwHOzcMlIZhXnWDBwywTV+tRkKqNkCDFhQJ9ql31juXMlZtpdwCY1Un4hwktt8l3v7M55MuQewNRtOj+Ym1z26cumFjyevjHQ6vN98ayWtDN6mQ3rh+x523K1Jfc2Jk13AeHh5aq0L4wBNfW5toTgzf2czp88HcjbnBTD6YHc8OZsivSiy77pFb++LhbF8sgIxToiSXmpt7i5JfDsujudH8U5Fba2SrNirJYau9Lze8a3iiqf9ddGuNjN89ysbjWDMy0TzfP4gcg/nMYA6LK7n+aTbB9DJFZhg1ZexQTBVZr1YP7jVUN+lqp6MRrtxxlSJgUFOpJhD3hIAGQUQ90F7Ux9q9n/r0/q0byqYuWn89Azd98e6IqYuNn09QBYw3dzSbOw7sWL58xz9kx6fGs8aDTSxOfl0y4fasaG4xJz69q6dFRmfWdCYeCt67ns42shxZdPj8PWQpkyzpFNR1TGxTwP0Yokgw5xkCrlE3J5sehZhFMvdccqPWcQ1cOgUY8K9q+G2nAQhw/vqqwADZ1z5rMyh0kc5XciEzFBoeCvLOP3xsen/TYQuURsNDyTUtgQ+WRkNDqSODU9iiWQrygikPWTD8me96tEVICOQ3plfrv6ctOraiO+Ei4+zMgby3iM98OJte3DElDGw8yDCNRK2iXnWnPuJ9wcByVxDd9V8WZjt/LbPUzBLFsS3Z59ZwzY0yK5k1Rgz6rXa8PpTGgpg9dU35O+5tT83OwkH9JViuH1uknEhd1Cfhud9tO9v+d03TWubNMB+wYQftUpRMcibi/WdN66Le9n+iBbt+uJ/tRc0J1O4IaKnpWbWRwdlieMy04Jh+sHVcPw/p+fnSLLyth2dL5HHttHYc0pDWz8+X0QLlLq99iKOzzBbDp1GtHCoYwxvVar0FtXSmhH7uBnTpMDSwRqOhzxc3WmEljXZF8wPtLeEHrC4Z697gkiB+3GvEeu32vpnQLf3JKmdVAqKTFVPePo/bm8gdXp6NzBT8ITW7K3tzaM+g2qfmwjbgUgHZIdIuuQaokggOVky4+yS7Y3UxnSVreKeld9NAOrQn5HO5RtOJsaDIJlJiUs7sHColc72qJ7qn+PBwMQJ8FLl+YXgoGuYdlsiugopcfW7P+mKoJhl9Yr7kHYXSep+364+Pso9+YI0w1KMoprfgbXgX3g3znUMaPVS7Zy4/By/k5/IQWFhozy8srEWabMNaXCnbFiJI4JUvowdswxKvuWcWrvhCm7QRWbpwtx2hzsClBgF3Eo1fsG+O7d+4H/7WLOfOs7T8aqcw90MF8mp3rw7oCd0fW2h/CaONeUOghbZvdW0fx/htjGcOZA4Lr/YYA/1JZ7z/eLMHi33wozfZsX2b9pt9n8V9XscHuwgKXbdzEALNx4pvnS8+thL+aiVSbw0+Bhseyp09m3sIzrTn4UyHphga+RxhDzIKRp8G02LWMlPIj7qaqhhul0kb3tXQiEpfOavphxh0qW9hK1qZQcTBg2KE20FATAJGp3pDNYK02kjDwh2bN+61O7Ppmyeev/WO1aMrCElF73505YbxG27j+VR607oz66azCZtt69jkU1Grdf3oqslqKQOH9F9WZgayCFHOrFrerx9NOvzBenMTr1XLsiJejrCfIdXS09vuvG3DslpKVlrLvjq1ZXLlznqL5LNf3DB98/pizpItbJ6Y3vh4rvDy6MTYbDzJWYIK3K8/5e1NpavN4VdIWNGPtk6sXD1QsGjsQP+INnzZvngGM8Pej97Xz4ygZoyDIuPwSE588KAgwZUVujmo1iGG4Euo1odBjtUoOBMkK9nndAcimyMBt3M2vjyOF1zslAtCIBAPBMChO4PJZLAFB7VgKsWGRMnvFkW3XxKxkT5pdnoOH4I/6ser/fVUAJ4LJmdnk0F9MpBajE+HDZmbKHEXIdXRCFhQY3E0QdIwg4uJ5tEIcGmcEnSs11CVioGhYOMJID0WPtQcbOx0N0NRCMsr1vwB5lBWkgvqkxge/8XHO23eU/X+sgBBm0rARp6w4VbALXpfhwdOIGLwOPsdvGNHcTQs62/3TTvvtFoCtdyQ6sDu5Eter8+tnHKzbK/+r1Yp46+KT2Iw52zi64z9qrwURe2vZMYM77yN2cHs/h9yU0xQjINVC01PEYQxndUgI9DhEp0jScVQRkpSK7WMlavUGllARVQwscoV6tEpa4KTK410Qq58WOKCQ+2XfvkeZhW+bQPMMVH4vj0/PZXns2P9B/j89HTeviJZDoah/TIcvh9gtlVdi5nuUAvOHKLtURfLsw/+aNmND35oKrvUftnKY/P3zgpeHAzuB4/BnL+n/8Yc4fNTOA7gdkvJhseWPfDDydqDv6mntrcOH47ThAdweBYeWPQJeu5Fzz/N008v9YIoVYf3mtPPuLG5oF/g4iMH9q2+4YbV+w6At0s9cnD3zubISHPn7veQGB5Ggr1AP+jvL22sLWlDiZHumurKov1W0lxzNmu0+bgiwnevc+r6seXWJ6eX9qTMrsUCFD9gwMdkpCIowGieYffp54+39INwrHW8NKuH4e3Z0vw8IorzxykaOE5hwPy8yYeeT7swEjO4z0Mcae77BEs3urP+9vO3lOJkPF7SvzfTPHeuOTOFrH4CSf0n9BQQkn0zw+fODc/AycXzeAs5aZzj0QMKtkd/34AyZDeFp0gw17YDemaGeCzfga1HOuVimxe6Z4IqttFP/CVu0VeRJ5AoPAyrFnkViESt7EMdnDaSnk9bjKV72Rm0ew7xJeOLI5BEtI6Zhm7GMLJiPvEhpgkTBDMZ7goGygBFO6qxtOk/Uzq0cW7zNCFJQv4Ulr1LLAalz71LvEU1pGz6/Z1JraAl7sr6Y5xNDmoF+MbAuhBWCYXA4GZRECJIR6JWpXfnMnYPdraQU/rcO8gQrOQUNN4l+n0IX7B9xGDk7PUW+5KTvchoMmrwUVhLOd+/Ffm0Iptv7y8N4wz/G4A9L1cAAHicY2BkYGAAYgWvvDnx/DZfGbiZXwAFojgf72uA0f/////D/IL5DVAlBwMTkGQAAHb/DvN4nGNgZGBgfsHAACL//wezGRlQgQcAdFMFCgAAeJxjYGBgYH6BDf//j8C41AwspgcAANyGMDUAAHicY2AAghkMFxieMTowRjEuYXzFpMEUxVTD1Md0g+kT8wWWdSxHWM1YV7DuYQtgO8EuwK7FXsL+iYOHw4hjD8cPTjFOA04/ziIuJq4YrgPcadxreIR4zHgSeEp42nhm8azglSEdAgCdlRu1AHicY2BkYGDwYJjHwMMAAkxAzAWEDAz/wXwGACBkAgkAeJx1jz9OwzAYxV9oWkSLEBISYsMTC1L6Z2Do2KHZO3RgcxsnbZXEkeNW6sYxOAHHYOQInIJD8BK+oUKqLTk///zeJwXALb4QoFkBrtuzWRe45O2PO6Q74ZD8KNzFAM/CPfoX4T7tTHjAZsEJQXhF84A34Qvc4F24Q/8hHJI/hbu4x7dwj/5HuI9lEAoP8BS86ix222Sm840uFibb59qdqlNeGldvbanG0ehUx6Y0TnuTqNVR1Yds4n2qUmcLNbelN3luVeXszqx9tPG+mg6HqfhobQtoZIjhsEXCP9fIseFZYAHDlz3vmq/nUuf8km2Hmt6ihMIYEUZn0zHTZdvQ8PwmbKxw5FnjwM6E1iPlPWXGsqEwbyc36Zzb0lTt245mTR9xdtOqMMWQO/2Xj5jipF9al2jJAAAAeJxtkQdv2zAQhf3Fku3YaeO6bbr3Hmrr7p3upj+DpmiZiEQKJOWRX18iLgIE6AE8vPdwvHu4a2201tFv/T/22KBNQkqHLj026TNgixOcZJshpxhxmjOcZYdznOcCF7nEZa5wlWtc5wY3ucVt7nCXe9znAQ95xGMynvCUZ4x5zgte8orXvOEt73jPBz7yic/s8oWvfOM7P/jJL36zx5/WQBSFU4UI2pqOcM4ufFt42ZHCSFWmciZcGMqZkvsTu8wOgcp3jgRtchWUq7QRQY2O5Mb8q9yStrQuq3UkrhtJUxnfl9YEJ2RQeSJtvUqls963pZ+n8WXjJFdepmoZDXQPczbuqWUt4qx8U61U5kvhZ+2IOlNdxvHpVDsfksLpOi2cbeokFoSkVNPQKbWJPrqlFbk2Ra8SS13pA5VUyjS96HvNjDVqYGzIRFnahcrTOjZQ7VqbtNZzG4YufrfZpAnBmsxOp9vHBZM6XcxC4sVc9X0Vu2S5XZjeGkZDIW5gFJxSx1fWa8zaIIIChyKgsRgWeCQlM/aZsIwnzqloqFkxZ8pBq/UXq/Gj5g==\") format(\"woff\");\n font-weight: normal;\n font-style: normal;\n}\n.ag-theme-balham-dark .ag-icon {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n.ag-theme-balham-dark .ag-icon-aggregation::before {\n content: \"\\f101\";\n}\n.ag-theme-balham-dark .ag-icon-arrows::before {\n content: \"\\f102\";\n}\n.ag-theme-balham-dark .ag-icon-asc::before {\n content: \"\\f103\";\n}\n.ag-theme-balham-dark .ag-icon-cancel::before {\n content: \"\\f104\";\n}\n.ag-theme-balham-dark .ag-icon-chart::before {\n content: \"\\f105\";\n}\n.ag-theme-balham-dark .ag-icon-color-picker::before {\n content: \"\\f109\";\n}\n.ag-theme-balham-dark .ag-icon-columns::before {\n content: \"\\f10a\";\n}\n.ag-theme-balham-dark .ag-icon-contracted::before {\n content: \"\\f10b\";\n}\n.ag-theme-balham-dark .ag-icon-copy::before {\n content: \"\\f10c\";\n}\n.ag-theme-balham-dark .ag-icon-cross::before {\n content: \"\\f10d\";\n}\n.ag-theme-balham-dark .ag-icon-csv::before {\n content: \"\\f10e\";\n}\n.ag-theme-balham-dark .ag-icon-desc::before {\n content: \"\\f10f\";\n}\n.ag-theme-balham-dark .ag-icon-excel::before {\n content: \"\\f110\";\n}\n.ag-theme-balham-dark .ag-icon-expanded::before {\n content: \"\\f111\";\n}\n.ag-theme-balham-dark .ag-icon-eye-slash::before {\n content: \"\\f112\";\n}\n.ag-theme-balham-dark .ag-icon-eye::before {\n content: \"\\f113\";\n}\n.ag-theme-balham-dark .ag-icon-filter::before {\n content: \"\\f114\";\n}\n.ag-theme-balham-dark .ag-icon-first::before {\n content: \"\\f115\";\n}\n.ag-theme-balham-dark .ag-icon-grip::before {\n content: \"\\f116\";\n}\n.ag-theme-balham-dark .ag-icon-group::before {\n content: \"\\f117\";\n}\n.ag-theme-balham-dark .ag-icon-last::before {\n content: \"\\f118\";\n}\n.ag-theme-balham-dark .ag-icon-left::before {\n content: \"\\f119\";\n}\n.ag-theme-balham-dark .ag-icon-linked::before {\n content: \"\\f11a\";\n}\n.ag-theme-balham-dark .ag-icon-loading::before {\n content: \"\\f11b\";\n}\n.ag-theme-balham-dark .ag-icon-maximize::before {\n content: \"\\f11c\";\n}\n.ag-theme-balham-dark .ag-icon-menu::before {\n content: \"\\f11d\";\n}\n.ag-theme-balham-dark .ag-icon-minimize::before {\n content: \"\\f11e\";\n}\n.ag-theme-balham-dark .ag-icon-next::before {\n content: \"\\f11f\";\n}\n.ag-theme-balham-dark .ag-icon-none::before {\n content: \"\\f120\";\n}\n.ag-theme-balham-dark .ag-icon-not-allowed::before {\n content: \"\\f121\";\n}\n.ag-theme-balham-dark .ag-icon-paste::before {\n content: \"\\f122\";\n}\n.ag-theme-balham-dark .ag-icon-pin::before {\n content: \"\\f123\";\n}\n.ag-theme-balham-dark .ag-icon-pivot::before {\n content: \"\\f124\";\n}\n.ag-theme-balham-dark .ag-icon-previous::before {\n content: \"\\f125\";\n}\n.ag-theme-balham-dark .ag-icon-right::before {\n content: \"\\f128\";\n}\n.ag-theme-balham-dark .ag-icon-save::before {\n content: \"\\f129\";\n}\n.ag-theme-balham-dark .ag-icon-small-down::before {\n content: \"\\f12a\";\n}\n.ag-theme-balham-dark .ag-icon-small-left::before {\n content: \"\\f12b\";\n}\n.ag-theme-balham-dark .ag-icon-small-right::before {\n content: \"\\f12c\";\n}\n.ag-theme-balham-dark .ag-icon-small-up::before {\n content: \"\\f12d\";\n}\n.ag-theme-balham-dark .ag-icon-tick::before {\n content: \"\\f12e\";\n}\n.ag-theme-balham-dark .ag-icon-tree-closed::before {\n content: \"\\f12f\";\n}\n.ag-theme-balham-dark .ag-icon-tree-indeterminate::before {\n content: \"\\f130\";\n}\n.ag-theme-balham-dark .ag-icon-tree-open::before {\n content: \"\\f131\";\n}\n.ag-theme-balham-dark .ag-icon-unlinked::before {\n content: \"\\f132\";\n}\n.ag-theme-balham-dark .ag-icon-row-drag::before {\n content: \"\\f116\";\n}\n.ag-theme-balham-dark .ag-left-arrow::before {\n content: \"\\f119\";\n}\n.ag-theme-balham-dark .ag-right-arrow::before {\n content: \"\\f128\";\n}\n.ag-theme-balham-dark .ag-root-wrapper {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n}\n.ag-theme-balham-dark [class^=ag-], .ag-theme-balham-dark [class^=ag-]:focus, .ag-theme-balham-dark [class^=ag-]:after, .ag-theme-balham-dark [class^=ag-]:before {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n outline: none;\n}\n.ag-theme-balham-dark [class^=ag-]::-ms-clear {\n display: none;\n}\n.ag-theme-balham-dark .ag-checkbox .ag-input-wrapper,\n.ag-theme-balham-dark .ag-radio-button .ag-input-wrapper {\n overflow: visible;\n}\n.ag-theme-balham-dark .ag-range-field .ag-input-wrapper {\n height: 100%;\n}\n.ag-theme-balham-dark .ag-toggle-button {\n -webkit-box-flex: 0;\n flex: none;\n width: unset;\n min-width: unset;\n}\n.ag-theme-balham-dark .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px;\n}\n\n.ag-theme-balham-dark input[class^=ag-] {\n margin: 0;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n}\n.ag-theme-balham-dark textarea[class^=ag-],\n.ag-theme-balham-dark select[class^=ag-] {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n}\n.ag-theme-balham-dark input[class^=ag-]:not([type]),\n.ag-theme-balham-dark input[class^=ag-][type=text],\n.ag-theme-balham-dark input[class^=ag-][type=number],\n.ag-theme-balham-dark input[class^=ag-][type=tel],\n.ag-theme-balham-dark input[class^=ag-][type=date],\n.ag-theme-balham-dark input[class^=ag-][type=datetime-local],\n.ag-theme-balham-dark textarea[class^=ag-] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #f0f0f0;\n border-color: var(--ag-input-border-color, #f0f0f0);\n}\n.ag-theme-balham-dark input[class^=ag-]:not([type]):disabled,\n.ag-theme-balham-dark input[class^=ag-][type=text]:disabled,\n.ag-theme-balham-dark input[class^=ag-][type=number]:disabled,\n.ag-theme-balham-dark input[class^=ag-][type=tel]:disabled,\n.ag-theme-balham-dark input[class^=ag-][type=date]:disabled,\n.ag-theme-balham-dark input[class^=ag-][type=datetime-local]:disabled,\n.ag-theme-balham-dark textarea[class^=ag-]:disabled {\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n background-color: rgba(48, 46, 46, 0.3);\n background-color: var(--ag-input-disabled-background-color, rgba(48, 46, 46, 0.3));\n border-color: rgba(240, 240, 240, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(240, 240, 240, 0.3));\n}\n.ag-theme-balham-dark input[class^=ag-]:not([type]):focus,\n.ag-theme-balham-dark input[class^=ag-][type=text]:focus,\n.ag-theme-balham-dark input[class^=ag-][type=number]:focus,\n.ag-theme-balham-dark input[class^=ag-][type=tel]:focus,\n.ag-theme-balham-dark input[class^=ag-][type=date]:focus,\n.ag-theme-balham-dark input[class^=ag-][type=datetime-local]:focus,\n.ag-theme-balham-dark textarea[class^=ag-]:focus {\n outline: none;\n -webkit-box-shadow: 0 0 4px 1.5px #719ECE;\n box-shadow: 0 0 4px 1.5px #719ECE;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham-dark input[class^=ag-]:not([type]):invalid,\n.ag-theme-balham-dark input[class^=ag-][type=text]:invalid,\n.ag-theme-balham-dark input[class^=ag-][type=number]:invalid,\n.ag-theme-balham-dark input[class^=ag-][type=tel]:invalid,\n.ag-theme-balham-dark input[class^=ag-][type=date]:invalid,\n.ag-theme-balham-dark input[class^=ag-][type=datetime-local]:invalid,\n.ag-theme-balham-dark textarea[class^=ag-]:invalid {\n border-width: 2px;\n border-style: solid;\n border-color: #e02525;\n border-color: var(--ag-input-border-color-invalid, var(--ag-invalid-color, #e02525));\n}\n.ag-theme-balham-dark input[class^=ag-][type=number] {\n -moz-appearance: textfield;\n}\n.ag-theme-balham-dark input[class^=ag-][type=number]::-webkit-outer-spin-button, .ag-theme-balham-dark input[class^=ag-][type=number]::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n}\n.ag-theme-balham-dark input[class^=ag-][type=range] {\n padding: 0;\n}\n.ag-theme-balham-dark input[class^=ag-][type=button]:focus, .ag-theme-balham-dark button[class^=ag-]:focus {\n -webkit-box-shadow: 0 0 4px 1.5px #719ECE;\n box-shadow: 0 0 4px 1.5px #719ECE;\n}\n.ag-theme-balham-dark .ag-drag-handle {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n}\n.ag-theme-balham-dark .ag-list-item, .ag-theme-balham-dark .ag-virtual-list-item {\n height: 24px;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham-dark .ag-select-list {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n overflow-y: auto;\n overflow-x: hidden;\n}\n.ag-theme-balham-dark .ag-list-item {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-balham-dark .ag-list-item.ag-active-item {\n background-color: #3d4749;\n background-color: var(--ag-row-hover-color, #3d4749);\n}\n.ag-theme-balham-dark .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n user-select: none;\n}\n.ag-theme-balham-dark .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n.ag-theme-balham-dark .ag-select .ag-picker-field-wrapper {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n min-height: 24px;\n cursor: default;\n}\n.ag-theme-balham-dark .ag-select.ag-disabled .ag-picker-field-wrapper:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-balham-dark .ag-select:not(.ag-cell-editor) {\n height: 24px;\n}\n.ag-theme-balham-dark .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-balham-dark .ag-select .ag-picker-field-icon {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-balham-dark .ag-select.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-balham-dark .ag-rich-select {\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020);\n}\n.ag-theme-balham-dark .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 182px;\n}\n.ag-theme-balham-dark .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 28px;\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242));\n}\n.ag-theme-balham-dark .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 24px;\n}\n.ag-theme-balham-dark .ag-rich-select-virtual-list-item:hover {\n background-color: #3d4749;\n background-color: var(--ag-row-hover-color, #3d4749);\n}\n.ag-theme-balham-dark .ag-rich-select-row {\n padding-left: 12px;\n}\n.ag-theme-balham-dark .ag-rich-select-row-selected {\n background-color: #005880;\n background-color: var(--ag-selected-row-background-color, #005880);\n}\n.ag-theme-balham-dark .ag-row-drag,\n.ag-theme-balham-dark .ag-selection-checkbox,\n.ag-theme-balham-dark .ag-group-expanded,\n.ag-theme-balham-dark .ag-group-contracted {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n}\n.ag-theme-balham-dark .ag-ltr .ag-row-drag, .ag-theme-balham-dark .ag-ltr .ag-selection-checkbox, .ag-theme-balham-dark .ag-ltr .ag-group-expanded, .ag-theme-balham-dark .ag-ltr .ag-group-contracted {\n margin-right: 12px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-drag, .ag-theme-balham-dark .ag-rtl .ag-selection-checkbox, .ag-theme-balham-dark .ag-rtl .ag-group-expanded, .ag-theme-balham-dark .ag-rtl .ag-group-contracted {\n margin-left: 12px;\n}\n\n.ag-theme-balham-dark .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: min(var(--ag-row-height, 26px), 26px);\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-balham-dark .ag-group-expanded,\n.ag-theme-balham-dark .ag-group-contracted {\n cursor: pointer;\n}\n.ag-theme-balham-dark .ag-group-title-bar-icon {\n cursor: pointer;\n -webkit-box-flex: 0;\n flex: none;\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n}\n.ag-theme-balham-dark .ag-ltr .ag-group-child-count {\n margin-left: 2px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-group-child-count {\n margin-right: 2px;\n}\n\n.ag-theme-balham-dark .ag-group-title-bar {\n background-color: #111;\n background-color: var(--ag-subheader-background-color, #111);\n padding: 4px;\n}\n.ag-theme-balham-dark .ag-group-toolbar {\n padding: 4px;\n}\n.ag-theme-balham-dark .ag-disabled-group-title-bar, .ag-theme-balham-dark .ag-disabled-group-container {\n opacity: 0.5;\n}\n.ag-theme-balham-dark .group-item {\n margin: 2px 0;\n}\n.ag-theme-balham-dark .ag-label {\n white-space: nowrap;\n}\n.ag-theme-balham-dark .ag-ltr .ag-label {\n margin-right: 4px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-label {\n margin-left: 4px;\n}\n\n.ag-theme-balham-dark .ag-label-align-top .ag-label {\n margin-bottom: 2px;\n}\n.ag-theme-balham-dark .ag-ltr .ag-slider-field, .ag-theme-balham-dark .ag-ltr .ag-angle-select-field {\n margin-right: 8px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-slider-field, .ag-theme-balham-dark .ag-rtl .ag-angle-select-field {\n margin-left: 8px;\n}\n\n.ag-theme-balham-dark .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n}\n.ag-theme-balham-dark .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #F5F5F5;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n}\n.ag-theme-balham-dark .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n border-radius: 5px;\n}\n.ag-theme-balham-dark .ag-picker-field-wrapper:focus {\n -webkit-box-shadow: 0 0 4px 1.5px #719ECE;\n box-shadow: 0 0 4px 1.5px #719ECE;\n}\n.ag-theme-balham-dark .ag-picker-field-button {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n}\n.ag-theme-balham-dark .ag-dialog.ag-color-dialog {\n border-radius: 5px;\n}\n.ag-theme-balham-dark .ag-color-picker .ag-picker-field-display {\n height: 16px;\n}\n.ag-theme-balham-dark .ag-color-panel {\n padding: 4px;\n}\n.ag-theme-balham-dark .ag-spectrum-color {\n background-color: red;\n border-radius: 2px;\n}\n.ag-theme-balham-dark .ag-spectrum-tools {\n padding: 10px;\n}\n.ag-theme-balham-dark .ag-spectrum-sat {\n background-image: -webkit-gradient(linear, left top, right top, from(white), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0));\n}\n.ag-theme-balham-dark .ag-spectrum-val {\n background-image: -webkit-gradient(linear, left bottom, left top, from(black), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0));\n}\n.ag-theme-balham-dark .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n -webkit-box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n}\n.ag-theme-balham-dark .ag-spectrum-hue-background {\n border-radius: 2px;\n}\n.ag-theme-balham-dark .ag-spectrum-alpha-background {\n border-radius: 2px;\n}\n.ag-theme-balham-dark .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px;\n}\n.ag-theme-balham-dark .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n -webkit-box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n}\n.ag-theme-balham-dark .ag-recent-color {\n margin: 0 3px;\n}\n.ag-theme-balham-dark .ag-recent-color:first-child {\n margin-left: 0;\n}\n.ag-theme-balham-dark .ag-recent-color:last-child {\n margin-right: 0;\n}\n.ag-theme-balham-dark.ag-dnd-ghost {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242));\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n height: 32px !important;\n line-height: 32px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px);\n}\n.ag-theme-balham-dark .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5);\n}\n.ag-theme-balham-dark .ag-popup-child:not(.ag-tooltip-custom) {\n -webkit-box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3);\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3);\n}\n.ag-dragging-range-handle .ag-theme-balham-dark .ag-dialog, .ag-dragging-fill-handle .ag-theme-balham-dark .ag-dialog {\n opacity: 0.7;\n pointer-events: none;\n}\n.ag-theme-balham-dark .ag-dialog {\n border-radius: 2px;\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-panel {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n}\n.ag-theme-balham-dark .ag-panel-title-bar {\n background-color: #1c1c1c;\n background-color: var(--ag-header-background-color, #1c1c1c);\n color: rgba(245, 245, 245, 0.64);\n color: var(--ag-header-foreground-color, rgba(245, 245, 245, 0.64));\n height: 32px;\n padding: 4px 12px;\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px;\n}\n\n.ag-theme-balham-dark .ag-tooltip {\n background-color: #1c1c1c;\n background-color: var(--ag-header-background-color, #1c1c1c);\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5);\n padding: 4px;\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n border-radius: 2px;\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n white-space: normal;\n}\n.ag-theme-balham-dark .ag-tooltip.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-balham-dark .ag-tooltip-custom {\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n}\n.ag-theme-balham-dark .ag-tooltip-custom.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-1 {\n padding-left: 20px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-1 {\n padding-right: 20px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-2 {\n padding-left: 40px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-2 {\n padding-right: 40px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-3 {\n padding-left: 60px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-3 {\n padding-right: 60px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-4 {\n padding-left: 80px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-4 {\n padding-right: 80px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-5 {\n padding-left: 100px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-5 {\n padding-right: 100px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-6 {\n padding-left: 120px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-6 {\n padding-right: 120px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-7 {\n padding-left: 140px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-7 {\n padding-right: 140px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-8 {\n padding-left: 160px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-8 {\n padding-right: 160px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-9 {\n padding-left: 180px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-9 {\n padding-right: 180px;\n}\n\n.ag-theme-balham-dark .ag-column-select-header-icon {\n cursor: pointer;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-header-icon:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham-dark .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 8px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 8px;\n}\n\n.ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham-dark .ag-column-select-column-group:not(:last-child),\n.ag-theme-balham-dark .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px;\n}\n.ag-theme-balham-dark .ag-column-select-column-readonly,\n.ag-theme-balham-dark .ag-column-select-column-group-readonly {\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n pointer-events: none;\n}\n.ag-theme-balham-dark .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 24px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 24px;\n}\n\n.ag-theme-balham-dark .ag-column-select-virtual-list-viewport {\n padding: 3px 0px;\n}\n.ag-theme-balham-dark .ag-column-select-virtual-list-item {\n padding: 0 6px;\n}\n.ag-theme-balham-dark .ag-rtl {\n text-align: right;\n}\n.ag-theme-balham-dark .ag-root-wrapper {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 40px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 40px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-1 {\n padding-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-1 {\n padding-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-1 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-1 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 68px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 68px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-2 {\n padding-left: 56px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-2 {\n padding-right: 56px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-2 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-2 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 96px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 96px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-3 {\n padding-left: 84px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-3 {\n padding-right: 84px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-3 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-3 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 124px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 124px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-4 {\n padding-left: 112px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-4 {\n padding-right: 112px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-4 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-4 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 152px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 152px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-5 {\n padding-left: 140px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-5 {\n padding-right: 140px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-5 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-5 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 180px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 180px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-6 {\n padding-left: 168px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-6 {\n padding-right: 168px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-6 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-6 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 208px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 208px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-7 {\n padding-left: 196px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-7 {\n padding-right: 196px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-7 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-7 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 236px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 236px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-8 {\n padding-left: 224px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-8 {\n padding-right: 224px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-8 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-8 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 264px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 264px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-9 {\n padding-left: 252px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-9 {\n padding-right: 252px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-9 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-9 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 292px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 292px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-10 {\n padding-left: 280px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-10 {\n padding-right: 280px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-10 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-10 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 320px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 320px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-11 {\n padding-left: 308px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-11 {\n padding-right: 308px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-11 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-11 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 348px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 348px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-12 {\n padding-left: 336px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-12 {\n padding-right: 336px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-12 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-12 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 376px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 376px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-13 {\n padding-left: 364px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-13 {\n padding-right: 364px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-13 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-13 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 404px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 404px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-14 {\n padding-left: 392px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-14 {\n padding-right: 392px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-14 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-14 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 432px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 432px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-15 {\n padding-left: 420px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-15 {\n padding-right: 420px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-15 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-15 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 460px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 460px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-16 {\n padding-left: 448px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-16 {\n padding-right: 448px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-16 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-16 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 488px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 488px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-17 {\n padding-left: 476px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-17 {\n padding-right: 476px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-17 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-17 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 516px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 516px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-18 {\n padding-left: 504px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-18 {\n padding-right: 504px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-18 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-18 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 544px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 544px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-19 {\n padding-left: 532px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-19 {\n padding-right: 532px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-19 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-19 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-left: 572px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-right: 572px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-20 {\n padding-left: 560px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-20 {\n padding-right: 560px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-20 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-20 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-left: 600px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-right: 600px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-21 {\n padding-left: 588px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-21 {\n padding-right: 588px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-21 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-21 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-left: 628px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-right: 628px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-22 {\n padding-left: 616px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-22 {\n padding-right: 616px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-22 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-22 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-left: 656px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-right: 656px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-23 {\n padding-left: 644px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-23 {\n padding-right: 644px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-23 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-23 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-left: 684px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-right: 684px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-24 {\n padding-left: 672px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-24 {\n padding-right: 672px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-24 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-24 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-left: 712px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-right: 712px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-25 {\n padding-left: 700px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-25 {\n padding-right: 700px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-25 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-25 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-left: 740px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-right: 740px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-26 {\n padding-left: 728px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-26 {\n padding-right: 728px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-26 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-26 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-left: 768px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-right: 768px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-27 {\n padding-left: 756px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-27 {\n padding-right: 756px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-27 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-27 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-left: 796px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-right: 796px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-28 {\n padding-left: 784px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-28 {\n padding-right: 784px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-28 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-28 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-left: 824px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-right: 824px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-29 {\n padding-left: 812px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-29 {\n padding-right: 812px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-29 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-29 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-left: 852px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-right: 852px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-30 {\n padding-left: 840px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-30 {\n padding-right: 840px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-30 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-30 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-left: 880px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-right: 880px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-31 {\n padding-left: 868px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-31 {\n padding-right: 868px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-31 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-31 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-left: 908px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-right: 908px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-32 {\n padding-left: 896px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-32 {\n padding-right: 896px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-32 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-32 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-left: 936px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-right: 936px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-33 {\n padding-left: 924px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-33 {\n padding-right: 924px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-33 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-33 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-left: 964px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-right: 964px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-34 {\n padding-left: 952px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-34 {\n padding-right: 952px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-34 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-34 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-left: 992px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-right: 992px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-35 {\n padding-left: 980px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-35 {\n padding-right: 980px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-35 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-35 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-left: 1020px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-right: 1020px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-36 {\n padding-left: 1008px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-36 {\n padding-right: 1008px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-36 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-36 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-left: 1048px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-right: 1048px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-37 {\n padding-left: 1036px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-37 {\n padding-right: 1036px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-37 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-37 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-left: 1076px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-right: 1076px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-38 {\n padding-left: 1064px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-38 {\n padding-right: 1064px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-38 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-38 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-left: 1104px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-right: 1104px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-39 {\n padding-left: 1092px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-39 {\n padding-right: 1092px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-39 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-39 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-left: 1132px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-right: 1132px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-40 {\n padding-left: 1120px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-40 {\n padding-right: 1120px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-40 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-40 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-left: 1160px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-right: 1160px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-41 {\n padding-left: 1148px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-41 {\n padding-right: 1148px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-41 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-41 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-left: 1188px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-right: 1188px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-42 {\n padding-left: 1176px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-42 {\n padding-right: 1176px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-42 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-42 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-left: 1216px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-right: 1216px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-43 {\n padding-left: 1204px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-43 {\n padding-right: 1204px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-43 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-43 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-left: 1244px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-right: 1244px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-44 {\n padding-left: 1232px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-44 {\n padding-right: 1232px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-44 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-44 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-left: 1272px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-right: 1272px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-45 {\n padding-left: 1260px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-45 {\n padding-right: 1260px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-45 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-45 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-left: 1300px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-right: 1300px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-46 {\n padding-left: 1288px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-46 {\n padding-right: 1288px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-46 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-46 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-left: 1328px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-right: 1328px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-47 {\n padding-left: 1316px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-47 {\n padding-right: 1316px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-47 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-47 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-left: 1356px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-right: 1356px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-48 {\n padding-left: 1344px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-48 {\n padding-right: 1344px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-48 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-48 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-left: 1384px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-right: 1384px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-49 {\n padding-left: 1372px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-49 {\n padding-right: 1372px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-49 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-49 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-left: 1412px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-right: 1412px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-50 {\n padding-left: 1400px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-50 {\n padding-right: 1400px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-50 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-50 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-left: 1440px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-right: 1440px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-51 {\n padding-left: 1428px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-51 {\n padding-right: 1428px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-51 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-51 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-left: 1468px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-right: 1468px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-52 {\n padding-left: 1456px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-52 {\n padding-right: 1456px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-52 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-52 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-left: 1496px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-right: 1496px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-53 {\n padding-left: 1484px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-53 {\n padding-right: 1484px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-53 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-53 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-left: 1524px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-right: 1524px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-54 {\n padding-left: 1512px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-54 {\n padding-right: 1512px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-54 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-54 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-left: 1552px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-right: 1552px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-55 {\n padding-left: 1540px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-55 {\n padding-right: 1540px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-55 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-55 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-left: 1580px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-right: 1580px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-56 {\n padding-left: 1568px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-56 {\n padding-right: 1568px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-56 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-56 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-left: 1608px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-right: 1608px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-57 {\n padding-left: 1596px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-57 {\n padding-right: 1596px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-57 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-57 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-left: 1636px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-right: 1636px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-58 {\n padding-left: 1624px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-58 {\n padding-right: 1624px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-58 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-58 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-left: 1664px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-right: 1664px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-59 {\n padding-left: 1652px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-59 {\n padding-right: 1652px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-59 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-59 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-left: 1692px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-right: 1692px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-60 {\n padding-left: 1680px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-60 {\n padding-right: 1680px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-60 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-60 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-left: 1720px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-right: 1720px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-61 {\n padding-left: 1708px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-61 {\n padding-right: 1708px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-61 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-61 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-left: 1748px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-right: 1748px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-62 {\n padding-left: 1736px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-62 {\n padding-right: 1736px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-62 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-62 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-left: 1776px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-right: 1776px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-63 {\n padding-left: 1764px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-63 {\n padding-right: 1764px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-63 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-63 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-left: 1804px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-right: 1804px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-64 {\n padding-left: 1792px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-64 {\n padding-right: 1792px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-64 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-64 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-left: 1832px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-right: 1832px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-65 {\n padding-left: 1820px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-65 {\n padding-right: 1820px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-65 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-65 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-left: 1860px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-right: 1860px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-66 {\n padding-left: 1848px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-66 {\n padding-right: 1848px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-66 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-66 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-left: 1888px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-right: 1888px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-67 {\n padding-left: 1876px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-67 {\n padding-right: 1876px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-67 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-67 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-left: 1916px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-right: 1916px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-68 {\n padding-left: 1904px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-68 {\n padding-right: 1904px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-68 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-68 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-left: 1944px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-right: 1944px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-69 {\n padding-left: 1932px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-69 {\n padding-right: 1932px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-69 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-69 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-left: 1972px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-right: 1972px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-70 {\n padding-left: 1960px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-70 {\n padding-right: 1960px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-70 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-70 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-left: 2000px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-right: 2000px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-71 {\n padding-left: 1988px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-71 {\n padding-right: 1988px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-71 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-71 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-left: 2028px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-right: 2028px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-72 {\n padding-left: 2016px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-72 {\n padding-right: 2016px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-72 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-72 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-left: 2056px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-right: 2056px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-73 {\n padding-left: 2044px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-73 {\n padding-right: 2044px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-73 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-73 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-left: 2084px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-right: 2084px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-74 {\n padding-left: 2072px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-74 {\n padding-right: 2072px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-74 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-74 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-left: 2112px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-right: 2112px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-75 {\n padding-left: 2100px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-75 {\n padding-right: 2100px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-75 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-75 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-left: 2140px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-right: 2140px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-76 {\n padding-left: 2128px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-76 {\n padding-right: 2128px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-76 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-76 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-left: 2168px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-right: 2168px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-77 {\n padding-left: 2156px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-77 {\n padding-right: 2156px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-77 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-77 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-left: 2196px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-right: 2196px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-78 {\n padding-left: 2184px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-78 {\n padding-right: 2184px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-78 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-78 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-left: 2224px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-right: 2224px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-79 {\n padding-left: 2212px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-79 {\n padding-right: 2212px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-79 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-79 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-left: 2252px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-right: 2252px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-80 {\n padding-left: 2240px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-80 {\n padding-right: 2240px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-80 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-80 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-left: 2280px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-right: 2280px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-81 {\n padding-left: 2268px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-81 {\n padding-right: 2268px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-81 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-81 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-left: 2308px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-right: 2308px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-82 {\n padding-left: 2296px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-82 {\n padding-right: 2296px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-82 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-82 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-left: 2336px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-right: 2336px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-83 {\n padding-left: 2324px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-83 {\n padding-right: 2324px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-83 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-83 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-left: 2364px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-right: 2364px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-84 {\n padding-left: 2352px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-84 {\n padding-right: 2352px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-84 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-84 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-left: 2392px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-right: 2392px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-85 {\n padding-left: 2380px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-85 {\n padding-right: 2380px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-85 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-85 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-left: 2420px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-right: 2420px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-86 {\n padding-left: 2408px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-86 {\n padding-right: 2408px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-86 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-86 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-left: 2448px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-right: 2448px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-87 {\n padding-left: 2436px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-87 {\n padding-right: 2436px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-87 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-87 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-left: 2476px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-right: 2476px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-88 {\n padding-left: 2464px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-88 {\n padding-right: 2464px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-88 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-88 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-left: 2504px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-right: 2504px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-89 {\n padding-left: 2492px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-89 {\n padding-right: 2492px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-89 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-89 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-left: 2532px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-right: 2532px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-90 {\n padding-left: 2520px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-90 {\n padding-right: 2520px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-90 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-90 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-left: 2560px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-right: 2560px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-91 {\n padding-left: 2548px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-91 {\n padding-right: 2548px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-91 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-91 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-left: 2588px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-right: 2588px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-92 {\n padding-left: 2576px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-92 {\n padding-right: 2576px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-92 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-92 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-left: 2616px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-right: 2616px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-93 {\n padding-left: 2604px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-93 {\n padding-right: 2604px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-93 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-93 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-left: 2644px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-right: 2644px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-94 {\n padding-left: 2632px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-94 {\n padding-right: 2632px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-94 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-94 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-left: 2672px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-right: 2672px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-95 {\n padding-left: 2660px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-95 {\n padding-right: 2660px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-95 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-95 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-left: 2700px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-right: 2700px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-96 {\n padding-left: 2688px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-96 {\n padding-right: 2688px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-96 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-96 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-left: 2728px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-right: 2728px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-97 {\n padding-left: 2716px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-97 {\n padding-right: 2716px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-97 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-97 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-left: 2756px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-right: 2756px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-98 {\n padding-left: 2744px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-98 {\n padding-right: 2744px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-98 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-98 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-left: 2784px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-right: 2784px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-99 {\n padding-left: 2772px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-99 {\n padding-right: 2772px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-level-99 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-level-99 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-row-group-leaf-indent {\n margin-left: 28px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-row-group-leaf-indent {\n margin-right: 28px;\n}\n\n.ag-theme-balham-dark .ag-value-change-delta {\n padding-right: 2px;\n}\n.ag-theme-balham-dark .ag-value-change-delta-up {\n color: #43a047;\n color: var(--ag-value-change-delta-up-color, #43a047);\n}\n.ag-theme-balham-dark .ag-value-change-delta-down {\n color: #e53935;\n color: var(--ag-value-change-delta-down-color, #e53935);\n}\n.ag-theme-balham-dark .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n -webkit-transition: background-color 1s;\n transition: background-color 1s;\n}\n.ag-theme-balham-dark .ag-value-change-value-highlight {\n background-color: rgba(22, 160, 133, 0.5);\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5));\n -webkit-transition: background-color 0.1s;\n transition: background-color 0.1s;\n}\n.ag-theme-balham-dark .ag-cell-data-changed {\n background-color: rgba(22, 160, 133, 0.5) !important;\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5)) !important;\n}\n.ag-theme-balham-dark .ag-cell-data-changed-animation {\n background-color: transparent;\n}\n.ag-theme-balham-dark .ag-cell-highlight {\n background-color: #00B0FF !important;\n background-color: var(--ag-range-selection-highlight-color, var(--ag-balham-active-color, #00B0FF)) !important;\n}\n.ag-theme-balham-dark .ag-row {\n height: 28px;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n color: #F5F5F5;\n color: var(--ag-data-color, var(--ag-foreground-color, #F5F5F5));\n border-width: 1px;\n border-color: #5c5c5c;\n border-color: var(--ag-row-border-color, #5c5c5c);\n border-bottom-style: solid;\n}\n.ag-theme-balham-dark .ag-row-highlight-above::after, .ag-theme-balham-dark .ag-row-highlight-below::after {\n content: \"\";\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #00B0FF;\n background-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n left: 1px;\n}\n.ag-theme-balham-dark .ag-row-highlight-above::after {\n top: -1px;\n}\n.ag-theme-balham-dark .ag-row-highlight-above.ag-row-first::after {\n top: 0;\n}\n.ag-theme-balham-dark .ag-row-highlight-below::after {\n bottom: 0px;\n}\n.ag-theme-balham-dark .ag-row-odd {\n background-color: #262c2e;\n background-color: var(--ag-odd-row-background-color, #262c2e);\n}\n.ag-theme-balham-dark .ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-row-hover {\n background-color: #3d4749;\n background-color: var(--ag-row-hover-color, #3d4749);\n}\n.ag-theme-balham-dark .ag-column-hover {\n background-color: #3d4749;\n background-color: var(--ag-column-hover-color, #3d4749);\n}\n.ag-theme-balham-dark .ag-ltr .ag-right-aligned-cell {\n text-align: right;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-right-aligned-cell {\n text-align: left;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-right-aligned-cell .ag-cell-value, .ag-theme-balham-dark .ag-ltr .ag-right-aligned-cell .ag-group-value {\n margin-left: auto;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-right-aligned-cell .ag-cell-value, .ag-theme-balham-dark .ag-rtl .ag-right-aligned-cell .ag-group-value {\n margin-right: auto;\n}\n\n.ag-theme-balham-dark .ag-cell, .ag-theme-balham-dark .ag-full-width-row .ag-cell-wrapper.ag-row-group {\n border: 1px solid transparent;\n line-height: min(var(--ag-row-height, 26px), 26px);\n padding-left: 11px;\n padding-right: 11px;\n -webkit-font-smoothing: subpixel-antialiased;\n}\n.ag-theme-balham-dark .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px;\n}\n.ag-theme-balham-dark .ag-row-dragging {\n cursor: move;\n opacity: 0.5;\n}\n.ag-theme-balham-dark .ag-cell-inline-editing {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 28px;\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020);\n}\n.ag-theme-balham-dark .ag-popup-editor {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020);\n padding: 0;\n}\n.ag-theme-balham-dark .ag-large-text-input {\n height: auto;\n padding: 12px;\n}\n.ag-theme-balham-dark .ag-details-row {\n padding: 20px;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n}\n.ag-theme-balham-dark .ag-layout-auto-height .ag-center-cols-clipper, .ag-theme-balham-dark .ag-layout-auto-height .ag-center-cols-container, .ag-theme-balham-dark .ag-layout-print .ag-center-cols-clipper, .ag-theme-balham-dark .ag-layout-print .ag-center-cols-container {\n min-height: 50px;\n}\n.ag-theme-balham-dark .ag-overlay-loading-wrapper {\n background-color: rgba(45, 52, 54, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(45, 52, 54, 0.66));\n}\n.ag-theme-balham-dark .ag-overlay-loading-center {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n}\n.ag-theme-balham-dark .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px;\n}\n.ag-theme-balham-dark .ag-loading {\n padding-left: 12px;\n display: -webkit-box;\n display: flex;\n height: 100%;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-balham-dark .ag-loading-icon {\n padding-right: 12px;\n}\n.ag-theme-balham-dark .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear;\n}\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n.ag-theme-balham-dark .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-ltr .ag-cell {\n border-right: solid transparent;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-cell {\n border-left: solid transparent;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-cell {\n border-right-width: 1px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-cell {\n border-left-width: 1px;\n}\n\n.ag-theme-balham-dark .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-row-selected {\n background-color: #005880;\n background-color: var(--ag-selected-row-background-color, #005880);\n}\n.ag-theme-balham-dark .ag-cell-range-selected:not(.ag-cell-focus),\n.ag-theme-balham-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing) {\n background-color: rgba(0, 176, 255, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(0, 176, 255, 0.2));\n}\n.ag-theme-balham-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart,\n.ag-theme-balham-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart {\n background-color: rgba(45, 166, 255, 0.5) !important;\n background-color: var(--ag-range-selection-chart-background-color, rgba(45, 166, 255, 0.5)) !important;\n}\n.ag-theme-balham-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category,\n.ag-theme-balham-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(26, 177, 74, 0.5) !important;\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(26, 177, 74, 0.5)) !important;\n}\n.ag-theme-balham-dark .ag-cell-range-selected-1:not(.ag-cell-focus),\n.ag-theme-balham-dark .ag-root:not(.ag-context-menu-open) .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-1:not(.ag-cell-inline-editing) {\n background-color: rgba(0, 176, 255, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(0, 176, 255, 0.2)));\n}\n.ag-theme-balham-dark .ag-cell-range-selected-2:not(.ag-cell-focus),\n.ag-theme-balham-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-2 {\n background-color: rgba(0, 176, 255, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(0, 176, 255, 0.36));\n}\n.ag-theme-balham-dark .ag-cell-range-selected-3:not(.ag-cell-focus),\n.ag-theme-balham-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-3 {\n background-color: rgba(0, 176, 255, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(0, 176, 255, 0.488));\n}\n.ag-theme-balham-dark .ag-cell-range-selected-4:not(.ag-cell-focus),\n.ag-theme-balham-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-4 {\n background-color: rgba(0, 176, 255, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(0, 176, 255, 0.5904));\n}\n.ag-theme-balham-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #00B0FF;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n}\n.ag-theme-balham-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #00B0FF;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n}\n.ag-theme-balham-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #00B0FF;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n}\n.ag-theme-balham-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #00B0FF;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n}\n.ag-theme-balham-dark .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-balham-dark .ag-ltr .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-balham-dark .ag-ltr .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-balham-dark .ag-ltr .ag-cell-range-single-cell,\n.ag-theme-balham-dark .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-balham-dark .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-balham-dark .ag-rtl .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-balham-dark .ag-rtl .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-balham-dark .ag-rtl .ag-cell-range-single-cell,\n.ag-theme-balham-dark .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #00B0FF;\n border-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n outline: initial;\n}\n.ag-theme-balham-dark .ag-cell.ag-selection-fill-top,\n.ag-theme-balham-dark .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #00B0FF;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n}\n.ag-theme-balham-dark .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-balham-dark .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #00B0FF;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-balham-dark .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #00B0FF;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n}\n\n.ag-theme-balham-dark .ag-cell.ag-selection-fill-bottom,\n.ag-theme-balham-dark .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #00B0FF;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n}\n.ag-theme-balham-dark .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-balham-dark .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #00B0FF;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-balham-dark .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #00B0FF;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n}\n\n.ag-theme-balham-dark .ag-range-handle, .ag-theme-balham-dark .ag-fill-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #00B0FF;\n background-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n}\n.ag-theme-balham-dark .ag-ltr .ag-range-handle, .ag-theme-balham-dark .ag-ltr .ag-fill-handle {\n right: -1px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-range-handle, .ag-theme-balham-dark .ag-rtl .ag-fill-handle {\n left: -1px;\n}\n\n.ag-theme-balham-dark .ag-fill-handle {\n cursor: cell;\n}\n.ag-theme-balham-dark .ag-range-handle {\n cursor: nwse-resize;\n}\n.ag-theme-balham-dark .ag-cell-inline-editing {\n border-color: #719ECE !important;\n border-color: var(--ag-input-focus-border-color, #719ECE) !important;\n}\n.ag-theme-balham-dark .ag-menu {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n}\n.ag-theme-balham-dark .ag-menu-list {\n cursor: default;\n padding: 4px 0;\n}\n.ag-theme-balham-dark .ag-menu-separator {\n height: 9px;\n}\n.ag-theme-balham-dark .ag-menu-separator-part::after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-menu-option-active, .ag-theme-balham-dark .ag-compact-menu-option-active {\n background-color: #3d4749;\n background-color: var(--ag-row-hover-color, #3d4749);\n}\n.ag-theme-balham-dark .ag-menu-option-part, .ag-theme-balham-dark .ag-compact-menu-option-part {\n line-height: 16px;\n padding: 6px 0;\n}\n.ag-theme-balham-dark .ag-menu-option-disabled, .ag-theme-balham-dark .ag-compact-menu-option-disabled {\n opacity: 0.5;\n}\n.ag-theme-balham-dark .ag-menu-option-icon, .ag-theme-balham-dark .ag-compact-menu-option-icon {\n width: 16px;\n}\n.ag-theme-balham-dark .ag-ltr .ag-menu-option-icon, .ag-theme-balham-dark .ag-ltr .ag-compact-menu-option-icon {\n padding-left: 8px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-menu-option-icon, .ag-theme-balham-dark .ag-rtl .ag-compact-menu-option-icon {\n padding-right: 8px;\n}\n\n.ag-theme-balham-dark .ag-menu-option-text, .ag-theme-balham-dark .ag-compact-menu-option-text {\n padding-left: 8px;\n padding-right: 8px;\n}\n.ag-theme-balham-dark .ag-ltr .ag-menu-option-shortcut, .ag-theme-balham-dark .ag-ltr .ag-compact-menu-option-shortcut {\n padding-right: 4px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-menu-option-shortcut, .ag-theme-balham-dark .ag-rtl .ag-compact-menu-option-shortcut {\n padding-left: 4px;\n}\n\n.ag-theme-balham-dark .ag-menu-option-popup-pointer, .ag-theme-balham-dark .ag-compact-menu-option-popup-pointer {\n padding-right: 4px;\n}\n.ag-theme-balham-dark .ag-tabs {\n min-width: 220px;\n}\n.ag-theme-balham-dark .ag-tabs-header {\n width: 100%;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-balham-dark .ag-tab {\n border-bottom: 0 solid transparent;\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 0;\n flex: none;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-pack: center;\n justify-content: center;\n cursor: pointer;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-tab:focus {\n outline: none;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-tab:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham-dark .ag-tab-selected {\n border-bottom-color: #00B0FF;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)));\n}\n.ag-theme-balham-dark .ag-menu-header {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n}\n.ag-theme-balham-dark .ag-filter-separator {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-menu:not(.ag-tabs) .ag-filter-select {\n min-width: 167px;\n}\n.ag-theme-balham-dark .ag-tabs .ag-filter-select {\n min-width: 206px;\n}\n.ag-theme-balham-dark .ag-filter-select .ag-picker-field-wrapper {\n width: 0;\n}\n.ag-theme-balham-dark .ag-filter-condition-operator {\n height: 17px;\n}\n.ag-theme-balham-dark .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px;\n}\n\n.ag-theme-balham-dark .ag-set-filter-select-all {\n padding-top: 6px;\n}\n.ag-theme-balham-dark .ag-set-filter-list, .ag-theme-balham-dark .ag-filter-no-matches {\n height: 144px;\n}\n.ag-theme-balham-dark .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px;\n}\n.ag-theme-balham-dark .ag-filter-to {\n margin-top: 4px;\n}\n.ag-theme-balham-dark .ag-mini-filter {\n margin: 6px 6px;\n}\n.ag-theme-balham-dark .ag-set-filter-item {\n margin: 0px 6px;\n}\n.ag-theme-balham-dark .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px;\n}\n\n.ag-theme-balham-dark .ag-filter-apply-panel {\n padding: 6px 6px;\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242));\n}\n.ag-theme-balham-dark .ag-filter-apply-panel-button {\n line-height: 1.5;\n}\n.ag-theme-balham-dark .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px;\n}\n\n.ag-theme-balham-dark .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px;\n}\n.ag-theme-balham-dark .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px;\n}\n.ag-theme-balham-dark .ag-filter-no-matches {\n padding: 6px 6px;\n}\n.ag-theme-balham-dark .ag-multi-filter-menu-item {\n margin: 4px 0;\n}\n.ag-theme-balham-dark .ag-multi-filter-group-title-bar {\n padding: 8px 4px;\n background-color: transparent;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus {\n outline: none;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham-dark .ag-side-bar {\n position: relative;\n}\n.ag-theme-balham-dark .ag-tool-panel-wrapper {\n width: 200px;\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020);\n}\n.ag-theme-balham-dark .ag-side-buttons {\n padding-top: 16px;\n width: 20px;\n position: relative;\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5);\n overflow: hidden;\n}\n.ag-theme-balham-dark button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: calc(100% + 1px);\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark button.ag-side-button-button:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-side-button-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham-dark .ag-selected .ag-side-button-button {\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020);\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-side-button-icon-wrapper {\n margin-bottom: 3px;\n}\n.ag-theme-balham-dark .ag-ltr .ag-side-bar-left,\n.ag-theme-balham-dark .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n.ag-theme-balham-dark .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-ltr .ag-side-bar-left .ag-side-button-button,\n.ag-theme-balham-dark .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent;\n margin-right: -1px;\n padding-right: 1px;\n}\n.ag-theme-balham-dark .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-balham-dark .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #00B0FF;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)));\n}\n.ag-theme-balham-dark .ag-rtl .ag-side-bar-left,\n.ag-theme-balham-dark .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n.ag-theme-balham-dark .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-rtl .ag-side-bar-left .ag-side-button-button,\n.ag-theme-balham-dark .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent;\n margin-left: -1px;\n padding-left: 1px;\n}\n.ag-theme-balham-dark .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-balham-dark .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #00B0FF;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)));\n}\n.ag-theme-balham-dark .ag-filter-toolpanel-header {\n height: 24px;\n}\n.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-header, .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-header, .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px;\n}\n\n.ag-theme-balham-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham-dark .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f114\";\n position: absolute;\n}\n.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-left: 4px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-right: 4px;\n}\n\n.ag-theme-balham-dark .ag-filter-toolpanel-group-level-0-header {\n height: 32px;\n}\n.ag-theme-balham-dark .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px;\n}\n.ag-theme-balham-dark .ag-filter-toolpanel-search {\n height: 32px;\n}\n.ag-theme-balham-dark .ag-filter-toolpanel-search-input {\n -webkit-box-flex: 1;\n flex-grow: 1;\n height: 16px;\n}\n.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px;\n}\n\n.ag-theme-balham-dark .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242));\n}\n.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px;\n}\n\n.ag-theme-balham-dark .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px;\n}\n\n.ag-theme-balham-dark .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px;\n}\n\n.ag-theme-balham-dark .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px;\n}\n\n.ag-theme-balham-dark .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px;\n}\n\n.ag-theme-balham-dark .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px;\n}\n\n.ag-theme-balham-dark .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px;\n}\n\n.ag-theme-balham-dark .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px;\n}\n\n.ag-theme-balham-dark .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px;\n}\n\n.ag-theme-balham-dark .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px;\n}\n\n.ag-theme-balham-dark .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px;\n}\n\n.ag-theme-balham-dark .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px;\n}\n.ag-theme-balham-dark .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242);\n margin-top: 4px;\n}\n.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px;\n}\n\n.ag-theme-balham-dark .ag-pivot-mode-panel {\n min-height: 32px;\n height: 32px;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-balham-dark .ag-pivot-mode-select {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-balham-dark .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px;\n}\n\n.ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham-dark .ag-column-select-header {\n height: 32px;\n -webkit-box-align: center;\n align-items: center;\n padding: 0 6px;\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242));\n}\n.ag-theme-balham-dark .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242));\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242));\n}\n.ag-theme-balham-dark .ag-column-group-icons,\n.ag-theme-balham-dark .ag-column-select-header-icon {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n}\n.ag-theme-balham-dark .ag-column-select-list .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #00B0FF;\n background-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n}\n.ag-theme-balham-dark .ag-column-select-list .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-balham-dark .ag-column-select-list .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-balham-dark .ag-header {\n background-color: #1c1c1c;\n background-color: var(--ag-header-background-color, #1c1c1c);\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-header-row {\n color: rgba(245, 245, 245, 0.64);\n color: var(--ag-header-foreground-color, rgba(245, 245, 245, 0.64));\n height: 32px;\n}\n.ag-theme-balham-dark .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px;\n}\n\n.ag-theme-balham-dark .ag-header-cell,\n.ag-theme-balham-dark .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px;\n}\n.ag-theme-balham-dark .ag-header-cell.ag-header-cell-moving,\n.ag-theme-balham-dark .ag-header-group-cell.ag-header-cell-moving {\n background-color: #2d3436;\n background-color: var(--ag-header-cell-moving-background-color, var(--ag-background-color, #2d3436));\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-header-cell:focus {\n outline: none;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-header-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-header-group-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham-dark .ag-header-icon {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n}\n.ag-theme-balham-dark .ag-header-expand-icon {\n cursor: pointer;\n}\n.ag-theme-balham-dark .ag-ltr .ag-header-expand-icon {\n padding-left: 4px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-header-expand-icon {\n padding-right: 4px;\n}\n\n.ag-theme-balham-dark .ag-header-row:not(:first-child) .ag-header-cell,\n.ag-theme-balham-dark .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-header-cell::after,\n.ag-theme-balham-dark .ag-header-group-cell::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n width: 1px;\n height: 50%;\n top: calc(50% - 25%);\n background-color: rgba(66, 66, 66, 0.5);\n background-color: var(--ag-header-column-separator-color, rgba(66, 66, 66, 0.5));\n}\n.ag-theme-balham-dark .ag-ltr .ag-header-cell::after, .ag-theme-balham-dark .ag-ltr .ag-header-group-cell::after {\n right: 0;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-header-cell::after, .ag-theme-balham-dark .ag-rtl .ag-header-group-cell::after {\n left: 0;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-header-select-all {\n margin-right: 12px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-header-select-all {\n margin-left: 12px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-floating-filter-button {\n margin-left: 12px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-floating-filter-button {\n margin-right: 12px;\n}\n\n.ag-theme-balham-dark .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 16px;\n padding: 0;\n width: 16px;\n}\n.ag-theme-balham-dark .ag-filter-loading {\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1;\n}\n.ag-theme-balham-dark .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n height: 32px;\n}\n.ag-theme-balham-dark .ag-paging-panel > * {\n margin: 0 12px;\n}\n.ag-theme-balham-dark .ag-paging-button {\n cursor: pointer;\n}\n.ag-theme-balham-dark .ag-paging-button.ag-disabled {\n cursor: default;\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-paging-button:focus {\n outline: none;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-paging-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham-dark .ag-paging-button, .ag-theme-balham-dark .ag-paging-description {\n margin: 0 4px;\n}\n.ag-theme-balham-dark .ag-status-bar {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5;\n}\n.ag-theme-balham-dark .ag-status-name-value-value {\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5);\n}\n.ag-theme-balham-dark .ag-status-bar-center {\n text-align: center;\n}\n.ag-theme-balham-dark .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px;\n}\n.ag-theme-balham-dark .ag-column-drop-cell {\n background: #353535;\n background: var(--ag-chip-background-color, #353535);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px;\n border: 1px solid transparent;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-column-drop-cell:focus {\n outline: none;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-column-drop-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 2px;\n left: 2px;\n display: block;\n width: calc(100% - 4px);\n height: calc(100% - 4px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham-dark .ag-column-drop-cell-text {\n margin: 0 4px;\n}\n.ag-theme-balham-dark .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n}\n.ag-theme-balham-dark .ag-column-drop-cell-drag-handle {\n margin-left: 8px;\n}\n.ag-theme-balham-dark .ag-column-drop-cell-ghost {\n opacity: 0.5;\n}\n.ag-theme-balham-dark .ag-column-drop-horizontal {\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020);\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n height: 28px;\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242);\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242);\n}\n\n.ag-theme-balham-dark .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n}\n.ag-theme-balham-dark .ag-column-drop-horizontal-empty-message {\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n}\n.ag-theme-balham-dark .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px;\n}\n\n.ag-theme-balham-dark .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px;\n}\n.ag-theme-balham-dark .ag-column-drop-vertical-cell {\n margin-top: 4px;\n}\n.ag-theme-balham-dark .ag-column-drop-vertical {\n min-height: 50px;\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242));\n}\n.ag-theme-balham-dark .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none;\n}\n.ag-theme-balham-dark .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px;\n}\n.ag-theme-balham-dark .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n margin-top: 4px;\n}\n.ag-theme-balham-dark .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n height: 70px;\n padding: 0;\n}\n.ag-theme-balham-dark .ag-select-agg-func-virtual-list-item {\n cursor: default;\n padding-left: 8px;\n}\n.ag-theme-balham-dark .ag-select-agg-func-virtual-list-item:hover {\n background-color: #005880;\n background-color: var(--ag-selected-row-background-color, #005880);\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-balham-dark .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham-dark .ag-chart-menu {\n border-radius: 2px;\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n}\n.ag-theme-balham-dark .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 2px;\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n}\n.ag-theme-balham-dark .ag-chart-menu-icon:hover {\n opacity: 1;\n}\n.ag-theme-balham-dark .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: #424242;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242));\n border-radius: 5px;\n margin: 5px;\n}\n.ag-theme-balham-dark .ag-chart-mini-thumbnail:nth-last-child(3), .ag-theme-balham-dark .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto;\n}\n.ag-theme-balham-dark .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0;\n}\n\n.ag-theme-balham-dark .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0;\n}\n\n.ag-theme-balham-dark .ag-chart-mini-thumbnail.ag-selected {\n border-color: #00B0FF;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF)));\n}\n.ag-theme-balham-dark .ag-chart-settings-card-item {\n background: #F5F5F5;\n background: var(--ag-foreground-color, #F5F5F5);\n width: 8px;\n height: 8px;\n border-radius: 4px;\n}\n.ag-theme-balham-dark .ag-chart-settings-card-item.ag-selected {\n background-color: #00B0FF;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF)));\n}\n.ag-theme-balham-dark .ag-chart-data-column-drag-handle {\n margin-left: 4px;\n}\n.ag-theme-balham-dark .ag-charts-settings-group-title-bar,\n.ag-theme-balham-dark .ag-charts-data-group-title-bar,\n.ag-theme-balham-dark .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242));\n}\n.ag-theme-balham-dark .ag-charts-settings-group-container {\n padding: 4px;\n}\n.ag-theme-balham-dark .ag-charts-data-group-container {\n padding: 3px 6px;\n}\n.ag-theme-balham-dark .ag-charts-data-group-container .ag-charts-data-group-item:not(.ag-charts-format-sub-level-group) {\n height: 24px;\n}\n.ag-theme-balham-dark .ag-charts-data-group-container .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #00B0FF;\n background-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n}\n.ag-theme-balham-dark .ag-charts-data-group-container .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-balham-dark .ag-charts-data-group-container .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-balham-dark .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px;\n}\n.ag-theme-balham-dark .ag-charts-format-top-level-group-item {\n margin: 4px 0;\n}\n.ag-theme-balham-dark .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px;\n}\n.ag-theme-balham-dark .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px;\n}\n.ag-theme-balham-dark .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px;\n}\n.ag-theme-balham-dark .ag-chart-data-section,\n.ag-theme-balham-dark .ag-chart-format-section {\n display: -webkit-box;\n display: flex;\n margin: 0;\n}\n.ag-theme-balham-dark .ag-chart-menu-panel {\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020);\n}\n.ag-theme-balham-dark .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242);\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242);\n}\n\n.ag-theme-balham-dark .ag-date-time-list-page-title {\n -webkit-box-flex: 1;\n flex-grow: 1;\n text-align: center;\n}\n.ag-theme-balham-dark .ag-date-time-list-page-column-label {\n text-align: center;\n}\n.ag-theme-balham-dark .ag-date-time-list-page-entry {\n text-align: center;\n}\n.ag-theme-balham-dark .ag-checkbox-input-wrapper {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #2d3436;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #2d3436));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-balham-dark .ag-checkbox-input-wrapper input, .ag-theme-balham-dark .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-balham-dark .ag-checkbox-input-wrapper:focus-within, .ag-theme-balham-dark .ag-checkbox-input-wrapper:active {\n outline: none;\n -webkit-box-shadow: 0 0 4px 1.5px #719ECE;\n box-shadow: 0 0 4px 1.5px #719ECE;\n}\n.ag-theme-balham-dark .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-balham-dark .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #ecf0f1;\n color: var(--ag-checkbox-unchecked-color, #ecf0f1);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-balham-dark .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #00B0FF;\n color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-balham-dark .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #ecf0f1;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, #ecf0f1));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-balham-dark .ag-toggle-button-input-wrapper {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n width: 32px;\n height: 16px;\n background-color: transparent;\n background-color: var(--ag-toggle-button-off-background-color, transparent);\n border-radius: 8px;\n position: relative;\n -webkit-box-flex: 0;\n flex: none;\n border: 1px solid;\n border-color: #F5F5F5;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-foreground-color, #F5F5F5));\n}\n.ag-theme-balham-dark .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%;\n}\n.ag-theme-balham-dark .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n -webkit-box-shadow: 0 0 4px 1.5px #719ECE;\n box-shadow: 0 0 4px 1.5px #719ECE;\n}\n.ag-theme-balham-dark .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-balham-dark .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #00B0FF;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF)));\n border-color: #00B0FF;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF)));\n}\n.ag-theme-balham-dark .ag-toggle-button-input-wrapper::before {\n content: \" \";\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n height: 16px;\n width: 16px;\n background-color: #2d3436;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #2d3436));\n border-radius: 8px;\n -webkit-transition: left 100ms;\n transition: left 100ms;\n border: 1px solid;\n border-color: #F5F5F5;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-foreground-color, #F5F5F5)));\n}\n.ag-theme-balham-dark .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 16px );\n border-color: #00B0FF;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF)));\n}\n.ag-theme-balham-dark .ag-radio-button-input-wrapper {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #2d3436;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #2d3436));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n border-radius: 16px;\n}\n.ag-theme-balham-dark .ag-radio-button-input-wrapper input, .ag-theme-balham-dark .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-balham-dark .ag-radio-button-input-wrapper:focus-within, .ag-theme-balham-dark .ag-radio-button-input-wrapper:active {\n outline: none;\n -webkit-box-shadow: 0 0 4px 1.5px #719ECE;\n box-shadow: 0 0 4px 1.5px #719ECE;\n}\n.ag-theme-balham-dark .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-balham-dark .ag-radio-button-input-wrapper::after {\n content: \"\\f126\";\n color: #ecf0f1;\n color: var(--ag-checkbox-unchecked-color, #ecf0f1);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-balham-dark .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f127\";\n color: #00B0FF;\n color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-balham-dark input[class^=ag-][type=range] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible;\n}\n.ag-theme-balham-dark input[class^=ag-][type=range]::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #424242;\n background-color: var(--ag-border-color, #424242);\n border-radius: 2px;\n border-radius: 3px;\n}\n.ag-theme-balham-dark input[class^=ag-][type=range]::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #424242;\n background-color: var(--ag-border-color, #424242);\n border-radius: 2px;\n border-radius: 3px;\n}\n.ag-theme-balham-dark input[class^=ag-][type=range]::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #424242;\n background-color: var(--ag-border-color, #424242);\n border-radius: 2px;\n border-radius: 3px;\n color: transparent;\n width: calc(100% - 2px);\n}\n.ag-theme-balham-dark input[class^=ag-][type=range]::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n border: 1px solid;\n border-color: #ecf0f1;\n border-color: var(--ag-checkbox-unchecked-color, #ecf0f1);\n border-radius: 16px;\n -webkit-transform: translateY(-6.5px);\n transform: translateY(-6.5px);\n}\n.ag-theme-balham-dark input[class^=ag-][type=range]::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n border: 1px solid;\n border-color: #ecf0f1;\n border-color: var(--ag-checkbox-unchecked-color, #ecf0f1);\n border-radius: 16px;\n}\n.ag-theme-balham-dark input[class^=ag-][type=range]::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n border: 1px solid;\n border-color: #ecf0f1;\n border-color: var(--ag-checkbox-unchecked-color, #ecf0f1);\n border-radius: 16px;\n}\n.ag-theme-balham-dark input[class^=ag-][type=range]:focus {\n outline: none;\n}\n.ag-theme-balham-dark input[class^=ag-][type=range]:focus::-webkit-slider-thumb {\n -webkit-box-shadow: 0 0 4px 1.5px #719ECE;\n box-shadow: 0 0 4px 1.5px #719ECE;\n border-color: #00B0FF;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF));\n}\n.ag-theme-balham-dark input[class^=ag-][type=range]:focus::-ms-thumb {\n box-shadow: 0 0 4px 1.5px #719ECE;\n border-color: #00B0FF;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF));\n}\n.ag-theme-balham-dark input[class^=ag-][type=range]:focus::-moz-ag-range-thumb {\n box-shadow: 0 0 4px 1.5px #719ECE;\n border-color: #00B0FF;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF));\n}\n.ag-theme-balham-dark input[class^=ag-][type=range]:active::-webkit-slider-runnable-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham-dark input[class^=ag-][type=range]:active::-moz-ag-range-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham-dark input[class^=ag-][type=range]:active::-ms-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham-dark input[class^=ag-][type=range]:disabled {\n opacity: 0.5;\n}\n.ag-theme-balham-dark .ag-filter-toolpanel-header,\n.ag-theme-balham-dark .ag-filter-toolpanel-search,\n.ag-theme-balham-dark .ag-status-bar,\n.ag-theme-balham-dark .ag-header-row,\n.ag-theme-balham-dark .ag-multi-filter-group-title-bar {\n font-weight: 600;\n color: rgba(245, 245, 245, 0.64);\n color: var(--ag-header-foreground-color, rgba(245, 245, 245, 0.64));\n}\n.ag-theme-balham-dark .ag-ltr input[class^=ag-]:not([type]),\n.ag-theme-balham-dark .ag-ltr input[class^=ag-][type=text],\n.ag-theme-balham-dark .ag-ltr input[class^=ag-][type=number],\n.ag-theme-balham-dark .ag-ltr input[class^=ag-][type=tel],\n.ag-theme-balham-dark .ag-ltr input[class^=ag-][type=date],\n.ag-theme-balham-dark .ag-ltr input[class^=ag-][type=datetime-local],\n.ag-theme-balham-dark .ag-ltr textarea[class^=ag-] {\n padding-left: 4px;\n}\n\n.ag-theme-balham-dark .ag-rtl input[class^=ag-]:not([type]),\n.ag-theme-balham-dark .ag-rtl input[class^=ag-][type=text],\n.ag-theme-balham-dark .ag-rtl input[class^=ag-][type=number],\n.ag-theme-balham-dark .ag-rtl input[class^=ag-][type=tel],\n.ag-theme-balham-dark .ag-rtl input[class^=ag-][type=date],\n.ag-theme-balham-dark .ag-rtl input[class^=ag-][type=datetime-local],\n.ag-theme-balham-dark .ag-rtl textarea[class^=ag-] {\n padding-right: 4px;\n}\n\n.ag-theme-balham-dark .ag-column-drop-vertical-empty-message, .ag-theme-balham-dark .ag-status-bar {\n font-weight: 600;\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n}\n.ag-theme-balham-dark .ag-dnd-ghost {\n font-weight: 600;\n}\n.ag-theme-balham-dark .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px;\n}\n.ag-theme-balham-dark .ag-tab-selected {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n border-bottom-color: transparent;\n}\n.ag-theme-balham-dark .ag-tabs-header {\n border-bottom: 1px solid;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242);\n}\n.ag-theme-balham-dark .ag-column-drop-cell {\n height: 24px;\n}\n.ag-theme-balham-dark .ag-column-drop-vertical-title {\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5);\n}\n.ag-theme-balham-dark .ag-column-drop-vertical-cell {\n margin-left: 8px;\n margin-right: 8px;\n}\n.ag-theme-balham-dark .ag-column-drop-vertical-cell-text {\n margin-left: 8px;\n}\n.ag-theme-balham-dark .ag-column-drop-vertical-icon {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n}\n.ag-theme-balham-dark .ag-ltr .ag-column-drop-vertical-empty-message {\n padding-left: 24px;\n padding-right: 4px;\n}\n\n.ag-theme-balham-dark .ag-rtl .ag-column-drop-vertical-empty-message {\n padding-right: 24px;\n padding-left: 4px;\n}\n\n.ag-theme-balham-dark .ag-column-drop-horizontal {\n height: 32px;\n}\n.ag-theme-balham-dark .ag-column-drop-empty {\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n}\n.ag-theme-balham-dark .ag-column-drop-horizontal-cell-text {\n margin-left: 8px;\n}\n.ag-theme-balham-dark .ag-column-drop-vertical {\n padding-top: 8px;\n}\n.ag-theme-balham-dark .ag-menu-header {\n background-color: #1c1c1c;\n background-color: var(--ag-header-background-color, #1c1c1c);\n}\n.ag-theme-balham-dark .ag-overlay-loading-center {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n border: 1px solid;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5);\n padding: 16px;\n}\n.ag-theme-balham-dark .ag-tooltip {\n border: none;\n background-color: #cbd0d3;\n}\n.ag-theme-balham-dark .ag-panel-title-bar-button-icon {\n font-size: 20px;\n}\n.ag-theme-balham-dark .ag-chart-data-section,\n.ag-theme-balham-dark .ag-chart-format-section {\n padding-bottom: 2px;\n}\n.ag-theme-balham-dark .ag-group-toolbar {\n background-color: rgba(17, 17, 17, 0.5);\n background-color: var(--ag-subheader-toolbar-background-color, rgba(17, 17, 17, 0.5));\n}\n.ag-theme-balham-dark .ag-chart-tab {\n padding-top: 2px;\n}\n.ag-theme-balham-dark .ag-charts-format-sub-level-group-item {\n margin-bottom: 6px;\n}\n.ag-theme-balham-dark .ag-tooltip {\n background-color: #1c1f20;\n}\n", ""]); // Exports module.exports = exports; /***/ }), -/* 234 */ +/* 287 */ /***/ (function(module, exports, __webpack_require__) { -var api = __webpack_require__(225); - var content = __webpack_require__(235); +var api = __webpack_require__(278); + var content = __webpack_require__(288); content = content.__esModule ? content.default : content; @@ -48613,24 +57558,24 @@ var update = api(content, options); module.exports = content.locals || {}; /***/ }), -/* 235 */ +/* 288 */ /***/ (function(module, exports, __webpack_require__) { // Imports -var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227); +var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(280); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, ".ag-theme-balham {\n -webkit-font-smoothing: antialiased;\n color: #000;\n color: var(--ag-foreground-color, #000);\n font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n font-size: 12px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridBalham\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABX4AAsAAAAAJ8wAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlEAAAReXgFf/09TLzIAAANcAAAAPgAAAFZWTFJaY21hcAAAA5wAAAHtAAAFgFIH7gFnbHlmAAAFjAAADLgAABYYNphscGhlYWQAABJEAAAALwAAADZ2zsSBaGhlYQAAEnQAAAAbAAAAJAfTBC1obXR4AAASkAAAABIAAAEUp/gAAGxvY2EAABKkAAAAZAAAAIwBFQakbWF4cAAAEwgAAAAfAAAAIAFbAHNuYW1lAAATKAAAATUAAAJG0OP3eXBvc3QAABRgAAABlwAAAlqez14KeJx9k09yElEQxr9hCBKISYwxloga/0bjOAwM/yQQCFKWZWXhwoULN3GhpZVylRO49gCWB/AUnsBy6coDeADLA/jrZpCYRXjFzJvur7/+ul8/BZJKSrSr3OTx/nMtHx4cvVdFeU1/5j++Dw7fvjlQcfaFL+/vooLwj5Z1Qy90pG+BgtfB51whzIW74X74IfwU/lAIalMx6LIesGLVeEZkr6uhVDkVsMXsm2qBDnm23bqmC1pwz1AjrZMzJmbkjNt6qptahWfgPH31QCUs4+zzHLNuaeUURKrb8NdR08VqrFUyrGpRe2jso6NDdAvvCr4dMkfEDPANdA68ofLexyd6iaI1r80i6xku4R/TZfuO/KvMmqHa8DfgN74tss7sDTLViLgHex3Uw6yH27pGdAOePmwdj256dBlkDYWJrrKzympUtkT9PT3TK8+6m8X0vYvTmrdQP7cPnC+l2uPWDlxjsHfRMLfaidwhV6QJ/pI2eL/TR33RV33XT/3Sb53B2sVrFfTg3jm1M0X6dxI9xNv+Z7VKC5zPSdT/iEXqbnhvYnyjrIOWrYxO603CPsKaOL6ETsMPUZNyGnlyRJ63hnWB1eU7Bn02m8YWa8n7PGIGbAIqdKfB05im85bS4Usw2W6qa8O71YLnop+W9dRu0rJ/2czbKVfAXOYdUVnd+/MI7xUsxjS3VD0qRbVx3MefonaezVRVUdX02bXJmvgtGJJpkzqmSmrcXLsBE5+q6yioZzdyndMw9Z3spM47LvaoAM1RdpMT75lN8gBtNhXjv2nbY10AAAB4nGNgZMpnnMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVFgEqgRRAAAy9AKRgAAeJy102dSWzEUhuHXhW56TaN3Y2wwvRkb/rAM0hlSGNKZrDI70QZCvnPPyQLITDTz+Ls6o6srjSygDSjImhQhXySHtd+q5rJ6ge6sXuSX+iU6yeu5whU33KXa/b2qFS655jblst7fltPoEk9ZZEe9I811oKdjqrT0xh4b7LPLCXU2OWWdbWo0OGeLQ5qc6f28vl7UGtvp0He7tJIezdhLH/0MMMgQw4wwyhjjTPCYJ/raM42ZZIppZpjVuDnmWdAalvTcwzIr+l1Vr6wFtvOwdvTA8dbWDnaOq63Knna7e1Lf1Ea3a43zrcPm2T9M9h9ayX4KP6N3gZ2ms91eBvt/PA8H8iLYyb4Mx/IqVOV1aMmbYPO+DXtyFTbkOuzLu7Ar78OJfAh1+Rg25Sacym1Yl09hWz6HmnwJDfkazuVb2JLv4VB+hKbcBR1gyjm7KynvsCw4u1up6Ox+pTZn9y61Oyw7HJadDssuh2W3s/uYehyWJWcnmXodln0Oy36H5YDDctBhOeSwHHZYjjgsRx2WYw7LcYflhMPykdPdJAXdUlLQfSUF3VxSyPY16bCcclhOOyxnHJazDss5l+133mG1BYfVFh1WW3JYbdlhtRWXzbPqsrWVHTZ2zWFjKy4bs+6w96oum7PmKP8BU32drwAAAHic7RhpcBvVeb+3lmRZsm5pJdk6V4ety9YdS/Zu7MTGdu7DCRlC0jQHDTFH0tAwIYJCaCAhDDSZcEwzFDoDGZgpw7TTDNMmpUMZMFNi0hQ6JTD9AbQNaRtCyXQGFy393molxybl+l1pd9/33vve9773ve96j2EZ/LHPss8yHJNm1jMMeAlnYQ1E0xROkSixCqQYUgXVRlDbbZwXuKawAEULm4JohA+qVXyetzs45a/WyH97Np+1B6K5YqGIuIViIRKl/3yANXcMxqCpCWKDHdJ70nvTNfBIfwvPAWCbSI4HL3j5HNHpEF65de5/4CFxCqw6v9fg0JlanEZ/xMBNidJ+aNLYDf0Gu1rt9XVbPAC72KevRBo8cm2gEF77+JIfXF8nrUzDslMia7ToHQ691dI+4Gh1egycSazouuwhm75bbzWa250hm5+fR0UFsrweYR9hfAxj5TTRIqcJmOUiag7IRTFglgvOPDGcOHw4MQytM0vpY6X+5pXbG/2tynzkZdbGNGNFmYeHN/clz5xJ7hPI0X2JM2cS+6Q5lC2Zt23sNsbGdDJ5xA/S7bDRrcnQfcjRfdBkaN1Ge+R9KdAeK9JFykg/WoRLW1aPZbLZzNjq1+rAlrGRoVg8HhsaeYYCEENo7MnkU08ln5S/7LYZ6DIgzESXIenj+gj8Mg2enawTIQ2jQ5lmzTx9i1k7f7pSOb9z5we33EK2SteR4erzU1PTYz5gzzFWJsogmU4IpiBvzgmQDWS8YDfbDMAGggYKeWmbQHtToAGUH7C56vfTK7q7V6RJreyqVjwZDz5kr1x2SOteyz4KN01jpOUR7E88aU91D37wIXfj5yPEzDwKN8/mKf7VeWIDaBdfxlF/9SXS++XsSKlhWV1m8MJAfXo+0GBJdSVOcpcRp5PdNYsL9tzlvbQcms2BIodb2U2MCjXWyTBa0HBaYIs+qPkGmyNTyFNFJH+X1pc2SlUQJiZeeU6ncxkd6cG0w+iCF+GJMnZIv4W+iQmhtdXbFnEF0+mgK9zupeSb5DmSrEHRGSPDhHlz1qq8QN/jovgrQTghitVTgvA2yVQnp9+GHZPDrAr5RB6p3pND0sXE++8n4FKtVNayCO3JyvBMN52lLsByQ6gsekEEHNhSwK4Izi7vuT2A7eSnl+Ij8dhIghbxkcinkUJB/khNc2MjcTgiXRfOV7APsjJCXDqFH5IpRKSXKCr0RgqSnljiw3ExH57m+2XyMrUVmGG1l5kj8V9uZjN9iOKbssSq+BBYWPMhMDFbLrh1Gi2QQygM6SKYyJ+odExgQhSVLJtjbAkl08MsZMaYdYhfKGYxfNSiAOXMANGa7y/KXgbZ5AxgBDlY0KpaFmiuCAKIkCI4ppClgrVpwqgpqJwZEVBbUsAHNcCv32pZ+/SdoVazpc3tj/QlRhY8s2zl/GVpk1Wr05lMCbE3IXQv5CCybMmGzWsdtvbSSO+mcgLu6V7AgXfnkR8v4Esj5c2luDTpjl8V74om3LHhWFeUfJRm2cX3Xt0e9MbaAy4kHLbY7N3lVW0pm9PutffF+xIP+67OkzVCn83uVbe0x8ubyiMl6ff+NXkyfGMfGwxiS+9I6WxHF1J0J6JdcSymdfUYyzNtTIopo6TkCKuISH25eDBWcgZSl05NIhqUBioZSgmViqOSQLv1AIqGWi1UG/JYcMP1N+1YszSjyEL8zTgsvP9GnyKLZXfyVADDpQ2l0oadG3p6NvwxNrxyOCZ/WL6x+MUh3mCcW1qtLHxsU5NI+sYHawv3uG9ZQlfr60ESNTp/gBglEiO1ouF7kmwS8wn0gqCs0wOaYkFZbKQPAiqbkjPYi/maahTybBI6nQNFZ/MJAAIaZ2HA1Um2V081yxCqSK2XnIt2e8rdbq3+uwfHdpR0za50n7c7NCiate50n6c7tLdrRUe3p5R2a80KP2RK1mdtXaNVZt5MPlG0WvqW0FBsh6SHS4y+tgZyoeFfrLiaNoz4vOzbuximyOez3GVv+EvqU7IvmvZIV65MVWo/USkFpUR2mmfkaXm0uT6mnxlkRr5uxmZFblQYc8Kzym+Ymx2tVGCX9Ar0SPsbkB6hS9IoHP9m6Vj1n4IgiMrbiGfTe1jz1tTLk7jisf8sCHWvXf037mBdD3ewbSg5M913dMh061muGMXVFqMkKsJ+aZd4QDoLkcnJdAXelbyVNHlQOCEcgAhEpLOTGdyBTJ3WdowDMWa1rNMoVg0KGN0blWpBhHwkmkY9NwCqtBdzXhHVFVXdGpSxsJF6u5TSQUfbsAOb07Ldy1R44sRYGWhraWkf96zoCOU0aofLomctYVO70WDi43t6Yr7xpNPDxTbFFnm2dXHtXNzbDJqwy66z0CHxInA2C+hYC29ot7Xo5qUinWRQq1e1Le+MeLZ5rK2tfRF+yG1h+bAlZI9u7E6H4m2c0b8tdU855QOtH6neXe72e7U6lW9TkkOqVoNxScqTt8ljAtbQtcn0Eqvp/zK5kkxqNnofe9/n/AZDrYzGaRW+ssXhW1TqGoTRaoWbJxIT8GJiIgGuqanq5NTUAoTJOmxF77FuyocAPokMWsU6LPGZeHpq2j6qpMqoGTwyWH3UQDThLsDsoPgP9q2hHct2wO+UcuIsS8vHaoWS4yTJ6/X8G9A66n82WX0APbDygktEexDrex/EmCbPp0ykTAuvN8kT/bA237/easJiO7zwFju0ffkOZewzmLvV7LKejaA51w43UDqYevts6mA//KIfobe7DsLSvfFTp+J74WR1Ek7WYJyZ0rmL3cU4mAQzh5kr5yAMUFXjHLLaoa5R7SoKhKNVjVrRQwxEsm4hGm2NRrpACw45BnWBwwcgjyoUOTlyccUITF27atkNLfpYZNHI81dfO69vLiFh/4339S8dnn+NVhuOLF98cvFYjG9uXjM0uvqCX61e0jcwmktHYbf0YXa8M2Y0W08O9HRI+0I6p7tQWq4Vchm7w/KZj/0eyaWPrdt8zdI5+bDdIfQ8tnL1aP/GgkgSsfuXji1akoqrYslVI2PLHownX+0bGaoEQxqV2wG3SQ+b2sKRXKn8GvE6pH3iof55nUmVwHZ29Arlz1qUfR1nb0Pt62B6UTLy4U8+ENr5zyf/vCbjsKmDkVwBAsEINhXKYA/ksxkHIqrJdr3B5Vvlcxn0lWBPEB+4VCunzC5X0OUCnaR3h0JuEXYJ7nCY9VhsToPFYnDaLIgkjSqDjuPH7PQ78ak+HnbBcXeoUgm5pVFXuOGz9yDPQYxuDNSzxgLuAS1EoNuloXkD9TRoTzS98IEmgquC2v4VOUdWTi1h2SEgTSqtp9RV3Nhs1LssnA289rmD38HsgrXZk9xDGDj+YtXqm01HCx0ZM7ibOQLN5Ehzi85osJjegNsPYS5l1HfotLoNbq+zzWoxSO+2j+k3q1WufLyb0yEF8oDJZDU4jhpYtk36q9oWdeYsD2Gk0zRb3qDLabksbvtxJ/qZIWYBs5K5htnAbPkfsTtgdsgXJyoavn2Y5tUsw46JoIavXTk4ZMGEbVw2H1VrsvliDFAiWUw87Fmq3WE1r7FnixHenv2iwA67q698eAGjrrbaDBiD/fDLlsTYyoQ2NtSxU5sYG0u0zA1l3F6ovgp7bgOoiLkFmAnsFuHkboqP4uiJ3fHCnKvu+MJQ/2n1VbUW0S+cMptwMrgNjDJx7c0dV8WJNrES5wGVxuqIeYfm3P7r0fwdnxTC68U9e4I0IQDYU4HbG/pxDs+19H5Dud0wUXXwU3GYZt1uBGmdXkIV4NK9O7fPmz9/3vadYKpD9+7asrHU21vauOUCAuUyAuw52iFdnIkszMChQG/9vF/nRfha3My6e5FxviqL8NwVblW+Mt/S6NjMkZTY7FyJ5lfo/DEwcZg0oWePstulswdEaRfsFw+kK5IX3q2kJycx4zp7gGZLB2iaNDmp0BnHnKAVvTID5gDm2TYHOhk8Gavqnp51Vp9fkQ6S4WBa+vl46fTp0vhKJPUOhKR36CkfQu3j5dOny+NwuHHfpiKH5XM6KXJFtkm6KKd6ZAtN3xFgZuMBPRNjvpqopfV31coGzov1Mz+HONKhn+HRd4AcQSB5Dww0aCWJje6yFWVwQg6AVqFx93QDO477Hsf8m7EGMdHG0wxGHXpYRS+LscWK+Y2XoMOKaqbzoSjQzIeTTZteltZgGqT4Y4SECPkRzDlPVDIkTZwnphTncSz/9saQkBT4rTFnQNNsdwtJeKJzsQebzElX1yqL2exD2OdXO9o2zmG34WAVOSpNfIAEQU2OQvE8kW7FVAbxfTIhfZsp1R4abUNCo36ZjoNVZRIda5CO6Fu1tiNdxhX+FyXYf3Z4nGNgZGBgAOJNb47Mjue3+crAzfwCKBDF+XhfA4JmYGB+CRJn4GBgAvEAeqIMgAB4nGNgZGBgfsHAACH//2d+ycDIgApcAXBnBQgAeJxjYGBgYH4xdDA9AADYnCd6AAB4nGNgAIIZDBcYnjE6MEYxLmF8xaTBFMVUw9THdIPpEzMHswzzBhYNlgKWLpYrrEGsOayT2GTYlrE9Ymdgl2K3YI9hf8PhxrGBM4xzDhcTlxpXAFcKVxlXF9cMbh7SIQDoHxaseJxjYGRgYHBlSGfgYQABJiDmAkIGhv9gPgMAGrQBzwB4nHWPP07DMBjFX2haRIsQEhJiwxMLUvpnYOjYodk7dGBzGydtlcSR41bqxjE4Acdg5AicgkPwEr6hQqotOT///N4nBcAtvhCgWQGu27NZF7jk7Y87pDvhkPwo3MUAz8I9+hfhPu1MeMBmwQlBeEXzgDfhC9zgXbhD/yEckj+Fu7jHt3CP/ke4j2UQCg/wFLzqLHbbZKbzjS4WJtvn2p2qU14aV29tqcbR6FTHpjROe5Oo1VHVh2zifapSZws1t6U3eW5V5ezOrH208b6aDoep+GhtC2hkiOGwRcI/18ix4VlgAcOXPe+ar+dS5/ySbYea3qKEwhgRRmfTMdNl29Dw/CZsrHDkWePAzoTWI+U9ZcayoTBvJzfpnNvSVO3bjmZNH3F206owxZA7/ZePmOKkX1qXaMkAAAB4nG2R6W7bMBCE/cWSrThp47ptet/3obbpfadX+h40RclEJFIgKR95+hJ1ESBA9w9nBsvZWbK30VvXqPf/OmCDPgkpA4ZkbDJii21OcZodxpxhwlnOcZ5dLnCRS1zmCle5xnVucJNb3OYOd7nHfR7wkEc85glPyXnGc16wx0te8Zo3vOUd7/nARz7xmS98ZZ9vfOcHP/nFAb97W6KqnKpE0NYMhHN24fvCy4EURqo6lTPhwljOlDyc2mX+F6hi91jQplBBuUYbEdTkWO7Mv85taWvr8lZH4oaRdI3xI2lNcEIGVSTStqtUOut9UigvM7VsRfQsNtVK5b4WftaPaFDqOo5JS+18SCqn27RytmuT2BCSWpVhUGsT52XrI98b1lYU2lRZI5a60UcqaZTpshh0zYw1asvYkIu6tgtVpG10Uv1Wm7TVcxvGLl63+bQLwZrcluXOScGkTlezkHgxVyPfRJe8sAuTrWFMFuLKk+CUOvlGWWfWERFUOBQBjcWwwCOpmXHIlGX8zYKGjpYVJUfMe70/6zKeWwA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-balham .ag-icon {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-balham .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-balham .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-balham .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-balham .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-balham .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-balham .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-balham .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-balham .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-balham .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-balham .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-balham .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-balham .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-balham .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-balham .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-balham .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-balham .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-balham .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-balham .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-balham .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-balham .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-balham .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-balham .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-balham .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-balham .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-balham .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-balham .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-balham .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-balham .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-balham .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-balham .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-balham .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-balham .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-balham .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-balham .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-balham .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-balham .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-balham .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-balham .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-balham .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-balham .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-balham .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-balham .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-balham .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-balham .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-balham .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-balham .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-balham .ag-root-wrapper {\n background-color: white;\n background-color: var(--ag-background-color, white); }\n .ag-theme-balham [class^='ag-'], .ag-theme-balham [class^='ag-']:focus, .ag-theme-balham [class^='ag-']:after, .ag-theme-balham [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-balham [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-balham .ag-checkbox .ag-input-wrapper,\n .ag-theme-balham .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-balham .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-balham .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-balham .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px; }\n .ag-theme-balham .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px; }\n .ag-theme-balham input[class^='ag-'] {\n margin: 0;\n background-color: white;\n background-color: var(--ag-background-color, white); }\n .ag-theme-balham textarea[class^='ag-'],\n .ag-theme-balham select[class^='ag-'] {\n background-color: white;\n background-color: var(--ag-background-color, white); }\n .ag-theme-balham input[class^='ag-']:not([type]),\n .ag-theme-balham input[class^='ag-'][type='text'],\n .ag-theme-balham input[class^='ag-'][type='number'],\n .ag-theme-balham input[class^='ag-'][type='tel'],\n .ag-theme-balham input[class^='ag-'][type='date'],\n .ag-theme-balham input[class^='ag-'][type='datetime-local'],\n .ag-theme-balham textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #95a5a6;\n border-color: var(--ag-input-border-color, #95a5a6); }\n .ag-theme-balham input[class^='ag-']:not([type]):disabled,\n .ag-theme-balham input[class^='ag-'][type='text']:disabled,\n .ag-theme-balham input[class^='ag-'][type='number']:disabled,\n .ag-theme-balham input[class^='ag-'][type='tel']:disabled,\n .ag-theme-balham input[class^='ag-'][type='date']:disabled,\n .ag-theme-balham input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-balham textarea[class^='ag-']:disabled {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n background-color: #ebebeb;\n background-color: var(--ag-input-disabled-background-color, #ebebeb);\n border-color: rgba(149, 165, 166, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(149, 165, 166, 0.3)); }\n .ag-theme-balham input[class^='ag-']:not([type]):focus,\n .ag-theme-balham input[class^='ag-'][type='text']:focus,\n .ag-theme-balham input[class^='ag-'][type='number']:focus,\n .ag-theme-balham input[class^='ag-'][type='tel']:focus,\n .ag-theme-balham input[class^='ag-'][type='date']:focus,\n .ag-theme-balham input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-balham textarea[class^='ag-']:focus {\n outline: none;\n box-shadow: 0 0 2px 1px #719ECE;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-balham input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-balham input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-balham input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-balham input[class^='ag-'][type='button']:focus, .ag-theme-balham button[class^='ag-']:focus {\n box-shadow: 0 0 2px 1px #719ECE; }\n .ag-theme-balham .ag-drag-handle {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-list-item, .ag-theme-balham .ag-virtual-list-item {\n height: 28px; }\n .ag-theme-balham .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-select-list {\n background-color: white;\n background-color: var(--ag-background-color, white);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-balham .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-balham .ag-list-item.ag-active-item {\n background-color: #ecf0f1;\n background-color: var(--ag-row-hover-color, #ecf0f1); }\n .ag-theme-balham .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-balham .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-balham .ag-select .ag-picker-field-wrapper {\n background-color: white;\n background-color: var(--ag-background-color, white);\n min-height: 28px;\n cursor: default; }\n .ag-theme-balham .ag-select:not(.ag-cell-editor) {\n height: 28px; }\n .ag-theme-balham .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-balham .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-balham .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-balham .ag-rich-select {\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7); }\n .ag-theme-balham .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 182px; }\n .ag-theme-balham .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 28px;\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7)); }\n .ag-theme-balham .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 28px; }\n .ag-theme-balham .ag-rich-select-virtual-list-item:hover {\n background-color: #ecf0f1;\n background-color: var(--ag-row-hover-color, #ecf0f1); }\n .ag-theme-balham .ag-rich-select-row {\n padding-left: 12px; }\n .ag-theme-balham .ag-rich-select-row-selected {\n background-color: #b7e4ff;\n background-color: var(--ag-selected-row-background-color, #b7e4ff); }\n .ag-theme-balham .ag-row-drag,\n .ag-theme-balham .ag-selection-checkbox,\n .ag-theme-balham .ag-group-expanded,\n .ag-theme-balham .ag-group-contracted {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-ltr .ag-row-drag, .ag-theme-balham .ag-ltr .ag-selection-checkbox, .ag-theme-balham .ag-ltr .ag-group-expanded, .ag-theme-balham .ag-ltr .ag-group-contracted {\n margin-right: 12px; }\n .ag-theme-balham .ag-rtl .ag-row-drag, .ag-theme-balham .ag-rtl .ag-selection-checkbox, .ag-theme-balham .ag-rtl .ag-group-expanded, .ag-theme-balham .ag-rtl .ag-group-contracted {\n margin-left: 12px; }\n .ag-theme-balham .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 26px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-balham .ag-group-expanded,\n .ag-theme-balham .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-balham .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-balham .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-balham .ag-group-title-bar {\n background-color: #e2e9eb;\n background-color: var(--ag-subheader-background-color, #e2e9eb);\n padding: 4px; }\n .ag-theme-balham .ag-group-toolbar {\n padding: 4px; }\n .ag-theme-balham .ag-disabled-group-title-bar, .ag-theme-balham .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-balham .group-item {\n margin: 2px 0; }\n .ag-theme-balham .ag-label {\n white-space: nowrap; }\n .ag-theme-balham .ag-ltr .ag-label {\n margin-right: 4px; }\n .ag-theme-balham .ag-rtl .ag-label {\n margin-left: 4px; }\n .ag-theme-balham .ag-label-align-top .ag-label {\n margin-bottom: 2px; }\n .ag-theme-balham .ag-ltr .ag-slider-field, .ag-theme-balham .ag-ltr .ag-angle-select-field {\n margin-right: 8px; }\n .ag-theme-balham .ag-rtl .ag-slider-field, .ag-theme-balham .ag-rtl .ag-angle-select-field {\n margin-left: 8px; }\n .ag-theme-balham .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background-color: white;\n background-color: var(--ag-background-color, white); }\n .ag-theme-balham .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: rgba(0, 0, 0, 0.54);\n background-color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n border-radius: 5px; }\n .ag-theme-balham .ag-picker-field-wrapper:focus {\n box-shadow: 0 0 2px 1px #719ECE; }\n .ag-theme-balham .ag-picker-field-button {\n background-color: white;\n background-color: var(--ag-background-color, white);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-balham .ag-color-picker .ag-picker-field-display {\n height: 16px; }\n .ag-theme-balham .ag-color-panel {\n padding: 4px; }\n .ag-theme-balham .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-balham .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-balham .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-balham .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-balham .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-balham .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-balham .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-balham .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-balham .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-balham .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-balham .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-balham .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-balham.ag-dnd-ghost {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7));\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 32px !important;\n line-height: 32px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px); }\n .ag-theme-balham .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #000;\n color: var(--ag-foreground-color, #000); }\n .ag-theme-balham .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3); }\n .ag-dragging-range-handle .ag-theme-balham .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-balham .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-balham .ag-dialog {\n border-radius: 2px;\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-panel {\n background-color: white;\n background-color: var(--ag-background-color, white); }\n .ag-theme-balham .ag-panel-title-bar {\n background-color: #f5f7f7;\n background-color: var(--ag-header-background-color, #f5f7f7);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)));\n height: 32px;\n padding: 4px 12px;\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px; }\n .ag-theme-balham .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px; }\n .ag-theme-balham .ag-tooltip {\n background-color: #f5f7f7;\n background-color: var(--ag-header-background-color, #f5f7f7);\n color: #000;\n color: var(--ag-foreground-color, #000);\n padding: 4px;\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n border-radius: 2px;\n transition: opacity 1s; }\n .ag-theme-balham .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-1 {\n padding-left: 20px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-1 {\n padding-right: 20px; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-2 {\n padding-left: 40px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-2 {\n padding-right: 40px; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-3 {\n padding-left: 60px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-3 {\n padding-right: 60px; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-4 {\n padding-left: 80px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-4 {\n padding-right: 80px; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-5 {\n padding-left: 100px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-5 {\n padding-right: 100px; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-6 {\n padding-left: 120px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-6 {\n padding-right: 120px; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-7 {\n padding-left: 140px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-7 {\n padding-right: 140px; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-8 {\n padding-left: 160px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-8 {\n padding-right: 160px; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-9 {\n padding-left: 180px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-9 {\n padding-right: 180px; }\n .ag-theme-balham .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-balham .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 6px; }\n .ag-theme-balham .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 6px; }\n .ag-theme-balham .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-column-select-column-group:not(:last-child),\n .ag-theme-balham .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px; }\n .ag-theme-balham .ag-column-select-column-readonly,\n .ag-theme-balham .ag-column-select-column-group-readonly {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n pointer-events: none; }\n .ag-theme-balham .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 24px; }\n .ag-theme-balham .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 24px; }\n .ag-theme-balham .ag-column-select-list {\n padding: 6px 6px; }\n .ag-theme-balham .ag-rtl {\n text-align: right; }\n .ag-theme-balham .ag-root-wrapper {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n border-radius: 2px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 40px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 40px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-1 {\n padding-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-1 {\n padding-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 68px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 68px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-2 {\n padding-left: 56px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-2 {\n padding-right: 56px; }\n .ag-theme-balham .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 96px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 96px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-3 {\n padding-left: 84px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-3 {\n padding-right: 84px; }\n .ag-theme-balham .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 124px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 124px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-4 {\n padding-left: 112px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-4 {\n padding-right: 112px; }\n .ag-theme-balham .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 152px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 152px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-5 {\n padding-left: 140px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-5 {\n padding-right: 140px; }\n .ag-theme-balham .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 180px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 180px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-6 {\n padding-left: 168px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-6 {\n padding-right: 168px; }\n .ag-theme-balham .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 208px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 208px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-7 {\n padding-left: 196px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-7 {\n padding-right: 196px; }\n .ag-theme-balham .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 236px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 236px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-8 {\n padding-left: 224px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-8 {\n padding-right: 224px; }\n .ag-theme-balham .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 264px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 264px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-9 {\n padding-left: 252px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-9 {\n padding-right: 252px; }\n .ag-theme-balham .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 292px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 292px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-10 {\n padding-left: 280px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-10 {\n padding-right: 280px; }\n .ag-theme-balham .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 320px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 320px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-11 {\n padding-left: 308px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-11 {\n padding-right: 308px; }\n .ag-theme-balham .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 348px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 348px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-12 {\n padding-left: 336px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-12 {\n padding-right: 336px; }\n .ag-theme-balham .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 376px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 376px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-13 {\n padding-left: 364px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-13 {\n padding-right: 364px; }\n .ag-theme-balham .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 404px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 404px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-14 {\n padding-left: 392px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-14 {\n padding-right: 392px; }\n .ag-theme-balham .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 432px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 432px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-15 {\n padding-left: 420px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-15 {\n padding-right: 420px; }\n .ag-theme-balham .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 460px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 460px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-16 {\n padding-left: 448px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-16 {\n padding-right: 448px; }\n .ag-theme-balham .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 488px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 488px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-17 {\n padding-left: 476px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-17 {\n padding-right: 476px; }\n .ag-theme-balham .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 516px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 516px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-18 {\n padding-left: 504px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-18 {\n padding-right: 504px; }\n .ag-theme-balham .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 544px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 544px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-19 {\n padding-left: 532px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-19 {\n padding-right: 532px; }\n .ag-theme-balham .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-balham .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-balham .ag-value-change-delta-up {\n color: #43a047;\n color: var(--ag-value-change-delta-up-color, #43a047); }\n .ag-theme-balham .ag-value-change-delta-down {\n color: #e53935;\n color: var(--ag-value-change-delta-down-color, #e53935); }\n .ag-theme-balham .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-balham .ag-value-change-value-highlight {\n background-color: rgba(22, 160, 133, 0.5);\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5));\n transition: background-color 0.1s; }\n .ag-theme-balham .ag-cell-data-changed {\n background-color: rgba(22, 160, 133, 0.5) !important;\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5)) !important; }\n .ag-theme-balham .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-balham .ag-cell-highlight {\n background-color: #0091ea !important;\n background-color: var(--ag-range-selection-highlight-color, var(--ag-balham-active-color, #0091ea)) !important; }\n .ag-theme-balham .ag-row {\n height: 28px;\n background-color: white;\n background-color: var(--ag-background-color, white);\n color: #000;\n color: var(--ag-data-color, var(--ag-foreground-color, #000));\n border-width: 1px;\n border-color: #d9dcde;\n border-color: var(--ag-row-border-color, #d9dcde); }\n .ag-theme-balham .ag-row:not(.ag-row-first) {\n border-top-style: solid; }\n .ag-theme-balham .ag-row.ag-row-last {\n border-bottom-style: solid; }\n .ag-theme-balham .ag-row-highlight-above::after, .ag-theme-balham .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #0091ea;\n background-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n left: 1px; }\n .ag-theme-balham .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-balham .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-balham .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-balham .ag-row-odd {\n background-color: #fcfdfe;\n background-color: var(--ag-odd-row-background-color, #fcfdfe); }\n .ag-theme-balham .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-row-hover {\n background-color: #ecf0f1;\n background-color: var(--ag-row-hover-color, #ecf0f1); }\n .ag-theme-balham .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-balham .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-balham .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-balham .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-balham .ag-cell {\n border: 1px solid transparent;\n line-height: 26px;\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-balham .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-balham .ag-row-dragging {\n cursor: move; }\n .ag-theme-balham .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-balham .ag-cell-inline-editing {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 28px;\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7); }\n .ag-theme-balham .ag-popup-editor {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7);\n padding: 0; }\n .ag-theme-balham .ag-large-text-input {\n height: auto;\n padding: 12px; }\n .ag-theme-balham .ag-details-row {\n padding: 20px;\n background-color: white;\n background-color: var(--ag-background-color, white); }\n .ag-theme-balham .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66)); }\n .ag-theme-balham .ag-overlay-loading-center {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px; }\n .ag-theme-balham .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-balham .ag-loading {\n padding-left: 12px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-balham .ag-loading-icon {\n padding-right: 12px; }\n .ag-theme-balham .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-balham .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-ltr .ag-cell {\n border-right: solid transparent; }\n .ag-theme-balham .ag-rtl .ag-cell {\n border-left: solid transparent; }\n .ag-theme-balham .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-balham .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-balham .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-row-selected {\n background-color: #b7e4ff;\n background-color: var(--ag-selected-row-background-color, #b7e4ff); }\n .ag-theme-balham .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(0, 145, 234, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(0, 145, 234, 0.2)); }\n .ag-theme-balham .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1);\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)); }\n .ag-theme-balham .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)); }\n .ag-theme-balham .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(0, 145, 234, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(0, 145, 234, 0.2))); }\n .ag-theme-balham .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(0, 145, 234, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(0, 145, 234, 0.36)); }\n .ag-theme-balham .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(0, 145, 234, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(0, 145, 234, 0.488)); }\n .ag-theme-balham .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(0, 145, 234, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(0, 145, 234, 0.5904)); }\n .ag-theme-balham .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #0091ea;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #0091ea;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #0091ea;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #0091ea;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-balham .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-balham .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-balham .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-balham .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-balham .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #0091ea;\n border-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n outline: initial; }\n .ag-theme-balham .ag-cell.ag-selection-fill-top,\n .ag-theme-balham .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #0091ea;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-balham .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #0091ea;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-balham .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #0091ea;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-cell.ag-selection-fill-bottom,\n .ag-theme-balham .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #0091ea;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-balham .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #0091ea;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-balham .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #0091ea;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-fill-handle, .ag-theme-balham .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #0091ea;\n background-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-ltr .ag-fill-handle, .ag-theme-balham .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-balham .ag-rtl .ag-fill-handle, .ag-theme-balham .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-balham .ag-fill-handle {\n cursor: cell; }\n .ag-theme-balham .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-balham .ag-cell-inline-editing {\n border-color: #719ECE !important;\n border-color: var(--ag-input-focus-border-color, #719ECE) !important; }\n .ag-theme-balham .ag-menu {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n padding: 0; }\n .ag-theme-balham .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-balham .ag-menu-option-part {\n padding-top: 6px;\n padding-bottom: 6px;\n line-height: 16px; }\n .ag-theme-balham .ag-menu-option-active {\n background-color: #ecf0f1;\n background-color: var(--ag-row-hover-color, #ecf0f1); }\n .ag-theme-balham .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-balham .ag-menu-option-text {\n margin-left: 4px; }\n .ag-theme-balham .ag-menu-option-icon {\n padding-left: 8px;\n padding-right: 4px;\n min-width: 24px; }\n .ag-theme-balham .ag-menu-option-shortcut {\n padding-left: 8px; }\n .ag-theme-balham .ag-menu-separator {\n height: 8px; }\n .ag-theme-balham .ag-menu-separator-cell:after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-menu-option-popup-pointer {\n width: 24px;\n text-align: center; }\n .ag-theme-balham .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-balham .ag-tab {\n border-bottom: 0 solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer; }\n .ag-theme-balham .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-tab-selected {\n border-bottom-color: #0091ea;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea))); }\n .ag-theme-balham .ag-menu-header {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-balham .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px; }\n .ag-theme-balham .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px; }\n .ag-theme-balham .ag-set-filter-select-all {\n padding-top: 6px; }\n .ag-theme-balham .ag-set-filter-list {\n height: 168px; }\n .ag-theme-balham .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px; }\n .ag-theme-balham .ag-filter-to {\n margin-top: 4px; }\n .ag-theme-balham .ag-mini-filter {\n margin: 6px 6px;\n margin-bottom: 0; }\n .ag-theme-balham .ag-set-filter-item {\n margin: 0px 6px; }\n .ag-theme-balham .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px; }\n .ag-theme-balham .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px; }\n .ag-theme-balham .ag-filter-header-container {\n padding-bottom: 6px;\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7)); }\n .ag-theme-balham .ag-filter-apply-panel {\n padding: 6px 6px;\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7)); }\n .ag-theme-balham .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-balham .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px; }\n .ag-theme-balham .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px; }\n .ag-theme-balham .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-balham .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px; }\n .ag-theme-balham .ag-filter-no-matches {\n margin: 6px 6px; }\n .ag-theme-balham .ag-side-bar {\n position: relative; }\n .ag-theme-balham .ag-tool-panel-wrapper {\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7); }\n .ag-theme-balham .ag-side-buttons {\n padding-top: 16px;\n width: 20px;\n position: relative;\n color: #000;\n color: var(--ag-foreground-color, #000);\n overflow: hidden; }\n .ag-theme-balham button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: calc(100% + 1px);\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-selected .ag-side-button-button {\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7);\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-balham .ag-ltr .ag-side-bar-left,\n .ag-theme-balham .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-balham .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-balham .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent;\n margin-right: -1px;\n padding-right: 1px; }\n .ag-theme-balham .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-balham .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #0091ea;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea))); }\n .ag-theme-balham .ag-rtl .ag-side-bar-left,\n .ag-theme-balham .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-balham .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-balham .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent;\n margin-left: -1px;\n padding-left: 1px; }\n .ag-theme-balham .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-balham .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #0091ea;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea))); }\n .ag-theme-balham .ag-filter-toolpanel-header {\n height: 24px; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-header, .ag-theme-balham .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-header, .ag-theme-balham .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px; }\n .ag-theme-balham .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 4px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 4px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-0-header {\n height: 32px; }\n .ag-theme-balham .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px; }\n .ag-theme-balham .ag-filter-toolpanel-search {\n height: 32px; }\n .ag-theme-balham .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 16px; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7)); }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px; }\n .ag-theme-balham .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px; }\n .ag-theme-balham .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7);\n padding-top: 4px; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px; }\n .ag-theme-balham .ag-pivot-mode-panel {\n height: 32px;\n display: flex; }\n .ag-theme-balham .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-balham .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px; }\n .ag-theme-balham .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px; }\n .ag-theme-balham .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-column-select-header {\n height: 32px;\n align-items: center;\n padding: 0 6px;\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7)); }\n .ag-theme-balham .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7));\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7)); }\n .ag-theme-balham .ag-column-group-icons,\n .ag-theme-balham .ag-column-select-header-icon {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-header {\n background-color: #f5f7f7;\n background-color: var(--ag-header-background-color, #f5f7f7);\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-header-row {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54))); }\n .ag-theme-balham .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-header-row {\n height: 32px; }\n .ag-theme-balham .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-balham .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-balham .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-balham .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-balham .ag-header-cell,\n .ag-theme-balham .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px; }\n .ag-theme-balham .ag-header-cell.ag-header-cell-moving,\n .ag-theme-balham .ag-header-group-cell.ag-header-cell-moving {\n background-color: white;\n background-color: var(--ag-header-cell-moving-background-color, var(--ag-background-color, white)); }\n .ag-theme-balham .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-header-icon {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-balham .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-balham .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-balham .ag-header-row:not(:first-child) .ag-header-cell,\n .ag-theme-balham .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-header-cell::after,\n .ag-theme-balham .ag-header-group-cell::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n width: 1px;\n height: 50%;\n top: calc(50% - 25%);\n background-color: rgba(189, 195, 199, 0.5);\n background-color: var(--ag-header-column-separator-color, rgba(189, 195, 199, 0.5)); }\n .ag-theme-balham .ag-ltr .ag-header-cell::after, .ag-theme-balham .ag-ltr .ag-header-group-cell::after {\n right: 0; }\n .ag-theme-balham .ag-rtl .ag-header-cell::after, .ag-theme-balham .ag-rtl .ag-header-group-cell::after {\n left: 0; }\n .ag-theme-balham .ag-ltr .ag-header-select-all {\n margin-right: 12px; }\n .ag-theme-balham .ag-rtl .ag-header-select-all {\n margin-left: 12px; }\n .ag-theme-balham .ag-ltr .ag-floating-filter-button {\n margin-left: 12px; }\n .ag-theme-balham .ag-rtl .ag-floating-filter-button {\n margin-right: 12px; }\n .ag-theme-balham .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 16px;\n padding: 0;\n width: 16px; }\n .ag-theme-balham .ag-filter-loading {\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-balham .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 32px; }\n .ag-theme-balham .ag-paging-panel > * {\n margin: 0 12px; }\n .ag-theme-balham .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 16px; }\n .ag-theme-balham .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-balham .ag-paging-button-wrapper.ag-disabled {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n cursor: default; }\n .ag-theme-balham .ag-paging-button-wrapper, .ag-theme-balham .ag-paging-description {\n margin: 0 4px; }\n .ag-theme-balham .ag-status-bar {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5; }\n .ag-theme-balham .ag-status-name-value-value {\n color: #000;\n color: var(--ag-foreground-color, #000); }\n .ag-theme-balham .ag-status-bar-center {\n text-align: center; }\n .ag-theme-balham .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px; }\n .ag-theme-balham .ag-column-drop-cell {\n background: #dddede;\n background: var(--ag-chip-background-color, #dddede);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px; }\n .ag-theme-balham .ag-column-drop-cell-text {\n margin: 0 4px; }\n .ag-theme-balham .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-column-drop-cell-drag-handle {\n margin-left: 8px; }\n .ag-theme-balham .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-balham .ag-column-drop-horizontal {\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 28px;\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px; }\n .ag-theme-balham .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px; }\n .ag-theme-balham .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-column-drop-horizontal-empty-message {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-balham .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px; }\n .ag-theme-balham .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px; }\n .ag-theme-balham .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px; }\n .ag-theme-balham .ag-column-drop-vertical-cell {\n margin-top: 4px; }\n .ag-theme-balham .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px;\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7)); }\n .ag-theme-balham .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none; }\n .ag-theme-balham .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px; }\n .ag-theme-balham .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-balham .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n margin-top: 4px; }\n .ag-theme-balham .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n background: white;\n background: var(--ag-background-color, white);\n height: 70px;\n padding: 0; }\n .ag-theme-balham .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 20px;\n padding-left: 8px; }\n .ag-theme-balham .ag-select-agg-func-virtual-list-item:hover {\n background-color: #b7e4ff;\n background-color: var(--ag-selected-row-background-color, #b7e4ff); }\n .ag-theme-balham .ag-chart-menu {\n border-radius: 2px;\n background: white;\n background: var(--ag-background-color, white); }\n .ag-theme-balham .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 2px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-balham .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: #bdc3c7;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7));\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-balham .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-balham .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-balham .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-balham .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-balham .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-balham .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-balham .ag-chart-mini-thumbnail.ag-selected {\n border-color: #0091ea;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea))); }\n .ag-theme-balham .ag-chart-settings-card-item {\n background: #000;\n background: var(--ag-foreground-color, #000);\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-balham .ag-chart-settings-card-item.ag-selected {\n background-color: #0091ea;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea))); }\n .ag-theme-balham .ag-chart-data-column-drag-handle {\n margin-left: 4px; }\n .ag-theme-balham .ag-charts-settings-group-title-bar,\n .ag-theme-balham .ag-charts-data-group-title-bar,\n .ag-theme-balham .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7)); }\n .ag-theme-balham .ag-charts-settings-group-container {\n padding: 4px; }\n .ag-theme-balham .ag-charts-data-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-balham .ag-charts-data-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-balham .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px; }\n .ag-theme-balham .ag-charts-format-top-level-group-item {\n margin: 4px 0; }\n .ag-theme-balham .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-balham .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-balham .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px; }\n .ag-theme-balham .ag-chart-data-section,\n .ag-theme-balham .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-balham .ag-chart-menu-panel {\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7); }\n .ag-theme-balham .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-balham .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-balham .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-balham .ag-checkbox-input-wrapper {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: white;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, white));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-balham .ag-checkbox-input-wrapper input, .ag-theme-balham .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-balham .ag-checkbox-input-wrapper:focus-within, .ag-theme-balham .ag-checkbox-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 2px 1px #719ECE; }\n .ag-theme-balham .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-balham .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #7f8c8d;\n color: var(--ag-checkbox-unchecked-color, #7f8c8d);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #0091ea;\n color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #7f8c8d;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, #7f8c8d));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 32px;\n height: 16px;\n background-color: #7f8c8d;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, #7f8c8d));\n border-radius: 8px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #7f8c8d;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #7f8c8d)); }\n .ag-theme-balham .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-balham .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n box-shadow: 0 0 2px 1px #719ECE; }\n .ag-theme-balham .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-balham .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #0091ea;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea)));\n border-color: #0091ea;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea))); }\n .ag-theme-balham .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 16px;\n width: 16px;\n background-color: white;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, white));\n border-radius: 8px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #7f8c8d;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #7f8c8d))); }\n .ag-theme-balham .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 16px);\n border-color: #0091ea;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea))); }\n .ag-theme-balham .ag-radio-button-input-wrapper {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: white;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, white));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 16px; }\n .ag-theme-balham .ag-radio-button-input-wrapper input, .ag-theme-balham .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-balham .ag-radio-button-input-wrapper:focus-within, .ag-theme-balham .ag-radio-button-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 2px 1px #719ECE; }\n .ag-theme-balham .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-balham .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #7f8c8d;\n color: var(--ag-checkbox-unchecked-color, #7f8c8d);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #0091ea;\n color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-balham input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #bdc3c7;\n background-color: var(--ag-border-color, #bdc3c7);\n border-radius: 2px;\n border-radius: 3px; }\n .ag-theme-balham input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #bdc3c7;\n background-color: var(--ag-border-color, #bdc3c7);\n border-radius: 2px;\n border-radius: 3px; }\n .ag-theme-balham input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #bdc3c7;\n background-color: var(--ag-border-color, #bdc3c7);\n border-radius: 2px;\n border-radius: 3px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-balham input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: white;\n background-color: var(--ag-background-color, white);\n border: 1px solid;\n border-color: #7f8c8d;\n border-color: var(--ag-checkbox-unchecked-color, #7f8c8d);\n border-radius: 16px;\n -webkit-transform: translateY(-6.5px);\n transform: translateY(-6.5px); }\n .ag-theme-balham input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: white;\n background-color: var(--ag-background-color, white);\n border: 1px solid;\n border-color: #7f8c8d;\n border-color: var(--ag-checkbox-unchecked-color, #7f8c8d);\n border-radius: 16px; }\n .ag-theme-balham input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: white;\n background-color: var(--ag-background-color, white);\n border: 1px solid;\n border-color: #7f8c8d;\n border-color: var(--ag-checkbox-unchecked-color, #7f8c8d);\n border-radius: 16px; }\n .ag-theme-balham input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-balham input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n box-shadow: 0 0 2px 1px #719ECE;\n border-color: #0091ea;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham input[class^='ag-'][type='range']:focus::-ms-thumb {\n box-shadow: 0 0 2px 1px #719ECE;\n border-color: #0091ea;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n box-shadow: 0 0 2px 1px #719ECE;\n border-color: #0091ea;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham input[class^='ag-'][type='range']:active::-ms-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-balham .ag-filter-toolpanel-header,\n .ag-theme-balham .ag-filter-toolpanel-search,\n .ag-theme-balham .ag-status-bar,\n .ag-theme-balham .ag-header-row {\n font-weight: 600;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54))); }\n .ag-theme-balham .ag-ltr input[class^='ag-']:not([type]),\n .ag-theme-balham .ag-ltr input[class^='ag-'][type='text'],\n .ag-theme-balham .ag-ltr input[class^='ag-'][type='number'],\n .ag-theme-balham .ag-ltr input[class^='ag-'][type='tel'],\n .ag-theme-balham .ag-ltr input[class^='ag-'][type='date'],\n .ag-theme-balham .ag-ltr input[class^='ag-'][type='datetime-local'],\n .ag-theme-balham .ag-ltr textarea[class^='ag-'] {\n padding-left: 4px; }\n .ag-theme-balham .ag-rtl input[class^='ag-']:not([type]),\n .ag-theme-balham .ag-rtl input[class^='ag-'][type='text'],\n .ag-theme-balham .ag-rtl input[class^='ag-'][type='number'],\n .ag-theme-balham .ag-rtl input[class^='ag-'][type='tel'],\n .ag-theme-balham .ag-rtl input[class^='ag-'][type='date'],\n .ag-theme-balham .ag-rtl input[class^='ag-'][type='datetime-local'],\n .ag-theme-balham .ag-rtl textarea[class^='ag-'] {\n padding-right: 4px; }\n .ag-theme-balham .ag-column-drop-vertical-empty-message, .ag-theme-balham .ag-status-bar {\n font-weight: 600;\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-balham .ag-dnd-ghost {\n font-weight: 600; }\n .ag-theme-balham .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px; }\n .ag-theme-balham .ag-tab-selected {\n background-color: white;\n background-color: var(--ag-background-color, white);\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n border-bottom-color: transparent; }\n .ag-theme-balham .ag-tabs-header {\n border-bottom: 1px solid;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-column-drop-cell {\n height: 24px; }\n .ag-theme-balham .ag-column-drop-vertical-title {\n color: #000;\n color: var(--ag-foreground-color, #000); }\n .ag-theme-balham .ag-column-drop-vertical-cell {\n margin-left: 8px;\n margin-right: 8px; }\n .ag-theme-balham .ag-column-drop-vertical-cell-text {\n margin-left: 8px; }\n .ag-theme-balham .ag-column-drop-vertical-icon {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-ltr .ag-column-drop-vertical-empty-message {\n padding-left: 24px;\n padding-right: 4px; }\n .ag-theme-balham .ag-rtl .ag-column-drop-vertical-empty-message {\n padding-right: 24px;\n padding-left: 4px; }\n .ag-theme-balham .ag-column-drop-horizontal {\n height: 32px; }\n .ag-theme-balham .ag-column-drop-empty {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-balham .ag-column-drop-horizontal-cell-text {\n margin-left: 8px; }\n .ag-theme-balham .ag-column-drop-vertical {\n padding-top: 8px; }\n .ag-theme-balham .ag-menu-header {\n background-color: #f5f7f7;\n background-color: var(--ag-header-background-color, #f5f7f7); }\n .ag-theme-balham .ag-overlay-loading-center {\n background-color: white;\n background-color: var(--ag-background-color, white);\n border: 1px solid;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n color: #000;\n color: var(--ag-foreground-color, #000);\n padding: 16px; }\n .ag-theme-balham .ag-tooltip {\n border: none;\n background-color: #cbd0d3; }\n .ag-theme-balham .ag-panel-title-bar-button-icon {\n font-size: 20px; }\n .ag-theme-balham .ag-chart-data-section,\n .ag-theme-balham .ag-chart-format-section {\n padding-bottom: 2px; }\n .ag-theme-balham .ag-group-toolbar {\n background-color: rgba(226, 233, 235, 0.5);\n background-color: var(--ag-subheader-toolbar-background-color, rgba(226, 233, 235, 0.5)); }\n .ag-theme-balham .ag-chart-tab {\n padding-top: 2px; }\n .ag-theme-balham .ag-charts-format-sub-level-group-item {\n margin-bottom: 6px; }\n\n", ""]); +exports.push([module.i, ".ag-theme-balham {\n -webkit-font-smoothing: antialiased;\n color: #000;\n color: var(--ag-foreground-color, #000);\n font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n font-size: 12px;\n line-height: normal;\n}\n@font-face {\n font-family: \"agGridBalham\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABgoAAsAAAAALEgAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAmMAAAR2YfRkQU9TLzIAAANsAAAAQQAAAFZWUFLwY21hcAAAA7AAAAIMAAAFnGSNxkJnbHlmAAAFvAAADpIAABo4y6JNTGhlYWQAABRQAAAANAAAADZ2zcSBaGhlYQAAFIQAAAAaAAAAJAfQBDFobXR4AAAUoAAAABoAAAEgs7L//WxvY2EAABS8AAAAawAAAJJHu0GKbWF4cAAAFSgAAAAfAAAAIAFeAKpuYW1lAAAVSAAAATUAAAJG0OP3eXBvc3QAABaAAAABqAAAAm9qOX49eJx9lM1SE1EQhc8wAYFEoDQqRkRQ/IvKMD8Zk/CTkJBoWS5cWJYLN1hWWVZRrngOH8AnYOkT+AAufAIfwIVL15ZfdwaDLMitTO50n+4+fW7fKJA0qw3taGJv+Pyl5g72Dz+qppJGH/Of3AcHH97va/r4DV/Jf6cVlCqa00291qG+BXPBYXA0UQ1r4avwXfg5/BL+UghqReugy1TcUKyEZ6RUmRrKNaEpbDH7x2qCDnm23HpBVzXpnp76WqRmTEzfM9b1THe0QJ6u5+loG1TKspwdnkPWXc2fgch1j/wZbDaxllBkmf2WqprRHiw7MGkT38R/kZo71I6I6uLrwm4SS4t9W5fgZBElV/Wp3ugRfuvUsmRFTMo31q6/R/5WZh2jWuRpUMty12FwbG9QNSHiIdkzUFuFonVUL+NNwUTEtl1Biy6DTOCWapWd9ZnAtaI1MC/01qvuFjEd13SkQB32Y3vX8+V0ftLaJtcQ7AM4jK12PvepFWngXS2COdAnHemrvuuHfuq3/uicLlMn8R62yb5zpjbTKHga3cPb+me1XqeYgdOo/xEzdN5wdWJ8/UJDq1amM1MnZR9hTR0/C0/D92CTcx4lakRe1056krXJewz6fDGdTVbFle4zBfM+wQOfhRoTlui6ZxzNYY7WS2S03YhfzXVrku+an5upazdswd/sLth51zj/ZX4jOsxcpyd4V7BYprHlhkflsLcc6/hzWI+rGaslWGU+0TZjA78dPSrdop8Rk0S3/WYMfL7WYJAVN7XKGRr7dnFiVxwXe1TAP0FU3PDUtbOZ7sLN5mP4F/iHapMAeJxjYGSqZ5zAwMrAwFTFtIeBgaEHQjM+YDBkZAKKMrAyM2AFAWmuKQwHGHQ/GjG/AHKjmN8wsABpRpAcANz2CuAAAAB4nLXUZ1IbQRCG4VeBKIEDOeNEVkAgssjhh0+BM4UDhTPn8Nl8jz4B/ma7fQBc5al61Duzo9FMrb4F2oCCLEkR8p3kdEUur9FcNl6gOxsv8lv9Mp3kdV3hgiturHF7q9EK51xybbms97flNLvMODOsqbdHjRab7NPglDrbrLLDFge62+SIZTZY4ZAT1tnlmDN9P+2iqD2206Hf7dJOSlqxh17u84A++hlgkCGGGWGUMf3WBJNMMa15j3jME57yTPNmmGWOeRZ0XWJRpyppzwtUtcl27tb27jg/tVprc79xWt/WibcO1po67MbK4cn67vHZPyz2H1o5fRR+Re856Ym6dNrzUJMXoSUvw6a8CvvyOjTkTTiVt6Eu78K2XIRVuQw78j5syYdwIB9D+ld9Ck25CkdyHZblc9iQL2FFvoZD+RZO5HtYlx9hV36GY7kJeoCWcykvlnekWnApX1Z0KWPW5lL2rN2Raocj1U5Hql2OVLtdyqSVHKmWXXqS1uNItdeR6j2n7GBBKcKCsoE9dEoW1ueUMazfKW3YgFPusEGnBGJDTlnEhp1SiY045RMbdUoqNuaUWWzcKb3YhFOOsUmnRGNTLjvvtFPKsaC8Y0HJx4LeAVjQ2wAL2XlnHKnOOlKdc6Q670h1wZHqosvWWXLZ3iqOdL/q0vvVai6bU3cpY7bssjUbjuofQy2jW3ic7VlrkBzVde5ze2d6et7d04+Z2Z33a3deu/OWZnd79EDL7gr0YldCBqQoEnKwVhgpwsJCC7ZwBBI4JlIBdkXxq8qmoCouJ65QlC3ZKeKCpYIWhUAShCs/sBML4mAcq1LljaaVc3t6VlqhAPa/VLLT3ff07XvPPfecc8/57l2GZfCP/Q77HUZlSsx2hoEwUUXWTbieVJFkiE8jjaQlbvWAVZbUMKg9KQ0aIluETDoRt1oStYSsqObPyhk/uVKryLFMtVFvYNt6o57O0F8txgr9a7LQ0wPZNf36T/WfXnmDkP7z1DIAtodUExCGcKJKHA6kp+5a8V/wZGsBfI5o2K04vHa/J5p2qwst/Rj0cLJ7pVu2WsORITEEcJB95nqsIWS8raqnbv/6+j/6VJe1OQzLLrRYj+hUFKdP7FuluPwht+ptzToG5aTkHHL6PEKfPylFE6upqsDQ15fZLzMRhvGpXKahcjHBKDJCzCgaMcEoVGFuPH/yZH4cXEtL/dfm+xvXr1/87jLHIy+yEmPDF3OcBLxxtPDaa4WjGjl1NP/aa/mj+jIqliHbHnYPIzEDTA3bx6k5JGqaMrVDldqBK9N3iX4x7FKnX3zIFzkj/0wDLu7eMl2uVMrTW17pErunJ8ayuVx2bOJZSkAWqelvFb797cK3jCe7Z0lzg9CWNjco/dfdHvhkFmX2s36kOMaBOq0ICXo3KnLi3OzsuwcOvHPvveQu/ZNkvP38woLR/PJlfFxg32F8TIZBNgMQL0JNqGpQiZXDIAuSG9hY3E2pMK3T6NcicID6A7ba/lzplqGhW0qkUw62Z0PlEF7kIaPs17e9UvkKfPpKi5LRg/1mqBRqH8YHXuQL+PgVtix/Be65Vqbcx5eJjeG6+CiJVrZ/TEY+Why9OG64y2X8Q1kuGLIw0B0+EVsUyXI9SapXMaeDHblGCvbC1V9pOXatBKY972N3MRb0WD/D8MCpPLCNCHRig6SU6zXqiOTf9O3NnXobtLm5l77rcAQ8SmlNSfEE4AX4xjB+0P8GRufmNJcr3JsOxEuleCDVF6bse4wxCqzb9BkPw6QSQsVn3kDv51qtH2ja6VarfVbT3iLl9vyVe3Edk5OsBeVEGanfkxP6+/mf/SwPFzulOZebcT35mAQzREfpKnB4UaksRkEkFKyp46c0jm7YXI5hPfnzi7mJXHYiT4vcRPpSul43HnrPiuxEDp7QP5mqzeI3qBgNcvpZfJByPa3/mDaFkXRddxIxN55r1VJX5H6RvEjXCixZtVctRxK9eplZGebyJfZu9heMF2cSYsaZzzF/hr3p8rd0pEcvqNfYRA2EmGpVcTK+lOQmON2eWlUjFTpZyRpPZ4pAp4tuU6axvayo1K3iWF2r1sthtkJti6mhSKgOymFidur0iYCihklDxYBT0qgCJdkDboI6HWSxu8Lu5XbfY9HXZRqNDKlnGmPf01fBMQKsxXue6Nt5MSx5Vclrt7j8MZ+a9Nldth6b5FH7nGpUsRKb2/4XYlwJCS4v77ZxNo9TUByiV+oVxIgi+gWb3cX1WDxh0eqwiKLDJdpHclnCEpvDZiE1wtk9TiupsGAXbeTnts8csZBlmUuvGsIcO3fpOHvfGwFeaD/+j85I2GcTe6MpOV5LS30ZkffYXbJULUdzit9v97g9gQHF40iJDrcjIDhV0S3YrJwvVkz5XLJf9todHtHn4h08y3EWzhf64x+c5h1WO+eyW/jXeY+Nd/PzHt7uFamp/992/3tttzR3m5igQnxm7oabOrkb5joxbYmdJz7Sxg2avKv1SlmJQItQkymy5AHEaGjXeHoQOOoE6Vr1w01T2LqW5yySR/B5R1bY3VaXzeOT10057bwoiT23bunhBaz5MKXOfXaP2+VQvD7/Jz7hES0Wr1MI7f2sRxbdPG998JDVZhU8IvN/ZI5L8gqmPo4HcgKTif4+eMk/0eziBS82sRi55Wm2iZllOXMTM81sw/b1RgXhdwdF08juhkwHOzcMlIZhXnWDBwywTV+tRkKqNkCDFhQJ9ql31juXMlZtpdwCY1Un4hwktt8l3v7M55MuQewNRtOj+Ym1z26cumFjyevjHQ6vN98ayWtDN6mQ3rh+x523K1Jfc2Jk13AeHh5aq0L4wBNfW5toTgzf2czp88HcjbnBTD6YHc8OZsivSiy77pFb++LhbF8sgIxToiSXmpt7i5JfDsujudH8U5Fba2SrNirJYau9Lze8a3iiqf9ddGuNjN89ysbjWDMy0TzfP4gcg/nMYA6LK7n+aTbB9DJFZhg1ZexQTBVZr1YP7jVUN+lqp6MRrtxxlSJgUFOpJhD3hIAGQUQ90F7Ux9q9n/r0/q0byqYuWn89Azd98e6IqYuNn09QBYw3dzSbOw7sWL58xz9kx6fGs8aDTSxOfl0y4fasaG4xJz69q6dFRmfWdCYeCt67ns42shxZdPj8PWQpkyzpFNR1TGxTwP0Yokgw5xkCrlE3J5sehZhFMvdccqPWcQ1cOgUY8K9q+G2nAQhw/vqqwADZ1z5rMyh0kc5XciEzFBoeCvLOP3xsen/TYQuURsNDyTUtgQ+WRkNDqSODU9iiWQrygikPWTD8me96tEVICOQ3plfrv6ctOraiO+Ei4+zMgby3iM98OJte3DElDGw8yDCNRK2iXnWnPuJ9wcByVxDd9V8WZjt/LbPUzBLFsS3Z59ZwzY0yK5k1Rgz6rXa8PpTGgpg9dU35O+5tT83OwkH9JViuH1uknEhd1Cfhud9tO9v+d03TWubNMB+wYQftUpRMcibi/WdN66Le9n+iBbt+uJ/tRc0J1O4IaKnpWbWRwdlieMy04Jh+sHVcPw/p+fnSLLyth2dL5HHttHYc0pDWz8+X0QLlLq99iKOzzBbDp1GtHCoYwxvVar0FtXSmhH7uBnTpMDSwRqOhzxc3WmEljXZF8wPtLeEHrC4Z697gkiB+3GvEeu32vpnQLf3JKmdVAqKTFVPePo/bm8gdXp6NzBT8ITW7K3tzaM+g2qfmwjbgUgHZIdIuuQaokggOVky4+yS7Y3UxnSVreKeld9NAOrQn5HO5RtOJsaDIJlJiUs7sHColc72qJ7qn+PBwMQJ8FLl+YXgoGuYdlsiugopcfW7P+mKoJhl9Yr7kHYXSep+364+Pso9+YI0w1KMoprfgbXgX3g3znUMaPVS7Zy4/By/k5/IQWFhozy8srEWabMNaXCnbFiJI4JUvowdswxKvuWcWrvhCm7QRWbpwtx2hzsClBgF3Eo1fsG+O7d+4H/7WLOfOs7T8aqcw90MF8mp3rw7oCd0fW2h/CaONeUOghbZvdW0fx/htjGcOZA4Lr/YYA/1JZ7z/eLMHi33wozfZsX2b9pt9n8V9XscHuwgKXbdzEALNx4pvnS8+thL+aiVSbw0+Bhseyp09m3sIzrTn4UyHphga+RxhDzIKRp8G02LWMlPIj7qaqhhul0kb3tXQiEpfOavphxh0qW9hK1qZQcTBg2KE20FATAJGp3pDNYK02kjDwh2bN+61O7Ppmyeev/WO1aMrCElF73505YbxG27j+VR607oz66azCZtt69jkU1Grdf3oqslqKQOH9F9WZgayCFHOrFrerx9NOvzBenMTr1XLsiJejrCfIdXS09vuvG3DslpKVlrLvjq1ZXLlznqL5LNf3DB98/pizpItbJ6Y3vh4rvDy6MTYbDzJWYIK3K8/5e1NpavN4VdIWNGPtk6sXD1QsGjsQP+INnzZvngGM8Pej97Xz4ygZoyDIuPwSE588KAgwZUVujmo1iGG4Euo1odBjtUoOBMkK9nndAcimyMBt3M2vjyOF1zslAtCIBAPBMChO4PJZLAFB7VgKsWGRMnvFkW3XxKxkT5pdnoOH4I/6ser/fVUAJ4LJmdnk0F9MpBajE+HDZmbKHEXIdXRCFhQY3E0QdIwg4uJ5tEIcGmcEnSs11CVioGhYOMJID0WPtQcbOx0N0NRCMsr1vwB5lBWkgvqkxge/8XHO23eU/X+sgBBm0rARp6w4VbALXpfhwdOIGLwOPsdvGNHcTQs62/3TTvvtFoCtdyQ6sDu5Eter8+tnHKzbK/+r1Yp46+KT2Iw52zi64z9qrwURe2vZMYM77yN2cHs/h9yU0xQjINVC01PEYQxndUgI9DhEp0jScVQRkpSK7WMlavUGllARVQwscoV6tEpa4KTK410Qq58WOKCQ+2XfvkeZhW+bQPMMVH4vj0/PZXns2P9B/j89HTeviJZDoah/TIcvh9gtlVdi5nuUAvOHKLtURfLsw/+aNmND35oKrvUftnKY/P3zgpeHAzuB4/BnL+n/8Yc4fNTOA7gdkvJhseWPfDDydqDv6mntrcOH47ThAdweBYeWPQJeu5Fzz/N008v9YIoVYf3mtPPuLG5oF/g4iMH9q2+4YbV+w6At0s9cnD3zubISHPn7veQGB5Ggr1AP+jvL22sLWlDiZHumurKov1W0lxzNmu0+bgiwnevc+r6seXWJ6eX9qTMrsUCFD9gwMdkpCIowGieYffp54+39INwrHW8NKuH4e3Z0vw8IorzxykaOE5hwPy8yYeeT7swEjO4z0Mcae77BEs3urP+9vO3lOJkPF7SvzfTPHeuOTOFrH4CSf0n9BQQkn0zw+fODc/AycXzeAs5aZzj0QMKtkd/34AyZDeFp0gw17YDemaGeCzfga1HOuVimxe6Z4IqttFP/CVu0VeRJ5AoPAyrFnkViESt7EMdnDaSnk9bjKV72Rm0ew7xJeOLI5BEtI6Zhm7GMLJiPvEhpgkTBDMZ7goGygBFO6qxtOk/Uzq0cW7zNCFJQv4Ulr1LLAalz71LvEU1pGz6/Z1JraAl7sr6Y5xNDmoF+MbAuhBWCYXA4GZRECJIR6JWpXfnMnYPdraQU/rcO8gQrOQUNN4l+n0IX7B9xGDk7PUW+5KTvchoMmrwUVhLOd+/Ffm0Iptv7y8N4wz/G4A9L1cAAHicY2BkYGAAYgWvvDnx/DZfGbiZXwAFojgf72uA0f/////D/IL5DVAlBwMTkGQAAHb/DvN4nGNgZGBgfsHAACL//wezGRlQgQcAdFMFCgAAeJxjYGBgYH6BDf//j8C41AwspgcAANyGMDUAAHicY2AAghkMFxieMTowRjEuYXzFpMEUxVTD1Md0g+kT8wWWdSxHWM1YV7DuYQtgO8EuwK7FXsL+iYOHw4hjD8cPTjFOA04/ziIuJq4YrgPcadxreIR4zHgSeEp42nhm8azglSEdAgCdlRu1AHicY2BkYGDwYJjHwMMAAkxAzAWEDAz/wXwGACBkAgkAeJx1jz9OwzAYxV9oWkSLEBISYsMTC1L6Z2Do2KHZO3RgcxsnbZXEkeNW6sYxOAHHYOQInIJD8BK+oUKqLTk///zeJwXALb4QoFkBrtuzWRe45O2PO6Q74ZD8KNzFAM/CPfoX4T7tTHjAZsEJQXhF84A34Qvc4F24Q/8hHJI/hbu4x7dwj/5HuI9lEAoP8BS86ix222Sm840uFibb59qdqlNeGldvbanG0ehUx6Y0TnuTqNVR1Yds4n2qUmcLNbelN3luVeXszqx9tPG+mg6HqfhobQtoZIjhsEXCP9fIseFZYAHDlz3vmq/nUuf8km2Hmt6ihMIYEUZn0zHTZdvQ8PwmbKxw5FnjwM6E1iPlPWXGsqEwbyc36Zzb0lTt245mTR9xdtOqMMWQO/2Xj5jipF9al2jJAAAAeJxtkQdv2zAQhf3Fku3YaeO6bbr3Hmrr7p3upj+DpmiZiEQKJOWRX18iLgIE6AE8vPdwvHu4a2201tFv/T/22KBNQkqHLj026TNgixOcZJshpxhxmjOcZYdznOcCF7nEZa5wlWtc5wY3ucVt7nCXe9znAQ95xGMynvCUZ4x5zgte8orXvOEt73jPBz7yic/s8oWvfOM7P/jJL36zx5/WQBSFU4UI2pqOcM4ufFt42ZHCSFWmciZcGMqZkvsTu8wOgcp3jgRtchWUq7QRQY2O5Mb8q9yStrQuq3UkrhtJUxnfl9YEJ2RQeSJtvUqls963pZ+n8WXjJFdepmoZDXQPczbuqWUt4qx8U61U5kvhZ+2IOlNdxvHpVDsfksLpOi2cbeokFoSkVNPQKbWJPrqlFbk2Ra8SS13pA5VUyjS96HvNjDVqYGzIRFnahcrTOjZQ7VqbtNZzG4YufrfZpAnBmsxOp9vHBZM6XcxC4sVc9X0Vu2S5XZjeGkZDIW5gFJxSx1fWa8zaIIIChyKgsRgWeCQlM/aZsIwnzqloqFkxZ8pBq/UXq/Gj5g==\") format(\"woff\");\n font-weight: normal;\n font-style: normal;\n}\n.ag-theme-balham .ag-icon {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n.ag-theme-balham .ag-icon-aggregation::before {\n content: \"\\f101\";\n}\n.ag-theme-balham .ag-icon-arrows::before {\n content: \"\\f102\";\n}\n.ag-theme-balham .ag-icon-asc::before {\n content: \"\\f103\";\n}\n.ag-theme-balham .ag-icon-cancel::before {\n content: \"\\f104\";\n}\n.ag-theme-balham .ag-icon-chart::before {\n content: \"\\f105\";\n}\n.ag-theme-balham .ag-icon-color-picker::before {\n content: \"\\f109\";\n}\n.ag-theme-balham .ag-icon-columns::before {\n content: \"\\f10a\";\n}\n.ag-theme-balham .ag-icon-contracted::before {\n content: \"\\f10b\";\n}\n.ag-theme-balham .ag-icon-copy::before {\n content: \"\\f10c\";\n}\n.ag-theme-balham .ag-icon-cross::before {\n content: \"\\f10d\";\n}\n.ag-theme-balham .ag-icon-csv::before {\n content: \"\\f10e\";\n}\n.ag-theme-balham .ag-icon-desc::before {\n content: \"\\f10f\";\n}\n.ag-theme-balham .ag-icon-excel::before {\n content: \"\\f110\";\n}\n.ag-theme-balham .ag-icon-expanded::before {\n content: \"\\f111\";\n}\n.ag-theme-balham .ag-icon-eye-slash::before {\n content: \"\\f112\";\n}\n.ag-theme-balham .ag-icon-eye::before {\n content: \"\\f113\";\n}\n.ag-theme-balham .ag-icon-filter::before {\n content: \"\\f114\";\n}\n.ag-theme-balham .ag-icon-first::before {\n content: \"\\f115\";\n}\n.ag-theme-balham .ag-icon-grip::before {\n content: \"\\f116\";\n}\n.ag-theme-balham .ag-icon-group::before {\n content: \"\\f117\";\n}\n.ag-theme-balham .ag-icon-last::before {\n content: \"\\f118\";\n}\n.ag-theme-balham .ag-icon-left::before {\n content: \"\\f119\";\n}\n.ag-theme-balham .ag-icon-linked::before {\n content: \"\\f11a\";\n}\n.ag-theme-balham .ag-icon-loading::before {\n content: \"\\f11b\";\n}\n.ag-theme-balham .ag-icon-maximize::before {\n content: \"\\f11c\";\n}\n.ag-theme-balham .ag-icon-menu::before {\n content: \"\\f11d\";\n}\n.ag-theme-balham .ag-icon-minimize::before {\n content: \"\\f11e\";\n}\n.ag-theme-balham .ag-icon-next::before {\n content: \"\\f11f\";\n}\n.ag-theme-balham .ag-icon-none::before {\n content: \"\\f120\";\n}\n.ag-theme-balham .ag-icon-not-allowed::before {\n content: \"\\f121\";\n}\n.ag-theme-balham .ag-icon-paste::before {\n content: \"\\f122\";\n}\n.ag-theme-balham .ag-icon-pin::before {\n content: \"\\f123\";\n}\n.ag-theme-balham .ag-icon-pivot::before {\n content: \"\\f124\";\n}\n.ag-theme-balham .ag-icon-previous::before {\n content: \"\\f125\";\n}\n.ag-theme-balham .ag-icon-right::before {\n content: \"\\f128\";\n}\n.ag-theme-balham .ag-icon-save::before {\n content: \"\\f129\";\n}\n.ag-theme-balham .ag-icon-small-down::before {\n content: \"\\f12a\";\n}\n.ag-theme-balham .ag-icon-small-left::before {\n content: \"\\f12b\";\n}\n.ag-theme-balham .ag-icon-small-right::before {\n content: \"\\f12c\";\n}\n.ag-theme-balham .ag-icon-small-up::before {\n content: \"\\f12d\";\n}\n.ag-theme-balham .ag-icon-tick::before {\n content: \"\\f12e\";\n}\n.ag-theme-balham .ag-icon-tree-closed::before {\n content: \"\\f12f\";\n}\n.ag-theme-balham .ag-icon-tree-indeterminate::before {\n content: \"\\f130\";\n}\n.ag-theme-balham .ag-icon-tree-open::before {\n content: \"\\f131\";\n}\n.ag-theme-balham .ag-icon-unlinked::before {\n content: \"\\f132\";\n}\n.ag-theme-balham .ag-icon-row-drag::before {\n content: \"\\f116\";\n}\n.ag-theme-balham .ag-left-arrow::before {\n content: \"\\f119\";\n}\n.ag-theme-balham .ag-right-arrow::before {\n content: \"\\f128\";\n}\n.ag-theme-balham .ag-root-wrapper {\n background-color: white;\n background-color: var(--ag-background-color, white);\n}\n.ag-theme-balham [class^=ag-], .ag-theme-balham [class^=ag-]:focus, .ag-theme-balham [class^=ag-]:after, .ag-theme-balham [class^=ag-]:before {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n outline: none;\n}\n.ag-theme-balham [class^=ag-]::-ms-clear {\n display: none;\n}\n.ag-theme-balham .ag-checkbox .ag-input-wrapper,\n.ag-theme-balham .ag-radio-button .ag-input-wrapper {\n overflow: visible;\n}\n.ag-theme-balham .ag-range-field .ag-input-wrapper {\n height: 100%;\n}\n.ag-theme-balham .ag-toggle-button {\n -webkit-box-flex: 0;\n flex: none;\n width: unset;\n min-width: unset;\n}\n.ag-theme-balham .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px;\n}\n\n.ag-theme-balham .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px;\n}\n\n.ag-theme-balham input[class^=ag-] {\n margin: 0;\n background-color: white;\n background-color: var(--ag-background-color, white);\n}\n.ag-theme-balham textarea[class^=ag-],\n.ag-theme-balham select[class^=ag-] {\n background-color: white;\n background-color: var(--ag-background-color, white);\n}\n.ag-theme-balham input[class^=ag-]:not([type]),\n.ag-theme-balham input[class^=ag-][type=text],\n.ag-theme-balham input[class^=ag-][type=number],\n.ag-theme-balham input[class^=ag-][type=tel],\n.ag-theme-balham input[class^=ag-][type=date],\n.ag-theme-balham input[class^=ag-][type=datetime-local],\n.ag-theme-balham textarea[class^=ag-] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #95a5a6;\n border-color: var(--ag-input-border-color, #95a5a6);\n}\n.ag-theme-balham input[class^=ag-]:not([type]):disabled,\n.ag-theme-balham input[class^=ag-][type=text]:disabled,\n.ag-theme-balham input[class^=ag-][type=number]:disabled,\n.ag-theme-balham input[class^=ag-][type=tel]:disabled,\n.ag-theme-balham input[class^=ag-][type=date]:disabled,\n.ag-theme-balham input[class^=ag-][type=datetime-local]:disabled,\n.ag-theme-balham textarea[class^=ag-]:disabled {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n background-color: #ebebeb;\n background-color: var(--ag-input-disabled-background-color, #ebebeb);\n border-color: rgba(149, 165, 166, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(149, 165, 166, 0.3));\n}\n.ag-theme-balham input[class^=ag-]:not([type]):focus,\n.ag-theme-balham input[class^=ag-][type=text]:focus,\n.ag-theme-balham input[class^=ag-][type=number]:focus,\n.ag-theme-balham input[class^=ag-][type=tel]:focus,\n.ag-theme-balham input[class^=ag-][type=date]:focus,\n.ag-theme-balham input[class^=ag-][type=datetime-local]:focus,\n.ag-theme-balham textarea[class^=ag-]:focus {\n outline: none;\n -webkit-box-shadow: 0 0 2px 1px #719ECE;\n box-shadow: 0 0 2px 1px #719ECE;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham input[class^=ag-]:not([type]):invalid,\n.ag-theme-balham input[class^=ag-][type=text]:invalid,\n.ag-theme-balham input[class^=ag-][type=number]:invalid,\n.ag-theme-balham input[class^=ag-][type=tel]:invalid,\n.ag-theme-balham input[class^=ag-][type=date]:invalid,\n.ag-theme-balham input[class^=ag-][type=datetime-local]:invalid,\n.ag-theme-balham textarea[class^=ag-]:invalid {\n border-width: 2px;\n border-style: solid;\n border-color: #e02525;\n border-color: var(--ag-input-border-color-invalid, var(--ag-invalid-color, #e02525));\n}\n.ag-theme-balham input[class^=ag-][type=number] {\n -moz-appearance: textfield;\n}\n.ag-theme-balham input[class^=ag-][type=number]::-webkit-outer-spin-button, .ag-theme-balham input[class^=ag-][type=number]::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n}\n.ag-theme-balham input[class^=ag-][type=range] {\n padding: 0;\n}\n.ag-theme-balham input[class^=ag-][type=button]:focus, .ag-theme-balham button[class^=ag-]:focus {\n -webkit-box-shadow: 0 0 2px 1px #719ECE;\n box-shadow: 0 0 2px 1px #719ECE;\n}\n.ag-theme-balham .ag-drag-handle {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-balham .ag-list-item, .ag-theme-balham .ag-virtual-list-item {\n height: 24px;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham .ag-select-list {\n background-color: white;\n background-color: var(--ag-background-color, white);\n overflow-y: auto;\n overflow-x: hidden;\n}\n.ag-theme-balham .ag-list-item {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-balham .ag-list-item.ag-active-item {\n background-color: #ecf0f1;\n background-color: var(--ag-row-hover-color, #ecf0f1);\n}\n.ag-theme-balham .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n user-select: none;\n}\n.ag-theme-balham .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n.ag-theme-balham .ag-select .ag-picker-field-wrapper {\n background-color: white;\n background-color: var(--ag-background-color, white);\n min-height: 24px;\n cursor: default;\n}\n.ag-theme-balham .ag-select.ag-disabled .ag-picker-field-wrapper:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-balham .ag-select:not(.ag-cell-editor) {\n height: 24px;\n}\n.ag-theme-balham .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-balham .ag-select .ag-picker-field-icon {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-balham .ag-select.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-balham .ag-rich-select {\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7);\n}\n.ag-theme-balham .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 182px;\n}\n.ag-theme-balham .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 28px;\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7));\n}\n.ag-theme-balham .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 24px;\n}\n.ag-theme-balham .ag-rich-select-virtual-list-item:hover {\n background-color: #ecf0f1;\n background-color: var(--ag-row-hover-color, #ecf0f1);\n}\n.ag-theme-balham .ag-rich-select-row {\n padding-left: 12px;\n}\n.ag-theme-balham .ag-rich-select-row-selected {\n background-color: #b7e4ff;\n background-color: var(--ag-selected-row-background-color, #b7e4ff);\n}\n.ag-theme-balham .ag-row-drag,\n.ag-theme-balham .ag-selection-checkbox,\n.ag-theme-balham .ag-group-expanded,\n.ag-theme-balham .ag-group-contracted {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-balham .ag-ltr .ag-row-drag, .ag-theme-balham .ag-ltr .ag-selection-checkbox, .ag-theme-balham .ag-ltr .ag-group-expanded, .ag-theme-balham .ag-ltr .ag-group-contracted {\n margin-right: 12px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-drag, .ag-theme-balham .ag-rtl .ag-selection-checkbox, .ag-theme-balham .ag-rtl .ag-group-expanded, .ag-theme-balham .ag-rtl .ag-group-contracted {\n margin-left: 12px;\n}\n\n.ag-theme-balham .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: min(var(--ag-row-height, 26px), 26px);\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-balham .ag-group-expanded,\n.ag-theme-balham .ag-group-contracted {\n cursor: pointer;\n}\n.ag-theme-balham .ag-group-title-bar-icon {\n cursor: pointer;\n -webkit-box-flex: 0;\n flex: none;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-balham .ag-ltr .ag-group-child-count {\n margin-left: 2px;\n}\n\n.ag-theme-balham .ag-rtl .ag-group-child-count {\n margin-right: 2px;\n}\n\n.ag-theme-balham .ag-group-title-bar {\n background-color: #e2e9eb;\n background-color: var(--ag-subheader-background-color, #e2e9eb);\n padding: 4px;\n}\n.ag-theme-balham .ag-group-toolbar {\n padding: 4px;\n}\n.ag-theme-balham .ag-disabled-group-title-bar, .ag-theme-balham .ag-disabled-group-container {\n opacity: 0.5;\n}\n.ag-theme-balham .group-item {\n margin: 2px 0;\n}\n.ag-theme-balham .ag-label {\n white-space: nowrap;\n}\n.ag-theme-balham .ag-ltr .ag-label {\n margin-right: 4px;\n}\n\n.ag-theme-balham .ag-rtl .ag-label {\n margin-left: 4px;\n}\n\n.ag-theme-balham .ag-label-align-top .ag-label {\n margin-bottom: 2px;\n}\n.ag-theme-balham .ag-ltr .ag-slider-field, .ag-theme-balham .ag-ltr .ag-angle-select-field {\n margin-right: 8px;\n}\n\n.ag-theme-balham .ag-rtl .ag-slider-field, .ag-theme-balham .ag-rtl .ag-angle-select-field {\n margin-left: 8px;\n}\n\n.ag-theme-balham .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background-color: white;\n background-color: var(--ag-background-color, white);\n}\n.ag-theme-balham .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: rgba(0, 0, 0, 0.54);\n background-color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-balham .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n border-radius: 5px;\n}\n.ag-theme-balham .ag-picker-field-wrapper:focus {\n -webkit-box-shadow: 0 0 2px 1px #719ECE;\n box-shadow: 0 0 2px 1px #719ECE;\n}\n.ag-theme-balham .ag-picker-field-button {\n background-color: white;\n background-color: var(--ag-background-color, white);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-balham .ag-dialog.ag-color-dialog {\n border-radius: 5px;\n}\n.ag-theme-balham .ag-color-picker .ag-picker-field-display {\n height: 16px;\n}\n.ag-theme-balham .ag-color-panel {\n padding: 4px;\n}\n.ag-theme-balham .ag-spectrum-color {\n background-color: red;\n border-radius: 2px;\n}\n.ag-theme-balham .ag-spectrum-tools {\n padding: 10px;\n}\n.ag-theme-balham .ag-spectrum-sat {\n background-image: -webkit-gradient(linear, left top, right top, from(white), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0));\n}\n.ag-theme-balham .ag-spectrum-val {\n background-image: -webkit-gradient(linear, left bottom, left top, from(black), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0));\n}\n.ag-theme-balham .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n -webkit-box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n}\n.ag-theme-balham .ag-spectrum-hue-background {\n border-radius: 2px;\n}\n.ag-theme-balham .ag-spectrum-alpha-background {\n border-radius: 2px;\n}\n.ag-theme-balham .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px;\n}\n.ag-theme-balham .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n -webkit-box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n}\n.ag-theme-balham .ag-recent-color {\n margin: 0 3px;\n}\n.ag-theme-balham .ag-recent-color:first-child {\n margin-left: 0;\n}\n.ag-theme-balham .ag-recent-color:last-child {\n margin-right: 0;\n}\n.ag-theme-balham.ag-dnd-ghost {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7));\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 32px !important;\n line-height: 32px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px);\n}\n.ag-theme-balham .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #000;\n color: var(--ag-foreground-color, #000);\n}\n.ag-theme-balham .ag-popup-child:not(.ag-tooltip-custom) {\n -webkit-box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3);\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3);\n}\n.ag-dragging-range-handle .ag-theme-balham .ag-dialog, .ag-dragging-fill-handle .ag-theme-balham .ag-dialog {\n opacity: 0.7;\n pointer-events: none;\n}\n.ag-theme-balham .ag-dialog {\n border-radius: 2px;\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-panel {\n background-color: white;\n background-color: var(--ag-background-color, white);\n}\n.ag-theme-balham .ag-panel-title-bar {\n background-color: #f5f7f7;\n background-color: var(--ag-header-background-color, #f5f7f7);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)));\n height: 32px;\n padding: 4px 12px;\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px;\n}\n\n.ag-theme-balham .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px;\n}\n\n.ag-theme-balham .ag-tooltip {\n background-color: #f5f7f7;\n background-color: var(--ag-header-background-color, #f5f7f7);\n color: #000;\n color: var(--ag-foreground-color, #000);\n padding: 4px;\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n border-radius: 2px;\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n white-space: normal;\n}\n.ag-theme-balham .ag-tooltip.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-balham .ag-tooltip-custom {\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n}\n.ag-theme-balham .ag-tooltip-custom.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-balham .ag-ltr .ag-column-select-indent-1 {\n padding-left: 20px;\n}\n\n.ag-theme-balham .ag-rtl .ag-column-select-indent-1 {\n padding-right: 20px;\n}\n\n.ag-theme-balham .ag-ltr .ag-column-select-indent-2 {\n padding-left: 40px;\n}\n\n.ag-theme-balham .ag-rtl .ag-column-select-indent-2 {\n padding-right: 40px;\n}\n\n.ag-theme-balham .ag-ltr .ag-column-select-indent-3 {\n padding-left: 60px;\n}\n\n.ag-theme-balham .ag-rtl .ag-column-select-indent-3 {\n padding-right: 60px;\n}\n\n.ag-theme-balham .ag-ltr .ag-column-select-indent-4 {\n padding-left: 80px;\n}\n\n.ag-theme-balham .ag-rtl .ag-column-select-indent-4 {\n padding-right: 80px;\n}\n\n.ag-theme-balham .ag-ltr .ag-column-select-indent-5 {\n padding-left: 100px;\n}\n\n.ag-theme-balham .ag-rtl .ag-column-select-indent-5 {\n padding-right: 100px;\n}\n\n.ag-theme-balham .ag-ltr .ag-column-select-indent-6 {\n padding-left: 120px;\n}\n\n.ag-theme-balham .ag-rtl .ag-column-select-indent-6 {\n padding-right: 120px;\n}\n\n.ag-theme-balham .ag-ltr .ag-column-select-indent-7 {\n padding-left: 140px;\n}\n\n.ag-theme-balham .ag-rtl .ag-column-select-indent-7 {\n padding-right: 140px;\n}\n\n.ag-theme-balham .ag-ltr .ag-column-select-indent-8 {\n padding-left: 160px;\n}\n\n.ag-theme-balham .ag-rtl .ag-column-select-indent-8 {\n padding-right: 160px;\n}\n\n.ag-theme-balham .ag-ltr .ag-column-select-indent-9 {\n padding-left: 180px;\n}\n\n.ag-theme-balham .ag-rtl .ag-column-select-indent-9 {\n padding-right: 180px;\n}\n\n.ag-theme-balham .ag-column-select-header-icon {\n cursor: pointer;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-column-select-header-icon:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 8px;\n}\n\n.ag-theme-balham .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 8px;\n}\n\n.ag-theme-balham .ag-keyboard-focus .ag-column-select-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-column-select-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham .ag-column-select-column-group:not(:last-child),\n.ag-theme-balham .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px;\n}\n.ag-theme-balham .ag-column-select-column-readonly,\n.ag-theme-balham .ag-column-select-column-group-readonly {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n pointer-events: none;\n}\n.ag-theme-balham .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 24px;\n}\n\n.ag-theme-balham .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 24px;\n}\n\n.ag-theme-balham .ag-column-select-virtual-list-viewport {\n padding: 3px 0px;\n}\n.ag-theme-balham .ag-column-select-virtual-list-item {\n padding: 0 6px;\n}\n.ag-theme-balham .ag-rtl {\n text-align: right;\n}\n.ag-theme-balham .ag-root-wrapper {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 40px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 40px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-1 {\n padding-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-1 {\n padding-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-1 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-1 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 68px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 68px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-2 {\n padding-left: 56px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-2 {\n padding-right: 56px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-2 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-2 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 96px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 96px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-3 {\n padding-left: 84px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-3 {\n padding-right: 84px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-3 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-3 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 124px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 124px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-4 {\n padding-left: 112px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-4 {\n padding-right: 112px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-4 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-4 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 152px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 152px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-5 {\n padding-left: 140px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-5 {\n padding-right: 140px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-5 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-5 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 180px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 180px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-6 {\n padding-left: 168px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-6 {\n padding-right: 168px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-6 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-6 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 208px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 208px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-7 {\n padding-left: 196px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-7 {\n padding-right: 196px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-7 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-7 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 236px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 236px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-8 {\n padding-left: 224px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-8 {\n padding-right: 224px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-8 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-8 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 264px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 264px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-9 {\n padding-left: 252px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-9 {\n padding-right: 252px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-9 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-9 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 292px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 292px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-10 {\n padding-left: 280px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-10 {\n padding-right: 280px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-10 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-10 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 320px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 320px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-11 {\n padding-left: 308px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-11 {\n padding-right: 308px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-11 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-11 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 348px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 348px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-12 {\n padding-left: 336px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-12 {\n padding-right: 336px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-12 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-12 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 376px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 376px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-13 {\n padding-left: 364px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-13 {\n padding-right: 364px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-13 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-13 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 404px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 404px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-14 {\n padding-left: 392px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-14 {\n padding-right: 392px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-14 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-14 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 432px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 432px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-15 {\n padding-left: 420px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-15 {\n padding-right: 420px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-15 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-15 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 460px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 460px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-16 {\n padding-left: 448px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-16 {\n padding-right: 448px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-16 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-16 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 488px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 488px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-17 {\n padding-left: 476px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-17 {\n padding-right: 476px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-17 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-17 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 516px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 516px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-18 {\n padding-left: 504px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-18 {\n padding-right: 504px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-18 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-18 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 544px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 544px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-19 {\n padding-left: 532px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-19 {\n padding-right: 532px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-19 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-19 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-left: 572px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-right: 572px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-20 {\n padding-left: 560px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-20 {\n padding-right: 560px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-20 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-20 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-left: 600px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-right: 600px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-21 {\n padding-left: 588px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-21 {\n padding-right: 588px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-21 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-21 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-left: 628px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-right: 628px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-22 {\n padding-left: 616px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-22 {\n padding-right: 616px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-22 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-22 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-left: 656px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-right: 656px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-23 {\n padding-left: 644px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-23 {\n padding-right: 644px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-23 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-23 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-left: 684px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-right: 684px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-24 {\n padding-left: 672px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-24 {\n padding-right: 672px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-24 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-24 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-left: 712px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-right: 712px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-25 {\n padding-left: 700px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-25 {\n padding-right: 700px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-25 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-25 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-left: 740px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-right: 740px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-26 {\n padding-left: 728px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-26 {\n padding-right: 728px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-26 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-26 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-left: 768px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-right: 768px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-27 {\n padding-left: 756px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-27 {\n padding-right: 756px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-27 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-27 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-left: 796px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-right: 796px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-28 {\n padding-left: 784px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-28 {\n padding-right: 784px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-28 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-28 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-left: 824px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-right: 824px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-29 {\n padding-left: 812px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-29 {\n padding-right: 812px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-29 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-29 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-left: 852px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-right: 852px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-30 {\n padding-left: 840px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-30 {\n padding-right: 840px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-30 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-30 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-left: 880px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-right: 880px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-31 {\n padding-left: 868px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-31 {\n padding-right: 868px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-31 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-31 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-left: 908px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-right: 908px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-32 {\n padding-left: 896px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-32 {\n padding-right: 896px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-32 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-32 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-left: 936px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-right: 936px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-33 {\n padding-left: 924px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-33 {\n padding-right: 924px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-33 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-33 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-left: 964px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-right: 964px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-34 {\n padding-left: 952px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-34 {\n padding-right: 952px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-34 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-34 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-left: 992px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-right: 992px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-35 {\n padding-left: 980px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-35 {\n padding-right: 980px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-35 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-35 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-left: 1020px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-right: 1020px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-36 {\n padding-left: 1008px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-36 {\n padding-right: 1008px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-36 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-36 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-left: 1048px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-right: 1048px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-37 {\n padding-left: 1036px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-37 {\n padding-right: 1036px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-37 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-37 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-left: 1076px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-right: 1076px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-38 {\n padding-left: 1064px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-38 {\n padding-right: 1064px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-38 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-38 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-left: 1104px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-right: 1104px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-39 {\n padding-left: 1092px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-39 {\n padding-right: 1092px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-39 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-39 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-left: 1132px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-right: 1132px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-40 {\n padding-left: 1120px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-40 {\n padding-right: 1120px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-40 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-40 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-left: 1160px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-right: 1160px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-41 {\n padding-left: 1148px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-41 {\n padding-right: 1148px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-41 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-41 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-left: 1188px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-right: 1188px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-42 {\n padding-left: 1176px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-42 {\n padding-right: 1176px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-42 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-42 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-left: 1216px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-right: 1216px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-43 {\n padding-left: 1204px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-43 {\n padding-right: 1204px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-43 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-43 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-left: 1244px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-right: 1244px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-44 {\n padding-left: 1232px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-44 {\n padding-right: 1232px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-44 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-44 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-left: 1272px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-right: 1272px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-45 {\n padding-left: 1260px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-45 {\n padding-right: 1260px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-45 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-45 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-left: 1300px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-right: 1300px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-46 {\n padding-left: 1288px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-46 {\n padding-right: 1288px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-46 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-46 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-left: 1328px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-right: 1328px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-47 {\n padding-left: 1316px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-47 {\n padding-right: 1316px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-47 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-47 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-left: 1356px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-right: 1356px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-48 {\n padding-left: 1344px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-48 {\n padding-right: 1344px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-48 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-48 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-left: 1384px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-right: 1384px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-49 {\n padding-left: 1372px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-49 {\n padding-right: 1372px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-49 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-49 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-left: 1412px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-right: 1412px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-50 {\n padding-left: 1400px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-50 {\n padding-right: 1400px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-50 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-50 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-left: 1440px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-right: 1440px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-51 {\n padding-left: 1428px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-51 {\n padding-right: 1428px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-51 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-51 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-left: 1468px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-right: 1468px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-52 {\n padding-left: 1456px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-52 {\n padding-right: 1456px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-52 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-52 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-left: 1496px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-right: 1496px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-53 {\n padding-left: 1484px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-53 {\n padding-right: 1484px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-53 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-53 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-left: 1524px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-right: 1524px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-54 {\n padding-left: 1512px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-54 {\n padding-right: 1512px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-54 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-54 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-left: 1552px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-right: 1552px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-55 {\n padding-left: 1540px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-55 {\n padding-right: 1540px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-55 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-55 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-left: 1580px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-right: 1580px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-56 {\n padding-left: 1568px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-56 {\n padding-right: 1568px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-56 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-56 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-left: 1608px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-right: 1608px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-57 {\n padding-left: 1596px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-57 {\n padding-right: 1596px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-57 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-57 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-left: 1636px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-right: 1636px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-58 {\n padding-left: 1624px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-58 {\n padding-right: 1624px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-58 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-58 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-left: 1664px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-right: 1664px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-59 {\n padding-left: 1652px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-59 {\n padding-right: 1652px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-59 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-59 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-left: 1692px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-right: 1692px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-60 {\n padding-left: 1680px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-60 {\n padding-right: 1680px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-60 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-60 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-left: 1720px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-right: 1720px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-61 {\n padding-left: 1708px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-61 {\n padding-right: 1708px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-61 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-61 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-left: 1748px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-right: 1748px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-62 {\n padding-left: 1736px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-62 {\n padding-right: 1736px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-62 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-62 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-left: 1776px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-right: 1776px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-63 {\n padding-left: 1764px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-63 {\n padding-right: 1764px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-63 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-63 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-left: 1804px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-right: 1804px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-64 {\n padding-left: 1792px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-64 {\n padding-right: 1792px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-64 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-64 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-left: 1832px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-right: 1832px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-65 {\n padding-left: 1820px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-65 {\n padding-right: 1820px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-65 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-65 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-left: 1860px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-right: 1860px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-66 {\n padding-left: 1848px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-66 {\n padding-right: 1848px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-66 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-66 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-left: 1888px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-right: 1888px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-67 {\n padding-left: 1876px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-67 {\n padding-right: 1876px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-67 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-67 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-left: 1916px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-right: 1916px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-68 {\n padding-left: 1904px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-68 {\n padding-right: 1904px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-68 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-68 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-left: 1944px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-right: 1944px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-69 {\n padding-left: 1932px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-69 {\n padding-right: 1932px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-69 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-69 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-left: 1972px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-right: 1972px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-70 {\n padding-left: 1960px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-70 {\n padding-right: 1960px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-70 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-70 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-left: 2000px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-right: 2000px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-71 {\n padding-left: 1988px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-71 {\n padding-right: 1988px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-71 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-71 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-left: 2028px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-right: 2028px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-72 {\n padding-left: 2016px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-72 {\n padding-right: 2016px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-72 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-72 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-left: 2056px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-right: 2056px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-73 {\n padding-left: 2044px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-73 {\n padding-right: 2044px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-73 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-73 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-left: 2084px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-right: 2084px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-74 {\n padding-left: 2072px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-74 {\n padding-right: 2072px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-74 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-74 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-left: 2112px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-right: 2112px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-75 {\n padding-left: 2100px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-75 {\n padding-right: 2100px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-75 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-75 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-left: 2140px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-right: 2140px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-76 {\n padding-left: 2128px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-76 {\n padding-right: 2128px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-76 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-76 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-left: 2168px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-right: 2168px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-77 {\n padding-left: 2156px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-77 {\n padding-right: 2156px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-77 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-77 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-left: 2196px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-right: 2196px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-78 {\n padding-left: 2184px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-78 {\n padding-right: 2184px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-78 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-78 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-left: 2224px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-right: 2224px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-79 {\n padding-left: 2212px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-79 {\n padding-right: 2212px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-79 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-79 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-left: 2252px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-right: 2252px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-80 {\n padding-left: 2240px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-80 {\n padding-right: 2240px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-80 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-80 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-left: 2280px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-right: 2280px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-81 {\n padding-left: 2268px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-81 {\n padding-right: 2268px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-81 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-81 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-left: 2308px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-right: 2308px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-82 {\n padding-left: 2296px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-82 {\n padding-right: 2296px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-82 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-82 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-left: 2336px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-right: 2336px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-83 {\n padding-left: 2324px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-83 {\n padding-right: 2324px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-83 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-83 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-left: 2364px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-right: 2364px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-84 {\n padding-left: 2352px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-84 {\n padding-right: 2352px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-84 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-84 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-left: 2392px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-right: 2392px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-85 {\n padding-left: 2380px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-85 {\n padding-right: 2380px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-85 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-85 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-left: 2420px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-right: 2420px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-86 {\n padding-left: 2408px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-86 {\n padding-right: 2408px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-86 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-86 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-left: 2448px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-right: 2448px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-87 {\n padding-left: 2436px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-87 {\n padding-right: 2436px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-87 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-87 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-left: 2476px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-right: 2476px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-88 {\n padding-left: 2464px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-88 {\n padding-right: 2464px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-88 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-88 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-left: 2504px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-right: 2504px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-89 {\n padding-left: 2492px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-89 {\n padding-right: 2492px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-89 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-89 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-left: 2532px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-right: 2532px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-90 {\n padding-left: 2520px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-90 {\n padding-right: 2520px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-90 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-90 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-left: 2560px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-right: 2560px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-91 {\n padding-left: 2548px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-91 {\n padding-right: 2548px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-91 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-91 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-left: 2588px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-right: 2588px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-92 {\n padding-left: 2576px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-92 {\n padding-right: 2576px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-92 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-92 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-left: 2616px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-right: 2616px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-93 {\n padding-left: 2604px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-93 {\n padding-right: 2604px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-93 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-93 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-left: 2644px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-right: 2644px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-94 {\n padding-left: 2632px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-94 {\n padding-right: 2632px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-94 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-94 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-left: 2672px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-right: 2672px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-95 {\n padding-left: 2660px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-95 {\n padding-right: 2660px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-95 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-95 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-left: 2700px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-right: 2700px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-96 {\n padding-left: 2688px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-96 {\n padding-right: 2688px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-96 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-96 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-left: 2728px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-right: 2728px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-97 {\n padding-left: 2716px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-97 {\n padding-right: 2716px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-97 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-97 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-left: 2756px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-right: 2756px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-98 {\n padding-left: 2744px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-98 {\n padding-right: 2744px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-98 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-98 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-left: 2784px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-right: 2784px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-indent-99 {\n padding-left: 2772px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-indent-99 {\n padding-right: 2772px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-level-99 .ag-pivot-leaf-group {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-level-99 .ag-pivot-leaf-group {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-ltr .ag-row-group-leaf-indent {\n margin-left: 28px;\n}\n\n.ag-theme-balham .ag-rtl .ag-row-group-leaf-indent {\n margin-right: 28px;\n}\n\n.ag-theme-balham .ag-value-change-delta {\n padding-right: 2px;\n}\n.ag-theme-balham .ag-value-change-delta-up {\n color: #43a047;\n color: var(--ag-value-change-delta-up-color, #43a047);\n}\n.ag-theme-balham .ag-value-change-delta-down {\n color: #e53935;\n color: var(--ag-value-change-delta-down-color, #e53935);\n}\n.ag-theme-balham .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n -webkit-transition: background-color 1s;\n transition: background-color 1s;\n}\n.ag-theme-balham .ag-value-change-value-highlight {\n background-color: rgba(22, 160, 133, 0.5);\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5));\n -webkit-transition: background-color 0.1s;\n transition: background-color 0.1s;\n}\n.ag-theme-balham .ag-cell-data-changed {\n background-color: rgba(22, 160, 133, 0.5) !important;\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5)) !important;\n}\n.ag-theme-balham .ag-cell-data-changed-animation {\n background-color: transparent;\n}\n.ag-theme-balham .ag-cell-highlight {\n background-color: #0091ea !important;\n background-color: var(--ag-range-selection-highlight-color, var(--ag-balham-active-color, #0091ea)) !important;\n}\n.ag-theme-balham .ag-row {\n height: 28px;\n background-color: white;\n background-color: var(--ag-background-color, white);\n color: #000;\n color: var(--ag-data-color, var(--ag-foreground-color, #000));\n border-width: 1px;\n border-color: #d9dcde;\n border-color: var(--ag-row-border-color, #d9dcde);\n border-bottom-style: solid;\n}\n.ag-theme-balham .ag-row-highlight-above::after, .ag-theme-balham .ag-row-highlight-below::after {\n content: \"\";\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #0091ea;\n background-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n left: 1px;\n}\n.ag-theme-balham .ag-row-highlight-above::after {\n top: -1px;\n}\n.ag-theme-balham .ag-row-highlight-above.ag-row-first::after {\n top: 0;\n}\n.ag-theme-balham .ag-row-highlight-below::after {\n bottom: 0px;\n}\n.ag-theme-balham .ag-row-odd {\n background-color: #fcfdfe;\n background-color: var(--ag-odd-row-background-color, #fcfdfe);\n}\n.ag-theme-balham .ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-row-hover {\n background-color: #ecf0f1;\n background-color: var(--ag-row-hover-color, #ecf0f1);\n}\n.ag-theme-balham .ag-column-hover {\n background-color: #ecf0f1;\n background-color: var(--ag-column-hover-color, #ecf0f1);\n}\n.ag-theme-balham .ag-ltr .ag-right-aligned-cell {\n text-align: right;\n}\n\n.ag-theme-balham .ag-rtl .ag-right-aligned-cell {\n text-align: left;\n}\n\n.ag-theme-balham .ag-ltr .ag-right-aligned-cell .ag-cell-value, .ag-theme-balham .ag-ltr .ag-right-aligned-cell .ag-group-value {\n margin-left: auto;\n}\n\n.ag-theme-balham .ag-rtl .ag-right-aligned-cell .ag-cell-value, .ag-theme-balham .ag-rtl .ag-right-aligned-cell .ag-group-value {\n margin-right: auto;\n}\n\n.ag-theme-balham .ag-cell, .ag-theme-balham .ag-full-width-row .ag-cell-wrapper.ag-row-group {\n border: 1px solid transparent;\n line-height: min(var(--ag-row-height, 26px), 26px);\n padding-left: 11px;\n padding-right: 11px;\n -webkit-font-smoothing: subpixel-antialiased;\n}\n.ag-theme-balham .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px;\n}\n.ag-theme-balham .ag-row-dragging {\n cursor: move;\n opacity: 0.5;\n}\n.ag-theme-balham .ag-cell-inline-editing {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 28px;\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7);\n}\n.ag-theme-balham .ag-popup-editor {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7);\n padding: 0;\n}\n.ag-theme-balham .ag-large-text-input {\n height: auto;\n padding: 12px;\n}\n.ag-theme-balham .ag-details-row {\n padding: 20px;\n background-color: white;\n background-color: var(--ag-background-color, white);\n}\n.ag-theme-balham .ag-layout-auto-height .ag-center-cols-clipper, .ag-theme-balham .ag-layout-auto-height .ag-center-cols-container, .ag-theme-balham .ag-layout-print .ag-center-cols-clipper, .ag-theme-balham .ag-layout-print .ag-center-cols-container {\n min-height: 50px;\n}\n.ag-theme-balham .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66));\n}\n.ag-theme-balham .ag-overlay-loading-center {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n}\n.ag-theme-balham .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px;\n}\n.ag-theme-balham .ag-loading {\n padding-left: 12px;\n display: -webkit-box;\n display: flex;\n height: 100%;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-balham .ag-loading-icon {\n padding-right: 12px;\n}\n.ag-theme-balham .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear;\n}\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n.ag-theme-balham .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-ltr .ag-cell {\n border-right: solid transparent;\n}\n\n.ag-theme-balham .ag-rtl .ag-cell {\n border-left: solid transparent;\n}\n\n.ag-theme-balham .ag-ltr .ag-cell {\n border-right-width: 1px;\n}\n\n.ag-theme-balham .ag-rtl .ag-cell {\n border-left-width: 1px;\n}\n\n.ag-theme-balham .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-row-selected {\n background-color: #b7e4ff;\n background-color: var(--ag-selected-row-background-color, #b7e4ff);\n}\n.ag-theme-balham .ag-cell-range-selected:not(.ag-cell-focus),\n.ag-theme-balham .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing) {\n background-color: rgba(0, 145, 234, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(0, 145, 234, 0.2));\n}\n.ag-theme-balham .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart,\n.ag-theme-balham .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1) !important;\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)) !important;\n}\n.ag-theme-balham .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category,\n.ag-theme-balham .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1) !important;\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)) !important;\n}\n.ag-theme-balham .ag-cell-range-selected-1:not(.ag-cell-focus),\n.ag-theme-balham .ag-root:not(.ag-context-menu-open) .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-1:not(.ag-cell-inline-editing) {\n background-color: rgba(0, 145, 234, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(0, 145, 234, 0.2)));\n}\n.ag-theme-balham .ag-cell-range-selected-2:not(.ag-cell-focus),\n.ag-theme-balham .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-2 {\n background-color: rgba(0, 145, 234, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(0, 145, 234, 0.36));\n}\n.ag-theme-balham .ag-cell-range-selected-3:not(.ag-cell-focus),\n.ag-theme-balham .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-3 {\n background-color: rgba(0, 145, 234, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(0, 145, 234, 0.488));\n}\n.ag-theme-balham .ag-cell-range-selected-4:not(.ag-cell-focus),\n.ag-theme-balham .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-4 {\n background-color: rgba(0, 145, 234, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(0, 145, 234, 0.5904));\n}\n.ag-theme-balham .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #0091ea;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n}\n.ag-theme-balham .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #0091ea;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n}\n.ag-theme-balham .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #0091ea;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n}\n.ag-theme-balham .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #0091ea;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n}\n.ag-theme-balham .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-balham .ag-ltr .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-balham .ag-ltr .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-balham .ag-ltr .ag-cell-range-single-cell,\n.ag-theme-balham .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-balham .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-balham .ag-rtl .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-balham .ag-rtl .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-balham .ag-rtl .ag-cell-range-single-cell,\n.ag-theme-balham .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #0091ea;\n border-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n outline: initial;\n}\n.ag-theme-balham .ag-cell.ag-selection-fill-top,\n.ag-theme-balham .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #0091ea;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n}\n.ag-theme-balham .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-balham .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #0091ea;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n}\n\n.ag-theme-balham .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-balham .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #0091ea;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n}\n\n.ag-theme-balham .ag-cell.ag-selection-fill-bottom,\n.ag-theme-balham .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #0091ea;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n}\n.ag-theme-balham .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-balham .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #0091ea;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n}\n\n.ag-theme-balham .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-balham .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #0091ea;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n}\n\n.ag-theme-balham .ag-range-handle, .ag-theme-balham .ag-fill-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #0091ea;\n background-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n}\n.ag-theme-balham .ag-ltr .ag-range-handle, .ag-theme-balham .ag-ltr .ag-fill-handle {\n right: -1px;\n}\n\n.ag-theme-balham .ag-rtl .ag-range-handle, .ag-theme-balham .ag-rtl .ag-fill-handle {\n left: -1px;\n}\n\n.ag-theme-balham .ag-fill-handle {\n cursor: cell;\n}\n.ag-theme-balham .ag-range-handle {\n cursor: nwse-resize;\n}\n.ag-theme-balham .ag-cell-inline-editing {\n border-color: #719ECE !important;\n border-color: var(--ag-input-focus-border-color, #719ECE) !important;\n}\n.ag-theme-balham .ag-menu {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n}\n.ag-theme-balham .ag-menu-list {\n cursor: default;\n padding: 4px 0;\n}\n.ag-theme-balham .ag-menu-separator {\n height: 9px;\n}\n.ag-theme-balham .ag-menu-separator-part::after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-menu-option-active, .ag-theme-balham .ag-compact-menu-option-active {\n background-color: #ecf0f1;\n background-color: var(--ag-row-hover-color, #ecf0f1);\n}\n.ag-theme-balham .ag-menu-option-part, .ag-theme-balham .ag-compact-menu-option-part {\n line-height: 16px;\n padding: 6px 0;\n}\n.ag-theme-balham .ag-menu-option-disabled, .ag-theme-balham .ag-compact-menu-option-disabled {\n opacity: 0.5;\n}\n.ag-theme-balham .ag-menu-option-icon, .ag-theme-balham .ag-compact-menu-option-icon {\n width: 16px;\n}\n.ag-theme-balham .ag-ltr .ag-menu-option-icon, .ag-theme-balham .ag-ltr .ag-compact-menu-option-icon {\n padding-left: 8px;\n}\n\n.ag-theme-balham .ag-rtl .ag-menu-option-icon, .ag-theme-balham .ag-rtl .ag-compact-menu-option-icon {\n padding-right: 8px;\n}\n\n.ag-theme-balham .ag-menu-option-text, .ag-theme-balham .ag-compact-menu-option-text {\n padding-left: 8px;\n padding-right: 8px;\n}\n.ag-theme-balham .ag-ltr .ag-menu-option-shortcut, .ag-theme-balham .ag-ltr .ag-compact-menu-option-shortcut {\n padding-right: 4px;\n}\n\n.ag-theme-balham .ag-rtl .ag-menu-option-shortcut, .ag-theme-balham .ag-rtl .ag-compact-menu-option-shortcut {\n padding-left: 4px;\n}\n\n.ag-theme-balham .ag-menu-option-popup-pointer, .ag-theme-balham .ag-compact-menu-option-popup-pointer {\n padding-right: 4px;\n}\n.ag-theme-balham .ag-tabs {\n min-width: 220px;\n}\n.ag-theme-balham .ag-tabs-header {\n width: 100%;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-balham .ag-tab {\n border-bottom: 0 solid transparent;\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 0;\n flex: none;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-pack: center;\n justify-content: center;\n cursor: pointer;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-tab:focus {\n outline: none;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-tab:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham .ag-tab-selected {\n border-bottom-color: #0091ea;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)));\n}\n.ag-theme-balham .ag-menu-header {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-balham .ag-filter-separator {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-menu:not(.ag-tabs) .ag-filter-select {\n min-width: 167px;\n}\n.ag-theme-balham .ag-tabs .ag-filter-select {\n min-width: 206px;\n}\n.ag-theme-balham .ag-filter-select .ag-picker-field-wrapper {\n width: 0;\n}\n.ag-theme-balham .ag-filter-condition-operator {\n height: 17px;\n}\n.ag-theme-balham .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px;\n}\n\n.ag-theme-balham .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px;\n}\n\n.ag-theme-balham .ag-set-filter-select-all {\n padding-top: 6px;\n}\n.ag-theme-balham .ag-set-filter-list, .ag-theme-balham .ag-filter-no-matches {\n height: 144px;\n}\n.ag-theme-balham .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px;\n}\n.ag-theme-balham .ag-filter-to {\n margin-top: 4px;\n}\n.ag-theme-balham .ag-mini-filter {\n margin: 6px 6px;\n}\n.ag-theme-balham .ag-set-filter-item {\n margin: 0px 6px;\n}\n.ag-theme-balham .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px;\n}\n\n.ag-theme-balham .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px;\n}\n\n.ag-theme-balham .ag-filter-apply-panel {\n padding: 6px 6px;\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7));\n}\n.ag-theme-balham .ag-filter-apply-panel-button {\n line-height: 1.5;\n}\n.ag-theme-balham .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px;\n}\n\n.ag-theme-balham .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px;\n}\n\n.ag-theme-balham .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px;\n}\n.ag-theme-balham .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px;\n}\n.ag-theme-balham .ag-filter-no-matches {\n padding: 6px 6px;\n}\n.ag-theme-balham .ag-multi-filter-menu-item {\n margin: 4px 0;\n}\n.ag-theme-balham .ag-multi-filter-group-title-bar {\n padding: 8px 4px;\n background-color: transparent;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus {\n outline: none;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham .ag-side-bar {\n position: relative;\n}\n.ag-theme-balham .ag-tool-panel-wrapper {\n width: 200px;\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7);\n}\n.ag-theme-balham .ag-side-buttons {\n padding-top: 16px;\n width: 20px;\n position: relative;\n color: #000;\n color: var(--ag-foreground-color, #000);\n overflow: hidden;\n}\n.ag-theme-balham button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: calc(100% + 1px);\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham button.ag-side-button-button:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-side-button-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham .ag-selected .ag-side-button-button {\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7);\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-side-button-icon-wrapper {\n margin-bottom: 3px;\n}\n.ag-theme-balham .ag-ltr .ag-side-bar-left,\n.ag-theme-balham .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n.ag-theme-balham .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-ltr .ag-side-bar-left .ag-side-button-button,\n.ag-theme-balham .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent;\n margin-right: -1px;\n padding-right: 1px;\n}\n.ag-theme-balham .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-balham .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #0091ea;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)));\n}\n.ag-theme-balham .ag-rtl .ag-side-bar-left,\n.ag-theme-balham .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n.ag-theme-balham .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-rtl .ag-side-bar-left .ag-side-button-button,\n.ag-theme-balham .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent;\n margin-left: -1px;\n padding-left: 1px;\n}\n.ag-theme-balham .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-balham .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #0091ea;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)));\n}\n.ag-theme-balham .ag-filter-toolpanel-header {\n height: 24px;\n}\n.ag-theme-balham .ag-ltr .ag-filter-toolpanel-header, .ag-theme-balham .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px;\n}\n\n.ag-theme-balham .ag-rtl .ag-filter-toolpanel-header, .ag-theme-balham .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px;\n}\n\n.ag-theme-balham .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-filter-toolpanel-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f114\";\n position: absolute;\n}\n.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-left: 4px;\n}\n\n.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-right: 4px;\n}\n\n.ag-theme-balham .ag-filter-toolpanel-group-level-0-header {\n height: 32px;\n}\n.ag-theme-balham .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px;\n}\n.ag-theme-balham .ag-filter-toolpanel-search {\n height: 32px;\n}\n.ag-theme-balham .ag-filter-toolpanel-search-input {\n -webkit-box-flex: 1;\n flex-grow: 1;\n height: 16px;\n}\n.ag-theme-balham .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px;\n}\n\n.ag-theme-balham .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px;\n}\n\n.ag-theme-balham .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7));\n}\n.ag-theme-balham .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px;\n}\n\n.ag-theme-balham .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px;\n}\n\n.ag-theme-balham .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px;\n}\n\n.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px;\n}\n\n.ag-theme-balham .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px;\n}\n\n.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px;\n}\n\n.ag-theme-balham .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px;\n}\n\n.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px;\n}\n\n.ag-theme-balham .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px;\n}\n\n.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px;\n}\n\n.ag-theme-balham .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px;\n}\n\n.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px;\n}\n\n.ag-theme-balham .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px;\n}\n\n.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px;\n}\n\n.ag-theme-balham .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px;\n}\n\n.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px;\n}\n\n.ag-theme-balham .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px;\n}\n\n.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px;\n}\n\n.ag-theme-balham .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px;\n}\n\n.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px;\n}\n\n.ag-theme-balham .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px;\n}\n\n.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px;\n}\n\n.ag-theme-balham .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px;\n}\n.ag-theme-balham .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7);\n margin-top: 4px;\n}\n.ag-theme-balham .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px;\n}\n\n.ag-theme-balham .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px;\n}\n\n.ag-theme-balham .ag-pivot-mode-panel {\n min-height: 32px;\n height: 32px;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-balham .ag-pivot-mode-select {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-balham .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px;\n}\n\n.ag-theme-balham .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px;\n}\n\n.ag-theme-balham .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-column-select-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham .ag-column-select-header {\n height: 32px;\n -webkit-box-align: center;\n align-items: center;\n padding: 0 6px;\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7));\n}\n.ag-theme-balham .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7));\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7));\n}\n.ag-theme-balham .ag-column-group-icons,\n.ag-theme-balham .ag-column-select-header-icon {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-balham .ag-column-select-list .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #0091ea;\n background-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n}\n.ag-theme-balham .ag-column-select-list .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-balham .ag-column-select-list .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-balham .ag-header {\n background-color: #f5f7f7;\n background-color: var(--ag-header-background-color, #f5f7f7);\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-header-row {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)));\n height: 32px;\n}\n.ag-theme-balham .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px;\n}\n\n.ag-theme-balham .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px;\n}\n\n.ag-theme-balham .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px;\n}\n\n.ag-theme-balham .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px;\n}\n\n.ag-theme-balham .ag-header-cell,\n.ag-theme-balham .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px;\n}\n.ag-theme-balham .ag-header-cell.ag-header-cell-moving,\n.ag-theme-balham .ag-header-group-cell.ag-header-cell-moving {\n background-color: white;\n background-color: var(--ag-header-cell-moving-background-color, var(--ag-background-color, white));\n}\n.ag-theme-balham .ag-keyboard-focus .ag-header-cell:focus {\n outline: none;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-header-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-header-group-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham .ag-header-icon {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-balham .ag-header-expand-icon {\n cursor: pointer;\n}\n.ag-theme-balham .ag-ltr .ag-header-expand-icon {\n padding-left: 4px;\n}\n\n.ag-theme-balham .ag-rtl .ag-header-expand-icon {\n padding-right: 4px;\n}\n\n.ag-theme-balham .ag-header-row:not(:first-child) .ag-header-cell,\n.ag-theme-balham .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-header-cell::after,\n.ag-theme-balham .ag-header-group-cell::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n width: 1px;\n height: 50%;\n top: calc(50% - 25%);\n background-color: rgba(189, 195, 199, 0.5);\n background-color: var(--ag-header-column-separator-color, rgba(189, 195, 199, 0.5));\n}\n.ag-theme-balham .ag-ltr .ag-header-cell::after, .ag-theme-balham .ag-ltr .ag-header-group-cell::after {\n right: 0;\n}\n\n.ag-theme-balham .ag-rtl .ag-header-cell::after, .ag-theme-balham .ag-rtl .ag-header-group-cell::after {\n left: 0;\n}\n\n.ag-theme-balham .ag-ltr .ag-header-select-all {\n margin-right: 12px;\n}\n\n.ag-theme-balham .ag-rtl .ag-header-select-all {\n margin-left: 12px;\n}\n\n.ag-theme-balham .ag-ltr .ag-floating-filter-button {\n margin-left: 12px;\n}\n\n.ag-theme-balham .ag-rtl .ag-floating-filter-button {\n margin-right: 12px;\n}\n\n.ag-theme-balham .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 16px;\n padding: 0;\n width: 16px;\n}\n.ag-theme-balham .ag-filter-loading {\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1;\n}\n.ag-theme-balham .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 32px;\n}\n.ag-theme-balham .ag-paging-panel > * {\n margin: 0 12px;\n}\n.ag-theme-balham .ag-paging-button {\n cursor: pointer;\n}\n.ag-theme-balham .ag-paging-button.ag-disabled {\n cursor: default;\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n}\n.ag-theme-balham .ag-keyboard-focus .ag-paging-button:focus {\n outline: none;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-paging-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham .ag-paging-button, .ag-theme-balham .ag-paging-description {\n margin: 0 4px;\n}\n.ag-theme-balham .ag-status-bar {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5;\n}\n.ag-theme-balham .ag-status-name-value-value {\n color: #000;\n color: var(--ag-foreground-color, #000);\n}\n.ag-theme-balham .ag-status-bar-center {\n text-align: center;\n}\n.ag-theme-balham .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px;\n}\n.ag-theme-balham .ag-column-drop-cell {\n background: #dddede;\n background: var(--ag-chip-background-color, #dddede);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px;\n border: 1px solid transparent;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-column-drop-cell:focus {\n outline: none;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-column-drop-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 2px;\n left: 2px;\n display: block;\n width: calc(100% - 4px);\n height: calc(100% - 4px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham .ag-column-drop-cell-text {\n margin: 0 4px;\n}\n.ag-theme-balham .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-balham .ag-column-drop-cell-drag-handle {\n margin-left: 8px;\n}\n.ag-theme-balham .ag-column-drop-cell-ghost {\n opacity: 0.5;\n}\n.ag-theme-balham .ag-column-drop-horizontal {\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 28px;\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px;\n}\n\n.ag-theme-balham .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px;\n}\n\n.ag-theme-balham .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7);\n}\n\n.ag-theme-balham .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7);\n}\n\n.ag-theme-balham .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-balham .ag-column-drop-horizontal-empty-message {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n}\n.ag-theme-balham .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px;\n}\n\n.ag-theme-balham .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px;\n}\n\n.ag-theme-balham .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px;\n}\n.ag-theme-balham .ag-column-drop-vertical-cell {\n margin-top: 4px;\n}\n.ag-theme-balham .ag-column-drop-vertical {\n min-height: 50px;\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7));\n}\n.ag-theme-balham .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none;\n}\n.ag-theme-balham .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px;\n}\n.ag-theme-balham .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n margin-top: 4px;\n}\n.ag-theme-balham .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n background: white;\n background: var(--ag-background-color, white);\n height: 70px;\n padding: 0;\n}\n.ag-theme-balham .ag-select-agg-func-virtual-list-item {\n cursor: default;\n padding-left: 8px;\n}\n.ag-theme-balham .ag-select-agg-func-virtual-list-item:hover {\n background-color: #b7e4ff;\n background-color: var(--ag-selected-row-background-color, #b7e4ff);\n}\n.ag-theme-balham .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-balham .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham .ag-chart-menu {\n border-radius: 2px;\n background: white;\n background: var(--ag-background-color, white);\n}\n.ag-theme-balham .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 2px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-balham .ag-chart-menu-icon:hover {\n opacity: 1;\n}\n.ag-theme-balham .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: #bdc3c7;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7));\n border-radius: 5px;\n margin: 5px;\n}\n.ag-theme-balham .ag-chart-mini-thumbnail:nth-last-child(3), .ag-theme-balham .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto;\n}\n.ag-theme-balham .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0;\n}\n\n.ag-theme-balham .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0;\n}\n\n.ag-theme-balham .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0;\n}\n\n.ag-theme-balham .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0;\n}\n\n.ag-theme-balham .ag-chart-mini-thumbnail.ag-selected {\n border-color: #0091ea;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea)));\n}\n.ag-theme-balham .ag-chart-settings-card-item {\n background: #000;\n background: var(--ag-foreground-color, #000);\n width: 8px;\n height: 8px;\n border-radius: 4px;\n}\n.ag-theme-balham .ag-chart-settings-card-item.ag-selected {\n background-color: #0091ea;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea)));\n}\n.ag-theme-balham .ag-chart-data-column-drag-handle {\n margin-left: 4px;\n}\n.ag-theme-balham .ag-charts-settings-group-title-bar,\n.ag-theme-balham .ag-charts-data-group-title-bar,\n.ag-theme-balham .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7));\n}\n.ag-theme-balham .ag-charts-settings-group-container {\n padding: 4px;\n}\n.ag-theme-balham .ag-charts-data-group-container {\n padding: 3px 6px;\n}\n.ag-theme-balham .ag-charts-data-group-container .ag-charts-data-group-item:not(.ag-charts-format-sub-level-group) {\n height: 24px;\n}\n.ag-theme-balham .ag-charts-data-group-container .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #0091ea;\n background-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n}\n.ag-theme-balham .ag-charts-data-group-container .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-balham .ag-charts-data-group-container .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-balham .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px;\n}\n.ag-theme-balham .ag-charts-format-top-level-group-item {\n margin: 4px 0;\n}\n.ag-theme-balham .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px;\n}\n.ag-theme-balham .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px;\n}\n.ag-theme-balham .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px;\n}\n.ag-theme-balham .ag-chart-data-section,\n.ag-theme-balham .ag-chart-format-section {\n display: -webkit-box;\n display: flex;\n margin: 0;\n}\n.ag-theme-balham .ag-chart-menu-panel {\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7);\n}\n.ag-theme-balham .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7);\n}\n\n.ag-theme-balham .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7);\n}\n\n.ag-theme-balham .ag-date-time-list-page-title {\n -webkit-box-flex: 1;\n flex-grow: 1;\n text-align: center;\n}\n.ag-theme-balham .ag-date-time-list-page-column-label {\n text-align: center;\n}\n.ag-theme-balham .ag-date-time-list-page-entry {\n text-align: center;\n}\n.ag-theme-balham .ag-checkbox-input-wrapper {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: white;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, white));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-balham .ag-checkbox-input-wrapper input, .ag-theme-balham .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-balham .ag-checkbox-input-wrapper:focus-within, .ag-theme-balham .ag-checkbox-input-wrapper:active {\n outline: none;\n -webkit-box-shadow: 0 0 2px 1px #719ECE;\n box-shadow: 0 0 2px 1px #719ECE;\n}\n.ag-theme-balham .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-balham .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #7f8c8d;\n color: var(--ag-checkbox-unchecked-color, #7f8c8d);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-balham .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #0091ea;\n color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-balham .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #7f8c8d;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, #7f8c8d));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-balham .ag-toggle-button-input-wrapper {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n width: 32px;\n height: 16px;\n background-color: #7f8c8d;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, #7f8c8d));\n border-radius: 8px;\n position: relative;\n -webkit-box-flex: 0;\n flex: none;\n border: 1px solid;\n border-color: #7f8c8d;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #7f8c8d));\n}\n.ag-theme-balham .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%;\n}\n.ag-theme-balham .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n -webkit-box-shadow: 0 0 2px 1px #719ECE;\n box-shadow: 0 0 2px 1px #719ECE;\n}\n.ag-theme-balham .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-balham .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #0091ea;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea)));\n border-color: #0091ea;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea)));\n}\n.ag-theme-balham .ag-toggle-button-input-wrapper::before {\n content: \" \";\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n height: 16px;\n width: 16px;\n background-color: white;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, white));\n border-radius: 8px;\n -webkit-transition: left 100ms;\n transition: left 100ms;\n border: 1px solid;\n border-color: #7f8c8d;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #7f8c8d)));\n}\n.ag-theme-balham .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 16px );\n border-color: #0091ea;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea)));\n}\n.ag-theme-balham .ag-radio-button-input-wrapper {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: white;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, white));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n border-radius: 16px;\n}\n.ag-theme-balham .ag-radio-button-input-wrapper input, .ag-theme-balham .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-balham .ag-radio-button-input-wrapper:focus-within, .ag-theme-balham .ag-radio-button-input-wrapper:active {\n outline: none;\n -webkit-box-shadow: 0 0 2px 1px #719ECE;\n box-shadow: 0 0 2px 1px #719ECE;\n}\n.ag-theme-balham .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-balham .ag-radio-button-input-wrapper::after {\n content: \"\\f126\";\n color: #7f8c8d;\n color: var(--ag-checkbox-unchecked-color, #7f8c8d);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-balham .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f127\";\n color: #0091ea;\n color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-balham input[class^=ag-][type=range] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible;\n}\n.ag-theme-balham input[class^=ag-][type=range]::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #bdc3c7;\n background-color: var(--ag-border-color, #bdc3c7);\n border-radius: 2px;\n border-radius: 3px;\n}\n.ag-theme-balham input[class^=ag-][type=range]::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #bdc3c7;\n background-color: var(--ag-border-color, #bdc3c7);\n border-radius: 2px;\n border-radius: 3px;\n}\n.ag-theme-balham input[class^=ag-][type=range]::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #bdc3c7;\n background-color: var(--ag-border-color, #bdc3c7);\n border-radius: 2px;\n border-radius: 3px;\n color: transparent;\n width: calc(100% - 2px);\n}\n.ag-theme-balham input[class^=ag-][type=range]::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: white;\n background-color: var(--ag-background-color, white);\n border: 1px solid;\n border-color: #7f8c8d;\n border-color: var(--ag-checkbox-unchecked-color, #7f8c8d);\n border-radius: 16px;\n -webkit-transform: translateY(-6.5px);\n transform: translateY(-6.5px);\n}\n.ag-theme-balham input[class^=ag-][type=range]::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: white;\n background-color: var(--ag-background-color, white);\n border: 1px solid;\n border-color: #7f8c8d;\n border-color: var(--ag-checkbox-unchecked-color, #7f8c8d);\n border-radius: 16px;\n}\n.ag-theme-balham input[class^=ag-][type=range]::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: white;\n background-color: var(--ag-background-color, white);\n border: 1px solid;\n border-color: #7f8c8d;\n border-color: var(--ag-checkbox-unchecked-color, #7f8c8d);\n border-radius: 16px;\n}\n.ag-theme-balham input[class^=ag-][type=range]:focus {\n outline: none;\n}\n.ag-theme-balham input[class^=ag-][type=range]:focus::-webkit-slider-thumb {\n -webkit-box-shadow: 0 0 2px 1px #719ECE;\n box-shadow: 0 0 2px 1px #719ECE;\n border-color: #0091ea;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea));\n}\n.ag-theme-balham input[class^=ag-][type=range]:focus::-ms-thumb {\n box-shadow: 0 0 2px 1px #719ECE;\n border-color: #0091ea;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea));\n}\n.ag-theme-balham input[class^=ag-][type=range]:focus::-moz-ag-range-thumb {\n box-shadow: 0 0 2px 1px #719ECE;\n border-color: #0091ea;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea));\n}\n.ag-theme-balham input[class^=ag-][type=range]:active::-webkit-slider-runnable-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham input[class^=ag-][type=range]:active::-moz-ag-range-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham input[class^=ag-][type=range]:active::-ms-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE);\n}\n.ag-theme-balham input[class^=ag-][type=range]:disabled {\n opacity: 0.5;\n}\n.ag-theme-balham .ag-filter-toolpanel-header,\n.ag-theme-balham .ag-filter-toolpanel-search,\n.ag-theme-balham .ag-status-bar,\n.ag-theme-balham .ag-header-row,\n.ag-theme-balham .ag-multi-filter-group-title-bar {\n font-weight: 600;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)));\n}\n.ag-theme-balham .ag-ltr input[class^=ag-]:not([type]),\n.ag-theme-balham .ag-ltr input[class^=ag-][type=text],\n.ag-theme-balham .ag-ltr input[class^=ag-][type=number],\n.ag-theme-balham .ag-ltr input[class^=ag-][type=tel],\n.ag-theme-balham .ag-ltr input[class^=ag-][type=date],\n.ag-theme-balham .ag-ltr input[class^=ag-][type=datetime-local],\n.ag-theme-balham .ag-ltr textarea[class^=ag-] {\n padding-left: 4px;\n}\n\n.ag-theme-balham .ag-rtl input[class^=ag-]:not([type]),\n.ag-theme-balham .ag-rtl input[class^=ag-][type=text],\n.ag-theme-balham .ag-rtl input[class^=ag-][type=number],\n.ag-theme-balham .ag-rtl input[class^=ag-][type=tel],\n.ag-theme-balham .ag-rtl input[class^=ag-][type=date],\n.ag-theme-balham .ag-rtl input[class^=ag-][type=datetime-local],\n.ag-theme-balham .ag-rtl textarea[class^=ag-] {\n padding-right: 4px;\n}\n\n.ag-theme-balham .ag-column-drop-vertical-empty-message, .ag-theme-balham .ag-status-bar {\n font-weight: 600;\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n}\n.ag-theme-balham .ag-dnd-ghost {\n font-weight: 600;\n}\n.ag-theme-balham .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px;\n}\n.ag-theme-balham .ag-tab-selected {\n background-color: white;\n background-color: var(--ag-background-color, white);\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n border-bottom-color: transparent;\n}\n.ag-theme-balham .ag-tabs-header {\n border-bottom: 1px solid;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7);\n}\n.ag-theme-balham .ag-column-drop-cell {\n height: 24px;\n}\n.ag-theme-balham .ag-column-drop-vertical-title {\n color: #000;\n color: var(--ag-foreground-color, #000);\n}\n.ag-theme-balham .ag-column-drop-vertical-cell {\n margin-left: 8px;\n margin-right: 8px;\n}\n.ag-theme-balham .ag-column-drop-vertical-cell-text {\n margin-left: 8px;\n}\n.ag-theme-balham .ag-column-drop-vertical-icon {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-balham .ag-ltr .ag-column-drop-vertical-empty-message {\n padding-left: 24px;\n padding-right: 4px;\n}\n\n.ag-theme-balham .ag-rtl .ag-column-drop-vertical-empty-message {\n padding-right: 24px;\n padding-left: 4px;\n}\n\n.ag-theme-balham .ag-column-drop-horizontal {\n height: 32px;\n}\n.ag-theme-balham .ag-column-drop-empty {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n}\n.ag-theme-balham .ag-column-drop-horizontal-cell-text {\n margin-left: 8px;\n}\n.ag-theme-balham .ag-column-drop-vertical {\n padding-top: 8px;\n}\n.ag-theme-balham .ag-menu-header {\n background-color: #f5f7f7;\n background-color: var(--ag-header-background-color, #f5f7f7);\n}\n.ag-theme-balham .ag-overlay-loading-center {\n background-color: white;\n background-color: var(--ag-background-color, white);\n border: 1px solid;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n color: #000;\n color: var(--ag-foreground-color, #000);\n padding: 16px;\n}\n.ag-theme-balham .ag-tooltip {\n border: none;\n background-color: #cbd0d3;\n}\n.ag-theme-balham .ag-panel-title-bar-button-icon {\n font-size: 20px;\n}\n.ag-theme-balham .ag-chart-data-section,\n.ag-theme-balham .ag-chart-format-section {\n padding-bottom: 2px;\n}\n.ag-theme-balham .ag-group-toolbar {\n background-color: rgba(226, 233, 235, 0.5);\n background-color: var(--ag-subheader-toolbar-background-color, rgba(226, 233, 235, 0.5));\n}\n.ag-theme-balham .ag-chart-tab {\n padding-top: 2px;\n}\n.ag-theme-balham .ag-charts-format-sub-level-group-item {\n margin-bottom: 6px;\n}\n", ""]); // Exports module.exports = exports; /***/ }), -/* 236 */ +/* 289 */ /***/ (function(module, exports, __webpack_require__) { -var api = __webpack_require__(225); - var content = __webpack_require__(237); +var api = __webpack_require__(278); + var content = __webpack_require__(290); content = content.__esModule ? content.default : content; @@ -48650,24 +57595,24 @@ var update = api(content, options); module.exports = content.locals || {}; /***/ }), -/* 237 */ +/* 290 */ /***/ (function(module, exports, __webpack_require__) { // Imports -var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227); +var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(280); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, ".ag-theme-blue {\n -webkit-font-smoothing: antialiased;\n color: #222;\n color: var(--ag-foreground-color, #222);\n font-family: \"Helvetica Neue\", sans-serif;\n font-size: 14px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridClassic\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABOsAAsAAAAAJiwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlIAAAReYchjok9TLzIAAANcAAAAQQAAAFZWVlJ+Y21hcAAAA6AAAAHtAAAFgHClDfdnbHlmAAAFkAAACi0AABQQq+8lqmhlYWQAAA/AAAAANAAAADZ2z8SBaGhlYQAAD/QAAAAeAAAAJAfTBChobXR4AAAQFAAAABoAAAEou4L/4mxvY2EAABAwAAAAbwAAAJb7HvWgbWF4cAAAEKAAAAAfAAAAIAFgAHhuYW1lAAAQwAAAATMAAAJS8kTiWnBvc3QAABH0AAABtgAAApcplp2DeJx9k0lyE0EQRX+rZSMPyGDMZMRkRpsh3O5BjSTLltzyQHjBggULNmYBAeFg5ROw5gAEB+AUnIBgyYoDcACCA/Ay1UbGC6tC1VWZP3/+yspSIGlSy+qqUmzuPld9f+/gveZV1fBn/qPrYP/tmz3VDnf4qv6tKQj/qK4FvdCBvgUKXgefK+NhJeyGu+GH8FP4QyGoG3oMekorjFgJc6RUmZrKVdE4tpj1E7VAh8xtt87qgsbcU2ig8+SMiRk445Ke6o7OwNN3np7WQKUM4+wxbzHuauYERK578GeoWcVqrA10ntWENtHYQ0eH6BbeGXzrZI6I6eProy10VNXruK2XRM762SwyK3Ep/1gbvo9894AqHKLa8DfhN75Fsh7am2RKiHgEewaqW9Zwif8U3hRMRGzHa2bR10AmKEx1nZWdLOFk07oN+zO98qwbZUzPqzg88yLqR/a+8+XkOWrtwLUF9iEaRla7kfvkirSDf5KbKvROH/VFX/VdP/VLv3UK6ypeO8Ea3OsnVqZG/Y6jC7ztf1Y76Th3fhz1P2KCcze9NjG+QVlByzaFTqtNyjrCmjp+Ep2GL1CTU68qOSLPm2AdY6yyj0GfLruxxZj2Og/oAeuAeWqxwmxMw37L2V+GyVZDXRe9Wi14LvltWU3tJdV9Zz1vtzxPna/wjThZ5vXZxnsVizGNLA2PylFtHMv4c9SOspmqBqoSeqDmnbXjr6Ag003OMVSS6Ja/gB3vqgUUZOWLnNM5V98pb2rOcbFHBWiOypeces2sk/tos67Y+gsvGGrHAAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMnxi4gDQjSA4A1QYKdAAAAHictdQHTltBFIXh3wXTTEnvvRc6hGp6XQbpiBREOsoqs5O7gZBzPScLIFJG+nw9o+c3b/R8LtAB1OSp1KFap0KO31qttNdr9LTX6/zSvEkXVX0fYo8DjmL0+FirQ+yyz2FU2rO/o6Krm1zlPs80W2GMJeZZZZItxmlpdZEF1phhmg0mmGOKdXaYZZlNtvX7qnav6xkbdGrfbj1Jr+7YRz8DDHKaM5zlHOe5wEUucZkr2u0a17nBTW5xmzvc5Z72f8BDHvGYJzrPkD6HNRvRAzY42Vg54fU5xpbmVye3xls67cLazLQOOje1vjO7vLn9Dzf7D6OZH7Wfnu2Qb7PI0+7amDy3JXlh8/LSVuWVTcpr25I3Ni5vrSV7lv+QfVuUd7Yg721NPtiMfLRpObANObQJ+WRz8tmm5Iuty1fLs3+zWfluy/LDNuXI9AKjUmRWolqQtVZktqJeZL6io8jcRaMga2dB1q6CrN0FWXuKzGP0FmRtFvkmo68ga39B1oGCrIMFWU8VyhJhShVhyhdhShphyhxhSh9hyiFhSiRhyiZhSilhyithSi5hyjBhSjNhyjVhSjhhyjphSj1hyj9h6gSEqScQpu5AmPoEYeoRhKl3EKb+QVj2zbDMTFj7muGCrCNF+56jBSN/AHzNoH4AAAB4nO1Ye2xT1xm/37nEN87D8bUdXwezwLWJDZQCtmNfO4FATIgdQhLWGwhrt0DSGJHHpgaawFRatBIVVrXbHxXTWCiPabMHo9MgSH1IGxJMa6b+sbBJFZVK2/HHVNjI6JZ2k8W97DvHjzyggPrntBufe17fPec73/md3/edcMDhw4f4fs7IcSBLglwuW3mZD+mj+/ZBQtv//vtkhPxuYiIFe2EvijD5T/lPuUVYCQpeRRK8oswyRRZZJokyywQZLrXFxscbNwPf1oh5m65txjzWpuu0PdYGhF9k/LIuWm/czOXm3Mq/whViRfAaMYlu+NkbCeiG7sTZU2TPGz3QrR/vOavdzMmTSTLJFTN51AW1QX3IZOOFsdiFC7GxC41jUJ8rjTVe4Ao47q6O67rBWTk35+Ue41ZyXIHsWgFBsboOArK/EspFmwl42WXAgh1bQtjlgYDorgqUu3nM+T7N5qpx4Y/83VUjyzWyZjY7HGZyW5Qk7ReqCi2qmmpvJ66Ii3yGL/xpZfjifySJmig6HCL5hyjpY/q1ZBJO6jtw2Vm9bjK9luJ6coq4p5UrmKOTALheK9/HdHDldbo1Q5teffLf1aev8zdyKuRU2jJTk3f0ot/XH4YTc/XwPpoevByUH6jFX/Tz0PoQHfTSJN3OWfM/2uwPmvkhk9L14qL38T2IjELOwXEIOskIvLIQDAL+ldvsOEu11+Mlf9O31zyta1A3Pv7ur4uLK8rsvg0+e1kFXIJTtdihX4Y14+N1paWVTk+Fy+dzVVQtqKTDG9gcR/gjOJuAWC3DtUkcV1WOZsPEz8nhlH6ej+rnk7OydAofaEniA620zGV1v5HF8spHsxYghsvdQXcwEAzw/RmLadaMBcmkZmaWoZbT30uxJ2NBS9aCk1kLWlFCJLdw2y5QlVJMFfaK8lG2ShH1CYhy0I0sIYsyH5TFQJCMJvWSJEyp+hi0pPQxlYyyehrrp7AxzeV54Hn+eXqujYDbIRgB2UCBKbAM65PspU8OgwVfpG9WFSxYncElhxmXiAFkLDrAz0+eTejH9eMJ+C4xaVNYOQFdCe6r4p7u2oPQ9wO95GGoH0smp233Lq9wFZyPW43zK1IoYJfskgkBicwGobUQdLsQk17rCuI1CJUg2RXJgMikfyEUUFgJ5UGu9qyNHnpucNvSb9cF6xeZ9D+taPYW1T0WfvzAX0PfXF3UUO17pVX9uv9bT3ZtrYus9D85BFc3N5os9kq5uHY5b1qyyjLvieaDa3Z5GgJLiuFAEQG1wGBy6tcM4W1Bf7zhabujeN2CImN1VZ1/40ub9KO+TqskLZwfaHf+b65FQjwv4UK4FroORg1ZXUNYpm12Jac0QcB4qzxrwE3lJBRR4A5dQdvw/hd/uJ8q+Y0933umoXpdZ/euZ3Zs3ciULWnctbc3VgQboagtFAtVLQl5VvPlvNr84nBLW0nJRs8af/NI85Yz/vg2JWwwKP4eq2RfVBF+qjrUWcOXLlgGhcXzm22FAuEyPMo4px95DT2+VQbRG/SVB4Iq45Qk34/eZ3sq3d6elSV30I/yLDoQ3SI6Fq8gwVqVmC9fDqfTZFIvgSm94dIlrFDxkuxZvziL05zcwmmvqiDT5BI8pCwjH6WSyTT7ISN8WQlOJpMTSUaCJ+/NUKWC7Lovcl/jZK4KPenjlIcYsSLvZSk2n0R3UAZ3Ofr0TKrCBKeQYdFGyLY0p0zF8h3t0JqdjqnD96tovqSaxiytklhas6hwqh15TFXn2rTKLQaARicCuaOq2m1m1PQMi2b46iS/lfGVhIRHQzTYebpHPw7dPWdIDZw8nYmDzlCyJXe/uPsF/y/+n1w1159BpaGMuiwvYs+j4AEL+RkqsdUElQQb6sCDnUGfhxaxC6segXVTOSlgpx95q70+KsbkK0muuxL82KmEvB7yQsRmWxIeibQ2b2rZbcMnEi+qsAARyTxDhdNmCTY1OQ8usFidRgepWFpoL7JbwBpp2dTcGhkJL0FxSzkU2QuXOUhpsdFptToPOpuaghabs8IwjzcTsFQUxSN0XJyptfkozkQru9kAcaPZFPQXWgzznfGmkM3qHHHG406jaHY5lhYSg5nOxFQaCR9FcUuZQAqXOlxmo1BEBUecVluoKe6cb7AU+oMmszHOVjHzvBxBFC9kjCUgLJGs0FciYyE8cfPQYwaUoNctlJPY0eGjV6/iK5kv/Pjl7u6Xu8lvZjXSgvZWN+3i5s2KPZchNz5a5CmwoBYU5E5JeXDseevjmG80fAyuxT7xvR5+/SEBqFYX+2jVMRR//pOYD/O8H5qOVViUAtnEH7nzWz6aSelMNEJjEfrJV12bwsJ2XCIlnAev7bmPYquOKaNQHfuYKv2wtaWza3sNTXJMOZa/L7yKZ7KA7jA9jfAUO4ngzxFb5hw6+T9zpdN3EBY7SDDamwAveBO9vQn9A/2DRC8514ctWOrTX+rDNuzry8YSd1ksYeMWcwEaS9ATZqZOYxF1EWb0CKECemYDflqk8eVKehyZTzSU0+MIU4efHYxu2BAdfFb/bGgw2tAQHRyCCe3NUH00Nti1XYlI0rJ4qH49VjrDEcAafxOlh/TbQ7up9O4hMON3Gz7X3lwmSRGls3swFl0XaspUugbj0fpQDvdR9BMCcjiL2DBMC0iUKTFyo6y2M51Mqfp5FaZ4h5Ygo2qK8l/eVjTewxq4RckteN0KpVQy2Xkurarpc50wha5jvDed7oWwmuHnPE5k9Khhbu39kUIDBAaVWvRHwQKMIBExfOYeyg4mPaFWSuL0BjAHN9p3DlDcHEjx67R3SKUo/adk9eBgbcnFklqaDUxo10mjdA+CyO1kBkIkhiT9tkOE1ZkPMt+VkljyBbwzzMYR85Tk1Tk4IjMwQG9zbGPNFAaL6I6bKQwEBgsb7XHRejXtgalD+d0uyyHgMNvwiLK96zpuNj6dXfff7C10a693d1Lhzm4UViKz8biUxTD3w6PEVGQ+g4GS3nk8VtwJ3BvcGdyX+0LyUAZ+VKXrOSW/v37P4T3r2euR1dR3NGQ/Wb8nj60TWX/oVfACoMhBcvCXCejSTyROa38gsTOZUP50Ks/fA4jjUs5OYxh07XmeKcj+uyKAAH5L9blI3OXTxwZqJiZqBtrRCX8Ii/UP6Y0NFi8YqJ2YqB2A16bxTUbp6BhBpchP9DG8sJzPc8koYp/QO4pIYwS8nrRoO+f2kUz4wNdjwDU2Z0wj0CCjJSOR7UvyMYorI0HG4ZPaFf294YvwNrmiXYHgEJam9YrTnaVHABXTdiI4aXM+LnBzMa4D+dtumxsXLATalo0KQn6Jt/vz3t5gw96sr6dfCKxNAooH8LgyFbufPCEIHTNCgA7BKrQaDNvQn1MH2yHYBBemDuqm0cVvMxhaUaJjhivvEATiWG4y3fmpyWPCnO80ef54r0zL7FHgV7MnablXjTufL8cRcTgc1VuKw//fJvfa5L+BscYKAAAAeJxjYGRgYABi/jvPp8Xz23xl4GZ+ARSI4ny8rwFG///2/xvzZ+ZPQJUcDExAkgEAoUMP6XicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AIAnloHAgAAeJxjYGBgYH5Ba/z/G+3M/f+NgQ4AAPv8MfAAAHicY2AAAgmGIIYshhaGC4wijCGMPYz7GF8xGTGFMVUwTWC6wGzGPIf5BwsfiwZLCcsOlgssL1gnsB5iE2EzYGtim8K2jZ2HXYvdhX0Z+w72fxwRHAUcszhWcGzjOMJxieMZxxfOOi4O0iEAtgsblgB4nGNgZGBg8GLIYeBhAAEmIOYCQgaG/2A+AwAbuAHZAHicfZC9TsMwFIVP+odoBaoEYmAyCwtS+rPRtVKzd+ieJnaaKo2D41bqznPwBDxHn4OnYObEeCkStSXnu9899w4BMMQJAZoT4Ma9zWnhitUvt0n3njvkJ89dDBB67tG/eu7jBQvPA9zhjRuCzjXNI949t3CLD89t+k/PHfLJcxcP+PLco//23McqGHoe4DlQcRaZPJ0XcV3nyVJm+yI2Z+6sWElT57oUk3B85iNZShNbmYr1UdSHbGqtEsronVjo0sqi0KIyeisTG26srWajkfI+TPQOMTJEMMiRYo6Cdc2bI8ESkr29c+ZC7v/OihuMY40SAhP+9/GFfMR86WZiWH5Tzqxx5FvjwKkprYVirZjR2JEWbneTLng1TeV6W5qEPsTGTVWYYcSr/uRDprjpB8WrbRMAeJxtkmdv2zAURX1iyVbstEnTNt17D7VN994z/RUMRctEJFIgKY/8+rJxGiBA36dzHx7uu3xgZ6mzqEHn/7XFEl0SUnr0yVhmwJAVjnCUVdY4xjrHOcFJNjjFac5wlnOc5wIXucRlrnCVa1znBje5xW3ucJd73CfnAQ95xCaPecJTnvGcF7zkFa95w1ve8Z4PfOQTn/nCV77xnR/85Bdb/O4MRVk6VYqgrekJ5+zUd4WXPSmMVFUqx8KFNTlWcmfbzvI9UMXGQUObQgXlam1EUOsH7dbsT65IW1mXNzoK14+irY0fSGuCEzKoIpG2mafSWe+TQnmZqVkjomexrOYq95Xw4+EB5ZvdyL2RruLKdKSdD0npdJOWzrZNEkdCUqlR6FXaxN39yopCmzKrxUzXelcltTJtFrMulFGzkBhr1NDYkIuqslNVpE10Ud1Gm7TRExuyxqmJtq1fc9HM5tttCNbkdjRaPdwwqdPlOCReTNTA19EuL+zU7OPfWMMF7o1lC46pQzzNenBKHb5l1prFKwb/IN9EUOJQBDQWwxSPpGLMDtvM4lcoqGlpmDNil0mn8wcxorJdAAA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-blue .ag-icon {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-blue .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-blue .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-blue .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-blue .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-blue .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-blue .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-blue .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-blue .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-blue .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-blue .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-blue .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-blue .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-blue .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-blue .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-blue .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-blue .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-blue .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-blue .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-blue .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-blue .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-blue .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-blue .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-blue .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-blue .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-blue .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-blue .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-blue .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-blue .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-blue .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-blue .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-blue .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-blue .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-blue .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-blue .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-blue .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-blue .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-blue .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-blue .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-blue .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-blue .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-blue .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-blue .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-blue .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-blue .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-blue .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-blue .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-blue .ag-root-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-blue [class^='ag-'], .ag-theme-blue [class^='ag-']:focus, .ag-theme-blue [class^='ag-']:after, .ag-theme-blue [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-blue [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-blue .ag-checkbox .ag-input-wrapper,\n .ag-theme-blue .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-blue .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-blue .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-blue .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px; }\n .ag-theme-blue .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px; }\n .ag-theme-blue input[class^='ag-'] {\n margin: 0;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-blue textarea[class^='ag-'],\n .ag-theme-blue select[class^='ag-'] {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-blue input[class^='ag-']:not([type]),\n .ag-theme-blue input[class^='ag-'][type='text'],\n .ag-theme-blue input[class^='ag-'][type='number'],\n .ag-theme-blue input[class^='ag-'][type='tel'],\n .ag-theme-blue input[class^='ag-'][type='date'],\n .ag-theme-blue input[class^='ag-'][type='datetime-local'],\n .ag-theme-blue textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #000;\n border-color: var(--ag-input-border-color, #000); }\n .ag-theme-blue input[class^='ag-']:not([type]):disabled,\n .ag-theme-blue input[class^='ag-'][type='text']:disabled,\n .ag-theme-blue input[class^='ag-'][type='number']:disabled,\n .ag-theme-blue input[class^='ag-'][type='tel']:disabled,\n .ag-theme-blue input[class^='ag-'][type='date']:disabled,\n .ag-theme-blue input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-blue textarea[class^='ag-']:disabled {\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5));\n background-color: #dedede;\n background-color: var(--ag-input-disabled-background-color, #dedede);\n border-color: rgba(0, 0, 0, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(0, 0, 0, 0.3)); }\n .ag-theme-blue input[class^='ag-']:not([type]):focus,\n .ag-theme-blue input[class^='ag-'][type='text']:focus,\n .ag-theme-blue input[class^='ag-'][type='number']:focus,\n .ag-theme-blue input[class^='ag-'][type='tel']:focus,\n .ag-theme-blue input[class^='ag-'][type='date']:focus,\n .ag-theme-blue input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-blue textarea[class^='ag-']:focus {\n outline: none;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-blue input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-blue input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-blue input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-blue .ag-drag-handle {\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-list-item, .ag-theme-blue .ag-virtual-list-item {\n height: 20px; }\n .ag-theme-blue .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-select-list {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-blue .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-blue .ag-list-item.ag-active-item {\n background-color: #f0f0f0;\n background-color: var(--ag-row-hover-color, #f0f0f0); }\n .ag-theme-blue .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-blue .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-blue .ag-select .ag-picker-field-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n min-height: 20px;\n cursor: default; }\n .ag-theme-blue .ag-select:not(.ag-cell-editor) {\n height: 20px; }\n .ag-theme-blue .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-blue .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-blue .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-blue .ag-rich-select {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-blue .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 162.5px; }\n .ag-theme-blue .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6)); }\n .ag-theme-blue .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 20px; }\n .ag-theme-blue .ag-rich-select-virtual-list-item:hover {\n background-color: #f0f0f0;\n background-color: var(--ag-row-hover-color, #f0f0f0); }\n .ag-theme-blue .ag-rich-select-row {\n padding-left: 12px; }\n .ag-theme-blue .ag-rich-select-row-selected {\n background-color: #c8c8c8;\n background-color: var(--ag-selected-row-background-color, #c8c8c8); }\n .ag-theme-blue .ag-row-drag,\n .ag-theme-blue .ag-selection-checkbox,\n .ag-theme-blue .ag-group-expanded,\n .ag-theme-blue .ag-group-contracted {\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-ltr .ag-row-drag, .ag-theme-blue .ag-ltr .ag-selection-checkbox, .ag-theme-blue .ag-ltr .ag-group-expanded, .ag-theme-blue .ag-ltr .ag-group-contracted {\n margin-right: 12px; }\n .ag-theme-blue .ag-rtl .ag-row-drag, .ag-theme-blue .ag-rtl .ag-selection-checkbox, .ag-theme-blue .ag-rtl .ag-group-expanded, .ag-theme-blue .ag-rtl .ag-group-contracted {\n margin-left: 12px; }\n .ag-theme-blue .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 23px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-blue .ag-group-expanded,\n .ag-theme-blue .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-blue .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-blue .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-blue .ag-group-title-bar {\n background-color: #ececec;\n background-color: var(--ag-subheader-background-color, #ececec);\n padding: 4px; }\n .ag-theme-blue .ag-group-toolbar {\n padding: 4px; }\n .ag-theme-blue .ag-disabled-group-title-bar, .ag-theme-blue .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-blue .group-item {\n margin: 2px 0; }\n .ag-theme-blue .ag-label {\n white-space: nowrap; }\n .ag-theme-blue .ag-ltr .ag-label {\n margin-right: 4px; }\n .ag-theme-blue .ag-rtl .ag-label {\n margin-left: 4px; }\n .ag-theme-blue .ag-label-align-top .ag-label {\n margin-bottom: 2px; }\n .ag-theme-blue .ag-ltr .ag-slider-field, .ag-theme-blue .ag-ltr .ag-angle-select-field {\n margin-right: 8px; }\n .ag-theme-blue .ag-rtl .ag-slider-field, .ag-theme-blue .ag-rtl .ag-angle-select-field {\n margin-left: 8px; }\n .ag-theme-blue .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-blue .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #222;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n border-radius: 5px; }\n .ag-theme-blue .ag-picker-field-button {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-blue .ag-color-picker .ag-picker-field-display {\n height: 12px; }\n .ag-theme-blue .ag-color-panel {\n padding: 4px; }\n .ag-theme-blue .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-blue .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-blue .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-blue .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-blue .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-blue .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-blue .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-blue .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-blue .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-blue .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-blue .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-blue .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-blue.ag-dnd-ghost {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6));\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n height: 25px !important;\n line-height: 25px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px); }\n .ag-theme-blue .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #222;\n color: var(--ag-foreground-color, #222); }\n .ag-theme-blue .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3); }\n .ag-dragging-range-handle .ag-theme-blue .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-blue .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-blue .ag-dialog {\n border-radius: 0px;\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-panel {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-blue .ag-panel-title-bar {\n background-color: #5e9cd3;\n background-color: var(--ag-header-background-color, #5e9cd3);\n color: #fff;\n color: var(--ag-header-foreground-color, #fff);\n height: 25px;\n padding: 4px 12px;\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px; }\n .ag-theme-blue .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px; }\n .ag-theme-blue .ag-tooltip {\n background-color: #5e9cd3;\n background-color: var(--ag-header-background-color, #5e9cd3);\n color: #222;\n color: var(--ag-foreground-color, #222);\n padding: 4px;\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n border-radius: 0px;\n transition: opacity 1s; }\n .ag-theme-blue .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px; }\n .ag-theme-blue .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-blue .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 6px; }\n .ag-theme-blue .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 6px; }\n .ag-theme-blue .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-column-select-column-group:not(:last-child),\n .ag-theme-blue .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px; }\n .ag-theme-blue .ag-column-select-column-readonly,\n .ag-theme-blue .ag-column-select-column-group-readonly {\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5));\n pointer-events: none; }\n .ag-theme-blue .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 20px; }\n .ag-theme-blue .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 20px; }\n .ag-theme-blue .ag-column-select-list {\n padding: 6px 6px; }\n .ag-theme-blue .ag-rtl {\n text-align: right; }\n .ag-theme-blue .ag-root-wrapper {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n border-radius: 0px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 36px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 36px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-1 {\n padding-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-1 {\n padding-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 60px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 60px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-2 {\n padding-left: 48px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-2 {\n padding-right: 48px; }\n .ag-theme-blue .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 84px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 84px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-3 {\n padding-left: 72px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-3 {\n padding-right: 72px; }\n .ag-theme-blue .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 108px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 108px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-4 {\n padding-left: 96px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-4 {\n padding-right: 96px; }\n .ag-theme-blue .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 132px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 132px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-5 {\n padding-left: 120px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-5 {\n padding-right: 120px; }\n .ag-theme-blue .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 156px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 156px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-6 {\n padding-left: 144px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-6 {\n padding-right: 144px; }\n .ag-theme-blue .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 180px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 180px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-7 {\n padding-left: 168px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-7 {\n padding-right: 168px; }\n .ag-theme-blue .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 204px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 204px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-8 {\n padding-left: 192px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-8 {\n padding-right: 192px; }\n .ag-theme-blue .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 228px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 228px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-9 {\n padding-left: 216px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-9 {\n padding-right: 216px; }\n .ag-theme-blue .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 252px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 252px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-10 {\n padding-left: 240px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-10 {\n padding-right: 240px; }\n .ag-theme-blue .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 276px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 276px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-11 {\n padding-left: 264px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-11 {\n padding-right: 264px; }\n .ag-theme-blue .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 300px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 300px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-12 {\n padding-left: 288px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-12 {\n padding-right: 288px; }\n .ag-theme-blue .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 324px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 324px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-13 {\n padding-left: 312px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-13 {\n padding-right: 312px; }\n .ag-theme-blue .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 348px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 348px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-14 {\n padding-left: 336px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-14 {\n padding-right: 336px; }\n .ag-theme-blue .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 372px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 372px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-15 {\n padding-left: 360px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-15 {\n padding-right: 360px; }\n .ag-theme-blue .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 396px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 396px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-16 {\n padding-left: 384px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-16 {\n padding-right: 384px; }\n .ag-theme-blue .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 420px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 420px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-17 {\n padding-left: 408px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-17 {\n padding-right: 408px; }\n .ag-theme-blue .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 444px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 444px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-18 {\n padding-left: 432px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-18 {\n padding-right: 432px; }\n .ag-theme-blue .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 468px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 468px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-19 {\n padding-left: 456px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-19 {\n padding-right: 456px; }\n .ag-theme-blue .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-blue .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-blue .ag-value-change-delta-up {\n color: darkgreen;\n color: var(--ag-value-change-delta-up-color, darkgreen); }\n .ag-theme-blue .ag-value-change-delta-down {\n color: darkred;\n color: var(--ag-value-change-delta-down-color, darkred); }\n .ag-theme-blue .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-blue .ag-value-change-value-highlight {\n background-color: #cec;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec);\n transition: background-color 0.1s; }\n .ag-theme-blue .ag-cell-data-changed {\n background-color: #cec !important;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec) !important; }\n .ag-theme-blue .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-blue .ag-cell-highlight {\n background-color: rgba(136, 255, 136, 0.4) !important;\n background-color: var(--ag-range-selection-highlight-color, rgba(136, 255, 136, 0.4)) !important; }\n .ag-theme-blue .ag-row {\n height: 25px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: #222;\n color: var(--ag-data-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-row-highlight-above::after, .ag-theme-blue .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #222;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n left: 1px; }\n .ag-theme-blue .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-blue .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-blue .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-blue .ag-row-odd {\n background-color: #deebf7;\n background-color: var(--ag-odd-row-background-color, #deebf7); }\n .ag-theme-blue .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-row-hover {\n background-color: #f0f0f0;\n background-color: var(--ag-row-hover-color, #f0f0f0); }\n .ag-theme-blue .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-blue .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-blue .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-blue .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-blue .ag-cell {\n border: 1px solid transparent;\n line-height: 23px;\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-blue .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-blue .ag-row-dragging {\n cursor: move; }\n .ag-theme-blue .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-blue .ag-cell-inline-editing {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 25px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-blue .ag-popup-editor {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n padding: 0; }\n .ag-theme-blue .ag-large-text-input {\n height: auto;\n padding: 12px; }\n .ag-theme-blue .ag-details-row {\n padding: 20px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-blue .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66)); }\n .ag-theme-blue .ag-overlay-loading-center {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px; }\n .ag-theme-blue .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-blue .ag-loading {\n padding-left: 12px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-blue .ag-loading-icon {\n padding-right: 12px; }\n .ag-theme-blue .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-blue .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-ltr .ag-cell {\n border-right: dotted #9bc2e6; }\n .ag-theme-blue .ag-rtl .ag-cell {\n border-left: dotted #9bc2e6; }\n .ag-theme-blue .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-blue .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-blue .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-row-selected {\n background-color: #c8c8c8;\n background-color: var(--ag-selected-row-background-color, #c8c8c8); }\n .ag-theme-blue .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(34, 34, 34, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(34, 34, 34, 0.2)); }\n .ag-theme-blue .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1);\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)); }\n .ag-theme-blue .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)); }\n .ag-theme-blue .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(34, 34, 34, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(34, 34, 34, 0.2))); }\n .ag-theme-blue .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(34, 34, 34, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(34, 34, 34, 0.36)); }\n .ag-theme-blue .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(34, 34, 34, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(34, 34, 34, 0.488)); }\n .ag-theme-blue .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(34, 34, 34, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(34, 34, 34, 0.5904)); }\n .ag-theme-blue .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #222;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #222;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #222;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #222;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-blue .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-blue .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-blue .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-blue .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-blue .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n outline: initial; }\n .ag-theme-blue .ag-cell.ag-selection-fill-top,\n .ag-theme-blue .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #222;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-blue .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #222;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-blue .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #222;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-cell.ag-selection-fill-bottom,\n .ag-theme-blue .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #222;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-blue .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #222;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-blue .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #222;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-fill-handle, .ag-theme-blue .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #222;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-ltr .ag-fill-handle, .ag-theme-blue .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-blue .ag-rtl .ag-fill-handle, .ag-theme-blue .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-blue .ag-fill-handle {\n cursor: cell; }\n .ag-theme-blue .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-blue .ag-cell-inline-editing {\n border-color: var(--ag-input-focus-border-color) !important; }\n .ag-theme-blue .ag-menu {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n padding: 0; }\n .ag-theme-blue .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-blue .ag-menu-option-part {\n padding-top: 6px;\n padding-bottom: 6px;\n line-height: 12px; }\n .ag-theme-blue .ag-menu-option-active {\n background-color: #f0f0f0;\n background-color: var(--ag-row-hover-color, #f0f0f0); }\n .ag-theme-blue .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-blue .ag-menu-option-text {\n margin-left: 4px; }\n .ag-theme-blue .ag-menu-option-icon {\n padding-left: 8px;\n padding-right: 4px;\n min-width: 20px; }\n .ag-theme-blue .ag-menu-option-shortcut {\n padding-left: 8px; }\n .ag-theme-blue .ag-menu-separator {\n height: 8px; }\n .ag-theme-blue .ag-menu-separator-cell:after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-menu-option-popup-pointer {\n width: 20px;\n text-align: center; }\n .ag-theme-blue .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-blue .ag-tab {\n border-bottom: 0 solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer; }\n .ag-theme-blue .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-tab-selected {\n border-bottom-color: #222;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #222))); }\n .ag-theme-blue .ag-menu-header {\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-blue .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px; }\n .ag-theme-blue .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px; }\n .ag-theme-blue .ag-set-filter-select-all {\n padding-top: 6px; }\n .ag-theme-blue .ag-set-filter-list {\n height: 120px; }\n .ag-theme-blue .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px; }\n .ag-theme-blue .ag-filter-to {\n margin-top: 4px; }\n .ag-theme-blue .ag-mini-filter {\n margin: 6px 6px;\n margin-bottom: 0; }\n .ag-theme-blue .ag-set-filter-item {\n margin: 0px 6px; }\n .ag-theme-blue .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px; }\n .ag-theme-blue .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px; }\n .ag-theme-blue .ag-filter-header-container {\n padding-bottom: 6px;\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6)); }\n .ag-theme-blue .ag-filter-apply-panel {\n padding: 6px 6px;\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6)); }\n .ag-theme-blue .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-blue .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px; }\n .ag-theme-blue .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px; }\n .ag-theme-blue .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-blue .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px; }\n .ag-theme-blue .ag-filter-no-matches {\n margin: 6px 6px; }\n .ag-theme-blue .ag-side-bar {\n position: relative; }\n .ag-theme-blue .ag-tool-panel-wrapper {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-blue .ag-side-buttons {\n padding-top: 16px;\n width: 16px;\n position: relative;\n color: #222;\n color: var(--ag-foreground-color, #222);\n overflow: hidden; }\n .ag-theme-blue button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: calc(100% + 1px);\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-selected .ag-side-button-button {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-blue .ag-ltr .ag-side-bar-left,\n .ag-theme-blue .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-blue .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-blue .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent;\n margin-right: -1px;\n padding-right: 1px; }\n .ag-theme-blue .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-blue .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #222;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #222))); }\n .ag-theme-blue .ag-rtl .ag-side-bar-left,\n .ag-theme-blue .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-blue .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-blue .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent;\n margin-left: -1px;\n padding-left: 1px; }\n .ag-theme-blue .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-blue .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #222;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #222))); }\n .ag-theme-blue .ag-filter-toolpanel-header {\n height: 24px; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-header, .ag-theme-blue .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-header, .ag-theme-blue .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px; }\n .ag-theme-blue .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 4px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 4px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-0-header {\n height: 32px; }\n .ag-theme-blue .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px; }\n .ag-theme-blue .ag-filter-toolpanel-search {\n height: 25px; }\n .ag-theme-blue .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 16px; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6)); }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px; }\n .ag-theme-blue .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px; }\n .ag-theme-blue .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6);\n padding-top: 4px; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px; }\n .ag-theme-blue .ag-pivot-mode-panel {\n height: 25px;\n display: flex; }\n .ag-theme-blue .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-blue .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px; }\n .ag-theme-blue .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px; }\n .ag-theme-blue .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-column-select-header {\n height: 25px;\n align-items: center;\n padding: 0 6px;\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6)); }\n .ag-theme-blue .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6));\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6)); }\n .ag-theme-blue .ag-column-group-icons,\n .ag-theme-blue .ag-column-select-header-icon {\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-header {\n background-color: #5e9cd3;\n background-color: var(--ag-header-background-color, #5e9cd3);\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-header-row {\n color: #fff;\n color: var(--ag-header-foreground-color, #fff); }\n .ag-theme-blue .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-header-row {\n height: 25px; }\n .ag-theme-blue .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-blue .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-blue .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-blue .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-blue .ag-header-cell,\n .ag-theme-blue .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px; }\n .ag-theme-blue .ag-header-cell.ag-header-cell-moving,\n .ag-theme-blue .ag-header-group-cell.ag-header-cell-moving {\n background-color: #9bc2e6;\n background-color: var(--ag-header-cell-moving-background-color, #9bc2e6); }\n .ag-theme-blue .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-header-icon {\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-blue .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-blue .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-blue .ag-header-row:not(:first-child) .ag-header-cell,\n .ag-theme-blue .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-header-cell::after,\n .ag-theme-blue .ag-header-group-cell::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n width: 1px;\n height: 100%;\n top: calc(50% - 50%);\n background-color: rgba(155, 194, 230, 0.5);\n background-color: var(--ag-header-column-separator-color, rgba(155, 194, 230, 0.5)); }\n .ag-theme-blue .ag-ltr .ag-header-cell::after, .ag-theme-blue .ag-ltr .ag-header-group-cell::after {\n right: 0; }\n .ag-theme-blue .ag-rtl .ag-header-cell::after, .ag-theme-blue .ag-rtl .ag-header-group-cell::after {\n left: 0; }\n .ag-theme-blue .ag-ltr .ag-header-select-all {\n margin-right: 12px; }\n .ag-theme-blue .ag-rtl .ag-header-select-all {\n margin-left: 12px; }\n .ag-theme-blue .ag-ltr .ag-floating-filter-button {\n margin-left: 12px; }\n .ag-theme-blue .ag-rtl .ag-floating-filter-button {\n margin-right: 12px; }\n .ag-theme-blue .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 12px;\n padding: 0;\n width: 12px; }\n .ag-theme-blue .ag-filter-loading {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-blue .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n height: 25px; }\n .ag-theme-blue .ag-paging-panel > * {\n margin: 0 12px; }\n .ag-theme-blue .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 12px; }\n .ag-theme-blue .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-blue .ag-paging-button-wrapper.ag-disabled {\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5));\n cursor: default; }\n .ag-theme-blue .ag-paging-button-wrapper, .ag-theme-blue .ag-paging-description {\n margin: 0 4px; }\n .ag-theme-blue .ag-status-bar {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5; }\n .ag-theme-blue .ag-status-name-value-value {\n color: #222;\n color: var(--ag-foreground-color, #222); }\n .ag-theme-blue .ag-status-bar-center {\n text-align: center; }\n .ag-theme-blue .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px; }\n .ag-theme-blue .ag-column-drop-cell {\n background: #ddebf7;\n background: var(--ag-chip-background-color, #ddebf7);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px; }\n .ag-theme-blue .ag-column-drop-cell-text {\n margin: 0 4px; }\n .ag-theme-blue .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-column-drop-cell-drag-handle {\n margin-left: 8px; }\n .ag-theme-blue .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-blue .ag-column-drop-horizontal {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px; }\n .ag-theme-blue .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px; }\n .ag-theme-blue .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-column-drop-horizontal-empty-message {\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5)); }\n .ag-theme-blue .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px; }\n .ag-theme-blue .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px; }\n .ag-theme-blue .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px; }\n .ag-theme-blue .ag-column-drop-vertical-cell {\n margin-top: 4px; }\n .ag-theme-blue .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px;\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6)); }\n .ag-theme-blue .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none; }\n .ag-theme-blue .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px; }\n .ag-theme-blue .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-blue .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5));\n margin-top: 4px; }\n .ag-theme-blue .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n background: #fff;\n background: var(--ag-background-color, #fff);\n height: 70px;\n padding: 0; }\n .ag-theme-blue .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 20px;\n padding-left: 8px; }\n .ag-theme-blue .ag-select-agg-func-virtual-list-item:hover {\n background-color: #c8c8c8;\n background-color: var(--ag-selected-row-background-color, #c8c8c8); }\n .ag-theme-blue .ag-chart-menu {\n border-radius: 0px;\n background: #fff;\n background: var(--ag-background-color, #fff); }\n .ag-theme-blue .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 0px;\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-blue .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: #9bc2e6;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6));\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-blue .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-blue .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-blue .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-blue .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-blue .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-blue .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-blue .ag-chart-mini-thumbnail.ag-selected {\n border-color: #222;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222))); }\n .ag-theme-blue .ag-chart-settings-card-item {\n background: #222;\n background: var(--ag-foreground-color, #222);\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-blue .ag-chart-settings-card-item.ag-selected {\n background-color: #222;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222))); }\n .ag-theme-blue .ag-chart-data-column-drag-handle {\n margin-left: 4px; }\n .ag-theme-blue .ag-charts-settings-group-title-bar,\n .ag-theme-blue .ag-charts-data-group-title-bar,\n .ag-theme-blue .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6)); }\n .ag-theme-blue .ag-charts-settings-group-container {\n padding: 4px; }\n .ag-theme-blue .ag-charts-data-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-blue .ag-charts-data-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-blue .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px; }\n .ag-theme-blue .ag-charts-format-top-level-group-item {\n margin: 4px 0; }\n .ag-theme-blue .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-blue .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-blue .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px; }\n .ag-theme-blue .ag-chart-data-section,\n .ag-theme-blue .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-blue .ag-chart-menu-panel {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-blue .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-blue .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-blue .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-blue .ag-checkbox-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-blue .ag-checkbox-input-wrapper input, .ag-theme-blue .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-blue .ag-checkbox-input-wrapper:focus-within, .ag-theme-blue .ag-checkbox-input-wrapper:active {\n outline: none; }\n .ag-theme-blue .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-blue .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #222;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-blue .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #222;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-blue .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #222;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222)));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-blue .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 24px;\n height: 12px;\n background-color: #222;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222)));\n border-radius: 6px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222))); }\n .ag-theme-blue .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-blue .ag-toggle-button-input-wrapper:focus-within {\n outline: none; }\n .ag-theme-blue .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-blue .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #222;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222)));\n border-color: #222;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222))); }\n .ag-theme-blue .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n background-color: #fff;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #fff));\n border-radius: 6px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222)))); }\n .ag-theme-blue .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 12px);\n border-color: #222;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222))); }\n .ag-theme-blue .ag-radio-button-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 12px; }\n .ag-theme-blue .ag-radio-button-input-wrapper input, .ag-theme-blue .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-blue .ag-radio-button-input-wrapper:focus-within, .ag-theme-blue .ag-radio-button-input-wrapper:active {\n outline: none; }\n .ag-theme-blue .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-blue .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #222;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-blue .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #222;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-blue input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-blue input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #9bc2e6;\n background-color: var(--ag-border-color, #9bc2e6);\n border-radius: 0px;\n border-radius: 0px; }\n .ag-theme-blue input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #9bc2e6;\n background-color: var(--ag-border-color, #9bc2e6);\n border-radius: 0px;\n border-radius: 0px; }\n .ag-theme-blue input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #9bc2e6;\n background-color: var(--ag-border-color, #9bc2e6);\n border-radius: 0px;\n border-radius: 0px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-blue input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222));\n border-radius: 12px;\n -webkit-transform: translateY(-4.5px);\n transform: translateY(-4.5px); }\n .ag-theme-blue input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222));\n border-radius: 12px; }\n .ag-theme-blue input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222));\n border-radius: 12px; }\n .ag-theme-blue input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-blue input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n border-color: #222;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue input[class^='ag-'][type='range']:focus::-ms-thumb {\n border-color: #222;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n border-color: #222;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue input[class^='ag-'][type='range']:active::-ms-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-blue .ag-icon {\n color: #333; }\n .ag-theme-blue .ag-icon-tree-closed::before {\n content: \"\\f10b\"; }\n .ag-theme-blue .ag-icon-tree-open::before {\n content: \"\\f10f\"; }\n .ag-theme-blue .ag-header, .ag-theme-blue .ag-column-drop-cell {\n background-image: none; }\n .ag-theme-blue .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px; }\n .ag-theme-blue .ag-tabs-body {\n margin: 2px 0; }\n .ag-theme-blue .ag-icon {\n margin: 1px 1px 2px 1px; }\n .ag-theme-blue .ag-tab-selected {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n border-bottom-color: transparent; }\n .ag-theme-blue .ag-tabs-header {\n background-color: #5e9cd3;\n background-color: var(--ag-header-background-color, #5e9cd3);\n border-bottom: 1px solid;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-filter .ag-filter-apply-panel {\n justify-content: flex-start; }\n .ag-theme-blue .ag-menu-option-active {\n background-color: #c8c8c8;\n background-color: var(--ag-selected-row-background-color, #c8c8c8); }\n .ag-theme-blue .ag-column-drop-cell {\n border: 1px solid;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n border-radius: 0; }\n .ag-theme-blue .ag-column-drop-cell-button .ag-icon {\n border: 1px solid transparent; }\n .ag-theme-blue .ag-column-drop-cell-button:hover .ag-icon {\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-panel-title-bar-button-icon {\n font-size: 20px;\n line-height: 20px; }\n .ag-theme-blue .ag-menu-option-part {\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-blue .ag-column-drop-vertical-title-bar {\n margin-top: 4px;\n margin-left: 4px; }\n .ag-theme-blue .ag-column-drop-vertical-title {\n margin-left: 4px; }\n .ag-theme-blue .ag-column-drop-vertical-empty-message {\n margin-left: 24px; }\n\n", ""]); +exports.push([module.i, ".ag-theme-blue {\n -webkit-font-smoothing: antialiased;\n color: #222;\n color: var(--ag-foreground-color, #222);\n font-family: \"Helvetica Neue\", sans-serif;\n font-size: 14px;\n line-height: normal;\n}\n@font-face {\n font-family: \"agGridClassic\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABXwAAsAAAAAKrgAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAmMAAAR2Zoxou09TLzIAAANsAAAAQQAAAFZWVlMSY21hcAAAA7AAAAIbAAAFnIlT7KJnbHlmAAAFzAAADBkAABg4HeN0mGhlYWQAABHoAAAANAAAADZ2z8SBaGhlYQAAEhwAAAAeAAAAJAfTBCxobXR4AAASPAAAABgAAAE4yyH/7GxvY2EAABJUAAAAdgAAAJ5JCULobWF4cAAAEswAAAAfAAAAIAFkAKpuYW1lAAAS7AAAATMAAAJS8kTiWnBvc3QAABQgAAABzQAAArBhTs2TeJx9lMtOU1EUhv/DaREoAlG8pCIiGi+oiMrxXHpoy6WH1tbEgTEOnGBMjAlxxHP4AD4BQ5/AB3DgE/gADhw6Nn5r9WCFAey03Xtd/vXvf62NAklTWlNTYzvF4KVm9vcOPqquioZ/5v9/H+x/eL+niaMTvor/TiioTGtGy3qtA30LZoKD4HBsPqyHr8J34efwS/hLIVFLWiW6pqesWAnfkVJlaijXmMaxxew34BOymmq59RyMqu7pqqfL1IzJ6Tniip7xmQOncJyOtolKWYbZ4XvAuqfZUyJy3Qc/g80m1gqKLKJJrnlNgp4Q01Sb/Cb+89TcoXaEv8BXwK6KpcW+rQtwsoyKq9rVGz3Bbzc1lKzMSfnE2vVz5Kc1NDmKaoHToJZhr8LgyN6gakLGY9AzorZKRVd0k+wGOB3Q2p694dnLRCZwS3WDnd0zges08Zle6K1X3S1zOq7pUIFV2I/shePlenjM2gZrQOwjOIys1p8H1IrUx1+jV4X29UmH+qrv+qGf+q0/OqOL1En8Dtug75yqzQQKnozu4m39s9pdx5mBk1HHIya5ecPVifH1Sg2tWo2bmTop+whr6vFT8LT4Lmxy+lGhRuR1rdNV1ibnmOiz5XQ2WdOudI8pmPUJ7vss1HWHvi064nAOc7S+CqLthvyuuG5N8Ba8b6auvbA5P9lbsH7XmdVr/EbcMHOdnuO9jsWQRpYlz8phbxjr+HNYj6oZqwVYresuPpuxvr+OLpVucZ8hk4QIexl9n6/bMMjKlzpPD419u+zYJY+LPSvgP0FUvvDUtbOZLuBm8zH4C3G+c6UAeJxjYGSazTiBgZWBgamKaQ8DA0MPhGZ8wGDIyAQUZWBlZsAKAtJcUxgOMOh+NGJ+AeRGMX9i4ALSjCA5AOaCCwgAAAB4nLXUB1IbQRCF4V+BLMA22eQcBQaTcxAiHwJnCgcKZ87hs/kefQL8Rt0+AK7yVn3bO1Or3ZlavQaqgJzMSB6ytWR0RSar2UxlPkd9ZT7Pb40L1JLVdZErbrizhft7zRa55Jpby1RGf4+M7i7QwxjLGh2yxAE7lFnlXDN7rLPPLkdsssEJK2yzxjFnbFHilAv9Pq0irzVWU6P31mklDXpiI0084jEttNJGOx100kW33tRLH/0MMMgQw4wwyjgTTDLFtHZSZJY5njHPgs7PNVrUIqt52HH4wPvTsXSwU149X97TjnePNje02e2147Ot0unFPzzsPxyFdMr9itEZ6Yu6tNvLsCQvwoG8DDvyKpTldViVN+Fc3ob0b3gX9uQqrMt12Jf3YVc+hCP5GDblU9iQm3Ait2FFPodt+RLW5Gs4lm8h7f172JIfoSQ/w6ncBX1Ay7iUF8s6Us25lC/Lu5Qxq3Ipe1btSLXGkWqtI9U6R6r1LmXSGhypFlz6ktboSLXJkWqzU3awoBRhQXnCnjglC2txyhjW6pQ2rM0pd1i7UwKxDqcsYp1OqcS6nPKJPXVKKtbtlFmsxym9WK9TjrE+p0Rj/U7ZxgacUo4NOuUdG3JKPjbs1AOwEadugI069QVszKlDYONOvQKbcKkv2qRLebApp96BTTv1FGzGqa9gRac+g806dRxszlXuCepC2LyrPHPBsfgHpKymyQB4nO1Ye2wUxxnfmfXt3t57d+92zxycvXf4FkNico+99QMMGOOzcWzTnIMJaQ04GMWYRDEESJqktAElJErSShFVqUmAqj0XmlQFI+XRBxKpGleRGqePNKnyKn+0Sdq4pHXS6uRb+s3eww8ooPSfVu3Zu/P6Zuabb34z3+9bClHwo5P0IMVRFFJkVvEpIq3QSWN4717Un7v/9dfxAfzT8fERtBftBRFT/n36faoSChqr6jKr8oqZ6ApvJjKvmAmroHNdqbGxlnWIXgdpap2RW9cCaZdhkPpUF8J0JdcFVS1dlzblu1LFOdfTj1FWKLAqBw8fRt9+th/1ob7+Z47jXc9uRX3G01ufyX1YlMcTeIKym/KgC2gD+uCJljOjqTNnUqNnWkbRqmJutOUMZaGoiwas6wNKpMKUSi2hllKURQnVII1PNKK4EgsiH+91IVoJMZCRoCYJTREU58NVcV+YhpTenhOV+lCoXsEfwUupV3Iej9/vwRd4Wc59N51GHen0SHc3DtWF8Mfwgv+cG17012U+x/N+P4//wsvGqPF2JoOOGZth2bP0WgzrKSoSnlbOMkcnFsF6RZnebioRKik1MUOdAWPi74kT59fSHxSVKCp180xdXjRsP1t1EB1dRM3VRb02XWhFU66oyO+N06jzKloYzgzZ0lnzX9vsV5r5KpOS9cKi76G3AjqslJ+iAHgyh2i9AjEs/Pm8EsySUCMq/pOxqf42I4cax8Ze/oHdXu6WomuikrscnUPHG6DBeAktHxtrdDqDgUh5KBoNlVfND5LhGXOOQ/QhmI0FvLphbTJFVfnAbPDQc1J03DhNNxmnM7OS7Aj8UEcGfqiT5KmC7h8UbLX02qyFAMe+sBbW4lqcHgwRi4Hl8hYkljMtQyxnvDJi/vIWFAoWnChYUAQJHn8E23aGqDRCUUV9mugmc5U86BPnFS0MN4XCK7Sm8HEND2cMRwZNpo1R1DFijKbxsFnOQvk4VGap0l3wAP0AOdscgu1gOQQ3go4mkbDHmDBfxsQeJMALb59VRAIU8za/OEXfSf+Z8oB1FlCt1Jepp2DoCOykZYZF6LCGQEFGlhqQWOV14XCopkxLNOI4saWXCUXUGhSGDt4giiX1RhSTZGLgEFRriWQsSMcJPmqQWoOJuWNBXOiU71OBJDmI4WZK6tFGsj9enxu5MGzPUhq6S/Qd7La7LEanqusqTqp6y6jRhB7BiLZ4foeNTZwQ9Hpkr8dmcfoVUV4o2pzWMqvXLc93yJUSg60u2ykhJC3gnR7OZWWtbgcv2QWPN8ALFZLg5602J1tmcQcFxm4RBLtTsC1bshjT2Gq3WrCGWZvbweA4jWyCFf/RuudBC65Vp141lXlkfOpR+p7flHN87mu/dVQERasQqKzyhbSId74qcG6b0+dNxCqXSH6/ze1yl1dLbnuVYHfZy3mHLLh4K8OKSk2V6PT5fR6b3S2ITs7O0SxrYcUFT/zwR5ydsbFOm4X7Nee2ci7uF27O5hGo/+/df/XeFf34QdOP83FgC+TgfufYM/3G08bT/ehe7MpNQuEo2tIPomVz9rrtqvusQ2skkYzHpAq0ApNtk3xeN5Jhe1woFFmKWAKEiJa48vZcf0s7x1q8bl70LFtpczFOq1v0dXY7bJzgFco29JRxPNRcybBj9w66nHbJI/o3bnQLFovHwS+44163T3BxHLPvi4yV4d2mTf4X1vjZeAPxelfy3k8YjquxhtFMZtr3vEzrVDkVpZbB/LqcjEuyJLvAoQM7RMkVSAuHwKerYg1WGTaIZEmXGWJp+EuCgGl1FeSRkoisaHr4vqEN1Xc0aqsqXcYva9pVW+OS2uv3/SH5+WW25kT0sc7052Jf2LhlfWPd0tjG3eiNdS0uQQoq9obraNeiG4Sym9r3L7890hxfZEf7bBilLYwrYLzN1G7QYq3Nt0l++8r5Ni5R1Rhb+9CNxuForyjLFfPi3YHptcjgQxdRSVgLWYdJRwq6JiFP6iS9qDS5ldSqyHIUJnIyiOhoiqyga8/9D371fqLkLbu+cldzYmVv3+13bV6/1lTW0XL73oGUDa1Ftq5kKlm1KBlZRvvodPuDezq6HI61keWx9gPtN5+MtW7QaxlGj20VZamyvPbWRLK3nnbOX4ys9nntXiuLqTx3M3nODuBSEGmICuJVLeqLa2mTx2ToQWC9m0ay3d0FWTwF/J02oxI+zAOhVVkZrUhjz0sv1WazeMJwoEmj+dw5KBBxR4FfnJ3FowJUxTSb14HdFB90lbwCHGgkk8ma/8BC/lUOHctkxjMm8Tp2aQIqWQrrPgtnW6GqqGrqesJ9TDIHXKtA60oPH9YUFPZBLJF/quBBx4HVgY2A4ZGUsCMz3dyNOgvTmerQg2kwXyadhSSbxqlsTkij493AndLp/xg95uxtVZiPIxKdsXgqnc5dMDc3O2Nn8z7jGL3e9BkykD0SoqJtJ/Je4iSuR8dO5OPAk4Ro4oufXvyU/hv9VypBDeZPB+MmdB08txrR4aCDc5bztS4UxFDRiIhb16IRkoUmcv+yZjORk+MS6aQm1CgRM+WDuNgM5AEa9aQawV+q83oX1R6o62y/sWOnF351rbZyAWEelzHlAa+gtbUF9s8XxADnx+XVVskmCUis67ixvbPuQO0iEBd8yCZZF/ux084FRDGwP9DWpgneQDlTBoMgodzWWkfGhZk62w/DTKSw0xyglfO4tJhVYOYFWtuSXjFwINDaGuB4T8hfbcWMh8xkqnSg9jCIC24WW6v9IQ/H2ojggYDoTba1BuYxgjWmuTxcq7mKmef2EJymCvPmZOF4wKUJcQLcnHBMYPMgWojrmhpmfTh1eM/hN96AV6aU+cajfX2P9uEfz6okmdzzfaTJ9IEzY9zoNUberBnUIx3ucFm/cuz90bup6HDtEfR26r3oU7VPXSUAzzWm3rnhCIg/8F4qCmnJh0zHaWaEhgoPfWjqJ3RT/snmIzEShxX9+2dZm25+toAlkovvymu7753UDUf0YZRIvUuUvtrasoW1PQkmOaIfKX0veRzOpIXsMDmN6FbzJKJY8YLNn8MA/SvKOf0NxuRvMhoe6EcqUvsHBvqNN403+wfwqe1QA7ntxkPboQ7athd4wEWwxYeUl1pIxQkPICfMQ5xXJXFVHvBMSQs5s/EYyZLYeik5jqZvBt5NTufkwbuHmtasaRq62/h491BTc3PT0G40nnsuuaopNbRlk14ny4vbtFWrodBbW+eXF9MfgvBu48LunUR4527kgW5rPsk9t1iW6/TevqFU08pkW76wZai1aVWyhPsmehB2252PViFEjcvkpoSoldxq27KZkbRxOo0maX+uHw+nR8j992/2RaU4GUoozMthVg3r5DrGE72nsul09lQvmgT3NzaQzQ6g2nTex5QwpgArqKVWXB5lhOSYMGsAn6pZIPIm7DL/Dc881OR0i8QBkC8nczCXu3Mfwdy+EXpl7kUc5OV/OBuGhhocZx1msmM8dx63yJegD1/I5OGHU3DBv+Dn0TLHjH5OnMp8iZfnYND09vjxORjEM/BTDVImKDwEQpUELR4CIdaElJe0hEyiTFrQ5MMlpLiL6DlogqVO37TlPAAFfr1bLo+Umwkuzvf1EuHePhDW62ZjudrkYZfDsmyqSGArmYAm34oiIuHpNShhho2XhfPDQ0WNzhd1fGT1roO7Vpuva9bS2Nxc6LJ613T8dbTgS1Wdg0fR8P7v9aMtxtH+E7mf49TJfCh2YqSE40HAsZOSCA8DWlC6oyyFT71xAPDz6WgIt4aixuiO+vHx+h3d4MDfQguNt8iXLrRw/o6G8fGGHejJaXzjYTI6sMAR/E1jFA8bp0v30DBgH5NvOzzhF2gSdeS2zW3DeepBrwLSODpnTA4RgtKRlyi0ZegUwRUHATuiM7nXjFf2nEUv4NdyryFtN+Sm9WolO0uOACiW2wbgJNUlThGmUlQP3P2Sdy6nqECkrsAokjGZlmIlpsB4obXAE0gP1qyTEcEDioTyBSmGb2LZnhn0oYcV2U6G2QBcgDjnHtbLhuDpIS4e6MEGhukEiZ4ZNKCHZbH/Opdr6luuiAtSutcVefVSmY7Zo6Dvz56k41I1pj65DkaE4WBU1QnD/xPnjHQ0AAAAeJxjYGRgYADiY81JvPH8Nl8ZuJlfAAWiOB/va4DR/7/9/8b8mfkTUCUHAxOQZAAAhKEPOXicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AMAnl4HBgAAeJxjYGBgYH5Bb/z/Gy3NZqADAAB/FDOneJxjYAACCYYghiyGFoYLjGKMYYx9jAcY3zCZMEUwVTFHsJix+LEcYDViLWK9wWbC5sWWwraB7Qu7BXsAewaHAIcTxxSODZxMnCKcZpw9nKs4T3A+4nLhCuOaw/WNm4/bgtuNO4Q7ibuAu4V7Eo8M6RAAslkbZAAAeJxjYGRgYPBjmMfAwwACTEDMBYQMDP/BfAYAIQYCDwB4nH2QvU7DMBSFT/qHaAWqBGJgMgsLUvqz0bVSs3foniZ2miqNg+NW6s5z8AQ8R5+Dp2DmxHgpErUl57vfPfcOATDECQGaE+DGvc1p4YrVL7dJ95475CfPXQwQeu7Rv3ru4wULzwPc4Y0bgs41zSPePbdwiw/PbfpPzx3yyXMXD/jy3KP/9tzHKhh6HuA5UHEWmTydF3Fd58lSZvsiNmfurFhJU+e6FJNwfOYjWUoTW5mK9VHUh2xqrRLK6J1Y6NLKotCiMnorExturK1mo5HyPkz0DjEyRDDIkWKOgnXNmyPBEpK9vXPmQu7/zoobjGONEgIT/vfxhXzEfOlmYlh+U86sceRb48CpKa2FYq2Y0diRFm53ky54NU3leluahD7Exk1VmGHEq/7kQ6a46QfFq20TAHicbZIHb9swEIX9xZKt2GmTpm269x5q6+6990h/A0PRMhGZFEjKdvLry9pBgQA9gIf3Dod37w5sLbUW0Wv9PzZZok1CSocuGcv06LPCAQ6yyhqHWOcwRzjKBsc4zglOcorTnOEs5zjPBS5yictc4SrXuM4NbnKL2+Tc4S73GHCfBzzkEY95wlOe8ZwXvOQVr3nDW97xng985BOf+cJXvvGdH/zkF5v8bvVFWTpViqCt6Qjn7NS3hZcdKYxUVSpHwoU1OVJye8vO8jlQxca/gjaFCsqNtRFBrf8rN2avc0Xayrq81pG4biTN2PietCY4IYMqEmnrnVQ6631b+kkaXz5ICuVlqmbRQHee80GmZrWIs4pltaNyXwk/akfUGeoqjk+H2vmQlE7XaelsU3fnOSrFxpBUahg6lTbRT7eyotCmzMZipsd6VyVjZZos+l8wo2YhMdaovrEhF1Vlp6pI66iiuvOcD9q1NmmtJzZktVMTbRu/5qKozbeaEKzJ7XC4ur9gUqfLUUi8mKieH0fZvLBTswf/2usv4LwtW+CmTkI823pwSu2/c9aYxTYIShyKgMZimOKRVIzYZotZ/CMFYxpqdpgwZLfV+gPpZLiDAAAA\") format(\"woff\");\n font-weight: normal;\n font-style: normal;\n}\n.ag-theme-blue .ag-icon {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n.ag-theme-blue .ag-icon-aggregation::before {\n content: \"\\f101\";\n}\n.ag-theme-blue .ag-icon-arrows::before {\n content: \"\\f102\";\n}\n.ag-theme-blue .ag-icon-asc::before {\n content: \"\\f103\";\n}\n.ag-theme-blue .ag-icon-cancel::before {\n content: \"\\f104\";\n}\n.ag-theme-blue .ag-icon-chart::before {\n content: \"\\f105\";\n}\n.ag-theme-blue .ag-icon-color-picker::before {\n content: \"\\f109\";\n}\n.ag-theme-blue .ag-icon-columns::before {\n content: \"\\f10a\";\n}\n.ag-theme-blue .ag-icon-contracted::before {\n content: \"\\f10b\";\n}\n.ag-theme-blue .ag-icon-copy::before {\n content: \"\\f10c\";\n}\n.ag-theme-blue .ag-icon-cross::before {\n content: \"\\f10d\";\n}\n.ag-theme-blue .ag-icon-csv::before {\n content: \"\\f10e\";\n}\n.ag-theme-blue .ag-icon-desc::before {\n content: \"\\f10f\";\n}\n.ag-theme-blue .ag-icon-excel::before {\n content: \"\\f110\";\n}\n.ag-theme-blue .ag-icon-expanded::before {\n content: \"\\f111\";\n}\n.ag-theme-blue .ag-icon-eye-slash::before {\n content: \"\\f112\";\n}\n.ag-theme-blue .ag-icon-eye::before {\n content: \"\\f113\";\n}\n.ag-theme-blue .ag-icon-filter::before {\n content: \"\\f114\";\n}\n.ag-theme-blue .ag-icon-first::before {\n content: \"\\f115\";\n}\n.ag-theme-blue .ag-icon-grip::before {\n content: \"\\f116\";\n}\n.ag-theme-blue .ag-icon-group::before {\n content: \"\\f117\";\n}\n.ag-theme-blue .ag-icon-last::before {\n content: \"\\f118\";\n}\n.ag-theme-blue .ag-icon-left::before {\n content: \"\\f119\";\n}\n.ag-theme-blue .ag-icon-linked::before {\n content: \"\\f11a\";\n}\n.ag-theme-blue .ag-icon-loading::before {\n content: \"\\f11b\";\n}\n.ag-theme-blue .ag-icon-maximize::before {\n content: \"\\f11c\";\n}\n.ag-theme-blue .ag-icon-menu::before {\n content: \"\\f11d\";\n}\n.ag-theme-blue .ag-icon-minimize::before {\n content: \"\\f11e\";\n}\n.ag-theme-blue .ag-icon-next::before {\n content: \"\\f11f\";\n}\n.ag-theme-blue .ag-icon-none::before {\n content: \"\\f120\";\n}\n.ag-theme-blue .ag-icon-not-allowed::before {\n content: \"\\f121\";\n}\n.ag-theme-blue .ag-icon-paste::before {\n content: \"\\f122\";\n}\n.ag-theme-blue .ag-icon-pin::before {\n content: \"\\f123\";\n}\n.ag-theme-blue .ag-icon-pivot::before {\n content: \"\\f124\";\n}\n.ag-theme-blue .ag-icon-previous::before {\n content: \"\\f125\";\n}\n.ag-theme-blue .ag-icon-right::before {\n content: \"\\f128\";\n}\n.ag-theme-blue .ag-icon-save::before {\n content: \"\\f129\";\n}\n.ag-theme-blue .ag-icon-small-down::before {\n content: \"\\f12a\";\n}\n.ag-theme-blue .ag-icon-small-left::before {\n content: \"\\f12b\";\n}\n.ag-theme-blue .ag-icon-small-right::before {\n content: \"\\f12c\";\n}\n.ag-theme-blue .ag-icon-small-up::before {\n content: \"\\f12d\";\n}\n.ag-theme-blue .ag-icon-tick::before {\n content: \"\\f12e\";\n}\n.ag-theme-blue .ag-icon-tree-closed::before {\n content: \"\\f12f\";\n}\n.ag-theme-blue .ag-icon-tree-indeterminate::before {\n content: \"\\f130\";\n}\n.ag-theme-blue .ag-icon-tree-open::before {\n content: \"\\f131\";\n}\n.ag-theme-blue .ag-icon-unlinked::before {\n content: \"\\f132\";\n}\n.ag-theme-blue .ag-icon-row-drag::before {\n content: \"\\f116\";\n}\n.ag-theme-blue .ag-left-arrow::before {\n content: \"\\f119\";\n}\n.ag-theme-blue .ag-right-arrow::before {\n content: \"\\f128\";\n}\n.ag-theme-blue .ag-root-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-blue [class^=ag-], .ag-theme-blue [class^=ag-]:focus, .ag-theme-blue [class^=ag-]:after, .ag-theme-blue [class^=ag-]:before {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n outline: none;\n}\n.ag-theme-blue [class^=ag-]::-ms-clear {\n display: none;\n}\n.ag-theme-blue .ag-checkbox .ag-input-wrapper,\n.ag-theme-blue .ag-radio-button .ag-input-wrapper {\n overflow: visible;\n}\n.ag-theme-blue .ag-range-field .ag-input-wrapper {\n height: 100%;\n}\n.ag-theme-blue .ag-toggle-button {\n -webkit-box-flex: 0;\n flex: none;\n width: unset;\n min-width: unset;\n}\n.ag-theme-blue .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px;\n}\n\n.ag-theme-blue .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px;\n}\n\n.ag-theme-blue input[class^=ag-] {\n margin: 0;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-blue textarea[class^=ag-],\n.ag-theme-blue select[class^=ag-] {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-blue input[class^=ag-]:not([type]),\n.ag-theme-blue input[class^=ag-][type=text],\n.ag-theme-blue input[class^=ag-][type=number],\n.ag-theme-blue input[class^=ag-][type=tel],\n.ag-theme-blue input[class^=ag-][type=date],\n.ag-theme-blue input[class^=ag-][type=datetime-local],\n.ag-theme-blue textarea[class^=ag-] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #000;\n border-color: var(--ag-input-border-color, #000);\n}\n.ag-theme-blue input[class^=ag-]:not([type]):disabled,\n.ag-theme-blue input[class^=ag-][type=text]:disabled,\n.ag-theme-blue input[class^=ag-][type=number]:disabled,\n.ag-theme-blue input[class^=ag-][type=tel]:disabled,\n.ag-theme-blue input[class^=ag-][type=date]:disabled,\n.ag-theme-blue input[class^=ag-][type=datetime-local]:disabled,\n.ag-theme-blue textarea[class^=ag-]:disabled {\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5));\n background-color: #dedede;\n background-color: var(--ag-input-disabled-background-color, #dedede);\n border-color: rgba(0, 0, 0, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(0, 0, 0, 0.3));\n}\n.ag-theme-blue input[class^=ag-]:not([type]):focus,\n.ag-theme-blue input[class^=ag-][type=text]:focus,\n.ag-theme-blue input[class^=ag-][type=number]:focus,\n.ag-theme-blue input[class^=ag-][type=tel]:focus,\n.ag-theme-blue input[class^=ag-][type=date]:focus,\n.ag-theme-blue input[class^=ag-][type=datetime-local]:focus,\n.ag-theme-blue textarea[class^=ag-]:focus {\n outline: none;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-blue input[class^=ag-]:not([type]):invalid,\n.ag-theme-blue input[class^=ag-][type=text]:invalid,\n.ag-theme-blue input[class^=ag-][type=number]:invalid,\n.ag-theme-blue input[class^=ag-][type=tel]:invalid,\n.ag-theme-blue input[class^=ag-][type=date]:invalid,\n.ag-theme-blue input[class^=ag-][type=datetime-local]:invalid,\n.ag-theme-blue textarea[class^=ag-]:invalid {\n border-width: 2px;\n border-style: solid;\n border-color: var(--ag-input-border-color-invalid);\n}\n.ag-theme-blue input[class^=ag-][type=number] {\n -moz-appearance: textfield;\n}\n.ag-theme-blue input[class^=ag-][type=number]::-webkit-outer-spin-button, .ag-theme-blue input[class^=ag-][type=number]::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n}\n.ag-theme-blue input[class^=ag-][type=range] {\n padding: 0;\n}\n.ag-theme-blue .ag-drag-handle {\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-list-item, .ag-theme-blue .ag-virtual-list-item {\n height: 20px;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-blue .ag-select-list {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n overflow-y: auto;\n overflow-x: hidden;\n}\n.ag-theme-blue .ag-list-item {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-blue .ag-list-item.ag-active-item {\n background-color: #f0f0f0;\n background-color: var(--ag-row-hover-color, #f0f0f0);\n}\n.ag-theme-blue .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n user-select: none;\n}\n.ag-theme-blue .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n.ag-theme-blue .ag-select .ag-picker-field-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n min-height: 20px;\n cursor: default;\n}\n.ag-theme-blue .ag-select.ag-disabled .ag-picker-field-wrapper:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-blue .ag-select:not(.ag-cell-editor) {\n height: 20px;\n}\n.ag-theme-blue .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-blue .ag-select .ag-picker-field-icon {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-blue .ag-select.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-blue .ag-rich-select {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n}\n.ag-theme-blue .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 162.5px;\n}\n.ag-theme-blue .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6));\n}\n.ag-theme-blue .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 20px;\n}\n.ag-theme-blue .ag-rich-select-virtual-list-item:hover {\n background-color: #f0f0f0;\n background-color: var(--ag-row-hover-color, #f0f0f0);\n}\n.ag-theme-blue .ag-rich-select-row {\n padding-left: 12px;\n}\n.ag-theme-blue .ag-rich-select-row-selected {\n background-color: #c8c8c8;\n background-color: var(--ag-selected-row-background-color, #c8c8c8);\n}\n.ag-theme-blue .ag-row-drag,\n.ag-theme-blue .ag-selection-checkbox,\n.ag-theme-blue .ag-group-expanded,\n.ag-theme-blue .ag-group-contracted {\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-ltr .ag-row-drag, .ag-theme-blue .ag-ltr .ag-selection-checkbox, .ag-theme-blue .ag-ltr .ag-group-expanded, .ag-theme-blue .ag-ltr .ag-group-contracted {\n margin-right: 12px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-drag, .ag-theme-blue .ag-rtl .ag-selection-checkbox, .ag-theme-blue .ag-rtl .ag-group-expanded, .ag-theme-blue .ag-rtl .ag-group-contracted {\n margin-left: 12px;\n}\n\n.ag-theme-blue .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: min(var(--ag-row-height, 23px), 23px);\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-blue .ag-group-expanded,\n.ag-theme-blue .ag-group-contracted {\n cursor: pointer;\n}\n.ag-theme-blue .ag-group-title-bar-icon {\n cursor: pointer;\n -webkit-box-flex: 0;\n flex: none;\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-ltr .ag-group-child-count {\n margin-left: 2px;\n}\n\n.ag-theme-blue .ag-rtl .ag-group-child-count {\n margin-right: 2px;\n}\n\n.ag-theme-blue .ag-group-title-bar {\n background-color: #ececec;\n background-color: var(--ag-subheader-background-color, #ececec);\n padding: 4px;\n}\n.ag-theme-blue .ag-group-toolbar {\n padding: 4px;\n}\n.ag-theme-blue .ag-disabled-group-title-bar, .ag-theme-blue .ag-disabled-group-container {\n opacity: 0.5;\n}\n.ag-theme-blue .group-item {\n margin: 2px 0;\n}\n.ag-theme-blue .ag-label {\n white-space: nowrap;\n}\n.ag-theme-blue .ag-ltr .ag-label {\n margin-right: 4px;\n}\n\n.ag-theme-blue .ag-rtl .ag-label {\n margin-left: 4px;\n}\n\n.ag-theme-blue .ag-label-align-top .ag-label {\n margin-bottom: 2px;\n}\n.ag-theme-blue .ag-ltr .ag-slider-field, .ag-theme-blue .ag-ltr .ag-angle-select-field {\n margin-right: 8px;\n}\n\n.ag-theme-blue .ag-rtl .ag-slider-field, .ag-theme-blue .ag-rtl .ag-angle-select-field {\n margin-left: 8px;\n}\n\n.ag-theme-blue .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-blue .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #222;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n border-radius: 5px;\n}\n.ag-theme-blue .ag-picker-field-button {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-dialog.ag-color-dialog {\n border-radius: 5px;\n}\n.ag-theme-blue .ag-color-picker .ag-picker-field-display {\n height: 12px;\n}\n.ag-theme-blue .ag-color-panel {\n padding: 4px;\n}\n.ag-theme-blue .ag-spectrum-color {\n background-color: red;\n border-radius: 2px;\n}\n.ag-theme-blue .ag-spectrum-tools {\n padding: 10px;\n}\n.ag-theme-blue .ag-spectrum-sat {\n background-image: -webkit-gradient(linear, left top, right top, from(white), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0));\n}\n.ag-theme-blue .ag-spectrum-val {\n background-image: -webkit-gradient(linear, left bottom, left top, from(black), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0));\n}\n.ag-theme-blue .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n -webkit-box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n}\n.ag-theme-blue .ag-spectrum-hue-background {\n border-radius: 2px;\n}\n.ag-theme-blue .ag-spectrum-alpha-background {\n border-radius: 2px;\n}\n.ag-theme-blue .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px;\n}\n.ag-theme-blue .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n -webkit-box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n}\n.ag-theme-blue .ag-recent-color {\n margin: 0 3px;\n}\n.ag-theme-blue .ag-recent-color:first-child {\n margin-left: 0;\n}\n.ag-theme-blue .ag-recent-color:last-child {\n margin-right: 0;\n}\n.ag-theme-blue.ag-dnd-ghost {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6));\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n height: 25px !important;\n line-height: 25px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px);\n}\n.ag-theme-blue .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #222;\n color: var(--ag-foreground-color, #222);\n}\n.ag-theme-blue .ag-popup-child:not(.ag-tooltip-custom) {\n -webkit-box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3);\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3);\n}\n.ag-dragging-range-handle .ag-theme-blue .ag-dialog, .ag-dragging-fill-handle .ag-theme-blue .ag-dialog {\n opacity: 0.7;\n pointer-events: none;\n}\n.ag-theme-blue .ag-dialog {\n border-radius: 0px;\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-panel {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-blue .ag-panel-title-bar {\n background-color: #5e9cd3;\n background-color: var(--ag-header-background-color, #5e9cd3);\n color: #fff;\n color: var(--ag-header-foreground-color, #fff);\n height: 25px;\n padding: 4px 12px;\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px;\n}\n\n.ag-theme-blue .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px;\n}\n\n.ag-theme-blue .ag-tooltip {\n background-color: #5e9cd3;\n background-color: var(--ag-header-background-color, #5e9cd3);\n color: #222;\n color: var(--ag-foreground-color, #222);\n padding: 4px;\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n border-radius: 0px;\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n white-space: normal;\n}\n.ag-theme-blue .ag-tooltip.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-blue .ag-tooltip-custom {\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n}\n.ag-theme-blue .ag-tooltip-custom.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-blue .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px;\n}\n\n.ag-theme-blue .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px;\n}\n\n.ag-theme-blue .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px;\n}\n\n.ag-theme-blue .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px;\n}\n\n.ag-theme-blue .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px;\n}\n\n.ag-theme-blue .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px;\n}\n\n.ag-theme-blue .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px;\n}\n\n.ag-theme-blue .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px;\n}\n\n.ag-theme-blue .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px;\n}\n\n.ag-theme-blue .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px;\n}\n\n.ag-theme-blue .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px;\n}\n\n.ag-theme-blue .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px;\n}\n\n.ag-theme-blue .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px;\n}\n\n.ag-theme-blue .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px;\n}\n\n.ag-theme-blue .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px;\n}\n\n.ag-theme-blue .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px;\n}\n\n.ag-theme-blue .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px;\n}\n\n.ag-theme-blue .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px;\n}\n\n.ag-theme-blue .ag-column-select-header-icon {\n cursor: pointer;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-column-select-header-icon:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-blue .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 8px;\n}\n\n.ag-theme-blue .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 8px;\n}\n\n.ag-theme-blue .ag-keyboard-focus .ag-column-select-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-column-select-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-blue .ag-column-select-column-group:not(:last-child),\n.ag-theme-blue .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px;\n}\n.ag-theme-blue .ag-column-select-column-readonly,\n.ag-theme-blue .ag-column-select-column-group-readonly {\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5));\n pointer-events: none;\n}\n.ag-theme-blue .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 20px;\n}\n\n.ag-theme-blue .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 20px;\n}\n\n.ag-theme-blue .ag-column-select-virtual-list-viewport {\n padding: 3px 0px;\n}\n.ag-theme-blue .ag-column-select-virtual-list-item {\n padding: 0 6px;\n}\n.ag-theme-blue .ag-rtl {\n text-align: right;\n}\n.ag-theme-blue .ag-root-wrapper {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 36px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 36px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-1 {\n padding-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-1 {\n padding-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-1 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-1 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 60px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 60px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-2 {\n padding-left: 48px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-2 {\n padding-right: 48px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-2 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-2 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 84px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 84px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-3 {\n padding-left: 72px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-3 {\n padding-right: 72px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-3 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-3 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 108px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 108px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-4 {\n padding-left: 96px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-4 {\n padding-right: 96px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-4 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-4 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 132px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 132px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-5 {\n padding-left: 120px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-5 {\n padding-right: 120px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-5 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-5 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 156px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 156px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-6 {\n padding-left: 144px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-6 {\n padding-right: 144px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-6 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-6 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 180px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 180px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-7 {\n padding-left: 168px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-7 {\n padding-right: 168px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-7 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-7 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 204px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 204px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-8 {\n padding-left: 192px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-8 {\n padding-right: 192px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-8 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-8 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 228px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 228px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-9 {\n padding-left: 216px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-9 {\n padding-right: 216px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-9 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-9 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 252px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 252px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-10 {\n padding-left: 240px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-10 {\n padding-right: 240px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-10 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-10 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 276px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 276px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-11 {\n padding-left: 264px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-11 {\n padding-right: 264px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-11 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-11 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 300px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 300px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-12 {\n padding-left: 288px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-12 {\n padding-right: 288px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-12 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-12 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 324px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 324px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-13 {\n padding-left: 312px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-13 {\n padding-right: 312px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-13 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-13 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 348px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 348px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-14 {\n padding-left: 336px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-14 {\n padding-right: 336px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-14 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-14 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 372px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 372px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-15 {\n padding-left: 360px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-15 {\n padding-right: 360px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-15 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-15 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 396px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 396px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-16 {\n padding-left: 384px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-16 {\n padding-right: 384px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-16 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-16 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 420px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 420px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-17 {\n padding-left: 408px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-17 {\n padding-right: 408px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-17 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-17 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 444px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 444px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-18 {\n padding-left: 432px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-18 {\n padding-right: 432px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-18 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-18 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 468px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 468px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-19 {\n padding-left: 456px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-19 {\n padding-right: 456px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-19 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-19 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-left: 492px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-right: 492px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-20 {\n padding-left: 480px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-20 {\n padding-right: 480px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-20 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-20 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-left: 516px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-right: 516px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-21 {\n padding-left: 504px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-21 {\n padding-right: 504px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-21 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-21 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-left: 540px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-right: 540px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-22 {\n padding-left: 528px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-22 {\n padding-right: 528px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-22 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-22 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-left: 564px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-right: 564px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-23 {\n padding-left: 552px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-23 {\n padding-right: 552px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-23 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-23 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-left: 588px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-right: 588px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-24 {\n padding-left: 576px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-24 {\n padding-right: 576px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-24 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-24 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-left: 612px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-right: 612px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-25 {\n padding-left: 600px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-25 {\n padding-right: 600px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-25 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-25 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-left: 636px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-right: 636px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-26 {\n padding-left: 624px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-26 {\n padding-right: 624px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-26 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-26 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-left: 660px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-right: 660px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-27 {\n padding-left: 648px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-27 {\n padding-right: 648px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-27 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-27 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-left: 684px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-right: 684px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-28 {\n padding-left: 672px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-28 {\n padding-right: 672px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-28 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-28 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-left: 708px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-right: 708px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-29 {\n padding-left: 696px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-29 {\n padding-right: 696px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-29 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-29 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-left: 732px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-right: 732px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-30 {\n padding-left: 720px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-30 {\n padding-right: 720px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-30 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-30 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-left: 756px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-right: 756px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-31 {\n padding-left: 744px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-31 {\n padding-right: 744px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-31 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-31 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-left: 780px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-right: 780px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-32 {\n padding-left: 768px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-32 {\n padding-right: 768px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-32 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-32 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-left: 804px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-right: 804px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-33 {\n padding-left: 792px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-33 {\n padding-right: 792px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-33 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-33 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-left: 828px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-right: 828px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-34 {\n padding-left: 816px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-34 {\n padding-right: 816px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-34 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-34 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-left: 852px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-right: 852px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-35 {\n padding-left: 840px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-35 {\n padding-right: 840px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-35 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-35 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-left: 876px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-right: 876px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-36 {\n padding-left: 864px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-36 {\n padding-right: 864px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-36 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-36 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-left: 900px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-right: 900px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-37 {\n padding-left: 888px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-37 {\n padding-right: 888px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-37 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-37 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-left: 924px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-right: 924px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-38 {\n padding-left: 912px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-38 {\n padding-right: 912px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-38 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-38 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-left: 948px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-right: 948px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-39 {\n padding-left: 936px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-39 {\n padding-right: 936px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-39 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-39 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-left: 972px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-right: 972px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-40 {\n padding-left: 960px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-40 {\n padding-right: 960px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-40 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-40 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-left: 996px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-right: 996px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-41 {\n padding-left: 984px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-41 {\n padding-right: 984px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-41 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-41 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-left: 1020px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-right: 1020px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-42 {\n padding-left: 1008px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-42 {\n padding-right: 1008px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-42 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-42 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-left: 1044px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-right: 1044px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-43 {\n padding-left: 1032px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-43 {\n padding-right: 1032px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-43 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-43 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-left: 1068px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-right: 1068px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-44 {\n padding-left: 1056px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-44 {\n padding-right: 1056px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-44 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-44 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-left: 1092px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-right: 1092px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-45 {\n padding-left: 1080px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-45 {\n padding-right: 1080px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-45 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-45 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-left: 1116px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-right: 1116px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-46 {\n padding-left: 1104px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-46 {\n padding-right: 1104px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-46 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-46 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-left: 1140px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-right: 1140px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-47 {\n padding-left: 1128px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-47 {\n padding-right: 1128px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-47 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-47 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-left: 1164px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-right: 1164px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-48 {\n padding-left: 1152px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-48 {\n padding-right: 1152px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-48 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-48 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-left: 1188px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-right: 1188px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-49 {\n padding-left: 1176px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-49 {\n padding-right: 1176px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-49 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-49 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-left: 1212px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-right: 1212px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-50 {\n padding-left: 1200px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-50 {\n padding-right: 1200px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-50 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-50 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-left: 1236px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-right: 1236px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-51 {\n padding-left: 1224px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-51 {\n padding-right: 1224px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-51 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-51 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-left: 1260px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-right: 1260px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-52 {\n padding-left: 1248px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-52 {\n padding-right: 1248px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-52 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-52 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-left: 1284px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-right: 1284px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-53 {\n padding-left: 1272px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-53 {\n padding-right: 1272px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-53 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-53 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-left: 1308px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-right: 1308px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-54 {\n padding-left: 1296px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-54 {\n padding-right: 1296px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-54 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-54 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-left: 1332px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-right: 1332px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-55 {\n padding-left: 1320px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-55 {\n padding-right: 1320px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-55 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-55 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-left: 1356px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-right: 1356px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-56 {\n padding-left: 1344px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-56 {\n padding-right: 1344px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-56 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-56 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-left: 1380px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-right: 1380px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-57 {\n padding-left: 1368px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-57 {\n padding-right: 1368px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-57 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-57 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-left: 1404px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-right: 1404px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-58 {\n padding-left: 1392px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-58 {\n padding-right: 1392px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-58 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-58 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-left: 1428px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-right: 1428px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-59 {\n padding-left: 1416px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-59 {\n padding-right: 1416px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-59 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-59 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-left: 1452px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-right: 1452px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-60 {\n padding-left: 1440px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-60 {\n padding-right: 1440px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-60 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-60 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-left: 1476px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-right: 1476px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-61 {\n padding-left: 1464px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-61 {\n padding-right: 1464px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-61 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-61 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-left: 1500px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-right: 1500px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-62 {\n padding-left: 1488px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-62 {\n padding-right: 1488px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-62 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-62 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-left: 1524px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-right: 1524px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-63 {\n padding-left: 1512px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-63 {\n padding-right: 1512px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-63 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-63 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-left: 1548px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-right: 1548px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-64 {\n padding-left: 1536px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-64 {\n padding-right: 1536px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-64 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-64 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-left: 1572px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-right: 1572px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-65 {\n padding-left: 1560px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-65 {\n padding-right: 1560px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-65 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-65 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-left: 1596px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-right: 1596px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-66 {\n padding-left: 1584px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-66 {\n padding-right: 1584px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-66 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-66 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-left: 1620px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-right: 1620px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-67 {\n padding-left: 1608px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-67 {\n padding-right: 1608px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-67 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-67 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-left: 1644px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-right: 1644px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-68 {\n padding-left: 1632px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-68 {\n padding-right: 1632px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-68 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-68 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-left: 1668px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-right: 1668px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-69 {\n padding-left: 1656px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-69 {\n padding-right: 1656px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-69 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-69 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-left: 1692px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-right: 1692px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-70 {\n padding-left: 1680px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-70 {\n padding-right: 1680px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-70 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-70 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-left: 1716px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-right: 1716px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-71 {\n padding-left: 1704px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-71 {\n padding-right: 1704px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-71 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-71 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-left: 1740px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-right: 1740px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-72 {\n padding-left: 1728px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-72 {\n padding-right: 1728px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-72 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-72 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-left: 1764px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-right: 1764px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-73 {\n padding-left: 1752px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-73 {\n padding-right: 1752px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-73 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-73 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-left: 1788px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-right: 1788px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-74 {\n padding-left: 1776px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-74 {\n padding-right: 1776px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-74 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-74 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-left: 1812px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-right: 1812px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-75 {\n padding-left: 1800px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-75 {\n padding-right: 1800px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-75 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-75 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-left: 1836px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-right: 1836px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-76 {\n padding-left: 1824px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-76 {\n padding-right: 1824px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-76 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-76 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-left: 1860px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-right: 1860px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-77 {\n padding-left: 1848px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-77 {\n padding-right: 1848px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-77 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-77 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-left: 1884px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-right: 1884px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-78 {\n padding-left: 1872px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-78 {\n padding-right: 1872px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-78 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-78 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-left: 1908px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-right: 1908px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-79 {\n padding-left: 1896px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-79 {\n padding-right: 1896px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-79 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-79 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-left: 1932px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-right: 1932px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-80 {\n padding-left: 1920px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-80 {\n padding-right: 1920px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-80 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-80 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-left: 1956px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-right: 1956px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-81 {\n padding-left: 1944px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-81 {\n padding-right: 1944px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-81 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-81 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-left: 1980px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-right: 1980px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-82 {\n padding-left: 1968px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-82 {\n padding-right: 1968px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-82 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-82 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-left: 2004px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-right: 2004px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-83 {\n padding-left: 1992px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-83 {\n padding-right: 1992px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-83 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-83 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-left: 2028px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-right: 2028px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-84 {\n padding-left: 2016px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-84 {\n padding-right: 2016px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-84 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-84 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-left: 2052px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-right: 2052px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-85 {\n padding-left: 2040px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-85 {\n padding-right: 2040px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-85 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-85 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-left: 2076px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-right: 2076px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-86 {\n padding-left: 2064px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-86 {\n padding-right: 2064px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-86 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-86 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-left: 2100px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-right: 2100px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-87 {\n padding-left: 2088px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-87 {\n padding-right: 2088px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-87 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-87 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-left: 2124px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-right: 2124px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-88 {\n padding-left: 2112px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-88 {\n padding-right: 2112px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-88 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-88 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-left: 2148px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-right: 2148px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-89 {\n padding-left: 2136px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-89 {\n padding-right: 2136px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-89 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-89 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-left: 2172px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-right: 2172px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-90 {\n padding-left: 2160px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-90 {\n padding-right: 2160px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-90 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-90 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-left: 2196px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-right: 2196px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-91 {\n padding-left: 2184px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-91 {\n padding-right: 2184px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-91 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-91 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-left: 2220px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-right: 2220px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-92 {\n padding-left: 2208px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-92 {\n padding-right: 2208px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-92 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-92 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-left: 2244px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-right: 2244px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-93 {\n padding-left: 2232px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-93 {\n padding-right: 2232px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-93 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-93 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-left: 2268px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-right: 2268px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-94 {\n padding-left: 2256px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-94 {\n padding-right: 2256px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-94 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-94 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-left: 2292px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-right: 2292px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-95 {\n padding-left: 2280px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-95 {\n padding-right: 2280px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-95 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-95 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-left: 2316px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-right: 2316px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-96 {\n padding-left: 2304px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-96 {\n padding-right: 2304px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-96 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-96 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-left: 2340px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-right: 2340px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-97 {\n padding-left: 2328px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-97 {\n padding-right: 2328px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-97 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-97 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-left: 2364px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-right: 2364px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-98 {\n padding-left: 2352px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-98 {\n padding-right: 2352px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-98 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-98 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-left: 2388px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-right: 2388px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-indent-99 {\n padding-left: 2376px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-indent-99 {\n padding-right: 2376px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-level-99 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-level-99 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-ltr .ag-row-group-leaf-indent {\n margin-left: 24px;\n}\n\n.ag-theme-blue .ag-rtl .ag-row-group-leaf-indent {\n margin-right: 24px;\n}\n\n.ag-theme-blue .ag-value-change-delta {\n padding-right: 2px;\n}\n.ag-theme-blue .ag-value-change-delta-up {\n color: darkgreen;\n color: var(--ag-value-change-delta-up-color, darkgreen);\n}\n.ag-theme-blue .ag-value-change-delta-down {\n color: darkred;\n color: var(--ag-value-change-delta-down-color, darkred);\n}\n.ag-theme-blue .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n -webkit-transition: background-color 1s;\n transition: background-color 1s;\n}\n.ag-theme-blue .ag-value-change-value-highlight {\n background-color: #cec;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec);\n -webkit-transition: background-color 0.1s;\n transition: background-color 0.1s;\n}\n.ag-theme-blue .ag-cell-data-changed {\n background-color: #cec !important;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec) !important;\n}\n.ag-theme-blue .ag-cell-data-changed-animation {\n background-color: transparent;\n}\n.ag-theme-blue .ag-cell-highlight {\n background-color: rgba(136, 255, 136, 0.4) !important;\n background-color: var(--ag-range-selection-highlight-color, rgba(136, 255, 136, 0.4)) !important;\n}\n.ag-theme-blue .ag-row {\n height: 25px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: #222;\n color: var(--ag-data-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-row-highlight-above::after, .ag-theme-blue .ag-row-highlight-below::after {\n content: \"\";\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #222;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n left: 1px;\n}\n.ag-theme-blue .ag-row-highlight-above::after {\n top: -1px;\n}\n.ag-theme-blue .ag-row-highlight-above.ag-row-first::after {\n top: 0;\n}\n.ag-theme-blue .ag-row-highlight-below::after {\n bottom: 0px;\n}\n.ag-theme-blue .ag-row-odd {\n background-color: #deebf7;\n background-color: var(--ag-odd-row-background-color, #deebf7);\n}\n.ag-theme-blue .ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-row-hover {\n background-color: #f0f0f0;\n background-color: var(--ag-row-hover-color, #f0f0f0);\n}\n.ag-theme-blue .ag-column-hover {\n background-color: #f0f0f0;\n background-color: var(--ag-column-hover-color, #f0f0f0);\n}\n.ag-theme-blue .ag-ltr .ag-right-aligned-cell {\n text-align: right;\n}\n\n.ag-theme-blue .ag-rtl .ag-right-aligned-cell {\n text-align: left;\n}\n\n.ag-theme-blue .ag-ltr .ag-right-aligned-cell .ag-cell-value, .ag-theme-blue .ag-ltr .ag-right-aligned-cell .ag-group-value {\n margin-left: auto;\n}\n\n.ag-theme-blue .ag-rtl .ag-right-aligned-cell .ag-cell-value, .ag-theme-blue .ag-rtl .ag-right-aligned-cell .ag-group-value {\n margin-right: auto;\n}\n\n.ag-theme-blue .ag-cell, .ag-theme-blue .ag-full-width-row .ag-cell-wrapper.ag-row-group {\n border: 1px solid transparent;\n line-height: min(var(--ag-row-height, 23px), 23px);\n padding-left: 11px;\n padding-right: 11px;\n -webkit-font-smoothing: subpixel-antialiased;\n}\n.ag-theme-blue .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px;\n}\n.ag-theme-blue .ag-row-dragging {\n cursor: move;\n opacity: 0.5;\n}\n.ag-theme-blue .ag-cell-inline-editing {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 25px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n}\n.ag-theme-blue .ag-popup-editor {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n padding: 0;\n}\n.ag-theme-blue .ag-large-text-input {\n height: auto;\n padding: 12px;\n}\n.ag-theme-blue .ag-details-row {\n padding: 20px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-blue .ag-layout-auto-height .ag-center-cols-clipper, .ag-theme-blue .ag-layout-auto-height .ag-center-cols-container, .ag-theme-blue .ag-layout-print .ag-center-cols-clipper, .ag-theme-blue .ag-layout-print .ag-center-cols-container {\n min-height: 50px;\n}\n.ag-theme-blue .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66));\n}\n.ag-theme-blue .ag-overlay-loading-center {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n}\n.ag-theme-blue .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px;\n}\n.ag-theme-blue .ag-loading {\n padding-left: 12px;\n display: -webkit-box;\n display: flex;\n height: 100%;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-blue .ag-loading-icon {\n padding-right: 12px;\n}\n.ag-theme-blue .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear;\n}\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n.ag-theme-blue .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-ltr .ag-cell {\n border-right: dotted #9bc2e6;\n}\n\n.ag-theme-blue .ag-rtl .ag-cell {\n border-left: dotted #9bc2e6;\n}\n\n.ag-theme-blue .ag-ltr .ag-cell {\n border-right-width: 1px;\n}\n\n.ag-theme-blue .ag-rtl .ag-cell {\n border-left-width: 1px;\n}\n\n.ag-theme-blue .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-row-selected {\n background-color: #c8c8c8;\n background-color: var(--ag-selected-row-background-color, #c8c8c8);\n}\n.ag-theme-blue .ag-cell-range-selected:not(.ag-cell-focus),\n.ag-theme-blue .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing) {\n background-color: rgba(34, 34, 34, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(34, 34, 34, 0.2));\n}\n.ag-theme-blue .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart,\n.ag-theme-blue .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1) !important;\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)) !important;\n}\n.ag-theme-blue .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category,\n.ag-theme-blue .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1) !important;\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)) !important;\n}\n.ag-theme-blue .ag-cell-range-selected-1:not(.ag-cell-focus),\n.ag-theme-blue .ag-root:not(.ag-context-menu-open) .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-1:not(.ag-cell-inline-editing) {\n background-color: rgba(34, 34, 34, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(34, 34, 34, 0.2)));\n}\n.ag-theme-blue .ag-cell-range-selected-2:not(.ag-cell-focus),\n.ag-theme-blue .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-2 {\n background-color: rgba(34, 34, 34, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(34, 34, 34, 0.36));\n}\n.ag-theme-blue .ag-cell-range-selected-3:not(.ag-cell-focus),\n.ag-theme-blue .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-3 {\n background-color: rgba(34, 34, 34, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(34, 34, 34, 0.488));\n}\n.ag-theme-blue .ag-cell-range-selected-4:not(.ag-cell-focus),\n.ag-theme-blue .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-4 {\n background-color: rgba(34, 34, 34, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(34, 34, 34, 0.5904));\n}\n.ag-theme-blue .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #222;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #222;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #222;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #222;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-blue .ag-ltr .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-blue .ag-ltr .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-blue .ag-ltr .ag-cell-range-single-cell,\n.ag-theme-blue .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-blue .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-blue .ag-rtl .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-blue .ag-rtl .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-blue .ag-rtl .ag-cell-range-single-cell,\n.ag-theme-blue .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n outline: initial;\n}\n.ag-theme-blue .ag-cell.ag-selection-fill-top,\n.ag-theme-blue .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #222;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-blue .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #222;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n}\n\n.ag-theme-blue .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-blue .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #222;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n}\n\n.ag-theme-blue .ag-cell.ag-selection-fill-bottom,\n.ag-theme-blue .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #222;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-blue .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #222;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n}\n\n.ag-theme-blue .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-blue .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #222;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n}\n\n.ag-theme-blue .ag-range-handle, .ag-theme-blue .ag-fill-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #222;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-ltr .ag-range-handle, .ag-theme-blue .ag-ltr .ag-fill-handle {\n right: -1px;\n}\n\n.ag-theme-blue .ag-rtl .ag-range-handle, .ag-theme-blue .ag-rtl .ag-fill-handle {\n left: -1px;\n}\n\n.ag-theme-blue .ag-fill-handle {\n cursor: cell;\n}\n.ag-theme-blue .ag-range-handle {\n cursor: nwse-resize;\n}\n.ag-theme-blue .ag-cell-inline-editing {\n border-color: var(--ag-input-focus-border-color) !important;\n}\n.ag-theme-blue .ag-menu {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n}\n.ag-theme-blue .ag-menu-list {\n cursor: default;\n padding: 4px 0;\n}\n.ag-theme-blue .ag-menu-separator {\n height: 9px;\n}\n.ag-theme-blue .ag-menu-separator-part::after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-menu-option-active, .ag-theme-blue .ag-compact-menu-option-active {\n background-color: #f0f0f0;\n background-color: var(--ag-row-hover-color, #f0f0f0);\n}\n.ag-theme-blue .ag-menu-option-part, .ag-theme-blue .ag-compact-menu-option-part {\n line-height: 12px;\n padding: 6px 0;\n}\n.ag-theme-blue .ag-menu-option-disabled, .ag-theme-blue .ag-compact-menu-option-disabled {\n opacity: 0.5;\n}\n.ag-theme-blue .ag-menu-option-icon, .ag-theme-blue .ag-compact-menu-option-icon {\n width: 12px;\n}\n.ag-theme-blue .ag-ltr .ag-menu-option-icon, .ag-theme-blue .ag-ltr .ag-compact-menu-option-icon {\n padding-left: 8px;\n}\n\n.ag-theme-blue .ag-rtl .ag-menu-option-icon, .ag-theme-blue .ag-rtl .ag-compact-menu-option-icon {\n padding-right: 8px;\n}\n\n.ag-theme-blue .ag-menu-option-text, .ag-theme-blue .ag-compact-menu-option-text {\n padding-left: 8px;\n padding-right: 8px;\n}\n.ag-theme-blue .ag-ltr .ag-menu-option-shortcut, .ag-theme-blue .ag-ltr .ag-compact-menu-option-shortcut {\n padding-right: 4px;\n}\n\n.ag-theme-blue .ag-rtl .ag-menu-option-shortcut, .ag-theme-blue .ag-rtl .ag-compact-menu-option-shortcut {\n padding-left: 4px;\n}\n\n.ag-theme-blue .ag-menu-option-popup-pointer, .ag-theme-blue .ag-compact-menu-option-popup-pointer {\n padding-right: 4px;\n}\n.ag-theme-blue .ag-tabs {\n min-width: 220px;\n}\n.ag-theme-blue .ag-tabs-header {\n width: 100%;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-blue .ag-tab {\n border-bottom: 0 solid transparent;\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 0;\n flex: none;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-pack: center;\n justify-content: center;\n cursor: pointer;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-tab:focus {\n outline: none;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-tab:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-blue .ag-tab-selected {\n border-bottom-color: #222;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)));\n}\n.ag-theme-blue .ag-menu-header {\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-filter-separator {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-menu:not(.ag-tabs) .ag-filter-select {\n min-width: 167px;\n}\n.ag-theme-blue .ag-tabs .ag-filter-select {\n min-width: 206px;\n}\n.ag-theme-blue .ag-filter-select .ag-picker-field-wrapper {\n width: 0;\n}\n.ag-theme-blue .ag-filter-condition-operator {\n height: 17px;\n}\n.ag-theme-blue .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px;\n}\n\n.ag-theme-blue .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px;\n}\n\n.ag-theme-blue .ag-set-filter-select-all {\n padding-top: 6px;\n}\n.ag-theme-blue .ag-set-filter-list, .ag-theme-blue .ag-filter-no-matches {\n height: 120px;\n}\n.ag-theme-blue .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px;\n}\n.ag-theme-blue .ag-filter-to {\n margin-top: 4px;\n}\n.ag-theme-blue .ag-mini-filter {\n margin: 6px 6px;\n}\n.ag-theme-blue .ag-set-filter-item {\n margin: 0px 6px;\n}\n.ag-theme-blue .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px;\n}\n\n.ag-theme-blue .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px;\n}\n\n.ag-theme-blue .ag-filter-apply-panel {\n padding: 6px 6px;\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6));\n}\n.ag-theme-blue .ag-filter-apply-panel-button {\n line-height: 1.5;\n}\n.ag-theme-blue .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px;\n}\n\n.ag-theme-blue .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px;\n}\n\n.ag-theme-blue .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px;\n}\n.ag-theme-blue .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px;\n}\n.ag-theme-blue .ag-filter-no-matches {\n padding: 6px 6px;\n}\n.ag-theme-blue .ag-multi-filter-menu-item {\n margin: 4px 0;\n}\n.ag-theme-blue .ag-multi-filter-group-title-bar {\n padding: 8px 4px;\n background-color: transparent;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus {\n outline: none;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-blue .ag-side-bar {\n position: relative;\n}\n.ag-theme-blue .ag-tool-panel-wrapper {\n width: 200px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n}\n.ag-theme-blue .ag-side-buttons {\n padding-top: 16px;\n width: 16px;\n position: relative;\n color: #222;\n color: var(--ag-foreground-color, #222);\n overflow: hidden;\n}\n.ag-theme-blue button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: calc(100% + 1px);\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue button.ag-side-button-button:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-side-button-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-blue .ag-selected .ag-side-button-button {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-side-button-icon-wrapper {\n margin-bottom: 3px;\n}\n.ag-theme-blue .ag-ltr .ag-side-bar-left,\n.ag-theme-blue .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n.ag-theme-blue .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-ltr .ag-side-bar-left .ag-side-button-button,\n.ag-theme-blue .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent;\n margin-right: -1px;\n padding-right: 1px;\n}\n.ag-theme-blue .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-blue .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #222;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)));\n}\n.ag-theme-blue .ag-rtl .ag-side-bar-left,\n.ag-theme-blue .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n.ag-theme-blue .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-rtl .ag-side-bar-left .ag-side-button-button,\n.ag-theme-blue .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent;\n margin-left: -1px;\n padding-left: 1px;\n}\n.ag-theme-blue .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-blue .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #222;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)));\n}\n.ag-theme-blue .ag-filter-toolpanel-header {\n height: 24px;\n}\n.ag-theme-blue .ag-ltr .ag-filter-toolpanel-header, .ag-theme-blue .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px;\n}\n\n.ag-theme-blue .ag-rtl .ag-filter-toolpanel-header, .ag-theme-blue .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px;\n}\n\n.ag-theme-blue .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-filter-toolpanel-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-blue .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f114\";\n position: absolute;\n}\n.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-left: 4px;\n}\n\n.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-right: 4px;\n}\n\n.ag-theme-blue .ag-filter-toolpanel-group-level-0-header {\n height: 32px;\n}\n.ag-theme-blue .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px;\n}\n.ag-theme-blue .ag-filter-toolpanel-search {\n height: 25px;\n}\n.ag-theme-blue .ag-filter-toolpanel-search-input {\n -webkit-box-flex: 1;\n flex-grow: 1;\n height: 16px;\n}\n.ag-theme-blue .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px;\n}\n\n.ag-theme-blue .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px;\n}\n\n.ag-theme-blue .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6));\n}\n.ag-theme-blue .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px;\n}\n\n.ag-theme-blue .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px;\n}\n\n.ag-theme-blue .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px;\n}\n\n.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px;\n}\n\n.ag-theme-blue .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px;\n}\n\n.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px;\n}\n\n.ag-theme-blue .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px;\n}\n\n.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px;\n}\n\n.ag-theme-blue .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px;\n}\n\n.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px;\n}\n\n.ag-theme-blue .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px;\n}\n\n.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px;\n}\n\n.ag-theme-blue .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px;\n}\n\n.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px;\n}\n\n.ag-theme-blue .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px;\n}\n\n.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px;\n}\n\n.ag-theme-blue .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px;\n}\n\n.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px;\n}\n\n.ag-theme-blue .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px;\n}\n\n.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px;\n}\n\n.ag-theme-blue .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px;\n}\n\n.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px;\n}\n\n.ag-theme-blue .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px;\n}\n.ag-theme-blue .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6);\n margin-top: 4px;\n}\n.ag-theme-blue .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px;\n}\n\n.ag-theme-blue .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px;\n}\n\n.ag-theme-blue .ag-pivot-mode-panel {\n min-height: 25px;\n height: 25px;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-blue .ag-pivot-mode-select {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-blue .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px;\n}\n\n.ag-theme-blue .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px;\n}\n\n.ag-theme-blue .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-column-select-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-blue .ag-column-select-header {\n height: 25px;\n -webkit-box-align: center;\n align-items: center;\n padding: 0 6px;\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6));\n}\n.ag-theme-blue .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6));\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6));\n}\n.ag-theme-blue .ag-column-group-icons,\n.ag-theme-blue .ag-column-select-header-icon {\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-column-select-list .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #222;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-column-select-list .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-blue .ag-column-select-list .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-blue .ag-header {\n background-color: #5e9cd3;\n background-color: var(--ag-header-background-color, #5e9cd3);\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-header-row {\n color: #fff;\n color: var(--ag-header-foreground-color, #fff);\n height: 25px;\n}\n.ag-theme-blue .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px;\n}\n\n.ag-theme-blue .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px;\n}\n\n.ag-theme-blue .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px;\n}\n\n.ag-theme-blue .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px;\n}\n\n.ag-theme-blue .ag-header-cell,\n.ag-theme-blue .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px;\n}\n.ag-theme-blue .ag-header-cell.ag-header-cell-moving,\n.ag-theme-blue .ag-header-group-cell.ag-header-cell-moving {\n background-color: #9bc2e6;\n background-color: var(--ag-header-cell-moving-background-color, #9bc2e6);\n}\n.ag-theme-blue .ag-keyboard-focus .ag-header-cell:focus {\n outline: none;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-header-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-blue .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-header-group-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-blue .ag-header-icon {\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-header-expand-icon {\n cursor: pointer;\n}\n.ag-theme-blue .ag-ltr .ag-header-expand-icon {\n padding-left: 4px;\n}\n\n.ag-theme-blue .ag-rtl .ag-header-expand-icon {\n padding-right: 4px;\n}\n\n.ag-theme-blue .ag-header-row:not(:first-child) .ag-header-cell,\n.ag-theme-blue .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-header-cell::after,\n.ag-theme-blue .ag-header-group-cell::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n width: 1px;\n height: 100%;\n top: calc(50% - 50%);\n background-color: rgba(155, 194, 230, 0.5);\n background-color: var(--ag-header-column-separator-color, rgba(155, 194, 230, 0.5));\n}\n.ag-theme-blue .ag-ltr .ag-header-cell::after, .ag-theme-blue .ag-ltr .ag-header-group-cell::after {\n right: 0;\n}\n\n.ag-theme-blue .ag-rtl .ag-header-cell::after, .ag-theme-blue .ag-rtl .ag-header-group-cell::after {\n left: 0;\n}\n\n.ag-theme-blue .ag-ltr .ag-header-select-all {\n margin-right: 12px;\n}\n\n.ag-theme-blue .ag-rtl .ag-header-select-all {\n margin-left: 12px;\n}\n\n.ag-theme-blue .ag-ltr .ag-floating-filter-button {\n margin-left: 12px;\n}\n\n.ag-theme-blue .ag-rtl .ag-floating-filter-button {\n margin-right: 12px;\n}\n\n.ag-theme-blue .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 12px;\n padding: 0;\n width: 12px;\n}\n.ag-theme-blue .ag-filter-loading {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1;\n}\n.ag-theme-blue .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n height: 25px;\n}\n.ag-theme-blue .ag-paging-panel > * {\n margin: 0 12px;\n}\n.ag-theme-blue .ag-paging-button {\n cursor: pointer;\n}\n.ag-theme-blue .ag-paging-button.ag-disabled {\n cursor: default;\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5));\n}\n.ag-theme-blue .ag-keyboard-focus .ag-paging-button:focus {\n outline: none;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-paging-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-blue .ag-paging-button, .ag-theme-blue .ag-paging-description {\n margin: 0 4px;\n}\n.ag-theme-blue .ag-status-bar {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5;\n}\n.ag-theme-blue .ag-status-name-value-value {\n color: #222;\n color: var(--ag-foreground-color, #222);\n}\n.ag-theme-blue .ag-status-bar-center {\n text-align: center;\n}\n.ag-theme-blue .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px;\n}\n.ag-theme-blue .ag-column-drop-cell {\n background: #ddebf7;\n background: var(--ag-chip-background-color, #ddebf7);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px;\n border: 1px solid transparent;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-column-drop-cell:focus {\n outline: none;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-column-drop-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 2px;\n left: 2px;\n display: block;\n width: calc(100% - 4px);\n height: calc(100% - 4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-blue .ag-column-drop-cell-text {\n margin: 0 4px;\n}\n.ag-theme-blue .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-column-drop-cell-drag-handle {\n margin-left: 8px;\n}\n.ag-theme-blue .ag-column-drop-cell-ghost {\n opacity: 0.5;\n}\n.ag-theme-blue .ag-column-drop-horizontal {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px;\n}\n\n.ag-theme-blue .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px;\n}\n\n.ag-theme-blue .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6);\n}\n\n.ag-theme-blue .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6);\n}\n\n.ag-theme-blue .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-column-drop-horizontal-empty-message {\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5));\n}\n.ag-theme-blue .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px;\n}\n\n.ag-theme-blue .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px;\n}\n\n.ag-theme-blue .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px;\n}\n.ag-theme-blue .ag-column-drop-vertical-cell {\n margin-top: 4px;\n}\n.ag-theme-blue .ag-column-drop-vertical {\n min-height: 50px;\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6));\n}\n.ag-theme-blue .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none;\n}\n.ag-theme-blue .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px;\n}\n.ag-theme-blue .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5));\n margin-top: 4px;\n}\n.ag-theme-blue .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n background: #fff;\n background: var(--ag-background-color, #fff);\n height: 70px;\n padding: 0;\n}\n.ag-theme-blue .ag-select-agg-func-virtual-list-item {\n cursor: default;\n padding-left: 8px;\n}\n.ag-theme-blue .ag-select-agg-func-virtual-list-item:hover {\n background-color: #c8c8c8;\n background-color: var(--ag-selected-row-background-color, #c8c8c8);\n}\n.ag-theme-blue .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-blue .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-blue .ag-chart-menu {\n border-radius: 0px;\n background: #fff;\n background: var(--ag-background-color, #fff);\n}\n.ag-theme-blue .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 0px;\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-chart-menu-icon:hover {\n opacity: 1;\n}\n.ag-theme-blue .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: #9bc2e6;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6));\n border-radius: 5px;\n margin: 5px;\n}\n.ag-theme-blue .ag-chart-mini-thumbnail:nth-last-child(3), .ag-theme-blue .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto;\n}\n.ag-theme-blue .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0;\n}\n\n.ag-theme-blue .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0;\n}\n\n.ag-theme-blue .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0;\n}\n\n.ag-theme-blue .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0;\n}\n\n.ag-theme-blue .ag-chart-mini-thumbnail.ag-selected {\n border-color: #222;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222)));\n}\n.ag-theme-blue .ag-chart-settings-card-item {\n background: #222;\n background: var(--ag-foreground-color, #222);\n width: 8px;\n height: 8px;\n border-radius: 4px;\n}\n.ag-theme-blue .ag-chart-settings-card-item.ag-selected {\n background-color: #222;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222)));\n}\n.ag-theme-blue .ag-chart-data-column-drag-handle {\n margin-left: 4px;\n}\n.ag-theme-blue .ag-charts-settings-group-title-bar,\n.ag-theme-blue .ag-charts-data-group-title-bar,\n.ag-theme-blue .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6));\n}\n.ag-theme-blue .ag-charts-settings-group-container {\n padding: 4px;\n}\n.ag-theme-blue .ag-charts-data-group-container {\n padding: 3px 6px;\n}\n.ag-theme-blue .ag-charts-data-group-container .ag-charts-data-group-item:not(.ag-charts-format-sub-level-group) {\n height: 20px;\n}\n.ag-theme-blue .ag-charts-data-group-container .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #222;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue .ag-charts-data-group-container .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-blue .ag-charts-data-group-container .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-blue .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px;\n}\n.ag-theme-blue .ag-charts-format-top-level-group-item {\n margin: 4px 0;\n}\n.ag-theme-blue .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px;\n}\n.ag-theme-blue .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px;\n}\n.ag-theme-blue .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px;\n}\n.ag-theme-blue .ag-chart-data-section,\n.ag-theme-blue .ag-chart-format-section {\n display: -webkit-box;\n display: flex;\n margin: 0;\n}\n.ag-theme-blue .ag-chart-menu-panel {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n}\n.ag-theme-blue .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6);\n}\n\n.ag-theme-blue .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6);\n}\n\n.ag-theme-blue .ag-date-time-list-page-title {\n -webkit-box-flex: 1;\n flex-grow: 1;\n text-align: center;\n}\n.ag-theme-blue .ag-date-time-list-page-column-label {\n text-align: center;\n}\n.ag-theme-blue .ag-date-time-list-page-entry {\n text-align: center;\n}\n.ag-theme-blue .ag-checkbox-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-blue .ag-checkbox-input-wrapper input, .ag-theme-blue .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-blue .ag-checkbox-input-wrapper:focus-within, .ag-theme-blue .ag-checkbox-input-wrapper:active {\n outline: none;\n}\n.ag-theme-blue .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-blue .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #222;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-blue .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #222;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-blue .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #222;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222)));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-blue .ag-toggle-button-input-wrapper {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n width: 24px;\n height: 12px;\n background-color: #222;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222)));\n border-radius: 6px;\n position: relative;\n -webkit-box-flex: 0;\n flex: none;\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222)));\n}\n.ag-theme-blue .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%;\n}\n.ag-theme-blue .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n}\n.ag-theme-blue .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-blue .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #222;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222)));\n border-color: #222;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222)));\n}\n.ag-theme-blue .ag-toggle-button-input-wrapper::before {\n content: \" \";\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n background-color: #fff;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #fff));\n border-radius: 6px;\n -webkit-transition: left 100ms;\n transition: left 100ms;\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222))));\n}\n.ag-theme-blue .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 12px );\n border-color: #222;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222)));\n}\n.ag-theme-blue .ag-radio-button-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n border-radius: 12px;\n}\n.ag-theme-blue .ag-radio-button-input-wrapper input, .ag-theme-blue .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-blue .ag-radio-button-input-wrapper:focus-within, .ag-theme-blue .ag-radio-button-input-wrapper:active {\n outline: none;\n}\n.ag-theme-blue .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-blue .ag-radio-button-input-wrapper::after {\n content: \"\\f126\";\n color: #222;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-blue .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f127\";\n color: #222;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-blue input[class^=ag-][type=range] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible;\n}\n.ag-theme-blue input[class^=ag-][type=range]::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #9bc2e6;\n background-color: var(--ag-border-color, #9bc2e6);\n border-radius: 0px;\n border-radius: 0px;\n}\n.ag-theme-blue input[class^=ag-][type=range]::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #9bc2e6;\n background-color: var(--ag-border-color, #9bc2e6);\n border-radius: 0px;\n border-radius: 0px;\n}\n.ag-theme-blue input[class^=ag-][type=range]::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #9bc2e6;\n background-color: var(--ag-border-color, #9bc2e6);\n border-radius: 0px;\n border-radius: 0px;\n color: transparent;\n width: calc(100% - 2px);\n}\n.ag-theme-blue input[class^=ag-][type=range]::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222));\n border-radius: 12px;\n -webkit-transform: translateY(-4.5px);\n transform: translateY(-4.5px);\n}\n.ag-theme-blue input[class^=ag-][type=range]::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222));\n border-radius: 12px;\n}\n.ag-theme-blue input[class^=ag-][type=range]::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222));\n border-radius: 12px;\n}\n.ag-theme-blue input[class^=ag-][type=range]:focus {\n outline: none;\n}\n.ag-theme-blue input[class^=ag-][type=range]:focus::-webkit-slider-thumb {\n border-color: #222;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue input[class^=ag-][type=range]:focus::-ms-thumb {\n border-color: #222;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue input[class^=ag-][type=range]:focus::-moz-ag-range-thumb {\n border-color: #222;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222));\n}\n.ag-theme-blue input[class^=ag-][type=range]:active::-webkit-slider-runnable-track {\n background-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-blue input[class^=ag-][type=range]:active::-moz-ag-range-track {\n background-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-blue input[class^=ag-][type=range]:active::-ms-track {\n background-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-blue input[class^=ag-][type=range]:disabled {\n opacity: 0.5;\n}\n.ag-theme-blue .ag-icon {\n color: #333;\n margin: 1px 1px 2px 1px;\n}\n.ag-theme-blue .ag-icon-tree-closed::before {\n content: \"\\f10b\";\n}\n.ag-theme-blue .ag-icon-tree-open::before {\n content: \"\\f111\";\n}\n.ag-theme-blue .ag-header, .ag-theme-blue .ag-column-drop-cell {\n background-image: none;\n}\n.ag-theme-blue .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px;\n}\n.ag-theme-blue .ag-tabs-body {\n margin: 2px 0;\n}\n.ag-theme-blue .ag-tab-selected {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n border-bottom-color: transparent;\n}\n.ag-theme-blue .ag-tabs-header {\n background-color: #5e9cd3;\n background-color: var(--ag-header-background-color, #5e9cd3);\n border-bottom: 1px solid;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-filter .ag-filter-apply-panel {\n -webkit-box-pack: start;\n justify-content: flex-start;\n}\n.ag-theme-blue .ag-menu-option-active {\n background-color: #c8c8c8;\n background-color: var(--ag-selected-row-background-color, #c8c8c8);\n}\n.ag-theme-blue .ag-column-drop-cell {\n border: 1px solid;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n border-radius: 0;\n}\n.ag-theme-blue .ag-column-drop-cell-button .ag-icon {\n border: 1px solid transparent;\n}\n.ag-theme-blue .ag-column-drop-cell-button:hover .ag-icon {\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n}\n.ag-theme-blue .ag-panel-title-bar-button-icon {\n font-size: 20px;\n line-height: 20px;\n}\n.ag-theme-blue .ag-menu-option-part {\n padding-top: 4px;\n padding-bottom: 4px;\n}\n.ag-theme-blue .ag-column-drop-vertical-title-bar {\n margin-top: 4px;\n margin-left: 4px;\n}\n.ag-theme-blue .ag-column-drop-vertical-title {\n margin-left: 4px;\n}\n.ag-theme-blue .ag-column-drop-vertical-empty-message {\n margin-left: 24px;\n}\n", ""]); // Exports module.exports = exports; /***/ }), -/* 238 */ +/* 291 */ /***/ (function(module, exports, __webpack_require__) { -var api = __webpack_require__(225); - var content = __webpack_require__(239); +var api = __webpack_require__(278); + var content = __webpack_require__(292); content = content.__esModule ? content.default : content; @@ -48687,24 +57632,24 @@ var update = api(content, options); module.exports = content.locals || {}; /***/ }), -/* 239 */ +/* 292 */ /***/ (function(module, exports, __webpack_require__) { // Imports -var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227); +var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(280); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, ".ag-theme-bootstrap {\n -webkit-font-smoothing: antialiased;\n color: #000;\n color: var(--ag-foreground-color, #000);\n font-family: \"Helvetica Neue\", sans-serif;\n font-size: 14px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridClassic\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABOsAAsAAAAAJiwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlIAAAReYchjok9TLzIAAANcAAAAQQAAAFZWVlJ+Y21hcAAAA6AAAAHtAAAFgHClDfdnbHlmAAAFkAAACi0AABQQq+8lqmhlYWQAAA/AAAAANAAAADZ2z8SBaGhlYQAAD/QAAAAeAAAAJAfTBChobXR4AAAQFAAAABoAAAEou4L/4mxvY2EAABAwAAAAbwAAAJb7HvWgbWF4cAAAEKAAAAAfAAAAIAFgAHhuYW1lAAAQwAAAATMAAAJS8kTiWnBvc3QAABH0AAABtgAAApcplp2DeJx9k0lyE0EQRX+rZSMPyGDMZMRkRpsh3O5BjSTLltzyQHjBggULNmYBAeFg5ROw5gAEB+AUnIBgyYoDcACCA/Ay1UbGC6tC1VWZP3/+yspSIGlSy+qqUmzuPld9f+/gveZV1fBn/qPrYP/tmz3VDnf4qv6tKQj/qK4FvdCBvgUKXgefK+NhJeyGu+GH8FP4QyGoG3oMekorjFgJc6RUmZrKVdE4tpj1E7VAh8xtt87qgsbcU2ig8+SMiRk445Ke6o7OwNN3np7WQKUM4+wxbzHuauYERK578GeoWcVqrA10ntWENtHYQ0eH6BbeGXzrZI6I6eProy10VNXruK2XRM762SwyK3Ep/1gbvo9894AqHKLa8DfhN75Fsh7am2RKiHgEewaqW9Zwif8U3hRMRGzHa2bR10AmKEx1nZWdLOFk07oN+zO98qwbZUzPqzg88yLqR/a+8+XkOWrtwLUF9iEaRla7kfvkirSDf5KbKvROH/VFX/VdP/VLv3UK6ypeO8Ea3OsnVqZG/Y6jC7ztf1Y76Th3fhz1P2KCcze9NjG+QVlByzaFTqtNyjrCmjp+Ep2GL1CTU68qOSLPm2AdY6yyj0GfLruxxZj2Og/oAeuAeWqxwmxMw37L2V+GyVZDXRe9Wi14LvltWU3tJdV9Zz1vtzxPna/wjThZ5vXZxnsVizGNLA2PylFtHMv4c9SOspmqBqoSeqDmnbXjr6Ag003OMVSS6Ja/gB3vqgUUZOWLnNM5V98pb2rOcbFHBWiOypeces2sk/tos67Y+gsvGGrHAAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMnxi4gDQjSA4A1QYKdAAAAHictdQHTltBFIXh3wXTTEnvvRc6hGp6XQbpiBREOsoqs5O7gZBzPScLIFJG+nw9o+c3b/R8LtAB1OSp1KFap0KO31qttNdr9LTX6/zSvEkXVX0fYo8DjmL0+FirQ+yyz2FU2rO/o6Krm1zlPs80W2GMJeZZZZItxmlpdZEF1phhmg0mmGOKdXaYZZlNtvX7qnav6xkbdGrfbj1Jr+7YRz8DDHKaM5zlHOe5wEUucZkr2u0a17nBTW5xmzvc5Z72f8BDHvGYJzrPkD6HNRvRAzY42Vg54fU5xpbmVye3xls67cLazLQOOje1vjO7vLn9Dzf7D6OZH7Wfnu2Qb7PI0+7amDy3JXlh8/LSVuWVTcpr25I3Ni5vrSV7lv+QfVuUd7Yg721NPtiMfLRpObANObQJ+WRz8tmm5Iuty1fLs3+zWfluy/LDNuXI9AKjUmRWolqQtVZktqJeZL6io8jcRaMga2dB1q6CrN0FWXuKzGP0FmRtFvkmo68ga39B1oGCrIMFWU8VyhJhShVhyhdhShphyhxhSh9hyiFhSiRhyiZhSilhyithSi5hyjBhSjNhyjVhSjhhyjphSj1hyj9h6gSEqScQpu5AmPoEYeoRhKl3EKb+QVj2zbDMTFj7muGCrCNF+56jBSN/AHzNoH4AAAB4nO1Ye2xT1xm/37nEN87D8bUdXwezwLWJDZQCtmNfO4FATIgdQhLWGwhrt0DSGJHHpgaawFRatBIVVrXbHxXTWCiPabMHo9MgSH1IGxJMa6b+sbBJFZVK2/HHVNjI6JZ2k8W97DvHjzyggPrntBufe17fPec73/md3/edcMDhw4f4fs7IcSBLglwuW3mZD+mj+/ZBQtv//vtkhPxuYiIFe2EvijD5T/lPuUVYCQpeRRK8oswyRRZZJokyywQZLrXFxscbNwPf1oh5m65txjzWpuu0PdYGhF9k/LIuWm/czOXm3Mq/whViRfAaMYlu+NkbCeiG7sTZU2TPGz3QrR/vOavdzMmTSTLJFTN51AW1QX3IZOOFsdiFC7GxC41jUJ8rjTVe4Ao47q6O67rBWTk35+Ue41ZyXIHsWgFBsboOArK/EspFmwl42WXAgh1bQtjlgYDorgqUu3nM+T7N5qpx4Y/83VUjyzWyZjY7HGZyW5Qk7ReqCi2qmmpvJ66Ii3yGL/xpZfjifySJmig6HCL5hyjpY/q1ZBJO6jtw2Vm9bjK9luJ6coq4p5UrmKOTALheK9/HdHDldbo1Q5teffLf1aev8zdyKuRU2jJTk3f0ot/XH4YTc/XwPpoevByUH6jFX/Tz0PoQHfTSJN3OWfM/2uwPmvkhk9L14qL38T2IjELOwXEIOskIvLIQDAL+ldvsOEu11+Mlf9O31zyta1A3Pv7ur4uLK8rsvg0+e1kFXIJTtdihX4Y14+N1paWVTk+Fy+dzVVQtqKTDG9gcR/gjOJuAWC3DtUkcV1WOZsPEz8nhlH6ej+rnk7OydAofaEniA620zGV1v5HF8spHsxYghsvdQXcwEAzw/RmLadaMBcmkZmaWoZbT30uxJ2NBS9aCk1kLWlFCJLdw2y5QlVJMFfaK8lG2ShH1CYhy0I0sIYsyH5TFQJCMJvWSJEyp+hi0pPQxlYyyehrrp7AxzeV54Hn+eXqujYDbIRgB2UCBKbAM65PspU8OgwVfpG9WFSxYncElhxmXiAFkLDrAz0+eTejH9eMJ+C4xaVNYOQFdCe6r4p7u2oPQ9wO95GGoH0smp233Lq9wFZyPW43zK1IoYJfskgkBicwGobUQdLsQk17rCuI1CJUg2RXJgMikfyEUUFgJ5UGu9qyNHnpucNvSb9cF6xeZ9D+taPYW1T0WfvzAX0PfXF3UUO17pVX9uv9bT3ZtrYus9D85BFc3N5os9kq5uHY5b1qyyjLvieaDa3Z5GgJLiuFAEQG1wGBy6tcM4W1Bf7zhabujeN2CImN1VZ1/40ub9KO+TqskLZwfaHf+b65FQjwv4UK4FroORg1ZXUNYpm12Jac0QcB4qzxrwE3lJBRR4A5dQdvw/hd/uJ8q+Y0933umoXpdZ/euZ3Zs3ciULWnctbc3VgQboagtFAtVLQl5VvPlvNr84nBLW0nJRs8af/NI85Yz/vg2JWwwKP4eq2RfVBF+qjrUWcOXLlgGhcXzm22FAuEyPMo4px95DT2+VQbRG/SVB4Iq45Qk34/eZ3sq3d6elSV30I/yLDoQ3SI6Fq8gwVqVmC9fDqfTZFIvgSm94dIlrFDxkuxZvziL05zcwmmvqiDT5BI8pCwjH6WSyTT7ISN8WQlOJpMTSUaCJ+/NUKWC7Lovcl/jZK4KPenjlIcYsSLvZSk2n0R3UAZ3Ofr0TKrCBKeQYdFGyLY0p0zF8h3t0JqdjqnD96tovqSaxiytklhas6hwqh15TFXn2rTKLQaARicCuaOq2m1m1PQMi2b46iS/lfGVhIRHQzTYebpHPw7dPWdIDZw8nYmDzlCyJXe/uPsF/y/+n1w1159BpaGMuiwvYs+j4AEL+RkqsdUElQQb6sCDnUGfhxaxC6segXVTOSlgpx95q70+KsbkK0muuxL82KmEvB7yQsRmWxIeibQ2b2rZbcMnEi+qsAARyTxDhdNmCTY1OQ8usFidRgepWFpoL7JbwBpp2dTcGhkJL0FxSzkU2QuXOUhpsdFptToPOpuaghabs8IwjzcTsFQUxSN0XJyptfkozkQru9kAcaPZFPQXWgzznfGmkM3qHHHG406jaHY5lhYSg5nOxFQaCR9FcUuZQAqXOlxmo1BEBUecVluoKe6cb7AU+oMmszHOVjHzvBxBFC9kjCUgLJGs0FciYyE8cfPQYwaUoNctlJPY0eGjV6/iK5kv/Pjl7u6Xu8lvZjXSgvZWN+3i5s2KPZchNz5a5CmwoBYU5E5JeXDseevjmG80fAyuxT7xvR5+/SEBqFYX+2jVMRR//pOYD/O8H5qOVViUAtnEH7nzWz6aSelMNEJjEfrJV12bwsJ2XCIlnAev7bmPYquOKaNQHfuYKv2wtaWza3sNTXJMOZa/L7yKZ7KA7jA9jfAUO4ngzxFb5hw6+T9zpdN3EBY7SDDamwAveBO9vQn9A/2DRC8514ctWOrTX+rDNuzry8YSd1ksYeMWcwEaS9ATZqZOYxF1EWb0CKECemYDflqk8eVKehyZTzSU0+MIU4efHYxu2BAdfFb/bGgw2tAQHRyCCe3NUH00Nti1XYlI0rJ4qH49VjrDEcAafxOlh/TbQ7up9O4hMON3Gz7X3lwmSRGls3swFl0XaspUugbj0fpQDvdR9BMCcjiL2DBMC0iUKTFyo6y2M51Mqfp5FaZ4h5Ygo2qK8l/eVjTewxq4RckteN0KpVQy2Xkurarpc50wha5jvDed7oWwmuHnPE5k9Khhbu39kUIDBAaVWvRHwQKMIBExfOYeyg4mPaFWSuL0BjAHN9p3DlDcHEjx67R3SKUo/adk9eBgbcnFklqaDUxo10mjdA+CyO1kBkIkhiT9tkOE1ZkPMt+VkljyBbwzzMYR85Tk1Tk4IjMwQG9zbGPNFAaL6I6bKQwEBgsb7XHRejXtgalD+d0uyyHgMNvwiLK96zpuNj6dXfff7C10a693d1Lhzm4UViKz8biUxTD3w6PEVGQ+g4GS3nk8VtwJ3BvcGdyX+0LyUAZ+VKXrOSW/v37P4T3r2euR1dR3NGQ/Wb8nj60TWX/oVfACoMhBcvCXCejSTyROa38gsTOZUP50Ks/fA4jjUs5OYxh07XmeKcj+uyKAAH5L9blI3OXTxwZqJiZqBtrRCX8Ii/UP6Y0NFi8YqJ2YqB2A16bxTUbp6BhBpchP9DG8sJzPc8koYp/QO4pIYwS8nrRoO+f2kUz4wNdjwDU2Z0wj0CCjJSOR7UvyMYorI0HG4ZPaFf294YvwNrmiXYHgEJam9YrTnaVHABXTdiI4aXM+LnBzMa4D+dtumxsXLATalo0KQn6Jt/vz3t5gw96sr6dfCKxNAooH8LgyFbufPCEIHTNCgA7BKrQaDNvQn1MH2yHYBBemDuqm0cVvMxhaUaJjhivvEATiWG4y3fmpyWPCnO80ef54r0zL7FHgV7MnablXjTufL8cRcTgc1VuKw//fJvfa5L+BscYKAAAAeJxjYGRgYABi/jvPp8Xz23xl4GZ+ARSI4ny8rwFG///2/xvzZ+ZPQJUcDExAkgEAoUMP6XicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AIAnloHAgAAeJxjYGBgYH5Ba/z/G+3M/f+NgQ4AAPv8MfAAAHicY2AAAgmGIIYshhaGC4wijCGMPYz7GF8xGTGFMVUwTWC6wGzGPIf5BwsfiwZLCcsOlgssL1gnsB5iE2EzYGtim8K2jZ2HXYvdhX0Z+w72fxwRHAUcszhWcGzjOMJxieMZxxfOOi4O0iEAtgsblgB4nGNgZGBg8GLIYeBhAAEmIOYCQgaG/2A+AwAbuAHZAHicfZC9TsMwFIVP+odoBaoEYmAyCwtS+rPRtVKzd+ieJnaaKo2D41bqznPwBDxHn4OnYObEeCkStSXnu9899w4BMMQJAZoT4Ma9zWnhitUvt0n3njvkJ89dDBB67tG/eu7jBQvPA9zhjRuCzjXNI949t3CLD89t+k/PHfLJcxcP+PLco//23McqGHoe4DlQcRaZPJ0XcV3nyVJm+yI2Z+6sWElT57oUk3B85iNZShNbmYr1UdSHbGqtEsronVjo0sqi0KIyeisTG26srWajkfI+TPQOMTJEMMiRYo6Cdc2bI8ESkr29c+ZC7v/OihuMY40SAhP+9/GFfMR86WZiWH5Tzqxx5FvjwKkprYVirZjR2JEWbneTLng1TeV6W5qEPsTGTVWYYcSr/uRDprjpB8WrbRMAeJxtkmdv2zAURX1iyVbstEnTNt17D7VN994z/RUMRctEJFIgKY/8+rJxGiBA36dzHx7uu3xgZ6mzqEHn/7XFEl0SUnr0yVhmwJAVjnCUVdY4xjrHOcFJNjjFac5wlnOc5wIXucRlrnCVa1znBje5xW3ucJd73CfnAQ95xCaPecJTnvGcF7zkFa95w1ve8Z4PfOQTn/nCV77xnR/85Bdb/O4MRVk6VYqgrekJ5+zUd4WXPSmMVFUqx8KFNTlWcmfbzvI9UMXGQUObQgXlam1EUOsH7dbsT65IW1mXNzoK14+irY0fSGuCEzKoIpG2mafSWe+TQnmZqVkjomexrOYq95Xw4+EB5ZvdyL2RruLKdKSdD0npdJOWzrZNEkdCUqlR6FXaxN39yopCmzKrxUzXelcltTJtFrMulFGzkBhr1NDYkIuqslNVpE10Ud1Gm7TRExuyxqmJtq1fc9HM5tttCNbkdjRaPdwwqdPlOCReTNTA19EuL+zU7OPfWMMF7o1lC46pQzzNenBKHb5l1prFKwb/IN9EUOJQBDQWwxSPpGLMDtvM4lcoqGlpmDNil0mn8wcxorJdAAA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-bootstrap .ag-icon {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-bootstrap .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-bootstrap .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-bootstrap .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-bootstrap .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-bootstrap .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-bootstrap .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-bootstrap .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-bootstrap .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-bootstrap .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-bootstrap .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-bootstrap .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-bootstrap .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-bootstrap .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-bootstrap .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-bootstrap .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-bootstrap .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-bootstrap .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-bootstrap .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-bootstrap .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-bootstrap .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-bootstrap .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-bootstrap .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-bootstrap .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-bootstrap .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-bootstrap .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-bootstrap .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-bootstrap .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-bootstrap .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-bootstrap .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-bootstrap .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-bootstrap .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-bootstrap .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-bootstrap .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-bootstrap .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-bootstrap .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-bootstrap .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-bootstrap .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-bootstrap .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-bootstrap .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-bootstrap .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-bootstrap .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-bootstrap .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-bootstrap .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-bootstrap .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-bootstrap .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-bootstrap .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-bootstrap .ag-root-wrapper {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-bootstrap [class^='ag-'], .ag-theme-bootstrap [class^='ag-']:focus, .ag-theme-bootstrap [class^='ag-']:after, .ag-theme-bootstrap [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-bootstrap [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-bootstrap .ag-checkbox .ag-input-wrapper,\n .ag-theme-bootstrap .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-bootstrap .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-bootstrap .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-bootstrap .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px; }\n .ag-theme-bootstrap input[class^='ag-'] {\n margin: 0;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-bootstrap textarea[class^='ag-'],\n .ag-theme-bootstrap select[class^='ag-'] {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-bootstrap input[class^='ag-']:not([type]),\n .ag-theme-bootstrap input[class^='ag-'][type='text'],\n .ag-theme-bootstrap input[class^='ag-'][type='number'],\n .ag-theme-bootstrap input[class^='ag-'][type='tel'],\n .ag-theme-bootstrap input[class^='ag-'][type='date'],\n .ag-theme-bootstrap input[class^='ag-'][type='datetime-local'],\n .ag-theme-bootstrap textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #000;\n border-color: var(--ag-input-border-color, #000); }\n .ag-theme-bootstrap input[class^='ag-']:not([type]):disabled,\n .ag-theme-bootstrap input[class^='ag-'][type='text']:disabled,\n .ag-theme-bootstrap input[class^='ag-'][type='number']:disabled,\n .ag-theme-bootstrap input[class^='ag-'][type='tel']:disabled,\n .ag-theme-bootstrap input[class^='ag-'][type='date']:disabled,\n .ag-theme-bootstrap input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-bootstrap textarea[class^='ag-']:disabled {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n background-color: #ebebeb;\n background-color: var(--ag-input-disabled-background-color, #ebebeb);\n border-color: rgba(0, 0, 0, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(0, 0, 0, 0.3)); }\n .ag-theme-bootstrap input[class^='ag-']:not([type]):focus,\n .ag-theme-bootstrap input[class^='ag-'][type='text']:focus,\n .ag-theme-bootstrap input[class^='ag-'][type='number']:focus,\n .ag-theme-bootstrap input[class^='ag-'][type='tel']:focus,\n .ag-theme-bootstrap input[class^='ag-'][type='date']:focus,\n .ag-theme-bootstrap input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-bootstrap textarea[class^='ag-']:focus {\n outline: none;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-bootstrap input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-bootstrap input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-bootstrap input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-bootstrap .ag-drag-handle {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-list-item, .ag-theme-bootstrap .ag-virtual-list-item {\n height: 20px; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-select-list {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-bootstrap .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-bootstrap .ag-list-item.ag-active-item {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-bootstrap .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-bootstrap .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-bootstrap .ag-select .ag-picker-field-wrapper {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n min-height: 20px;\n cursor: default; }\n .ag-theme-bootstrap .ag-select:not(.ag-cell-editor) {\n height: 20px; }\n .ag-theme-bootstrap .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-bootstrap .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-bootstrap .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-bootstrap .ag-rich-select {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-bootstrap .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 162.5px; }\n .ag-theme-bootstrap .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 25px; }\n .ag-theme-bootstrap .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 20px; }\n .ag-theme-bootstrap .ag-rich-select-virtual-list-item:hover {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-bootstrap .ag-rich-select-row {\n padding-left: 12px; }\n .ag-theme-bootstrap .ag-rich-select-row-selected {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5); }\n .ag-theme-bootstrap .ag-row-drag,\n .ag-theme-bootstrap .ag-selection-checkbox,\n .ag-theme-bootstrap .ag-group-expanded,\n .ag-theme-bootstrap .ag-group-contracted {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-ltr .ag-row-drag, .ag-theme-bootstrap .ag-ltr .ag-selection-checkbox, .ag-theme-bootstrap .ag-ltr .ag-group-expanded, .ag-theme-bootstrap .ag-ltr .ag-group-contracted {\n margin-right: 12px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-drag, .ag-theme-bootstrap .ag-rtl .ag-selection-checkbox, .ag-theme-bootstrap .ag-rtl .ag-group-expanded, .ag-theme-bootstrap .ag-rtl .ag-group-contracted {\n margin-left: 12px; }\n .ag-theme-bootstrap .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 23px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-bootstrap .ag-group-expanded,\n .ag-theme-bootstrap .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-bootstrap .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-bootstrap .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-bootstrap .ag-group-title-bar {\n background-color: #ececec;\n background-color: var(--ag-subheader-background-color, #ececec);\n padding: 4px; }\n .ag-theme-bootstrap .ag-group-toolbar {\n padding: 4px; }\n .ag-theme-bootstrap .ag-disabled-group-title-bar, .ag-theme-bootstrap .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-bootstrap .group-item {\n margin: 2px 0; }\n .ag-theme-bootstrap .ag-label {\n white-space: nowrap; }\n .ag-theme-bootstrap .ag-ltr .ag-label {\n margin-right: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-label {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-label-align-top .ag-label {\n margin-bottom: 2px; }\n .ag-theme-bootstrap .ag-ltr .ag-slider-field, .ag-theme-bootstrap .ag-ltr .ag-angle-select-field {\n margin-right: 8px; }\n .ag-theme-bootstrap .ag-rtl .ag-slider-field, .ag-theme-bootstrap .ag-rtl .ag-angle-select-field {\n margin-left: 8px; }\n .ag-theme-bootstrap .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-bootstrap .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #000;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 5px; }\n .ag-theme-bootstrap .ag-picker-field-button {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-bootstrap .ag-color-picker .ag-picker-field-display {\n height: 12px; }\n .ag-theme-bootstrap .ag-color-panel {\n padding: 4px; }\n .ag-theme-bootstrap .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-bootstrap .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-bootstrap .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-bootstrap .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-bootstrap .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-bootstrap .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-bootstrap .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-bootstrap .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-bootstrap .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-bootstrap .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-bootstrap .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-bootstrap .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-bootstrap.ag-dnd-ghost {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px !important;\n line-height: 25px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px); }\n .ag-theme-bootstrap .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #000;\n color: var(--ag-foreground-color, #000); }\n .ag-theme-bootstrap .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3); }\n .ag-dragging-range-handle .ag-theme-bootstrap .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-bootstrap .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-bootstrap .ag-dialog {\n border-radius: 0px; }\n .ag-theme-bootstrap .ag-panel {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-bootstrap .ag-panel-title-bar {\n background-color: var(--ag-header-background-color);\n color: #000;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)));\n height: 25px;\n padding: 4px 12px; }\n .ag-theme-bootstrap .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px; }\n .ag-theme-bootstrap .ag-tooltip {\n background-color: var(--ag-header-background-color);\n color: #000;\n color: var(--ag-foreground-color, #000);\n padding: 4px;\n border-radius: 0px;\n transition: opacity 1s; }\n .ag-theme-bootstrap .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px; }\n .ag-theme-bootstrap .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 6px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 6px; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-column-select-column-group:not(:last-child),\n .ag-theme-bootstrap .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px; }\n .ag-theme-bootstrap .ag-column-select-column-readonly,\n .ag-theme-bootstrap .ag-column-select-column-group-readonly {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n pointer-events: none; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 20px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 20px; }\n .ag-theme-bootstrap .ag-column-select-list {\n padding: 6px 6px; }\n .ag-theme-bootstrap .ag-rtl {\n text-align: right; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 36px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 36px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-1 {\n padding-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-1 {\n padding-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 60px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 60px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-2 {\n padding-left: 48px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-2 {\n padding-right: 48px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 84px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 84px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-3 {\n padding-left: 72px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-3 {\n padding-right: 72px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 108px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 108px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-4 {\n padding-left: 96px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-4 {\n padding-right: 96px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 132px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 132px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-5 {\n padding-left: 120px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-5 {\n padding-right: 120px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 156px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 156px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-6 {\n padding-left: 144px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-6 {\n padding-right: 144px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 180px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 180px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-7 {\n padding-left: 168px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-7 {\n padding-right: 168px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 204px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 204px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-8 {\n padding-left: 192px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-8 {\n padding-right: 192px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 228px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 228px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-9 {\n padding-left: 216px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-9 {\n padding-right: 216px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 252px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 252px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-10 {\n padding-left: 240px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-10 {\n padding-right: 240px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 276px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 276px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-11 {\n padding-left: 264px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-11 {\n padding-right: 264px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 300px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 300px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-12 {\n padding-left: 288px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-12 {\n padding-right: 288px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 324px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 324px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-13 {\n padding-left: 312px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-13 {\n padding-right: 312px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 348px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 348px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-14 {\n padding-left: 336px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-14 {\n padding-right: 336px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 372px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 372px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-15 {\n padding-left: 360px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-15 {\n padding-right: 360px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 396px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 396px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-16 {\n padding-left: 384px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-16 {\n padding-right: 384px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 420px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 420px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-17 {\n padding-left: 408px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-17 {\n padding-right: 408px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 444px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 444px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-18 {\n padding-left: 432px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-18 {\n padding-right: 432px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 468px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 468px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-19 {\n padding-left: 456px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-19 {\n padding-right: 456px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-bootstrap .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-bootstrap .ag-value-change-delta-up {\n color: darkgreen;\n color: var(--ag-value-change-delta-up-color, darkgreen); }\n .ag-theme-bootstrap .ag-value-change-delta-down {\n color: darkred;\n color: var(--ag-value-change-delta-down-color, darkred); }\n .ag-theme-bootstrap .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-bootstrap .ag-value-change-value-highlight {\n background-color: #cec;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec);\n transition: background-color 0.1s; }\n .ag-theme-bootstrap .ag-cell-data-changed {\n background-color: #cec !important;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec) !important; }\n .ag-theme-bootstrap .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-cell-highlight {\n background-color: rgba(136, 255, 136, 0.4) !important;\n background-color: var(--ag-range-selection-highlight-color, rgba(136, 255, 136, 0.4)) !important; }\n .ag-theme-bootstrap .ag-row {\n height: 25px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n color: #000;\n color: var(--ag-data-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-row-highlight-above::after, .ag-theme-bootstrap .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #000;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n left: 1px; }\n .ag-theme-bootstrap .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-bootstrap .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-bootstrap .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-bootstrap .ag-row-odd {\n background-color: #f6f6f6;\n background-color: var(--ag-odd-row-background-color, #f6f6f6); }\n .ag-theme-bootstrap .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-bootstrap .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-bootstrap .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-bootstrap .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-bootstrap .ag-cell {\n border: 1px solid transparent;\n line-height: 23px;\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-bootstrap .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-bootstrap .ag-row-dragging {\n cursor: move; }\n .ag-theme-bootstrap .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-bootstrap .ag-cell-inline-editing {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 25px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-bootstrap .ag-popup-editor {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n padding: 0; }\n .ag-theme-bootstrap .ag-large-text-input {\n height: auto;\n padding: 12px; }\n .ag-theme-bootstrap .ag-details-row {\n padding: 20px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-bootstrap .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66)); }\n .ag-theme-bootstrap .ag-overlay-loading-center {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px; }\n .ag-theme-bootstrap .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-bootstrap .ag-loading {\n padding-left: 12px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-bootstrap .ag-loading-icon {\n padding-right: 12px; }\n .ag-theme-bootstrap .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-bootstrap .ag-ltr .ag-cell {\n border-right: solid transparent; }\n .ag-theme-bootstrap .ag-rtl .ag-cell {\n border-left: solid transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-bootstrap .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-bootstrap .ag-row-selected {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5); }\n .ag-theme-bootstrap .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(0, 0, 0, 0.2)); }\n .ag-theme-bootstrap .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1);\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)); }\n .ag-theme-bootstrap .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)); }\n .ag-theme-bootstrap .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(0, 0, 0, 0.2))); }\n .ag-theme-bootstrap .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(0, 0, 0, 0.36)); }\n .ag-theme-bootstrap .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(0, 0, 0, 0.488)); }\n .ag-theme-bootstrap .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(0, 0, 0, 0.5904)); }\n .ag-theme-bootstrap .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #000;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #000;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-bootstrap .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-bootstrap .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-bootstrap .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-bootstrap .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-bootstrap .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n outline: initial; }\n .ag-theme-bootstrap .ag-cell.ag-selection-fill-top,\n .ag-theme-bootstrap .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #000;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-bootstrap .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-bootstrap .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-cell.ag-selection-fill-bottom,\n .ag-theme-bootstrap .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #000;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-bootstrap .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-bootstrap .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-fill-handle, .ag-theme-bootstrap .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #000;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-ltr .ag-fill-handle, .ag-theme-bootstrap .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-bootstrap .ag-rtl .ag-fill-handle, .ag-theme-bootstrap .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-bootstrap .ag-fill-handle {\n cursor: cell; }\n .ag-theme-bootstrap .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-bootstrap .ag-cell-inline-editing {\n border-color: var(--ag-input-focus-border-color) !important; }\n .ag-theme-bootstrap .ag-menu {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n padding: 0; }\n .ag-theme-bootstrap .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-bootstrap .ag-menu-option-part {\n padding-top: 6px;\n padding-bottom: 6px;\n line-height: 12px; }\n .ag-theme-bootstrap .ag-menu-option-active {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-bootstrap .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-bootstrap .ag-menu-option-text {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-menu-option-icon {\n padding-left: 8px;\n padding-right: 4px;\n min-width: 20px; }\n .ag-theme-bootstrap .ag-menu-option-shortcut {\n padding-left: 8px; }\n .ag-theme-bootstrap .ag-menu-separator {\n height: 8px; }\n .ag-theme-bootstrap .ag-menu-separator-cell:after {\n content: \"\";\n display: block; }\n .ag-theme-bootstrap .ag-menu-option-popup-pointer {\n width: 20px;\n text-align: center; }\n .ag-theme-bootstrap .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-bootstrap .ag-tab {\n border-bottom: 0 solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-tab-selected {\n border-bottom-color: #000;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-menu-header {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px; }\n .ag-theme-bootstrap .ag-set-filter-select-all {\n padding-top: 6px; }\n .ag-theme-bootstrap .ag-set-filter-list {\n height: 120px; }\n .ag-theme-bootstrap .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px; }\n .ag-theme-bootstrap .ag-filter-to {\n margin-top: 4px; }\n .ag-theme-bootstrap .ag-mini-filter {\n margin: 6px 6px;\n margin-bottom: 0; }\n .ag-theme-bootstrap .ag-set-filter-item {\n margin: 0px 6px; }\n .ag-theme-bootstrap .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px; }\n .ag-theme-bootstrap .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px; }\n .ag-theme-bootstrap .ag-filter-header-container {\n padding-bottom: 6px; }\n .ag-theme-bootstrap .ag-filter-apply-panel {\n padding: 6px 6px; }\n .ag-theme-bootstrap .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px; }\n .ag-theme-bootstrap .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-bootstrap .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px; }\n .ag-theme-bootstrap .ag-filter-no-matches {\n margin: 6px 6px; }\n .ag-theme-bootstrap .ag-side-bar {\n position: relative; }\n .ag-theme-bootstrap .ag-tool-panel-wrapper {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-bootstrap .ag-side-buttons {\n padding-top: 16px;\n width: 16px;\n position: relative;\n color: #000;\n color: var(--ag-foreground-color, #000);\n overflow: hidden; }\n .ag-theme-bootstrap button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: 100%;\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none; }\n .ag-theme-bootstrap button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-bootstrap .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-bootstrap .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-bootstrap .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #000;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-bootstrap .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent; }\n .ag-theme-bootstrap .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-bootstrap .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #000;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-filter-toolpanel-header {\n height: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-header, .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-header, .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 4px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-0-header {\n height: 32px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-search {\n height: 25px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 16px; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-instance-filter {\n padding-top: 4px; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px; }\n .ag-theme-bootstrap .ag-pivot-mode-panel {\n height: 25px;\n display: flex; }\n .ag-theme-bootstrap .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-bootstrap .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px; }\n .ag-theme-bootstrap .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-column-select-header {\n height: 25px;\n align-items: center;\n padding: 0 6px; }\n .ag-theme-bootstrap .ag-column-group-icons,\n .ag-theme-bootstrap .ag-column-select-header-icon {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-header {\n background-color: var(--ag-header-background-color); }\n .ag-theme-bootstrap .ag-header-row {\n color: #000;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-header-row {\n height: 25px; }\n .ag-theme-bootstrap .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-bootstrap .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-header-cell,\n .ag-theme-bootstrap .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px; }\n .ag-theme-bootstrap .ag-header-cell.ag-header-cell-moving,\n .ag-theme-bootstrap .ag-header-group-cell.ag-header-cell-moving {\n background-color: #bebebe;\n background-color: var(--ag-header-cell-moving-background-color, #bebebe); }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-header-icon {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-bootstrap .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-bootstrap .ag-ltr .ag-header-select-all {\n margin-right: 12px; }\n .ag-theme-bootstrap .ag-rtl .ag-header-select-all {\n margin-left: 12px; }\n .ag-theme-bootstrap .ag-ltr .ag-floating-filter-button {\n margin-left: 12px; }\n .ag-theme-bootstrap .ag-rtl .ag-floating-filter-button {\n margin-right: 12px; }\n .ag-theme-bootstrap .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 12px;\n padding: 0;\n width: 12px; }\n .ag-theme-bootstrap .ag-filter-loading {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-bootstrap .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px; }\n .ag-theme-bootstrap .ag-paging-panel > * {\n margin: 0 12px; }\n .ag-theme-bootstrap .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 12px; }\n .ag-theme-bootstrap .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-bootstrap .ag-paging-button-wrapper.ag-disabled {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n cursor: default; }\n .ag-theme-bootstrap .ag-paging-button-wrapper, .ag-theme-bootstrap .ag-paging-description {\n margin: 0 4px; }\n .ag-theme-bootstrap .ag-status-bar {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5; }\n .ag-theme-bootstrap .ag-status-name-value-value {\n color: #000;\n color: var(--ag-foreground-color, #000); }\n .ag-theme-bootstrap .ag-status-bar-center {\n text-align: center; }\n .ag-theme-bootstrap .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px; }\n .ag-theme-bootstrap .ag-column-drop-cell {\n background: #ecf0f1;\n background: var(--ag-chip-background-color, #ecf0f1);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px; }\n .ag-theme-bootstrap .ag-column-drop-cell-text {\n margin: 0 4px; }\n .ag-theme-bootstrap .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-column-drop-cell-drag-handle {\n margin-left: 8px; }\n .ag-theme-bootstrap .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-bootstrap .ag-column-drop-horizontal {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px; }\n .ag-theme-bootstrap .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-column-drop-horizontal-empty-message {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5)); }\n .ag-theme-bootstrap .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px; }\n .ag-theme-bootstrap .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px; }\n .ag-theme-bootstrap .ag-column-drop-vertical-cell {\n margin-top: 4px; }\n .ag-theme-bootstrap .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px; }\n .ag-theme-bootstrap .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px; }\n .ag-theme-bootstrap .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-bootstrap .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n margin-top: 4px; }\n .ag-theme-bootstrap .ag-select-agg-func-popup {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n height: 70px;\n padding: 0; }\n .ag-theme-bootstrap .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 20px;\n padding-left: 8px; }\n .ag-theme-bootstrap .ag-select-agg-func-virtual-list-item:hover {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5); }\n .ag-theme-bootstrap .ag-chart-menu {\n border-radius: 0px;\n background: #FFF;\n background: var(--ag-background-color, #FFF); }\n .ag-theme-bootstrap .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 0px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-bootstrap .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-bootstrap .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-bootstrap .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-bootstrap .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-bootstrap .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-bootstrap .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-bootstrap .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-bootstrap .ag-chart-mini-thumbnail.ag-selected {\n border-color: #000;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-chart-settings-card-item {\n background: #000;\n background: var(--ag-foreground-color, #000);\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-bootstrap .ag-chart-settings-card-item.ag-selected {\n background-color: #000;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-chart-data-column-drag-handle {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-charts-settings-group-container {\n padding: 4px; }\n .ag-theme-bootstrap .ag-charts-data-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-bootstrap .ag-charts-data-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-bootstrap .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px; }\n .ag-theme-bootstrap .ag-charts-format-top-level-group-item {\n margin: 4px 0; }\n .ag-theme-bootstrap .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-bootstrap .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-bootstrap .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px; }\n .ag-theme-bootstrap .ag-chart-data-section,\n .ag-theme-bootstrap .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-bootstrap .ag-chart-menu-panel {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-bootstrap .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-bootstrap .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-bootstrap .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-bootstrap .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-bootstrap .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-bootstrap .ag-checkbox-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-bootstrap .ag-checkbox-input-wrapper input, .ag-theme-bootstrap .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-bootstrap .ag-checkbox-input-wrapper:focus-within, .ag-theme-bootstrap .ag-checkbox-input-wrapper:active {\n outline: none; }\n .ag-theme-bootstrap .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-bootstrap .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #000;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-bootstrap .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #000;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-bootstrap .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #000;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-bootstrap .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 24px;\n height: 12px;\n background-color: #000;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)));\n border-radius: 6px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-bootstrap .ag-toggle-button-input-wrapper:focus-within {\n outline: none; }\n .ag-theme-bootstrap .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-bootstrap .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #000;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)));\n border-color: #000;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n background-color: #FFF;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #FFF));\n border-radius: 6px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)))); }\n .ag-theme-bootstrap .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 12px);\n border-color: #000;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-radio-button-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 12px; }\n .ag-theme-bootstrap .ag-radio-button-input-wrapper input, .ag-theme-bootstrap .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-bootstrap .ag-radio-button-input-wrapper:focus-within, .ag-theme-bootstrap .ag-radio-button-input-wrapper:active {\n outline: none; }\n .ag-theme-bootstrap .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-bootstrap .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #000;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-bootstrap .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #000;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-bootstrap input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-bootstrap input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px; }\n .ag-theme-bootstrap input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px; }\n .ag-theme-bootstrap input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-bootstrap input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px;\n -webkit-transform: translateY(-4.5px);\n transform: translateY(-4.5px); }\n .ag-theme-bootstrap input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px; }\n .ag-theme-bootstrap input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px; }\n .ag-theme-bootstrap input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-bootstrap input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap input[class^='ag-'][type='range']:focus::-ms-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap input[class^='ag-'][type='range']:active::-ms-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-bootstrap .ag-icon {\n color: #333; }\n .ag-theme-bootstrap .ag-icon-tree-closed::before {\n content: \"\\f10b\"; }\n .ag-theme-bootstrap .ag-icon-tree-open::before {\n content: \"\\f10f\"; }\n .ag-theme-bootstrap .ag-header, .ag-theme-bootstrap .ag-column-drop-cell {\n background-image: none; }\n .ag-theme-bootstrap .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px; }\n .ag-theme-bootstrap .ag-tabs-body {\n margin: 2px 0; }\n .ag-theme-bootstrap .ag-icon {\n margin: 1px 1px 2px 1px; }\n .ag-theme-bootstrap .ag-tab-selected {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-bottom-color: transparent; }\n .ag-theme-bootstrap .ag-tabs-header {\n background-color: var(--ag-header-background-color);\n border-bottom: 1px solid;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-bootstrap .ag-filter .ag-filter-apply-panel {\n justify-content: flex-start; }\n .ag-theme-bootstrap .ag-menu-option-active {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5); }\n .ag-theme-bootstrap .ag-column-drop-cell {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0; }\n .ag-theme-bootstrap .ag-column-drop-cell-button .ag-icon {\n border: 1px solid transparent; }\n .ag-theme-bootstrap .ag-column-drop-cell-button:hover .ag-icon {\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey); }\n .ag-theme-bootstrap .ag-panel-title-bar-button-icon {\n font-size: 20px;\n line-height: 20px; }\n .ag-theme-bootstrap .ag-menu-option-part {\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-bootstrap .ag-column-drop-vertical-title-bar {\n margin-top: 4px;\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-column-drop-vertical-title {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-column-drop-vertical-empty-message {\n margin-left: 24px; }\n\n", ""]); +exports.push([module.i, ".ag-theme-bootstrap {\n -webkit-font-smoothing: antialiased;\n color: #000;\n color: var(--ag-foreground-color, #000);\n font-family: \"Helvetica Neue\", sans-serif;\n font-size: 14px;\n line-height: normal;\n}\n@font-face {\n font-family: \"agGridClassic\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABXwAAsAAAAAKrgAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAmMAAAR2Zoxou09TLzIAAANsAAAAQQAAAFZWVlMSY21hcAAAA7AAAAIbAAAFnIlT7KJnbHlmAAAFzAAADBkAABg4HeN0mGhlYWQAABHoAAAANAAAADZ2z8SBaGhlYQAAEhwAAAAeAAAAJAfTBCxobXR4AAASPAAAABgAAAE4yyH/7GxvY2EAABJUAAAAdgAAAJ5JCULobWF4cAAAEswAAAAfAAAAIAFkAKpuYW1lAAAS7AAAATMAAAJS8kTiWnBvc3QAABQgAAABzQAAArBhTs2TeJx9lMtOU1EUhv/DaREoAlG8pCIiGi+oiMrxXHpoy6WH1tbEgTEOnGBMjAlxxHP4AD4BQ5/AB3DgE/gADhw6Nn5r9WCFAey03Xtd/vXvf62NAklTWlNTYzvF4KVm9vcOPqquioZ/5v9/H+x/eL+niaMTvor/TiioTGtGy3qtA30LZoKD4HBsPqyHr8J34efwS/hLIVFLWiW6pqesWAnfkVJlaijXmMaxxew34BOymmq59RyMqu7pqqfL1IzJ6Tniip7xmQOncJyOtolKWYbZ4XvAuqfZUyJy3Qc/g80m1gqKLKJJrnlNgp4Q01Sb/Cb+89TcoXaEv8BXwK6KpcW+rQtwsoyKq9rVGz3Bbzc1lKzMSfnE2vVz5Kc1NDmKaoHToJZhr8LgyN6gakLGY9AzorZKRVd0k+wGOB3Q2p694dnLRCZwS3WDnd0zges08Zle6K1X3S1zOq7pUIFV2I/shePlenjM2gZrQOwjOIys1p8H1IrUx1+jV4X29UmH+qrv+qGf+q0/OqOL1En8Dtug75yqzQQKnozu4m39s9pdx5mBk1HHIya5ecPVifH1Sg2tWo2bmTop+whr6vFT8LT4Lmxy+lGhRuR1rdNV1ibnmOiz5XQ2WdOudI8pmPUJ7vss1HWHvi064nAOc7S+CqLthvyuuG5N8Ba8b6auvbA5P9lbsH7XmdVr/EbcMHOdnuO9jsWQRpYlz8phbxjr+HNYj6oZqwVYresuPpuxvr+OLpVucZ8hk4QIexl9n6/bMMjKlzpPD419u+zYJY+LPSvgP0FUvvDUtbOZLuBm8zH4C3G+c6UAeJxjYGSazTiBgZWBgamKaQ8DA0MPhGZ8wGDIyAQUZWBlZsAKAtJcUxgOMOh+NGJ+AeRGMX9i4ALSjCA5AOaCCwgAAAB4nLXUB1IbQRCF4V+BLMA22eQcBQaTcxAiHwJnCgcKZ87hs/kefQL8Rt0+AK7yVn3bO1Or3ZlavQaqgJzMSB6ytWR0RSar2UxlPkd9ZT7Pb40L1JLVdZErbrizhft7zRa55Jpby1RGf4+M7i7QwxjLGh2yxAE7lFnlXDN7rLPPLkdsssEJK2yzxjFnbFHilAv9Pq0irzVWU6P31mklDXpiI0084jEttNJGOx100kW33tRLH/0MMMgQw4wwyjgTTDLFtHZSZJY5njHPgs7PNVrUIqt52HH4wPvTsXSwU149X97TjnePNje02e2147Ot0unFPzzsPxyFdMr9itEZ6Yu6tNvLsCQvwoG8DDvyKpTldViVN+Fc3ob0b3gX9uQqrMt12Jf3YVc+hCP5GDblU9iQm3Ait2FFPodt+RLW5Gs4lm8h7f172JIfoSQ/w6ncBX1Ay7iUF8s6Us25lC/Lu5Qxq3Ipe1btSLXGkWqtI9U6R6r1LmXSGhypFlz6ktboSLXJkWqzU3awoBRhQXnCnjglC2txyhjW6pQ2rM0pd1i7UwKxDqcsYp1OqcS6nPKJPXVKKtbtlFmsxym9WK9TjrE+p0Rj/U7ZxgacUo4NOuUdG3JKPjbs1AOwEadugI069QVszKlDYONOvQKbcKkv2qRLebApp96BTTv1FGzGqa9gRac+g806dRxszlXuCepC2LyrPHPBsfgHpKymyQB4nO1Ye2wUxxnfmfXt3t57d+92zxycvXf4FkNico+99QMMGOOzcWzTnIMJaQ04GMWYRDEESJqktAElJErSShFVqUmAqj0XmlQFI+XRBxKpGleRGqePNKnyKn+0Sdq4pHXS6uRb+s3eww8ooPSfVu3Zu/P6Zuabb34z3+9bClHwo5P0IMVRFFJkVvEpIq3QSWN4717Un7v/9dfxAfzT8fERtBftBRFT/n36faoSChqr6jKr8oqZ6ApvJjKvmAmroHNdqbGxlnWIXgdpap2RW9cCaZdhkPpUF8J0JdcFVS1dlzblu1LFOdfTj1FWKLAqBw8fRt9+th/1ob7+Z47jXc9uRX3G01ufyX1YlMcTeIKym/KgC2gD+uCJljOjqTNnUqNnWkbRqmJutOUMZaGoiwas6wNKpMKUSi2hllKURQnVII1PNKK4EgsiH+91IVoJMZCRoCYJTREU58NVcV+YhpTenhOV+lCoXsEfwUupV3Iej9/vwRd4Wc59N51GHen0SHc3DtWF8Mfwgv+cG17012U+x/N+P4//wsvGqPF2JoOOGZth2bP0WgzrKSoSnlbOMkcnFsF6RZnebioRKik1MUOdAWPi74kT59fSHxSVKCp180xdXjRsP1t1EB1dRM3VRb02XWhFU66oyO+N06jzKloYzgzZ0lnzX9vsV5r5KpOS9cKi76G3AjqslJ+iAHgyh2i9AjEs/Pm8EsySUCMq/pOxqf42I4cax8Ze/oHdXu6WomuikrscnUPHG6DBeAktHxtrdDqDgUh5KBoNlVfND5LhGXOOQ/QhmI0FvLphbTJFVfnAbPDQc1J03DhNNxmnM7OS7Aj8UEcGfqiT5KmC7h8UbLX02qyFAMe+sBbW4lqcHgwRi4Hl8hYkljMtQyxnvDJi/vIWFAoWnChYUAQJHn8E23aGqDRCUUV9mugmc5U86BPnFS0MN4XCK7Sm8HEND2cMRwZNpo1R1DFijKbxsFnOQvk4VGap0l3wAP0AOdscgu1gOQQ3go4mkbDHmDBfxsQeJMALb59VRAIU8za/OEXfSf+Z8oB1FlCt1Jepp2DoCOykZYZF6LCGQEFGlhqQWOV14XCopkxLNOI4saWXCUXUGhSGDt4giiX1RhSTZGLgEFRriWQsSMcJPmqQWoOJuWNBXOiU71OBJDmI4WZK6tFGsj9enxu5MGzPUhq6S/Qd7La7LEanqusqTqp6y6jRhB7BiLZ4foeNTZwQ9Hpkr8dmcfoVUV4o2pzWMqvXLc93yJUSg60u2ykhJC3gnR7OZWWtbgcv2QWPN8ALFZLg5602J1tmcQcFxm4RBLtTsC1bshjT2Gq3WrCGWZvbweA4jWyCFf/RuudBC65Vp141lXlkfOpR+p7flHN87mu/dVQERasQqKzyhbSId74qcG6b0+dNxCqXSH6/ze1yl1dLbnuVYHfZy3mHLLh4K8OKSk2V6PT5fR6b3S2ITs7O0SxrYcUFT/zwR5ydsbFOm4X7Nee2ci7uF27O5hGo/+/df/XeFf34QdOP83FgC+TgfufYM/3G08bT/ehe7MpNQuEo2tIPomVz9rrtqvusQ2skkYzHpAq0ApNtk3xeN5Jhe1woFFmKWAKEiJa48vZcf0s7x1q8bl70LFtpczFOq1v0dXY7bJzgFco29JRxPNRcybBj9w66nHbJI/o3bnQLFovHwS+44163T3BxHLPvi4yV4d2mTf4X1vjZeAPxelfy3k8YjquxhtFMZtr3vEzrVDkVpZbB/LqcjEuyJLvAoQM7RMkVSAuHwKerYg1WGTaIZEmXGWJp+EuCgGl1FeSRkoisaHr4vqEN1Xc0aqsqXcYva9pVW+OS2uv3/SH5+WW25kT0sc7052Jf2LhlfWPd0tjG3eiNdS0uQQoq9obraNeiG4Sym9r3L7890hxfZEf7bBilLYwrYLzN1G7QYq3Nt0l++8r5Ni5R1Rhb+9CNxuForyjLFfPi3YHptcjgQxdRSVgLWYdJRwq6JiFP6iS9qDS5ldSqyHIUJnIyiOhoiqyga8/9D371fqLkLbu+cldzYmVv3+13bV6/1lTW0XL73oGUDa1Ftq5kKlm1KBlZRvvodPuDezq6HI61keWx9gPtN5+MtW7QaxlGj20VZamyvPbWRLK3nnbOX4ys9nntXiuLqTx3M3nODuBSEGmICuJVLeqLa2mTx2ToQWC9m0ay3d0FWTwF/J02oxI+zAOhVVkZrUhjz0sv1WazeMJwoEmj+dw5KBBxR4FfnJ3FowJUxTSb14HdFB90lbwCHGgkk8ma/8BC/lUOHctkxjMm8Tp2aQIqWQrrPgtnW6GqqGrqesJ9TDIHXKtA60oPH9YUFPZBLJF/quBBx4HVgY2A4ZGUsCMz3dyNOgvTmerQg2kwXyadhSSbxqlsTkij493AndLp/xg95uxtVZiPIxKdsXgqnc5dMDc3O2Nn8z7jGL3e9BkykD0SoqJtJ/Je4iSuR8dO5OPAk4Ro4oufXvyU/hv9VypBDeZPB+MmdB08txrR4aCDc5bztS4UxFDRiIhb16IRkoUmcv+yZjORk+MS6aQm1CgRM+WDuNgM5AEa9aQawV+q83oX1R6o62y/sWOnF351rbZyAWEelzHlAa+gtbUF9s8XxADnx+XVVskmCUis67ixvbPuQO0iEBd8yCZZF/ux084FRDGwP9DWpgneQDlTBoMgodzWWkfGhZk62w/DTKSw0xyglfO4tJhVYOYFWtuSXjFwINDaGuB4T8hfbcWMh8xkqnSg9jCIC24WW6v9IQ/H2ojggYDoTba1BuYxgjWmuTxcq7mKmef2EJymCvPmZOF4wKUJcQLcnHBMYPMgWojrmhpmfTh1eM/hN96AV6aU+cajfX2P9uEfz6okmdzzfaTJ9IEzY9zoNUberBnUIx3ucFm/cuz90bup6HDtEfR26r3oU7VPXSUAzzWm3rnhCIg/8F4qCmnJh0zHaWaEhgoPfWjqJ3RT/snmIzEShxX9+2dZm25+toAlkovvymu7753UDUf0YZRIvUuUvtrasoW1PQkmOaIfKX0veRzOpIXsMDmN6FbzJKJY8YLNn8MA/SvKOf0NxuRvMhoe6EcqUvsHBvqNN403+wfwqe1QA7ntxkPboQ7athd4wEWwxYeUl1pIxQkPICfMQ5xXJXFVHvBMSQs5s/EYyZLYeik5jqZvBt5NTufkwbuHmtasaRq62/h491BTc3PT0G40nnsuuaopNbRlk14ny4vbtFWrodBbW+eXF9MfgvBu48LunUR4527kgW5rPsk9t1iW6/TevqFU08pkW76wZai1aVWyhPsmehB2252PViFEjcvkpoSoldxq27KZkbRxOo0maX+uHw+nR8j992/2RaU4GUoozMthVg3r5DrGE72nsul09lQvmgT3NzaQzQ6g2nTex5QwpgArqKVWXB5lhOSYMGsAn6pZIPIm7DL/Dc881OR0i8QBkC8nczCXu3Mfwdy+EXpl7kUc5OV/OBuGhhocZx1msmM8dx63yJegD1/I5OGHU3DBv+Dn0TLHjH5OnMp8iZfnYND09vjxORjEM/BTDVImKDwEQpUELR4CIdaElJe0hEyiTFrQ5MMlpLiL6DlogqVO37TlPAAFfr1bLo+Umwkuzvf1EuHePhDW62ZjudrkYZfDsmyqSGArmYAm34oiIuHpNShhho2XhfPDQ0WNzhd1fGT1roO7Vpuva9bS2Nxc6LJ613T8dbTgS1Wdg0fR8P7v9aMtxtH+E7mf49TJfCh2YqSE40HAsZOSCA8DWlC6oyyFT71xAPDz6WgIt4aixuiO+vHx+h3d4MDfQguNt8iXLrRw/o6G8fGGHejJaXzjYTI6sMAR/E1jFA8bp0v30DBgH5NvOzzhF2gSdeS2zW3DeepBrwLSODpnTA4RgtKRlyi0ZegUwRUHATuiM7nXjFf2nEUv4NdyryFtN+Sm9WolO0uOACiW2wbgJNUlThGmUlQP3P2Sdy6nqECkrsAokjGZlmIlpsB4obXAE0gP1qyTEcEDioTyBSmGb2LZnhn0oYcV2U6G2QBcgDjnHtbLhuDpIS4e6MEGhukEiZ4ZNKCHZbH/Opdr6luuiAtSutcVefVSmY7Zo6Dvz56k41I1pj65DkaE4WBU1QnD/xPnjHQ0AAAAeJxjYGRgYADiY81JvPH8Nl8ZuJlfAAWiOB/va4DR/7/9/8b8mfkTUCUHAxOQZAAAhKEPOXicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AMAnl4HBgAAeJxjYGBgYH5Bb/z/Gy3NZqADAAB/FDOneJxjYAACCYYghiyGFoYLjGKMYYx9jAcY3zCZMEUwVTFHsJix+LEcYDViLWK9wWbC5sWWwraB7Qu7BXsAewaHAIcTxxSODZxMnCKcZpw9nKs4T3A+4nLhCuOaw/WNm4/bgtuNO4Q7ibuAu4V7Eo8M6RAAslkbZAAAeJxjYGRgYPBjmMfAwwACTEDMBYQMDP/BfAYAIQYCDwB4nH2QvU7DMBSFT/qHaAWqBGJgMgsLUvqz0bVSs3foniZ2miqNg+NW6s5z8AQ8R5+Dp2DmxHgpErUl57vfPfcOATDECQGaE+DGvc1p4YrVL7dJ95475CfPXQwQeu7Rv3ru4wULzwPc4Y0bgs41zSPePbdwiw/PbfpPzx3yyXMXD/jy3KP/9tzHKhh6HuA5UHEWmTydF3Fd58lSZvsiNmfurFhJU+e6FJNwfOYjWUoTW5mK9VHUh2xqrRLK6J1Y6NLKotCiMnorExturK1mo5HyPkz0DjEyRDDIkWKOgnXNmyPBEpK9vXPmQu7/zoobjGONEgIT/vfxhXzEfOlmYlh+U86sceRb48CpKa2FYq2Y0diRFm53ky54NU3leluahD7Exk1VmGHEq/7kQ6a46QfFq20TAHicbZIHb9swEIX9xZKt2GmTpm269x5q6+6990h/A0PRMhGZFEjKdvLry9pBgQA9gIf3Dod37w5sLbUW0Wv9PzZZok1CSocuGcv06LPCAQ6yyhqHWOcwRzjKBsc4zglOcorTnOEs5zjPBS5yictc4SrXuM4NbnKL2+Tc4S73GHCfBzzkEY95wlOe8ZwXvOQVr3nDW97xng985BOf+cJXvvGdH/zkF5v8bvVFWTpViqCt6Qjn7NS3hZcdKYxUVSpHwoU1OVJye8vO8jlQxca/gjaFCsqNtRFBrf8rN2avc0Xayrq81pG4biTN2PietCY4IYMqEmnrnVQ6631b+kkaXz5ICuVlqmbRQHee80GmZrWIs4pltaNyXwk/akfUGeoqjk+H2vmQlE7XaelsU3fnOSrFxpBUahg6lTbRT7eyotCmzMZipsd6VyVjZZos+l8wo2YhMdaovrEhF1Vlp6pI66iiuvOcD9q1NmmtJzZktVMTbRu/5qKozbeaEKzJ7XC4ur9gUqfLUUi8mKieH0fZvLBTswf/2usv4LwtW+CmTkI823pwSu2/c9aYxTYIShyKgMZimOKRVIzYZotZ/CMFYxpqdpgwZLfV+gPpZLiDAAAA\") format(\"woff\");\n font-weight: normal;\n font-style: normal;\n}\n.ag-theme-bootstrap .ag-icon {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n.ag-theme-bootstrap .ag-icon-aggregation::before {\n content: \"\\f101\";\n}\n.ag-theme-bootstrap .ag-icon-arrows::before {\n content: \"\\f102\";\n}\n.ag-theme-bootstrap .ag-icon-asc::before {\n content: \"\\f103\";\n}\n.ag-theme-bootstrap .ag-icon-cancel::before {\n content: \"\\f104\";\n}\n.ag-theme-bootstrap .ag-icon-chart::before {\n content: \"\\f105\";\n}\n.ag-theme-bootstrap .ag-icon-color-picker::before {\n content: \"\\f109\";\n}\n.ag-theme-bootstrap .ag-icon-columns::before {\n content: \"\\f10a\";\n}\n.ag-theme-bootstrap .ag-icon-contracted::before {\n content: \"\\f10b\";\n}\n.ag-theme-bootstrap .ag-icon-copy::before {\n content: \"\\f10c\";\n}\n.ag-theme-bootstrap .ag-icon-cross::before {\n content: \"\\f10d\";\n}\n.ag-theme-bootstrap .ag-icon-csv::before {\n content: \"\\f10e\";\n}\n.ag-theme-bootstrap .ag-icon-desc::before {\n content: \"\\f10f\";\n}\n.ag-theme-bootstrap .ag-icon-excel::before {\n content: \"\\f110\";\n}\n.ag-theme-bootstrap .ag-icon-expanded::before {\n content: \"\\f111\";\n}\n.ag-theme-bootstrap .ag-icon-eye-slash::before {\n content: \"\\f112\";\n}\n.ag-theme-bootstrap .ag-icon-eye::before {\n content: \"\\f113\";\n}\n.ag-theme-bootstrap .ag-icon-filter::before {\n content: \"\\f114\";\n}\n.ag-theme-bootstrap .ag-icon-first::before {\n content: \"\\f115\";\n}\n.ag-theme-bootstrap .ag-icon-grip::before {\n content: \"\\f116\";\n}\n.ag-theme-bootstrap .ag-icon-group::before {\n content: \"\\f117\";\n}\n.ag-theme-bootstrap .ag-icon-last::before {\n content: \"\\f118\";\n}\n.ag-theme-bootstrap .ag-icon-left::before {\n content: \"\\f119\";\n}\n.ag-theme-bootstrap .ag-icon-linked::before {\n content: \"\\f11a\";\n}\n.ag-theme-bootstrap .ag-icon-loading::before {\n content: \"\\f11b\";\n}\n.ag-theme-bootstrap .ag-icon-maximize::before {\n content: \"\\f11c\";\n}\n.ag-theme-bootstrap .ag-icon-menu::before {\n content: \"\\f11d\";\n}\n.ag-theme-bootstrap .ag-icon-minimize::before {\n content: \"\\f11e\";\n}\n.ag-theme-bootstrap .ag-icon-next::before {\n content: \"\\f11f\";\n}\n.ag-theme-bootstrap .ag-icon-none::before {\n content: \"\\f120\";\n}\n.ag-theme-bootstrap .ag-icon-not-allowed::before {\n content: \"\\f121\";\n}\n.ag-theme-bootstrap .ag-icon-paste::before {\n content: \"\\f122\";\n}\n.ag-theme-bootstrap .ag-icon-pin::before {\n content: \"\\f123\";\n}\n.ag-theme-bootstrap .ag-icon-pivot::before {\n content: \"\\f124\";\n}\n.ag-theme-bootstrap .ag-icon-previous::before {\n content: \"\\f125\";\n}\n.ag-theme-bootstrap .ag-icon-right::before {\n content: \"\\f128\";\n}\n.ag-theme-bootstrap .ag-icon-save::before {\n content: \"\\f129\";\n}\n.ag-theme-bootstrap .ag-icon-small-down::before {\n content: \"\\f12a\";\n}\n.ag-theme-bootstrap .ag-icon-small-left::before {\n content: \"\\f12b\";\n}\n.ag-theme-bootstrap .ag-icon-small-right::before {\n content: \"\\f12c\";\n}\n.ag-theme-bootstrap .ag-icon-small-up::before {\n content: \"\\f12d\";\n}\n.ag-theme-bootstrap .ag-icon-tick::before {\n content: \"\\f12e\";\n}\n.ag-theme-bootstrap .ag-icon-tree-closed::before {\n content: \"\\f12f\";\n}\n.ag-theme-bootstrap .ag-icon-tree-indeterminate::before {\n content: \"\\f130\";\n}\n.ag-theme-bootstrap .ag-icon-tree-open::before {\n content: \"\\f131\";\n}\n.ag-theme-bootstrap .ag-icon-unlinked::before {\n content: \"\\f132\";\n}\n.ag-theme-bootstrap .ag-icon-row-drag::before {\n content: \"\\f116\";\n}\n.ag-theme-bootstrap .ag-left-arrow::before {\n content: \"\\f119\";\n}\n.ag-theme-bootstrap .ag-right-arrow::before {\n content: \"\\f128\";\n}\n.ag-theme-bootstrap .ag-root-wrapper {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n}\n.ag-theme-bootstrap [class^=ag-], .ag-theme-bootstrap [class^=ag-]:focus, .ag-theme-bootstrap [class^=ag-]:after, .ag-theme-bootstrap [class^=ag-]:before {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n outline: none;\n}\n.ag-theme-bootstrap [class^=ag-]::-ms-clear {\n display: none;\n}\n.ag-theme-bootstrap .ag-checkbox .ag-input-wrapper,\n.ag-theme-bootstrap .ag-radio-button .ag-input-wrapper {\n overflow: visible;\n}\n.ag-theme-bootstrap .ag-range-field .ag-input-wrapper {\n height: 100%;\n}\n.ag-theme-bootstrap .ag-toggle-button {\n -webkit-box-flex: 0;\n flex: none;\n width: unset;\n min-width: unset;\n}\n.ag-theme-bootstrap .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px;\n}\n\n.ag-theme-bootstrap input[class^=ag-] {\n margin: 0;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n}\n.ag-theme-bootstrap textarea[class^=ag-],\n.ag-theme-bootstrap select[class^=ag-] {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n}\n.ag-theme-bootstrap input[class^=ag-]:not([type]),\n.ag-theme-bootstrap input[class^=ag-][type=text],\n.ag-theme-bootstrap input[class^=ag-][type=number],\n.ag-theme-bootstrap input[class^=ag-][type=tel],\n.ag-theme-bootstrap input[class^=ag-][type=date],\n.ag-theme-bootstrap input[class^=ag-][type=datetime-local],\n.ag-theme-bootstrap textarea[class^=ag-] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #000;\n border-color: var(--ag-input-border-color, #000);\n}\n.ag-theme-bootstrap input[class^=ag-]:not([type]):disabled,\n.ag-theme-bootstrap input[class^=ag-][type=text]:disabled,\n.ag-theme-bootstrap input[class^=ag-][type=number]:disabled,\n.ag-theme-bootstrap input[class^=ag-][type=tel]:disabled,\n.ag-theme-bootstrap input[class^=ag-][type=date]:disabled,\n.ag-theme-bootstrap input[class^=ag-][type=datetime-local]:disabled,\n.ag-theme-bootstrap textarea[class^=ag-]:disabled {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n background-color: #ebebeb;\n background-color: var(--ag-input-disabled-background-color, #ebebeb);\n border-color: rgba(0, 0, 0, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(0, 0, 0, 0.3));\n}\n.ag-theme-bootstrap input[class^=ag-]:not([type]):focus,\n.ag-theme-bootstrap input[class^=ag-][type=text]:focus,\n.ag-theme-bootstrap input[class^=ag-][type=number]:focus,\n.ag-theme-bootstrap input[class^=ag-][type=tel]:focus,\n.ag-theme-bootstrap input[class^=ag-][type=date]:focus,\n.ag-theme-bootstrap input[class^=ag-][type=datetime-local]:focus,\n.ag-theme-bootstrap textarea[class^=ag-]:focus {\n outline: none;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-bootstrap input[class^=ag-]:not([type]):invalid,\n.ag-theme-bootstrap input[class^=ag-][type=text]:invalid,\n.ag-theme-bootstrap input[class^=ag-][type=number]:invalid,\n.ag-theme-bootstrap input[class^=ag-][type=tel]:invalid,\n.ag-theme-bootstrap input[class^=ag-][type=date]:invalid,\n.ag-theme-bootstrap input[class^=ag-][type=datetime-local]:invalid,\n.ag-theme-bootstrap textarea[class^=ag-]:invalid {\n border-width: 2px;\n border-style: solid;\n border-color: var(--ag-input-border-color-invalid);\n}\n.ag-theme-bootstrap input[class^=ag-][type=number] {\n -moz-appearance: textfield;\n}\n.ag-theme-bootstrap input[class^=ag-][type=number]::-webkit-outer-spin-button, .ag-theme-bootstrap input[class^=ag-][type=number]::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n}\n.ag-theme-bootstrap input[class^=ag-][type=range] {\n padding: 0;\n}\n.ag-theme-bootstrap .ag-drag-handle {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-list-item, .ag-theme-bootstrap .ag-virtual-list-item {\n height: 20px;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-bootstrap .ag-select-list {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n overflow-y: auto;\n overflow-x: hidden;\n}\n.ag-theme-bootstrap .ag-list-item {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-bootstrap .ag-list-item.ag-active-item {\n background-color: var(--ag-row-hover-color);\n}\n.ag-theme-bootstrap .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n user-select: none;\n}\n.ag-theme-bootstrap .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n.ag-theme-bootstrap .ag-select .ag-picker-field-wrapper {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n min-height: 20px;\n cursor: default;\n}\n.ag-theme-bootstrap .ag-select.ag-disabled .ag-picker-field-wrapper:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-bootstrap .ag-select:not(.ag-cell-editor) {\n height: 20px;\n}\n.ag-theme-bootstrap .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-bootstrap .ag-select .ag-picker-field-icon {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-bootstrap .ag-select.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-bootstrap .ag-rich-select {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n}\n.ag-theme-bootstrap .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 162.5px;\n}\n.ag-theme-bootstrap .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 25px;\n}\n.ag-theme-bootstrap .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 20px;\n}\n.ag-theme-bootstrap .ag-rich-select-virtual-list-item:hover {\n background-color: var(--ag-row-hover-color);\n}\n.ag-theme-bootstrap .ag-rich-select-row {\n padding-left: 12px;\n}\n.ag-theme-bootstrap .ag-rich-select-row-selected {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5);\n}\n.ag-theme-bootstrap .ag-row-drag,\n.ag-theme-bootstrap .ag-selection-checkbox,\n.ag-theme-bootstrap .ag-group-expanded,\n.ag-theme-bootstrap .ag-group-contracted {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-ltr .ag-row-drag, .ag-theme-bootstrap .ag-ltr .ag-selection-checkbox, .ag-theme-bootstrap .ag-ltr .ag-group-expanded, .ag-theme-bootstrap .ag-ltr .ag-group-contracted {\n margin-right: 12px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-drag, .ag-theme-bootstrap .ag-rtl .ag-selection-checkbox, .ag-theme-bootstrap .ag-rtl .ag-group-expanded, .ag-theme-bootstrap .ag-rtl .ag-group-contracted {\n margin-left: 12px;\n}\n\n.ag-theme-bootstrap .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: min(var(--ag-row-height, 23px), 23px);\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-bootstrap .ag-group-expanded,\n.ag-theme-bootstrap .ag-group-contracted {\n cursor: pointer;\n}\n.ag-theme-bootstrap .ag-group-title-bar-icon {\n cursor: pointer;\n -webkit-box-flex: 0;\n flex: none;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-ltr .ag-group-child-count {\n margin-left: 2px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-group-child-count {\n margin-right: 2px;\n}\n\n.ag-theme-bootstrap .ag-group-title-bar {\n background-color: #ececec;\n background-color: var(--ag-subheader-background-color, #ececec);\n padding: 4px;\n}\n.ag-theme-bootstrap .ag-group-toolbar {\n padding: 4px;\n}\n.ag-theme-bootstrap .ag-disabled-group-title-bar, .ag-theme-bootstrap .ag-disabled-group-container {\n opacity: 0.5;\n}\n.ag-theme-bootstrap .group-item {\n margin: 2px 0;\n}\n.ag-theme-bootstrap .ag-label {\n white-space: nowrap;\n}\n.ag-theme-bootstrap .ag-ltr .ag-label {\n margin-right: 4px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-label {\n margin-left: 4px;\n}\n\n.ag-theme-bootstrap .ag-label-align-top .ag-label {\n margin-bottom: 2px;\n}\n.ag-theme-bootstrap .ag-ltr .ag-slider-field, .ag-theme-bootstrap .ag-ltr .ag-angle-select-field {\n margin-right: 8px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-slider-field, .ag-theme-bootstrap .ag-rtl .ag-angle-select-field {\n margin-left: 8px;\n}\n\n.ag-theme-bootstrap .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n}\n.ag-theme-bootstrap .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #000;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 5px;\n}\n.ag-theme-bootstrap .ag-picker-field-button {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-dialog.ag-color-dialog {\n border-radius: 5px;\n}\n.ag-theme-bootstrap .ag-color-picker .ag-picker-field-display {\n height: 12px;\n}\n.ag-theme-bootstrap .ag-color-panel {\n padding: 4px;\n}\n.ag-theme-bootstrap .ag-spectrum-color {\n background-color: red;\n border-radius: 2px;\n}\n.ag-theme-bootstrap .ag-spectrum-tools {\n padding: 10px;\n}\n.ag-theme-bootstrap .ag-spectrum-sat {\n background-image: -webkit-gradient(linear, left top, right top, from(white), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0));\n}\n.ag-theme-bootstrap .ag-spectrum-val {\n background-image: -webkit-gradient(linear, left bottom, left top, from(black), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0));\n}\n.ag-theme-bootstrap .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n -webkit-box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n}\n.ag-theme-bootstrap .ag-spectrum-hue-background {\n border-radius: 2px;\n}\n.ag-theme-bootstrap .ag-spectrum-alpha-background {\n border-radius: 2px;\n}\n.ag-theme-bootstrap .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px;\n}\n.ag-theme-bootstrap .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n -webkit-box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n}\n.ag-theme-bootstrap .ag-recent-color {\n margin: 0 3px;\n}\n.ag-theme-bootstrap .ag-recent-color:first-child {\n margin-left: 0;\n}\n.ag-theme-bootstrap .ag-recent-color:last-child {\n margin-right: 0;\n}\n.ag-theme-bootstrap.ag-dnd-ghost {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px !important;\n line-height: 25px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px);\n}\n.ag-theme-bootstrap .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #000;\n color: var(--ag-foreground-color, #000);\n}\n.ag-theme-bootstrap .ag-popup-child:not(.ag-tooltip-custom) {\n -webkit-box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3);\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3);\n}\n.ag-dragging-range-handle .ag-theme-bootstrap .ag-dialog, .ag-dragging-fill-handle .ag-theme-bootstrap .ag-dialog {\n opacity: 0.7;\n pointer-events: none;\n}\n.ag-theme-bootstrap .ag-dialog {\n border-radius: 0px;\n}\n.ag-theme-bootstrap .ag-panel {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n}\n.ag-theme-bootstrap .ag-panel-title-bar {\n background-color: var(--ag-header-background-color);\n color: #000;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)));\n height: 25px;\n padding: 4px 12px;\n}\n.ag-theme-bootstrap .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px;\n}\n\n.ag-theme-bootstrap .ag-tooltip {\n background-color: var(--ag-header-background-color);\n color: #000;\n color: var(--ag-foreground-color, #000);\n padding: 4px;\n border-radius: 0px;\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n white-space: normal;\n}\n.ag-theme-bootstrap .ag-tooltip.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-bootstrap .ag-tooltip-custom {\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n}\n.ag-theme-bootstrap .ag-tooltip-custom.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px;\n}\n\n.ag-theme-bootstrap .ag-column-select-header-icon {\n cursor: pointer;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-header-icon:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-bootstrap .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 8px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 8px;\n}\n\n.ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-bootstrap .ag-column-select-column-group:not(:last-child),\n.ag-theme-bootstrap .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px;\n}\n.ag-theme-bootstrap .ag-column-select-column-readonly,\n.ag-theme-bootstrap .ag-column-select-column-group-readonly {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n pointer-events: none;\n}\n.ag-theme-bootstrap .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 20px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 20px;\n}\n\n.ag-theme-bootstrap .ag-column-select-virtual-list-viewport {\n padding: 3px 0px;\n}\n.ag-theme-bootstrap .ag-column-select-virtual-list-item {\n padding: 0 6px;\n}\n.ag-theme-bootstrap .ag-rtl {\n text-align: right;\n}\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 36px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 36px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-1 {\n padding-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-1 {\n padding-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-1 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-1 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 60px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 60px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-2 {\n padding-left: 48px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-2 {\n padding-right: 48px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-2 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-2 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 84px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 84px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-3 {\n padding-left: 72px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-3 {\n padding-right: 72px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-3 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-3 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 108px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 108px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-4 {\n padding-left: 96px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-4 {\n padding-right: 96px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-4 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-4 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 132px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 132px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-5 {\n padding-left: 120px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-5 {\n padding-right: 120px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-5 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-5 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 156px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 156px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-6 {\n padding-left: 144px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-6 {\n padding-right: 144px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-6 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-6 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 180px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 180px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-7 {\n padding-left: 168px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-7 {\n padding-right: 168px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-7 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-7 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 204px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 204px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-8 {\n padding-left: 192px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-8 {\n padding-right: 192px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-8 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-8 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 228px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 228px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-9 {\n padding-left: 216px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-9 {\n padding-right: 216px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-9 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-9 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 252px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 252px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-10 {\n padding-left: 240px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-10 {\n padding-right: 240px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-10 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-10 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 276px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 276px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-11 {\n padding-left: 264px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-11 {\n padding-right: 264px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-11 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-11 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 300px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 300px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-12 {\n padding-left: 288px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-12 {\n padding-right: 288px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-12 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-12 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 324px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 324px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-13 {\n padding-left: 312px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-13 {\n padding-right: 312px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-13 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-13 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 348px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 348px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-14 {\n padding-left: 336px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-14 {\n padding-right: 336px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-14 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-14 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 372px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 372px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-15 {\n padding-left: 360px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-15 {\n padding-right: 360px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-15 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-15 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 396px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 396px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-16 {\n padding-left: 384px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-16 {\n padding-right: 384px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-16 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-16 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 420px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 420px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-17 {\n padding-left: 408px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-17 {\n padding-right: 408px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-17 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-17 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 444px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 444px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-18 {\n padding-left: 432px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-18 {\n padding-right: 432px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-18 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-18 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 468px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 468px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-19 {\n padding-left: 456px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-19 {\n padding-right: 456px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-19 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-19 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-left: 492px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-right: 492px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-20 {\n padding-left: 480px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-20 {\n padding-right: 480px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-20 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-20 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-left: 516px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-right: 516px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-21 {\n padding-left: 504px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-21 {\n padding-right: 504px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-21 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-21 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-left: 540px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-right: 540px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-22 {\n padding-left: 528px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-22 {\n padding-right: 528px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-22 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-22 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-left: 564px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-right: 564px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-23 {\n padding-left: 552px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-23 {\n padding-right: 552px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-23 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-23 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-left: 588px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-right: 588px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-24 {\n padding-left: 576px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-24 {\n padding-right: 576px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-24 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-24 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-left: 612px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-right: 612px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-25 {\n padding-left: 600px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-25 {\n padding-right: 600px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-25 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-25 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-left: 636px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-right: 636px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-26 {\n padding-left: 624px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-26 {\n padding-right: 624px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-26 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-26 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-left: 660px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-right: 660px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-27 {\n padding-left: 648px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-27 {\n padding-right: 648px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-27 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-27 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-left: 684px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-right: 684px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-28 {\n padding-left: 672px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-28 {\n padding-right: 672px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-28 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-28 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-left: 708px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-right: 708px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-29 {\n padding-left: 696px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-29 {\n padding-right: 696px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-29 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-29 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-left: 732px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-right: 732px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-30 {\n padding-left: 720px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-30 {\n padding-right: 720px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-30 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-30 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-left: 756px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-right: 756px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-31 {\n padding-left: 744px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-31 {\n padding-right: 744px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-31 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-31 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-left: 780px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-right: 780px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-32 {\n padding-left: 768px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-32 {\n padding-right: 768px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-32 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-32 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-left: 804px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-right: 804px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-33 {\n padding-left: 792px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-33 {\n padding-right: 792px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-33 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-33 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-left: 828px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-right: 828px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-34 {\n padding-left: 816px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-34 {\n padding-right: 816px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-34 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-34 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-left: 852px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-right: 852px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-35 {\n padding-left: 840px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-35 {\n padding-right: 840px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-35 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-35 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-left: 876px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-right: 876px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-36 {\n padding-left: 864px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-36 {\n padding-right: 864px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-36 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-36 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-left: 900px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-right: 900px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-37 {\n padding-left: 888px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-37 {\n padding-right: 888px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-37 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-37 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-left: 924px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-right: 924px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-38 {\n padding-left: 912px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-38 {\n padding-right: 912px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-38 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-38 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-left: 948px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-right: 948px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-39 {\n padding-left: 936px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-39 {\n padding-right: 936px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-39 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-39 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-left: 972px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-right: 972px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-40 {\n padding-left: 960px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-40 {\n padding-right: 960px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-40 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-40 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-left: 996px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-right: 996px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-41 {\n padding-left: 984px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-41 {\n padding-right: 984px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-41 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-41 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-left: 1020px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-right: 1020px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-42 {\n padding-left: 1008px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-42 {\n padding-right: 1008px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-42 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-42 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-left: 1044px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-right: 1044px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-43 {\n padding-left: 1032px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-43 {\n padding-right: 1032px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-43 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-43 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-left: 1068px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-right: 1068px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-44 {\n padding-left: 1056px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-44 {\n padding-right: 1056px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-44 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-44 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-left: 1092px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-right: 1092px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-45 {\n padding-left: 1080px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-45 {\n padding-right: 1080px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-45 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-45 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-left: 1116px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-right: 1116px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-46 {\n padding-left: 1104px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-46 {\n padding-right: 1104px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-46 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-46 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-left: 1140px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-right: 1140px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-47 {\n padding-left: 1128px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-47 {\n padding-right: 1128px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-47 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-47 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-left: 1164px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-right: 1164px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-48 {\n padding-left: 1152px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-48 {\n padding-right: 1152px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-48 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-48 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-left: 1188px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-right: 1188px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-49 {\n padding-left: 1176px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-49 {\n padding-right: 1176px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-49 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-49 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-left: 1212px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-right: 1212px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-50 {\n padding-left: 1200px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-50 {\n padding-right: 1200px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-50 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-50 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-left: 1236px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-right: 1236px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-51 {\n padding-left: 1224px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-51 {\n padding-right: 1224px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-51 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-51 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-left: 1260px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-right: 1260px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-52 {\n padding-left: 1248px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-52 {\n padding-right: 1248px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-52 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-52 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-left: 1284px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-right: 1284px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-53 {\n padding-left: 1272px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-53 {\n padding-right: 1272px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-53 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-53 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-left: 1308px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-right: 1308px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-54 {\n padding-left: 1296px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-54 {\n padding-right: 1296px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-54 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-54 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-left: 1332px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-right: 1332px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-55 {\n padding-left: 1320px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-55 {\n padding-right: 1320px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-55 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-55 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-left: 1356px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-right: 1356px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-56 {\n padding-left: 1344px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-56 {\n padding-right: 1344px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-56 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-56 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-left: 1380px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-right: 1380px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-57 {\n padding-left: 1368px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-57 {\n padding-right: 1368px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-57 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-57 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-left: 1404px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-right: 1404px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-58 {\n padding-left: 1392px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-58 {\n padding-right: 1392px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-58 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-58 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-left: 1428px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-right: 1428px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-59 {\n padding-left: 1416px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-59 {\n padding-right: 1416px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-59 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-59 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-left: 1452px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-right: 1452px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-60 {\n padding-left: 1440px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-60 {\n padding-right: 1440px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-60 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-60 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-left: 1476px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-right: 1476px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-61 {\n padding-left: 1464px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-61 {\n padding-right: 1464px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-61 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-61 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-left: 1500px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-right: 1500px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-62 {\n padding-left: 1488px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-62 {\n padding-right: 1488px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-62 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-62 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-left: 1524px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-right: 1524px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-63 {\n padding-left: 1512px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-63 {\n padding-right: 1512px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-63 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-63 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-left: 1548px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-right: 1548px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-64 {\n padding-left: 1536px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-64 {\n padding-right: 1536px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-64 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-64 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-left: 1572px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-right: 1572px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-65 {\n padding-left: 1560px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-65 {\n padding-right: 1560px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-65 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-65 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-left: 1596px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-right: 1596px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-66 {\n padding-left: 1584px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-66 {\n padding-right: 1584px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-66 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-66 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-left: 1620px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-right: 1620px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-67 {\n padding-left: 1608px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-67 {\n padding-right: 1608px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-67 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-67 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-left: 1644px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-right: 1644px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-68 {\n padding-left: 1632px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-68 {\n padding-right: 1632px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-68 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-68 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-left: 1668px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-right: 1668px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-69 {\n padding-left: 1656px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-69 {\n padding-right: 1656px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-69 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-69 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-left: 1692px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-right: 1692px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-70 {\n padding-left: 1680px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-70 {\n padding-right: 1680px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-70 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-70 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-left: 1716px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-right: 1716px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-71 {\n padding-left: 1704px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-71 {\n padding-right: 1704px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-71 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-71 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-left: 1740px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-right: 1740px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-72 {\n padding-left: 1728px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-72 {\n padding-right: 1728px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-72 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-72 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-left: 1764px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-right: 1764px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-73 {\n padding-left: 1752px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-73 {\n padding-right: 1752px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-73 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-73 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-left: 1788px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-right: 1788px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-74 {\n padding-left: 1776px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-74 {\n padding-right: 1776px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-74 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-74 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-left: 1812px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-right: 1812px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-75 {\n padding-left: 1800px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-75 {\n padding-right: 1800px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-75 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-75 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-left: 1836px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-right: 1836px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-76 {\n padding-left: 1824px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-76 {\n padding-right: 1824px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-76 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-76 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-left: 1860px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-right: 1860px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-77 {\n padding-left: 1848px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-77 {\n padding-right: 1848px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-77 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-77 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-left: 1884px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-right: 1884px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-78 {\n padding-left: 1872px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-78 {\n padding-right: 1872px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-78 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-78 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-left: 1908px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-right: 1908px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-79 {\n padding-left: 1896px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-79 {\n padding-right: 1896px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-79 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-79 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-left: 1932px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-right: 1932px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-80 {\n padding-left: 1920px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-80 {\n padding-right: 1920px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-80 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-80 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-left: 1956px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-right: 1956px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-81 {\n padding-left: 1944px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-81 {\n padding-right: 1944px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-81 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-81 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-left: 1980px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-right: 1980px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-82 {\n padding-left: 1968px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-82 {\n padding-right: 1968px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-82 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-82 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-left: 2004px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-right: 2004px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-83 {\n padding-left: 1992px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-83 {\n padding-right: 1992px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-83 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-83 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-left: 2028px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-right: 2028px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-84 {\n padding-left: 2016px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-84 {\n padding-right: 2016px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-84 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-84 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-left: 2052px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-right: 2052px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-85 {\n padding-left: 2040px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-85 {\n padding-right: 2040px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-85 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-85 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-left: 2076px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-right: 2076px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-86 {\n padding-left: 2064px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-86 {\n padding-right: 2064px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-86 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-86 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-left: 2100px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-right: 2100px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-87 {\n padding-left: 2088px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-87 {\n padding-right: 2088px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-87 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-87 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-left: 2124px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-right: 2124px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-88 {\n padding-left: 2112px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-88 {\n padding-right: 2112px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-88 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-88 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-left: 2148px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-right: 2148px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-89 {\n padding-left: 2136px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-89 {\n padding-right: 2136px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-89 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-89 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-left: 2172px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-right: 2172px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-90 {\n padding-left: 2160px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-90 {\n padding-right: 2160px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-90 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-90 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-left: 2196px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-right: 2196px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-91 {\n padding-left: 2184px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-91 {\n padding-right: 2184px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-91 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-91 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-left: 2220px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-right: 2220px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-92 {\n padding-left: 2208px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-92 {\n padding-right: 2208px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-92 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-92 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-left: 2244px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-right: 2244px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-93 {\n padding-left: 2232px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-93 {\n padding-right: 2232px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-93 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-93 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-left: 2268px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-right: 2268px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-94 {\n padding-left: 2256px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-94 {\n padding-right: 2256px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-94 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-94 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-left: 2292px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-right: 2292px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-95 {\n padding-left: 2280px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-95 {\n padding-right: 2280px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-95 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-95 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-left: 2316px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-right: 2316px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-96 {\n padding-left: 2304px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-96 {\n padding-right: 2304px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-96 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-96 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-left: 2340px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-right: 2340px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-97 {\n padding-left: 2328px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-97 {\n padding-right: 2328px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-97 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-97 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-left: 2364px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-right: 2364px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-98 {\n padding-left: 2352px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-98 {\n padding-right: 2352px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-98 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-98 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-left: 2388px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-right: 2388px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-99 {\n padding-left: 2376px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-99 {\n padding-right: 2376px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-level-99 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-level-99 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-row-group-leaf-indent {\n margin-left: 24px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-row-group-leaf-indent {\n margin-right: 24px;\n}\n\n.ag-theme-bootstrap .ag-value-change-delta {\n padding-right: 2px;\n}\n.ag-theme-bootstrap .ag-value-change-delta-up {\n color: darkgreen;\n color: var(--ag-value-change-delta-up-color, darkgreen);\n}\n.ag-theme-bootstrap .ag-value-change-delta-down {\n color: darkred;\n color: var(--ag-value-change-delta-down-color, darkred);\n}\n.ag-theme-bootstrap .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n -webkit-transition: background-color 1s;\n transition: background-color 1s;\n}\n.ag-theme-bootstrap .ag-value-change-value-highlight {\n background-color: #cec;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec);\n -webkit-transition: background-color 0.1s;\n transition: background-color 0.1s;\n}\n.ag-theme-bootstrap .ag-cell-data-changed {\n background-color: #cec !important;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec) !important;\n}\n.ag-theme-bootstrap .ag-cell-data-changed-animation {\n background-color: transparent;\n}\n.ag-theme-bootstrap .ag-cell-highlight {\n background-color: rgba(136, 255, 136, 0.4) !important;\n background-color: var(--ag-range-selection-highlight-color, rgba(136, 255, 136, 0.4)) !important;\n}\n.ag-theme-bootstrap .ag-row {\n height: 25px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n color: #000;\n color: var(--ag-data-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-row-highlight-above::after, .ag-theme-bootstrap .ag-row-highlight-below::after {\n content: \"\";\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #000;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n left: 1px;\n}\n.ag-theme-bootstrap .ag-row-highlight-above::after {\n top: -1px;\n}\n.ag-theme-bootstrap .ag-row-highlight-above.ag-row-first::after {\n top: 0;\n}\n.ag-theme-bootstrap .ag-row-highlight-below::after {\n bottom: 0px;\n}\n.ag-theme-bootstrap .ag-row-odd {\n background-color: #f6f6f6;\n background-color: var(--ag-odd-row-background-color, #f6f6f6);\n}\n.ag-theme-bootstrap .ag-ltr .ag-right-aligned-cell {\n text-align: right;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-right-aligned-cell {\n text-align: left;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-right-aligned-cell .ag-cell-value, .ag-theme-bootstrap .ag-ltr .ag-right-aligned-cell .ag-group-value {\n margin-left: auto;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-right-aligned-cell .ag-cell-value, .ag-theme-bootstrap .ag-rtl .ag-right-aligned-cell .ag-group-value {\n margin-right: auto;\n}\n\n.ag-theme-bootstrap .ag-cell, .ag-theme-bootstrap .ag-full-width-row .ag-cell-wrapper.ag-row-group {\n border: 1px solid transparent;\n line-height: min(var(--ag-row-height, 23px), 23px);\n padding-left: 11px;\n padding-right: 11px;\n -webkit-font-smoothing: subpixel-antialiased;\n}\n.ag-theme-bootstrap .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px;\n}\n.ag-theme-bootstrap .ag-row-dragging {\n cursor: move;\n opacity: 0.5;\n}\n.ag-theme-bootstrap .ag-cell-inline-editing {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 25px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n}\n.ag-theme-bootstrap .ag-popup-editor {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n padding: 0;\n}\n.ag-theme-bootstrap .ag-large-text-input {\n height: auto;\n padding: 12px;\n}\n.ag-theme-bootstrap .ag-details-row {\n padding: 20px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n}\n.ag-theme-bootstrap .ag-layout-auto-height .ag-center-cols-clipper, .ag-theme-bootstrap .ag-layout-auto-height .ag-center-cols-container, .ag-theme-bootstrap .ag-layout-print .ag-center-cols-clipper, .ag-theme-bootstrap .ag-layout-print .ag-center-cols-container {\n min-height: 50px;\n}\n.ag-theme-bootstrap .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66));\n}\n.ag-theme-bootstrap .ag-overlay-loading-center {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n}\n.ag-theme-bootstrap .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px;\n}\n.ag-theme-bootstrap .ag-loading {\n padding-left: 12px;\n display: -webkit-box;\n display: flex;\n height: 100%;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-bootstrap .ag-loading-icon {\n padding-right: 12px;\n}\n.ag-theme-bootstrap .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear;\n}\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n.ag-theme-bootstrap .ag-ltr .ag-cell {\n border-right: solid transparent;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-cell {\n border-left: solid transparent;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-cell {\n border-right-width: 1px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-cell {\n border-left-width: 1px;\n}\n\n.ag-theme-bootstrap .ag-row-selected {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5);\n}\n.ag-theme-bootstrap .ag-cell-range-selected:not(.ag-cell-focus),\n.ag-theme-bootstrap .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing) {\n background-color: rgba(0, 0, 0, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(0, 0, 0, 0.2));\n}\n.ag-theme-bootstrap .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart,\n.ag-theme-bootstrap .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1) !important;\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)) !important;\n}\n.ag-theme-bootstrap .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category,\n.ag-theme-bootstrap .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1) !important;\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)) !important;\n}\n.ag-theme-bootstrap .ag-cell-range-selected-1:not(.ag-cell-focus),\n.ag-theme-bootstrap .ag-root:not(.ag-context-menu-open) .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-1:not(.ag-cell-inline-editing) {\n background-color: rgba(0, 0, 0, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(0, 0, 0, 0.2)));\n}\n.ag-theme-bootstrap .ag-cell-range-selected-2:not(.ag-cell-focus),\n.ag-theme-bootstrap .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-2 {\n background-color: rgba(0, 0, 0, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(0, 0, 0, 0.36));\n}\n.ag-theme-bootstrap .ag-cell-range-selected-3:not(.ag-cell-focus),\n.ag-theme-bootstrap .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-3 {\n background-color: rgba(0, 0, 0, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(0, 0, 0, 0.488));\n}\n.ag-theme-bootstrap .ag-cell-range-selected-4:not(.ag-cell-focus),\n.ag-theme-bootstrap .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-4 {\n background-color: rgba(0, 0, 0, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(0, 0, 0, 0.5904));\n}\n.ag-theme-bootstrap .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #000;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #000;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-bootstrap .ag-ltr .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-bootstrap .ag-ltr .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-bootstrap .ag-ltr .ag-cell-range-single-cell,\n.ag-theme-bootstrap .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-bootstrap .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-bootstrap .ag-rtl .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-bootstrap .ag-rtl .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-bootstrap .ag-rtl .ag-cell-range-single-cell,\n.ag-theme-bootstrap .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n outline: initial;\n}\n.ag-theme-bootstrap .ag-cell.ag-selection-fill-top,\n.ag-theme-bootstrap .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #000;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-bootstrap .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-bootstrap .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n\n.ag-theme-bootstrap .ag-cell.ag-selection-fill-bottom,\n.ag-theme-bootstrap .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #000;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-bootstrap .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-bootstrap .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n\n.ag-theme-bootstrap .ag-range-handle, .ag-theme-bootstrap .ag-fill-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #000;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-ltr .ag-range-handle, .ag-theme-bootstrap .ag-ltr .ag-fill-handle {\n right: -1px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-range-handle, .ag-theme-bootstrap .ag-rtl .ag-fill-handle {\n left: -1px;\n}\n\n.ag-theme-bootstrap .ag-fill-handle {\n cursor: cell;\n}\n.ag-theme-bootstrap .ag-range-handle {\n cursor: nwse-resize;\n}\n.ag-theme-bootstrap .ag-cell-inline-editing {\n border-color: var(--ag-input-focus-border-color) !important;\n}\n.ag-theme-bootstrap .ag-menu {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n}\n.ag-theme-bootstrap .ag-menu-list {\n cursor: default;\n padding: 4px 0;\n}\n.ag-theme-bootstrap .ag-menu-separator {\n height: 9px;\n}\n.ag-theme-bootstrap .ag-menu-separator-part::after {\n content: \"\";\n display: block;\n}\n.ag-theme-bootstrap .ag-menu-option-active, .ag-theme-bootstrap .ag-compact-menu-option-active {\n background-color: var(--ag-row-hover-color);\n}\n.ag-theme-bootstrap .ag-menu-option-part, .ag-theme-bootstrap .ag-compact-menu-option-part {\n line-height: 12px;\n padding: 6px 0;\n}\n.ag-theme-bootstrap .ag-menu-option-disabled, .ag-theme-bootstrap .ag-compact-menu-option-disabled {\n opacity: 0.5;\n}\n.ag-theme-bootstrap .ag-menu-option-icon, .ag-theme-bootstrap .ag-compact-menu-option-icon {\n width: 12px;\n}\n.ag-theme-bootstrap .ag-ltr .ag-menu-option-icon, .ag-theme-bootstrap .ag-ltr .ag-compact-menu-option-icon {\n padding-left: 8px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-menu-option-icon, .ag-theme-bootstrap .ag-rtl .ag-compact-menu-option-icon {\n padding-right: 8px;\n}\n\n.ag-theme-bootstrap .ag-menu-option-text, .ag-theme-bootstrap .ag-compact-menu-option-text {\n padding-left: 8px;\n padding-right: 8px;\n}\n.ag-theme-bootstrap .ag-ltr .ag-menu-option-shortcut, .ag-theme-bootstrap .ag-ltr .ag-compact-menu-option-shortcut {\n padding-right: 4px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-menu-option-shortcut, .ag-theme-bootstrap .ag-rtl .ag-compact-menu-option-shortcut {\n padding-left: 4px;\n}\n\n.ag-theme-bootstrap .ag-menu-option-popup-pointer, .ag-theme-bootstrap .ag-compact-menu-option-popup-pointer {\n padding-right: 4px;\n}\n.ag-theme-bootstrap .ag-tabs {\n min-width: 220px;\n}\n.ag-theme-bootstrap .ag-tabs-header {\n width: 100%;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-bootstrap .ag-tab {\n border-bottom: 0 solid transparent;\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 0;\n flex: none;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-pack: center;\n justify-content: center;\n cursor: pointer;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-tab:focus {\n outline: none;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-tab:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-bootstrap .ag-tab-selected {\n border-bottom-color: #000;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)));\n}\n.ag-theme-bootstrap .ag-menu-header {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-menu:not(.ag-tabs) .ag-filter-select {\n min-width: 167px;\n}\n.ag-theme-bootstrap .ag-tabs .ag-filter-select {\n min-width: 206px;\n}\n.ag-theme-bootstrap .ag-filter-select .ag-picker-field-wrapper {\n width: 0;\n}\n.ag-theme-bootstrap .ag-filter-condition-operator {\n height: 17px;\n}\n.ag-theme-bootstrap .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px;\n}\n\n.ag-theme-bootstrap .ag-set-filter-select-all {\n padding-top: 6px;\n}\n.ag-theme-bootstrap .ag-set-filter-list, .ag-theme-bootstrap .ag-filter-no-matches {\n height: 120px;\n}\n.ag-theme-bootstrap .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px;\n}\n.ag-theme-bootstrap .ag-filter-to {\n margin-top: 4px;\n}\n.ag-theme-bootstrap .ag-mini-filter {\n margin: 6px 6px;\n}\n.ag-theme-bootstrap .ag-set-filter-item {\n margin: 0px 6px;\n}\n.ag-theme-bootstrap .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px;\n}\n\n.ag-theme-bootstrap .ag-filter-apply-panel {\n padding: 6px 6px;\n}\n.ag-theme-bootstrap .ag-filter-apply-panel-button {\n line-height: 1.5;\n}\n.ag-theme-bootstrap .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px;\n}\n\n.ag-theme-bootstrap .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px;\n}\n.ag-theme-bootstrap .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px;\n}\n.ag-theme-bootstrap .ag-filter-no-matches {\n padding: 6px 6px;\n}\n.ag-theme-bootstrap .ag-multi-filter-menu-item {\n margin: 4px 0;\n}\n.ag-theme-bootstrap .ag-multi-filter-group-title-bar {\n padding: 8px 4px;\n background-color: transparent;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus {\n outline: none;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-bootstrap .ag-side-bar {\n position: relative;\n}\n.ag-theme-bootstrap .ag-tool-panel-wrapper {\n width: 200px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n}\n.ag-theme-bootstrap .ag-side-buttons {\n padding-top: 16px;\n width: 16px;\n position: relative;\n color: #000;\n color: var(--ag-foreground-color, #000);\n overflow: hidden;\n}\n.ag-theme-bootstrap button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: 100%;\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n}\n.ag-theme-bootstrap button.ag-side-button-button:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-side-button-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-bootstrap .ag-side-button-icon-wrapper {\n margin-bottom: 3px;\n}\n.ag-theme-bootstrap .ag-ltr .ag-side-bar-left .ag-side-button-button,\n.ag-theme-bootstrap .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent;\n}\n.ag-theme-bootstrap .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-bootstrap .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #000;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)));\n}\n.ag-theme-bootstrap .ag-rtl .ag-side-bar-left .ag-side-button-button,\n.ag-theme-bootstrap .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent;\n}\n.ag-theme-bootstrap .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-bootstrap .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #000;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)));\n}\n.ag-theme-bootstrap .ag-filter-toolpanel-header {\n height: 24px;\n}\n.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-header, .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-header, .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px;\n}\n\n.ag-theme-bootstrap .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-filter-toolpanel-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-bootstrap .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f114\";\n position: absolute;\n}\n.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-left: 4px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-right: 4px;\n}\n\n.ag-theme-bootstrap .ag-filter-toolpanel-group-level-0-header {\n height: 32px;\n}\n.ag-theme-bootstrap .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px;\n}\n.ag-theme-bootstrap .ag-filter-toolpanel-search {\n height: 25px;\n}\n.ag-theme-bootstrap .ag-filter-toolpanel-search-input {\n -webkit-box-flex: 1;\n flex-grow: 1;\n height: 16px;\n}\n.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px;\n}\n\n.ag-theme-bootstrap .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px;\n}\n\n.ag-theme-bootstrap .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px;\n}\n\n.ag-theme-bootstrap .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px;\n}\n\n.ag-theme-bootstrap .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px;\n}\n\n.ag-theme-bootstrap .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px;\n}\n\n.ag-theme-bootstrap .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px;\n}\n\n.ag-theme-bootstrap .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px;\n}\n\n.ag-theme-bootstrap .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px;\n}\n\n.ag-theme-bootstrap .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px;\n}\n\n.ag-theme-bootstrap .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px;\n}\n\n.ag-theme-bootstrap .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px;\n}\n.ag-theme-bootstrap .ag-filter-toolpanel-instance-filter {\n margin-top: 4px;\n}\n.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px;\n}\n\n.ag-theme-bootstrap .ag-pivot-mode-panel {\n min-height: 25px;\n height: 25px;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-bootstrap .ag-pivot-mode-select {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-bootstrap .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px;\n}\n\n.ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-bootstrap .ag-column-select-header {\n height: 25px;\n -webkit-box-align: center;\n align-items: center;\n padding: 0 6px;\n}\n.ag-theme-bootstrap .ag-column-group-icons,\n.ag-theme-bootstrap .ag-column-select-header-icon {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-column-select-list .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #000;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-column-select-list .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-bootstrap .ag-column-select-list .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-bootstrap .ag-header {\n background-color: var(--ag-header-background-color);\n}\n.ag-theme-bootstrap .ag-header-row {\n color: #000;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)));\n height: 25px;\n}\n.ag-theme-bootstrap .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px;\n}\n\n.ag-theme-bootstrap .ag-header-cell,\n.ag-theme-bootstrap .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px;\n}\n.ag-theme-bootstrap .ag-header-cell.ag-header-cell-moving,\n.ag-theme-bootstrap .ag-header-group-cell.ag-header-cell-moving {\n background-color: #bebebe;\n background-color: var(--ag-header-cell-moving-background-color, #bebebe);\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-header-cell:focus {\n outline: none;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-header-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-header-group-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-bootstrap .ag-header-icon {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-header-expand-icon {\n cursor: pointer;\n}\n.ag-theme-bootstrap .ag-ltr .ag-header-expand-icon {\n padding-left: 4px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-header-expand-icon {\n padding-right: 4px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-header-select-all {\n margin-right: 12px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-header-select-all {\n margin-left: 12px;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-floating-filter-button {\n margin-left: 12px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-floating-filter-button {\n margin-right: 12px;\n}\n\n.ag-theme-bootstrap .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 12px;\n padding: 0;\n width: 12px;\n}\n.ag-theme-bootstrap .ag-filter-loading {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1;\n}\n.ag-theme-bootstrap .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px;\n}\n.ag-theme-bootstrap .ag-paging-panel > * {\n margin: 0 12px;\n}\n.ag-theme-bootstrap .ag-paging-button {\n cursor: pointer;\n}\n.ag-theme-bootstrap .ag-paging-button.ag-disabled {\n cursor: default;\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-paging-button:focus {\n outline: none;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-paging-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-bootstrap .ag-paging-button, .ag-theme-bootstrap .ag-paging-description {\n margin: 0 4px;\n}\n.ag-theme-bootstrap .ag-status-bar {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5;\n}\n.ag-theme-bootstrap .ag-status-name-value-value {\n color: #000;\n color: var(--ag-foreground-color, #000);\n}\n.ag-theme-bootstrap .ag-status-bar-center {\n text-align: center;\n}\n.ag-theme-bootstrap .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px;\n}\n.ag-theme-bootstrap .ag-column-drop-cell {\n background: #ecf0f1;\n background: var(--ag-chip-background-color, #ecf0f1);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px;\n border: 1px solid transparent;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-column-drop-cell:focus {\n outline: none;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-column-drop-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 2px;\n left: 2px;\n display: block;\n width: calc(100% - 4px);\n height: calc(100% - 4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-bootstrap .ag-column-drop-cell-text {\n margin: 0 4px;\n}\n.ag-theme-bootstrap .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-column-drop-cell-drag-handle {\n margin-left: 8px;\n}\n.ag-theme-bootstrap .ag-column-drop-cell-ghost {\n opacity: 0.5;\n}\n.ag-theme-bootstrap .ag-column-drop-horizontal {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px;\n}\n.ag-theme-bootstrap .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px;\n}\n\n.ag-theme-bootstrap .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-column-drop-horizontal-empty-message {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n}\n.ag-theme-bootstrap .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px;\n}\n\n.ag-theme-bootstrap .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px;\n}\n.ag-theme-bootstrap .ag-column-drop-vertical-cell {\n margin-top: 4px;\n}\n.ag-theme-bootstrap .ag-column-drop-vertical {\n min-height: 50px;\n}\n.ag-theme-bootstrap .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px;\n}\n.ag-theme-bootstrap .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n margin-top: 4px;\n}\n.ag-theme-bootstrap .ag-select-agg-func-popup {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n height: 70px;\n padding: 0;\n}\n.ag-theme-bootstrap .ag-select-agg-func-virtual-list-item {\n cursor: default;\n padding-left: 8px;\n}\n.ag-theme-bootstrap .ag-select-agg-func-virtual-list-item:hover {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5);\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-bootstrap .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-bootstrap .ag-chart-menu {\n border-radius: 0px;\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n}\n.ag-theme-bootstrap .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 0px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-chart-menu-icon:hover {\n opacity: 1;\n}\n.ag-theme-bootstrap .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n border-radius: 5px;\n margin: 5px;\n}\n.ag-theme-bootstrap .ag-chart-mini-thumbnail:nth-last-child(3), .ag-theme-bootstrap .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto;\n}\n.ag-theme-bootstrap .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0;\n}\n\n.ag-theme-bootstrap .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0;\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0;\n}\n\n.ag-theme-bootstrap .ag-chart-mini-thumbnail.ag-selected {\n border-color: #000;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)));\n}\n.ag-theme-bootstrap .ag-chart-settings-card-item {\n background: #000;\n background: var(--ag-foreground-color, #000);\n width: 8px;\n height: 8px;\n border-radius: 4px;\n}\n.ag-theme-bootstrap .ag-chart-settings-card-item.ag-selected {\n background-color: #000;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)));\n}\n.ag-theme-bootstrap .ag-chart-data-column-drag-handle {\n margin-left: 4px;\n}\n.ag-theme-bootstrap .ag-charts-settings-group-container {\n padding: 4px;\n}\n.ag-theme-bootstrap .ag-charts-data-group-container {\n padding: 3px 6px;\n}\n.ag-theme-bootstrap .ag-charts-data-group-container .ag-charts-data-group-item:not(.ag-charts-format-sub-level-group) {\n height: 20px;\n}\n.ag-theme-bootstrap .ag-charts-data-group-container .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #000;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap .ag-charts-data-group-container .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-bootstrap .ag-charts-data-group-container .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-bootstrap .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px;\n}\n.ag-theme-bootstrap .ag-charts-format-top-level-group-item {\n margin: 4px 0;\n}\n.ag-theme-bootstrap .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px;\n}\n.ag-theme-bootstrap .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px;\n}\n.ag-theme-bootstrap .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px;\n}\n.ag-theme-bootstrap .ag-chart-data-section,\n.ag-theme-bootstrap .ag-chart-format-section {\n display: -webkit-box;\n display: flex;\n margin: 0;\n}\n.ag-theme-bootstrap .ag-chart-menu-panel {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n}\n.ag-theme-bootstrap .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey);\n}\n\n.ag-theme-bootstrap .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey);\n}\n\n.ag-theme-bootstrap .ag-date-time-list-page-title {\n -webkit-box-flex: 1;\n flex-grow: 1;\n text-align: center;\n}\n.ag-theme-bootstrap .ag-date-time-list-page-column-label {\n text-align: center;\n}\n.ag-theme-bootstrap .ag-date-time-list-page-entry {\n text-align: center;\n}\n.ag-theme-bootstrap .ag-checkbox-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-bootstrap .ag-checkbox-input-wrapper input, .ag-theme-bootstrap .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-bootstrap .ag-checkbox-input-wrapper:focus-within, .ag-theme-bootstrap .ag-checkbox-input-wrapper:active {\n outline: none;\n}\n.ag-theme-bootstrap .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-bootstrap .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #000;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-bootstrap .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #000;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-bootstrap .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #000;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-bootstrap .ag-toggle-button-input-wrapper {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n width: 24px;\n height: 12px;\n background-color: #000;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)));\n border-radius: 6px;\n position: relative;\n -webkit-box-flex: 0;\n flex: none;\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)));\n}\n.ag-theme-bootstrap .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%;\n}\n.ag-theme-bootstrap .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n}\n.ag-theme-bootstrap .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-bootstrap .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #000;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)));\n border-color: #000;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)));\n}\n.ag-theme-bootstrap .ag-toggle-button-input-wrapper::before {\n content: \" \";\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n background-color: #FFF;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #FFF));\n border-radius: 6px;\n -webkit-transition: left 100ms;\n transition: left 100ms;\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000))));\n}\n.ag-theme-bootstrap .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 12px );\n border-color: #000;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)));\n}\n.ag-theme-bootstrap .ag-radio-button-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n border-radius: 12px;\n}\n.ag-theme-bootstrap .ag-radio-button-input-wrapper input, .ag-theme-bootstrap .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-bootstrap .ag-radio-button-input-wrapper:focus-within, .ag-theme-bootstrap .ag-radio-button-input-wrapper:active {\n outline: none;\n}\n.ag-theme-bootstrap .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-bootstrap .ag-radio-button-input-wrapper::after {\n content: \"\\f126\";\n color: #000;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-bootstrap .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f127\";\n color: #000;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-bootstrap input[class^=ag-][type=range] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible;\n}\n.ag-theme-bootstrap input[class^=ag-][type=range]::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px;\n}\n.ag-theme-bootstrap input[class^=ag-][type=range]::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px;\n}\n.ag-theme-bootstrap input[class^=ag-][type=range]::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px;\n color: transparent;\n width: calc(100% - 2px);\n}\n.ag-theme-bootstrap input[class^=ag-][type=range]::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px;\n -webkit-transform: translateY(-4.5px);\n transform: translateY(-4.5px);\n}\n.ag-theme-bootstrap input[class^=ag-][type=range]::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px;\n}\n.ag-theme-bootstrap input[class^=ag-][type=range]::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px;\n}\n.ag-theme-bootstrap input[class^=ag-][type=range]:focus {\n outline: none;\n}\n.ag-theme-bootstrap input[class^=ag-][type=range]:focus::-webkit-slider-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap input[class^=ag-][type=range]:focus::-ms-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap input[class^=ag-][type=range]:focus::-moz-ag-range-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-bootstrap input[class^=ag-][type=range]:active::-webkit-slider-runnable-track {\n background-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-bootstrap input[class^=ag-][type=range]:active::-moz-ag-range-track {\n background-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-bootstrap input[class^=ag-][type=range]:active::-ms-track {\n background-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-bootstrap input[class^=ag-][type=range]:disabled {\n opacity: 0.5;\n}\n.ag-theme-bootstrap .ag-icon {\n color: #333;\n margin: 1px 1px 2px 1px;\n}\n.ag-theme-bootstrap .ag-icon-tree-closed::before {\n content: \"\\f10b\";\n}\n.ag-theme-bootstrap .ag-icon-tree-open::before {\n content: \"\\f111\";\n}\n.ag-theme-bootstrap .ag-header, .ag-theme-bootstrap .ag-column-drop-cell {\n background-image: none;\n}\n.ag-theme-bootstrap .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px;\n}\n.ag-theme-bootstrap .ag-tabs-body {\n margin: 2px 0;\n}\n.ag-theme-bootstrap .ag-tab-selected {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-bottom-color: transparent;\n}\n.ag-theme-bootstrap .ag-tabs-header {\n background-color: var(--ag-header-background-color);\n border-bottom: 1px solid;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-bootstrap .ag-filter .ag-filter-apply-panel {\n -webkit-box-pack: start;\n justify-content: flex-start;\n}\n.ag-theme-bootstrap .ag-menu-option-active {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5);\n}\n.ag-theme-bootstrap .ag-column-drop-cell {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0;\n}\n.ag-theme-bootstrap .ag-column-drop-cell-button .ag-icon {\n border: 1px solid transparent;\n}\n.ag-theme-bootstrap .ag-column-drop-cell-button:hover .ag-icon {\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-bootstrap .ag-panel-title-bar-button-icon {\n font-size: 20px;\n line-height: 20px;\n}\n.ag-theme-bootstrap .ag-menu-option-part {\n padding-top: 4px;\n padding-bottom: 4px;\n}\n.ag-theme-bootstrap .ag-column-drop-vertical-title-bar {\n margin-top: 4px;\n margin-left: 4px;\n}\n.ag-theme-bootstrap .ag-column-drop-vertical-title {\n margin-left: 4px;\n}\n.ag-theme-bootstrap .ag-column-drop-vertical-empty-message {\n margin-left: 24px;\n}\n", ""]); // Exports module.exports = exports; /***/ }), -/* 240 */ +/* 293 */ /***/ (function(module, exports, __webpack_require__) { -var api = __webpack_require__(225); - var content = __webpack_require__(241); +var api = __webpack_require__(278); + var content = __webpack_require__(294); content = content.__esModule ? content.default : content; @@ -48724,24 +57669,24 @@ var update = api(content, options); module.exports = content.locals || {}; /***/ }), -/* 241 */ +/* 294 */ /***/ (function(module, exports, __webpack_require__) { // Imports -var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227); +var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(280); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, ".ag-theme-dark {\n -webkit-font-smoothing: antialiased;\n color: #ccc;\n color: var(--ag-foreground-color, #ccc);\n font-family: \"Helvetica Neue\", sans-serif;\n font-size: 14px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridClassic\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABOsAAsAAAAAJiwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlIAAAReYchjok9TLzIAAANcAAAAQQAAAFZWVlJ+Y21hcAAAA6AAAAHtAAAFgHClDfdnbHlmAAAFkAAACi0AABQQq+8lqmhlYWQAAA/AAAAANAAAADZ2z8SBaGhlYQAAD/QAAAAeAAAAJAfTBChobXR4AAAQFAAAABoAAAEou4L/4mxvY2EAABAwAAAAbwAAAJb7HvWgbWF4cAAAEKAAAAAfAAAAIAFgAHhuYW1lAAAQwAAAATMAAAJS8kTiWnBvc3QAABH0AAABtgAAApcplp2DeJx9k0lyE0EQRX+rZSMPyGDMZMRkRpsh3O5BjSTLltzyQHjBggULNmYBAeFg5ROw5gAEB+AUnIBgyYoDcACCA/Ay1UbGC6tC1VWZP3/+yspSIGlSy+qqUmzuPld9f+/gveZV1fBn/qPrYP/tmz3VDnf4qv6tKQj/qK4FvdCBvgUKXgefK+NhJeyGu+GH8FP4QyGoG3oMekorjFgJc6RUmZrKVdE4tpj1E7VAh8xtt87qgsbcU2ig8+SMiRk445Ke6o7OwNN3np7WQKUM4+wxbzHuauYERK578GeoWcVqrA10ntWENtHYQ0eH6BbeGXzrZI6I6eProy10VNXruK2XRM762SwyK3Ep/1gbvo9894AqHKLa8DfhN75Fsh7am2RKiHgEewaqW9Zwif8U3hRMRGzHa2bR10AmKEx1nZWdLOFk07oN+zO98qwbZUzPqzg88yLqR/a+8+XkOWrtwLUF9iEaRla7kfvkirSDf5KbKvROH/VFX/VdP/VLv3UK6ypeO8Ea3OsnVqZG/Y6jC7ztf1Y76Th3fhz1P2KCcze9NjG+QVlByzaFTqtNyjrCmjp+Ep2GL1CTU68qOSLPm2AdY6yyj0GfLruxxZj2Og/oAeuAeWqxwmxMw37L2V+GyVZDXRe9Wi14LvltWU3tJdV9Zz1vtzxPna/wjThZ5vXZxnsVizGNLA2PylFtHMv4c9SOspmqBqoSeqDmnbXjr6Ag003OMVSS6Ja/gB3vqgUUZOWLnNM5V98pb2rOcbFHBWiOypeces2sk/tos67Y+gsvGGrHAAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMnxi4gDQjSA4A1QYKdAAAAHictdQHTltBFIXh3wXTTEnvvRc6hGp6XQbpiBREOsoqs5O7gZBzPScLIFJG+nw9o+c3b/R8LtAB1OSp1KFap0KO31qttNdr9LTX6/zSvEkXVX0fYo8DjmL0+FirQ+yyz2FU2rO/o6Krm1zlPs80W2GMJeZZZZItxmlpdZEF1phhmg0mmGOKdXaYZZlNtvX7qnav6xkbdGrfbj1Jr+7YRz8DDHKaM5zlHOe5wEUucZkr2u0a17nBTW5xmzvc5Z72f8BDHvGYJzrPkD6HNRvRAzY42Vg54fU5xpbmVye3xls67cLazLQOOje1vjO7vLn9Dzf7D6OZH7Wfnu2Qb7PI0+7amDy3JXlh8/LSVuWVTcpr25I3Ni5vrSV7lv+QfVuUd7Yg721NPtiMfLRpObANObQJ+WRz8tmm5Iuty1fLs3+zWfluy/LDNuXI9AKjUmRWolqQtVZktqJeZL6io8jcRaMga2dB1q6CrN0FWXuKzGP0FmRtFvkmo68ga39B1oGCrIMFWU8VyhJhShVhyhdhShphyhxhSh9hyiFhSiRhyiZhSilhyithSi5hyjBhSjNhyjVhSjhhyjphSj1hyj9h6gSEqScQpu5AmPoEYeoRhKl3EKb+QVj2zbDMTFj7muGCrCNF+56jBSN/AHzNoH4AAAB4nO1Ye2xT1xm/37nEN87D8bUdXwezwLWJDZQCtmNfO4FATIgdQhLWGwhrt0DSGJHHpgaawFRatBIVVrXbHxXTWCiPabMHo9MgSH1IGxJMa6b+sbBJFZVK2/HHVNjI6JZ2k8W97DvHjzyggPrntBufe17fPec73/md3/edcMDhw4f4fs7IcSBLglwuW3mZD+mj+/ZBQtv//vtkhPxuYiIFe2EvijD5T/lPuUVYCQpeRRK8oswyRRZZJokyywQZLrXFxscbNwPf1oh5m65txjzWpuu0PdYGhF9k/LIuWm/czOXm3Mq/whViRfAaMYlu+NkbCeiG7sTZU2TPGz3QrR/vOavdzMmTSTLJFTN51AW1QX3IZOOFsdiFC7GxC41jUJ8rjTVe4Ao47q6O67rBWTk35+Ue41ZyXIHsWgFBsboOArK/EspFmwl42WXAgh1bQtjlgYDorgqUu3nM+T7N5qpx4Y/83VUjyzWyZjY7HGZyW5Qk7ReqCi2qmmpvJ66Ii3yGL/xpZfjifySJmig6HCL5hyjpY/q1ZBJO6jtw2Vm9bjK9luJ6coq4p5UrmKOTALheK9/HdHDldbo1Q5teffLf1aev8zdyKuRU2jJTk3f0ot/XH4YTc/XwPpoevByUH6jFX/Tz0PoQHfTSJN3OWfM/2uwPmvkhk9L14qL38T2IjELOwXEIOskIvLIQDAL+ldvsOEu11+Mlf9O31zyta1A3Pv7ur4uLK8rsvg0+e1kFXIJTtdihX4Y14+N1paWVTk+Fy+dzVVQtqKTDG9gcR/gjOJuAWC3DtUkcV1WOZsPEz8nhlH6ej+rnk7OydAofaEniA620zGV1v5HF8spHsxYghsvdQXcwEAzw/RmLadaMBcmkZmaWoZbT30uxJ2NBS9aCk1kLWlFCJLdw2y5QlVJMFfaK8lG2ShH1CYhy0I0sIYsyH5TFQJCMJvWSJEyp+hi0pPQxlYyyehrrp7AxzeV54Hn+eXqujYDbIRgB2UCBKbAM65PspU8OgwVfpG9WFSxYncElhxmXiAFkLDrAz0+eTejH9eMJ+C4xaVNYOQFdCe6r4p7u2oPQ9wO95GGoH0smp233Lq9wFZyPW43zK1IoYJfskgkBicwGobUQdLsQk17rCuI1CJUg2RXJgMikfyEUUFgJ5UGu9qyNHnpucNvSb9cF6xeZ9D+taPYW1T0WfvzAX0PfXF3UUO17pVX9uv9bT3ZtrYus9D85BFc3N5os9kq5uHY5b1qyyjLvieaDa3Z5GgJLiuFAEQG1wGBy6tcM4W1Bf7zhabujeN2CImN1VZ1/40ub9KO+TqskLZwfaHf+b65FQjwv4UK4FroORg1ZXUNYpm12Jac0QcB4qzxrwE3lJBRR4A5dQdvw/hd/uJ8q+Y0933umoXpdZ/euZ3Zs3ciULWnctbc3VgQboagtFAtVLQl5VvPlvNr84nBLW0nJRs8af/NI85Yz/vg2JWwwKP4eq2RfVBF+qjrUWcOXLlgGhcXzm22FAuEyPMo4px95DT2+VQbRG/SVB4Iq45Qk34/eZ3sq3d6elSV30I/yLDoQ3SI6Fq8gwVqVmC9fDqfTZFIvgSm94dIlrFDxkuxZvziL05zcwmmvqiDT5BI8pCwjH6WSyTT7ISN8WQlOJpMTSUaCJ+/NUKWC7Lovcl/jZK4KPenjlIcYsSLvZSk2n0R3UAZ3Ofr0TKrCBKeQYdFGyLY0p0zF8h3t0JqdjqnD96tovqSaxiytklhas6hwqh15TFXn2rTKLQaARicCuaOq2m1m1PQMi2b46iS/lfGVhIRHQzTYebpHPw7dPWdIDZw8nYmDzlCyJXe/uPsF/y/+n1w1159BpaGMuiwvYs+j4AEL+RkqsdUElQQb6sCDnUGfhxaxC6segXVTOSlgpx95q70+KsbkK0muuxL82KmEvB7yQsRmWxIeibQ2b2rZbcMnEi+qsAARyTxDhdNmCTY1OQ8usFidRgepWFpoL7JbwBpp2dTcGhkJL0FxSzkU2QuXOUhpsdFptToPOpuaghabs8IwjzcTsFQUxSN0XJyptfkozkQru9kAcaPZFPQXWgzznfGmkM3qHHHG406jaHY5lhYSg5nOxFQaCR9FcUuZQAqXOlxmo1BEBUecVluoKe6cb7AU+oMmszHOVjHzvBxBFC9kjCUgLJGs0FciYyE8cfPQYwaUoNctlJPY0eGjV6/iK5kv/Pjl7u6Xu8lvZjXSgvZWN+3i5s2KPZchNz5a5CmwoBYU5E5JeXDseevjmG80fAyuxT7xvR5+/SEBqFYX+2jVMRR//pOYD/O8H5qOVViUAtnEH7nzWz6aSelMNEJjEfrJV12bwsJ2XCIlnAev7bmPYquOKaNQHfuYKv2wtaWza3sNTXJMOZa/L7yKZ7KA7jA9jfAUO4ngzxFb5hw6+T9zpdN3EBY7SDDamwAveBO9vQn9A/2DRC8514ctWOrTX+rDNuzry8YSd1ksYeMWcwEaS9ATZqZOYxF1EWb0CKECemYDflqk8eVKehyZTzSU0+MIU4efHYxu2BAdfFb/bGgw2tAQHRyCCe3NUH00Nti1XYlI0rJ4qH49VjrDEcAafxOlh/TbQ7up9O4hMON3Gz7X3lwmSRGls3swFl0XaspUugbj0fpQDvdR9BMCcjiL2DBMC0iUKTFyo6y2M51Mqfp5FaZ4h5Ygo2qK8l/eVjTewxq4RckteN0KpVQy2Xkurarpc50wha5jvDed7oWwmuHnPE5k9Khhbu39kUIDBAaVWvRHwQKMIBExfOYeyg4mPaFWSuL0BjAHN9p3DlDcHEjx67R3SKUo/adk9eBgbcnFklqaDUxo10mjdA+CyO1kBkIkhiT9tkOE1ZkPMt+VkljyBbwzzMYR85Tk1Tk4IjMwQG9zbGPNFAaL6I6bKQwEBgsb7XHRejXtgalD+d0uyyHgMNvwiLK96zpuNj6dXfff7C10a693d1Lhzm4UViKz8biUxTD3w6PEVGQ+g4GS3nk8VtwJ3BvcGdyX+0LyUAZ+VKXrOSW/v37P4T3r2euR1dR3NGQ/Wb8nj60TWX/oVfACoMhBcvCXCejSTyROa38gsTOZUP50Ks/fA4jjUs5OYxh07XmeKcj+uyKAAH5L9blI3OXTxwZqJiZqBtrRCX8Ii/UP6Y0NFi8YqJ2YqB2A16bxTUbp6BhBpchP9DG8sJzPc8koYp/QO4pIYwS8nrRoO+f2kUz4wNdjwDU2Z0wj0CCjJSOR7UvyMYorI0HG4ZPaFf294YvwNrmiXYHgEJam9YrTnaVHABXTdiI4aXM+LnBzMa4D+dtumxsXLATalo0KQn6Jt/vz3t5gw96sr6dfCKxNAooH8LgyFbufPCEIHTNCgA7BKrQaDNvQn1MH2yHYBBemDuqm0cVvMxhaUaJjhivvEATiWG4y3fmpyWPCnO80ef54r0zL7FHgV7MnablXjTufL8cRcTgc1VuKw//fJvfa5L+BscYKAAAAeJxjYGRgYABi/jvPp8Xz23xl4GZ+ARSI4ny8rwFG///2/xvzZ+ZPQJUcDExAkgEAoUMP6XicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AIAnloHAgAAeJxjYGBgYH5Ba/z/G+3M/f+NgQ4AAPv8MfAAAHicY2AAAgmGIIYshhaGC4wijCGMPYz7GF8xGTGFMVUwTWC6wGzGPIf5BwsfiwZLCcsOlgssL1gnsB5iE2EzYGtim8K2jZ2HXYvdhX0Z+w72fxwRHAUcszhWcGzjOMJxieMZxxfOOi4O0iEAtgsblgB4nGNgZGBg8GLIYeBhAAEmIOYCQgaG/2A+AwAbuAHZAHicfZC9TsMwFIVP+odoBaoEYmAyCwtS+rPRtVKzd+ieJnaaKo2D41bqznPwBDxHn4OnYObEeCkStSXnu9899w4BMMQJAZoT4Ma9zWnhitUvt0n3njvkJ89dDBB67tG/eu7jBQvPA9zhjRuCzjXNI949t3CLD89t+k/PHfLJcxcP+PLco//23McqGHoe4DlQcRaZPJ0XcV3nyVJm+yI2Z+6sWElT57oUk3B85iNZShNbmYr1UdSHbGqtEsronVjo0sqi0KIyeisTG26srWajkfI+TPQOMTJEMMiRYo6Cdc2bI8ESkr29c+ZC7v/OihuMY40SAhP+9/GFfMR86WZiWH5Tzqxx5FvjwKkprYVirZjR2JEWbneTLng1TeV6W5qEPsTGTVWYYcSr/uRDprjpB8WrbRMAeJxtkmdv2zAURX1iyVbstEnTNt17D7VN994z/RUMRctEJFIgKY/8+rJxGiBA36dzHx7uu3xgZ6mzqEHn/7XFEl0SUnr0yVhmwJAVjnCUVdY4xjrHOcFJNjjFac5wlnOc5wIXucRlrnCVa1znBje5xW3ucJd73CfnAQ95xCaPecJTnvGcF7zkFa95w1ve8Z4PfOQTn/nCV77xnR/85Bdb/O4MRVk6VYqgrekJ5+zUd4WXPSmMVFUqx8KFNTlWcmfbzvI9UMXGQUObQgXlam1EUOsH7dbsT65IW1mXNzoK14+irY0fSGuCEzKoIpG2mafSWe+TQnmZqVkjomexrOYq95Xw4+EB5ZvdyL2RruLKdKSdD0npdJOWzrZNEkdCUqlR6FXaxN39yopCmzKrxUzXelcltTJtFrMulFGzkBhr1NDYkIuqslNVpE10Ud1Gm7TRExuyxqmJtq1fc9HM5tttCNbkdjRaPdwwqdPlOCReTNTA19EuL+zU7OPfWMMF7o1lC46pQzzNenBKHb5l1prFKwb/IN9EUOJQBDQWwxSPpGLMDtvM4lcoqGlpmDNil0mn8wcxorJdAAA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-dark .ag-icon {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-dark .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-dark .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-dark .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-dark .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-dark .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-dark .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-dark .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-dark .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-dark .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-dark .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-dark .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-dark .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-dark .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-dark .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-dark .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-dark .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-dark .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-dark .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-dark .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-dark .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-dark .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-dark .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-dark .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-dark .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-dark .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-dark .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-dark .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-dark .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-dark .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-dark .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-dark .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-dark .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-dark .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-dark .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-dark .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-dark .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-dark .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-dark .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-dark .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-dark .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-dark .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-dark .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-dark .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-dark .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-dark .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-dark .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-dark .ag-root-wrapper {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e); }\n .ag-theme-dark [class^='ag-'], .ag-theme-dark [class^='ag-']:focus, .ag-theme-dark [class^='ag-']:after, .ag-theme-dark [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-dark [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-dark .ag-checkbox .ag-input-wrapper,\n .ag-theme-dark .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-dark .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-dark .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-dark .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px; }\n .ag-theme-dark .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px; }\n .ag-theme-dark input[class^='ag-'] {\n margin: 0;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e); }\n .ag-theme-dark textarea[class^='ag-'],\n .ag-theme-dark select[class^='ag-'] {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e); }\n .ag-theme-dark input[class^='ag-']:not([type]),\n .ag-theme-dark input[class^='ag-'][type='text'],\n .ag-theme-dark input[class^='ag-'][type='number'],\n .ag-theme-dark input[class^='ag-'][type='tel'],\n .ag-theme-dark input[class^='ag-'][type='date'],\n .ag-theme-dark input[class^='ag-'][type='datetime-local'],\n .ag-theme-dark textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #000;\n border-color: var(--ag-input-border-color, #000); }\n .ag-theme-dark input[class^='ag-']:not([type]):disabled,\n .ag-theme-dark input[class^='ag-'][type='text']:disabled,\n .ag-theme-dark input[class^='ag-'][type='number']:disabled,\n .ag-theme-dark input[class^='ag-'][type='tel']:disabled,\n .ag-theme-dark input[class^='ag-'][type='date']:disabled,\n .ag-theme-dark input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-dark textarea[class^='ag-']:disabled {\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5));\n background-color: rgba(48, 46, 46, 0.3);\n background-color: var(--ag-input-disabled-background-color, rgba(48, 46, 46, 0.3));\n border-color: rgba(0, 0, 0, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(0, 0, 0, 0.3)); }\n .ag-theme-dark input[class^='ag-']:not([type]):focus,\n .ag-theme-dark input[class^='ag-'][type='text']:focus,\n .ag-theme-dark input[class^='ag-'][type='number']:focus,\n .ag-theme-dark input[class^='ag-'][type='tel']:focus,\n .ag-theme-dark input[class^='ag-'][type='date']:focus,\n .ag-theme-dark input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-dark textarea[class^='ag-']:focus {\n outline: none;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-dark input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-dark input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-dark input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-dark .ag-drag-handle {\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-list-item, .ag-theme-dark .ag-virtual-list-item {\n height: 20px; }\n .ag-theme-dark .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-select-list {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-dark .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-dark .ag-list-item.ag-active-item {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-dark .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-dark .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-dark .ag-select .ag-picker-field-wrapper {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n min-height: 20px;\n cursor: default; }\n .ag-theme-dark .ag-select:not(.ag-cell-editor) {\n height: 20px; }\n .ag-theme-dark .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-dark .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-dark .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-dark .ag-rich-select {\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e); }\n .ag-theme-dark .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 162.5px; }\n .ag-theme-dark .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-dark .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 20px; }\n .ag-theme-dark .ag-rich-select-virtual-list-item:hover {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-dark .ag-rich-select-row {\n padding-left: 12px; }\n .ag-theme-dark .ag-rich-select-row-selected {\n background-color: #4a708b;\n background-color: var(--ag-selected-row-background-color, #4a708b); }\n .ag-theme-dark .ag-row-drag,\n .ag-theme-dark .ag-selection-checkbox,\n .ag-theme-dark .ag-group-expanded,\n .ag-theme-dark .ag-group-contracted {\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-ltr .ag-row-drag, .ag-theme-dark .ag-ltr .ag-selection-checkbox, .ag-theme-dark .ag-ltr .ag-group-expanded, .ag-theme-dark .ag-ltr .ag-group-contracted {\n margin-right: 12px; }\n .ag-theme-dark .ag-rtl .ag-row-drag, .ag-theme-dark .ag-rtl .ag-selection-checkbox, .ag-theme-dark .ag-rtl .ag-group-expanded, .ag-theme-dark .ag-rtl .ag-group-contracted {\n margin-left: 12px; }\n .ag-theme-dark .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 23px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-dark .ag-group-expanded,\n .ag-theme-dark .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-dark .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-dark .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-dark .ag-group-title-bar {\n background-color: #201f1f;\n background-color: var(--ag-subheader-background-color, #201f1f);\n padding: 4px; }\n .ag-theme-dark .ag-group-toolbar {\n padding: 4px; }\n .ag-theme-dark .ag-disabled-group-title-bar, .ag-theme-dark .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-dark .group-item {\n margin: 2px 0; }\n .ag-theme-dark .ag-label {\n white-space: nowrap; }\n .ag-theme-dark .ag-ltr .ag-label {\n margin-right: 4px; }\n .ag-theme-dark .ag-rtl .ag-label {\n margin-left: 4px; }\n .ag-theme-dark .ag-label-align-top .ag-label {\n margin-bottom: 2px; }\n .ag-theme-dark .ag-ltr .ag-slider-field, .ag-theme-dark .ag-ltr .ag-angle-select-field {\n margin-right: 8px; }\n .ag-theme-dark .ag-rtl .ag-slider-field, .ag-theme-dark .ag-rtl .ag-angle-select-field {\n margin-left: 8px; }\n .ag-theme-dark .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e); }\n .ag-theme-dark .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #ccc;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 5px; }\n .ag-theme-dark .ag-picker-field-button {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-dark .ag-color-picker .ag-picker-field-display {\n height: 12px; }\n .ag-theme-dark .ag-color-panel {\n padding: 4px; }\n .ag-theme-dark .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-dark .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-dark .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-dark .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-dark .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-dark .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-dark .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-dark .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-dark .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-dark .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-dark .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-dark .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-dark.ag-dnd-ghost {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n height: 25px !important;\n line-height: 25px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px); }\n .ag-theme-dark .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #ccc;\n color: var(--ag-foreground-color, #ccc); }\n .ag-theme-dark .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3); }\n .ag-dragging-range-handle .ag-theme-dark .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-dark .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-dark .ag-dialog {\n border-radius: 0px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-panel {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e); }\n .ag-theme-dark .ag-panel-title-bar {\n background-color: #626262;\n background-color: var(--ag-header-background-color, #626262);\n color: #ccc;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)));\n height: 25px;\n padding: 4px 12px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px; }\n .ag-theme-dark .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px; }\n .ag-theme-dark .ag-tooltip {\n background-color: #626262;\n background-color: var(--ag-header-background-color, #626262);\n color: #ccc;\n color: var(--ag-foreground-color, #ccc);\n padding: 4px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n transition: opacity 1s; }\n .ag-theme-dark .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px; }\n .ag-theme-dark .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-dark .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 6px; }\n .ag-theme-dark .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 6px; }\n .ag-theme-dark .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-column-select-column-group:not(:last-child),\n .ag-theme-dark .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px; }\n .ag-theme-dark .ag-column-select-column-readonly,\n .ag-theme-dark .ag-column-select-column-group-readonly {\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5));\n pointer-events: none; }\n .ag-theme-dark .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 20px; }\n .ag-theme-dark .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 20px; }\n .ag-theme-dark .ag-column-select-list {\n padding: 6px 6px; }\n .ag-theme-dark .ag-rtl {\n text-align: right; }\n .ag-theme-dark .ag-root-wrapper {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 36px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 36px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-1 {\n padding-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-1 {\n padding-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 60px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 60px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-2 {\n padding-left: 48px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-2 {\n padding-right: 48px; }\n .ag-theme-dark .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 84px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 84px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-3 {\n padding-left: 72px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-3 {\n padding-right: 72px; }\n .ag-theme-dark .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 108px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 108px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-4 {\n padding-left: 96px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-4 {\n padding-right: 96px; }\n .ag-theme-dark .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 132px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 132px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-5 {\n padding-left: 120px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-5 {\n padding-right: 120px; }\n .ag-theme-dark .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 156px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 156px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-6 {\n padding-left: 144px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-6 {\n padding-right: 144px; }\n .ag-theme-dark .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 180px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 180px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-7 {\n padding-left: 168px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-7 {\n padding-right: 168px; }\n .ag-theme-dark .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 204px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 204px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-8 {\n padding-left: 192px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-8 {\n padding-right: 192px; }\n .ag-theme-dark .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 228px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 228px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-9 {\n padding-left: 216px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-9 {\n padding-right: 216px; }\n .ag-theme-dark .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 252px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 252px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-10 {\n padding-left: 240px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-10 {\n padding-right: 240px; }\n .ag-theme-dark .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 276px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 276px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-11 {\n padding-left: 264px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-11 {\n padding-right: 264px; }\n .ag-theme-dark .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 300px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 300px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-12 {\n padding-left: 288px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-12 {\n padding-right: 288px; }\n .ag-theme-dark .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 324px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 324px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-13 {\n padding-left: 312px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-13 {\n padding-right: 312px; }\n .ag-theme-dark .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 348px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 348px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-14 {\n padding-left: 336px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-14 {\n padding-right: 336px; }\n .ag-theme-dark .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 372px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 372px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-15 {\n padding-left: 360px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-15 {\n padding-right: 360px; }\n .ag-theme-dark .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 396px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 396px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-16 {\n padding-left: 384px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-16 {\n padding-right: 384px; }\n .ag-theme-dark .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 420px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 420px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-17 {\n padding-left: 408px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-17 {\n padding-right: 408px; }\n .ag-theme-dark .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 444px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 444px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-18 {\n padding-left: 432px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-18 {\n padding-right: 432px; }\n .ag-theme-dark .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 468px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 468px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-19 {\n padding-left: 456px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-19 {\n padding-right: 456px; }\n .ag-theme-dark .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-dark .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-dark .ag-value-change-delta-up {\n color: greenyellow;\n color: var(--ag-value-change-delta-up-color, greenyellow); }\n .ag-theme-dark .ag-value-change-delta-down {\n color: red;\n color: var(--ag-value-change-delta-down-color, red); }\n .ag-theme-dark .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-dark .ag-value-change-value-highlight {\n background-color: chocolate;\n background-color: var(--ag-value-change-value-highlight-background-color, chocolate);\n transition: background-color 0.1s; }\n .ag-theme-dark .ag-cell-data-changed {\n background-color: chocolate !important;\n background-color: var(--ag-value-change-value-highlight-background-color, chocolate) !important; }\n .ag-theme-dark .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-dark .ag-cell-highlight {\n background-color: rgba(255, 255, 255, 0.4) !important;\n background-color: var(--ag-range-selection-highlight-color, rgba(255, 255, 255, 0.4)) !important; }\n .ag-theme-dark .ag-row {\n height: 25px;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n color: #ccc;\n color: var(--ag-data-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-row-highlight-above::after, .ag-theme-dark .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #ccc;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n left: 1px; }\n .ag-theme-dark .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-dark .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-dark .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-dark .ag-row-odd {\n background-color: #403e3e;\n background-color: var(--ag-odd-row-background-color, #403e3e); }\n .ag-theme-dark .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-dark .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-dark .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-dark .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-dark .ag-cell {\n border: 1px solid transparent;\n line-height: 23px;\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-dark .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-dark .ag-row-dragging {\n cursor: move; }\n .ag-theme-dark .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-dark .ag-cell-inline-editing {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 25px;\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e); }\n .ag-theme-dark .ag-popup-editor {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e);\n padding: 0; }\n .ag-theme-dark .ag-large-text-input {\n height: auto;\n padding: 12px; }\n .ag-theme-dark .ag-details-row {\n padding: 20px;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e); }\n .ag-theme-dark .ag-overlay-loading-wrapper {\n background-color: rgba(48, 46, 46, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(48, 46, 46, 0.66)); }\n .ag-theme-dark .ag-overlay-loading-center {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px; }\n .ag-theme-dark .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-dark .ag-loading {\n padding-left: 12px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-dark .ag-loading-icon {\n padding-right: 12px; }\n .ag-theme-dark .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-dark .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-ltr .ag-cell {\n border-right: dotted grey; }\n .ag-theme-dark .ag-rtl .ag-cell {\n border-left: dotted grey; }\n .ag-theme-dark .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-dark .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-dark .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-row-selected {\n background-color: #4a708b;\n background-color: var(--ag-selected-row-background-color, #4a708b); }\n .ag-theme-dark .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(100, 160, 160, 0.4);\n background-color: var(--ag-range-selection-background-color, rgba(100, 160, 160, 0.4)); }\n .ag-theme-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1);\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)); }\n .ag-theme-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)); }\n .ag-theme-dark .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(100, 160, 160, 0.4);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(100, 160, 160, 0.4))); }\n .ag-theme-dark .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(100, 160, 160, 0.64);\n background-color: var(--ag-range-selection-background-color-2, rgba(100, 160, 160, 0.64)); }\n .ag-theme-dark .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(100, 160, 160, 0.784);\n background-color: var(--ag-range-selection-background-color-3, rgba(100, 160, 160, 0.784)); }\n .ag-theme-dark .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(100, 160, 160, 0.8704);\n background-color: var(--ag-range-selection-background-color-4, rgba(100, 160, 160, 0.8704)); }\n .ag-theme-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #ccc;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #ccc;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #ccc;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #ccc;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-dark .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-dark .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-dark .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-dark .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-dark .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n outline: initial; }\n .ag-theme-dark .ag-cell.ag-selection-fill-top,\n .ag-theme-dark .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #ccc;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-dark .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #ccc;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-dark .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #ccc;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-cell.ag-selection-fill-bottom,\n .ag-theme-dark .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #ccc;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-dark .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #ccc;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-dark .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #ccc;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-fill-handle, .ag-theme-dark .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #ccc;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-ltr .ag-fill-handle, .ag-theme-dark .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-dark .ag-rtl .ag-fill-handle, .ag-theme-dark .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-dark .ag-fill-handle {\n cursor: cell; }\n .ag-theme-dark .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-dark .ag-cell-inline-editing {\n border-color: var(--ag-input-focus-border-color) !important; }\n .ag-theme-dark .ag-menu {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n padding: 0; }\n .ag-theme-dark .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-dark .ag-menu-option-part {\n padding-top: 6px;\n padding-bottom: 6px;\n line-height: 12px; }\n .ag-theme-dark .ag-menu-option-active {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-dark .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-dark .ag-menu-option-text {\n margin-left: 4px; }\n .ag-theme-dark .ag-menu-option-icon {\n padding-left: 8px;\n padding-right: 4px;\n min-width: 20px; }\n .ag-theme-dark .ag-menu-option-shortcut {\n padding-left: 8px; }\n .ag-theme-dark .ag-menu-separator {\n height: 8px; }\n .ag-theme-dark .ag-menu-separator-cell:after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-menu-option-popup-pointer {\n width: 20px;\n text-align: center; }\n .ag-theme-dark .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-dark .ag-tab {\n border-bottom: 0 solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer; }\n .ag-theme-dark .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-tab-selected {\n border-bottom-color: #ccc;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-menu-header {\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-dark .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px; }\n .ag-theme-dark .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px; }\n .ag-theme-dark .ag-set-filter-select-all {\n padding-top: 6px; }\n .ag-theme-dark .ag-set-filter-list {\n height: 120px; }\n .ag-theme-dark .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px; }\n .ag-theme-dark .ag-filter-to {\n margin-top: 4px; }\n .ag-theme-dark .ag-mini-filter {\n margin: 6px 6px;\n margin-bottom: 0; }\n .ag-theme-dark .ag-set-filter-item {\n margin: 0px 6px; }\n .ag-theme-dark .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px; }\n .ag-theme-dark .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px; }\n .ag-theme-dark .ag-filter-header-container {\n padding-bottom: 6px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-dark .ag-filter-apply-panel {\n padding: 6px 6px;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-dark .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-dark .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px; }\n .ag-theme-dark .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px; }\n .ag-theme-dark .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-dark .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px; }\n .ag-theme-dark .ag-filter-no-matches {\n margin: 6px 6px; }\n .ag-theme-dark .ag-side-bar {\n position: relative; }\n .ag-theme-dark .ag-tool-panel-wrapper {\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e); }\n .ag-theme-dark .ag-side-buttons {\n padding-top: 16px;\n width: 16px;\n position: relative;\n color: #ccc;\n color: var(--ag-foreground-color, #ccc);\n overflow: hidden; }\n .ag-theme-dark button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: calc(100% + 1px);\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-selected .ag-side-button-button {\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e);\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-dark .ag-ltr .ag-side-bar-left,\n .ag-theme-dark .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-dark .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-dark .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent;\n margin-right: -1px;\n padding-right: 1px; }\n .ag-theme-dark .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-dark .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #ccc;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-rtl .ag-side-bar-left,\n .ag-theme-dark .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-dark .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-dark .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent;\n margin-left: -1px;\n padding-left: 1px; }\n .ag-theme-dark .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-dark .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #ccc;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-filter-toolpanel-header {\n height: 24px; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-header, .ag-theme-dark .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-header, .ag-theme-dark .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px; }\n .ag-theme-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 4px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 4px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-0-header {\n height: 32px; }\n .ag-theme-dark .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px; }\n .ag-theme-dark .ag-filter-toolpanel-search {\n height: 25px; }\n .ag-theme-dark .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 16px; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px; }\n .ag-theme-dark .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px; }\n .ag-theme-dark .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n padding-top: 4px; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px; }\n .ag-theme-dark .ag-pivot-mode-panel {\n height: 25px;\n display: flex; }\n .ag-theme-dark .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-dark .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px; }\n .ag-theme-dark .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px; }\n .ag-theme-dark .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-column-select-header {\n height: 25px;\n align-items: center;\n padding: 0 6px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-dark .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-dark .ag-column-group-icons,\n .ag-theme-dark .ag-column-select-header-icon {\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-header {\n background-color: #626262;\n background-color: var(--ag-header-background-color, #626262);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-header-row {\n color: #ccc;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-header-row {\n height: 25px; }\n .ag-theme-dark .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-dark .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-dark .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-dark .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-dark .ag-header-cell,\n .ag-theme-dark .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px; }\n .ag-theme-dark .ag-header-cell.ag-header-cell-moving,\n .ag-theme-dark .ag-header-group-cell.ag-header-cell-moving {\n background-color: #bebebe;\n background-color: var(--ag-header-cell-moving-background-color, #bebebe); }\n .ag-theme-dark .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-header-icon {\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-dark .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-dark .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-dark .ag-header-row:not(:first-child) .ag-header-cell,\n .ag-theme-dark .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-header-cell::after,\n .ag-theme-dark .ag-header-group-cell::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n width: 1px;\n height: 100%;\n top: calc(50% - 50%);\n background-color: rgba(169, 169, 169, 0.5);\n background-color: var(--ag-header-column-separator-color, rgba(169, 169, 169, 0.5)); }\n .ag-theme-dark .ag-ltr .ag-header-cell::after, .ag-theme-dark .ag-ltr .ag-header-group-cell::after {\n right: 0; }\n .ag-theme-dark .ag-rtl .ag-header-cell::after, .ag-theme-dark .ag-rtl .ag-header-group-cell::after {\n left: 0; }\n .ag-theme-dark .ag-ltr .ag-header-select-all {\n margin-right: 12px; }\n .ag-theme-dark .ag-rtl .ag-header-select-all {\n margin-left: 12px; }\n .ag-theme-dark .ag-ltr .ag-floating-filter-button {\n margin-left: 12px; }\n .ag-theme-dark .ag-rtl .ag-floating-filter-button {\n margin-right: 12px; }\n .ag-theme-dark .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 12px;\n padding: 0;\n width: 12px; }\n .ag-theme-dark .ag-filter-loading {\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-dark .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n height: 25px; }\n .ag-theme-dark .ag-paging-panel > * {\n margin: 0 12px; }\n .ag-theme-dark .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 12px; }\n .ag-theme-dark .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-dark .ag-paging-button-wrapper.ag-disabled {\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5));\n cursor: default; }\n .ag-theme-dark .ag-paging-button-wrapper, .ag-theme-dark .ag-paging-description {\n margin: 0 4px; }\n .ag-theme-dark .ag-status-bar {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5; }\n .ag-theme-dark .ag-status-name-value-value {\n color: #ccc;\n color: var(--ag-foreground-color, #ccc); }\n .ag-theme-dark .ag-status-bar-center {\n text-align: center; }\n .ag-theme-dark .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px; }\n .ag-theme-dark .ag-column-drop-cell {\n background: #403e3e;\n background: var(--ag-chip-background-color, #403e3e);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px; }\n .ag-theme-dark .ag-column-drop-cell-text {\n margin: 0 4px; }\n .ag-theme-dark .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-column-drop-cell-drag-handle {\n margin-left: 8px; }\n .ag-theme-dark .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-dark .ag-column-drop-horizontal {\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e);\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px; }\n .ag-theme-dark .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px; }\n .ag-theme-dark .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-column-drop-horizontal-empty-message {\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5)); }\n .ag-theme-dark .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px; }\n .ag-theme-dark .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px; }\n .ag-theme-dark .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px; }\n .ag-theme-dark .ag-column-drop-vertical-cell {\n margin-top: 4px; }\n .ag-theme-dark .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-dark .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none; }\n .ag-theme-dark .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px; }\n .ag-theme-dark .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-dark .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5));\n margin-top: 4px; }\n .ag-theme-dark .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n height: 70px;\n padding: 0; }\n .ag-theme-dark .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 20px;\n padding-left: 8px; }\n .ag-theme-dark .ag-select-agg-func-virtual-list-item:hover {\n background-color: #4a708b;\n background-color: var(--ag-selected-row-background-color, #4a708b); }\n .ag-theme-dark .ag-chart-menu {\n border-radius: 0px;\n background: #302e2e;\n background: var(--ag-background-color, #302e2e); }\n .ag-theme-dark .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 0px;\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-dark .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-dark .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-dark .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-dark .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-dark .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-dark .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-dark .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-dark .ag-chart-mini-thumbnail.ag-selected {\n border-color: #ccc;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-chart-settings-card-item {\n background: #ccc;\n background: var(--ag-foreground-color, #ccc);\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-dark .ag-chart-settings-card-item.ag-selected {\n background-color: #ccc;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-chart-data-column-drag-handle {\n margin-left: 4px; }\n .ag-theme-dark .ag-charts-settings-group-title-bar,\n .ag-theme-dark .ag-charts-data-group-title-bar,\n .ag-theme-dark .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-dark .ag-charts-settings-group-container {\n padding: 4px; }\n .ag-theme-dark .ag-charts-data-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-dark .ag-charts-data-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-dark .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px; }\n .ag-theme-dark .ag-charts-format-top-level-group-item {\n margin: 4px 0; }\n .ag-theme-dark .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-dark .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-dark .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px; }\n .ag-theme-dark .ag-chart-data-section,\n .ag-theme-dark .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-dark .ag-chart-menu-panel {\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e); }\n .ag-theme-dark .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-dark .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-dark .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-dark .ag-checkbox-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-dark .ag-checkbox-input-wrapper input, .ag-theme-dark .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-dark .ag-checkbox-input-wrapper:focus-within, .ag-theme-dark .ag-checkbox-input-wrapper:active {\n outline: none; }\n .ag-theme-dark .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-dark .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #ccc;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-dark .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #ccc;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-dark .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #ccc;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc)));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-dark .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 24px;\n height: 12px;\n background-color: #ccc;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc)));\n border-radius: 6px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-dark .ag-toggle-button-input-wrapper:focus-within {\n outline: none; }\n .ag-theme-dark .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-dark .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #ccc;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc)));\n border-color: #ccc;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n background-color: #302e2e;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #302e2e));\n border-radius: 6px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc)))); }\n .ag-theme-dark .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 12px);\n border-color: #ccc;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-radio-button-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 12px; }\n .ag-theme-dark .ag-radio-button-input-wrapper input, .ag-theme-dark .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-dark .ag-radio-button-input-wrapper:focus-within, .ag-theme-dark .ag-radio-button-input-wrapper:active {\n outline: none; }\n .ag-theme-dark .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-dark .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #ccc;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-dark .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #ccc;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-dark input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-dark input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px; }\n .ag-theme-dark input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px; }\n .ag-theme-dark input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-dark input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc));\n border-radius: 12px;\n -webkit-transform: translateY(-4.5px);\n transform: translateY(-4.5px); }\n .ag-theme-dark input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc));\n border-radius: 12px; }\n .ag-theme-dark input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc));\n border-radius: 12px; }\n .ag-theme-dark input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-dark input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n border-color: #ccc;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark input[class^='ag-'][type='range']:focus::-ms-thumb {\n border-color: #ccc;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n border-color: #ccc;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark input[class^='ag-'][type='range']:active::-ms-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-dark .ag-icon {\n color: #d6d5d5; }\n .ag-theme-dark .ag-icon-tree-closed::before {\n content: \"\\f10b\"; }\n .ag-theme-dark .ag-icon-tree-open::before {\n content: \"\\f10f\"; }\n .ag-theme-dark .ag-header, .ag-theme-dark .ag-column-drop-cell {\n background-image: none; }\n .ag-theme-dark .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px; }\n .ag-theme-dark .ag-tabs-body {\n margin: 2px 0; }\n .ag-theme-dark .ag-icon {\n margin: 1px 1px 2px 1px; }\n .ag-theme-dark .ag-tab-selected {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-bottom-color: transparent; }\n .ag-theme-dark .ag-tabs-header {\n background-color: #626262;\n background-color: var(--ag-header-background-color, #626262);\n border-bottom: 1px solid;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-filter .ag-filter-apply-panel {\n justify-content: flex-start; }\n .ag-theme-dark .ag-menu-option-active {\n background-color: #4a708b;\n background-color: var(--ag-selected-row-background-color, #4a708b); }\n .ag-theme-dark .ag-column-drop-cell {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0; }\n .ag-theme-dark .ag-column-drop-cell-button .ag-icon {\n border: 1px solid transparent; }\n .ag-theme-dark .ag-column-drop-cell-button:hover .ag-icon {\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-panel-title-bar-button-icon {\n font-size: 20px;\n line-height: 20px; }\n .ag-theme-dark .ag-menu-option-part {\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-dark .ag-column-drop-vertical-title-bar {\n margin-top: 4px;\n margin-left: 4px; }\n .ag-theme-dark .ag-column-drop-vertical-title {\n margin-left: 4px; }\n .ag-theme-dark .ag-column-drop-vertical-empty-message {\n margin-left: 24px; }\n\n", ""]); +exports.push([module.i, ".ag-theme-dark {\n -webkit-font-smoothing: antialiased;\n color: #ccc;\n color: var(--ag-foreground-color, #ccc);\n font-family: \"Helvetica Neue\", sans-serif;\n font-size: 14px;\n line-height: normal;\n}\n@font-face {\n font-family: \"agGridClassic\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABXwAAsAAAAAKrgAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAmMAAAR2Zoxou09TLzIAAANsAAAAQQAAAFZWVlMSY21hcAAAA7AAAAIbAAAFnIlT7KJnbHlmAAAFzAAADBkAABg4HeN0mGhlYWQAABHoAAAANAAAADZ2z8SBaGhlYQAAEhwAAAAeAAAAJAfTBCxobXR4AAASPAAAABgAAAE4yyH/7GxvY2EAABJUAAAAdgAAAJ5JCULobWF4cAAAEswAAAAfAAAAIAFkAKpuYW1lAAAS7AAAATMAAAJS8kTiWnBvc3QAABQgAAABzQAAArBhTs2TeJx9lMtOU1EUhv/DaREoAlG8pCIiGi+oiMrxXHpoy6WH1tbEgTEOnGBMjAlxxHP4AD4BQ5/AB3DgE/gADhw6Nn5r9WCFAey03Xtd/vXvf62NAklTWlNTYzvF4KVm9vcOPqquioZ/5v9/H+x/eL+niaMTvor/TiioTGtGy3qtA30LZoKD4HBsPqyHr8J34efwS/hLIVFLWiW6pqesWAnfkVJlaijXmMaxxew34BOymmq59RyMqu7pqqfL1IzJ6Tniip7xmQOncJyOtolKWYbZ4XvAuqfZUyJy3Qc/g80m1gqKLKJJrnlNgp4Q01Sb/Cb+89TcoXaEv8BXwK6KpcW+rQtwsoyKq9rVGz3Bbzc1lKzMSfnE2vVz5Kc1NDmKaoHToJZhr8LgyN6gakLGY9AzorZKRVd0k+wGOB3Q2p694dnLRCZwS3WDnd0zges08Zle6K1X3S1zOq7pUIFV2I/shePlenjM2gZrQOwjOIys1p8H1IrUx1+jV4X29UmH+qrv+qGf+q0/OqOL1En8Dtug75yqzQQKnozu4m39s9pdx5mBk1HHIya5ecPVifH1Sg2tWo2bmTop+whr6vFT8LT4Lmxy+lGhRuR1rdNV1ibnmOiz5XQ2WdOudI8pmPUJ7vss1HWHvi064nAOc7S+CqLthvyuuG5N8Ba8b6auvbA5P9lbsH7XmdVr/EbcMHOdnuO9jsWQRpYlz8phbxjr+HNYj6oZqwVYresuPpuxvr+OLpVucZ8hk4QIexl9n6/bMMjKlzpPD419u+zYJY+LPSvgP0FUvvDUtbOZLuBm8zH4C3G+c6UAeJxjYGSazTiBgZWBgamKaQ8DA0MPhGZ8wGDIyAQUZWBlZsAKAtJcUxgOMOh+NGJ+AeRGMX9i4ALSjCA5AOaCCwgAAAB4nLXUB1IbQRCF4V+BLMA22eQcBQaTcxAiHwJnCgcKZ87hs/kefQL8Rt0+AK7yVn3bO1Or3ZlavQaqgJzMSB6ytWR0RSar2UxlPkd9ZT7Pb40L1JLVdZErbrizhft7zRa55Jpby1RGf4+M7i7QwxjLGh2yxAE7lFnlXDN7rLPPLkdsssEJK2yzxjFnbFHilAv9Pq0irzVWU6P31mklDXpiI0084jEttNJGOx100kW33tRLH/0MMMgQw4wwyjgTTDLFtHZSZJY5njHPgs7PNVrUIqt52HH4wPvTsXSwU149X97TjnePNje02e2147Ot0unFPzzsPxyFdMr9itEZ6Yu6tNvLsCQvwoG8DDvyKpTldViVN+Fc3ob0b3gX9uQqrMt12Jf3YVc+hCP5GDblU9iQm3Ait2FFPodt+RLW5Gs4lm8h7f172JIfoSQ/w6ncBX1Ay7iUF8s6Us25lC/Lu5Qxq3Ipe1btSLXGkWqtI9U6R6r1LmXSGhypFlz6ktboSLXJkWqzU3awoBRhQXnCnjglC2txyhjW6pQ2rM0pd1i7UwKxDqcsYp1OqcS6nPKJPXVKKtbtlFmsxym9WK9TjrE+p0Rj/U7ZxgacUo4NOuUdG3JKPjbs1AOwEadugI069QVszKlDYONOvQKbcKkv2qRLebApp96BTTv1FGzGqa9gRac+g806dRxszlXuCepC2LyrPHPBsfgHpKymyQB4nO1Ye2wUxxnfmfXt3t57d+92zxycvXf4FkNico+99QMMGOOzcWzTnIMJaQ04GMWYRDEESJqktAElJErSShFVqUmAqj0XmlQFI+XRBxKpGleRGqePNKnyKn+0Sdq4pHXS6uRb+s3eww8ooPSfVu3Zu/P6Zuabb34z3+9bClHwo5P0IMVRFFJkVvEpIq3QSWN4717Un7v/9dfxAfzT8fERtBftBRFT/n36faoSChqr6jKr8oqZ6ApvJjKvmAmroHNdqbGxlnWIXgdpap2RW9cCaZdhkPpUF8J0JdcFVS1dlzblu1LFOdfTj1FWKLAqBw8fRt9+th/1ob7+Z47jXc9uRX3G01ufyX1YlMcTeIKym/KgC2gD+uCJljOjqTNnUqNnWkbRqmJutOUMZaGoiwas6wNKpMKUSi2hllKURQnVII1PNKK4EgsiH+91IVoJMZCRoCYJTREU58NVcV+YhpTenhOV+lCoXsEfwUupV3Iej9/vwRd4Wc59N51GHen0SHc3DtWF8Mfwgv+cG17012U+x/N+P4//wsvGqPF2JoOOGZth2bP0WgzrKSoSnlbOMkcnFsF6RZnebioRKik1MUOdAWPi74kT59fSHxSVKCp180xdXjRsP1t1EB1dRM3VRb02XWhFU66oyO+N06jzKloYzgzZ0lnzX9vsV5r5KpOS9cKi76G3AjqslJ+iAHgyh2i9AjEs/Pm8EsySUCMq/pOxqf42I4cax8Ze/oHdXu6WomuikrscnUPHG6DBeAktHxtrdDqDgUh5KBoNlVfND5LhGXOOQ/QhmI0FvLphbTJFVfnAbPDQc1J03DhNNxmnM7OS7Aj8UEcGfqiT5KmC7h8UbLX02qyFAMe+sBbW4lqcHgwRi4Hl8hYkljMtQyxnvDJi/vIWFAoWnChYUAQJHn8E23aGqDRCUUV9mugmc5U86BPnFS0MN4XCK7Sm8HEND2cMRwZNpo1R1DFijKbxsFnOQvk4VGap0l3wAP0AOdscgu1gOQQ3go4mkbDHmDBfxsQeJMALb59VRAIU8za/OEXfSf+Z8oB1FlCt1Jepp2DoCOykZYZF6LCGQEFGlhqQWOV14XCopkxLNOI4saWXCUXUGhSGDt4giiX1RhSTZGLgEFRriWQsSMcJPmqQWoOJuWNBXOiU71OBJDmI4WZK6tFGsj9enxu5MGzPUhq6S/Qd7La7LEanqusqTqp6y6jRhB7BiLZ4foeNTZwQ9Hpkr8dmcfoVUV4o2pzWMqvXLc93yJUSg60u2ykhJC3gnR7OZWWtbgcv2QWPN8ALFZLg5602J1tmcQcFxm4RBLtTsC1bshjT2Gq3WrCGWZvbweA4jWyCFf/RuudBC65Vp141lXlkfOpR+p7flHN87mu/dVQERasQqKzyhbSId74qcG6b0+dNxCqXSH6/ze1yl1dLbnuVYHfZy3mHLLh4K8OKSk2V6PT5fR6b3S2ITs7O0SxrYcUFT/zwR5ydsbFOm4X7Nee2ci7uF27O5hGo/+/df/XeFf34QdOP83FgC+TgfufYM/3G08bT/ehe7MpNQuEo2tIPomVz9rrtqvusQ2skkYzHpAq0ApNtk3xeN5Jhe1woFFmKWAKEiJa48vZcf0s7x1q8bl70LFtpczFOq1v0dXY7bJzgFco29JRxPNRcybBj9w66nHbJI/o3bnQLFovHwS+44163T3BxHLPvi4yV4d2mTf4X1vjZeAPxelfy3k8YjquxhtFMZtr3vEzrVDkVpZbB/LqcjEuyJLvAoQM7RMkVSAuHwKerYg1WGTaIZEmXGWJp+EuCgGl1FeSRkoisaHr4vqEN1Xc0aqsqXcYva9pVW+OS2uv3/SH5+WW25kT0sc7052Jf2LhlfWPd0tjG3eiNdS0uQQoq9obraNeiG4Sym9r3L7890hxfZEf7bBilLYwrYLzN1G7QYq3Nt0l++8r5Ni5R1Rhb+9CNxuForyjLFfPi3YHptcjgQxdRSVgLWYdJRwq6JiFP6iS9qDS5ldSqyHIUJnIyiOhoiqyga8/9D371fqLkLbu+cldzYmVv3+13bV6/1lTW0XL73oGUDa1Ftq5kKlm1KBlZRvvodPuDezq6HI61keWx9gPtN5+MtW7QaxlGj20VZamyvPbWRLK3nnbOX4ys9nntXiuLqTx3M3nODuBSEGmICuJVLeqLa2mTx2ToQWC9m0ay3d0FWTwF/J02oxI+zAOhVVkZrUhjz0sv1WazeMJwoEmj+dw5KBBxR4FfnJ3FowJUxTSb14HdFB90lbwCHGgkk8ma/8BC/lUOHctkxjMm8Tp2aQIqWQrrPgtnW6GqqGrqesJ9TDIHXKtA60oPH9YUFPZBLJF/quBBx4HVgY2A4ZGUsCMz3dyNOgvTmerQg2kwXyadhSSbxqlsTkij493AndLp/xg95uxtVZiPIxKdsXgqnc5dMDc3O2Nn8z7jGL3e9BkykD0SoqJtJ/Je4iSuR8dO5OPAk4Ro4oufXvyU/hv9VypBDeZPB+MmdB08txrR4aCDc5bztS4UxFDRiIhb16IRkoUmcv+yZjORk+MS6aQm1CgRM+WDuNgM5AEa9aQawV+q83oX1R6o62y/sWOnF351rbZyAWEelzHlAa+gtbUF9s8XxADnx+XVVskmCUis67ixvbPuQO0iEBd8yCZZF/ux084FRDGwP9DWpgneQDlTBoMgodzWWkfGhZk62w/DTKSw0xyglfO4tJhVYOYFWtuSXjFwINDaGuB4T8hfbcWMh8xkqnSg9jCIC24WW6v9IQ/H2ojggYDoTba1BuYxgjWmuTxcq7mKmef2EJymCvPmZOF4wKUJcQLcnHBMYPMgWojrmhpmfTh1eM/hN96AV6aU+cajfX2P9uEfz6okmdzzfaTJ9IEzY9zoNUberBnUIx3ucFm/cuz90bup6HDtEfR26r3oU7VPXSUAzzWm3rnhCIg/8F4qCmnJh0zHaWaEhgoPfWjqJ3RT/snmIzEShxX9+2dZm25+toAlkovvymu7753UDUf0YZRIvUuUvtrasoW1PQkmOaIfKX0veRzOpIXsMDmN6FbzJKJY8YLNn8MA/SvKOf0NxuRvMhoe6EcqUvsHBvqNN403+wfwqe1QA7ntxkPboQ7athd4wEWwxYeUl1pIxQkPICfMQ5xXJXFVHvBMSQs5s/EYyZLYeik5jqZvBt5NTufkwbuHmtasaRq62/h491BTc3PT0G40nnsuuaopNbRlk14ny4vbtFWrodBbW+eXF9MfgvBu48LunUR4527kgW5rPsk9t1iW6/TevqFU08pkW76wZai1aVWyhPsmehB2252PViFEjcvkpoSoldxq27KZkbRxOo0maX+uHw+nR8j992/2RaU4GUoozMthVg3r5DrGE72nsul09lQvmgT3NzaQzQ6g2nTex5QwpgArqKVWXB5lhOSYMGsAn6pZIPIm7DL/Dc881OR0i8QBkC8nczCXu3Mfwdy+EXpl7kUc5OV/OBuGhhocZx1msmM8dx63yJegD1/I5OGHU3DBv+Dn0TLHjH5OnMp8iZfnYND09vjxORjEM/BTDVImKDwEQpUELR4CIdaElJe0hEyiTFrQ5MMlpLiL6DlogqVO37TlPAAFfr1bLo+Umwkuzvf1EuHePhDW62ZjudrkYZfDsmyqSGArmYAm34oiIuHpNShhho2XhfPDQ0WNzhd1fGT1roO7Vpuva9bS2Nxc6LJ613T8dbTgS1Wdg0fR8P7v9aMtxtH+E7mf49TJfCh2YqSE40HAsZOSCA8DWlC6oyyFT71xAPDz6WgIt4aixuiO+vHx+h3d4MDfQguNt8iXLrRw/o6G8fGGHejJaXzjYTI6sMAR/E1jFA8bp0v30DBgH5NvOzzhF2gSdeS2zW3DeepBrwLSODpnTA4RgtKRlyi0ZegUwRUHATuiM7nXjFf2nEUv4NdyryFtN+Sm9WolO0uOACiW2wbgJNUlThGmUlQP3P2Sdy6nqECkrsAokjGZlmIlpsB4obXAE0gP1qyTEcEDioTyBSmGb2LZnhn0oYcV2U6G2QBcgDjnHtbLhuDpIS4e6MEGhukEiZ4ZNKCHZbH/Opdr6luuiAtSutcVefVSmY7Zo6Dvz56k41I1pj65DkaE4WBU1QnD/xPnjHQ0AAAAeJxjYGRgYADiY81JvPH8Nl8ZuJlfAAWiOB/va4DR/7/9/8b8mfkTUCUHAxOQZAAAhKEPOXicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AMAnl4HBgAAeJxjYGBgYH5Bb/z/Gy3NZqADAAB/FDOneJxjYAACCYYghiyGFoYLjGKMYYx9jAcY3zCZMEUwVTFHsJix+LEcYDViLWK9wWbC5sWWwraB7Qu7BXsAewaHAIcTxxSODZxMnCKcZpw9nKs4T3A+4nLhCuOaw/WNm4/bgtuNO4Q7ibuAu4V7Eo8M6RAAslkbZAAAeJxjYGRgYPBjmMfAwwACTEDMBYQMDP/BfAYAIQYCDwB4nH2QvU7DMBSFT/qHaAWqBGJgMgsLUvqz0bVSs3foniZ2miqNg+NW6s5z8AQ8R5+Dp2DmxHgpErUl57vfPfcOATDECQGaE+DGvc1p4YrVL7dJ95475CfPXQwQeu7Rv3ru4wULzwPc4Y0bgs41zSPePbdwiw/PbfpPzx3yyXMXD/jy3KP/9tzHKhh6HuA5UHEWmTydF3Fd58lSZvsiNmfurFhJU+e6FJNwfOYjWUoTW5mK9VHUh2xqrRLK6J1Y6NLKotCiMnorExturK1mo5HyPkz0DjEyRDDIkWKOgnXNmyPBEpK9vXPmQu7/zoobjGONEgIT/vfxhXzEfOlmYlh+U86sceRb48CpKa2FYq2Y0diRFm53ky54NU3leluahD7Exk1VmGHEq/7kQ6a46QfFq20TAHicbZIHb9swEIX9xZKt2GmTpm269x5q6+6990h/A0PRMhGZFEjKdvLry9pBgQA9gIf3Dod37w5sLbUW0Wv9PzZZok1CSocuGcv06LPCAQ6yyhqHWOcwRzjKBsc4zglOcorTnOEs5zjPBS5yictc4SrXuM4NbnKL2+Tc4S73GHCfBzzkEY95wlOe8ZwXvOQVr3nDW97xng985BOf+cJXvvGdH/zkF5v8bvVFWTpViqCt6Qjn7NS3hZcdKYxUVSpHwoU1OVJye8vO8jlQxca/gjaFCsqNtRFBrf8rN2avc0Xayrq81pG4biTN2PietCY4IYMqEmnrnVQ6631b+kkaXz5ICuVlqmbRQHee80GmZrWIs4pltaNyXwk/akfUGeoqjk+H2vmQlE7XaelsU3fnOSrFxpBUahg6lTbRT7eyotCmzMZipsd6VyVjZZos+l8wo2YhMdaovrEhF1Vlp6pI66iiuvOcD9q1NmmtJzZktVMTbRu/5qKozbeaEKzJ7XC4ur9gUqfLUUi8mKieH0fZvLBTswf/2usv4LwtW+CmTkI823pwSu2/c9aYxTYIShyKgMZimOKRVIzYZotZ/CMFYxpqdpgwZLfV+gPpZLiDAAAA\") format(\"woff\");\n font-weight: normal;\n font-style: normal;\n}\n.ag-theme-dark .ag-icon {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n.ag-theme-dark .ag-icon-aggregation::before {\n content: \"\\f101\";\n}\n.ag-theme-dark .ag-icon-arrows::before {\n content: \"\\f102\";\n}\n.ag-theme-dark .ag-icon-asc::before {\n content: \"\\f103\";\n}\n.ag-theme-dark .ag-icon-cancel::before {\n content: \"\\f104\";\n}\n.ag-theme-dark .ag-icon-chart::before {\n content: \"\\f105\";\n}\n.ag-theme-dark .ag-icon-color-picker::before {\n content: \"\\f109\";\n}\n.ag-theme-dark .ag-icon-columns::before {\n content: \"\\f10a\";\n}\n.ag-theme-dark .ag-icon-contracted::before {\n content: \"\\f10b\";\n}\n.ag-theme-dark .ag-icon-copy::before {\n content: \"\\f10c\";\n}\n.ag-theme-dark .ag-icon-cross::before {\n content: \"\\f10d\";\n}\n.ag-theme-dark .ag-icon-csv::before {\n content: \"\\f10e\";\n}\n.ag-theme-dark .ag-icon-desc::before {\n content: \"\\f10f\";\n}\n.ag-theme-dark .ag-icon-excel::before {\n content: \"\\f110\";\n}\n.ag-theme-dark .ag-icon-expanded::before {\n content: \"\\f111\";\n}\n.ag-theme-dark .ag-icon-eye-slash::before {\n content: \"\\f112\";\n}\n.ag-theme-dark .ag-icon-eye::before {\n content: \"\\f113\";\n}\n.ag-theme-dark .ag-icon-filter::before {\n content: \"\\f114\";\n}\n.ag-theme-dark .ag-icon-first::before {\n content: \"\\f115\";\n}\n.ag-theme-dark .ag-icon-grip::before {\n content: \"\\f116\";\n}\n.ag-theme-dark .ag-icon-group::before {\n content: \"\\f117\";\n}\n.ag-theme-dark .ag-icon-last::before {\n content: \"\\f118\";\n}\n.ag-theme-dark .ag-icon-left::before {\n content: \"\\f119\";\n}\n.ag-theme-dark .ag-icon-linked::before {\n content: \"\\f11a\";\n}\n.ag-theme-dark .ag-icon-loading::before {\n content: \"\\f11b\";\n}\n.ag-theme-dark .ag-icon-maximize::before {\n content: \"\\f11c\";\n}\n.ag-theme-dark .ag-icon-menu::before {\n content: \"\\f11d\";\n}\n.ag-theme-dark .ag-icon-minimize::before {\n content: \"\\f11e\";\n}\n.ag-theme-dark .ag-icon-next::before {\n content: \"\\f11f\";\n}\n.ag-theme-dark .ag-icon-none::before {\n content: \"\\f120\";\n}\n.ag-theme-dark .ag-icon-not-allowed::before {\n content: \"\\f121\";\n}\n.ag-theme-dark .ag-icon-paste::before {\n content: \"\\f122\";\n}\n.ag-theme-dark .ag-icon-pin::before {\n content: \"\\f123\";\n}\n.ag-theme-dark .ag-icon-pivot::before {\n content: \"\\f124\";\n}\n.ag-theme-dark .ag-icon-previous::before {\n content: \"\\f125\";\n}\n.ag-theme-dark .ag-icon-right::before {\n content: \"\\f128\";\n}\n.ag-theme-dark .ag-icon-save::before {\n content: \"\\f129\";\n}\n.ag-theme-dark .ag-icon-small-down::before {\n content: \"\\f12a\";\n}\n.ag-theme-dark .ag-icon-small-left::before {\n content: \"\\f12b\";\n}\n.ag-theme-dark .ag-icon-small-right::before {\n content: \"\\f12c\";\n}\n.ag-theme-dark .ag-icon-small-up::before {\n content: \"\\f12d\";\n}\n.ag-theme-dark .ag-icon-tick::before {\n content: \"\\f12e\";\n}\n.ag-theme-dark .ag-icon-tree-closed::before {\n content: \"\\f12f\";\n}\n.ag-theme-dark .ag-icon-tree-indeterminate::before {\n content: \"\\f130\";\n}\n.ag-theme-dark .ag-icon-tree-open::before {\n content: \"\\f131\";\n}\n.ag-theme-dark .ag-icon-unlinked::before {\n content: \"\\f132\";\n}\n.ag-theme-dark .ag-icon-row-drag::before {\n content: \"\\f116\";\n}\n.ag-theme-dark .ag-left-arrow::before {\n content: \"\\f119\";\n}\n.ag-theme-dark .ag-right-arrow::before {\n content: \"\\f128\";\n}\n.ag-theme-dark .ag-root-wrapper {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n}\n.ag-theme-dark [class^=ag-], .ag-theme-dark [class^=ag-]:focus, .ag-theme-dark [class^=ag-]:after, .ag-theme-dark [class^=ag-]:before {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n outline: none;\n}\n.ag-theme-dark [class^=ag-]::-ms-clear {\n display: none;\n}\n.ag-theme-dark .ag-checkbox .ag-input-wrapper,\n.ag-theme-dark .ag-radio-button .ag-input-wrapper {\n overflow: visible;\n}\n.ag-theme-dark .ag-range-field .ag-input-wrapper {\n height: 100%;\n}\n.ag-theme-dark .ag-toggle-button {\n -webkit-box-flex: 0;\n flex: none;\n width: unset;\n min-width: unset;\n}\n.ag-theme-dark .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px;\n}\n\n.ag-theme-dark .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px;\n}\n\n.ag-theme-dark input[class^=ag-] {\n margin: 0;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n}\n.ag-theme-dark textarea[class^=ag-],\n.ag-theme-dark select[class^=ag-] {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n}\n.ag-theme-dark input[class^=ag-]:not([type]),\n.ag-theme-dark input[class^=ag-][type=text],\n.ag-theme-dark input[class^=ag-][type=number],\n.ag-theme-dark input[class^=ag-][type=tel],\n.ag-theme-dark input[class^=ag-][type=date],\n.ag-theme-dark input[class^=ag-][type=datetime-local],\n.ag-theme-dark textarea[class^=ag-] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #000;\n border-color: var(--ag-input-border-color, #000);\n}\n.ag-theme-dark input[class^=ag-]:not([type]):disabled,\n.ag-theme-dark input[class^=ag-][type=text]:disabled,\n.ag-theme-dark input[class^=ag-][type=number]:disabled,\n.ag-theme-dark input[class^=ag-][type=tel]:disabled,\n.ag-theme-dark input[class^=ag-][type=date]:disabled,\n.ag-theme-dark input[class^=ag-][type=datetime-local]:disabled,\n.ag-theme-dark textarea[class^=ag-]:disabled {\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5));\n background-color: rgba(48, 46, 46, 0.3);\n background-color: var(--ag-input-disabled-background-color, rgba(48, 46, 46, 0.3));\n border-color: rgba(0, 0, 0, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(0, 0, 0, 0.3));\n}\n.ag-theme-dark input[class^=ag-]:not([type]):focus,\n.ag-theme-dark input[class^=ag-][type=text]:focus,\n.ag-theme-dark input[class^=ag-][type=number]:focus,\n.ag-theme-dark input[class^=ag-][type=tel]:focus,\n.ag-theme-dark input[class^=ag-][type=date]:focus,\n.ag-theme-dark input[class^=ag-][type=datetime-local]:focus,\n.ag-theme-dark textarea[class^=ag-]:focus {\n outline: none;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-dark input[class^=ag-]:not([type]):invalid,\n.ag-theme-dark input[class^=ag-][type=text]:invalid,\n.ag-theme-dark input[class^=ag-][type=number]:invalid,\n.ag-theme-dark input[class^=ag-][type=tel]:invalid,\n.ag-theme-dark input[class^=ag-][type=date]:invalid,\n.ag-theme-dark input[class^=ag-][type=datetime-local]:invalid,\n.ag-theme-dark textarea[class^=ag-]:invalid {\n border-width: 2px;\n border-style: solid;\n border-color: var(--ag-input-border-color-invalid);\n}\n.ag-theme-dark input[class^=ag-][type=number] {\n -moz-appearance: textfield;\n}\n.ag-theme-dark input[class^=ag-][type=number]::-webkit-outer-spin-button, .ag-theme-dark input[class^=ag-][type=number]::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n}\n.ag-theme-dark input[class^=ag-][type=range] {\n padding: 0;\n}\n.ag-theme-dark .ag-drag-handle {\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-list-item, .ag-theme-dark .ag-virtual-list-item {\n height: 20px;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-dark .ag-select-list {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n overflow-y: auto;\n overflow-x: hidden;\n}\n.ag-theme-dark .ag-list-item {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-dark .ag-list-item.ag-active-item {\n background-color: var(--ag-row-hover-color);\n}\n.ag-theme-dark .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n user-select: none;\n}\n.ag-theme-dark .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n.ag-theme-dark .ag-select .ag-picker-field-wrapper {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n min-height: 20px;\n cursor: default;\n}\n.ag-theme-dark .ag-select.ag-disabled .ag-picker-field-wrapper:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-dark .ag-select:not(.ag-cell-editor) {\n height: 20px;\n}\n.ag-theme-dark .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-dark .ag-select .ag-picker-field-icon {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-dark .ag-select.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-dark .ag-rich-select {\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e);\n}\n.ag-theme-dark .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 162.5px;\n}\n.ag-theme-dark .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n}\n.ag-theme-dark .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 20px;\n}\n.ag-theme-dark .ag-rich-select-virtual-list-item:hover {\n background-color: var(--ag-row-hover-color);\n}\n.ag-theme-dark .ag-rich-select-row {\n padding-left: 12px;\n}\n.ag-theme-dark .ag-rich-select-row-selected {\n background-color: #4a708b;\n background-color: var(--ag-selected-row-background-color, #4a708b);\n}\n.ag-theme-dark .ag-row-drag,\n.ag-theme-dark .ag-selection-checkbox,\n.ag-theme-dark .ag-group-expanded,\n.ag-theme-dark .ag-group-contracted {\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-ltr .ag-row-drag, .ag-theme-dark .ag-ltr .ag-selection-checkbox, .ag-theme-dark .ag-ltr .ag-group-expanded, .ag-theme-dark .ag-ltr .ag-group-contracted {\n margin-right: 12px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-drag, .ag-theme-dark .ag-rtl .ag-selection-checkbox, .ag-theme-dark .ag-rtl .ag-group-expanded, .ag-theme-dark .ag-rtl .ag-group-contracted {\n margin-left: 12px;\n}\n\n.ag-theme-dark .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: min(var(--ag-row-height, 23px), 23px);\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-dark .ag-group-expanded,\n.ag-theme-dark .ag-group-contracted {\n cursor: pointer;\n}\n.ag-theme-dark .ag-group-title-bar-icon {\n cursor: pointer;\n -webkit-box-flex: 0;\n flex: none;\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-ltr .ag-group-child-count {\n margin-left: 2px;\n}\n\n.ag-theme-dark .ag-rtl .ag-group-child-count {\n margin-right: 2px;\n}\n\n.ag-theme-dark .ag-group-title-bar {\n background-color: #201f1f;\n background-color: var(--ag-subheader-background-color, #201f1f);\n padding: 4px;\n}\n.ag-theme-dark .ag-group-toolbar {\n padding: 4px;\n}\n.ag-theme-dark .ag-disabled-group-title-bar, .ag-theme-dark .ag-disabled-group-container {\n opacity: 0.5;\n}\n.ag-theme-dark .group-item {\n margin: 2px 0;\n}\n.ag-theme-dark .ag-label {\n white-space: nowrap;\n}\n.ag-theme-dark .ag-ltr .ag-label {\n margin-right: 4px;\n}\n\n.ag-theme-dark .ag-rtl .ag-label {\n margin-left: 4px;\n}\n\n.ag-theme-dark .ag-label-align-top .ag-label {\n margin-bottom: 2px;\n}\n.ag-theme-dark .ag-ltr .ag-slider-field, .ag-theme-dark .ag-ltr .ag-angle-select-field {\n margin-right: 8px;\n}\n\n.ag-theme-dark .ag-rtl .ag-slider-field, .ag-theme-dark .ag-rtl .ag-angle-select-field {\n margin-left: 8px;\n}\n\n.ag-theme-dark .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n}\n.ag-theme-dark .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #ccc;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 5px;\n}\n.ag-theme-dark .ag-picker-field-button {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-dialog.ag-color-dialog {\n border-radius: 5px;\n}\n.ag-theme-dark .ag-color-picker .ag-picker-field-display {\n height: 12px;\n}\n.ag-theme-dark .ag-color-panel {\n padding: 4px;\n}\n.ag-theme-dark .ag-spectrum-color {\n background-color: red;\n border-radius: 2px;\n}\n.ag-theme-dark .ag-spectrum-tools {\n padding: 10px;\n}\n.ag-theme-dark .ag-spectrum-sat {\n background-image: -webkit-gradient(linear, left top, right top, from(white), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0));\n}\n.ag-theme-dark .ag-spectrum-val {\n background-image: -webkit-gradient(linear, left bottom, left top, from(black), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0));\n}\n.ag-theme-dark .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n -webkit-box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n}\n.ag-theme-dark .ag-spectrum-hue-background {\n border-radius: 2px;\n}\n.ag-theme-dark .ag-spectrum-alpha-background {\n border-radius: 2px;\n}\n.ag-theme-dark .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px;\n}\n.ag-theme-dark .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n -webkit-box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n}\n.ag-theme-dark .ag-recent-color {\n margin: 0 3px;\n}\n.ag-theme-dark .ag-recent-color:first-child {\n margin-left: 0;\n}\n.ag-theme-dark .ag-recent-color:last-child {\n margin-right: 0;\n}\n.ag-theme-dark.ag-dnd-ghost {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n height: 25px !important;\n line-height: 25px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px);\n}\n.ag-theme-dark .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #ccc;\n color: var(--ag-foreground-color, #ccc);\n}\n.ag-theme-dark .ag-popup-child:not(.ag-tooltip-custom) {\n -webkit-box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3);\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3);\n}\n.ag-dragging-range-handle .ag-theme-dark .ag-dialog, .ag-dragging-fill-handle .ag-theme-dark .ag-dialog {\n opacity: 0.7;\n pointer-events: none;\n}\n.ag-theme-dark .ag-dialog {\n border-radius: 0px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-panel {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n}\n.ag-theme-dark .ag-panel-title-bar {\n background-color: #626262;\n background-color: var(--ag-header-background-color, #626262);\n color: #ccc;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)));\n height: 25px;\n padding: 4px 12px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px;\n}\n\n.ag-theme-dark .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px;\n}\n\n.ag-theme-dark .ag-tooltip {\n background-color: #626262;\n background-color: var(--ag-header-background-color, #626262);\n color: #ccc;\n color: var(--ag-foreground-color, #ccc);\n padding: 4px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n white-space: normal;\n}\n.ag-theme-dark .ag-tooltip.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-dark .ag-tooltip-custom {\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n}\n.ag-theme-dark .ag-tooltip-custom.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-dark .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px;\n}\n\n.ag-theme-dark .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px;\n}\n\n.ag-theme-dark .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px;\n}\n\n.ag-theme-dark .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px;\n}\n\n.ag-theme-dark .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px;\n}\n\n.ag-theme-dark .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px;\n}\n\n.ag-theme-dark .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px;\n}\n\n.ag-theme-dark .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px;\n}\n\n.ag-theme-dark .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px;\n}\n\n.ag-theme-dark .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px;\n}\n\n.ag-theme-dark .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px;\n}\n\n.ag-theme-dark .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px;\n}\n\n.ag-theme-dark .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px;\n}\n\n.ag-theme-dark .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px;\n}\n\n.ag-theme-dark .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px;\n}\n\n.ag-theme-dark .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px;\n}\n\n.ag-theme-dark .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px;\n}\n\n.ag-theme-dark .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px;\n}\n\n.ag-theme-dark .ag-column-select-header-icon {\n cursor: pointer;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-column-select-header-icon:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-dark .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 8px;\n}\n\n.ag-theme-dark .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 8px;\n}\n\n.ag-theme-dark .ag-keyboard-focus .ag-column-select-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-column-select-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-dark .ag-column-select-column-group:not(:last-child),\n.ag-theme-dark .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px;\n}\n.ag-theme-dark .ag-column-select-column-readonly,\n.ag-theme-dark .ag-column-select-column-group-readonly {\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5));\n pointer-events: none;\n}\n.ag-theme-dark .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 20px;\n}\n\n.ag-theme-dark .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 20px;\n}\n\n.ag-theme-dark .ag-column-select-virtual-list-viewport {\n padding: 3px 0px;\n}\n.ag-theme-dark .ag-column-select-virtual-list-item {\n padding: 0 6px;\n}\n.ag-theme-dark .ag-rtl {\n text-align: right;\n}\n.ag-theme-dark .ag-root-wrapper {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 36px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 36px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-1 {\n padding-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-1 {\n padding-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-1 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-1 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 60px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 60px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-2 {\n padding-left: 48px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-2 {\n padding-right: 48px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-2 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-2 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 84px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 84px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-3 {\n padding-left: 72px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-3 {\n padding-right: 72px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-3 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-3 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 108px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 108px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-4 {\n padding-left: 96px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-4 {\n padding-right: 96px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-4 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-4 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 132px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 132px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-5 {\n padding-left: 120px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-5 {\n padding-right: 120px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-5 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-5 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 156px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 156px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-6 {\n padding-left: 144px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-6 {\n padding-right: 144px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-6 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-6 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 180px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 180px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-7 {\n padding-left: 168px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-7 {\n padding-right: 168px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-7 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-7 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 204px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 204px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-8 {\n padding-left: 192px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-8 {\n padding-right: 192px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-8 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-8 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 228px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 228px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-9 {\n padding-left: 216px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-9 {\n padding-right: 216px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-9 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-9 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 252px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 252px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-10 {\n padding-left: 240px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-10 {\n padding-right: 240px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-10 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-10 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 276px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 276px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-11 {\n padding-left: 264px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-11 {\n padding-right: 264px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-11 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-11 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 300px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 300px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-12 {\n padding-left: 288px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-12 {\n padding-right: 288px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-12 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-12 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 324px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 324px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-13 {\n padding-left: 312px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-13 {\n padding-right: 312px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-13 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-13 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 348px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 348px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-14 {\n padding-left: 336px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-14 {\n padding-right: 336px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-14 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-14 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 372px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 372px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-15 {\n padding-left: 360px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-15 {\n padding-right: 360px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-15 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-15 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 396px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 396px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-16 {\n padding-left: 384px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-16 {\n padding-right: 384px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-16 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-16 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 420px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 420px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-17 {\n padding-left: 408px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-17 {\n padding-right: 408px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-17 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-17 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 444px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 444px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-18 {\n padding-left: 432px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-18 {\n padding-right: 432px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-18 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-18 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 468px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 468px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-19 {\n padding-left: 456px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-19 {\n padding-right: 456px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-19 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-19 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-left: 492px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-right: 492px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-20 {\n padding-left: 480px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-20 {\n padding-right: 480px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-20 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-20 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-left: 516px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-right: 516px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-21 {\n padding-left: 504px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-21 {\n padding-right: 504px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-21 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-21 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-left: 540px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-right: 540px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-22 {\n padding-left: 528px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-22 {\n padding-right: 528px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-22 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-22 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-left: 564px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-right: 564px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-23 {\n padding-left: 552px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-23 {\n padding-right: 552px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-23 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-23 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-left: 588px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-right: 588px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-24 {\n padding-left: 576px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-24 {\n padding-right: 576px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-24 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-24 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-left: 612px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-right: 612px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-25 {\n padding-left: 600px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-25 {\n padding-right: 600px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-25 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-25 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-left: 636px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-right: 636px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-26 {\n padding-left: 624px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-26 {\n padding-right: 624px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-26 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-26 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-left: 660px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-right: 660px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-27 {\n padding-left: 648px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-27 {\n padding-right: 648px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-27 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-27 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-left: 684px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-right: 684px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-28 {\n padding-left: 672px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-28 {\n padding-right: 672px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-28 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-28 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-left: 708px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-right: 708px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-29 {\n padding-left: 696px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-29 {\n padding-right: 696px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-29 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-29 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-left: 732px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-right: 732px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-30 {\n padding-left: 720px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-30 {\n padding-right: 720px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-30 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-30 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-left: 756px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-right: 756px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-31 {\n padding-left: 744px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-31 {\n padding-right: 744px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-31 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-31 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-left: 780px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-right: 780px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-32 {\n padding-left: 768px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-32 {\n padding-right: 768px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-32 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-32 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-left: 804px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-right: 804px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-33 {\n padding-left: 792px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-33 {\n padding-right: 792px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-33 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-33 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-left: 828px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-right: 828px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-34 {\n padding-left: 816px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-34 {\n padding-right: 816px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-34 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-34 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-left: 852px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-right: 852px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-35 {\n padding-left: 840px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-35 {\n padding-right: 840px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-35 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-35 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-left: 876px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-right: 876px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-36 {\n padding-left: 864px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-36 {\n padding-right: 864px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-36 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-36 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-left: 900px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-right: 900px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-37 {\n padding-left: 888px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-37 {\n padding-right: 888px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-37 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-37 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-left: 924px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-right: 924px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-38 {\n padding-left: 912px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-38 {\n padding-right: 912px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-38 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-38 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-left: 948px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-right: 948px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-39 {\n padding-left: 936px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-39 {\n padding-right: 936px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-39 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-39 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-left: 972px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-right: 972px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-40 {\n padding-left: 960px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-40 {\n padding-right: 960px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-40 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-40 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-left: 996px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-right: 996px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-41 {\n padding-left: 984px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-41 {\n padding-right: 984px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-41 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-41 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-left: 1020px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-right: 1020px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-42 {\n padding-left: 1008px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-42 {\n padding-right: 1008px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-42 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-42 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-left: 1044px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-right: 1044px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-43 {\n padding-left: 1032px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-43 {\n padding-right: 1032px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-43 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-43 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-left: 1068px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-right: 1068px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-44 {\n padding-left: 1056px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-44 {\n padding-right: 1056px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-44 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-44 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-left: 1092px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-right: 1092px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-45 {\n padding-left: 1080px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-45 {\n padding-right: 1080px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-45 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-45 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-left: 1116px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-right: 1116px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-46 {\n padding-left: 1104px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-46 {\n padding-right: 1104px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-46 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-46 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-left: 1140px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-right: 1140px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-47 {\n padding-left: 1128px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-47 {\n padding-right: 1128px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-47 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-47 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-left: 1164px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-right: 1164px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-48 {\n padding-left: 1152px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-48 {\n padding-right: 1152px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-48 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-48 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-left: 1188px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-right: 1188px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-49 {\n padding-left: 1176px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-49 {\n padding-right: 1176px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-49 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-49 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-left: 1212px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-right: 1212px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-50 {\n padding-left: 1200px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-50 {\n padding-right: 1200px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-50 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-50 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-left: 1236px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-right: 1236px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-51 {\n padding-left: 1224px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-51 {\n padding-right: 1224px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-51 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-51 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-left: 1260px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-right: 1260px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-52 {\n padding-left: 1248px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-52 {\n padding-right: 1248px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-52 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-52 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-left: 1284px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-right: 1284px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-53 {\n padding-left: 1272px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-53 {\n padding-right: 1272px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-53 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-53 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-left: 1308px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-right: 1308px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-54 {\n padding-left: 1296px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-54 {\n padding-right: 1296px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-54 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-54 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-left: 1332px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-right: 1332px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-55 {\n padding-left: 1320px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-55 {\n padding-right: 1320px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-55 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-55 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-left: 1356px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-right: 1356px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-56 {\n padding-left: 1344px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-56 {\n padding-right: 1344px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-56 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-56 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-left: 1380px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-right: 1380px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-57 {\n padding-left: 1368px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-57 {\n padding-right: 1368px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-57 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-57 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-left: 1404px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-right: 1404px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-58 {\n padding-left: 1392px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-58 {\n padding-right: 1392px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-58 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-58 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-left: 1428px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-right: 1428px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-59 {\n padding-left: 1416px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-59 {\n padding-right: 1416px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-59 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-59 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-left: 1452px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-right: 1452px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-60 {\n padding-left: 1440px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-60 {\n padding-right: 1440px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-60 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-60 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-left: 1476px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-right: 1476px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-61 {\n padding-left: 1464px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-61 {\n padding-right: 1464px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-61 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-61 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-left: 1500px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-right: 1500px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-62 {\n padding-left: 1488px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-62 {\n padding-right: 1488px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-62 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-62 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-left: 1524px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-right: 1524px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-63 {\n padding-left: 1512px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-63 {\n padding-right: 1512px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-63 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-63 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-left: 1548px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-right: 1548px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-64 {\n padding-left: 1536px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-64 {\n padding-right: 1536px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-64 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-64 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-left: 1572px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-right: 1572px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-65 {\n padding-left: 1560px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-65 {\n padding-right: 1560px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-65 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-65 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-left: 1596px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-right: 1596px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-66 {\n padding-left: 1584px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-66 {\n padding-right: 1584px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-66 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-66 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-left: 1620px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-right: 1620px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-67 {\n padding-left: 1608px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-67 {\n padding-right: 1608px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-67 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-67 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-left: 1644px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-right: 1644px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-68 {\n padding-left: 1632px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-68 {\n padding-right: 1632px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-68 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-68 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-left: 1668px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-right: 1668px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-69 {\n padding-left: 1656px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-69 {\n padding-right: 1656px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-69 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-69 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-left: 1692px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-right: 1692px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-70 {\n padding-left: 1680px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-70 {\n padding-right: 1680px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-70 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-70 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-left: 1716px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-right: 1716px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-71 {\n padding-left: 1704px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-71 {\n padding-right: 1704px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-71 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-71 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-left: 1740px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-right: 1740px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-72 {\n padding-left: 1728px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-72 {\n padding-right: 1728px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-72 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-72 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-left: 1764px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-right: 1764px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-73 {\n padding-left: 1752px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-73 {\n padding-right: 1752px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-73 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-73 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-left: 1788px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-right: 1788px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-74 {\n padding-left: 1776px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-74 {\n padding-right: 1776px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-74 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-74 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-left: 1812px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-right: 1812px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-75 {\n padding-left: 1800px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-75 {\n padding-right: 1800px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-75 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-75 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-left: 1836px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-right: 1836px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-76 {\n padding-left: 1824px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-76 {\n padding-right: 1824px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-76 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-76 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-left: 1860px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-right: 1860px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-77 {\n padding-left: 1848px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-77 {\n padding-right: 1848px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-77 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-77 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-left: 1884px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-right: 1884px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-78 {\n padding-left: 1872px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-78 {\n padding-right: 1872px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-78 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-78 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-left: 1908px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-right: 1908px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-79 {\n padding-left: 1896px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-79 {\n padding-right: 1896px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-79 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-79 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-left: 1932px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-right: 1932px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-80 {\n padding-left: 1920px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-80 {\n padding-right: 1920px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-80 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-80 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-left: 1956px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-right: 1956px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-81 {\n padding-left: 1944px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-81 {\n padding-right: 1944px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-81 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-81 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-left: 1980px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-right: 1980px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-82 {\n padding-left: 1968px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-82 {\n padding-right: 1968px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-82 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-82 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-left: 2004px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-right: 2004px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-83 {\n padding-left: 1992px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-83 {\n padding-right: 1992px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-83 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-83 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-left: 2028px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-right: 2028px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-84 {\n padding-left: 2016px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-84 {\n padding-right: 2016px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-84 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-84 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-left: 2052px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-right: 2052px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-85 {\n padding-left: 2040px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-85 {\n padding-right: 2040px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-85 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-85 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-left: 2076px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-right: 2076px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-86 {\n padding-left: 2064px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-86 {\n padding-right: 2064px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-86 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-86 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-left: 2100px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-right: 2100px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-87 {\n padding-left: 2088px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-87 {\n padding-right: 2088px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-87 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-87 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-left: 2124px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-right: 2124px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-88 {\n padding-left: 2112px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-88 {\n padding-right: 2112px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-88 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-88 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-left: 2148px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-right: 2148px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-89 {\n padding-left: 2136px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-89 {\n padding-right: 2136px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-89 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-89 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-left: 2172px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-right: 2172px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-90 {\n padding-left: 2160px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-90 {\n padding-right: 2160px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-90 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-90 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-left: 2196px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-right: 2196px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-91 {\n padding-left: 2184px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-91 {\n padding-right: 2184px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-91 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-91 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-left: 2220px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-right: 2220px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-92 {\n padding-left: 2208px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-92 {\n padding-right: 2208px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-92 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-92 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-left: 2244px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-right: 2244px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-93 {\n padding-left: 2232px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-93 {\n padding-right: 2232px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-93 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-93 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-left: 2268px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-right: 2268px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-94 {\n padding-left: 2256px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-94 {\n padding-right: 2256px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-94 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-94 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-left: 2292px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-right: 2292px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-95 {\n padding-left: 2280px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-95 {\n padding-right: 2280px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-95 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-95 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-left: 2316px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-right: 2316px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-96 {\n padding-left: 2304px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-96 {\n padding-right: 2304px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-96 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-96 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-left: 2340px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-right: 2340px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-97 {\n padding-left: 2328px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-97 {\n padding-right: 2328px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-97 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-97 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-left: 2364px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-right: 2364px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-98 {\n padding-left: 2352px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-98 {\n padding-right: 2352px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-98 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-98 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-left: 2388px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-right: 2388px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-indent-99 {\n padding-left: 2376px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-indent-99 {\n padding-right: 2376px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-level-99 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-level-99 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-ltr .ag-row-group-leaf-indent {\n margin-left: 24px;\n}\n\n.ag-theme-dark .ag-rtl .ag-row-group-leaf-indent {\n margin-right: 24px;\n}\n\n.ag-theme-dark .ag-value-change-delta {\n padding-right: 2px;\n}\n.ag-theme-dark .ag-value-change-delta-up {\n color: greenyellow;\n color: var(--ag-value-change-delta-up-color, greenyellow);\n}\n.ag-theme-dark .ag-value-change-delta-down {\n color: red;\n color: var(--ag-value-change-delta-down-color, red);\n}\n.ag-theme-dark .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n -webkit-transition: background-color 1s;\n transition: background-color 1s;\n}\n.ag-theme-dark .ag-value-change-value-highlight {\n background-color: chocolate;\n background-color: var(--ag-value-change-value-highlight-background-color, chocolate);\n -webkit-transition: background-color 0.1s;\n transition: background-color 0.1s;\n}\n.ag-theme-dark .ag-cell-data-changed {\n background-color: chocolate !important;\n background-color: var(--ag-value-change-value-highlight-background-color, chocolate) !important;\n}\n.ag-theme-dark .ag-cell-data-changed-animation {\n background-color: transparent;\n}\n.ag-theme-dark .ag-cell-highlight {\n background-color: rgba(255, 255, 255, 0.4) !important;\n background-color: var(--ag-range-selection-highlight-color, rgba(255, 255, 255, 0.4)) !important;\n}\n.ag-theme-dark .ag-row {\n height: 25px;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n color: #ccc;\n color: var(--ag-data-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-row-highlight-above::after, .ag-theme-dark .ag-row-highlight-below::after {\n content: \"\";\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #ccc;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n left: 1px;\n}\n.ag-theme-dark .ag-row-highlight-above::after {\n top: -1px;\n}\n.ag-theme-dark .ag-row-highlight-above.ag-row-first::after {\n top: 0;\n}\n.ag-theme-dark .ag-row-highlight-below::after {\n bottom: 0px;\n}\n.ag-theme-dark .ag-row-odd {\n background-color: #403e3e;\n background-color: var(--ag-odd-row-background-color, #403e3e);\n}\n.ag-theme-dark .ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-ltr .ag-right-aligned-cell {\n text-align: right;\n}\n\n.ag-theme-dark .ag-rtl .ag-right-aligned-cell {\n text-align: left;\n}\n\n.ag-theme-dark .ag-ltr .ag-right-aligned-cell .ag-cell-value, .ag-theme-dark .ag-ltr .ag-right-aligned-cell .ag-group-value {\n margin-left: auto;\n}\n\n.ag-theme-dark .ag-rtl .ag-right-aligned-cell .ag-cell-value, .ag-theme-dark .ag-rtl .ag-right-aligned-cell .ag-group-value {\n margin-right: auto;\n}\n\n.ag-theme-dark .ag-cell, .ag-theme-dark .ag-full-width-row .ag-cell-wrapper.ag-row-group {\n border: 1px solid transparent;\n line-height: min(var(--ag-row-height, 23px), 23px);\n padding-left: 11px;\n padding-right: 11px;\n -webkit-font-smoothing: subpixel-antialiased;\n}\n.ag-theme-dark .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px;\n}\n.ag-theme-dark .ag-row-dragging {\n cursor: move;\n opacity: 0.5;\n}\n.ag-theme-dark .ag-cell-inline-editing {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 25px;\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e);\n}\n.ag-theme-dark .ag-popup-editor {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e);\n padding: 0;\n}\n.ag-theme-dark .ag-large-text-input {\n height: auto;\n padding: 12px;\n}\n.ag-theme-dark .ag-details-row {\n padding: 20px;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n}\n.ag-theme-dark .ag-layout-auto-height .ag-center-cols-clipper, .ag-theme-dark .ag-layout-auto-height .ag-center-cols-container, .ag-theme-dark .ag-layout-print .ag-center-cols-clipper, .ag-theme-dark .ag-layout-print .ag-center-cols-container {\n min-height: 50px;\n}\n.ag-theme-dark .ag-overlay-loading-wrapper {\n background-color: rgba(48, 46, 46, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(48, 46, 46, 0.66));\n}\n.ag-theme-dark .ag-overlay-loading-center {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n}\n.ag-theme-dark .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px;\n}\n.ag-theme-dark .ag-loading {\n padding-left: 12px;\n display: -webkit-box;\n display: flex;\n height: 100%;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-dark .ag-loading-icon {\n padding-right: 12px;\n}\n.ag-theme-dark .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear;\n}\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n.ag-theme-dark .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-ltr .ag-cell {\n border-right: dotted grey;\n}\n\n.ag-theme-dark .ag-rtl .ag-cell {\n border-left: dotted grey;\n}\n\n.ag-theme-dark .ag-ltr .ag-cell {\n border-right-width: 1px;\n}\n\n.ag-theme-dark .ag-rtl .ag-cell {\n border-left-width: 1px;\n}\n\n.ag-theme-dark .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-row-selected {\n background-color: #4a708b;\n background-color: var(--ag-selected-row-background-color, #4a708b);\n}\n.ag-theme-dark .ag-cell-range-selected:not(.ag-cell-focus),\n.ag-theme-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing) {\n background-color: rgba(100, 160, 160, 0.4);\n background-color: var(--ag-range-selection-background-color, rgba(100, 160, 160, 0.4));\n}\n.ag-theme-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart,\n.ag-theme-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1) !important;\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)) !important;\n}\n.ag-theme-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category,\n.ag-theme-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1) !important;\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)) !important;\n}\n.ag-theme-dark .ag-cell-range-selected-1:not(.ag-cell-focus),\n.ag-theme-dark .ag-root:not(.ag-context-menu-open) .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-1:not(.ag-cell-inline-editing) {\n background-color: rgba(100, 160, 160, 0.4);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(100, 160, 160, 0.4)));\n}\n.ag-theme-dark .ag-cell-range-selected-2:not(.ag-cell-focus),\n.ag-theme-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-2 {\n background-color: rgba(100, 160, 160, 0.64);\n background-color: var(--ag-range-selection-background-color-2, rgba(100, 160, 160, 0.64));\n}\n.ag-theme-dark .ag-cell-range-selected-3:not(.ag-cell-focus),\n.ag-theme-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-3 {\n background-color: rgba(100, 160, 160, 0.784);\n background-color: var(--ag-range-selection-background-color-3, rgba(100, 160, 160, 0.784));\n}\n.ag-theme-dark .ag-cell-range-selected-4:not(.ag-cell-focus),\n.ag-theme-dark .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-4 {\n background-color: rgba(100, 160, 160, 0.8704);\n background-color: var(--ag-range-selection-background-color-4, rgba(100, 160, 160, 0.8704));\n}\n.ag-theme-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #ccc;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #ccc;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #ccc;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #ccc;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-dark .ag-ltr .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-dark .ag-ltr .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-dark .ag-ltr .ag-cell-range-single-cell,\n.ag-theme-dark .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-dark .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-dark .ag-rtl .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-dark .ag-rtl .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-dark .ag-rtl .ag-cell-range-single-cell,\n.ag-theme-dark .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n outline: initial;\n}\n.ag-theme-dark .ag-cell.ag-selection-fill-top,\n.ag-theme-dark .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #ccc;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-dark .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #ccc;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n}\n\n.ag-theme-dark .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-dark .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #ccc;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n}\n\n.ag-theme-dark .ag-cell.ag-selection-fill-bottom,\n.ag-theme-dark .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #ccc;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-dark .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #ccc;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n}\n\n.ag-theme-dark .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-dark .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #ccc;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n}\n\n.ag-theme-dark .ag-range-handle, .ag-theme-dark .ag-fill-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #ccc;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-ltr .ag-range-handle, .ag-theme-dark .ag-ltr .ag-fill-handle {\n right: -1px;\n}\n\n.ag-theme-dark .ag-rtl .ag-range-handle, .ag-theme-dark .ag-rtl .ag-fill-handle {\n left: -1px;\n}\n\n.ag-theme-dark .ag-fill-handle {\n cursor: cell;\n}\n.ag-theme-dark .ag-range-handle {\n cursor: nwse-resize;\n}\n.ag-theme-dark .ag-cell-inline-editing {\n border-color: var(--ag-input-focus-border-color) !important;\n}\n.ag-theme-dark .ag-menu {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n}\n.ag-theme-dark .ag-menu-list {\n cursor: default;\n padding: 4px 0;\n}\n.ag-theme-dark .ag-menu-separator {\n height: 9px;\n}\n.ag-theme-dark .ag-menu-separator-part::after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-menu-option-active, .ag-theme-dark .ag-compact-menu-option-active {\n background-color: var(--ag-row-hover-color);\n}\n.ag-theme-dark .ag-menu-option-part, .ag-theme-dark .ag-compact-menu-option-part {\n line-height: 12px;\n padding: 6px 0;\n}\n.ag-theme-dark .ag-menu-option-disabled, .ag-theme-dark .ag-compact-menu-option-disabled {\n opacity: 0.5;\n}\n.ag-theme-dark .ag-menu-option-icon, .ag-theme-dark .ag-compact-menu-option-icon {\n width: 12px;\n}\n.ag-theme-dark .ag-ltr .ag-menu-option-icon, .ag-theme-dark .ag-ltr .ag-compact-menu-option-icon {\n padding-left: 8px;\n}\n\n.ag-theme-dark .ag-rtl .ag-menu-option-icon, .ag-theme-dark .ag-rtl .ag-compact-menu-option-icon {\n padding-right: 8px;\n}\n\n.ag-theme-dark .ag-menu-option-text, .ag-theme-dark .ag-compact-menu-option-text {\n padding-left: 8px;\n padding-right: 8px;\n}\n.ag-theme-dark .ag-ltr .ag-menu-option-shortcut, .ag-theme-dark .ag-ltr .ag-compact-menu-option-shortcut {\n padding-right: 4px;\n}\n\n.ag-theme-dark .ag-rtl .ag-menu-option-shortcut, .ag-theme-dark .ag-rtl .ag-compact-menu-option-shortcut {\n padding-left: 4px;\n}\n\n.ag-theme-dark .ag-menu-option-popup-pointer, .ag-theme-dark .ag-compact-menu-option-popup-pointer {\n padding-right: 4px;\n}\n.ag-theme-dark .ag-tabs {\n min-width: 220px;\n}\n.ag-theme-dark .ag-tabs-header {\n width: 100%;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-dark .ag-tab {\n border-bottom: 0 solid transparent;\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 0;\n flex: none;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-pack: center;\n justify-content: center;\n cursor: pointer;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-tab:focus {\n outline: none;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-tab:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-dark .ag-tab-selected {\n border-bottom-color: #ccc;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)));\n}\n.ag-theme-dark .ag-menu-header {\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-filter-separator {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-menu:not(.ag-tabs) .ag-filter-select {\n min-width: 167px;\n}\n.ag-theme-dark .ag-tabs .ag-filter-select {\n min-width: 206px;\n}\n.ag-theme-dark .ag-filter-select .ag-picker-field-wrapper {\n width: 0;\n}\n.ag-theme-dark .ag-filter-condition-operator {\n height: 17px;\n}\n.ag-theme-dark .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px;\n}\n\n.ag-theme-dark .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px;\n}\n\n.ag-theme-dark .ag-set-filter-select-all {\n padding-top: 6px;\n}\n.ag-theme-dark .ag-set-filter-list, .ag-theme-dark .ag-filter-no-matches {\n height: 120px;\n}\n.ag-theme-dark .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px;\n}\n.ag-theme-dark .ag-filter-to {\n margin-top: 4px;\n}\n.ag-theme-dark .ag-mini-filter {\n margin: 6px 6px;\n}\n.ag-theme-dark .ag-set-filter-item {\n margin: 0px 6px;\n}\n.ag-theme-dark .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px;\n}\n\n.ag-theme-dark .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px;\n}\n\n.ag-theme-dark .ag-filter-apply-panel {\n padding: 6px 6px;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n}\n.ag-theme-dark .ag-filter-apply-panel-button {\n line-height: 1.5;\n}\n.ag-theme-dark .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px;\n}\n\n.ag-theme-dark .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px;\n}\n\n.ag-theme-dark .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px;\n}\n.ag-theme-dark .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px;\n}\n.ag-theme-dark .ag-filter-no-matches {\n padding: 6px 6px;\n}\n.ag-theme-dark .ag-multi-filter-menu-item {\n margin: 4px 0;\n}\n.ag-theme-dark .ag-multi-filter-group-title-bar {\n padding: 8px 4px;\n background-color: transparent;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus {\n outline: none;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-dark .ag-side-bar {\n position: relative;\n}\n.ag-theme-dark .ag-tool-panel-wrapper {\n width: 200px;\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e);\n}\n.ag-theme-dark .ag-side-buttons {\n padding-top: 16px;\n width: 16px;\n position: relative;\n color: #ccc;\n color: var(--ag-foreground-color, #ccc);\n overflow: hidden;\n}\n.ag-theme-dark button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: calc(100% + 1px);\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark button.ag-side-button-button:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-side-button-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-dark .ag-selected .ag-side-button-button {\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e);\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-side-button-icon-wrapper {\n margin-bottom: 3px;\n}\n.ag-theme-dark .ag-ltr .ag-side-bar-left,\n.ag-theme-dark .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n.ag-theme-dark .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-ltr .ag-side-bar-left .ag-side-button-button,\n.ag-theme-dark .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent;\n margin-right: -1px;\n padding-right: 1px;\n}\n.ag-theme-dark .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-dark .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #ccc;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)));\n}\n.ag-theme-dark .ag-rtl .ag-side-bar-left,\n.ag-theme-dark .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n.ag-theme-dark .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-rtl .ag-side-bar-left .ag-side-button-button,\n.ag-theme-dark .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent;\n margin-left: -1px;\n padding-left: 1px;\n}\n.ag-theme-dark .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-dark .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #ccc;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)));\n}\n.ag-theme-dark .ag-filter-toolpanel-header {\n height: 24px;\n}\n.ag-theme-dark .ag-ltr .ag-filter-toolpanel-header, .ag-theme-dark .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px;\n}\n\n.ag-theme-dark .ag-rtl .ag-filter-toolpanel-header, .ag-theme-dark .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px;\n}\n\n.ag-theme-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-dark .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f114\";\n position: absolute;\n}\n.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-left: 4px;\n}\n\n.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-right: 4px;\n}\n\n.ag-theme-dark .ag-filter-toolpanel-group-level-0-header {\n height: 32px;\n}\n.ag-theme-dark .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px;\n}\n.ag-theme-dark .ag-filter-toolpanel-search {\n height: 25px;\n}\n.ag-theme-dark .ag-filter-toolpanel-search-input {\n -webkit-box-flex: 1;\n flex-grow: 1;\n height: 16px;\n}\n.ag-theme-dark .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px;\n}\n\n.ag-theme-dark .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px;\n}\n\n.ag-theme-dark .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n}\n.ag-theme-dark .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px;\n}\n\n.ag-theme-dark .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px;\n}\n\n.ag-theme-dark .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px;\n}\n\n.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px;\n}\n\n.ag-theme-dark .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px;\n}\n\n.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px;\n}\n\n.ag-theme-dark .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px;\n}\n\n.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px;\n}\n\n.ag-theme-dark .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px;\n}\n\n.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px;\n}\n\n.ag-theme-dark .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px;\n}\n\n.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px;\n}\n\n.ag-theme-dark .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px;\n}\n\n.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px;\n}\n\n.ag-theme-dark .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px;\n}\n\n.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px;\n}\n\n.ag-theme-dark .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px;\n}\n\n.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px;\n}\n\n.ag-theme-dark .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px;\n}\n\n.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px;\n}\n\n.ag-theme-dark .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px;\n}\n\n.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px;\n}\n\n.ag-theme-dark .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px;\n}\n.ag-theme-dark .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n margin-top: 4px;\n}\n.ag-theme-dark .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px;\n}\n\n.ag-theme-dark .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px;\n}\n\n.ag-theme-dark .ag-pivot-mode-panel {\n min-height: 25px;\n height: 25px;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-dark .ag-pivot-mode-select {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-dark .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px;\n}\n\n.ag-theme-dark .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px;\n}\n\n.ag-theme-dark .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-column-select-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-dark .ag-column-select-header {\n height: 25px;\n -webkit-box-align: center;\n align-items: center;\n padding: 0 6px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n}\n.ag-theme-dark .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n}\n.ag-theme-dark .ag-column-group-icons,\n.ag-theme-dark .ag-column-select-header-icon {\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-column-select-list .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #ccc;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-column-select-list .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-dark .ag-column-select-list .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-dark .ag-header {\n background-color: #626262;\n background-color: var(--ag-header-background-color, #626262);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-header-row {\n color: #ccc;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)));\n height: 25px;\n}\n.ag-theme-dark .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px;\n}\n\n.ag-theme-dark .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px;\n}\n\n.ag-theme-dark .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px;\n}\n\n.ag-theme-dark .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px;\n}\n\n.ag-theme-dark .ag-header-cell,\n.ag-theme-dark .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px;\n}\n.ag-theme-dark .ag-header-cell.ag-header-cell-moving,\n.ag-theme-dark .ag-header-group-cell.ag-header-cell-moving {\n background-color: #bebebe;\n background-color: var(--ag-header-cell-moving-background-color, #bebebe);\n}\n.ag-theme-dark .ag-keyboard-focus .ag-header-cell:focus {\n outline: none;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-header-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-dark .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-header-group-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-dark .ag-header-icon {\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-header-expand-icon {\n cursor: pointer;\n}\n.ag-theme-dark .ag-ltr .ag-header-expand-icon {\n padding-left: 4px;\n}\n\n.ag-theme-dark .ag-rtl .ag-header-expand-icon {\n padding-right: 4px;\n}\n\n.ag-theme-dark .ag-header-row:not(:first-child) .ag-header-cell,\n.ag-theme-dark .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-header-cell::after,\n.ag-theme-dark .ag-header-group-cell::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n width: 1px;\n height: 100%;\n top: calc(50% - 50%);\n background-color: rgba(169, 169, 169, 0.5);\n background-color: var(--ag-header-column-separator-color, rgba(169, 169, 169, 0.5));\n}\n.ag-theme-dark .ag-ltr .ag-header-cell::after, .ag-theme-dark .ag-ltr .ag-header-group-cell::after {\n right: 0;\n}\n\n.ag-theme-dark .ag-rtl .ag-header-cell::after, .ag-theme-dark .ag-rtl .ag-header-group-cell::after {\n left: 0;\n}\n\n.ag-theme-dark .ag-ltr .ag-header-select-all {\n margin-right: 12px;\n}\n\n.ag-theme-dark .ag-rtl .ag-header-select-all {\n margin-left: 12px;\n}\n\n.ag-theme-dark .ag-ltr .ag-floating-filter-button {\n margin-left: 12px;\n}\n\n.ag-theme-dark .ag-rtl .ag-floating-filter-button {\n margin-right: 12px;\n}\n\n.ag-theme-dark .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 12px;\n padding: 0;\n width: 12px;\n}\n.ag-theme-dark .ag-filter-loading {\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1;\n}\n.ag-theme-dark .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n height: 25px;\n}\n.ag-theme-dark .ag-paging-panel > * {\n margin: 0 12px;\n}\n.ag-theme-dark .ag-paging-button {\n cursor: pointer;\n}\n.ag-theme-dark .ag-paging-button.ag-disabled {\n cursor: default;\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5));\n}\n.ag-theme-dark .ag-keyboard-focus .ag-paging-button:focus {\n outline: none;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-paging-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-dark .ag-paging-button, .ag-theme-dark .ag-paging-description {\n margin: 0 4px;\n}\n.ag-theme-dark .ag-status-bar {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5;\n}\n.ag-theme-dark .ag-status-name-value-value {\n color: #ccc;\n color: var(--ag-foreground-color, #ccc);\n}\n.ag-theme-dark .ag-status-bar-center {\n text-align: center;\n}\n.ag-theme-dark .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px;\n}\n.ag-theme-dark .ag-column-drop-cell {\n background: #403e3e;\n background: var(--ag-chip-background-color, #403e3e);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px;\n border: 1px solid transparent;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-column-drop-cell:focus {\n outline: none;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-column-drop-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 2px;\n left: 2px;\n display: block;\n width: calc(100% - 4px);\n height: calc(100% - 4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-dark .ag-column-drop-cell-text {\n margin: 0 4px;\n}\n.ag-theme-dark .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-column-drop-cell-drag-handle {\n margin-left: 8px;\n}\n.ag-theme-dark .ag-column-drop-cell-ghost {\n opacity: 0.5;\n}\n.ag-theme-dark .ag-column-drop-horizontal {\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e);\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px;\n}\n\n.ag-theme-dark .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px;\n}\n\n.ag-theme-dark .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey);\n}\n\n.ag-theme-dark .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey);\n}\n\n.ag-theme-dark .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-column-drop-horizontal-empty-message {\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5));\n}\n.ag-theme-dark .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px;\n}\n\n.ag-theme-dark .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px;\n}\n\n.ag-theme-dark .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px;\n}\n.ag-theme-dark .ag-column-drop-vertical-cell {\n margin-top: 4px;\n}\n.ag-theme-dark .ag-column-drop-vertical {\n min-height: 50px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n}\n.ag-theme-dark .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none;\n}\n.ag-theme-dark .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px;\n}\n.ag-theme-dark .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5));\n margin-top: 4px;\n}\n.ag-theme-dark .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n height: 70px;\n padding: 0;\n}\n.ag-theme-dark .ag-select-agg-func-virtual-list-item {\n cursor: default;\n padding-left: 8px;\n}\n.ag-theme-dark .ag-select-agg-func-virtual-list-item:hover {\n background-color: #4a708b;\n background-color: var(--ag-selected-row-background-color, #4a708b);\n}\n.ag-theme-dark .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-dark .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-dark .ag-chart-menu {\n border-radius: 0px;\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n}\n.ag-theme-dark .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 0px;\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-chart-menu-icon:hover {\n opacity: 1;\n}\n.ag-theme-dark .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n border-radius: 5px;\n margin: 5px;\n}\n.ag-theme-dark .ag-chart-mini-thumbnail:nth-last-child(3), .ag-theme-dark .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto;\n}\n.ag-theme-dark .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0;\n}\n\n.ag-theme-dark .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0;\n}\n\n.ag-theme-dark .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0;\n}\n\n.ag-theme-dark .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0;\n}\n\n.ag-theme-dark .ag-chart-mini-thumbnail.ag-selected {\n border-color: #ccc;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc)));\n}\n.ag-theme-dark .ag-chart-settings-card-item {\n background: #ccc;\n background: var(--ag-foreground-color, #ccc);\n width: 8px;\n height: 8px;\n border-radius: 4px;\n}\n.ag-theme-dark .ag-chart-settings-card-item.ag-selected {\n background-color: #ccc;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc)));\n}\n.ag-theme-dark .ag-chart-data-column-drag-handle {\n margin-left: 4px;\n}\n.ag-theme-dark .ag-charts-settings-group-title-bar,\n.ag-theme-dark .ag-charts-data-group-title-bar,\n.ag-theme-dark .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n}\n.ag-theme-dark .ag-charts-settings-group-container {\n padding: 4px;\n}\n.ag-theme-dark .ag-charts-data-group-container {\n padding: 3px 6px;\n}\n.ag-theme-dark .ag-charts-data-group-container .ag-charts-data-group-item:not(.ag-charts-format-sub-level-group) {\n height: 20px;\n}\n.ag-theme-dark .ag-charts-data-group-container .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #ccc;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark .ag-charts-data-group-container .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-dark .ag-charts-data-group-container .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-dark .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px;\n}\n.ag-theme-dark .ag-charts-format-top-level-group-item {\n margin: 4px 0;\n}\n.ag-theme-dark .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px;\n}\n.ag-theme-dark .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px;\n}\n.ag-theme-dark .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px;\n}\n.ag-theme-dark .ag-chart-data-section,\n.ag-theme-dark .ag-chart-format-section {\n display: -webkit-box;\n display: flex;\n margin: 0;\n}\n.ag-theme-dark .ag-chart-menu-panel {\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e);\n}\n.ag-theme-dark .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey);\n}\n\n.ag-theme-dark .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey);\n}\n\n.ag-theme-dark .ag-date-time-list-page-title {\n -webkit-box-flex: 1;\n flex-grow: 1;\n text-align: center;\n}\n.ag-theme-dark .ag-date-time-list-page-column-label {\n text-align: center;\n}\n.ag-theme-dark .ag-date-time-list-page-entry {\n text-align: center;\n}\n.ag-theme-dark .ag-checkbox-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-dark .ag-checkbox-input-wrapper input, .ag-theme-dark .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-dark .ag-checkbox-input-wrapper:focus-within, .ag-theme-dark .ag-checkbox-input-wrapper:active {\n outline: none;\n}\n.ag-theme-dark .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-dark .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #ccc;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-dark .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #ccc;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-dark .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #ccc;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc)));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-dark .ag-toggle-button-input-wrapper {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n width: 24px;\n height: 12px;\n background-color: #ccc;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc)));\n border-radius: 6px;\n position: relative;\n -webkit-box-flex: 0;\n flex: none;\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc)));\n}\n.ag-theme-dark .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%;\n}\n.ag-theme-dark .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n}\n.ag-theme-dark .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-dark .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #ccc;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc)));\n border-color: #ccc;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc)));\n}\n.ag-theme-dark .ag-toggle-button-input-wrapper::before {\n content: \" \";\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n background-color: #302e2e;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #302e2e));\n border-radius: 6px;\n -webkit-transition: left 100ms;\n transition: left 100ms;\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc))));\n}\n.ag-theme-dark .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 12px );\n border-color: #ccc;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc)));\n}\n.ag-theme-dark .ag-radio-button-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n border-radius: 12px;\n}\n.ag-theme-dark .ag-radio-button-input-wrapper input, .ag-theme-dark .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-dark .ag-radio-button-input-wrapper:focus-within, .ag-theme-dark .ag-radio-button-input-wrapper:active {\n outline: none;\n}\n.ag-theme-dark .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-dark .ag-radio-button-input-wrapper::after {\n content: \"\\f126\";\n color: #ccc;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-dark .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f127\";\n color: #ccc;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-dark input[class^=ag-][type=range] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible;\n}\n.ag-theme-dark input[class^=ag-][type=range]::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px;\n}\n.ag-theme-dark input[class^=ag-][type=range]::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px;\n}\n.ag-theme-dark input[class^=ag-][type=range]::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px;\n color: transparent;\n width: calc(100% - 2px);\n}\n.ag-theme-dark input[class^=ag-][type=range]::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc));\n border-radius: 12px;\n -webkit-transform: translateY(-4.5px);\n transform: translateY(-4.5px);\n}\n.ag-theme-dark input[class^=ag-][type=range]::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc));\n border-radius: 12px;\n}\n.ag-theme-dark input[class^=ag-][type=range]::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc));\n border-radius: 12px;\n}\n.ag-theme-dark input[class^=ag-][type=range]:focus {\n outline: none;\n}\n.ag-theme-dark input[class^=ag-][type=range]:focus::-webkit-slider-thumb {\n border-color: #ccc;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark input[class^=ag-][type=range]:focus::-ms-thumb {\n border-color: #ccc;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark input[class^=ag-][type=range]:focus::-moz-ag-range-thumb {\n border-color: #ccc;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc));\n}\n.ag-theme-dark input[class^=ag-][type=range]:active::-webkit-slider-runnable-track {\n background-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-dark input[class^=ag-][type=range]:active::-moz-ag-range-track {\n background-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-dark input[class^=ag-][type=range]:active::-ms-track {\n background-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-dark input[class^=ag-][type=range]:disabled {\n opacity: 0.5;\n}\n.ag-theme-dark .ag-icon {\n color: #d6d5d5;\n margin: 1px 1px 2px 1px;\n}\n.ag-theme-dark .ag-icon-tree-closed::before {\n content: \"\\f10b\";\n}\n.ag-theme-dark .ag-icon-tree-open::before {\n content: \"\\f111\";\n}\n.ag-theme-dark .ag-header, .ag-theme-dark .ag-column-drop-cell {\n background-image: none;\n}\n.ag-theme-dark .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px;\n}\n.ag-theme-dark .ag-tabs-body {\n margin: 2px 0;\n}\n.ag-theme-dark .ag-tab-selected {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-bottom-color: transparent;\n}\n.ag-theme-dark .ag-tabs-header {\n background-color: #626262;\n background-color: var(--ag-header-background-color, #626262);\n border-bottom: 1px solid;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-filter .ag-filter-apply-panel {\n -webkit-box-pack: start;\n justify-content: flex-start;\n}\n.ag-theme-dark .ag-menu-option-active {\n background-color: #4a708b;\n background-color: var(--ag-selected-row-background-color, #4a708b);\n}\n.ag-theme-dark .ag-column-drop-cell {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0;\n}\n.ag-theme-dark .ag-column-drop-cell-button .ag-icon {\n border: 1px solid transparent;\n}\n.ag-theme-dark .ag-column-drop-cell-button:hover .ag-icon {\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-dark .ag-panel-title-bar-button-icon {\n font-size: 20px;\n line-height: 20px;\n}\n.ag-theme-dark .ag-menu-option-part {\n padding-top: 4px;\n padding-bottom: 4px;\n}\n.ag-theme-dark .ag-column-drop-vertical-title-bar {\n margin-top: 4px;\n margin-left: 4px;\n}\n.ag-theme-dark .ag-column-drop-vertical-title {\n margin-left: 4px;\n}\n.ag-theme-dark .ag-column-drop-vertical-empty-message {\n margin-left: 24px;\n}\n", ""]); // Exports module.exports = exports; /***/ }), -/* 242 */ +/* 295 */ /***/ (function(module, exports, __webpack_require__) { -var api = __webpack_require__(225); - var content = __webpack_require__(243); +var api = __webpack_require__(278); + var content = __webpack_require__(296); content = content.__esModule ? content.default : content; @@ -48761,24 +57706,24 @@ var update = api(content, options); module.exports = content.locals || {}; /***/ }), -/* 243 */ +/* 296 */ /***/ (function(module, exports, __webpack_require__) { // Imports -var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227); +var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(280); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, ".ag-theme-fresh {\n -webkit-font-smoothing: antialiased;\n color: #000;\n color: var(--ag-foreground-color, #000);\n font-family: \"Helvetica Neue\", sans-serif;\n font-size: 14px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridClassic\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABOsAAsAAAAAJiwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlIAAAReYchjok9TLzIAAANcAAAAQQAAAFZWVlJ+Y21hcAAAA6AAAAHtAAAFgHClDfdnbHlmAAAFkAAACi0AABQQq+8lqmhlYWQAAA/AAAAANAAAADZ2z8SBaGhlYQAAD/QAAAAeAAAAJAfTBChobXR4AAAQFAAAABoAAAEou4L/4mxvY2EAABAwAAAAbwAAAJb7HvWgbWF4cAAAEKAAAAAfAAAAIAFgAHhuYW1lAAAQwAAAATMAAAJS8kTiWnBvc3QAABH0AAABtgAAApcplp2DeJx9k0lyE0EQRX+rZSMPyGDMZMRkRpsh3O5BjSTLltzyQHjBggULNmYBAeFg5ROw5gAEB+AUnIBgyYoDcACCA/Ay1UbGC6tC1VWZP3/+yspSIGlSy+qqUmzuPld9f+/gveZV1fBn/qPrYP/tmz3VDnf4qv6tKQj/qK4FvdCBvgUKXgefK+NhJeyGu+GH8FP4QyGoG3oMekorjFgJc6RUmZrKVdE4tpj1E7VAh8xtt87qgsbcU2ig8+SMiRk445Ke6o7OwNN3np7WQKUM4+wxbzHuauYERK578GeoWcVqrA10ntWENtHYQ0eH6BbeGXzrZI6I6eProy10VNXruK2XRM762SwyK3Ep/1gbvo9894AqHKLa8DfhN75Fsh7am2RKiHgEewaqW9Zwif8U3hRMRGzHa2bR10AmKEx1nZWdLOFk07oN+zO98qwbZUzPqzg88yLqR/a+8+XkOWrtwLUF9iEaRla7kfvkirSDf5KbKvROH/VFX/VdP/VLv3UK6ypeO8Ea3OsnVqZG/Y6jC7ztf1Y76Th3fhz1P2KCcze9NjG+QVlByzaFTqtNyjrCmjp+Ep2GL1CTU68qOSLPm2AdY6yyj0GfLruxxZj2Og/oAeuAeWqxwmxMw37L2V+GyVZDXRe9Wi14LvltWU3tJdV9Zz1vtzxPna/wjThZ5vXZxnsVizGNLA2PylFtHMv4c9SOspmqBqoSeqDmnbXjr6Ag003OMVSS6Ja/gB3vqgUUZOWLnNM5V98pb2rOcbFHBWiOypeces2sk/tos67Y+gsvGGrHAAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMnxi4gDQjSA4A1QYKdAAAAHictdQHTltBFIXh3wXTTEnvvRc6hGp6XQbpiBREOsoqs5O7gZBzPScLIFJG+nw9o+c3b/R8LtAB1OSp1KFap0KO31qttNdr9LTX6/zSvEkXVX0fYo8DjmL0+FirQ+yyz2FU2rO/o6Krm1zlPs80W2GMJeZZZZItxmlpdZEF1phhmg0mmGOKdXaYZZlNtvX7qnav6xkbdGrfbj1Jr+7YRz8DDHKaM5zlHOe5wEUucZkr2u0a17nBTW5xmzvc5Z72f8BDHvGYJzrPkD6HNRvRAzY42Vg54fU5xpbmVye3xls67cLazLQOOje1vjO7vLn9Dzf7D6OZH7Wfnu2Qb7PI0+7amDy3JXlh8/LSVuWVTcpr25I3Ni5vrSV7lv+QfVuUd7Yg721NPtiMfLRpObANObQJ+WRz8tmm5Iuty1fLs3+zWfluy/LDNuXI9AKjUmRWolqQtVZktqJeZL6io8jcRaMga2dB1q6CrN0FWXuKzGP0FmRtFvkmo68ga39B1oGCrIMFWU8VyhJhShVhyhdhShphyhxhSh9hyiFhSiRhyiZhSilhyithSi5hyjBhSjNhyjVhSjhhyjphSj1hyj9h6gSEqScQpu5AmPoEYeoRhKl3EKb+QVj2zbDMTFj7muGCrCNF+56jBSN/AHzNoH4AAAB4nO1Ye2xT1xm/37nEN87D8bUdXwezwLWJDZQCtmNfO4FATIgdQhLWGwhrt0DSGJHHpgaawFRatBIVVrXbHxXTWCiPabMHo9MgSH1IGxJMa6b+sbBJFZVK2/HHVNjI6JZ2k8W97DvHjzyggPrntBufe17fPec73/md3/edcMDhw4f4fs7IcSBLglwuW3mZD+mj+/ZBQtv//vtkhPxuYiIFe2EvijD5T/lPuUVYCQpeRRK8oswyRRZZJokyywQZLrXFxscbNwPf1oh5m65txjzWpuu0PdYGhF9k/LIuWm/czOXm3Mq/whViRfAaMYlu+NkbCeiG7sTZU2TPGz3QrR/vOavdzMmTSTLJFTN51AW1QX3IZOOFsdiFC7GxC41jUJ8rjTVe4Ao47q6O67rBWTk35+Ue41ZyXIHsWgFBsboOArK/EspFmwl42WXAgh1bQtjlgYDorgqUu3nM+T7N5qpx4Y/83VUjyzWyZjY7HGZyW5Qk7ReqCi2qmmpvJ66Ii3yGL/xpZfjifySJmig6HCL5hyjpY/q1ZBJO6jtw2Vm9bjK9luJ6coq4p5UrmKOTALheK9/HdHDldbo1Q5teffLf1aev8zdyKuRU2jJTk3f0ot/XH4YTc/XwPpoevByUH6jFX/Tz0PoQHfTSJN3OWfM/2uwPmvkhk9L14qL38T2IjELOwXEIOskIvLIQDAL+ldvsOEu11+Mlf9O31zyta1A3Pv7ur4uLK8rsvg0+e1kFXIJTtdihX4Y14+N1paWVTk+Fy+dzVVQtqKTDG9gcR/gjOJuAWC3DtUkcV1WOZsPEz8nhlH6ej+rnk7OydAofaEniA620zGV1v5HF8spHsxYghsvdQXcwEAzw/RmLadaMBcmkZmaWoZbT30uxJ2NBS9aCk1kLWlFCJLdw2y5QlVJMFfaK8lG2ShH1CYhy0I0sIYsyH5TFQJCMJvWSJEyp+hi0pPQxlYyyehrrp7AxzeV54Hn+eXqujYDbIRgB2UCBKbAM65PspU8OgwVfpG9WFSxYncElhxmXiAFkLDrAz0+eTejH9eMJ+C4xaVNYOQFdCe6r4p7u2oPQ9wO95GGoH0smp233Lq9wFZyPW43zK1IoYJfskgkBicwGobUQdLsQk17rCuI1CJUg2RXJgMikfyEUUFgJ5UGu9qyNHnpucNvSb9cF6xeZ9D+taPYW1T0WfvzAX0PfXF3UUO17pVX9uv9bT3ZtrYus9D85BFc3N5os9kq5uHY5b1qyyjLvieaDa3Z5GgJLiuFAEQG1wGBy6tcM4W1Bf7zhabujeN2CImN1VZ1/40ub9KO+TqskLZwfaHf+b65FQjwv4UK4FroORg1ZXUNYpm12Jac0QcB4qzxrwE3lJBRR4A5dQdvw/hd/uJ8q+Y0933umoXpdZ/euZ3Zs3ciULWnctbc3VgQboagtFAtVLQl5VvPlvNr84nBLW0nJRs8af/NI85Yz/vg2JWwwKP4eq2RfVBF+qjrUWcOXLlgGhcXzm22FAuEyPMo4px95DT2+VQbRG/SVB4Iq45Qk34/eZ3sq3d6elSV30I/yLDoQ3SI6Fq8gwVqVmC9fDqfTZFIvgSm94dIlrFDxkuxZvziL05zcwmmvqiDT5BI8pCwjH6WSyTT7ISN8WQlOJpMTSUaCJ+/NUKWC7Lovcl/jZK4KPenjlIcYsSLvZSk2n0R3UAZ3Ofr0TKrCBKeQYdFGyLY0p0zF8h3t0JqdjqnD96tovqSaxiytklhas6hwqh15TFXn2rTKLQaARicCuaOq2m1m1PQMi2b46iS/lfGVhIRHQzTYebpHPw7dPWdIDZw8nYmDzlCyJXe/uPsF/y/+n1w1159BpaGMuiwvYs+j4AEL+RkqsdUElQQb6sCDnUGfhxaxC6segXVTOSlgpx95q70+KsbkK0muuxL82KmEvB7yQsRmWxIeibQ2b2rZbcMnEi+qsAARyTxDhdNmCTY1OQ8usFidRgepWFpoL7JbwBpp2dTcGhkJL0FxSzkU2QuXOUhpsdFptToPOpuaghabs8IwjzcTsFQUxSN0XJyptfkozkQru9kAcaPZFPQXWgzznfGmkM3qHHHG406jaHY5lhYSg5nOxFQaCR9FcUuZQAqXOlxmo1BEBUecVluoKe6cb7AU+oMmszHOVjHzvBxBFC9kjCUgLJGs0FciYyE8cfPQYwaUoNctlJPY0eGjV6/iK5kv/Pjl7u6Xu8lvZjXSgvZWN+3i5s2KPZchNz5a5CmwoBYU5E5JeXDseevjmG80fAyuxT7xvR5+/SEBqFYX+2jVMRR//pOYD/O8H5qOVViUAtnEH7nzWz6aSelMNEJjEfrJV12bwsJ2XCIlnAev7bmPYquOKaNQHfuYKv2wtaWza3sNTXJMOZa/L7yKZ7KA7jA9jfAUO4ngzxFb5hw6+T9zpdN3EBY7SDDamwAveBO9vQn9A/2DRC8514ctWOrTX+rDNuzry8YSd1ksYeMWcwEaS9ATZqZOYxF1EWb0CKECemYDflqk8eVKehyZTzSU0+MIU4efHYxu2BAdfFb/bGgw2tAQHRyCCe3NUH00Nti1XYlI0rJ4qH49VjrDEcAafxOlh/TbQ7up9O4hMON3Gz7X3lwmSRGls3swFl0XaspUugbj0fpQDvdR9BMCcjiL2DBMC0iUKTFyo6y2M51Mqfp5FaZ4h5Ygo2qK8l/eVjTewxq4RckteN0KpVQy2Xkurarpc50wha5jvDed7oWwmuHnPE5k9Khhbu39kUIDBAaVWvRHwQKMIBExfOYeyg4mPaFWSuL0BjAHN9p3DlDcHEjx67R3SKUo/adk9eBgbcnFklqaDUxo10mjdA+CyO1kBkIkhiT9tkOE1ZkPMt+VkljyBbwzzMYR85Tk1Tk4IjMwQG9zbGPNFAaL6I6bKQwEBgsb7XHRejXtgalD+d0uyyHgMNvwiLK96zpuNj6dXfff7C10a693d1Lhzm4UViKz8biUxTD3w6PEVGQ+g4GS3nk8VtwJ3BvcGdyX+0LyUAZ+VKXrOSW/v37P4T3r2euR1dR3NGQ/Wb8nj60TWX/oVfACoMhBcvCXCejSTyROa38gsTOZUP50Ks/fA4jjUs5OYxh07XmeKcj+uyKAAH5L9blI3OXTxwZqJiZqBtrRCX8Ii/UP6Y0NFi8YqJ2YqB2A16bxTUbp6BhBpchP9DG8sJzPc8koYp/QO4pIYwS8nrRoO+f2kUz4wNdjwDU2Z0wj0CCjJSOR7UvyMYorI0HG4ZPaFf294YvwNrmiXYHgEJam9YrTnaVHABXTdiI4aXM+LnBzMa4D+dtumxsXLATalo0KQn6Jt/vz3t5gw96sr6dfCKxNAooH8LgyFbufPCEIHTNCgA7BKrQaDNvQn1MH2yHYBBemDuqm0cVvMxhaUaJjhivvEATiWG4y3fmpyWPCnO80ef54r0zL7FHgV7MnablXjTufL8cRcTgc1VuKw//fJvfa5L+BscYKAAAAeJxjYGRgYABi/jvPp8Xz23xl4GZ+ARSI4ny8rwFG///2/xvzZ+ZPQJUcDExAkgEAoUMP6XicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AIAnloHAgAAeJxjYGBgYH5Ba/z/G+3M/f+NgQ4AAPv8MfAAAHicY2AAAgmGIIYshhaGC4wijCGMPYz7GF8xGTGFMVUwTWC6wGzGPIf5BwsfiwZLCcsOlgssL1gnsB5iE2EzYGtim8K2jZ2HXYvdhX0Z+w72fxwRHAUcszhWcGzjOMJxieMZxxfOOi4O0iEAtgsblgB4nGNgZGBg8GLIYeBhAAEmIOYCQgaG/2A+AwAbuAHZAHicfZC9TsMwFIVP+odoBaoEYmAyCwtS+rPRtVKzd+ieJnaaKo2D41bqznPwBDxHn4OnYObEeCkStSXnu9899w4BMMQJAZoT4Ma9zWnhitUvt0n3njvkJ89dDBB67tG/eu7jBQvPA9zhjRuCzjXNI949t3CLD89t+k/PHfLJcxcP+PLco//23McqGHoe4DlQcRaZPJ0XcV3nyVJm+yI2Z+6sWElT57oUk3B85iNZShNbmYr1UdSHbGqtEsronVjo0sqi0KIyeisTG26srWajkfI+TPQOMTJEMMiRYo6Cdc2bI8ESkr29c+ZC7v/OihuMY40SAhP+9/GFfMR86WZiWH5Tzqxx5FvjwKkprYVirZjR2JEWbneTLng1TeV6W5qEPsTGTVWYYcSr/uRDprjpB8WrbRMAeJxtkmdv2zAURX1iyVbstEnTNt17D7VN994z/RUMRctEJFIgKY/8+rJxGiBA36dzHx7uu3xgZ6mzqEHn/7XFEl0SUnr0yVhmwJAVjnCUVdY4xjrHOcFJNjjFac5wlnOc5wIXucRlrnCVa1znBje5xW3ucJd73CfnAQ95xCaPecJTnvGcF7zkFa95w1ve8Z4PfOQTn/nCV77xnR/85Bdb/O4MRVk6VYqgrekJ5+zUd4WXPSmMVFUqx8KFNTlWcmfbzvI9UMXGQUObQgXlam1EUOsH7dbsT65IW1mXNzoK14+irY0fSGuCEzKoIpG2mafSWe+TQnmZqVkjomexrOYq95Xw4+EB5ZvdyL2RruLKdKSdD0npdJOWzrZNEkdCUqlR6FXaxN39yopCmzKrxUzXelcltTJtFrMulFGzkBhr1NDYkIuqslNVpE10Ud1Gm7TRExuyxqmJtq1fc9HM5tttCNbkdjRaPdwwqdPlOCReTNTA19EuL+zU7OPfWMMF7o1lC46pQzzNenBKHb5l1prFKwb/IN9EUOJQBDQWwxSPpGLMDtvM4lcoqGlpmDNil0mn8wcxorJdAAA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-fresh .ag-icon {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-fresh .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-fresh .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-fresh .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-fresh .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-fresh .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-fresh .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-fresh .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-fresh .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-fresh .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-fresh .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-fresh .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-fresh .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-fresh .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-fresh .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-fresh .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-fresh .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-fresh .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-fresh .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-fresh .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-fresh .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-fresh .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-fresh .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-fresh .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-fresh .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-fresh .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-fresh .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-fresh .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-fresh .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-fresh .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-fresh .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-fresh .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-fresh .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-fresh .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-fresh .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-fresh .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-fresh .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-fresh .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-fresh .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-fresh .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-fresh .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-fresh .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-fresh .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-fresh .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-fresh .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-fresh .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-fresh .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-fresh .ag-root-wrapper {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-fresh [class^='ag-'], .ag-theme-fresh [class^='ag-']:focus, .ag-theme-fresh [class^='ag-']:after, .ag-theme-fresh [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-fresh [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-fresh .ag-checkbox .ag-input-wrapper,\n .ag-theme-fresh .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-fresh .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-fresh .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-fresh .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px; }\n .ag-theme-fresh .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px; }\n .ag-theme-fresh input[class^='ag-'] {\n margin: 0;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-fresh textarea[class^='ag-'],\n .ag-theme-fresh select[class^='ag-'] {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-fresh input[class^='ag-']:not([type]),\n .ag-theme-fresh input[class^='ag-'][type='text'],\n .ag-theme-fresh input[class^='ag-'][type='number'],\n .ag-theme-fresh input[class^='ag-'][type='tel'],\n .ag-theme-fresh input[class^='ag-'][type='date'],\n .ag-theme-fresh input[class^='ag-'][type='datetime-local'],\n .ag-theme-fresh textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #000;\n border-color: var(--ag-input-border-color, #000); }\n .ag-theme-fresh input[class^='ag-']:not([type]):disabled,\n .ag-theme-fresh input[class^='ag-'][type='text']:disabled,\n .ag-theme-fresh input[class^='ag-'][type='number']:disabled,\n .ag-theme-fresh input[class^='ag-'][type='tel']:disabled,\n .ag-theme-fresh input[class^='ag-'][type='date']:disabled,\n .ag-theme-fresh input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-fresh textarea[class^='ag-']:disabled {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n background-color: #ebebeb;\n background-color: var(--ag-input-disabled-background-color, #ebebeb);\n border-color: rgba(0, 0, 0, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(0, 0, 0, 0.3)); }\n .ag-theme-fresh input[class^='ag-']:not([type]):focus,\n .ag-theme-fresh input[class^='ag-'][type='text']:focus,\n .ag-theme-fresh input[class^='ag-'][type='number']:focus,\n .ag-theme-fresh input[class^='ag-'][type='tel']:focus,\n .ag-theme-fresh input[class^='ag-'][type='date']:focus,\n .ag-theme-fresh input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-fresh textarea[class^='ag-']:focus {\n outline: none;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-fresh input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-fresh input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-fresh input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-fresh .ag-drag-handle {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-list-item, .ag-theme-fresh .ag-virtual-list-item {\n height: 20px; }\n .ag-theme-fresh .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-select-list {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-fresh .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-fresh .ag-list-item.ag-active-item {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-fresh .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-fresh .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-fresh .ag-select .ag-picker-field-wrapper {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n min-height: 20px;\n cursor: default; }\n .ag-theme-fresh .ag-select:not(.ag-cell-editor) {\n height: 20px; }\n .ag-theme-fresh .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-fresh .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-fresh .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-fresh .ag-rich-select {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-fresh .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 162.5px; }\n .ag-theme-fresh .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-fresh .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 20px; }\n .ag-theme-fresh .ag-rich-select-virtual-list-item:hover {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-fresh .ag-rich-select-row {\n padding-left: 12px; }\n .ag-theme-fresh .ag-rich-select-row-selected {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5); }\n .ag-theme-fresh .ag-row-drag,\n .ag-theme-fresh .ag-selection-checkbox,\n .ag-theme-fresh .ag-group-expanded,\n .ag-theme-fresh .ag-group-contracted {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-ltr .ag-row-drag, .ag-theme-fresh .ag-ltr .ag-selection-checkbox, .ag-theme-fresh .ag-ltr .ag-group-expanded, .ag-theme-fresh .ag-ltr .ag-group-contracted {\n margin-right: 12px; }\n .ag-theme-fresh .ag-rtl .ag-row-drag, .ag-theme-fresh .ag-rtl .ag-selection-checkbox, .ag-theme-fresh .ag-rtl .ag-group-expanded, .ag-theme-fresh .ag-rtl .ag-group-contracted {\n margin-left: 12px; }\n .ag-theme-fresh .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 23px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-fresh .ag-group-expanded,\n .ag-theme-fresh .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-fresh .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-fresh .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-fresh .ag-group-title-bar {\n background-color: #ececec;\n background-color: var(--ag-subheader-background-color, #ececec);\n padding: 4px; }\n .ag-theme-fresh .ag-group-toolbar {\n padding: 4px; }\n .ag-theme-fresh .ag-disabled-group-title-bar, .ag-theme-fresh .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-fresh .group-item {\n margin: 2px 0; }\n .ag-theme-fresh .ag-label {\n white-space: nowrap; }\n .ag-theme-fresh .ag-ltr .ag-label {\n margin-right: 4px; }\n .ag-theme-fresh .ag-rtl .ag-label {\n margin-left: 4px; }\n .ag-theme-fresh .ag-label-align-top .ag-label {\n margin-bottom: 2px; }\n .ag-theme-fresh .ag-ltr .ag-slider-field, .ag-theme-fresh .ag-ltr .ag-angle-select-field {\n margin-right: 8px; }\n .ag-theme-fresh .ag-rtl .ag-slider-field, .ag-theme-fresh .ag-rtl .ag-angle-select-field {\n margin-left: 8px; }\n .ag-theme-fresh .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-fresh .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #000;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 5px; }\n .ag-theme-fresh .ag-picker-field-button {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-fresh .ag-color-picker .ag-picker-field-display {\n height: 12px; }\n .ag-theme-fresh .ag-color-panel {\n padding: 4px; }\n .ag-theme-fresh .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-fresh .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-fresh .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-fresh .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-fresh .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-fresh .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-fresh .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-fresh .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-fresh .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-fresh .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-fresh .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-fresh .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-fresh.ag-dnd-ghost {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px !important;\n line-height: 25px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px); }\n .ag-theme-fresh .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #000;\n color: var(--ag-foreground-color, #000); }\n .ag-theme-fresh .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3); }\n .ag-dragging-range-handle .ag-theme-fresh .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-fresh .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-fresh .ag-dialog {\n border-radius: 0px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-panel {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-fresh .ag-panel-title-bar {\n background-color: var(--ag-header-background-color);\n color: #000;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)));\n height: 25px;\n padding: 4px 12px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px; }\n .ag-theme-fresh .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px; }\n .ag-theme-fresh .ag-tooltip {\n background-color: var(--ag-header-background-color);\n color: #000;\n color: var(--ag-foreground-color, #000);\n padding: 4px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n transition: opacity 1s; }\n .ag-theme-fresh .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px; }\n .ag-theme-fresh .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-fresh .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 6px; }\n .ag-theme-fresh .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 6px; }\n .ag-theme-fresh .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-column-select-column-group:not(:last-child),\n .ag-theme-fresh .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px; }\n .ag-theme-fresh .ag-column-select-column-readonly,\n .ag-theme-fresh .ag-column-select-column-group-readonly {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n pointer-events: none; }\n .ag-theme-fresh .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 20px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 20px; }\n .ag-theme-fresh .ag-column-select-list {\n padding: 6px 6px; }\n .ag-theme-fresh .ag-rtl {\n text-align: right; }\n .ag-theme-fresh .ag-root-wrapper {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 36px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 36px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-1 {\n padding-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-1 {\n padding-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 60px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 60px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-2 {\n padding-left: 48px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-2 {\n padding-right: 48px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 84px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 84px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-3 {\n padding-left: 72px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-3 {\n padding-right: 72px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 108px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 108px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-4 {\n padding-left: 96px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-4 {\n padding-right: 96px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 132px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 132px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-5 {\n padding-left: 120px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-5 {\n padding-right: 120px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 156px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 156px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-6 {\n padding-left: 144px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-6 {\n padding-right: 144px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 180px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 180px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-7 {\n padding-left: 168px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-7 {\n padding-right: 168px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 204px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 204px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-8 {\n padding-left: 192px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-8 {\n padding-right: 192px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 228px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 228px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-9 {\n padding-left: 216px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-9 {\n padding-right: 216px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 252px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 252px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-10 {\n padding-left: 240px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-10 {\n padding-right: 240px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 276px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 276px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-11 {\n padding-left: 264px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-11 {\n padding-right: 264px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 300px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 300px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-12 {\n padding-left: 288px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-12 {\n padding-right: 288px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 324px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 324px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-13 {\n padding-left: 312px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-13 {\n padding-right: 312px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 348px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 348px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-14 {\n padding-left: 336px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-14 {\n padding-right: 336px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 372px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 372px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-15 {\n padding-left: 360px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-15 {\n padding-right: 360px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 396px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 396px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-16 {\n padding-left: 384px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-16 {\n padding-right: 384px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 420px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 420px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-17 {\n padding-left: 408px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-17 {\n padding-right: 408px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 444px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 444px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-18 {\n padding-left: 432px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-18 {\n padding-right: 432px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 468px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 468px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-19 {\n padding-left: 456px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-19 {\n padding-right: 456px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-fresh .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-fresh .ag-value-change-delta-up {\n color: darkgreen;\n color: var(--ag-value-change-delta-up-color, darkgreen); }\n .ag-theme-fresh .ag-value-change-delta-down {\n color: darkred;\n color: var(--ag-value-change-delta-down-color, darkred); }\n .ag-theme-fresh .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-fresh .ag-value-change-value-highlight {\n background-color: #cec;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec);\n transition: background-color 0.1s; }\n .ag-theme-fresh .ag-cell-data-changed {\n background-color: #cec !important;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec) !important; }\n .ag-theme-fresh .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-fresh .ag-cell-highlight {\n background-color: rgba(136, 255, 136, 0.4) !important;\n background-color: var(--ag-range-selection-highlight-color, rgba(136, 255, 136, 0.4)) !important; }\n .ag-theme-fresh .ag-row {\n height: 25px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n color: #000;\n color: var(--ag-data-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-row-highlight-above::after, .ag-theme-fresh .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #000;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n left: 1px; }\n .ag-theme-fresh .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-fresh .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-fresh .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-fresh .ag-row-odd {\n background-color: #f6f6f6;\n background-color: var(--ag-odd-row-background-color, #f6f6f6); }\n .ag-theme-fresh .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-fresh .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-fresh .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-fresh .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-fresh .ag-cell {\n border: 1px solid transparent;\n line-height: 23px;\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-fresh .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-fresh .ag-row-dragging {\n cursor: move; }\n .ag-theme-fresh .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-fresh .ag-cell-inline-editing {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 25px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-fresh .ag-popup-editor {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n padding: 0; }\n .ag-theme-fresh .ag-large-text-input {\n height: auto;\n padding: 12px; }\n .ag-theme-fresh .ag-details-row {\n padding: 20px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-fresh .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66)); }\n .ag-theme-fresh .ag-overlay-loading-center {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px; }\n .ag-theme-fresh .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-fresh .ag-loading {\n padding-left: 12px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-fresh .ag-loading-icon {\n padding-right: 12px; }\n .ag-theme-fresh .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-fresh .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-ltr .ag-cell {\n border-right: dotted darkgrey; }\n .ag-theme-fresh .ag-rtl .ag-cell {\n border-left: dotted darkgrey; }\n .ag-theme-fresh .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-fresh .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-fresh .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-row-selected {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5); }\n .ag-theme-fresh .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(0, 0, 0, 0.2)); }\n .ag-theme-fresh .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1);\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)); }\n .ag-theme-fresh .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)); }\n .ag-theme-fresh .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(0, 0, 0, 0.2))); }\n .ag-theme-fresh .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(0, 0, 0, 0.36)); }\n .ag-theme-fresh .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(0, 0, 0, 0.488)); }\n .ag-theme-fresh .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(0, 0, 0, 0.5904)); }\n .ag-theme-fresh .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #000;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #000;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-fresh .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-fresh .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-fresh .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-fresh .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-fresh .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n outline: initial; }\n .ag-theme-fresh .ag-cell.ag-selection-fill-top,\n .ag-theme-fresh .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #000;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-fresh .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-fresh .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-cell.ag-selection-fill-bottom,\n .ag-theme-fresh .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #000;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-fresh .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-fresh .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-fill-handle, .ag-theme-fresh .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #000;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-ltr .ag-fill-handle, .ag-theme-fresh .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-fresh .ag-rtl .ag-fill-handle, .ag-theme-fresh .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-fresh .ag-fill-handle {\n cursor: cell; }\n .ag-theme-fresh .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-fresh .ag-cell-inline-editing {\n border-color: var(--ag-input-focus-border-color) !important; }\n .ag-theme-fresh .ag-menu {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n padding: 0; }\n .ag-theme-fresh .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-fresh .ag-menu-option-part {\n padding-top: 6px;\n padding-bottom: 6px;\n line-height: 12px; }\n .ag-theme-fresh .ag-menu-option-active {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-fresh .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-fresh .ag-menu-option-text {\n margin-left: 4px; }\n .ag-theme-fresh .ag-menu-option-icon {\n padding-left: 8px;\n padding-right: 4px;\n min-width: 20px; }\n .ag-theme-fresh .ag-menu-option-shortcut {\n padding-left: 8px; }\n .ag-theme-fresh .ag-menu-separator {\n height: 8px; }\n .ag-theme-fresh .ag-menu-separator-cell:after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-menu-option-popup-pointer {\n width: 20px;\n text-align: center; }\n .ag-theme-fresh .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-fresh .ag-tab {\n border-bottom: 0 solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer; }\n .ag-theme-fresh .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-tab-selected {\n border-bottom-color: #000;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-menu-header {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-fresh .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px; }\n .ag-theme-fresh .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px; }\n .ag-theme-fresh .ag-set-filter-select-all {\n padding-top: 6px; }\n .ag-theme-fresh .ag-set-filter-list {\n height: 120px; }\n .ag-theme-fresh .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px; }\n .ag-theme-fresh .ag-filter-to {\n margin-top: 4px; }\n .ag-theme-fresh .ag-mini-filter {\n margin: 6px 6px;\n margin-bottom: 0; }\n .ag-theme-fresh .ag-set-filter-item {\n margin: 0px 6px; }\n .ag-theme-fresh .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px; }\n .ag-theme-fresh .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px; }\n .ag-theme-fresh .ag-filter-header-container {\n padding-bottom: 6px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-fresh .ag-filter-apply-panel {\n padding: 6px 6px;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-fresh .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-fresh .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px; }\n .ag-theme-fresh .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px; }\n .ag-theme-fresh .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-fresh .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px; }\n .ag-theme-fresh .ag-filter-no-matches {\n margin: 6px 6px; }\n .ag-theme-fresh .ag-side-bar {\n position: relative; }\n .ag-theme-fresh .ag-tool-panel-wrapper {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-fresh .ag-side-buttons {\n padding-top: 16px;\n width: 16px;\n position: relative;\n color: #000;\n color: var(--ag-foreground-color, #000);\n overflow: hidden; }\n .ag-theme-fresh button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: calc(100% + 1px);\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-selected .ag-side-button-button {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-fresh .ag-ltr .ag-side-bar-left,\n .ag-theme-fresh .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-fresh .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-fresh .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent;\n margin-right: -1px;\n padding-right: 1px; }\n .ag-theme-fresh .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-fresh .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #000;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-rtl .ag-side-bar-left,\n .ag-theme-fresh .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-fresh .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-fresh .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent;\n margin-left: -1px;\n padding-left: 1px; }\n .ag-theme-fresh .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-fresh .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #000;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-filter-toolpanel-header {\n height: 24px; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-header, .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-header, .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px; }\n .ag-theme-fresh .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 4px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 4px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-0-header {\n height: 32px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px; }\n .ag-theme-fresh .ag-filter-toolpanel-search {\n height: 25px; }\n .ag-theme-fresh .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 16px; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px; }\n .ag-theme-fresh .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px; }\n .ag-theme-fresh .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n padding-top: 4px; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px; }\n .ag-theme-fresh .ag-pivot-mode-panel {\n height: 25px;\n display: flex; }\n .ag-theme-fresh .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-fresh .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px; }\n .ag-theme-fresh .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px; }\n .ag-theme-fresh .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-column-select-header {\n height: 25px;\n align-items: center;\n padding: 0 6px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-fresh .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-fresh .ag-column-group-icons,\n .ag-theme-fresh .ag-column-select-header-icon {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-header {\n background-color: var(--ag-header-background-color);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-header-row {\n color: #000;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-header-row {\n height: 25px; }\n .ag-theme-fresh .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-fresh .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-fresh .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-fresh .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-fresh .ag-header-cell,\n .ag-theme-fresh .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px; }\n .ag-theme-fresh .ag-header-cell.ag-header-cell-moving,\n .ag-theme-fresh .ag-header-group-cell.ag-header-cell-moving {\n background-color: #bebebe;\n background-color: var(--ag-header-cell-moving-background-color, #bebebe); }\n .ag-theme-fresh .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-header-icon {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-fresh .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-fresh .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-fresh .ag-header-row:not(:first-child) .ag-header-cell,\n .ag-theme-fresh .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-header-cell::after,\n .ag-theme-fresh .ag-header-group-cell::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n width: 1px;\n height: 100%;\n top: calc(50% - 50%);\n background-color: rgba(169, 169, 169, 0.5);\n background-color: var(--ag-header-column-separator-color, rgba(169, 169, 169, 0.5)); }\n .ag-theme-fresh .ag-ltr .ag-header-cell::after, .ag-theme-fresh .ag-ltr .ag-header-group-cell::after {\n right: 0; }\n .ag-theme-fresh .ag-rtl .ag-header-cell::after, .ag-theme-fresh .ag-rtl .ag-header-group-cell::after {\n left: 0; }\n .ag-theme-fresh .ag-ltr .ag-header-select-all {\n margin-right: 12px; }\n .ag-theme-fresh .ag-rtl .ag-header-select-all {\n margin-left: 12px; }\n .ag-theme-fresh .ag-ltr .ag-floating-filter-button {\n margin-left: 12px; }\n .ag-theme-fresh .ag-rtl .ag-floating-filter-button {\n margin-right: 12px; }\n .ag-theme-fresh .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 12px;\n padding: 0;\n width: 12px; }\n .ag-theme-fresh .ag-filter-loading {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-fresh .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px; }\n .ag-theme-fresh .ag-paging-panel > * {\n margin: 0 12px; }\n .ag-theme-fresh .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 12px; }\n .ag-theme-fresh .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-fresh .ag-paging-button-wrapper.ag-disabled {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n cursor: default; }\n .ag-theme-fresh .ag-paging-button-wrapper, .ag-theme-fresh .ag-paging-description {\n margin: 0 4px; }\n .ag-theme-fresh .ag-status-bar {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5; }\n .ag-theme-fresh .ag-status-name-value-value {\n color: #000;\n color: var(--ag-foreground-color, #000); }\n .ag-theme-fresh .ag-status-bar-center {\n text-align: center; }\n .ag-theme-fresh .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px; }\n .ag-theme-fresh .ag-column-drop-cell {\n background: var(--ag-chip-background-color);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px; }\n .ag-theme-fresh .ag-column-drop-cell-text {\n margin: 0 4px; }\n .ag-theme-fresh .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-column-drop-cell-drag-handle {\n margin-left: 8px; }\n .ag-theme-fresh .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-fresh .ag-column-drop-horizontal {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px; }\n .ag-theme-fresh .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px; }\n .ag-theme-fresh .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-column-drop-horizontal-empty-message {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5)); }\n .ag-theme-fresh .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px; }\n .ag-theme-fresh .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px; }\n .ag-theme-fresh .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px; }\n .ag-theme-fresh .ag-column-drop-vertical-cell {\n margin-top: 4px; }\n .ag-theme-fresh .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-fresh .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none; }\n .ag-theme-fresh .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px; }\n .ag-theme-fresh .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-fresh .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n margin-top: 4px; }\n .ag-theme-fresh .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n height: 70px;\n padding: 0; }\n .ag-theme-fresh .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 20px;\n padding-left: 8px; }\n .ag-theme-fresh .ag-select-agg-func-virtual-list-item:hover {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5); }\n .ag-theme-fresh .ag-chart-menu {\n border-radius: 0px;\n background: #FFF;\n background: var(--ag-background-color, #FFF); }\n .ag-theme-fresh .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 0px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-fresh .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-fresh .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-fresh .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-fresh .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-fresh .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-fresh .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-fresh .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-fresh .ag-chart-mini-thumbnail.ag-selected {\n border-color: #000;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-chart-settings-card-item {\n background: #000;\n background: var(--ag-foreground-color, #000);\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-fresh .ag-chart-settings-card-item.ag-selected {\n background-color: #000;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-chart-data-column-drag-handle {\n margin-left: 4px; }\n .ag-theme-fresh .ag-charts-settings-group-title-bar,\n .ag-theme-fresh .ag-charts-data-group-title-bar,\n .ag-theme-fresh .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-fresh .ag-charts-settings-group-container {\n padding: 4px; }\n .ag-theme-fresh .ag-charts-data-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-fresh .ag-charts-data-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-fresh .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px; }\n .ag-theme-fresh .ag-charts-format-top-level-group-item {\n margin: 4px 0; }\n .ag-theme-fresh .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-fresh .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-fresh .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px; }\n .ag-theme-fresh .ag-chart-data-section,\n .ag-theme-fresh .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-fresh .ag-chart-menu-panel {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-fresh .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-fresh .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-fresh .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-fresh .ag-checkbox-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-fresh .ag-checkbox-input-wrapper input, .ag-theme-fresh .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-fresh .ag-checkbox-input-wrapper:focus-within, .ag-theme-fresh .ag-checkbox-input-wrapper:active {\n outline: none; }\n .ag-theme-fresh .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-fresh .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #000;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-fresh .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #000;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-fresh .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #000;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-fresh .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 24px;\n height: 12px;\n background-color: #000;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)));\n border-radius: 6px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-fresh .ag-toggle-button-input-wrapper:focus-within {\n outline: none; }\n .ag-theme-fresh .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-fresh .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #000;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)));\n border-color: #000;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n background-color: #FFF;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #FFF));\n border-radius: 6px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)))); }\n .ag-theme-fresh .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 12px);\n border-color: #000;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-radio-button-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 12px; }\n .ag-theme-fresh .ag-radio-button-input-wrapper input, .ag-theme-fresh .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-fresh .ag-radio-button-input-wrapper:focus-within, .ag-theme-fresh .ag-radio-button-input-wrapper:active {\n outline: none; }\n .ag-theme-fresh .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-fresh .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #000;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-fresh .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #000;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-fresh input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-fresh input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px; }\n .ag-theme-fresh input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px; }\n .ag-theme-fresh input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-fresh input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px;\n -webkit-transform: translateY(-4.5px);\n transform: translateY(-4.5px); }\n .ag-theme-fresh input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px; }\n .ag-theme-fresh input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px; }\n .ag-theme-fresh input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-fresh input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh input[class^='ag-'][type='range']:focus::-ms-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh input[class^='ag-'][type='range']:active::-ms-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-fresh .ag-icon {\n color: #333; }\n .ag-theme-fresh .ag-icon-tree-closed::before {\n content: \"\\f10b\"; }\n .ag-theme-fresh .ag-icon-tree-open::before {\n content: \"\\f10f\"; }\n .ag-theme-fresh .ag-header, .ag-theme-fresh .ag-column-drop-cell {\n background-image: linear-gradient(white, lightgrey); }\n .ag-theme-fresh .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px; }\n .ag-theme-fresh .ag-tabs-body {\n margin: 2px 0; }\n .ag-theme-fresh .ag-icon {\n margin: 1px 1px 2px 1px; }\n .ag-theme-fresh .ag-tab-selected {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-bottom-color: transparent; }\n .ag-theme-fresh .ag-tabs-header {\n background-color: var(--ag-header-background-color);\n border-bottom: 1px solid;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-filter .ag-filter-apply-panel {\n justify-content: flex-start; }\n .ag-theme-fresh .ag-menu-option-active {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5); }\n .ag-theme-fresh .ag-column-drop-cell {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0; }\n .ag-theme-fresh .ag-column-drop-cell-button .ag-icon {\n border: 1px solid transparent; }\n .ag-theme-fresh .ag-column-drop-cell-button:hover .ag-icon {\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-panel-title-bar-button-icon {\n font-size: 20px;\n line-height: 20px; }\n .ag-theme-fresh .ag-menu-option-part {\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-fresh .ag-column-drop-vertical-title-bar {\n margin-top: 4px;\n margin-left: 4px; }\n .ag-theme-fresh .ag-column-drop-vertical-title {\n margin-left: 4px; }\n .ag-theme-fresh .ag-column-drop-vertical-empty-message {\n margin-left: 24px; }\n\n", ""]); +exports.push([module.i, ".ag-theme-fresh {\n -webkit-font-smoothing: antialiased;\n color: #000;\n color: var(--ag-foreground-color, #000);\n font-family: \"Helvetica Neue\", sans-serif;\n font-size: 14px;\n line-height: normal;\n}\n@font-face {\n font-family: \"agGridClassic\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABXwAAsAAAAAKrgAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAmMAAAR2Zoxou09TLzIAAANsAAAAQQAAAFZWVlMSY21hcAAAA7AAAAIbAAAFnIlT7KJnbHlmAAAFzAAADBkAABg4HeN0mGhlYWQAABHoAAAANAAAADZ2z8SBaGhlYQAAEhwAAAAeAAAAJAfTBCxobXR4AAASPAAAABgAAAE4yyH/7GxvY2EAABJUAAAAdgAAAJ5JCULobWF4cAAAEswAAAAfAAAAIAFkAKpuYW1lAAAS7AAAATMAAAJS8kTiWnBvc3QAABQgAAABzQAAArBhTs2TeJx9lMtOU1EUhv/DaREoAlG8pCIiGi+oiMrxXHpoy6WH1tbEgTEOnGBMjAlxxHP4AD4BQ5/AB3DgE/gADhw6Nn5r9WCFAey03Xtd/vXvf62NAklTWlNTYzvF4KVm9vcOPqquioZ/5v9/H+x/eL+niaMTvor/TiioTGtGy3qtA30LZoKD4HBsPqyHr8J34efwS/hLIVFLWiW6pqesWAnfkVJlaijXmMaxxew34BOymmq59RyMqu7pqqfL1IzJ6Tniip7xmQOncJyOtolKWYbZ4XvAuqfZUyJy3Qc/g80m1gqKLKJJrnlNgp4Q01Sb/Cb+89TcoXaEv8BXwK6KpcW+rQtwsoyKq9rVGz3Bbzc1lKzMSfnE2vVz5Kc1NDmKaoHToJZhr8LgyN6gakLGY9AzorZKRVd0k+wGOB3Q2p694dnLRCZwS3WDnd0zges08Zle6K1X3S1zOq7pUIFV2I/shePlenjM2gZrQOwjOIys1p8H1IrUx1+jV4X29UmH+qrv+qGf+q0/OqOL1En8Dtug75yqzQQKnozu4m39s9pdx5mBk1HHIya5ecPVifH1Sg2tWo2bmTop+whr6vFT8LT4Lmxy+lGhRuR1rdNV1ibnmOiz5XQ2WdOudI8pmPUJ7vss1HWHvi064nAOc7S+CqLthvyuuG5N8Ba8b6auvbA5P9lbsH7XmdVr/EbcMHOdnuO9jsWQRpYlz8phbxjr+HNYj6oZqwVYresuPpuxvr+OLpVucZ8hk4QIexl9n6/bMMjKlzpPD419u+zYJY+LPSvgP0FUvvDUtbOZLuBm8zH4C3G+c6UAeJxjYGSazTiBgZWBgamKaQ8DA0MPhGZ8wGDIyAQUZWBlZsAKAtJcUxgOMOh+NGJ+AeRGMX9i4ALSjCA5AOaCCwgAAAB4nLXUB1IbQRCF4V+BLMA22eQcBQaTcxAiHwJnCgcKZ87hs/kefQL8Rt0+AK7yVn3bO1Or3ZlavQaqgJzMSB6ytWR0RSar2UxlPkd9ZT7Pb40L1JLVdZErbrizhft7zRa55Jpby1RGf4+M7i7QwxjLGh2yxAE7lFnlXDN7rLPPLkdsssEJK2yzxjFnbFHilAv9Pq0irzVWU6P31mklDXpiI0084jEttNJGOx100kW33tRLH/0MMMgQw4wwyjgTTDLFtHZSZJY5njHPgs7PNVrUIqt52HH4wPvTsXSwU149X97TjnePNje02e2147Ot0unFPzzsPxyFdMr9itEZ6Yu6tNvLsCQvwoG8DDvyKpTldViVN+Fc3ob0b3gX9uQqrMt12Jf3YVc+hCP5GDblU9iQm3Ait2FFPodt+RLW5Gs4lm8h7f172JIfoSQ/w6ncBX1Ay7iUF8s6Us25lC/Lu5Qxq3Ipe1btSLXGkWqtI9U6R6r1LmXSGhypFlz6ktboSLXJkWqzU3awoBRhQXnCnjglC2txyhjW6pQ2rM0pd1i7UwKxDqcsYp1OqcS6nPKJPXVKKtbtlFmsxym9WK9TjrE+p0Rj/U7ZxgacUo4NOuUdG3JKPjbs1AOwEadugI069QVszKlDYONOvQKbcKkv2qRLebApp96BTTv1FGzGqa9gRac+g806dRxszlXuCepC2LyrPHPBsfgHpKymyQB4nO1Ye2wUxxnfmfXt3t57d+92zxycvXf4FkNico+99QMMGOOzcWzTnIMJaQ04GMWYRDEESJqktAElJErSShFVqUmAqj0XmlQFI+XRBxKpGleRGqePNKnyKn+0Sdq4pHXS6uRb+s3eww8ooPSfVu3Zu/P6Zuabb34z3+9bClHwo5P0IMVRFFJkVvEpIq3QSWN4717Un7v/9dfxAfzT8fERtBftBRFT/n36faoSChqr6jKr8oqZ6ApvJjKvmAmroHNdqbGxlnWIXgdpap2RW9cCaZdhkPpUF8J0JdcFVS1dlzblu1LFOdfTj1FWKLAqBw8fRt9+th/1ob7+Z47jXc9uRX3G01ufyX1YlMcTeIKym/KgC2gD+uCJljOjqTNnUqNnWkbRqmJutOUMZaGoiwas6wNKpMKUSi2hllKURQnVII1PNKK4EgsiH+91IVoJMZCRoCYJTREU58NVcV+YhpTenhOV+lCoXsEfwUupV3Iej9/vwRd4Wc59N51GHen0SHc3DtWF8Mfwgv+cG17012U+x/N+P4//wsvGqPF2JoOOGZth2bP0WgzrKSoSnlbOMkcnFsF6RZnebioRKik1MUOdAWPi74kT59fSHxSVKCp180xdXjRsP1t1EB1dRM3VRb02XWhFU66oyO+N06jzKloYzgzZ0lnzX9vsV5r5KpOS9cKi76G3AjqslJ+iAHgyh2i9AjEs/Pm8EsySUCMq/pOxqf42I4cax8Ze/oHdXu6WomuikrscnUPHG6DBeAktHxtrdDqDgUh5KBoNlVfND5LhGXOOQ/QhmI0FvLphbTJFVfnAbPDQc1J03DhNNxmnM7OS7Aj8UEcGfqiT5KmC7h8UbLX02qyFAMe+sBbW4lqcHgwRi4Hl8hYkljMtQyxnvDJi/vIWFAoWnChYUAQJHn8E23aGqDRCUUV9mugmc5U86BPnFS0MN4XCK7Sm8HEND2cMRwZNpo1R1DFijKbxsFnOQvk4VGap0l3wAP0AOdscgu1gOQQ3go4mkbDHmDBfxsQeJMALb59VRAIU8za/OEXfSf+Z8oB1FlCt1Jepp2DoCOykZYZF6LCGQEFGlhqQWOV14XCopkxLNOI4saWXCUXUGhSGDt4giiX1RhSTZGLgEFRriWQsSMcJPmqQWoOJuWNBXOiU71OBJDmI4WZK6tFGsj9enxu5MGzPUhq6S/Qd7La7LEanqusqTqp6y6jRhB7BiLZ4foeNTZwQ9Hpkr8dmcfoVUV4o2pzWMqvXLc93yJUSg60u2ykhJC3gnR7OZWWtbgcv2QWPN8ALFZLg5602J1tmcQcFxm4RBLtTsC1bshjT2Gq3WrCGWZvbweA4jWyCFf/RuudBC65Vp141lXlkfOpR+p7flHN87mu/dVQERasQqKzyhbSId74qcG6b0+dNxCqXSH6/ze1yl1dLbnuVYHfZy3mHLLh4K8OKSk2V6PT5fR6b3S2ITs7O0SxrYcUFT/zwR5ydsbFOm4X7Nee2ci7uF27O5hGo/+/df/XeFf34QdOP83FgC+TgfufYM/3G08bT/ehe7MpNQuEo2tIPomVz9rrtqvusQ2skkYzHpAq0ApNtk3xeN5Jhe1woFFmKWAKEiJa48vZcf0s7x1q8bl70LFtpczFOq1v0dXY7bJzgFco29JRxPNRcybBj9w66nHbJI/o3bnQLFovHwS+44163T3BxHLPvi4yV4d2mTf4X1vjZeAPxelfy3k8YjquxhtFMZtr3vEzrVDkVpZbB/LqcjEuyJLvAoQM7RMkVSAuHwKerYg1WGTaIZEmXGWJp+EuCgGl1FeSRkoisaHr4vqEN1Xc0aqsqXcYva9pVW+OS2uv3/SH5+WW25kT0sc7052Jf2LhlfWPd0tjG3eiNdS0uQQoq9obraNeiG4Sym9r3L7890hxfZEf7bBilLYwrYLzN1G7QYq3Nt0l++8r5Ni5R1Rhb+9CNxuForyjLFfPi3YHptcjgQxdRSVgLWYdJRwq6JiFP6iS9qDS5ldSqyHIUJnIyiOhoiqyga8/9D371fqLkLbu+cldzYmVv3+13bV6/1lTW0XL73oGUDa1Ftq5kKlm1KBlZRvvodPuDezq6HI61keWx9gPtN5+MtW7QaxlGj20VZamyvPbWRLK3nnbOX4ys9nntXiuLqTx3M3nODuBSEGmICuJVLeqLa2mTx2ToQWC9m0ay3d0FWTwF/J02oxI+zAOhVVkZrUhjz0sv1WazeMJwoEmj+dw5KBBxR4FfnJ3FowJUxTSb14HdFB90lbwCHGgkk8ma/8BC/lUOHctkxjMm8Tp2aQIqWQrrPgtnW6GqqGrqesJ9TDIHXKtA60oPH9YUFPZBLJF/quBBx4HVgY2A4ZGUsCMz3dyNOgvTmerQg2kwXyadhSSbxqlsTkij493AndLp/xg95uxtVZiPIxKdsXgqnc5dMDc3O2Nn8z7jGL3e9BkykD0SoqJtJ/Je4iSuR8dO5OPAk4Ro4oufXvyU/hv9VypBDeZPB+MmdB08txrR4aCDc5bztS4UxFDRiIhb16IRkoUmcv+yZjORk+MS6aQm1CgRM+WDuNgM5AEa9aQawV+q83oX1R6o62y/sWOnF351rbZyAWEelzHlAa+gtbUF9s8XxADnx+XVVskmCUis67ixvbPuQO0iEBd8yCZZF/ux084FRDGwP9DWpgneQDlTBoMgodzWWkfGhZk62w/DTKSw0xyglfO4tJhVYOYFWtuSXjFwINDaGuB4T8hfbcWMh8xkqnSg9jCIC24WW6v9IQ/H2ojggYDoTba1BuYxgjWmuTxcq7mKmef2EJymCvPmZOF4wKUJcQLcnHBMYPMgWojrmhpmfTh1eM/hN96AV6aU+cajfX2P9uEfz6okmdzzfaTJ9IEzY9zoNUberBnUIx3ucFm/cuz90bup6HDtEfR26r3oU7VPXSUAzzWm3rnhCIg/8F4qCmnJh0zHaWaEhgoPfWjqJ3RT/snmIzEShxX9+2dZm25+toAlkovvymu7753UDUf0YZRIvUuUvtrasoW1PQkmOaIfKX0veRzOpIXsMDmN6FbzJKJY8YLNn8MA/SvKOf0NxuRvMhoe6EcqUvsHBvqNN403+wfwqe1QA7ntxkPboQ7athd4wEWwxYeUl1pIxQkPICfMQ5xXJXFVHvBMSQs5s/EYyZLYeik5jqZvBt5NTufkwbuHmtasaRq62/h491BTc3PT0G40nnsuuaopNbRlk14ny4vbtFWrodBbW+eXF9MfgvBu48LunUR4527kgW5rPsk9t1iW6/TevqFU08pkW76wZai1aVWyhPsmehB2252PViFEjcvkpoSoldxq27KZkbRxOo0maX+uHw+nR8j992/2RaU4GUoozMthVg3r5DrGE72nsul09lQvmgT3NzaQzQ6g2nTex5QwpgArqKVWXB5lhOSYMGsAn6pZIPIm7DL/Dc881OR0i8QBkC8nczCXu3Mfwdy+EXpl7kUc5OV/OBuGhhocZx1msmM8dx63yJegD1/I5OGHU3DBv+Dn0TLHjH5OnMp8iZfnYND09vjxORjEM/BTDVImKDwEQpUELR4CIdaElJe0hEyiTFrQ5MMlpLiL6DlogqVO37TlPAAFfr1bLo+Umwkuzvf1EuHePhDW62ZjudrkYZfDsmyqSGArmYAm34oiIuHpNShhho2XhfPDQ0WNzhd1fGT1roO7Vpuva9bS2Nxc6LJ613T8dbTgS1Wdg0fR8P7v9aMtxtH+E7mf49TJfCh2YqSE40HAsZOSCA8DWlC6oyyFT71xAPDz6WgIt4aixuiO+vHx+h3d4MDfQguNt8iXLrRw/o6G8fGGHejJaXzjYTI6sMAR/E1jFA8bp0v30DBgH5NvOzzhF2gSdeS2zW3DeepBrwLSODpnTA4RgtKRlyi0ZegUwRUHATuiM7nXjFf2nEUv4NdyryFtN+Sm9WolO0uOACiW2wbgJNUlThGmUlQP3P2Sdy6nqECkrsAokjGZlmIlpsB4obXAE0gP1qyTEcEDioTyBSmGb2LZnhn0oYcV2U6G2QBcgDjnHtbLhuDpIS4e6MEGhukEiZ4ZNKCHZbH/Opdr6luuiAtSutcVefVSmY7Zo6Dvz56k41I1pj65DkaE4WBU1QnD/xPnjHQ0AAAAeJxjYGRgYADiY81JvPH8Nl8ZuJlfAAWiOB/va4DR/7/9/8b8mfkTUCUHAxOQZAAAhKEPOXicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AMAnl4HBgAAeJxjYGBgYH5Bb/z/Gy3NZqADAAB/FDOneJxjYAACCYYghiyGFoYLjGKMYYx9jAcY3zCZMEUwVTFHsJix+LEcYDViLWK9wWbC5sWWwraB7Qu7BXsAewaHAIcTxxSODZxMnCKcZpw9nKs4T3A+4nLhCuOaw/WNm4/bgtuNO4Q7ibuAu4V7Eo8M6RAAslkbZAAAeJxjYGRgYPBjmMfAwwACTEDMBYQMDP/BfAYAIQYCDwB4nH2QvU7DMBSFT/qHaAWqBGJgMgsLUvqz0bVSs3foniZ2miqNg+NW6s5z8AQ8R5+Dp2DmxHgpErUl57vfPfcOATDECQGaE+DGvc1p4YrVL7dJ95475CfPXQwQeu7Rv3ru4wULzwPc4Y0bgs41zSPePbdwiw/PbfpPzx3yyXMXD/jy3KP/9tzHKhh6HuA5UHEWmTydF3Fd58lSZvsiNmfurFhJU+e6FJNwfOYjWUoTW5mK9VHUh2xqrRLK6J1Y6NLKotCiMnorExturK1mo5HyPkz0DjEyRDDIkWKOgnXNmyPBEpK9vXPmQu7/zoobjGONEgIT/vfxhXzEfOlmYlh+U86sceRb48CpKa2FYq2Y0diRFm53ky54NU3leluahD7Exk1VmGHEq/7kQ6a46QfFq20TAHicbZIHb9swEIX9xZKt2GmTpm269x5q6+6990h/A0PRMhGZFEjKdvLry9pBgQA9gIf3Dod37w5sLbUW0Wv9PzZZok1CSocuGcv06LPCAQ6yyhqHWOcwRzjKBsc4zglOcorTnOEs5zjPBS5yictc4SrXuM4NbnKL2+Tc4S73GHCfBzzkEY95wlOe8ZwXvOQVr3nDW97xng985BOf+cJXvvGdH/zkF5v8bvVFWTpViqCt6Qjn7NS3hZcdKYxUVSpHwoU1OVJye8vO8jlQxca/gjaFCsqNtRFBrf8rN2avc0Xayrq81pG4biTN2PietCY4IYMqEmnrnVQ6631b+kkaXz5ICuVlqmbRQHee80GmZrWIs4pltaNyXwk/akfUGeoqjk+H2vmQlE7XaelsU3fnOSrFxpBUahg6lTbRT7eyotCmzMZipsd6VyVjZZos+l8wo2YhMdaovrEhF1Vlp6pI66iiuvOcD9q1NmmtJzZktVMTbRu/5qKozbeaEKzJ7XC4ur9gUqfLUUi8mKieH0fZvLBTswf/2usv4LwtW+CmTkI823pwSu2/c9aYxTYIShyKgMZimOKRVIzYZotZ/CMFYxpqdpgwZLfV+gPpZLiDAAAA\") format(\"woff\");\n font-weight: normal;\n font-style: normal;\n}\n.ag-theme-fresh .ag-icon {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n.ag-theme-fresh .ag-icon-aggregation::before {\n content: \"\\f101\";\n}\n.ag-theme-fresh .ag-icon-arrows::before {\n content: \"\\f102\";\n}\n.ag-theme-fresh .ag-icon-asc::before {\n content: \"\\f103\";\n}\n.ag-theme-fresh .ag-icon-cancel::before {\n content: \"\\f104\";\n}\n.ag-theme-fresh .ag-icon-chart::before {\n content: \"\\f105\";\n}\n.ag-theme-fresh .ag-icon-color-picker::before {\n content: \"\\f109\";\n}\n.ag-theme-fresh .ag-icon-columns::before {\n content: \"\\f10a\";\n}\n.ag-theme-fresh .ag-icon-contracted::before {\n content: \"\\f10b\";\n}\n.ag-theme-fresh .ag-icon-copy::before {\n content: \"\\f10c\";\n}\n.ag-theme-fresh .ag-icon-cross::before {\n content: \"\\f10d\";\n}\n.ag-theme-fresh .ag-icon-csv::before {\n content: \"\\f10e\";\n}\n.ag-theme-fresh .ag-icon-desc::before {\n content: \"\\f10f\";\n}\n.ag-theme-fresh .ag-icon-excel::before {\n content: \"\\f110\";\n}\n.ag-theme-fresh .ag-icon-expanded::before {\n content: \"\\f111\";\n}\n.ag-theme-fresh .ag-icon-eye-slash::before {\n content: \"\\f112\";\n}\n.ag-theme-fresh .ag-icon-eye::before {\n content: \"\\f113\";\n}\n.ag-theme-fresh .ag-icon-filter::before {\n content: \"\\f114\";\n}\n.ag-theme-fresh .ag-icon-first::before {\n content: \"\\f115\";\n}\n.ag-theme-fresh .ag-icon-grip::before {\n content: \"\\f116\";\n}\n.ag-theme-fresh .ag-icon-group::before {\n content: \"\\f117\";\n}\n.ag-theme-fresh .ag-icon-last::before {\n content: \"\\f118\";\n}\n.ag-theme-fresh .ag-icon-left::before {\n content: \"\\f119\";\n}\n.ag-theme-fresh .ag-icon-linked::before {\n content: \"\\f11a\";\n}\n.ag-theme-fresh .ag-icon-loading::before {\n content: \"\\f11b\";\n}\n.ag-theme-fresh .ag-icon-maximize::before {\n content: \"\\f11c\";\n}\n.ag-theme-fresh .ag-icon-menu::before {\n content: \"\\f11d\";\n}\n.ag-theme-fresh .ag-icon-minimize::before {\n content: \"\\f11e\";\n}\n.ag-theme-fresh .ag-icon-next::before {\n content: \"\\f11f\";\n}\n.ag-theme-fresh .ag-icon-none::before {\n content: \"\\f120\";\n}\n.ag-theme-fresh .ag-icon-not-allowed::before {\n content: \"\\f121\";\n}\n.ag-theme-fresh .ag-icon-paste::before {\n content: \"\\f122\";\n}\n.ag-theme-fresh .ag-icon-pin::before {\n content: \"\\f123\";\n}\n.ag-theme-fresh .ag-icon-pivot::before {\n content: \"\\f124\";\n}\n.ag-theme-fresh .ag-icon-previous::before {\n content: \"\\f125\";\n}\n.ag-theme-fresh .ag-icon-right::before {\n content: \"\\f128\";\n}\n.ag-theme-fresh .ag-icon-save::before {\n content: \"\\f129\";\n}\n.ag-theme-fresh .ag-icon-small-down::before {\n content: \"\\f12a\";\n}\n.ag-theme-fresh .ag-icon-small-left::before {\n content: \"\\f12b\";\n}\n.ag-theme-fresh .ag-icon-small-right::before {\n content: \"\\f12c\";\n}\n.ag-theme-fresh .ag-icon-small-up::before {\n content: \"\\f12d\";\n}\n.ag-theme-fresh .ag-icon-tick::before {\n content: \"\\f12e\";\n}\n.ag-theme-fresh .ag-icon-tree-closed::before {\n content: \"\\f12f\";\n}\n.ag-theme-fresh .ag-icon-tree-indeterminate::before {\n content: \"\\f130\";\n}\n.ag-theme-fresh .ag-icon-tree-open::before {\n content: \"\\f131\";\n}\n.ag-theme-fresh .ag-icon-unlinked::before {\n content: \"\\f132\";\n}\n.ag-theme-fresh .ag-icon-row-drag::before {\n content: \"\\f116\";\n}\n.ag-theme-fresh .ag-left-arrow::before {\n content: \"\\f119\";\n}\n.ag-theme-fresh .ag-right-arrow::before {\n content: \"\\f128\";\n}\n.ag-theme-fresh .ag-root-wrapper {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n}\n.ag-theme-fresh [class^=ag-], .ag-theme-fresh [class^=ag-]:focus, .ag-theme-fresh [class^=ag-]:after, .ag-theme-fresh [class^=ag-]:before {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n outline: none;\n}\n.ag-theme-fresh [class^=ag-]::-ms-clear {\n display: none;\n}\n.ag-theme-fresh .ag-checkbox .ag-input-wrapper,\n.ag-theme-fresh .ag-radio-button .ag-input-wrapper {\n overflow: visible;\n}\n.ag-theme-fresh .ag-range-field .ag-input-wrapper {\n height: 100%;\n}\n.ag-theme-fresh .ag-toggle-button {\n -webkit-box-flex: 0;\n flex: none;\n width: unset;\n min-width: unset;\n}\n.ag-theme-fresh .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px;\n}\n\n.ag-theme-fresh input[class^=ag-] {\n margin: 0;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n}\n.ag-theme-fresh textarea[class^=ag-],\n.ag-theme-fresh select[class^=ag-] {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n}\n.ag-theme-fresh input[class^=ag-]:not([type]),\n.ag-theme-fresh input[class^=ag-][type=text],\n.ag-theme-fresh input[class^=ag-][type=number],\n.ag-theme-fresh input[class^=ag-][type=tel],\n.ag-theme-fresh input[class^=ag-][type=date],\n.ag-theme-fresh input[class^=ag-][type=datetime-local],\n.ag-theme-fresh textarea[class^=ag-] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #000;\n border-color: var(--ag-input-border-color, #000);\n}\n.ag-theme-fresh input[class^=ag-]:not([type]):disabled,\n.ag-theme-fresh input[class^=ag-][type=text]:disabled,\n.ag-theme-fresh input[class^=ag-][type=number]:disabled,\n.ag-theme-fresh input[class^=ag-][type=tel]:disabled,\n.ag-theme-fresh input[class^=ag-][type=date]:disabled,\n.ag-theme-fresh input[class^=ag-][type=datetime-local]:disabled,\n.ag-theme-fresh textarea[class^=ag-]:disabled {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n background-color: #ebebeb;\n background-color: var(--ag-input-disabled-background-color, #ebebeb);\n border-color: rgba(0, 0, 0, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(0, 0, 0, 0.3));\n}\n.ag-theme-fresh input[class^=ag-]:not([type]):focus,\n.ag-theme-fresh input[class^=ag-][type=text]:focus,\n.ag-theme-fresh input[class^=ag-][type=number]:focus,\n.ag-theme-fresh input[class^=ag-][type=tel]:focus,\n.ag-theme-fresh input[class^=ag-][type=date]:focus,\n.ag-theme-fresh input[class^=ag-][type=datetime-local]:focus,\n.ag-theme-fresh textarea[class^=ag-]:focus {\n outline: none;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-fresh input[class^=ag-]:not([type]):invalid,\n.ag-theme-fresh input[class^=ag-][type=text]:invalid,\n.ag-theme-fresh input[class^=ag-][type=number]:invalid,\n.ag-theme-fresh input[class^=ag-][type=tel]:invalid,\n.ag-theme-fresh input[class^=ag-][type=date]:invalid,\n.ag-theme-fresh input[class^=ag-][type=datetime-local]:invalid,\n.ag-theme-fresh textarea[class^=ag-]:invalid {\n border-width: 2px;\n border-style: solid;\n border-color: var(--ag-input-border-color-invalid);\n}\n.ag-theme-fresh input[class^=ag-][type=number] {\n -moz-appearance: textfield;\n}\n.ag-theme-fresh input[class^=ag-][type=number]::-webkit-outer-spin-button, .ag-theme-fresh input[class^=ag-][type=number]::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n}\n.ag-theme-fresh input[class^=ag-][type=range] {\n padding: 0;\n}\n.ag-theme-fresh .ag-drag-handle {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-list-item, .ag-theme-fresh .ag-virtual-list-item {\n height: 20px;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-fresh .ag-select-list {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n overflow-y: auto;\n overflow-x: hidden;\n}\n.ag-theme-fresh .ag-list-item {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-fresh .ag-list-item.ag-active-item {\n background-color: var(--ag-row-hover-color);\n}\n.ag-theme-fresh .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n user-select: none;\n}\n.ag-theme-fresh .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n.ag-theme-fresh .ag-select .ag-picker-field-wrapper {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n min-height: 20px;\n cursor: default;\n}\n.ag-theme-fresh .ag-select.ag-disabled .ag-picker-field-wrapper:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-fresh .ag-select:not(.ag-cell-editor) {\n height: 20px;\n}\n.ag-theme-fresh .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-fresh .ag-select .ag-picker-field-icon {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-fresh .ag-select.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-fresh .ag-rich-select {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n}\n.ag-theme-fresh .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 162.5px;\n}\n.ag-theme-fresh .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n}\n.ag-theme-fresh .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 20px;\n}\n.ag-theme-fresh .ag-rich-select-virtual-list-item:hover {\n background-color: var(--ag-row-hover-color);\n}\n.ag-theme-fresh .ag-rich-select-row {\n padding-left: 12px;\n}\n.ag-theme-fresh .ag-rich-select-row-selected {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5);\n}\n.ag-theme-fresh .ag-row-drag,\n.ag-theme-fresh .ag-selection-checkbox,\n.ag-theme-fresh .ag-group-expanded,\n.ag-theme-fresh .ag-group-contracted {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-ltr .ag-row-drag, .ag-theme-fresh .ag-ltr .ag-selection-checkbox, .ag-theme-fresh .ag-ltr .ag-group-expanded, .ag-theme-fresh .ag-ltr .ag-group-contracted {\n margin-right: 12px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-drag, .ag-theme-fresh .ag-rtl .ag-selection-checkbox, .ag-theme-fresh .ag-rtl .ag-group-expanded, .ag-theme-fresh .ag-rtl .ag-group-contracted {\n margin-left: 12px;\n}\n\n.ag-theme-fresh .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: min(var(--ag-row-height, 23px), 23px);\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-fresh .ag-group-expanded,\n.ag-theme-fresh .ag-group-contracted {\n cursor: pointer;\n}\n.ag-theme-fresh .ag-group-title-bar-icon {\n cursor: pointer;\n -webkit-box-flex: 0;\n flex: none;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-ltr .ag-group-child-count {\n margin-left: 2px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-group-child-count {\n margin-right: 2px;\n}\n\n.ag-theme-fresh .ag-group-title-bar {\n background-color: #ececec;\n background-color: var(--ag-subheader-background-color, #ececec);\n padding: 4px;\n}\n.ag-theme-fresh .ag-group-toolbar {\n padding: 4px;\n}\n.ag-theme-fresh .ag-disabled-group-title-bar, .ag-theme-fresh .ag-disabled-group-container {\n opacity: 0.5;\n}\n.ag-theme-fresh .group-item {\n margin: 2px 0;\n}\n.ag-theme-fresh .ag-label {\n white-space: nowrap;\n}\n.ag-theme-fresh .ag-ltr .ag-label {\n margin-right: 4px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-label {\n margin-left: 4px;\n}\n\n.ag-theme-fresh .ag-label-align-top .ag-label {\n margin-bottom: 2px;\n}\n.ag-theme-fresh .ag-ltr .ag-slider-field, .ag-theme-fresh .ag-ltr .ag-angle-select-field {\n margin-right: 8px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-slider-field, .ag-theme-fresh .ag-rtl .ag-angle-select-field {\n margin-left: 8px;\n}\n\n.ag-theme-fresh .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n}\n.ag-theme-fresh .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #000;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 5px;\n}\n.ag-theme-fresh .ag-picker-field-button {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-dialog.ag-color-dialog {\n border-radius: 5px;\n}\n.ag-theme-fresh .ag-color-picker .ag-picker-field-display {\n height: 12px;\n}\n.ag-theme-fresh .ag-color-panel {\n padding: 4px;\n}\n.ag-theme-fresh .ag-spectrum-color {\n background-color: red;\n border-radius: 2px;\n}\n.ag-theme-fresh .ag-spectrum-tools {\n padding: 10px;\n}\n.ag-theme-fresh .ag-spectrum-sat {\n background-image: -webkit-gradient(linear, left top, right top, from(white), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0));\n}\n.ag-theme-fresh .ag-spectrum-val {\n background-image: -webkit-gradient(linear, left bottom, left top, from(black), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0));\n}\n.ag-theme-fresh .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n -webkit-box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n}\n.ag-theme-fresh .ag-spectrum-hue-background {\n border-radius: 2px;\n}\n.ag-theme-fresh .ag-spectrum-alpha-background {\n border-radius: 2px;\n}\n.ag-theme-fresh .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px;\n}\n.ag-theme-fresh .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n -webkit-box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n}\n.ag-theme-fresh .ag-recent-color {\n margin: 0 3px;\n}\n.ag-theme-fresh .ag-recent-color:first-child {\n margin-left: 0;\n}\n.ag-theme-fresh .ag-recent-color:last-child {\n margin-right: 0;\n}\n.ag-theme-fresh.ag-dnd-ghost {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px !important;\n line-height: 25px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px);\n}\n.ag-theme-fresh .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #000;\n color: var(--ag-foreground-color, #000);\n}\n.ag-theme-fresh .ag-popup-child:not(.ag-tooltip-custom) {\n -webkit-box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3);\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3);\n}\n.ag-dragging-range-handle .ag-theme-fresh .ag-dialog, .ag-dragging-fill-handle .ag-theme-fresh .ag-dialog {\n opacity: 0.7;\n pointer-events: none;\n}\n.ag-theme-fresh .ag-dialog {\n border-radius: 0px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-panel {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n}\n.ag-theme-fresh .ag-panel-title-bar {\n background-color: var(--ag-header-background-color);\n color: #000;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)));\n height: 25px;\n padding: 4px 12px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px;\n}\n\n.ag-theme-fresh .ag-tooltip {\n background-color: var(--ag-header-background-color);\n color: #000;\n color: var(--ag-foreground-color, #000);\n padding: 4px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n white-space: normal;\n}\n.ag-theme-fresh .ag-tooltip.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-fresh .ag-tooltip-custom {\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n}\n.ag-theme-fresh .ag-tooltip-custom.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-fresh .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px;\n}\n\n.ag-theme-fresh .ag-column-select-header-icon {\n cursor: pointer;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-column-select-header-icon:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-fresh .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 8px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 8px;\n}\n\n.ag-theme-fresh .ag-keyboard-focus .ag-column-select-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-column-select-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-fresh .ag-column-select-column-group:not(:last-child),\n.ag-theme-fresh .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px;\n}\n.ag-theme-fresh .ag-column-select-column-readonly,\n.ag-theme-fresh .ag-column-select-column-group-readonly {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n pointer-events: none;\n}\n.ag-theme-fresh .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 20px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 20px;\n}\n\n.ag-theme-fresh .ag-column-select-virtual-list-viewport {\n padding: 3px 0px;\n}\n.ag-theme-fresh .ag-column-select-virtual-list-item {\n padding: 0 6px;\n}\n.ag-theme-fresh .ag-rtl {\n text-align: right;\n}\n.ag-theme-fresh .ag-root-wrapper {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 36px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 36px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-1 {\n padding-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-1 {\n padding-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-1 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-1 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 60px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 60px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-2 {\n padding-left: 48px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-2 {\n padding-right: 48px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-2 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-2 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 84px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 84px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-3 {\n padding-left: 72px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-3 {\n padding-right: 72px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-3 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-3 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 108px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 108px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-4 {\n padding-left: 96px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-4 {\n padding-right: 96px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-4 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-4 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 132px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 132px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-5 {\n padding-left: 120px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-5 {\n padding-right: 120px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-5 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-5 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 156px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 156px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-6 {\n padding-left: 144px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-6 {\n padding-right: 144px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-6 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-6 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 180px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 180px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-7 {\n padding-left: 168px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-7 {\n padding-right: 168px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-7 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-7 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 204px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 204px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-8 {\n padding-left: 192px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-8 {\n padding-right: 192px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-8 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-8 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 228px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 228px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-9 {\n padding-left: 216px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-9 {\n padding-right: 216px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-9 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-9 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 252px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 252px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-10 {\n padding-left: 240px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-10 {\n padding-right: 240px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-10 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-10 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 276px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 276px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-11 {\n padding-left: 264px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-11 {\n padding-right: 264px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-11 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-11 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 300px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 300px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-12 {\n padding-left: 288px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-12 {\n padding-right: 288px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-12 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-12 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 324px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 324px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-13 {\n padding-left: 312px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-13 {\n padding-right: 312px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-13 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-13 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 348px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 348px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-14 {\n padding-left: 336px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-14 {\n padding-right: 336px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-14 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-14 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 372px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 372px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-15 {\n padding-left: 360px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-15 {\n padding-right: 360px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-15 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-15 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 396px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 396px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-16 {\n padding-left: 384px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-16 {\n padding-right: 384px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-16 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-16 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 420px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 420px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-17 {\n padding-left: 408px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-17 {\n padding-right: 408px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-17 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-17 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 444px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 444px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-18 {\n padding-left: 432px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-18 {\n padding-right: 432px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-18 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-18 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 468px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 468px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-19 {\n padding-left: 456px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-19 {\n padding-right: 456px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-19 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-19 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-left: 492px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-right: 492px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-20 {\n padding-left: 480px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-20 {\n padding-right: 480px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-20 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-20 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-left: 516px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-right: 516px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-21 {\n padding-left: 504px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-21 {\n padding-right: 504px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-21 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-21 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-left: 540px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-right: 540px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-22 {\n padding-left: 528px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-22 {\n padding-right: 528px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-22 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-22 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-left: 564px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-right: 564px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-23 {\n padding-left: 552px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-23 {\n padding-right: 552px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-23 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-23 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-left: 588px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-right: 588px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-24 {\n padding-left: 576px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-24 {\n padding-right: 576px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-24 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-24 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-left: 612px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-right: 612px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-25 {\n padding-left: 600px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-25 {\n padding-right: 600px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-25 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-25 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-left: 636px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-right: 636px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-26 {\n padding-left: 624px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-26 {\n padding-right: 624px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-26 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-26 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-left: 660px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-right: 660px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-27 {\n padding-left: 648px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-27 {\n padding-right: 648px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-27 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-27 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-left: 684px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-right: 684px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-28 {\n padding-left: 672px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-28 {\n padding-right: 672px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-28 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-28 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-left: 708px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-right: 708px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-29 {\n padding-left: 696px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-29 {\n padding-right: 696px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-29 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-29 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-left: 732px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-right: 732px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-30 {\n padding-left: 720px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-30 {\n padding-right: 720px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-30 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-30 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-left: 756px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-right: 756px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-31 {\n padding-left: 744px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-31 {\n padding-right: 744px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-31 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-31 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-left: 780px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-right: 780px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-32 {\n padding-left: 768px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-32 {\n padding-right: 768px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-32 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-32 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-left: 804px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-right: 804px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-33 {\n padding-left: 792px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-33 {\n padding-right: 792px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-33 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-33 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-left: 828px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-right: 828px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-34 {\n padding-left: 816px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-34 {\n padding-right: 816px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-34 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-34 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-left: 852px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-right: 852px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-35 {\n padding-left: 840px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-35 {\n padding-right: 840px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-35 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-35 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-left: 876px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-right: 876px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-36 {\n padding-left: 864px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-36 {\n padding-right: 864px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-36 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-36 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-left: 900px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-right: 900px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-37 {\n padding-left: 888px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-37 {\n padding-right: 888px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-37 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-37 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-left: 924px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-right: 924px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-38 {\n padding-left: 912px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-38 {\n padding-right: 912px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-38 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-38 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-left: 948px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-right: 948px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-39 {\n padding-left: 936px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-39 {\n padding-right: 936px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-39 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-39 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-left: 972px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-right: 972px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-40 {\n padding-left: 960px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-40 {\n padding-right: 960px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-40 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-40 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-left: 996px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-right: 996px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-41 {\n padding-left: 984px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-41 {\n padding-right: 984px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-41 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-41 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-left: 1020px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-right: 1020px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-42 {\n padding-left: 1008px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-42 {\n padding-right: 1008px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-42 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-42 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-left: 1044px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-right: 1044px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-43 {\n padding-left: 1032px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-43 {\n padding-right: 1032px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-43 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-43 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-left: 1068px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-right: 1068px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-44 {\n padding-left: 1056px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-44 {\n padding-right: 1056px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-44 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-44 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-left: 1092px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-right: 1092px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-45 {\n padding-left: 1080px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-45 {\n padding-right: 1080px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-45 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-45 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-left: 1116px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-right: 1116px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-46 {\n padding-left: 1104px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-46 {\n padding-right: 1104px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-46 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-46 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-left: 1140px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-right: 1140px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-47 {\n padding-left: 1128px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-47 {\n padding-right: 1128px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-47 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-47 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-left: 1164px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-right: 1164px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-48 {\n padding-left: 1152px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-48 {\n padding-right: 1152px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-48 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-48 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-left: 1188px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-right: 1188px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-49 {\n padding-left: 1176px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-49 {\n padding-right: 1176px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-49 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-49 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-left: 1212px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-right: 1212px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-50 {\n padding-left: 1200px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-50 {\n padding-right: 1200px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-50 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-50 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-left: 1236px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-right: 1236px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-51 {\n padding-left: 1224px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-51 {\n padding-right: 1224px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-51 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-51 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-left: 1260px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-right: 1260px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-52 {\n padding-left: 1248px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-52 {\n padding-right: 1248px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-52 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-52 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-left: 1284px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-right: 1284px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-53 {\n padding-left: 1272px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-53 {\n padding-right: 1272px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-53 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-53 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-left: 1308px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-right: 1308px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-54 {\n padding-left: 1296px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-54 {\n padding-right: 1296px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-54 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-54 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-left: 1332px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-right: 1332px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-55 {\n padding-left: 1320px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-55 {\n padding-right: 1320px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-55 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-55 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-left: 1356px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-right: 1356px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-56 {\n padding-left: 1344px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-56 {\n padding-right: 1344px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-56 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-56 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-left: 1380px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-right: 1380px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-57 {\n padding-left: 1368px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-57 {\n padding-right: 1368px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-57 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-57 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-left: 1404px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-right: 1404px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-58 {\n padding-left: 1392px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-58 {\n padding-right: 1392px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-58 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-58 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-left: 1428px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-right: 1428px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-59 {\n padding-left: 1416px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-59 {\n padding-right: 1416px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-59 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-59 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-left: 1452px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-right: 1452px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-60 {\n padding-left: 1440px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-60 {\n padding-right: 1440px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-60 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-60 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-left: 1476px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-right: 1476px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-61 {\n padding-left: 1464px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-61 {\n padding-right: 1464px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-61 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-61 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-left: 1500px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-right: 1500px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-62 {\n padding-left: 1488px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-62 {\n padding-right: 1488px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-62 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-62 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-left: 1524px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-right: 1524px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-63 {\n padding-left: 1512px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-63 {\n padding-right: 1512px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-63 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-63 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-left: 1548px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-right: 1548px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-64 {\n padding-left: 1536px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-64 {\n padding-right: 1536px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-64 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-64 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-left: 1572px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-right: 1572px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-65 {\n padding-left: 1560px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-65 {\n padding-right: 1560px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-65 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-65 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-left: 1596px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-right: 1596px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-66 {\n padding-left: 1584px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-66 {\n padding-right: 1584px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-66 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-66 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-left: 1620px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-right: 1620px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-67 {\n padding-left: 1608px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-67 {\n padding-right: 1608px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-67 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-67 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-left: 1644px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-right: 1644px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-68 {\n padding-left: 1632px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-68 {\n padding-right: 1632px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-68 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-68 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-left: 1668px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-right: 1668px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-69 {\n padding-left: 1656px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-69 {\n padding-right: 1656px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-69 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-69 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-left: 1692px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-right: 1692px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-70 {\n padding-left: 1680px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-70 {\n padding-right: 1680px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-70 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-70 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-left: 1716px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-right: 1716px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-71 {\n padding-left: 1704px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-71 {\n padding-right: 1704px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-71 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-71 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-left: 1740px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-right: 1740px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-72 {\n padding-left: 1728px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-72 {\n padding-right: 1728px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-72 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-72 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-left: 1764px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-right: 1764px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-73 {\n padding-left: 1752px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-73 {\n padding-right: 1752px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-73 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-73 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-left: 1788px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-right: 1788px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-74 {\n padding-left: 1776px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-74 {\n padding-right: 1776px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-74 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-74 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-left: 1812px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-right: 1812px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-75 {\n padding-left: 1800px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-75 {\n padding-right: 1800px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-75 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-75 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-left: 1836px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-right: 1836px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-76 {\n padding-left: 1824px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-76 {\n padding-right: 1824px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-76 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-76 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-left: 1860px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-right: 1860px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-77 {\n padding-left: 1848px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-77 {\n padding-right: 1848px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-77 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-77 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-left: 1884px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-right: 1884px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-78 {\n padding-left: 1872px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-78 {\n padding-right: 1872px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-78 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-78 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-left: 1908px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-right: 1908px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-79 {\n padding-left: 1896px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-79 {\n padding-right: 1896px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-79 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-79 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-left: 1932px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-right: 1932px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-80 {\n padding-left: 1920px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-80 {\n padding-right: 1920px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-80 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-80 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-left: 1956px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-right: 1956px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-81 {\n padding-left: 1944px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-81 {\n padding-right: 1944px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-81 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-81 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-left: 1980px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-right: 1980px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-82 {\n padding-left: 1968px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-82 {\n padding-right: 1968px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-82 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-82 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-left: 2004px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-right: 2004px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-83 {\n padding-left: 1992px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-83 {\n padding-right: 1992px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-83 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-83 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-left: 2028px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-right: 2028px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-84 {\n padding-left: 2016px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-84 {\n padding-right: 2016px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-84 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-84 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-left: 2052px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-right: 2052px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-85 {\n padding-left: 2040px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-85 {\n padding-right: 2040px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-85 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-85 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-left: 2076px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-right: 2076px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-86 {\n padding-left: 2064px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-86 {\n padding-right: 2064px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-86 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-86 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-left: 2100px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-right: 2100px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-87 {\n padding-left: 2088px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-87 {\n padding-right: 2088px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-87 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-87 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-left: 2124px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-right: 2124px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-88 {\n padding-left: 2112px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-88 {\n padding-right: 2112px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-88 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-88 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-left: 2148px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-right: 2148px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-89 {\n padding-left: 2136px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-89 {\n padding-right: 2136px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-89 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-89 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-left: 2172px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-right: 2172px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-90 {\n padding-left: 2160px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-90 {\n padding-right: 2160px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-90 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-90 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-left: 2196px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-right: 2196px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-91 {\n padding-left: 2184px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-91 {\n padding-right: 2184px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-91 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-91 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-left: 2220px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-right: 2220px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-92 {\n padding-left: 2208px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-92 {\n padding-right: 2208px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-92 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-92 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-left: 2244px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-right: 2244px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-93 {\n padding-left: 2232px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-93 {\n padding-right: 2232px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-93 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-93 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-left: 2268px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-right: 2268px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-94 {\n padding-left: 2256px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-94 {\n padding-right: 2256px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-94 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-94 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-left: 2292px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-right: 2292px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-95 {\n padding-left: 2280px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-95 {\n padding-right: 2280px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-95 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-95 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-left: 2316px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-right: 2316px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-96 {\n padding-left: 2304px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-96 {\n padding-right: 2304px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-96 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-96 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-left: 2340px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-right: 2340px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-97 {\n padding-left: 2328px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-97 {\n padding-right: 2328px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-97 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-97 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-left: 2364px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-right: 2364px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-98 {\n padding-left: 2352px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-98 {\n padding-right: 2352px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-98 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-98 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-left: 2388px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-right: 2388px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-indent-99 {\n padding-left: 2376px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-indent-99 {\n padding-right: 2376px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-level-99 .ag-pivot-leaf-group {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-level-99 .ag-pivot-leaf-group {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-row-group-leaf-indent {\n margin-left: 24px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-row-group-leaf-indent {\n margin-right: 24px;\n}\n\n.ag-theme-fresh .ag-value-change-delta {\n padding-right: 2px;\n}\n.ag-theme-fresh .ag-value-change-delta-up {\n color: darkgreen;\n color: var(--ag-value-change-delta-up-color, darkgreen);\n}\n.ag-theme-fresh .ag-value-change-delta-down {\n color: darkred;\n color: var(--ag-value-change-delta-down-color, darkred);\n}\n.ag-theme-fresh .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n -webkit-transition: background-color 1s;\n transition: background-color 1s;\n}\n.ag-theme-fresh .ag-value-change-value-highlight {\n background-color: #cec;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec);\n -webkit-transition: background-color 0.1s;\n transition: background-color 0.1s;\n}\n.ag-theme-fresh .ag-cell-data-changed {\n background-color: #cec !important;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec) !important;\n}\n.ag-theme-fresh .ag-cell-data-changed-animation {\n background-color: transparent;\n}\n.ag-theme-fresh .ag-cell-highlight {\n background-color: rgba(136, 255, 136, 0.4) !important;\n background-color: var(--ag-range-selection-highlight-color, rgba(136, 255, 136, 0.4)) !important;\n}\n.ag-theme-fresh .ag-row {\n height: 25px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n color: #000;\n color: var(--ag-data-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-row-highlight-above::after, .ag-theme-fresh .ag-row-highlight-below::after {\n content: \"\";\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #000;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n left: 1px;\n}\n.ag-theme-fresh .ag-row-highlight-above::after {\n top: -1px;\n}\n.ag-theme-fresh .ag-row-highlight-above.ag-row-first::after {\n top: 0;\n}\n.ag-theme-fresh .ag-row-highlight-below::after {\n bottom: 0px;\n}\n.ag-theme-fresh .ag-row-odd {\n background-color: #f6f6f6;\n background-color: var(--ag-odd-row-background-color, #f6f6f6);\n}\n.ag-theme-fresh .ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-ltr .ag-right-aligned-cell {\n text-align: right;\n}\n\n.ag-theme-fresh .ag-rtl .ag-right-aligned-cell {\n text-align: left;\n}\n\n.ag-theme-fresh .ag-ltr .ag-right-aligned-cell .ag-cell-value, .ag-theme-fresh .ag-ltr .ag-right-aligned-cell .ag-group-value {\n margin-left: auto;\n}\n\n.ag-theme-fresh .ag-rtl .ag-right-aligned-cell .ag-cell-value, .ag-theme-fresh .ag-rtl .ag-right-aligned-cell .ag-group-value {\n margin-right: auto;\n}\n\n.ag-theme-fresh .ag-cell, .ag-theme-fresh .ag-full-width-row .ag-cell-wrapper.ag-row-group {\n border: 1px solid transparent;\n line-height: min(var(--ag-row-height, 23px), 23px);\n padding-left: 11px;\n padding-right: 11px;\n -webkit-font-smoothing: subpixel-antialiased;\n}\n.ag-theme-fresh .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px;\n}\n.ag-theme-fresh .ag-row-dragging {\n cursor: move;\n opacity: 0.5;\n}\n.ag-theme-fresh .ag-cell-inline-editing {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 25px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n}\n.ag-theme-fresh .ag-popup-editor {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n padding: 0;\n}\n.ag-theme-fresh .ag-large-text-input {\n height: auto;\n padding: 12px;\n}\n.ag-theme-fresh .ag-details-row {\n padding: 20px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n}\n.ag-theme-fresh .ag-layout-auto-height .ag-center-cols-clipper, .ag-theme-fresh .ag-layout-auto-height .ag-center-cols-container, .ag-theme-fresh .ag-layout-print .ag-center-cols-clipper, .ag-theme-fresh .ag-layout-print .ag-center-cols-container {\n min-height: 50px;\n}\n.ag-theme-fresh .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66));\n}\n.ag-theme-fresh .ag-overlay-loading-center {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n}\n.ag-theme-fresh .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px;\n}\n.ag-theme-fresh .ag-loading {\n padding-left: 12px;\n display: -webkit-box;\n display: flex;\n height: 100%;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-fresh .ag-loading-icon {\n padding-right: 12px;\n}\n.ag-theme-fresh .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear;\n}\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n.ag-theme-fresh .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-ltr .ag-cell {\n border-right: dotted darkgrey;\n}\n\n.ag-theme-fresh .ag-rtl .ag-cell {\n border-left: dotted darkgrey;\n}\n\n.ag-theme-fresh .ag-ltr .ag-cell {\n border-right-width: 1px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-cell {\n border-left-width: 1px;\n}\n\n.ag-theme-fresh .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-row-selected {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5);\n}\n.ag-theme-fresh .ag-cell-range-selected:not(.ag-cell-focus),\n.ag-theme-fresh .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing) {\n background-color: rgba(0, 0, 0, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(0, 0, 0, 0.2));\n}\n.ag-theme-fresh .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart,\n.ag-theme-fresh .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1) !important;\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)) !important;\n}\n.ag-theme-fresh .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category,\n.ag-theme-fresh .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1) !important;\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)) !important;\n}\n.ag-theme-fresh .ag-cell-range-selected-1:not(.ag-cell-focus),\n.ag-theme-fresh .ag-root:not(.ag-context-menu-open) .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-1:not(.ag-cell-inline-editing) {\n background-color: rgba(0, 0, 0, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(0, 0, 0, 0.2)));\n}\n.ag-theme-fresh .ag-cell-range-selected-2:not(.ag-cell-focus),\n.ag-theme-fresh .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-2 {\n background-color: rgba(0, 0, 0, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(0, 0, 0, 0.36));\n}\n.ag-theme-fresh .ag-cell-range-selected-3:not(.ag-cell-focus),\n.ag-theme-fresh .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-3 {\n background-color: rgba(0, 0, 0, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(0, 0, 0, 0.488));\n}\n.ag-theme-fresh .ag-cell-range-selected-4:not(.ag-cell-focus),\n.ag-theme-fresh .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-4 {\n background-color: rgba(0, 0, 0, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(0, 0, 0, 0.5904));\n}\n.ag-theme-fresh .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #000;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #000;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-fresh .ag-ltr .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-fresh .ag-ltr .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-fresh .ag-ltr .ag-cell-range-single-cell,\n.ag-theme-fresh .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-fresh .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-fresh .ag-rtl .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-fresh .ag-rtl .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-fresh .ag-rtl .ag-cell-range-single-cell,\n.ag-theme-fresh .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n outline: initial;\n}\n.ag-theme-fresh .ag-cell.ag-selection-fill-top,\n.ag-theme-fresh .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #000;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-fresh .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n\n.ag-theme-fresh .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-fresh .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n\n.ag-theme-fresh .ag-cell.ag-selection-fill-bottom,\n.ag-theme-fresh .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #000;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-fresh .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n\n.ag-theme-fresh .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-fresh .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n\n.ag-theme-fresh .ag-range-handle, .ag-theme-fresh .ag-fill-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #000;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-ltr .ag-range-handle, .ag-theme-fresh .ag-ltr .ag-fill-handle {\n right: -1px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-range-handle, .ag-theme-fresh .ag-rtl .ag-fill-handle {\n left: -1px;\n}\n\n.ag-theme-fresh .ag-fill-handle {\n cursor: cell;\n}\n.ag-theme-fresh .ag-range-handle {\n cursor: nwse-resize;\n}\n.ag-theme-fresh .ag-cell-inline-editing {\n border-color: var(--ag-input-focus-border-color) !important;\n}\n.ag-theme-fresh .ag-menu {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n}\n.ag-theme-fresh .ag-menu-list {\n cursor: default;\n padding: 4px 0;\n}\n.ag-theme-fresh .ag-menu-separator {\n height: 9px;\n}\n.ag-theme-fresh .ag-menu-separator-part::after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-menu-option-active, .ag-theme-fresh .ag-compact-menu-option-active {\n background-color: var(--ag-row-hover-color);\n}\n.ag-theme-fresh .ag-menu-option-part, .ag-theme-fresh .ag-compact-menu-option-part {\n line-height: 12px;\n padding: 6px 0;\n}\n.ag-theme-fresh .ag-menu-option-disabled, .ag-theme-fresh .ag-compact-menu-option-disabled {\n opacity: 0.5;\n}\n.ag-theme-fresh .ag-menu-option-icon, .ag-theme-fresh .ag-compact-menu-option-icon {\n width: 12px;\n}\n.ag-theme-fresh .ag-ltr .ag-menu-option-icon, .ag-theme-fresh .ag-ltr .ag-compact-menu-option-icon {\n padding-left: 8px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-menu-option-icon, .ag-theme-fresh .ag-rtl .ag-compact-menu-option-icon {\n padding-right: 8px;\n}\n\n.ag-theme-fresh .ag-menu-option-text, .ag-theme-fresh .ag-compact-menu-option-text {\n padding-left: 8px;\n padding-right: 8px;\n}\n.ag-theme-fresh .ag-ltr .ag-menu-option-shortcut, .ag-theme-fresh .ag-ltr .ag-compact-menu-option-shortcut {\n padding-right: 4px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-menu-option-shortcut, .ag-theme-fresh .ag-rtl .ag-compact-menu-option-shortcut {\n padding-left: 4px;\n}\n\n.ag-theme-fresh .ag-menu-option-popup-pointer, .ag-theme-fresh .ag-compact-menu-option-popup-pointer {\n padding-right: 4px;\n}\n.ag-theme-fresh .ag-tabs {\n min-width: 220px;\n}\n.ag-theme-fresh .ag-tabs-header {\n width: 100%;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-fresh .ag-tab {\n border-bottom: 0 solid transparent;\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 0;\n flex: none;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-pack: center;\n justify-content: center;\n cursor: pointer;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-tab:focus {\n outline: none;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-tab:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-fresh .ag-tab-selected {\n border-bottom-color: #000;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)));\n}\n.ag-theme-fresh .ag-menu-header {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-filter-separator {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-menu:not(.ag-tabs) .ag-filter-select {\n min-width: 167px;\n}\n.ag-theme-fresh .ag-tabs .ag-filter-select {\n min-width: 206px;\n}\n.ag-theme-fresh .ag-filter-select .ag-picker-field-wrapper {\n width: 0;\n}\n.ag-theme-fresh .ag-filter-condition-operator {\n height: 17px;\n}\n.ag-theme-fresh .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px;\n}\n\n.ag-theme-fresh .ag-set-filter-select-all {\n padding-top: 6px;\n}\n.ag-theme-fresh .ag-set-filter-list, .ag-theme-fresh .ag-filter-no-matches {\n height: 120px;\n}\n.ag-theme-fresh .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px;\n}\n.ag-theme-fresh .ag-filter-to {\n margin-top: 4px;\n}\n.ag-theme-fresh .ag-mini-filter {\n margin: 6px 6px;\n}\n.ag-theme-fresh .ag-set-filter-item {\n margin: 0px 6px;\n}\n.ag-theme-fresh .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px;\n}\n\n.ag-theme-fresh .ag-filter-apply-panel {\n padding: 6px 6px;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n}\n.ag-theme-fresh .ag-filter-apply-panel-button {\n line-height: 1.5;\n}\n.ag-theme-fresh .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px;\n}\n\n.ag-theme-fresh .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px;\n}\n.ag-theme-fresh .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px;\n}\n.ag-theme-fresh .ag-filter-no-matches {\n padding: 6px 6px;\n}\n.ag-theme-fresh .ag-multi-filter-menu-item {\n margin: 4px 0;\n}\n.ag-theme-fresh .ag-multi-filter-group-title-bar {\n padding: 8px 4px;\n background-color: transparent;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus {\n outline: none;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-fresh .ag-side-bar {\n position: relative;\n}\n.ag-theme-fresh .ag-tool-panel-wrapper {\n width: 200px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n}\n.ag-theme-fresh .ag-side-buttons {\n padding-top: 16px;\n width: 16px;\n position: relative;\n color: #000;\n color: var(--ag-foreground-color, #000);\n overflow: hidden;\n}\n.ag-theme-fresh button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: calc(100% + 1px);\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh button.ag-side-button-button:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-side-button-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-fresh .ag-selected .ag-side-button-button {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-side-button-icon-wrapper {\n margin-bottom: 3px;\n}\n.ag-theme-fresh .ag-ltr .ag-side-bar-left,\n.ag-theme-fresh .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n.ag-theme-fresh .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-ltr .ag-side-bar-left .ag-side-button-button,\n.ag-theme-fresh .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent;\n margin-right: -1px;\n padding-right: 1px;\n}\n.ag-theme-fresh .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-fresh .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #000;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)));\n}\n.ag-theme-fresh .ag-rtl .ag-side-bar-left,\n.ag-theme-fresh .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n.ag-theme-fresh .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-rtl .ag-side-bar-left .ag-side-button-button,\n.ag-theme-fresh .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent;\n margin-left: -1px;\n padding-left: 1px;\n}\n.ag-theme-fresh .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-fresh .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #000;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)));\n}\n.ag-theme-fresh .ag-filter-toolpanel-header {\n height: 24px;\n}\n.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-header, .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-header, .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px;\n}\n\n.ag-theme-fresh .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-filter-toolpanel-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-fresh .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f114\";\n position: absolute;\n}\n.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-left: 4px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-right: 4px;\n}\n\n.ag-theme-fresh .ag-filter-toolpanel-group-level-0-header {\n height: 32px;\n}\n.ag-theme-fresh .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px;\n}\n.ag-theme-fresh .ag-filter-toolpanel-search {\n height: 25px;\n}\n.ag-theme-fresh .ag-filter-toolpanel-search-input {\n -webkit-box-flex: 1;\n flex-grow: 1;\n height: 16px;\n}\n.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px;\n}\n\n.ag-theme-fresh .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n}\n.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px;\n}\n\n.ag-theme-fresh .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px;\n}\n\n.ag-theme-fresh .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px;\n}\n\n.ag-theme-fresh .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px;\n}\n\n.ag-theme-fresh .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px;\n}\n\n.ag-theme-fresh .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px;\n}\n\n.ag-theme-fresh .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px;\n}\n\n.ag-theme-fresh .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px;\n}\n\n.ag-theme-fresh .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px;\n}\n\n.ag-theme-fresh .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px;\n}\n\n.ag-theme-fresh .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px;\n}\n\n.ag-theme-fresh .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px;\n}\n.ag-theme-fresh .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n margin-top: 4px;\n}\n.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px;\n}\n\n.ag-theme-fresh .ag-pivot-mode-panel {\n min-height: 25px;\n height: 25px;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-fresh .ag-pivot-mode-select {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-fresh .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px;\n}\n\n.ag-theme-fresh .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-column-select-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-fresh .ag-column-select-header {\n height: 25px;\n -webkit-box-align: center;\n align-items: center;\n padding: 0 6px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n}\n.ag-theme-fresh .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n}\n.ag-theme-fresh .ag-column-group-icons,\n.ag-theme-fresh .ag-column-select-header-icon {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-column-select-list .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #000;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-column-select-list .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-fresh .ag-column-select-list .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-fresh .ag-header {\n background-color: var(--ag-header-background-color);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-header-row {\n color: #000;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)));\n height: 25px;\n}\n.ag-theme-fresh .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px;\n}\n\n.ag-theme-fresh .ag-header-cell,\n.ag-theme-fresh .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px;\n}\n.ag-theme-fresh .ag-header-cell.ag-header-cell-moving,\n.ag-theme-fresh .ag-header-group-cell.ag-header-cell-moving {\n background-color: #bebebe;\n background-color: var(--ag-header-cell-moving-background-color, #bebebe);\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-header-cell:focus {\n outline: none;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-header-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-header-group-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-fresh .ag-header-icon {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-header-expand-icon {\n cursor: pointer;\n}\n.ag-theme-fresh .ag-ltr .ag-header-expand-icon {\n padding-left: 4px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-header-expand-icon {\n padding-right: 4px;\n}\n\n.ag-theme-fresh .ag-header-row:not(:first-child) .ag-header-cell,\n.ag-theme-fresh .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-header-cell::after,\n.ag-theme-fresh .ag-header-group-cell::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n width: 1px;\n height: 100%;\n top: calc(50% - 50%);\n background-color: rgba(169, 169, 169, 0.5);\n background-color: var(--ag-header-column-separator-color, rgba(169, 169, 169, 0.5));\n}\n.ag-theme-fresh .ag-ltr .ag-header-cell::after, .ag-theme-fresh .ag-ltr .ag-header-group-cell::after {\n right: 0;\n}\n\n.ag-theme-fresh .ag-rtl .ag-header-cell::after, .ag-theme-fresh .ag-rtl .ag-header-group-cell::after {\n left: 0;\n}\n\n.ag-theme-fresh .ag-ltr .ag-header-select-all {\n margin-right: 12px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-header-select-all {\n margin-left: 12px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-floating-filter-button {\n margin-left: 12px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-floating-filter-button {\n margin-right: 12px;\n}\n\n.ag-theme-fresh .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 12px;\n padding: 0;\n width: 12px;\n}\n.ag-theme-fresh .ag-filter-loading {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1;\n}\n.ag-theme-fresh .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px;\n}\n.ag-theme-fresh .ag-paging-panel > * {\n margin: 0 12px;\n}\n.ag-theme-fresh .ag-paging-button {\n cursor: pointer;\n}\n.ag-theme-fresh .ag-paging-button.ag-disabled {\n cursor: default;\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-paging-button:focus {\n outline: none;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-paging-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-fresh .ag-paging-button, .ag-theme-fresh .ag-paging-description {\n margin: 0 4px;\n}\n.ag-theme-fresh .ag-status-bar {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5;\n}\n.ag-theme-fresh .ag-status-name-value-value {\n color: #000;\n color: var(--ag-foreground-color, #000);\n}\n.ag-theme-fresh .ag-status-bar-center {\n text-align: center;\n}\n.ag-theme-fresh .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px;\n}\n.ag-theme-fresh .ag-column-drop-cell {\n background: var(--ag-chip-background-color);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px;\n border: 1px solid transparent;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-column-drop-cell:focus {\n outline: none;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-column-drop-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 2px;\n left: 2px;\n display: block;\n width: calc(100% - 4px);\n height: calc(100% - 4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-fresh .ag-column-drop-cell-text {\n margin: 0 4px;\n}\n.ag-theme-fresh .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-column-drop-cell-drag-handle {\n margin-left: 8px;\n}\n.ag-theme-fresh .ag-column-drop-cell-ghost {\n opacity: 0.5;\n}\n.ag-theme-fresh .ag-column-drop-horizontal {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px;\n}\n\n.ag-theme-fresh .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey);\n}\n\n.ag-theme-fresh .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey);\n}\n\n.ag-theme-fresh .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-column-drop-horizontal-empty-message {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n}\n.ag-theme-fresh .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px;\n}\n\n.ag-theme-fresh .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px;\n}\n\n.ag-theme-fresh .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px;\n}\n.ag-theme-fresh .ag-column-drop-vertical-cell {\n margin-top: 4px;\n}\n.ag-theme-fresh .ag-column-drop-vertical {\n min-height: 50px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n}\n.ag-theme-fresh .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none;\n}\n.ag-theme-fresh .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px;\n}\n.ag-theme-fresh .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n margin-top: 4px;\n}\n.ag-theme-fresh .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n -webkit-box-shadow: none;\n box-shadow: none;\n padding: 4px;\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n height: 70px;\n padding: 0;\n}\n.ag-theme-fresh .ag-select-agg-func-virtual-list-item {\n cursor: default;\n padding-left: 8px;\n}\n.ag-theme-fresh .ag-select-agg-func-virtual-list-item:hover {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5);\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-fresh .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-fresh .ag-chart-menu {\n border-radius: 0px;\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n}\n.ag-theme-fresh .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 0px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-chart-menu-icon:hover {\n opacity: 1;\n}\n.ag-theme-fresh .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n border-radius: 5px;\n margin: 5px;\n}\n.ag-theme-fresh .ag-chart-mini-thumbnail:nth-last-child(3), .ag-theme-fresh .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto;\n}\n.ag-theme-fresh .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0;\n}\n\n.ag-theme-fresh .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0;\n}\n\n.ag-theme-fresh .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0;\n}\n\n.ag-theme-fresh .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0;\n}\n\n.ag-theme-fresh .ag-chart-mini-thumbnail.ag-selected {\n border-color: #000;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)));\n}\n.ag-theme-fresh .ag-chart-settings-card-item {\n background: #000;\n background: var(--ag-foreground-color, #000);\n width: 8px;\n height: 8px;\n border-radius: 4px;\n}\n.ag-theme-fresh .ag-chart-settings-card-item.ag-selected {\n background-color: #000;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)));\n}\n.ag-theme-fresh .ag-chart-data-column-drag-handle {\n margin-left: 4px;\n}\n.ag-theme-fresh .ag-charts-settings-group-title-bar,\n.ag-theme-fresh .ag-charts-data-group-title-bar,\n.ag-theme-fresh .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n}\n.ag-theme-fresh .ag-charts-settings-group-container {\n padding: 4px;\n}\n.ag-theme-fresh .ag-charts-data-group-container {\n padding: 3px 6px;\n}\n.ag-theme-fresh .ag-charts-data-group-container .ag-charts-data-group-item:not(.ag-charts-format-sub-level-group) {\n height: 20px;\n}\n.ag-theme-fresh .ag-charts-data-group-container .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #000;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh .ag-charts-data-group-container .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-fresh .ag-charts-data-group-container .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-fresh .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px;\n}\n.ag-theme-fresh .ag-charts-format-top-level-group-item {\n margin: 4px 0;\n}\n.ag-theme-fresh .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px;\n}\n.ag-theme-fresh .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px;\n}\n.ag-theme-fresh .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px;\n}\n.ag-theme-fresh .ag-chart-data-section,\n.ag-theme-fresh .ag-chart-format-section {\n display: -webkit-box;\n display: flex;\n margin: 0;\n}\n.ag-theme-fresh .ag-chart-menu-panel {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n}\n.ag-theme-fresh .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey);\n}\n\n.ag-theme-fresh .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey);\n}\n\n.ag-theme-fresh .ag-date-time-list-page-title {\n -webkit-box-flex: 1;\n flex-grow: 1;\n text-align: center;\n}\n.ag-theme-fresh .ag-date-time-list-page-column-label {\n text-align: center;\n}\n.ag-theme-fresh .ag-date-time-list-page-entry {\n text-align: center;\n}\n.ag-theme-fresh .ag-checkbox-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-fresh .ag-checkbox-input-wrapper input, .ag-theme-fresh .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-fresh .ag-checkbox-input-wrapper:focus-within, .ag-theme-fresh .ag-checkbox-input-wrapper:active {\n outline: none;\n}\n.ag-theme-fresh .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-fresh .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #000;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-fresh .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #000;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-fresh .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #000;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-fresh .ag-toggle-button-input-wrapper {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n width: 24px;\n height: 12px;\n background-color: #000;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)));\n border-radius: 6px;\n position: relative;\n -webkit-box-flex: 0;\n flex: none;\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)));\n}\n.ag-theme-fresh .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%;\n}\n.ag-theme-fresh .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n}\n.ag-theme-fresh .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-fresh .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #000;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)));\n border-color: #000;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)));\n}\n.ag-theme-fresh .ag-toggle-button-input-wrapper::before {\n content: \" \";\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n background-color: #FFF;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #FFF));\n border-radius: 6px;\n -webkit-transition: left 100ms;\n transition: left 100ms;\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000))));\n}\n.ag-theme-fresh .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 12px );\n border-color: #000;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)));\n}\n.ag-theme-fresh .ag-radio-button-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n border-radius: 12px;\n}\n.ag-theme-fresh .ag-radio-button-input-wrapper input, .ag-theme-fresh .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-fresh .ag-radio-button-input-wrapper:focus-within, .ag-theme-fresh .ag-radio-button-input-wrapper:active {\n outline: none;\n}\n.ag-theme-fresh .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-fresh .ag-radio-button-input-wrapper::after {\n content: \"\\f126\";\n color: #000;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-fresh .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f127\";\n color: #000;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-fresh input[class^=ag-][type=range] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible;\n}\n.ag-theme-fresh input[class^=ag-][type=range]::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px;\n}\n.ag-theme-fresh input[class^=ag-][type=range]::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px;\n}\n.ag-theme-fresh input[class^=ag-][type=range]::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px;\n color: transparent;\n width: calc(100% - 2px);\n}\n.ag-theme-fresh input[class^=ag-][type=range]::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px;\n -webkit-transform: translateY(-4.5px);\n transform: translateY(-4.5px);\n}\n.ag-theme-fresh input[class^=ag-][type=range]::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px;\n}\n.ag-theme-fresh input[class^=ag-][type=range]::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px;\n}\n.ag-theme-fresh input[class^=ag-][type=range]:focus {\n outline: none;\n}\n.ag-theme-fresh input[class^=ag-][type=range]:focus::-webkit-slider-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh input[class^=ag-][type=range]:focus::-ms-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh input[class^=ag-][type=range]:focus::-moz-ag-range-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n}\n.ag-theme-fresh input[class^=ag-][type=range]:active::-webkit-slider-runnable-track {\n background-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-fresh input[class^=ag-][type=range]:active::-moz-ag-range-track {\n background-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-fresh input[class^=ag-][type=range]:active::-ms-track {\n background-color: var(--ag-input-focus-border-color);\n}\n.ag-theme-fresh input[class^=ag-][type=range]:disabled {\n opacity: 0.5;\n}\n.ag-theme-fresh .ag-icon {\n color: #333;\n margin: 1px 1px 2px 1px;\n}\n.ag-theme-fresh .ag-icon-tree-closed::before {\n content: \"\\f10b\";\n}\n.ag-theme-fresh .ag-icon-tree-open::before {\n content: \"\\f111\";\n}\n.ag-theme-fresh .ag-header, .ag-theme-fresh .ag-column-drop-cell {\n background-image: -webkit-gradient(linear, left top, left bottom, from(white), to(lightgrey));\n background-image: linear-gradient(white, lightgrey);\n}\n.ag-theme-fresh .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px;\n}\n.ag-theme-fresh .ag-tabs-body {\n margin: 2px 0;\n}\n.ag-theme-fresh .ag-tab-selected {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-bottom-color: transparent;\n}\n.ag-theme-fresh .ag-tabs-header {\n background-color: var(--ag-header-background-color);\n border-bottom: 1px solid;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-filter .ag-filter-apply-panel {\n -webkit-box-pack: start;\n justify-content: flex-start;\n}\n.ag-theme-fresh .ag-menu-option-active {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5);\n}\n.ag-theme-fresh .ag-column-drop-cell {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0;\n}\n.ag-theme-fresh .ag-column-drop-cell-button .ag-icon {\n border: 1px solid transparent;\n}\n.ag-theme-fresh .ag-column-drop-cell-button:hover .ag-icon {\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n}\n.ag-theme-fresh .ag-panel-title-bar-button-icon {\n font-size: 20px;\n line-height: 20px;\n}\n.ag-theme-fresh .ag-menu-option-part {\n padding-top: 4px;\n padding-bottom: 4px;\n}\n.ag-theme-fresh .ag-column-drop-vertical-title-bar {\n margin-top: 4px;\n margin-left: 4px;\n}\n.ag-theme-fresh .ag-column-drop-vertical-title {\n margin-left: 4px;\n}\n.ag-theme-fresh .ag-column-drop-vertical-empty-message {\n margin-left: 24px;\n}\n", ""]); // Exports module.exports = exports; /***/ }), -/* 244 */ +/* 297 */ /***/ (function(module, exports, __webpack_require__) { -var api = __webpack_require__(225); - var content = __webpack_require__(245); +var api = __webpack_require__(278); + var content = __webpack_require__(298); content = content.__esModule ? content.default : content; @@ -48798,24 +57743,24 @@ var update = api(content, options); module.exports = content.locals || {}; /***/ }), -/* 245 */ +/* 298 */ /***/ (function(module, exports, __webpack_require__) { // Imports -var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227); +var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(280); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, ".ag-theme-material {\n -webkit-font-smoothing: antialiased;\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87));\n font-family: \"Roboto\", sans-serif;\n font-size: 13px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridMaterial\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABGsAAsAAAAAIJAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlEAAAReYPJi3U9TLzIAAANcAAAAPgAAAFZWTFJvY21hcAAAA5wAAAHsAAAFgGqPB0pnbHlmAAAFiAAACFEAAA58peGl1GhlYWQAAA3cAAAALwAAADZ2zcSBaGhlYQAADgwAAAAWAAAAJAfRBDJobXR4AAAOJAAAABIAAAEkt5gAAGxvY2EAAA44AAAAbQAAAJSyFLU8bWF4cAAADqgAAAAfAAAAIAFcAEluYW1lAAAOyAAAATIAAAJebBQ2inBvc3QAAA/8AAABrgAAAom3/2OGeJx9k09yElEQxr9hCCYBk6gRFVFT8X/UOM4MTIBIQBApKwsXLly4iQstrZSrnMC1B7A8gKfwBJZLVx7AA1gewF83g5gswhQz73V//fXX/fopkLSoSF0VhqPd51ra3zt4r5qKmvzM//862H/7Zk/z0x2+on/nFYR/tKR1vdCBvgUKXgefC6WwEHbD3fBD+Cn8oRDUmjZBl/WAJ1bCO1KqhprKVFAJW8x6Sy3QIe+2W0+rqjn3DDTUWXLGxAydcUNPdU0r8PSdp0ctAzhT5+zxHvFc1/IxiEw34G+gZhursdbReUoLeozGHjo6RLfwruDbIXNETB9fH22ho4rex7Fe6h42q80iGzku5R/rke8j31XowhTVhr8Jv/FtknVqb5IpIeIu7A1QD/MebugK0U14erB1PHrLoysgExSmuszKKkuorEKH2nqmV0SWUTGJ6XkXJzXfQv3M3ne+TLcPWTtwjcDeQcPMaidyk1xWewK+yv6dPuqLvuq7fuqXfoOvkiXxCrpw7xzbmQX6dxQ9wNv+Z7VKT3AWR1GHEYvU3fTexPiGeQctWwWf9SZlHWFNHV+G0/AD1GScxhyTF3neBGuJ/Tb7GPRSPo0tnpPe5yEzYBNQo5Mxb2OazFtGhy8QbauJrnPerRY85/20rKd2k5Z9ZzNvp1zj1C/yjais4f15gvcSFmOaWeoelaHaOO7jz1A7y2aq6qhKfXZtssZ+CwZkWqOOiZJEV/0GjH2q1lHQyG/kqs64+k5+UquOiz0qoBNRfpNT75lNch9tNhWjv/VfaSwAAAB4nGNgZGphnMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVFgEqgRRAAA0p8KWwAAeJy11AduVDEUheF/SkILvbcUSK+T3ntlGaFHoUShR6ySndwNEM4dHxYQJCx9c8d+nvdsPZ8BWoCaDEsdqnUqZPut0UpzvMbF5nidX+q3cZ6qvo9wwBEn0Tg91egI+xxyHJVm72+raHYbj+hlRr01GqywwDqT7DDOEtMss8gGs7q+xQTzTLHJHnOsss2ufl/V0+u0ck5PvaB1XNL9LnOFq1zjOje4yS1uc4e73OM+D3iopz3WnHY66KSLp5rXTY9W0Ec/AwwypB21ab2jjGmBrZytrZ1xfrbGysL65M74kna7uDE7o43OT23uza1u7/7Dzf5Da8uP2k/3npFvs1iTfWvIc1uRF7YgL21dXtmkvLYdeWPj8taW5MCm5dCW5Z0tynvbkA82Kx8tT9eRbcmxTcgnm5fPNiVfbFO+2p58szn5bqvyw7blxPQCo1JkVqJakLVWZLaiXmS+oqXQmSZMp5swnXPCdOIJywyGKQWE5dsLUzIIU0YIU1oIUx4IU4IIU5YIU6oIU74IU9IIU+YIU/oIUw4JUyIJUzYJU0oJU14JU3IJa+6rvSBrR0HWzoKsXQVZnxRKPWHN/XYXZO0pyNpbkLWvIGt/QdaBgqyDBVmHCrIOF/kfGiNFc/2jRWYpxgpyrFEw9gcVSJ+veJzFV21MW+cVvue9xTcmEOKAffECduyLfWkwrsy1udgGwlcCisrHZCdaG1LTdIG0sBjaVF2WoX1okyK1ayqt9Efzp9GkizSpTVv+pNOUVCxVmfrHUfNrYmzqn+GsQ1RCreTGVzvnxTbhY1Kn/Rjc933PfT/OPee8z/mwAAL+sTWxR9gvCOCxV4LdE/HoqoetmRVQZX4FG+byvXvQIHYncrnEbCYjCI/RGfED8QPBIlQKNcJhPKlFNFXSJCUiyRHNp9oVu2ZXFbsi6wrcMNKLi+k26lj/Yjo9z9/Zz7CfJyqxmDbSOlLIlssj9qA8+wShWtZtmk3WYT6WTa7GzQXYiGfNMvg2G4dBFJvvnRPnUIYjeNQrWSRLjeyQHS16q94aVv2qv1pSJVVXdVmXJdiYeTalR6N66tkvikQq9tZbsbk53otz25Y4kf9zcRV74f/zTZF/s1asRUqie6rWbAo1XbMrmdnZB5cuZV9+mT1vTrCB/K1cTijJuSquCtWCk27WewDsthoXaJ6WTojYwkGwgi6DLF5++LVLc+EjlvMxv2Y+GFoCY0hcxfdtiw+/BsfQp2AMb+cv781fRCDt4v6b/H0W2M05f3/6UZ4i52nz2Hx78UWeYvkOvpuT6Z18C7b7sfhDoQwRVSsIVpBkK4i6Gyx0dfYaR0trhK6N/dNMxZ4z89C5tPTp+/v3O6scoeMhR5UTFuFGHBfMP0HH0lJnZaXrsN/pDYW8Tl+di9hbS5jdvJ8qbpPDgltQ6K4iCjUJWwSbjE23a5GywrwN27xh5PhTGM2xwhu7buTHcUwahQlcwafoJ+waW0O9BFRJQi95M3b7dizH1uJ37sRzJdz8XLyDmjuFen5LFjt6lEfmRI0DjdqKNvUr1R6bh71vViihJGzMmhFSDz7DXgEzAp+Jt0Pe/EesPxFS8h/RGutXQvnzrL/gr4RNih+Iey6KrKtibTybLT7sr4+8bPdxPGNTbKoEYjd3chgkJ4dvzbIsOvwOPZG7rrLXY7lc7DZbiOdy8TulmPEUWxXa8SXIFK9FUlu1FtkF8gFAUldwQpEtitevKi6mtehEq0HAJdkiabTZIWvsTSnYp3ri8uBTEyMDJ16ok0+1DfmsvZLt6FDfPqsnvK9Xaj6uNhzp7x3A9ck6//fPWB/71eP1jUfC1h5m83UoTseg5nZf7O845xn0abWHjh4H1e3vVKpOfI+mx7pGq2sa6/xFXJLMhxAnjTySoKwoMQaSTtBRNr/oDUK4E1pcUHMARK+FoBr2wwaXre6FEwPvIFFfj8RI4GQgcPIH1AUao9GRaJT9g77Xf9HtLo7mZGEHdiDSnpFoESOTaN9CbPEhHikHAHovRm7DXGZr+WuYBSpyCbiRSJjLyVJ8Yd/we7HSzeh4N4AxiX3z8cd4MWYkmYQIATFHZwu+3cNm+Hco03jKKD5058fZ24U2k5hP0DYL3/uMWI5UuWAT7IheN51BMzQBCaejTXCo5h6FmUdBM2msHxzo8vPgMB/MI2FWpOlvhYICDFI3ND29gmM6fz+dnqbpXXpUE3pVD+rxFVcDXkkm2QJXA5XYmZ8AEyVGURXV2IQrDBJ0mSsbMxfMhVi2aN859gnmi1ohgF9AUeMQUTCuYVTjVBBkNIUPU2aLi5GKSHQCRrrfedsVw4iOtbWNRQ1Daff+HobMD+EVToNSWoQNJa4Mt6VeTLUNK3EpaWB/gmbGZlJtxbhajvaUuR0xLWHikCXM0hFMVGRAHbO2qOkRVZHsLHB+ePyNN8aHz0+XiPHR7u7RbvaTbZNEmFe6aalgl0lxkjSuxtudRdgcEicTwh4Y01Fd/o93yPdtNiwvkplEouDza8I9OqkjLw6hDMfGnrxsBbzO0r4ivy24io/kbI8Q/A9ZG8JEUiCAIABGCkCM1dDGvXK42dMceHLwTPRCk9nsbYBBJOBzbwNN7pXSzdSZwScDzQ1es7npgvllgxc+b7oQ5XNFnaYwTjvwflSUTwkCxjBlR5D2tDhqLF5/uBU8Ng1V1sTam5VdI12VN3lIHqDeXLY5nV6nEyL5W0l4JylO+oJBH0bv83zPdW+oVqnFB210fXa2iI0usROlqKJMourVwKM41S8qnHlVffVvEHC51ttPr59qv+yCVpyBv5v3Xa7L7afWT7evu7bqjf+dj7VUW27mUI/gE5qEJwRN0DE2edBX0BSdVA24qC44AIBug/bw+PinsOTUfLz8onlyKR0bRRm3Vl+vudnbfMz/yzAQK33wR/OLY8fUiYmb+P6l2nWsccK8gqRjZWXFMNq2Drg5A7Ab8GvzynvHuujI/BNqFxLgp8RsbKu5aoTHiyg7SCg7QtA6SCgTvdRzqLXQSgFgVy/N9Pb19c5cgoNF6uqPzj4d0fXI02f/UiTEVVow17dvfvjTbZs4UcAUyVKBNmwlaXjA2Qws6n8hWt9Lvb0vXaWu77tJydYK+7HLfWeBd8VWSUbPx5zyaM3Pa4RsDIt/VvCZSfwF4tisFZWSr5TpHHY2dJD8rcSma5gLU7FMJjaVpB800GAu8xKnoW4qnsnEp+C3pZrqE3aWuAMWVA2ZDBulXzzFtbMYxxmXjebZ3b3WEOyvZTJ0VtjFEwtunKf1LX2fEyuKtQ2ocPHd+CpsxCDxbiyLY7G+Yq5iXM1Qjc9cyRLvNXZtswak4qiQq9jrVAlu1YBzaCfKoy0UWyjNgN1hkWQsqBEMEtakVCjZt/JRJIyFEW6U8dGB3d1MOPrRjvCxtrFzo8l9+Vu/jA0Us1JP6LT7xdTAfDjfz+5i6lECx/d3HD7XHk21GUmY+kXt811RnpmU0Mmy08lncCf7gyD8G975gHwAAAB4nGNgZGBgAOLNefk58fw2Xxm4mV8ABaI4H+9rQNAMDMwvQOIMHAxMIB4AThwLfgB4nGNgZGBgfsHAgEQyMqACTwBFgwMNAAB4nGNgYGBgfjF0MT0AAODAKyYAAHicY2AAAikGD4Y4hhkMlxjeMMowujEWMC5ivMP4jkmByYopgCmJaQ8zA7MMswmzF3MD8wzmDcyfWFRYjFi8WCJYilgOsTKwqrB6sC5jfcPmxhbD1sY2hW0R2wa2fWwX2O6xfWC3Ix0CAAMJHZwAAAB4nGNgZGBg8GSwZeBkAAEmIOYCQgaG/2A+AwAWwQGmAHicfZA9asNAEIWf/BdiQwiEuFKxEEgTkH9Kk9qCgBsX7mVrJcustWK1NvgGOUhOkEOkzEFyijytt7ELz8LwvTdvplgAj/hBgKYCPLjeVAt3VGduk549d8gvnrsYYOK5R//dcx9v+PA8wBMOvBB07umE+PTcYv7Lc5v+t+cO+ddzF0P8ee4hDOC5j1UQeh7gNTBJHpsiXSRWmiJRS5kfVHJlXqqVNHWhSzGJxpeDWJbSkFOxPon6mE+tzURm9F7MdWmlUlpURu/kxkZba6vZaJR5P9roPRLkiGFQIMWCykI6lUBhSc75F4rK3Ezemq0c11QaJQT/P8L45kZMLp0++ym31jix1zhyb0rXIqPOmNHYk+buepNWfJpO5WY7Ohv6EbZuq8IMI77sKh8xxUv/NPJv3gAAeJxtkQdv2zAQhf3Fki3baeO6bbr3Hmqb7r1X+i9oipaJSKRAUR759WXtIECAHnDgew+Hd4OtjdY6+q3/xy4btImI6dAloUefAZsc4zhbDDnBiJOc4jTbnOEs5zjPBS5yictc4SrXuM4NbnKL29zhLve4zwMekvKIxzxhh6c84zkveMkrXvOGt7zjPR/4yCc+84WvfOM7P/jJL36zy5/WQOS5U7nw2pqOcM7O67aoZUcKI1WRrJ90J5ZT4fxQTpXcG9tFugIq2z4UtMmUV67URng1OpQbc1C5KW1hXVrpQFw3kKY0dV9a452QXmWRtNUyls7WdZSpWiZqUYngmfXUUqV1IeppO6DORBehTTzRrvZR7nQV5842VRQKfFSoie8U2oR+3cKKTJs8KcVCl3pfRaUyTRLmWzNjjRoY61NRFHausrgKBqpdaROHDAtXemb90AUTm44b761J7WSydVQwsdP51Ee1mKl+XQavNLNzcwD/jTNYw1VZssZhWh/OMPJOqaN3660kWymTNGa9B4Ich8KjsRjm1EgKpuwxZhE+P6OkoWLJhH1mrdZfDrCtIAAA\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-material .ag-icon {\n font-family: \"agGridMaterial\";\n font-size: 18px;\n line-height: 18px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-material .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-material .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-material .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-material .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-material .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-material .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-material .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-material .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-material .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-material .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-material .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-material .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-material .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-material .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-material .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-material .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-material .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-material .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-material .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-material .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-material .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-material .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-material .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-material .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-material .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-material .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-material .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-material .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-material .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-material .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-material .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-material .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-material .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-material .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-material .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-material .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-material .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-material .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-material .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-material .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-material .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-material .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-material .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-material .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-material .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-material .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-material .ag-root-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-material [class^='ag-'], .ag-theme-material [class^='ag-']:focus, .ag-theme-material [class^='ag-']:after, .ag-theme-material [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-material [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-material .ag-checkbox .ag-input-wrapper,\n .ag-theme-material .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-material .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-material .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-material .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 8px; }\n .ag-theme-material .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 8px; }\n .ag-theme-material input[class^='ag-'] {\n margin: 0;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-material textarea[class^='ag-'],\n .ag-theme-material select[class^='ag-'] {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-material input[class^='ag-']:not([type]),\n .ag-theme-material input[class^='ag-'][type='text'],\n .ag-theme-material input[class^='ag-'][type='number'],\n .ag-theme-material input[class^='ag-'][type='tel'],\n .ag-theme-material input[class^='ag-'][type='date'],\n .ag-theme-material input[class^='ag-'][type='datetime-local'],\n .ag-theme-material textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit; }\n .ag-theme-material input[class^='ag-']:not([type]):disabled,\n .ag-theme-material input[class^='ag-'][type='text']:disabled,\n .ag-theme-material input[class^='ag-'][type='number']:disabled,\n .ag-theme-material input[class^='ag-'][type='tel']:disabled,\n .ag-theme-material input[class^='ag-'][type='date']:disabled,\n .ag-theme-material input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-material textarea[class^='ag-']:disabled {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n background-color: var(--ag-input-disabled-background-color);\n border-color: var(--ag-input-disabled-border-color); }\n .ag-theme-material input[class^='ag-']:not([type]):focus,\n .ag-theme-material input[class^='ag-'][type='text']:focus,\n .ag-theme-material input[class^='ag-'][type='number']:focus,\n .ag-theme-material input[class^='ag-'][type='tel']:focus,\n .ag-theme-material input[class^='ag-'][type='date']:focus,\n .ag-theme-material input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-material textarea[class^='ag-']:focus {\n outline: none;\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-material input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-material input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-material input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-material input[class^='ag-'][type='button']:focus, .ag-theme-material button[class^='ag-']:focus {\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122); }\n .ag-theme-material .ag-drag-handle {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-list-item, .ag-theme-material .ag-virtual-list-item {\n height: 40px; }\n .ag-theme-material .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-select-list {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-material .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-material .ag-list-item.ag-active-item {\n background-color: #fafafa;\n background-color: var(--ag-row-hover-color, #fafafa); }\n .ag-theme-material .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-material .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-material .ag-select .ag-picker-field-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n min-height: 40px;\n cursor: default; }\n .ag-theme-material .ag-select:not(.ag-cell-editor) {\n height: 40px; }\n .ag-theme-material .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-material .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-material .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-material .ag-rich-select {\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa); }\n .ag-theme-material .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 312px; }\n .ag-theme-material .ag-rich-select-value {\n padding: 0 8px 0 24px;\n height: 48px; }\n .ag-theme-material .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 40px; }\n .ag-theme-material .ag-rich-select-virtual-list-item:hover {\n background-color: #fafafa;\n background-color: var(--ag-row-hover-color, #fafafa); }\n .ag-theme-material .ag-rich-select-row {\n padding-left: 24px; }\n .ag-theme-material .ag-rich-select-row-selected {\n background-color: #eee;\n background-color: var(--ag-selected-row-background-color, #eee); }\n .ag-theme-material .ag-row-drag,\n .ag-theme-material .ag-selection-checkbox,\n .ag-theme-material .ag-group-expanded,\n .ag-theme-material .ag-group-contracted {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-ltr .ag-row-drag, .ag-theme-material .ag-ltr .ag-selection-checkbox, .ag-theme-material .ag-ltr .ag-group-expanded, .ag-theme-material .ag-ltr .ag-group-contracted {\n margin-right: 24px; }\n .ag-theme-material .ag-rtl .ag-row-drag, .ag-theme-material .ag-rtl .ag-selection-checkbox, .ag-theme-material .ag-rtl .ag-group-expanded, .ag-theme-material .ag-rtl .ag-group-contracted {\n margin-left: 24px; }\n .ag-theme-material .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 46px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-material .ag-group-expanded,\n .ag-theme-material .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-material .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-material .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-material .ag-group-title-bar {\n background-color: #eee;\n background-color: var(--ag-subheader-background-color, #eee);\n padding: 8px; }\n .ag-theme-material .ag-group-toolbar {\n padding: 8px; }\n .ag-theme-material .ag-disabled-group-title-bar, .ag-theme-material .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-material .group-item {\n margin: 4px 0; }\n .ag-theme-material .ag-label {\n white-space: nowrap; }\n .ag-theme-material .ag-ltr .ag-label {\n margin-right: 8px; }\n .ag-theme-material .ag-rtl .ag-label {\n margin-left: 8px; }\n .ag-theme-material .ag-label-align-top .ag-label {\n margin-bottom: 4px; }\n .ag-theme-material .ag-ltr .ag-slider-field, .ag-theme-material .ag-ltr .ag-angle-select-field {\n margin-right: 16px; }\n .ag-theme-material .ag-rtl .ag-slider-field, .ag-theme-material .ag-rtl .ag-angle-select-field {\n margin-left: 16px; }\n .ag-theme-material .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #e2e2e2;\n border-color: var(--ag-border-color, #e2e2e2);\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-material .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: rgba(0, 0, 0, 0.54);\n background-color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #e2e2e2;\n border-color: var(--ag-border-color, #e2e2e2);\n border-radius: 5px; }\n .ag-theme-material .ag-picker-field-wrapper:focus {\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122); }\n .ag-theme-material .ag-picker-field-button {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-material .ag-color-picker .ag-picker-field-display {\n height: 18px; }\n .ag-theme-material .ag-color-panel {\n padding: 8px; }\n .ag-theme-material .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-material .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-material .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-material .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-material .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-material .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-material .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-material .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-material .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-material .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-material .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-material .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-material.ag-dnd-ghost {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 56px !important;\n line-height: 56px;\n margin: 0;\n padding: 0 16px;\n -webkit-transform: translateY(16px);\n transform: translateY(16px); }\n .ag-theme-material .ag-dnd-ghost-icon {\n margin-right: 8px;\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87)); }\n .ag-theme-material .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3); }\n .ag-dragging-range-handle .ag-theme-material .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-material .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-material .ag-dialog {\n border-radius: 0px; }\n .ag-theme-material .ag-panel {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-material .ag-panel-title-bar {\n background-color: #fff;\n background-color: var(--ag-header-background-color, #fff);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)));\n height: 56px;\n padding: 8px 24px; }\n .ag-theme-material .ag-ltr .ag-panel-title-bar-button {\n margin-left: 8px; }\n .ag-theme-material .ag-rtl .ag-panel-title-bar-button {\n margin-right: 8px; }\n .ag-theme-material .ag-tooltip {\n background-color: #fff;\n background-color: var(--ag-header-background-color, #fff);\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87));\n padding: 8px;\n border-radius: 2px;\n transition: opacity 1s; }\n .ag-theme-material .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-1 {\n padding-left: 26px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-1 {\n padding-right: 26px; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-2 {\n padding-left: 52px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-2 {\n padding-right: 52px; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-3 {\n padding-left: 78px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-3 {\n padding-right: 78px; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-4 {\n padding-left: 104px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-4 {\n padding-right: 104px; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-5 {\n padding-left: 130px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-5 {\n padding-right: 130px; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-6 {\n padding-left: 156px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-6 {\n padding-right: 156px; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-7 {\n padding-left: 182px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-7 {\n padding-right: 182px; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-8 {\n padding-left: 208px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-8 {\n padding-right: 208px; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-9 {\n padding-left: 234px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-9 {\n padding-right: 234px; }\n .ag-theme-material .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-material .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 12px; }\n .ag-theme-material .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 12px; }\n .ag-theme-material .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -4px;\n left: -4px;\n display: block;\n width: calc(100% - -8px);\n height: calc(100% - -8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -4px;\n left: -4px;\n display: block;\n width: calc(100% - -8px);\n height: calc(100% - -8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-column-select-column-group:not(:last-child),\n .ag-theme-material .ag-column-select-column:not(:last-child) {\n margin-bottom: 14px; }\n .ag-theme-material .ag-column-select-column-readonly,\n .ag-theme-material .ag-column-select-column-group-readonly {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n pointer-events: none; }\n .ag-theme-material .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 34px; }\n .ag-theme-material .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 34px; }\n .ag-theme-material .ag-column-select-list {\n padding: 16px 12px; }\n .ag-theme-material .ag-rtl {\n text-align: right; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 66px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 66px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-1 {\n padding-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-1 {\n padding-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 108px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 108px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-2 {\n padding-left: 84px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-2 {\n padding-right: 84px; }\n .ag-theme-material .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 150px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 150px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-3 {\n padding-left: 126px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-3 {\n padding-right: 126px; }\n .ag-theme-material .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 192px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 192px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-4 {\n padding-left: 168px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-4 {\n padding-right: 168px; }\n .ag-theme-material .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 234px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 234px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-5 {\n padding-left: 210px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-5 {\n padding-right: 210px; }\n .ag-theme-material .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 276px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 276px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-6 {\n padding-left: 252px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-6 {\n padding-right: 252px; }\n .ag-theme-material .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 318px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 318px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-7 {\n padding-left: 294px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-7 {\n padding-right: 294px; }\n .ag-theme-material .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 360px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 360px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-8 {\n padding-left: 336px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-8 {\n padding-right: 336px; }\n .ag-theme-material .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 402px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 402px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-9 {\n padding-left: 378px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-9 {\n padding-right: 378px; }\n .ag-theme-material .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 444px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 444px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-10 {\n padding-left: 420px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-10 {\n padding-right: 420px; }\n .ag-theme-material .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 486px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 486px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-11 {\n padding-left: 462px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-11 {\n padding-right: 462px; }\n .ag-theme-material .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 528px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 528px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-12 {\n padding-left: 504px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-12 {\n padding-right: 504px; }\n .ag-theme-material .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 570px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 570px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-13 {\n padding-left: 546px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-13 {\n padding-right: 546px; }\n .ag-theme-material .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 612px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 612px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-14 {\n padding-left: 588px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-14 {\n padding-right: 588px; }\n .ag-theme-material .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 654px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 654px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-15 {\n padding-left: 630px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-15 {\n padding-right: 630px; }\n .ag-theme-material .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 696px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 696px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-16 {\n padding-left: 672px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-16 {\n padding-right: 672px; }\n .ag-theme-material .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 738px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 738px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-17 {\n padding-left: 714px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-17 {\n padding-right: 714px; }\n .ag-theme-material .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 780px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 780px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-18 {\n padding-left: 756px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-18 {\n padding-right: 756px; }\n .ag-theme-material .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 822px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 822px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-19 {\n padding-left: 798px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-19 {\n padding-right: 798px; }\n .ag-theme-material .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-material .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-material .ag-value-change-delta-up {\n color: #43a047;\n color: var(--ag-value-change-delta-up-color, #43a047); }\n .ag-theme-material .ag-value-change-delta-down {\n color: #e53935;\n color: var(--ag-value-change-delta-down-color, #e53935); }\n .ag-theme-material .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-material .ag-value-change-value-highlight {\n background-color: #00acc1;\n background-color: var(--ag-value-change-value-highlight-background-color, #00acc1);\n transition: background-color 0.1s; }\n .ag-theme-material .ag-cell-data-changed {\n background-color: #00acc1 !important;\n background-color: var(--ag-value-change-value-highlight-background-color, #00acc1) !important; }\n .ag-theme-material .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-material .ag-cell-highlight {\n background-color: #fce4ec !important;\n background-color: var(--ag-range-selection-highlight-color, #fce4ec) !important; }\n .ag-theme-material .ag-row {\n height: 48px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-data-color, var(--ag-foreground-color, rgba(0, 0, 0, 0.87)));\n border-width: 1px;\n border-color: #e2e2e2;\n border-color: var(--ag-row-border-color, var(--ag-secondary-border-color, var(--ag-border-color, #e2e2e2))); }\n .ag-theme-material .ag-row:not(.ag-row-first) {\n border-top-style: solid; }\n .ag-theme-material .ag-row.ag-row-last {\n border-bottom-style: solid; }\n .ag-theme-material .ag-row-highlight-above::after, .ag-theme-material .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #3f51b5;\n background-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n left: 1px; }\n .ag-theme-material .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-material .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-material .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-material .ag-row-odd {\n background-color: var(--ag-odd-row-background-color); }\n .ag-theme-material .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #e2e2e2;\n border-right-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #e2e2e2;\n border-left-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-row-hover {\n background-color: #fafafa;\n background-color: var(--ag-row-hover-color, #fafafa); }\n .ag-theme-material .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-material .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-material .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-material .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-material .ag-cell {\n border: 1px solid transparent;\n line-height: 46px;\n padding-left: 23px;\n padding-right: 23px; }\n .ag-theme-material .ag-row > .ag-cell-wrapper {\n padding-left: 23px;\n padding-right: 23px; }\n .ag-theme-material .ag-row-dragging {\n cursor: move; }\n .ag-theme-material .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-material .ag-cell-inline-editing {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px;\n padding: 0;\n height: 48px;\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa); }\n .ag-theme-material .ag-popup-editor {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px;\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa);\n padding: 0; }\n .ag-theme-material .ag-large-text-input {\n height: auto;\n padding: 24px; }\n .ag-theme-material .ag-details-row {\n padding: 40px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-material .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66)); }\n .ag-theme-material .ag-overlay-loading-center {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px; }\n .ag-theme-material .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-material .ag-loading {\n padding-left: 24px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-material .ag-loading-icon {\n padding-right: 24px; }\n .ag-theme-material .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-material .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #e2e2e2;\n border-top-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-ltr .ag-cell {\n border-right: solid transparent; }\n .ag-theme-material .ag-rtl .ag-cell {\n border-left: solid transparent; }\n .ag-theme-material .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-material .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-material .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #e2e2e2;\n border-left-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #e2e2e2;\n border-right-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-row-selected {\n background-color: #eee;\n background-color: var(--ag-selected-row-background-color, #eee); }\n .ag-theme-material .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(122, 134, 203, 0.1);\n background-color: var(--ag-range-selection-background-color, rgba(122, 134, 203, 0.1)); }\n .ag-theme-material .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1);\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)); }\n .ag-theme-material .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)); }\n .ag-theme-material .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(122, 134, 203, 0.1);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(122, 134, 203, 0.1))); }\n .ag-theme-material .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(122, 134, 203, 0.19);\n background-color: var(--ag-range-selection-background-color-2, rgba(122, 134, 203, 0.19)); }\n .ag-theme-material .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(122, 134, 203, 0.271);\n background-color: var(--ag-range-selection-background-color-3, rgba(122, 134, 203, 0.271)); }\n .ag-theme-material .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(122, 134, 203, 0.3439);\n background-color: var(--ag-range-selection-background-color-4, rgba(122, 134, 203, 0.3439)); }\n .ag-theme-material .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #3f51b5;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #3f51b5;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #3f51b5;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #3f51b5;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-material .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-material .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-material .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-material .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-material .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #3f51b5;\n border-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n outline: initial; }\n .ag-theme-material .ag-cell.ag-selection-fill-top,\n .ag-theme-material .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #3f51b5;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-material .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #3f51b5;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-material .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #3f51b5;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-cell.ag-selection-fill-bottom,\n .ag-theme-material .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #3f51b5;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-material .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #3f51b5;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-material .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #3f51b5;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-fill-handle, .ag-theme-material .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #3f51b5;\n background-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-ltr .ag-fill-handle, .ag-theme-material .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-material .ag-rtl .ag-fill-handle, .ag-theme-material .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-material .ag-fill-handle {\n cursor: cell; }\n .ag-theme-material .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-material .ag-cell-inline-editing {\n border-color: #ff4081 !important;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)) !important; }\n .ag-theme-material .ag-menu {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px;\n padding: 0; }\n .ag-theme-material .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 8px;\n padding-bottom: 8px; }\n .ag-theme-material .ag-menu-option-part {\n padding-top: 10px;\n padding-bottom: 10px;\n line-height: 18px; }\n .ag-theme-material .ag-menu-option-active {\n background-color: #fafafa;\n background-color: var(--ag-row-hover-color, #fafafa); }\n .ag-theme-material .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-material .ag-menu-option-text {\n margin-left: 8px; }\n .ag-theme-material .ag-menu-option-icon {\n padding-left: 16px;\n padding-right: 8px;\n min-width: 34px; }\n .ag-theme-material .ag-menu-option-shortcut {\n padding-left: 16px; }\n .ag-theme-material .ag-menu-separator {\n height: 16px; }\n .ag-theme-material .ag-menu-separator-cell:after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #e2e2e2;\n border-top-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-menu-option-popup-pointer {\n width: 34px;\n text-align: center; }\n .ag-theme-material .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-material .ag-tab {\n border-bottom: 2px solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n flex: 1 1 auto; }\n .ag-theme-material .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-tab-selected {\n border-bottom-color: #3f51b5;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-menu-header {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-material .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 16px; }\n .ag-theme-material .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 16px; }\n .ag-theme-material .ag-set-filter-select-all {\n padding-top: 16px; }\n .ag-theme-material .ag-set-filter-list {\n height: 240px; }\n .ag-theme-material .ag-set-filter-filter {\n margin-top: 16px;\n margin-left: 12px;\n margin-right: 12px; }\n .ag-theme-material .ag-filter-to {\n margin-top: 14px; }\n .ag-theme-material .ag-mini-filter {\n margin: 16px 12px;\n margin-bottom: 0; }\n .ag-theme-material .ag-set-filter-item {\n margin: 0px 12px; }\n .ag-theme-material .ag-ltr .ag-set-filter-item-value {\n margin-left: 12px; }\n .ag-theme-material .ag-rtl .ag-set-filter-item-value {\n margin-right: 12px; }\n .ag-theme-material .ag-filter-header-container {\n padding-bottom: 16px; }\n .ag-theme-material .ag-filter-apply-panel {\n padding: 16px 12px; }\n .ag-theme-material .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-material .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 16px; }\n .ag-theme-material .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 16px; }\n .ag-theme-material .ag-simple-filter-body-wrapper {\n padding: 16px 12px;\n padding-bottom: 2px; }\n .ag-theme-material .ag-simple-filter-body-wrapper > * {\n margin-bottom: 14px; }\n .ag-theme-material .ag-filter-no-matches {\n margin: 16px 12px; }\n .ag-theme-material .ag-side-bar {\n position: relative; }\n .ag-theme-material .ag-tool-panel-wrapper {\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa); }\n .ag-theme-material .ag-side-buttons {\n padding-top: 32px;\n width: 22px;\n position: relative;\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87));\n overflow: hidden; }\n .ag-theme-material button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 16px 0 16px 0;\n width: 100%;\n margin: 0;\n min-height: 144px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none; }\n .ag-theme-material button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-material .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-material .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-material .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 2px solid transparent; }\n .ag-theme-material .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-material .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #3f51b5;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-material .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 2px solid transparent; }\n .ag-theme-material .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-material .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #3f51b5;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-filter-toolpanel-header {\n height: 48px; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-header, .ag-theme-material .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 8px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-header, .ag-theme-material .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 8px; }\n .ag-theme-material .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridMaterial\";\n font-size: 18px;\n line-height: 18px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 8px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 8px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-0-header {\n height: 64px; }\n .ag-theme-material .ag-filter-toolpanel-group-item {\n margin-top: 4px;\n margin-bottom: 4px; }\n .ag-theme-material .ag-filter-toolpanel-search {\n height: 56px; }\n .ag-theme-material .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 32px; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 8px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 8px; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 8px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 8px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 24px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 24px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 40px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 40px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 56px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 56px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 72px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 72px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 88px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 88px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 104px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 104px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 120px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 120px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 136px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 136px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 152px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 152px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 168px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 168px; }\n .ag-theme-material .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 8px; }\n .ag-theme-material .ag-filter-toolpanel-instance-filter {\n padding-top: 8px; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 8px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 8px; }\n .ag-theme-material .ag-pivot-mode-panel {\n height: 56px;\n display: flex; }\n .ag-theme-material .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-material .ag-ltr .ag-pivot-mode-select {\n margin-left: 12px; }\n .ag-theme-material .ag-rtl .ag-pivot-mode-select {\n margin-right: 12px; }\n .ag-theme-material .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-column-select-header {\n height: 56px;\n align-items: center;\n padding: 0 12px; }\n .ag-theme-material .ag-column-group-icons,\n .ag-theme-material .ag-column-select-header-icon {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-header {\n background-color: #fff;\n background-color: var(--ag-header-background-color, #fff);\n border-bottom: solid 1px;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-header-row {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54))); }\n .ag-theme-material .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #e2e2e2;\n border-left-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #e2e2e2;\n border-right-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-header-row {\n height: 56px; }\n .ag-theme-material .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 8px; }\n .ag-theme-material .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 8px; }\n .ag-theme-material .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 8px; }\n .ag-theme-material .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 8px; }\n .ag-theme-material .ag-header-cell,\n .ag-theme-material .ag-header-group-cell {\n padding-left: 24px;\n padding-right: 24px; }\n .ag-theme-material .ag-header-cell.ag-header-cell-moving,\n .ag-theme-material .ag-header-group-cell.ag-header-cell-moving {\n background-color: #f2f2f2;\n background-color: var(--ag-header-cell-moving-background-color, var(--ag-header-cell-hover-background-color, #f2f2f2)); }\n .ag-theme-material .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-header-icon {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-material .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-material .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-material .ag-header-row:not(:first-child) .ag-header-cell,\n .ag-theme-material .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #e2e2e2;\n border-top-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-header-group-cell:not(.ag-column-resizing) + .ag-header-group-cell:not(.ag-header-cell-moving):hover, .ag-theme-material .ag-header-group-cell:not(.ag-column-resizing) + .ag-header-group-cell.ag-column-resizing,\n .ag-theme-material .ag-header-cell:not(.ag-column-resizing) + .ag-header-cell:not(.ag-header-cell-moving):hover,\n .ag-theme-material .ag-header-cell:not(.ag-column-resizing) + .ag-header-cell.ag-column-resizing,\n .ag-theme-material .ag-header-group-cell:first-of-type:not(.ag-header-cell-moving):hover,\n .ag-theme-material .ag-header-group-cell:first-of-type.ag-column-resizing,\n .ag-theme-material .ag-header-cell:first-of-type:not(.ag-header-cell-moving):hover,\n .ag-theme-material .ag-header-cell:first-of-type.ag-column-resizing {\n background-color: #f2f2f2;\n background-color: var(--ag-header-cell-hover-background-color, #f2f2f2); }\n .ag-theme-material .ag-ltr .ag-header-select-all {\n margin-right: 24px; }\n .ag-theme-material .ag-rtl .ag-header-select-all {\n margin-left: 24px; }\n .ag-theme-material .ag-ltr .ag-floating-filter-button {\n margin-left: 24px; }\n .ag-theme-material .ag-rtl .ag-floating-filter-button {\n margin-right: 24px; }\n .ag-theme-material .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 18px;\n padding: 0;\n width: 18px; }\n .ag-theme-material .ag-filter-loading {\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa);\n height: 100%;\n padding: 16px 12px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-material .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #e2e2e2;\n border-top-color: var(--ag-border-color, #e2e2e2);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 56px; }\n .ag-theme-material .ag-paging-panel > * {\n margin: 0 24px; }\n .ag-theme-material .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 18px; }\n .ag-theme-material .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-material .ag-paging-button-wrapper.ag-disabled {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n cursor: default; }\n .ag-theme-material .ag-paging-button-wrapper, .ag-theme-material .ag-paging-description {\n margin: 0 8px; }\n .ag-theme-material .ag-status-bar {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n padding-right: 32px;\n padding-left: 32px;\n line-height: 1.5; }\n .ag-theme-material .ag-status-name-value-value {\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87)); }\n .ag-theme-material .ag-status-bar-center {\n text-align: center; }\n .ag-theme-material .ag-status-name-value {\n margin-left: 8px;\n margin-right: 8px;\n padding-top: 16px;\n padding-bottom: 16px; }\n .ag-theme-material .ag-column-drop-cell {\n background: #e2e2e2;\n background: var(--ag-chip-background-color, #e2e2e2);\n border-radius: 32px;\n height: 32px;\n padding: 0 4px; }\n .ag-theme-material .ag-column-drop-cell-text {\n margin: 0 8px; }\n .ag-theme-material .ag-column-drop-cell-button {\n min-width: 32px;\n margin: 0 4px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-column-drop-cell-drag-handle {\n margin-left: 16px; }\n .ag-theme-material .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-material .ag-column-drop-horizontal {\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 48px; }\n .ag-theme-material .ag-ltr .ag-column-drop-horizontal {\n padding-left: 24px; }\n .ag-theme-material .ag-rtl .ag-column-drop-horizontal {\n padding-right: 24px; }\n .ag-theme-material .ag-column-drop-horizontal-cell-separator {\n margin: 0 8px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-column-drop-horizontal-empty-message {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-material .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 24px; }\n .ag-theme-material .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 24px; }\n .ag-theme-material .ag-column-drop-vertical-list {\n padding-bottom: 8px;\n padding-right: 8px;\n padding-left: 8px; }\n .ag-theme-material .ag-column-drop-vertical-cell {\n margin-top: 8px; }\n .ag-theme-material .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px; }\n .ag-theme-material .ag-column-drop-vertical-icon {\n margin-left: 8px;\n margin-right: 8px; }\n .ag-theme-material .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-material .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n margin-top: 8px; }\n .ag-theme-material .ag-select-agg-func-popup {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px;\n background: #fff;\n background: var(--ag-background-color, #fff);\n height: 140px;\n padding: 0; }\n .ag-theme-material .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 40px;\n padding-left: 16px; }\n .ag-theme-material .ag-select-agg-func-virtual-list-item:hover {\n background-color: #eee;\n background-color: var(--ag-selected-row-background-color, #eee); }\n .ag-theme-material .ag-chart-menu {\n border-radius: 2px;\n background: #fff;\n background: var(--ag-background-color, #fff); }\n .ag-theme-material .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 2px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-material .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: #e2e2e2;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #e2e2e2));\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-material .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-material .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-material .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-material .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-material .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-material .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-material .ag-chart-mini-thumbnail.ag-selected {\n border-color: #ff4081;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081))); }\n .ag-theme-material .ag-chart-settings-card-item {\n background: rgba(0, 0, 0, 0.87);\n background: var(--ag-foreground-color, rgba(0, 0, 0, 0.87));\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-material .ag-chart-settings-card-item.ag-selected {\n background-color: #ff4081;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081))); }\n .ag-theme-material .ag-chart-data-column-drag-handle {\n margin-left: 8px; }\n .ag-theme-material .ag-charts-settings-group-container {\n padding: 8px; }\n .ag-theme-material .ag-charts-data-group-container {\n padding: 16px 12px;\n padding-bottom: 2px; }\n .ag-theme-material .ag-charts-data-group-container > * {\n margin-bottom: 14px; }\n .ag-theme-material .ag-charts-format-top-level-group-container {\n margin-left: 16px;\n padding: 8px; }\n .ag-theme-material .ag-charts-format-top-level-group-item {\n margin: 8px 0; }\n .ag-theme-material .ag-charts-format-sub-level-group-container {\n padding: 16px 12px;\n padding-bottom: 2px; }\n .ag-theme-material .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 14px; }\n .ag-theme-material .ag-charts-group-container.ag-group-container-horizontal {\n padding: 8px; }\n .ag-theme-material .ag-chart-data-section,\n .ag-theme-material .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-material .ag-chart-menu-panel {\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa); }\n .ag-theme-material .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #e2e2e2;\n border-left-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #e2e2e2;\n border-right-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-material .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-material .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-material .ag-checkbox-input-wrapper {\n font-family: \"agGridMaterial\";\n font-size: 18px;\n line-height: 18px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 18px;\n height: 18px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 2px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-material .ag-checkbox-input-wrapper input, .ag-theme-material .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-material .ag-checkbox-input-wrapper:focus-within, .ag-theme-material .ag-checkbox-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122); }\n .ag-theme-material .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-material .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #333;\n color: var(--ag-checkbox-unchecked-color, #333);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-material .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #ff4081;\n color: var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-material .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #333;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, #333));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-material .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 36px;\n height: 18px;\n background-color: #333;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, #333));\n border-radius: 9px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #333;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #333)); }\n .ag-theme-material .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-material .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122); }\n .ag-theme-material .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-material .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #ff4081;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081)));\n border-color: #ff4081;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081))); }\n .ag-theme-material .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 18px;\n width: 18px;\n background-color: #fff;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #fff));\n border-radius: 9px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #333;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #333))); }\n .ag-theme-material .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 18px);\n border-color: #ff4081;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081))); }\n .ag-theme-material .ag-radio-button-input-wrapper {\n font-family: \"agGridMaterial\";\n font-size: 18px;\n line-height: 18px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 18px;\n height: 18px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 2px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 18px; }\n .ag-theme-material .ag-radio-button-input-wrapper input, .ag-theme-material .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-material .ag-radio-button-input-wrapper:focus-within, .ag-theme-material .ag-radio-button-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122); }\n .ag-theme-material .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-material .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #333;\n color: var(--ag-checkbox-unchecked-color, #333);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-material .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #ff4081;\n color: var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-material input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-material input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #e2e2e2;\n background-color: var(--ag-border-color, #e2e2e2);\n border-radius: 0px;\n border-radius: 2px; }\n .ag-theme-material input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #e2e2e2;\n background-color: var(--ag-border-color, #e2e2e2);\n border-radius: 0px;\n border-radius: 2px; }\n .ag-theme-material input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #e2e2e2;\n background-color: var(--ag-border-color, #e2e2e2);\n border-radius: 0px;\n border-radius: 2px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-material input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 18px;\n height: 18px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #333;\n border-color: var(--ag-checkbox-unchecked-color, #333);\n border-radius: 18px;\n -webkit-transform: translateY(-7.5px);\n transform: translateY(-7.5px); }\n .ag-theme-material input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 18px;\n height: 18px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #333;\n border-color: var(--ag-checkbox-unchecked-color, #333);\n border-radius: 18px; }\n .ag-theme-material input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 18px;\n height: 18px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #333;\n border-color: var(--ag-checkbox-unchecked-color, #333);\n border-radius: 18px; }\n .ag-theme-material input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-material input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n border-color: #ff4081;\n border-color: var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material input[class^='ag-'][type='range']:focus::-ms-thumb {\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n border-color: #ff4081;\n border-color: var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n border-color: #ff4081;\n border-color: var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: #ff4081;\n background-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: #ff4081;\n background-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material input[class^='ag-'][type='range']:active::-ms-track {\n background-color: #ff4081;\n background-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-material .ag-filter-toolpanel-header,\n .ag-theme-material .ag-filter-toolpanel-search,\n .ag-theme-material .ag-status-bar,\n .ag-theme-material .ag-header-row,\n .ag-theme-material .ag-panel-title-bar-title,\n .ag-theme-material .ag-side-button-button {\n font-size: 12px;\n font-weight: 600;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54))); }\n .ag-theme-material .ag-tab {\n height: 36px; }\n .ag-theme-material .ag-tabs-header,\n .ag-theme-material .ag-column-drop-horizontal {\n background-color: #eee;\n background-color: var(--ag-subheader-background-color, #eee); }\n .ag-theme-material .ag-tabs-body {\n padding: 4px 0; }\n .ag-theme-material .ag-tabs-body .ag-menu-list {\n padding-top: 0;\n padding-bottom: 0; }\n .ag-theme-material .ag-header-cell,\n .ag-theme-material .ag-header-group-cell {\n transition: background-color 0.5s; }\n .ag-theme-material .ag-row-last .ag-cell-inline-editing {\n bottom: 0; }\n .ag-theme-material .ag-cell-inline-editing {\n padding: 8px;\n height: 72px; }\n .ag-theme-material .ag-side-button-button {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-column-drop-vertical {\n border-bottom: solid 1px;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2);\n padding-top: 8px; }\n .ag-theme-material .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none; }\n .ag-theme-material .ag-column-drop-vertical-cell {\n margin-left: 0; }\n .ag-theme-material .ag-set-filter-select-all {\n border-bottom: solid 1px;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-column-drop-vertical-empty-message {\n font-size: 12px;\n font-weight: 600;\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-material .ag-ltr .ag-column-drop-vertical-empty-message {\n padding-left: 34px;\n padding-right: 8px; }\n .ag-theme-material .ag-rtl .ag-column-drop-vertical-empty-message {\n padding-right: 34px;\n padding-left: 8px; }\n .ag-theme-material .ag-status-bar {\n border: solid 1px;\n border-color: #e2e2e2;\n border-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-column-panel-column-select {\n border-top: solid 1px;\n border-top-color: #e2e2e2;\n border-top-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-column-select, .ag-theme-material .ag-column-select-header {\n border-bottom: solid 1px;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-column-select-header {\n height: 56px; }\n .ag-theme-material .ag-group-title-bar {\n padding: 6px 8px; }\n .ag-theme-material .ag-charts-format-sub-level-group-title-bar {\n padding: 4px 8px; }\n .ag-theme-material .ag-chart-data-section,\n .ag-theme-material .ag-chart-format-section {\n padding-bottom: 4px; }\n .ag-theme-material .ag-group-toolbar {\n background-color: rgba(238, 238, 238, 0.5); }\n .ag-theme-material input[class^='ag-']:not([type]),\n .ag-theme-material input[class^='ag-'][type='text'],\n .ag-theme-material input[class^='ag-'][type='number'],\n .ag-theme-material input[class^='ag-'][type='tel'],\n .ag-theme-material input[class^='ag-'][type='date'],\n .ag-theme-material input[class^='ag-'][type='datetime-local'],\n .ag-theme-material textarea[class^='ag-'] {\n background: transparent;\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87));\n font-family: inherit;\n font-size: inherit;\n height: 40px;\n padding-bottom: 8px;\n border-width: 0;\n border-bottom: 2px solid;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material input:focus[class^='ag-']:not([type]),\n .ag-theme-material input:focus[class^='ag-'][type='text'],\n .ag-theme-material input:focus[class^='ag-'][type='number'],\n .ag-theme-material input:focus[class^='ag-'][type='tel'],\n .ag-theme-material input:focus[class^='ag-'][type='date'],\n .ag-theme-material input:focus[class^='ag-'][type='datetime-local'],\n .ag-theme-material textarea:focus[class^='ag-'] {\n border-bottom: 2px solid;\n border-bottom-color: #3f51b5;\n border-bottom-color: var(--ag-material-primary-color, #3f51b5);\n outline: none;\n box-shadow: none; }\n .ag-theme-material input:not([type])[class^='ag-']::-webkit-input-placeholder, .ag-theme-material input[type='text'][class^='ag-']::-webkit-input-placeholder, .ag-theme-material input[type='number'][class^='ag-']::-webkit-input-placeholder, .ag-theme-material input[type='tel'][class^='ag-']::-webkit-input-placeholder, .ag-theme-material input[type='date'][class^='ag-']::-webkit-input-placeholder, .ag-theme-material input[type='datetime-local'][class^='ag-']::-webkit-input-placeholder, .ag-theme-material textarea[class^='ag-']::-webkit-input-placeholder {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-material input:not([type])[class^='ag-']::-moz-placeholder, .ag-theme-material input[type='text'][class^='ag-']::-moz-placeholder, .ag-theme-material input[type='number'][class^='ag-']::-moz-placeholder, .ag-theme-material input[type='tel'][class^='ag-']::-moz-placeholder, .ag-theme-material input[type='date'][class^='ag-']::-moz-placeholder, .ag-theme-material input[type='datetime-local'][class^='ag-']::-moz-placeholder, .ag-theme-material textarea[class^='ag-']::-moz-placeholder {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-material input:not([type])[class^='ag-']:-ms-input-placeholder, .ag-theme-material input[type='text'][class^='ag-']:-ms-input-placeholder, .ag-theme-material input[type='number'][class^='ag-']:-ms-input-placeholder, .ag-theme-material input[type='tel'][class^='ag-']:-ms-input-placeholder, .ag-theme-material input[type='date'][class^='ag-']:-ms-input-placeholder, .ag-theme-material input[type='datetime-local'][class^='ag-']:-ms-input-placeholder, .ag-theme-material textarea[class^='ag-']:-ms-input-placeholder {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-material input:not([type])[class^='ag-']::-ms-input-placeholder, .ag-theme-material input[type='text'][class^='ag-']::-ms-input-placeholder, .ag-theme-material input[type='number'][class^='ag-']::-ms-input-placeholder, .ag-theme-material input[type='tel'][class^='ag-']::-ms-input-placeholder, .ag-theme-material input[type='date'][class^='ag-']::-ms-input-placeholder, .ag-theme-material input[type='datetime-local'][class^='ag-']::-ms-input-placeholder, .ag-theme-material textarea[class^='ag-']::-ms-input-placeholder {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-material input:not([type])[class^='ag-']::placeholder,\n .ag-theme-material input[type='text'][class^='ag-']::placeholder,\n .ag-theme-material input[type='number'][class^='ag-']::placeholder,\n .ag-theme-material input[type='tel'][class^='ag-']::placeholder,\n .ag-theme-material input[type='date'][class^='ag-']::placeholder,\n .ag-theme-material input[type='datetime-local'][class^='ag-']::placeholder,\n .ag-theme-material textarea[class^='ag-']::placeholder {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-material input:disabled[class^='ag-']:not([type]),\n .ag-theme-material input:disabled[class^='ag-'][type='text'],\n .ag-theme-material input:disabled[class^='ag-'][type='number'],\n .ag-theme-material input:disabled[class^='ag-'][type='tel'],\n .ag-theme-material input:disabled[class^='ag-'][type='date'],\n .ag-theme-material input:disabled[class^='ag-'][type='datetime-local'],\n .ag-theme-material textarea:disabled[class^='ag-'] {\n border-bottom: 1px solid;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-standard-button {\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background-color: transparent;\n border: 0;\n color: #3f51b5;\n color: var(--ag-material-primary-color, #3f51b5);\n font-family: inherit;\n font-size: inherit;\n margin: 0;\n padding: 0;\n text-transform: uppercase; }\n .ag-theme-material .ag-standard-button:disabled {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n background-color: var(--ag-input-disabled-background-color);\n border-color: var(--ag-input-disabled-border-color); }\n .ag-theme-material .ag-dnd-ghost {\n font-size: 12px;\n font-weight: 600; }\n .ag-theme-material .ag-filter-toolpanel-header {\n height: 32px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-0-header {\n height: 56px; }\n .ag-theme-material .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 60px; }\n\n", ""]); +exports.push([module.i, ".ag-theme-material {\n -webkit-font-smoothing: antialiased;\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87));\n font-family: \"Roboto\", sans-serif;\n font-size: 13px;\n line-height: normal;\n}\n@font-face {\n font-family: \"agGridMaterial\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABPwAAsAAAAAJjAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAmMAAAR2ZOVnMk9TLzIAAANsAAAAQQAAAFZWUFMDY21hcAAAA7AAAAIRAAAFnH0V34BnbHlmAAAFxAAACj0AABO8Q1oUYmhlYWQAABAEAAAAMQAAADZ2zsSBaGhlYQAAEDgAAAAWAAAAJAfRBDVobXR4AAAQUAAAABIAAAEww1AAAGxvY2EAABBkAAAAcwAAAJoHSQMCbWF4cAAAENgAAAAfAAAAIAFfAKpuYW1lAAAQ+AAAATIAAAJebBQ2inBvc3QAABIsAAABwgAAAqTvU9OHeJx9lEtyElEUhv+mm0gCklSMGjFq1PhCjZpO09DhYUIHAjpwYFkOnMSyyrKKcsQ6XIAryNAVuAAHrsAFOHDo2PK7h0ZMBuEWl3vP4z//eVzkSVrQY7WVS3vPX6o8Ohx/VEWBJh+n///sjT68P1RhekMX2G9BXlBSWTf0WmN988re2DvKrfgV/5X/zv/sf/F/ycdqXZtYF7XNilRjDxWrroYS5TSHLOK8oybWPnvLpMswypump74uETPCp2+IVQ11R0vgpIbT1S5WMcthdtmHrLtaPMUi0T3w67DpIA2oyFVq0tR5zesAll3Obfyb6M8Rc4/YIV4puhR2eSQtzm1dgJPzCKyqB3rDvmyZOpR65hPzjbRv99BuRdbUqgVOg1gO+wkMpvIGUWt4PAK9jtXTrKJV3cS7AU4XtLZ575h3Ecsa3GL6ElieNbiWtMHphd7qIRb7mU/XajqpwH3Yz+Sp4SV6cEzaBmuI7SYcZlLXnyqxQg0sq1UkI33Skb7qu37op37rj85Qpw56l8Mu6Hun1qZABU9a99C2/kldrnPMwEmr4xbzZN6w6kTo+lkNXbQimbnqxJxDpLHZL8DT2fdgk9CPgBihxXWdzrM63COsz2bT2WSVrNJ9er9oEzywWagwgVtMlUOczGFCra+A6E4Tfpetbk3w1qxvrrruhS3Zzb0F1+8KfbjGb0iGdavTM7TXkTikmWTdvBLYO4wt9AmsZ9EcqzVYbdtEuxkb2OvoEWmDfCZMarptL2Ng83ULBvXspa7oorFvZx1bNbvIvDz+CcLshcdWOzfTKdzcfAz/Au6DcHUAeJxjYGSaxDiBgZWBgamKaQ8DA0MPhGZ8wGDIyAQUZWBlZsAKAtJcUxgOMOh+NGJ+AeRGMb9hYAHSjCA5AOMfCvMAAAB4nLXUB1IbQRCF4V+BLMC2MDknR9kgBCIHIUDAKXCmcKBw5hw+m+/RJ8Bv1O0D4Cpv1afeGa12Z7T1GmgBcvJU8pBtJ6MzMlnNZprzOTqb83l+a1ygnazOS5xzybWVb240W+KMC64s0xz9PTK6usAo86xotM8Se2xR1+iECjussss2B6yzxhHLbFLlkGM2qNHgVL9Pq8hrja206bkdWkmX7thND3e4S5E++hlgkCGGGdGTxhhngkmmdN00M8wyp6cXecBDHvGYJ9pPiWc81/cLLFLWIlu53bF/y+vTsbS3VV85qexox9sH62va7Gb18Hij1jj9h5v9h6OQPnK/YpQWVQppt2dhSV6EPXkZtuRVqMvrkN76m3Aib0NF3oUdOQ+rchF25X3Ylg/hQD6GdfkU1uQyHMlVWJbPYVO+hKp8DYfyLRzL97AhP0JNfoaGXAf9V5ZxKS+WdaSacylflncpY9biUvas1ZFqmyPVdkeqHY5UO13KpHU5Ui249Cat25FqjyPVXqfsYEEpwoJygt1zShZWdMoY1ueUNuy+U+6wfqcEYgNOWcQGnVKJDTnlExt2Sio24pRZbNQpvdiYU46xcadEYxOuud9Jp5RjU055x6adko/NOPUAbNapG2BzrrnfeacOgQX1Ciyoa2BB/QML6iRYSL3TQsqMBfUZLKjjYKG5/gVHqouOVMuO8h8D8KVRAAAAeJztWH1sG+UZv+e92Ofz99m+O3tN7NgX+0qTGsXn88V2miZN2mSMpJ1sOvpFCqwtkNK0UAaFRTDEpDJGizTCH6BJoEmONAkGyz9lQy3qQHRC2lzRMQl13cQ/JIxFRYpAMvVtz3ux04ZmjP2JtuTe9557P557Pn73Ps9jBhj8IwvsJsbFMBAXPSDG9bihxsmC6Qaf+SksmhfPn4cOdqBUq5WmqlWGaaF72NfY1xg742FCzBrcqemaymmconOyriVVURE1UVVERTYUeKkyefbsZA/tyPDZyckZ65k8iv0MpUpnJyuTBlLI1pKH3YTyOBgmKBuCJsgGzBTmy3NFcxYWi/OmDb6YL8Ioim2tnWanUYZ23Jrg7Jw9JEuylDFyRi6rptRUkFM51VAN2ZA5WDxy+7iRzxvjt3/YJMYLzz1XmJ62enZ6xZRF1H/fnMWevs56Z5gNI8VRmwU1QaHN0ESlOjX18dGj8w88QO42D5CR+qlazTKvtWeOnWOCTIRaOeEFUQhFQYtn+kAXsmngwZBBZo9d+SyqRfFinda9vmB+PHYOKmPsHD6vmLzyGUhj70Bl60r+8ur8WXTqddyfrl8gXddzrl84fC1P1uIpxIXkanyRJ+v8Et+lwckv823Y7iH2+4wNvRtmGB44mQfWiIGduk4MSZmcTt1G/m6OF+4069B37tw7r7pcEZ/Uvblb8kXgLLxUxAnzd7Dh3Lk+jye6JhVJdHcnIsnWKGXPL+NnyT8+yyZrmBijUF/pCm0cNh2bjM0QNd3WGBewzVQqNetq3M29jSfyQqW+H+/lSmMAZ/BqYpacJAuoF4MqcYjYZwunTxdqZKF45kyxtoybx9gzluatlpfsIqI7LltESEKj5tCmKTYuxMmrplvpLsPilKlT7eBd2ps6vMue7k7UXyfDpW6l/jodJMNKd30fGV7+dig26beMuLdEkQ2VDRfn55sX+cs1D/gFM/+8wh5iP2H8aKk2ZoR5jPk57sZPR7VdIxir6IgB2S5LRQgmQ16iJNIteraPaJkoiCF7IqWmQcENCI9MzuiDjCSHvDiCw3o2l4myGvVtGtQ0yfYB7iKNTUt7YiDJUYLC5oxu3ByFkOgDL0mk4UYWt0vsvdz+wzZzTDUMleRUY8usuQmeJMDa/B8Qc5wPREN+OeR32jzheFDuCDo9jhZHyCe3uuV2yU4cXudrgYTUJnj8vNfBOXxuQXIF/KE1QiAmBcKCw+nhWmy+aMDusgUCLk/A2du5jrDE4XLYiE44p89tJxoLzoCDfOT4weM20qNe+aMlzJPVKz9hH/pThBfqz/zZHYsGHYE17UkxoadCrWqA9zk9Yiibae+UwmGnz+uL3CD5XMmAy+uKCG454BUcdi4YTyeDHjEs+p0uXyDo4V08y3E2Lth24rdv8C67k/M4bfwF3ufgvfwffLzTH6Cu/r/vvrm+WxHn8FsVFEHlgB2wAh2M0kAHX5i2eQx6NN6u8PO3/6OPDRr6sjktI8VgI6Euk8SQD2R0jRcSqRuBoyBI6dmvds36Hd/hOVvIJwT9vf1Or93j8AXFsbLbyQdCgZZbv9fCCzjyVUY9d2zC63FJ/mB4505fwGbzu4W2e4/5xICX5+2PPmx32AWfZY//BR1Xxgk8nZHRiUKtVjhNZou1WvHMMi52kDmmiA9p1MDOqagkqiV7AUlDwQFFtqNqqhLFT9igNH6LOCXbOY0ulmTyLJceUuNFeXTHgW0jW+5plW/pGUvyg5ywbmzIwcezjkFu/Wa1o314cATnJ1pT393FtzxxQ9va9ixPhOQGJSKNarHYoeENd8RHk1o4sG4zqLFUn+Lb8i06vLd/dzC0tjUV/YbKzC7LHMDcYK2VPaKsKDEmj31goGwpFk+w7NKB5gU2YafpSTYFi5ZwrfdsGXkRibY2JLZ13dTVddOttOtam89vy+fJR/SNw4disebdnGiswA5YumZbvinHBGKikU8mMQehOThgxoaZc8W8SBbqJzELd9dK8FKpZF4sL+eU5HMLSzxFk4F4AsxDyedvvolgMvVyGXSafNTo3kY+t4kcsd5DM/24jeaEA/X95PlGO1KaKTXiCq69jXUi5WQERsSsNUb3oBk6gQpn0MAR14NWFoWZv0LDAhkGCdO8GZDMj2eQMN2T9O8STQRhlHZjhw9fwvtk/cLk5GE6fJ0eQZqxqHHU41NLDXiwXCazlhqoxHXnJhYqmDmrqMbSUQmj9Ngk0fmCOWvOFuab9p0mb2ONEGa68A0oahF0BXNZDF0WlQYZTZHEkmXJ1Z2AVB9gwPtFolepVPJ7e3r25isVpTfxSxgzfw0PUlpRludgUSkqW3vG7xvv2aoUuXIF+y10ZO+R8Z5mLu1Ee8qWHbEUwWJB5rBK0rE4oQY0sGpiNUNXFU4kXfu27n/mmf1b9x1eJvbvHhjYPUAeXjFICfORATrVsMsEO0E1DqJ3pxA2AXaixKyCMQPVtf7Rh9a6pYblXblaKjXOqQXmPN1pIC8LQlULG6vyEhp4naLrmvyuwpW9pk6LM+l/U6lBlpL0IIA04AGuAk1O6MLV6jZz0/qum0d35e/qNNcnOmAUCXgv0UEHVyvjzPFdozd3re9ImOs77zI/6UjAe5135a2xpk4HMTeX0D8qyqfQ1IZTVibmSjwj0bwnm4O4oKHKGhv+lad/W7/3FSsRH7Fy9ItCJJKIRECvnyrDi2V2IplOJzFn32eteSHRHVbCeKGNXpiaamKjn+1DKXy0elCNIFiZO61ZVdj1lPrUX6ErGr3cu/3yLb3HopDDEfibeSEaPdZ7y+XtvZevqXtoTb5U7yioR5rJMDmmgGdKHDGOKvTRyi1KazgvAMId9Ygnl16FyBO1pFUsy3SKfg0GNnpAxLS2Ni1Gnrfu9X9UKujmIXjD/HDjRvXAAfV9HPhE7d+49sABM4S0dOnSpUql5+qWmMUCxAr82HzklY39uGktvD9zo9pPSXiaFlOVFXVyiLmhiRI/RUk7hYafooRNWGGfPmfoTAMgx48eGRwaGjxyFPxN6vi9e3bqhqHv3PNBk2Dn6IR5eeXiKz9cscgiGpigsrgRszkqjXVgLJ0L6n8h2tD9g4P3H6fd0NeTkiw01mNX+9oCX3c2cjJ+uRgTrv3NxMov5wsw2rA1PS88iHqrvleWsW4zLEwICPD6qdIStM3Zg4VqtXCwTH8Qgg7zolWXdrQeLFarxYPws+X85m2yh3IHLII7qlWym/5i1Jzbg+cwsWSj4+St1eYQ9D+tVule5jqeiE0cp/NX9b2TdTfzKVDh0MvFOVgsQOnlwjzemzUxiTbPxSr9XYZEy8u8F8jJpbqdJmSNWENO0Or9at0+jXaicTBDzwaxUTZxch/QqohTZI0mOuLVeIJVkyHjQhkvA8hbVrww1m3IbuzZe8fusqN+6vHCSDOmbOreHrtvfGQmWx8mb2HkULo2uzasuaM3P95TKcPBH4Xv7s9bgUXpvsm2vXwbriS/Qan+BR+vOg4AAAB4nGNgZGBgAGKpH/rO8fw2Xxm4mV8ABaI4H+9rQND//zC/YH4DVMnBwAQkGQBX3Q0FAAAAeJxjYGRgYH7BwIBEMjKgAh8ARYYDEAAAeJxjYGBgYH4xPDA9AAANeC3nAAB4nGNgAAIpBg+GOIYZDJsYHjHyMJoxZjAuYtzC+IyJgeke8x7mSywuLNtYTrAqsdawHmC9w/qFjYvNgS2CrYBtE9sTtk/sXOwS7EbsTewH2J9wuHH0cDzj+MOpxmnC6cQZwBnHWcBZxzmB8x7pEAB+RDEmAHicY2BkYGDwYZjHwMkAAkxAzAWEDAz/wXwGACCLAgoAeJx9kD1qw0AQhZ/8F2JDCIS4UrEQSBOQf0qT2oKAGxfuZWsly6y1YrU2+AY5SE6QQ6TMQXKKPK23sQvPwvC9N2+mWACP+EGApgI8uN5UC3dUZ26Tnj13yC+euxhg4rlH/91zH2/48DzAEw68EHTu6YT49Nxi/stzm/635w7513MXQ/x57iEM4LmPVRB6HuA1MEkemyJdJFaaIlFLmR9UcmVeqpU0daFLMYnGl4NYltKQU7E+ifqYT63NRGb0Xsx1aaVSWlRG7+TGRltrq9lolHk/2ug9EuSIYVAgxYLKQjqVQGFJzvkXisrcTN6arRzXVBolBP8/wvjmRkwunT77KbfWOLHXOHJvStcio86Y0diT5u56k1Z8mk7lZjs6G/oRtm6rwgwjvuwqHzHFS/808m/eAAB4nG2SB2/bMBCF/cWS7dhpk6Ztuvceauvune6Z/giGomUiEimQlO3k15e1gwABegCJ9x7uju8ObC21FtFv/T+2WKJNQkqHLj2W6TNghSMcZZU1jrHOcU5wkg1OcZoznOUc57nARS5xmStc5RrXucFNbnGbO9zlHvfJeMBDHjHkMU94yjOe84KXvOI1b3jLO96zyQc+8onPfOEr3/jOD37yi99s8ac1EEXhVCGCtqYjnLNT3xZedqQwUpWpHAsX1uRYyZ1tO8vmQOUbB4I2uQrKVdqIoNYP5MbsZ65IW1qX1ToS142kqYzvS2uCEzKoPJG23k2ls963pZ+k8WTDJFdepmoWDXTndzbsqVkt4lv5stpVmS+FHw8OUDZsR9wZ6TJaSUfa+ZAUTtdp4WxTJzElJKUahU6pTfTULa3ItSl6lZjpSu+ppFKm6cUZFsxYowbGhkyUpZ2qPK1jA9WutUlrPbFhzcVym203IViT2dFo9bBgUqeLcUi8mKi+r2KXLLdTsw//GRks4Dytt8DRZ4hLWg9OqcNbXZ5Ltlam15jFBAgKHIqAxmKY4pGUjNlhm1n8FzkVDTW7TBix12r9BZxqtRIAAA==\") format(\"woff\");\n font-weight: normal;\n font-style: normal;\n}\n.ag-theme-material .ag-icon {\n font-family: \"agGridMaterial\";\n font-size: 18px;\n line-height: 18px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n.ag-theme-material .ag-icon-aggregation::before {\n content: \"\\f101\";\n}\n.ag-theme-material .ag-icon-arrows::before {\n content: \"\\f102\";\n}\n.ag-theme-material .ag-icon-asc::before {\n content: \"\\f103\";\n}\n.ag-theme-material .ag-icon-cancel::before {\n content: \"\\f104\";\n}\n.ag-theme-material .ag-icon-chart::before {\n content: \"\\f105\";\n}\n.ag-theme-material .ag-icon-color-picker::before {\n content: \"\\f109\";\n}\n.ag-theme-material .ag-icon-columns::before {\n content: \"\\f10a\";\n}\n.ag-theme-material .ag-icon-contracted::before {\n content: \"\\f10b\";\n}\n.ag-theme-material .ag-icon-copy::before {\n content: \"\\f10c\";\n}\n.ag-theme-material .ag-icon-cross::before {\n content: \"\\f10d\";\n}\n.ag-theme-material .ag-icon-csv::before {\n content: \"\\f10e\";\n}\n.ag-theme-material .ag-icon-desc::before {\n content: \"\\f10f\";\n}\n.ag-theme-material .ag-icon-excel::before {\n content: \"\\f110\";\n}\n.ag-theme-material .ag-icon-expanded::before {\n content: \"\\f111\";\n}\n.ag-theme-material .ag-icon-eye-slash::before {\n content: \"\\f112\";\n}\n.ag-theme-material .ag-icon-eye::before {\n content: \"\\f113\";\n}\n.ag-theme-material .ag-icon-filter::before {\n content: \"\\f114\";\n}\n.ag-theme-material .ag-icon-first::before {\n content: \"\\f115\";\n}\n.ag-theme-material .ag-icon-grip::before {\n content: \"\\f116\";\n}\n.ag-theme-material .ag-icon-group::before {\n content: \"\\f117\";\n}\n.ag-theme-material .ag-icon-last::before {\n content: \"\\f118\";\n}\n.ag-theme-material .ag-icon-left::before {\n content: \"\\f119\";\n}\n.ag-theme-material .ag-icon-linked::before {\n content: \"\\f11a\";\n}\n.ag-theme-material .ag-icon-loading::before {\n content: \"\\f11b\";\n}\n.ag-theme-material .ag-icon-maximize::before {\n content: \"\\f11c\";\n}\n.ag-theme-material .ag-icon-menu::before {\n content: \"\\f11d\";\n}\n.ag-theme-material .ag-icon-minimize::before {\n content: \"\\f11e\";\n}\n.ag-theme-material .ag-icon-next::before {\n content: \"\\f11f\";\n}\n.ag-theme-material .ag-icon-none::before {\n content: \"\\f120\";\n}\n.ag-theme-material .ag-icon-not-allowed::before {\n content: \"\\f121\";\n}\n.ag-theme-material .ag-icon-paste::before {\n content: \"\\f122\";\n}\n.ag-theme-material .ag-icon-pin::before {\n content: \"\\f123\";\n}\n.ag-theme-material .ag-icon-pivot::before {\n content: \"\\f124\";\n}\n.ag-theme-material .ag-icon-previous::before {\n content: \"\\f125\";\n}\n.ag-theme-material .ag-icon-right::before {\n content: \"\\f128\";\n}\n.ag-theme-material .ag-icon-save::before {\n content: \"\\f129\";\n}\n.ag-theme-material .ag-icon-small-down::before {\n content: \"\\f12a\";\n}\n.ag-theme-material .ag-icon-small-left::before {\n content: \"\\f12b\";\n}\n.ag-theme-material .ag-icon-small-right::before {\n content: \"\\f12c\";\n}\n.ag-theme-material .ag-icon-small-up::before {\n content: \"\\f12d\";\n}\n.ag-theme-material .ag-icon-tick::before {\n content: \"\\f12e\";\n}\n.ag-theme-material .ag-icon-tree-closed::before {\n content: \"\\f12f\";\n}\n.ag-theme-material .ag-icon-tree-indeterminate::before {\n content: \"\\f130\";\n}\n.ag-theme-material .ag-icon-tree-open::before {\n content: \"\\f131\";\n}\n.ag-theme-material .ag-icon-unlinked::before {\n content: \"\\f132\";\n}\n.ag-theme-material .ag-icon-row-drag::before {\n content: \"\\f116\";\n}\n.ag-theme-material .ag-left-arrow::before {\n content: \"\\f119\";\n}\n.ag-theme-material .ag-right-arrow::before {\n content: \"\\f128\";\n}\n.ag-theme-material .ag-root-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-material [class^=ag-], .ag-theme-material [class^=ag-]:focus, .ag-theme-material [class^=ag-]:after, .ag-theme-material [class^=ag-]:before {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n outline: none;\n}\n.ag-theme-material [class^=ag-]::-ms-clear {\n display: none;\n}\n.ag-theme-material .ag-checkbox .ag-input-wrapper,\n.ag-theme-material .ag-radio-button .ag-input-wrapper {\n overflow: visible;\n}\n.ag-theme-material .ag-range-field .ag-input-wrapper {\n height: 100%;\n}\n.ag-theme-material .ag-toggle-button {\n -webkit-box-flex: 0;\n flex: none;\n width: unset;\n min-width: unset;\n}\n.ag-theme-material .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 8px;\n}\n\n.ag-theme-material .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 8px;\n}\n\n.ag-theme-material input[class^=ag-] {\n margin: 0;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-material textarea[class^=ag-],\n.ag-theme-material select[class^=ag-] {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-material input[class^=ag-]:not([type]),\n.ag-theme-material input[class^=ag-][type=text],\n.ag-theme-material input[class^=ag-][type=number],\n.ag-theme-material input[class^=ag-][type=tel],\n.ag-theme-material input[class^=ag-][type=date],\n.ag-theme-material input[class^=ag-][type=datetime-local],\n.ag-theme-material textarea[class^=ag-] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n}\n.ag-theme-material input[class^=ag-]:not([type]):disabled,\n.ag-theme-material input[class^=ag-][type=text]:disabled,\n.ag-theme-material input[class^=ag-][type=number]:disabled,\n.ag-theme-material input[class^=ag-][type=tel]:disabled,\n.ag-theme-material input[class^=ag-][type=date]:disabled,\n.ag-theme-material input[class^=ag-][type=datetime-local]:disabled,\n.ag-theme-material textarea[class^=ag-]:disabled {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n background-color: var(--ag-input-disabled-background-color);\n border-color: var(--ag-input-disabled-border-color);\n}\n.ag-theme-material input[class^=ag-]:not([type]):focus,\n.ag-theme-material input[class^=ag-][type=text]:focus,\n.ag-theme-material input[class^=ag-][type=number]:focus,\n.ag-theme-material input[class^=ag-][type=tel]:focus,\n.ag-theme-material input[class^=ag-][type=date]:focus,\n.ag-theme-material input[class^=ag-][type=datetime-local]:focus,\n.ag-theme-material textarea[class^=ag-]:focus {\n outline: none;\n -webkit-box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n border-color: #3f51b5;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material input[class^=ag-]:not([type]):invalid,\n.ag-theme-material input[class^=ag-][type=text]:invalid,\n.ag-theme-material input[class^=ag-][type=number]:invalid,\n.ag-theme-material input[class^=ag-][type=tel]:invalid,\n.ag-theme-material input[class^=ag-][type=date]:invalid,\n.ag-theme-material input[class^=ag-][type=datetime-local]:invalid,\n.ag-theme-material textarea[class^=ag-]:invalid {\n border-width: 2px;\n border-style: solid;\n border-color: var(--ag-input-border-color-invalid);\n}\n.ag-theme-material input[class^=ag-][type=number] {\n -moz-appearance: textfield;\n}\n.ag-theme-material input[class^=ag-][type=number]::-webkit-outer-spin-button, .ag-theme-material input[class^=ag-][type=number]::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n}\n.ag-theme-material input[class^=ag-][type=range] {\n padding: 0;\n}\n.ag-theme-material input[class^=ag-][type=button]:focus, .ag-theme-material button[class^=ag-]:focus {\n -webkit-box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n}\n.ag-theme-material .ag-drag-handle {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-material .ag-list-item, .ag-theme-material .ag-virtual-list-item {\n height: 32px;\n}\n.ag-theme-material .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-material .ag-keyboard-focus .ag-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #3f51b5;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-select-list {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n overflow-y: auto;\n overflow-x: hidden;\n}\n.ag-theme-material .ag-list-item {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-material .ag-list-item.ag-active-item {\n background-color: #fafafa;\n background-color: var(--ag-row-hover-color, #fafafa);\n}\n.ag-theme-material .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n user-select: none;\n}\n.ag-theme-material .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n.ag-theme-material .ag-select .ag-picker-field-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n min-height: 32px;\n cursor: default;\n}\n.ag-theme-material .ag-select.ag-disabled .ag-picker-field-wrapper:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-material .ag-select:not(.ag-cell-editor) {\n height: 32px;\n}\n.ag-theme-material .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.ag-theme-material .ag-select .ag-picker-field-icon {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-material .ag-select.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-material .ag-rich-select {\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa);\n}\n.ag-theme-material .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 312px;\n}\n.ag-theme-material .ag-rich-select-value {\n padding: 0 8px 0 24px;\n height: 48px;\n}\n.ag-theme-material .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 32px;\n}\n.ag-theme-material .ag-rich-select-virtual-list-item:hover {\n background-color: #fafafa;\n background-color: var(--ag-row-hover-color, #fafafa);\n}\n.ag-theme-material .ag-rich-select-row {\n padding-left: 24px;\n}\n.ag-theme-material .ag-rich-select-row-selected {\n background-color: #eee;\n background-color: var(--ag-selected-row-background-color, #eee);\n}\n.ag-theme-material .ag-row-drag,\n.ag-theme-material .ag-selection-checkbox,\n.ag-theme-material .ag-group-expanded,\n.ag-theme-material .ag-group-contracted {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-material .ag-ltr .ag-row-drag, .ag-theme-material .ag-ltr .ag-selection-checkbox, .ag-theme-material .ag-ltr .ag-group-expanded, .ag-theme-material .ag-ltr .ag-group-contracted {\n margin-right: 24px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-drag, .ag-theme-material .ag-rtl .ag-selection-checkbox, .ag-theme-material .ag-rtl .ag-group-expanded, .ag-theme-material .ag-rtl .ag-group-contracted {\n margin-left: 24px;\n}\n\n.ag-theme-material .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: min(var(--ag-row-height, 46px), 46px);\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-material .ag-group-expanded,\n.ag-theme-material .ag-group-contracted {\n cursor: pointer;\n}\n.ag-theme-material .ag-group-title-bar-icon {\n cursor: pointer;\n -webkit-box-flex: 0;\n flex: none;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-material .ag-ltr .ag-group-child-count {\n margin-left: 2px;\n}\n\n.ag-theme-material .ag-rtl .ag-group-child-count {\n margin-right: 2px;\n}\n\n.ag-theme-material .ag-group-title-bar {\n background-color: #eee;\n background-color: var(--ag-subheader-background-color, #eee);\n padding: 8px;\n}\n.ag-theme-material .ag-group-toolbar {\n padding: 8px;\n}\n.ag-theme-material .ag-disabled-group-title-bar, .ag-theme-material .ag-disabled-group-container {\n opacity: 0.5;\n}\n.ag-theme-material .group-item {\n margin: 4px 0;\n}\n.ag-theme-material .ag-label {\n white-space: nowrap;\n}\n.ag-theme-material .ag-ltr .ag-label {\n margin-right: 8px;\n}\n\n.ag-theme-material .ag-rtl .ag-label {\n margin-left: 8px;\n}\n\n.ag-theme-material .ag-label-align-top .ag-label {\n margin-bottom: 4px;\n}\n.ag-theme-material .ag-ltr .ag-slider-field, .ag-theme-material .ag-ltr .ag-angle-select-field {\n margin-right: 16px;\n}\n\n.ag-theme-material .ag-rtl .ag-slider-field, .ag-theme-material .ag-rtl .ag-angle-select-field {\n margin-left: 16px;\n}\n\n.ag-theme-material .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #e2e2e2;\n border-color: var(--ag-border-color, #e2e2e2);\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-material .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: rgba(0, 0, 0, 0.54);\n background-color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-material .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #e2e2e2;\n border-color: var(--ag-border-color, #e2e2e2);\n border-radius: 5px;\n}\n.ag-theme-material .ag-picker-field-wrapper:focus {\n -webkit-box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n}\n.ag-theme-material .ag-picker-field-button {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-material .ag-dialog.ag-color-dialog {\n border-radius: 5px;\n}\n.ag-theme-material .ag-color-picker .ag-picker-field-display {\n height: 18px;\n}\n.ag-theme-material .ag-color-panel {\n padding: 8px;\n}\n.ag-theme-material .ag-spectrum-color {\n background-color: red;\n border-radius: 2px;\n}\n.ag-theme-material .ag-spectrum-tools {\n padding: 10px;\n}\n.ag-theme-material .ag-spectrum-sat {\n background-image: -webkit-gradient(linear, left top, right top, from(white), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0));\n}\n.ag-theme-material .ag-spectrum-val {\n background-image: -webkit-gradient(linear, left bottom, left top, from(black), to(rgba(204, 154, 129, 0)));\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0));\n}\n.ag-theme-material .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n -webkit-box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);\n}\n.ag-theme-material .ag-spectrum-hue-background {\n border-radius: 2px;\n}\n.ag-theme-material .ag-spectrum-alpha-background {\n border-radius: 2px;\n}\n.ag-theme-material .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px;\n}\n.ag-theme-material .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n -webkit-box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);\n}\n.ag-theme-material .ag-recent-color {\n margin: 0 3px;\n}\n.ag-theme-material .ag-recent-color:first-child {\n margin-left: 0;\n}\n.ag-theme-material .ag-recent-color:last-child {\n margin-right: 0;\n}\n.ag-theme-material.ag-dnd-ghost {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n -webkit-box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px;\n overflow: hidden;\n text-overflow: ellipsis;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 56px !important;\n line-height: 56px;\n margin: 0;\n padding: 0 16px;\n -webkit-transform: translateY(16px);\n transform: translateY(16px);\n}\n.ag-theme-material .ag-dnd-ghost-icon {\n margin-right: 8px;\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87));\n}\n.ag-theme-material .ag-popup-child:not(.ag-tooltip-custom) {\n -webkit-box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3);\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3);\n}\n.ag-dragging-range-handle .ag-theme-material .ag-dialog, .ag-dragging-fill-handle .ag-theme-material .ag-dialog {\n opacity: 0.7;\n pointer-events: none;\n}\n.ag-theme-material .ag-dialog {\n border-radius: 0px;\n}\n.ag-theme-material .ag-panel {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-material .ag-panel-title-bar {\n background-color: #fff;\n background-color: var(--ag-header-background-color, #fff);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)));\n height: 56px;\n padding: 8px 24px;\n}\n.ag-theme-material .ag-ltr .ag-panel-title-bar-button {\n margin-left: 8px;\n}\n\n.ag-theme-material .ag-rtl .ag-panel-title-bar-button {\n margin-right: 8px;\n}\n\n.ag-theme-material .ag-tooltip {\n background-color: #fff;\n background-color: var(--ag-header-background-color, #fff);\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87));\n padding: 8px;\n border-radius: 2px;\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n white-space: normal;\n}\n.ag-theme-material .ag-tooltip.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-material .ag-tooltip-custom {\n -webkit-transition: opacity 1s;\n transition: opacity 1s;\n}\n.ag-theme-material .ag-tooltip-custom.ag-tooltip-hiding {\n opacity: 0;\n}\n.ag-theme-material .ag-ltr .ag-column-select-indent-1 {\n padding-left: 26px;\n}\n\n.ag-theme-material .ag-rtl .ag-column-select-indent-1 {\n padding-right: 26px;\n}\n\n.ag-theme-material .ag-ltr .ag-column-select-indent-2 {\n padding-left: 52px;\n}\n\n.ag-theme-material .ag-rtl .ag-column-select-indent-2 {\n padding-right: 52px;\n}\n\n.ag-theme-material .ag-ltr .ag-column-select-indent-3 {\n padding-left: 78px;\n}\n\n.ag-theme-material .ag-rtl .ag-column-select-indent-3 {\n padding-right: 78px;\n}\n\n.ag-theme-material .ag-ltr .ag-column-select-indent-4 {\n padding-left: 104px;\n}\n\n.ag-theme-material .ag-rtl .ag-column-select-indent-4 {\n padding-right: 104px;\n}\n\n.ag-theme-material .ag-ltr .ag-column-select-indent-5 {\n padding-left: 130px;\n}\n\n.ag-theme-material .ag-rtl .ag-column-select-indent-5 {\n padding-right: 130px;\n}\n\n.ag-theme-material .ag-ltr .ag-column-select-indent-6 {\n padding-left: 156px;\n}\n\n.ag-theme-material .ag-rtl .ag-column-select-indent-6 {\n padding-right: 156px;\n}\n\n.ag-theme-material .ag-ltr .ag-column-select-indent-7 {\n padding-left: 182px;\n}\n\n.ag-theme-material .ag-rtl .ag-column-select-indent-7 {\n padding-right: 182px;\n}\n\n.ag-theme-material .ag-ltr .ag-column-select-indent-8 {\n padding-left: 208px;\n}\n\n.ag-theme-material .ag-rtl .ag-column-select-indent-8 {\n padding-right: 208px;\n}\n\n.ag-theme-material .ag-ltr .ag-column-select-indent-9 {\n padding-left: 234px;\n}\n\n.ag-theme-material .ag-rtl .ag-column-select-indent-9 {\n padding-right: 234px;\n}\n\n.ag-theme-material .ag-column-select-header-icon {\n cursor: pointer;\n}\n.ag-theme-material .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none;\n}\n.ag-theme-material .ag-keyboard-focus .ag-column-select-header-icon:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: #3f51b5;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 16px;\n}\n\n.ag-theme-material .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 16px;\n}\n\n.ag-theme-material .ag-keyboard-focus .ag-column-select-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-material .ag-keyboard-focus .ag-column-select-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: #3f51b5;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-column-select-column-group:not(:last-child),\n.ag-theme-material .ag-column-select-column:not(:last-child) {\n margin-bottom: 14px;\n}\n.ag-theme-material .ag-column-select-column-readonly,\n.ag-theme-material .ag-column-select-column-group-readonly {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n pointer-events: none;\n}\n.ag-theme-material .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 34px;\n}\n\n.ag-theme-material .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 34px;\n}\n\n.ag-theme-material .ag-column-select-virtual-list-viewport {\n padding: 8px 0px;\n}\n.ag-theme-material .ag-column-select-virtual-list-item {\n padding: 0 12px;\n}\n.ag-theme-material .ag-rtl {\n text-align: right;\n}\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 66px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 66px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-1 {\n padding-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-1 {\n padding-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-1 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-1 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 108px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 108px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-2 {\n padding-left: 84px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-2 {\n padding-right: 84px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-2 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-2 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 150px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 150px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-3 {\n padding-left: 126px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-3 {\n padding-right: 126px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-3 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-3 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 192px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 192px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-4 {\n padding-left: 168px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-4 {\n padding-right: 168px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-4 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-4 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 234px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 234px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-5 {\n padding-left: 210px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-5 {\n padding-right: 210px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-5 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-5 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 276px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 276px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-6 {\n padding-left: 252px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-6 {\n padding-right: 252px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-6 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-6 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 318px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 318px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-7 {\n padding-left: 294px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-7 {\n padding-right: 294px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-7 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-7 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 360px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 360px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-8 {\n padding-left: 336px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-8 {\n padding-right: 336px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-8 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-8 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 402px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 402px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-9 {\n padding-left: 378px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-9 {\n padding-right: 378px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-9 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-9 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 444px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 444px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-10 {\n padding-left: 420px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-10 {\n padding-right: 420px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-10 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-10 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 486px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 486px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-11 {\n padding-left: 462px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-11 {\n padding-right: 462px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-11 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-11 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 528px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 528px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-12 {\n padding-left: 504px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-12 {\n padding-right: 504px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-12 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-12 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 570px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 570px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-13 {\n padding-left: 546px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-13 {\n padding-right: 546px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-13 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-13 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 612px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 612px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-14 {\n padding-left: 588px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-14 {\n padding-right: 588px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-14 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-14 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 654px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 654px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-15 {\n padding-left: 630px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-15 {\n padding-right: 630px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-15 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-15 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 696px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 696px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-16 {\n padding-left: 672px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-16 {\n padding-right: 672px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-16 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-16 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 738px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 738px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-17 {\n padding-left: 714px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-17 {\n padding-right: 714px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-17 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-17 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 780px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 780px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-18 {\n padding-left: 756px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-18 {\n padding-right: 756px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-18 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-18 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 822px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 822px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-19 {\n padding-left: 798px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-19 {\n padding-right: 798px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-19 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-19 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-left: 864px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-20 {\n padding-right: 864px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-20 {\n padding-left: 840px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-20 {\n padding-right: 840px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-20 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-20 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-left: 906px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-21 {\n padding-right: 906px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-21 {\n padding-left: 882px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-21 {\n padding-right: 882px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-21 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-21 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-left: 948px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-22 {\n padding-right: 948px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-22 {\n padding-left: 924px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-22 {\n padding-right: 924px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-22 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-22 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-left: 990px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-23 {\n padding-right: 990px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-23 {\n padding-left: 966px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-23 {\n padding-right: 966px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-23 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-23 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-left: 1032px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-24 {\n padding-right: 1032px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-24 {\n padding-left: 1008px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-24 {\n padding-right: 1008px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-24 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-24 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-left: 1074px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-25 {\n padding-right: 1074px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-25 {\n padding-left: 1050px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-25 {\n padding-right: 1050px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-25 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-25 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-left: 1116px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-26 {\n padding-right: 1116px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-26 {\n padding-left: 1092px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-26 {\n padding-right: 1092px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-26 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-26 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-left: 1158px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-27 {\n padding-right: 1158px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-27 {\n padding-left: 1134px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-27 {\n padding-right: 1134px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-27 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-27 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-left: 1200px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-28 {\n padding-right: 1200px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-28 {\n padding-left: 1176px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-28 {\n padding-right: 1176px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-28 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-28 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-left: 1242px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-29 {\n padding-right: 1242px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-29 {\n padding-left: 1218px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-29 {\n padding-right: 1218px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-29 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-29 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-left: 1284px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-30 {\n padding-right: 1284px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-30 {\n padding-left: 1260px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-30 {\n padding-right: 1260px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-30 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-30 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-left: 1326px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-31 {\n padding-right: 1326px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-31 {\n padding-left: 1302px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-31 {\n padding-right: 1302px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-31 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-31 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-left: 1368px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-32 {\n padding-right: 1368px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-32 {\n padding-left: 1344px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-32 {\n padding-right: 1344px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-32 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-32 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-left: 1410px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-33 {\n padding-right: 1410px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-33 {\n padding-left: 1386px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-33 {\n padding-right: 1386px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-33 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-33 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-left: 1452px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-34 {\n padding-right: 1452px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-34 {\n padding-left: 1428px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-34 {\n padding-right: 1428px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-34 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-34 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-left: 1494px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-35 {\n padding-right: 1494px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-35 {\n padding-left: 1470px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-35 {\n padding-right: 1470px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-35 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-35 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-left: 1536px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-36 {\n padding-right: 1536px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-36 {\n padding-left: 1512px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-36 {\n padding-right: 1512px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-36 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-36 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-left: 1578px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-37 {\n padding-right: 1578px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-37 {\n padding-left: 1554px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-37 {\n padding-right: 1554px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-37 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-37 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-left: 1620px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-38 {\n padding-right: 1620px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-38 {\n padding-left: 1596px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-38 {\n padding-right: 1596px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-38 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-38 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-left: 1662px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-39 {\n padding-right: 1662px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-39 {\n padding-left: 1638px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-39 {\n padding-right: 1638px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-39 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-39 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-left: 1704px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-40 {\n padding-right: 1704px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-40 {\n padding-left: 1680px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-40 {\n padding-right: 1680px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-40 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-40 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-left: 1746px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-41 {\n padding-right: 1746px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-41 {\n padding-left: 1722px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-41 {\n padding-right: 1722px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-41 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-41 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-left: 1788px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-42 {\n padding-right: 1788px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-42 {\n padding-left: 1764px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-42 {\n padding-right: 1764px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-42 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-42 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-left: 1830px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-43 {\n padding-right: 1830px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-43 {\n padding-left: 1806px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-43 {\n padding-right: 1806px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-43 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-43 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-left: 1872px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-44 {\n padding-right: 1872px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-44 {\n padding-left: 1848px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-44 {\n padding-right: 1848px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-44 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-44 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-left: 1914px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-45 {\n padding-right: 1914px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-45 {\n padding-left: 1890px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-45 {\n padding-right: 1890px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-45 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-45 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-left: 1956px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-46 {\n padding-right: 1956px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-46 {\n padding-left: 1932px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-46 {\n padding-right: 1932px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-46 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-46 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-left: 1998px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-47 {\n padding-right: 1998px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-47 {\n padding-left: 1974px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-47 {\n padding-right: 1974px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-47 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-47 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-left: 2040px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-48 {\n padding-right: 2040px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-48 {\n padding-left: 2016px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-48 {\n padding-right: 2016px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-48 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-48 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-left: 2082px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-49 {\n padding-right: 2082px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-49 {\n padding-left: 2058px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-49 {\n padding-right: 2058px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-49 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-49 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-left: 2124px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-50 {\n padding-right: 2124px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-50 {\n padding-left: 2100px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-50 {\n padding-right: 2100px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-50 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-50 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-left: 2166px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-51 {\n padding-right: 2166px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-51 {\n padding-left: 2142px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-51 {\n padding-right: 2142px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-51 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-51 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-left: 2208px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-52 {\n padding-right: 2208px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-52 {\n padding-left: 2184px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-52 {\n padding-right: 2184px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-52 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-52 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-left: 2250px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-53 {\n padding-right: 2250px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-53 {\n padding-left: 2226px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-53 {\n padding-right: 2226px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-53 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-53 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-left: 2292px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-54 {\n padding-right: 2292px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-54 {\n padding-left: 2268px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-54 {\n padding-right: 2268px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-54 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-54 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-left: 2334px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-55 {\n padding-right: 2334px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-55 {\n padding-left: 2310px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-55 {\n padding-right: 2310px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-55 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-55 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-left: 2376px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-56 {\n padding-right: 2376px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-56 {\n padding-left: 2352px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-56 {\n padding-right: 2352px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-56 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-56 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-left: 2418px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-57 {\n padding-right: 2418px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-57 {\n padding-left: 2394px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-57 {\n padding-right: 2394px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-57 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-57 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-left: 2460px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-58 {\n padding-right: 2460px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-58 {\n padding-left: 2436px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-58 {\n padding-right: 2436px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-58 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-58 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-left: 2502px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-59 {\n padding-right: 2502px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-59 {\n padding-left: 2478px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-59 {\n padding-right: 2478px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-59 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-59 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-left: 2544px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-60 {\n padding-right: 2544px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-60 {\n padding-left: 2520px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-60 {\n padding-right: 2520px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-60 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-60 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-left: 2586px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-61 {\n padding-right: 2586px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-61 {\n padding-left: 2562px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-61 {\n padding-right: 2562px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-61 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-61 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-left: 2628px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-62 {\n padding-right: 2628px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-62 {\n padding-left: 2604px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-62 {\n padding-right: 2604px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-62 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-62 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-left: 2670px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-63 {\n padding-right: 2670px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-63 {\n padding-left: 2646px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-63 {\n padding-right: 2646px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-63 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-63 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-left: 2712px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-64 {\n padding-right: 2712px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-64 {\n padding-left: 2688px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-64 {\n padding-right: 2688px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-64 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-64 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-left: 2754px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-65 {\n padding-right: 2754px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-65 {\n padding-left: 2730px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-65 {\n padding-right: 2730px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-65 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-65 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-left: 2796px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-66 {\n padding-right: 2796px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-66 {\n padding-left: 2772px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-66 {\n padding-right: 2772px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-66 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-66 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-left: 2838px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-67 {\n padding-right: 2838px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-67 {\n padding-left: 2814px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-67 {\n padding-right: 2814px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-67 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-67 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-left: 2880px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-68 {\n padding-right: 2880px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-68 {\n padding-left: 2856px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-68 {\n padding-right: 2856px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-68 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-68 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-left: 2922px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-69 {\n padding-right: 2922px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-69 {\n padding-left: 2898px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-69 {\n padding-right: 2898px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-69 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-69 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-left: 2964px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-70 {\n padding-right: 2964px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-70 {\n padding-left: 2940px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-70 {\n padding-right: 2940px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-70 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-70 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-left: 3006px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-71 {\n padding-right: 3006px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-71 {\n padding-left: 2982px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-71 {\n padding-right: 2982px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-71 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-71 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-left: 3048px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-72 {\n padding-right: 3048px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-72 {\n padding-left: 3024px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-72 {\n padding-right: 3024px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-72 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-72 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-left: 3090px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-73 {\n padding-right: 3090px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-73 {\n padding-left: 3066px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-73 {\n padding-right: 3066px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-73 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-73 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-left: 3132px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-74 {\n padding-right: 3132px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-74 {\n padding-left: 3108px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-74 {\n padding-right: 3108px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-74 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-74 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-left: 3174px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-75 {\n padding-right: 3174px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-75 {\n padding-left: 3150px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-75 {\n padding-right: 3150px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-75 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-75 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-left: 3216px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-76 {\n padding-right: 3216px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-76 {\n padding-left: 3192px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-76 {\n padding-right: 3192px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-76 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-76 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-left: 3258px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-77 {\n padding-right: 3258px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-77 {\n padding-left: 3234px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-77 {\n padding-right: 3234px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-77 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-77 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-left: 3300px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-78 {\n padding-right: 3300px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-78 {\n padding-left: 3276px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-78 {\n padding-right: 3276px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-78 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-78 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-left: 3342px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-79 {\n padding-right: 3342px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-79 {\n padding-left: 3318px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-79 {\n padding-right: 3318px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-79 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-79 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-left: 3384px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-80 {\n padding-right: 3384px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-80 {\n padding-left: 3360px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-80 {\n padding-right: 3360px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-80 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-80 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-left: 3426px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-81 {\n padding-right: 3426px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-81 {\n padding-left: 3402px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-81 {\n padding-right: 3402px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-81 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-81 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-left: 3468px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-82 {\n padding-right: 3468px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-82 {\n padding-left: 3444px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-82 {\n padding-right: 3444px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-82 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-82 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-left: 3510px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-83 {\n padding-right: 3510px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-83 {\n padding-left: 3486px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-83 {\n padding-right: 3486px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-83 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-83 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-left: 3552px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-84 {\n padding-right: 3552px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-84 {\n padding-left: 3528px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-84 {\n padding-right: 3528px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-84 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-84 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-left: 3594px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-85 {\n padding-right: 3594px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-85 {\n padding-left: 3570px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-85 {\n padding-right: 3570px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-85 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-85 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-left: 3636px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-86 {\n padding-right: 3636px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-86 {\n padding-left: 3612px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-86 {\n padding-right: 3612px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-86 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-86 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-left: 3678px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-87 {\n padding-right: 3678px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-87 {\n padding-left: 3654px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-87 {\n padding-right: 3654px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-87 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-87 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-left: 3720px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-88 {\n padding-right: 3720px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-88 {\n padding-left: 3696px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-88 {\n padding-right: 3696px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-88 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-88 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-left: 3762px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-89 {\n padding-right: 3762px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-89 {\n padding-left: 3738px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-89 {\n padding-right: 3738px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-89 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-89 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-left: 3804px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-90 {\n padding-right: 3804px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-90 {\n padding-left: 3780px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-90 {\n padding-right: 3780px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-90 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-90 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-left: 3846px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-91 {\n padding-right: 3846px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-91 {\n padding-left: 3822px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-91 {\n padding-right: 3822px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-91 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-91 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-left: 3888px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-92 {\n padding-right: 3888px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-92 {\n padding-left: 3864px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-92 {\n padding-right: 3864px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-92 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-92 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-left: 3930px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-93 {\n padding-right: 3930px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-93 {\n padding-left: 3906px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-93 {\n padding-right: 3906px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-93 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-93 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-left: 3972px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-94 {\n padding-right: 3972px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-94 {\n padding-left: 3948px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-94 {\n padding-right: 3948px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-94 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-94 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-left: 4014px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-95 {\n padding-right: 4014px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-95 {\n padding-left: 3990px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-95 {\n padding-right: 3990px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-95 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-95 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-left: 4056px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-96 {\n padding-right: 4056px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-96 {\n padding-left: 4032px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-96 {\n padding-right: 4032px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-96 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-96 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-left: 4098px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-97 {\n padding-right: 4098px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-97 {\n padding-left: 4074px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-97 {\n padding-right: 4074px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-97 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-97 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-left: 4140px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-98 {\n padding-right: 4140px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-98 {\n padding-left: 4116px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-98 {\n padding-right: 4116px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-98 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-98 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-left: 4182px;\n}\n\n.ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-99 {\n padding-right: 4182px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-indent-99 {\n padding-left: 4158px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-indent-99 {\n padding-right: 4158px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-level-99 .ag-pivot-leaf-group {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-level-99 .ag-pivot-leaf-group {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-ltr .ag-row-group-leaf-indent {\n margin-left: 42px;\n}\n\n.ag-theme-material .ag-rtl .ag-row-group-leaf-indent {\n margin-right: 42px;\n}\n\n.ag-theme-material .ag-value-change-delta {\n padding-right: 2px;\n}\n.ag-theme-material .ag-value-change-delta-up {\n color: #43a047;\n color: var(--ag-value-change-delta-up-color, #43a047);\n}\n.ag-theme-material .ag-value-change-delta-down {\n color: #e53935;\n color: var(--ag-value-change-delta-down-color, #e53935);\n}\n.ag-theme-material .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n -webkit-transition: background-color 1s;\n transition: background-color 1s;\n}\n.ag-theme-material .ag-value-change-value-highlight {\n background-color: #00acc1;\n background-color: var(--ag-value-change-value-highlight-background-color, #00acc1);\n -webkit-transition: background-color 0.1s;\n transition: background-color 0.1s;\n}\n.ag-theme-material .ag-cell-data-changed {\n background-color: #00acc1 !important;\n background-color: var(--ag-value-change-value-highlight-background-color, #00acc1) !important;\n}\n.ag-theme-material .ag-cell-data-changed-animation {\n background-color: transparent;\n}\n.ag-theme-material .ag-cell-highlight {\n background-color: #fce4ec !important;\n background-color: var(--ag-range-selection-highlight-color, #fce4ec) !important;\n}\n.ag-theme-material .ag-row {\n height: 48px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-data-color, var(--ag-foreground-color, rgba(0, 0, 0, 0.87)));\n border-width: 1px;\n border-color: #e2e2e2;\n border-color: var(--ag-row-border-color, var(--ag-secondary-border-color, var(--ag-border-color, #e2e2e2)));\n border-bottom-style: solid;\n}\n.ag-theme-material .ag-row-highlight-above::after, .ag-theme-material .ag-row-highlight-below::after {\n content: \"\";\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #3f51b5;\n background-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n left: 1px;\n}\n.ag-theme-material .ag-row-highlight-above::after {\n top: -1px;\n}\n.ag-theme-material .ag-row-highlight-above.ag-row-first::after {\n top: 0;\n}\n.ag-theme-material .ag-row-highlight-below::after {\n bottom: 0px;\n}\n.ag-theme-material .ag-row-odd {\n background-color: var(--ag-odd-row-background-color);\n}\n.ag-theme-material .ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #e2e2e2;\n border-right-color: var(--ag-border-color, #e2e2e2);\n}\n.ag-theme-material .ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #e2e2e2;\n border-left-color: var(--ag-border-color, #e2e2e2);\n}\n.ag-theme-material .ag-row-hover {\n background-color: #fafafa;\n background-color: var(--ag-row-hover-color, #fafafa);\n}\n.ag-theme-material .ag-column-hover {\n background-color: #fafafa;\n background-color: var(--ag-column-hover-color, #fafafa);\n}\n.ag-theme-material .ag-ltr .ag-right-aligned-cell {\n text-align: right;\n}\n\n.ag-theme-material .ag-rtl .ag-right-aligned-cell {\n text-align: left;\n}\n\n.ag-theme-material .ag-ltr .ag-right-aligned-cell .ag-cell-value, .ag-theme-material .ag-ltr .ag-right-aligned-cell .ag-group-value {\n margin-left: auto;\n}\n\n.ag-theme-material .ag-rtl .ag-right-aligned-cell .ag-cell-value, .ag-theme-material .ag-rtl .ag-right-aligned-cell .ag-group-value {\n margin-right: auto;\n}\n\n.ag-theme-material .ag-cell, .ag-theme-material .ag-full-width-row .ag-cell-wrapper.ag-row-group {\n border: 1px solid transparent;\n line-height: min(var(--ag-row-height, 46px), 46px);\n padding-left: 23px;\n padding-right: 23px;\n -webkit-font-smoothing: subpixel-antialiased;\n}\n.ag-theme-material .ag-row > .ag-cell-wrapper {\n padding-left: 23px;\n padding-right: 23px;\n}\n.ag-theme-material .ag-row-dragging {\n cursor: move;\n opacity: 0.5;\n}\n.ag-theme-material .ag-cell-inline-editing {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n -webkit-box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px;\n padding: 0;\n height: 48px;\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa);\n}\n.ag-theme-material .ag-popup-editor {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n -webkit-box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px;\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa);\n padding: 0;\n}\n.ag-theme-material .ag-large-text-input {\n height: auto;\n padding: 24px;\n}\n.ag-theme-material .ag-details-row {\n padding: 40px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n}\n.ag-theme-material .ag-layout-auto-height .ag-center-cols-clipper, .ag-theme-material .ag-layout-auto-height .ag-center-cols-container, .ag-theme-material .ag-layout-print .ag-center-cols-clipper, .ag-theme-material .ag-layout-print .ag-center-cols-container {\n min-height: 50px;\n}\n.ag-theme-material .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66));\n}\n.ag-theme-material .ag-overlay-loading-center {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n -webkit-box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px;\n}\n.ag-theme-material .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px;\n}\n.ag-theme-material .ag-loading {\n padding-left: 24px;\n display: -webkit-box;\n display: flex;\n height: 100%;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-material .ag-loading-icon {\n padding-right: 24px;\n}\n.ag-theme-material .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear;\n}\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg);\n }\n}\n.ag-theme-material .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2);\n}\n.ag-theme-material .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #e2e2e2;\n border-top-color: var(--ag-border-color, #e2e2e2);\n}\n.ag-theme-material .ag-ltr .ag-cell {\n border-right: solid transparent;\n}\n\n.ag-theme-material .ag-rtl .ag-cell {\n border-left: solid transparent;\n}\n\n.ag-theme-material .ag-ltr .ag-cell {\n border-right-width: 1px;\n}\n\n.ag-theme-material .ag-rtl .ag-cell {\n border-left-width: 1px;\n}\n\n.ag-theme-material .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #e2e2e2;\n border-left-color: var(--ag-border-color, #e2e2e2);\n}\n.ag-theme-material .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #e2e2e2;\n border-right-color: var(--ag-border-color, #e2e2e2);\n}\n.ag-theme-material .ag-row-selected {\n background-color: #eee;\n background-color: var(--ag-selected-row-background-color, #eee);\n}\n.ag-theme-material .ag-cell-range-selected:not(.ag-cell-focus),\n.ag-theme-material .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing) {\n background-color: rgba(122, 134, 203, 0.1);\n background-color: var(--ag-range-selection-background-color, rgba(122, 134, 203, 0.1));\n}\n.ag-theme-material .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart,\n.ag-theme-material .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1) !important;\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)) !important;\n}\n.ag-theme-material .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category,\n.ag-theme-material .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1) !important;\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)) !important;\n}\n.ag-theme-material .ag-cell-range-selected-1:not(.ag-cell-focus),\n.ag-theme-material .ag-root:not(.ag-context-menu-open) .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-1:not(.ag-cell-inline-editing) {\n background-color: rgba(122, 134, 203, 0.1);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(122, 134, 203, 0.1)));\n}\n.ag-theme-material .ag-cell-range-selected-2:not(.ag-cell-focus),\n.ag-theme-material .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-2 {\n background-color: rgba(122, 134, 203, 0.19);\n background-color: var(--ag-range-selection-background-color-2, rgba(122, 134, 203, 0.19));\n}\n.ag-theme-material .ag-cell-range-selected-3:not(.ag-cell-focus),\n.ag-theme-material .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-3 {\n background-color: rgba(122, 134, 203, 0.271);\n background-color: var(--ag-range-selection-background-color-3, rgba(122, 134, 203, 0.271));\n}\n.ag-theme-material .ag-cell-range-selected-4:not(.ag-cell-focus),\n.ag-theme-material .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-4 {\n background-color: rgba(122, 134, 203, 0.3439);\n background-color: var(--ag-range-selection-background-color-4, rgba(122, 134, 203, 0.3439));\n}\n.ag-theme-material .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #3f51b5;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #3f51b5;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #3f51b5;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #3f51b5;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-material .ag-ltr .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-material .ag-ltr .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-material .ag-ltr .ag-cell-range-single-cell,\n.ag-theme-material .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-material .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-material .ag-rtl .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected),\n.ag-theme-material .ag-rtl .ag-has-focus .ag-full-width-row.ag-row-focus .ag-cell-wrapper.ag-row-group,\n.ag-theme-material .ag-rtl .ag-cell-range-single-cell,\n.ag-theme-material .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #3f51b5;\n border-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n outline: initial;\n}\n.ag-theme-material .ag-cell.ag-selection-fill-top,\n.ag-theme-material .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #3f51b5;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-material .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #3f51b5;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n\n.ag-theme-material .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-material .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #3f51b5;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n\n.ag-theme-material .ag-cell.ag-selection-fill-bottom,\n.ag-theme-material .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #3f51b5;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-material .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #3f51b5;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n\n.ag-theme-material .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-material .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #3f51b5;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n\n.ag-theme-material .ag-range-handle, .ag-theme-material .ag-fill-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #3f51b5;\n background-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-ltr .ag-range-handle, .ag-theme-material .ag-ltr .ag-fill-handle {\n right: -1px;\n}\n\n.ag-theme-material .ag-rtl .ag-range-handle, .ag-theme-material .ag-rtl .ag-fill-handle {\n left: -1px;\n}\n\n.ag-theme-material .ag-fill-handle {\n cursor: cell;\n}\n.ag-theme-material .ag-range-handle {\n cursor: nwse-resize;\n}\n.ag-theme-material .ag-cell-inline-editing {\n border-color: #3f51b5 !important;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5)) !important;\n}\n.ag-theme-material .ag-menu {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n -webkit-box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px;\n padding: 0;\n}\n.ag-theme-material .ag-menu-list {\n cursor: default;\n padding: 8px 0;\n}\n.ag-theme-material .ag-menu-separator {\n height: 17px;\n}\n.ag-theme-material .ag-menu-separator-part::after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #e2e2e2;\n border-top-color: var(--ag-border-color, #e2e2e2);\n}\n.ag-theme-material .ag-menu-option-active, .ag-theme-material .ag-compact-menu-option-active {\n background-color: #fafafa;\n background-color: var(--ag-row-hover-color, #fafafa);\n}\n.ag-theme-material .ag-menu-option-part, .ag-theme-material .ag-compact-menu-option-part {\n line-height: 18px;\n padding: 10px 0;\n}\n.ag-theme-material .ag-menu-option-disabled, .ag-theme-material .ag-compact-menu-option-disabled {\n opacity: 0.5;\n}\n.ag-theme-material .ag-menu-option-icon, .ag-theme-material .ag-compact-menu-option-icon {\n width: 18px;\n}\n.ag-theme-material .ag-ltr .ag-menu-option-icon, .ag-theme-material .ag-ltr .ag-compact-menu-option-icon {\n padding-left: 16px;\n}\n\n.ag-theme-material .ag-rtl .ag-menu-option-icon, .ag-theme-material .ag-rtl .ag-compact-menu-option-icon {\n padding-right: 16px;\n}\n\n.ag-theme-material .ag-menu-option-text, .ag-theme-material .ag-compact-menu-option-text {\n padding-left: 16px;\n padding-right: 16px;\n}\n.ag-theme-material .ag-ltr .ag-menu-option-shortcut, .ag-theme-material .ag-ltr .ag-compact-menu-option-shortcut {\n padding-right: 8px;\n}\n\n.ag-theme-material .ag-rtl .ag-menu-option-shortcut, .ag-theme-material .ag-rtl .ag-compact-menu-option-shortcut {\n padding-left: 8px;\n}\n\n.ag-theme-material .ag-menu-option-popup-pointer, .ag-theme-material .ag-compact-menu-option-popup-pointer {\n padding-right: 8px;\n}\n.ag-theme-material .ag-tabs {\n min-width: 220px;\n}\n.ag-theme-material .ag-tabs-header {\n width: 100%;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-material .ag-tab {\n border-bottom: 2px solid transparent;\n display: -webkit-box;\n display: flex;\n -webkit-box-flex: 0;\n flex: none;\n -webkit-box-align: center;\n align-items: center;\n -webkit-box-pack: center;\n justify-content: center;\n cursor: pointer;\n -webkit-box-flex: 1;\n flex: 1 1 auto;\n}\n.ag-theme-material .ag-keyboard-focus .ag-tab:focus {\n outline: none;\n}\n.ag-theme-material .ag-keyboard-focus .ag-tab:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #3f51b5;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-tab-selected {\n border-bottom-color: #3f51b5;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-menu-header {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-material .ag-filter-separator {\n border-top: solid 1px;\n border-top-color: #e2e2e2;\n border-top-color: var(--ag-border-color, #e2e2e2);\n}\n.ag-theme-material .ag-menu:not(.ag-tabs) .ag-filter-select {\n min-width: 155px;\n}\n.ag-theme-material .ag-tabs .ag-filter-select {\n min-width: 194px;\n}\n.ag-theme-material .ag-filter-select .ag-picker-field-wrapper {\n width: 0;\n}\n.ag-theme-material .ag-filter-condition-operator {\n height: 17px;\n}\n.ag-theme-material .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 16px;\n}\n\n.ag-theme-material .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 16px;\n}\n\n.ag-theme-material .ag-set-filter-select-all {\n padding-top: 16px;\n}\n.ag-theme-material .ag-set-filter-list, .ag-theme-material .ag-filter-no-matches {\n height: 192px;\n}\n.ag-theme-material .ag-set-filter-filter {\n margin-top: 16px;\n margin-left: 12px;\n margin-right: 12px;\n}\n.ag-theme-material .ag-filter-to {\n margin-top: 14px;\n}\n.ag-theme-material .ag-mini-filter {\n margin: 16px 12px;\n}\n.ag-theme-material .ag-set-filter-item {\n margin: 0px 12px;\n}\n.ag-theme-material .ag-ltr .ag-set-filter-item-value {\n margin-left: 12px;\n}\n\n.ag-theme-material .ag-rtl .ag-set-filter-item-value {\n margin-right: 12px;\n}\n\n.ag-theme-material .ag-filter-apply-panel {\n padding: 16px 12px;\n}\n.ag-theme-material .ag-filter-apply-panel-button {\n line-height: 1.5;\n}\n.ag-theme-material .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 16px;\n}\n\n.ag-theme-material .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 16px;\n}\n\n.ag-theme-material .ag-simple-filter-body-wrapper {\n padding: 16px 12px;\n padding-bottom: 2px;\n}\n.ag-theme-material .ag-simple-filter-body-wrapper > * {\n margin-bottom: 14px;\n}\n.ag-theme-material .ag-filter-no-matches {\n padding: 16px 12px;\n}\n.ag-theme-material .ag-multi-filter-menu-item {\n margin: 8px 0;\n}\n.ag-theme-material .ag-multi-filter-group-title-bar {\n padding: 16px 8px;\n background-color: transparent;\n}\n.ag-theme-material .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus {\n outline: none;\n}\n.ag-theme-material .ag-keyboard-focus .ag-multi-filter-group-title-bar:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #3f51b5;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-side-bar {\n position: relative;\n}\n.ag-theme-material .ag-tool-panel-wrapper {\n width: 200px;\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa);\n}\n.ag-theme-material .ag-side-buttons {\n padding-top: 32px;\n width: 22px;\n position: relative;\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87));\n overflow: hidden;\n}\n.ag-theme-material button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 16px 0 16px 0;\n width: 100%;\n margin: 0;\n min-height: 144px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n}\n.ag-theme-material button.ag-side-button-button:focus {\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-material .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none;\n}\n.ag-theme-material .ag-keyboard-focus .ag-side-button-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #3f51b5;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-side-button-icon-wrapper {\n margin-bottom: 3px;\n}\n.ag-theme-material .ag-ltr .ag-side-bar-left .ag-side-button-button,\n.ag-theme-material .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 2px solid transparent;\n}\n.ag-theme-material .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-material .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #3f51b5;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-rtl .ag-side-bar-left .ag-side-button-button,\n.ag-theme-material .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 2px solid transparent;\n}\n.ag-theme-material .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n.ag-theme-material .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #3f51b5;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-filter-toolpanel-header {\n height: 48px;\n}\n.ag-theme-material .ag-ltr .ag-filter-toolpanel-header, .ag-theme-material .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 8px;\n}\n\n.ag-theme-material .ag-rtl .ag-filter-toolpanel-header, .ag-theme-material .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 8px;\n}\n\n.ag-theme-material .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none;\n}\n.ag-theme-material .ag-keyboard-focus .ag-filter-toolpanel-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #3f51b5;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n font-family: \"agGridMaterial\";\n font-size: 18px;\n line-height: 18px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f114\";\n position: absolute;\n}\n.ag-theme-material .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-left: 8px;\n}\n\n.ag-theme-material .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title::after {\n padding-right: 8px;\n}\n\n.ag-theme-material .ag-filter-toolpanel-group-level-0-header {\n height: 64px;\n}\n.ag-theme-material .ag-filter-toolpanel-group-item {\n margin-top: 4px;\n margin-bottom: 4px;\n}\n.ag-theme-material .ag-filter-toolpanel-search {\n height: 56px;\n}\n.ag-theme-material .ag-filter-toolpanel-search-input {\n -webkit-box-flex: 1;\n flex-grow: 1;\n height: 32px;\n}\n.ag-theme-material .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 8px;\n}\n\n.ag-theme-material .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 8px;\n}\n\n.ag-theme-material .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 8px;\n}\n\n.ag-theme-material .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 8px;\n}\n\n.ag-theme-material .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 24px;\n}\n\n.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 24px;\n}\n\n.ag-theme-material .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 40px;\n}\n\n.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 40px;\n}\n\n.ag-theme-material .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 56px;\n}\n\n.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 56px;\n}\n\n.ag-theme-material .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 72px;\n}\n\n.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 72px;\n}\n\n.ag-theme-material .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 88px;\n}\n\n.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 88px;\n}\n\n.ag-theme-material .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 104px;\n}\n\n.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 104px;\n}\n\n.ag-theme-material .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 120px;\n}\n\n.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 120px;\n}\n\n.ag-theme-material .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 136px;\n}\n\n.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 136px;\n}\n\n.ag-theme-material .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 152px;\n}\n\n.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 152px;\n}\n\n.ag-theme-material .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent;\n}\n.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 168px;\n}\n\n.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 168px;\n}\n\n.ag-theme-material .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 8px;\n}\n.ag-theme-material .ag-filter-toolpanel-instance-filter {\n margin-top: 8px;\n}\n.ag-theme-material .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 8px;\n}\n\n.ag-theme-material .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 8px;\n}\n\n.ag-theme-material .ag-pivot-mode-panel {\n min-height: 56px;\n height: 56px;\n display: -webkit-box;\n display: flex;\n}\n.ag-theme-material .ag-pivot-mode-select {\n display: -webkit-box;\n display: flex;\n -webkit-box-align: center;\n align-items: center;\n}\n.ag-theme-material .ag-ltr .ag-pivot-mode-select {\n margin-left: 12px;\n}\n\n.ag-theme-material .ag-rtl .ag-pivot-mode-select {\n margin-right: 12px;\n}\n\n.ag-theme-material .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none;\n}\n.ag-theme-material .ag-keyboard-focus .ag-column-select-header:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #3f51b5;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-column-select-header {\n height: 56px;\n -webkit-box-align: center;\n align-items: center;\n padding: 0 12px;\n}\n.ag-theme-material .ag-column-group-icons,\n.ag-theme-material .ag-column-select-header-icon {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-material .ag-column-select-list .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #3f51b5;\n background-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-column-select-list .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-material .ag-column-select-list .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-material .ag-header {\n background-color: #fff;\n background-color: var(--ag-header-background-color, #fff);\n border-bottom: solid 1px;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2);\n}\n.ag-theme-material .ag-header-row {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)));\n height: 56px;\n}\n.ag-theme-material .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #e2e2e2;\n border-left-color: var(--ag-border-color, #e2e2e2);\n}\n.ag-theme-material .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #e2e2e2;\n border-right-color: var(--ag-border-color, #e2e2e2);\n}\n.ag-theme-material .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 8px;\n}\n\n.ag-theme-material .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 8px;\n}\n\n.ag-theme-material .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 8px;\n}\n\n.ag-theme-material .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 8px;\n}\n\n.ag-theme-material .ag-header-cell,\n.ag-theme-material .ag-header-group-cell {\n padding-left: 24px;\n padding-right: 24px;\n}\n.ag-theme-material .ag-header-cell.ag-header-cell-moving,\n.ag-theme-material .ag-header-group-cell.ag-header-cell-moving {\n background-color: #f2f2f2;\n background-color: var(--ag-header-cell-moving-background-color, var(--ag-header-cell-hover-background-color, #f2f2f2));\n}\n.ag-theme-material .ag-keyboard-focus .ag-header-cell:focus {\n outline: none;\n}\n.ag-theme-material .ag-keyboard-focus .ag-header-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #3f51b5;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none;\n}\n.ag-theme-material .ag-keyboard-focus .ag-header-group-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #3f51b5;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-header-icon {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-material .ag-header-expand-icon {\n cursor: pointer;\n}\n.ag-theme-material .ag-ltr .ag-header-expand-icon {\n padding-left: 4px;\n}\n\n.ag-theme-material .ag-rtl .ag-header-expand-icon {\n padding-right: 4px;\n}\n\n.ag-theme-material .ag-header-row:not(:first-child) .ag-header-cell,\n.ag-theme-material .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #e2e2e2;\n border-top-color: var(--ag-border-color, #e2e2e2);\n}\n.ag-theme-material .ag-header-group-cell:not(.ag-column-resizing) + .ag-header-group-cell:not(.ag-header-cell-moving):hover, .ag-theme-material .ag-header-group-cell:not(.ag-column-resizing) + .ag-header-group-cell.ag-column-resizing,\n.ag-theme-material .ag-header-cell:not(.ag-column-resizing) + .ag-header-cell:not(.ag-header-cell-moving):hover,\n.ag-theme-material .ag-header-cell:not(.ag-column-resizing) + .ag-header-cell.ag-column-resizing,\n.ag-theme-material .ag-header-group-cell:first-of-type:not(.ag-header-cell-moving):hover,\n.ag-theme-material .ag-header-group-cell:first-of-type.ag-column-resizing,\n.ag-theme-material .ag-header-cell:first-of-type:not(.ag-header-cell-moving):hover,\n.ag-theme-material .ag-header-cell:first-of-type.ag-column-resizing {\n background-color: #f2f2f2;\n background-color: var(--ag-header-cell-hover-background-color, #f2f2f2);\n}\n.ag-theme-material .ag-ltr .ag-header-select-all {\n margin-right: 24px;\n}\n\n.ag-theme-material .ag-rtl .ag-header-select-all {\n margin-left: 24px;\n}\n\n.ag-theme-material .ag-ltr .ag-floating-filter-button {\n margin-left: 24px;\n}\n\n.ag-theme-material .ag-rtl .ag-floating-filter-button {\n margin-right: 24px;\n}\n\n.ag-theme-material .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 18px;\n padding: 0;\n width: 18px;\n}\n.ag-theme-material .ag-filter-loading {\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa);\n height: 100%;\n padding: 16px 12px;\n position: absolute;\n width: 100%;\n z-index: 1;\n}\n.ag-theme-material .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #e2e2e2;\n border-top-color: var(--ag-border-color, #e2e2e2);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 56px;\n}\n.ag-theme-material .ag-paging-panel > * {\n margin: 0 24px;\n}\n.ag-theme-material .ag-paging-button {\n cursor: pointer;\n}\n.ag-theme-material .ag-paging-button.ag-disabled {\n cursor: default;\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n}\n.ag-theme-material .ag-keyboard-focus .ag-paging-button:focus {\n outline: none;\n}\n.ag-theme-material .ag-keyboard-focus .ag-paging-button:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: #3f51b5;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-paging-button, .ag-theme-material .ag-paging-description {\n margin: 0 8px;\n}\n.ag-theme-material .ag-status-bar {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n padding-right: 32px;\n padding-left: 32px;\n line-height: 1.5;\n}\n.ag-theme-material .ag-status-name-value-value {\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87));\n}\n.ag-theme-material .ag-status-bar-center {\n text-align: center;\n}\n.ag-theme-material .ag-status-name-value {\n margin-left: 8px;\n margin-right: 8px;\n padding-top: 16px;\n padding-bottom: 16px;\n}\n.ag-theme-material .ag-column-drop-cell {\n background: #e2e2e2;\n background: var(--ag-chip-background-color, #e2e2e2);\n border-radius: 32px;\n height: 32px;\n padding: 0 4px;\n border: 1px solid transparent;\n}\n.ag-theme-material .ag-keyboard-focus .ag-column-drop-cell:focus {\n outline: none;\n}\n.ag-theme-material .ag-keyboard-focus .ag-column-drop-cell:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 2px;\n left: 2px;\n display: block;\n width: calc(100% - 4px);\n height: calc(100% - 4px);\n border: 1px solid;\n border-color: #3f51b5;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-column-drop-cell-text {\n margin: 0 8px;\n}\n.ag-theme-material .ag-column-drop-cell-button {\n min-width: 32px;\n margin: 0 4px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-material .ag-column-drop-cell-drag-handle {\n margin-left: 16px;\n}\n.ag-theme-material .ag-column-drop-cell-ghost {\n opacity: 0.5;\n}\n.ag-theme-material .ag-column-drop-horizontal {\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 48px;\n}\n.ag-theme-material .ag-ltr .ag-column-drop-horizontal {\n padding-left: 24px;\n}\n\n.ag-theme-material .ag-rtl .ag-column-drop-horizontal {\n padding-right: 24px;\n}\n\n.ag-theme-material .ag-column-drop-horizontal-cell-separator {\n margin: 0 8px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-material .ag-column-drop-horizontal-empty-message {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n}\n.ag-theme-material .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 24px;\n}\n\n.ag-theme-material .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 24px;\n}\n\n.ag-theme-material .ag-column-drop-vertical-list {\n padding-bottom: 8px;\n padding-right: 8px;\n padding-left: 8px;\n}\n.ag-theme-material .ag-column-drop-vertical-cell {\n margin-top: 8px;\n}\n.ag-theme-material .ag-column-drop-vertical {\n min-height: 50px;\n}\n.ag-theme-material .ag-column-drop-vertical-icon {\n margin-left: 8px;\n margin-right: 8px;\n}\n.ag-theme-material .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n margin-top: 8px;\n}\n.ag-theme-material .ag-select-agg-func-popup {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n -webkit-box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px;\n background: #fff;\n background: var(--ag-background-color, #fff);\n height: 140px;\n padding: 0;\n}\n.ag-theme-material .ag-select-agg-func-virtual-list-item {\n cursor: default;\n padding-left: 16px;\n}\n.ag-theme-material .ag-select-agg-func-virtual-list-item:hover {\n background-color: #eee;\n background-color: var(--ag-selected-row-background-color, #eee);\n}\n.ag-theme-material .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus {\n outline: none;\n}\n.ag-theme-material .ag-keyboard-focus .ag-select-agg-func-virtual-list-item:focus::after {\n content: \"\";\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 1px;\n left: 1px;\n display: block;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n border: 1px solid;\n border-color: #3f51b5;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-chart-menu {\n border-radius: 2px;\n background: #fff;\n background: var(--ag-background-color, #fff);\n}\n.ag-theme-material .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 2px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-material .ag-chart-menu-icon:hover {\n opacity: 1;\n}\n.ag-theme-material .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: #e2e2e2;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #e2e2e2));\n border-radius: 5px;\n margin: 5px;\n}\n.ag-theme-material .ag-chart-mini-thumbnail:nth-last-child(3), .ag-theme-material .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto;\n}\n.ag-theme-material .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0;\n}\n\n.ag-theme-material .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0;\n}\n\n.ag-theme-material .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0;\n}\n\n.ag-theme-material .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0;\n}\n\n.ag-theme-material .ag-chart-mini-thumbnail.ag-selected {\n border-color: #ff4081;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081)));\n}\n.ag-theme-material .ag-chart-settings-card-item {\n background: rgba(0, 0, 0, 0.87);\n background: var(--ag-foreground-color, rgba(0, 0, 0, 0.87));\n width: 8px;\n height: 8px;\n border-radius: 4px;\n}\n.ag-theme-material .ag-chart-settings-card-item.ag-selected {\n background-color: #ff4081;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081)));\n}\n.ag-theme-material .ag-chart-data-column-drag-handle {\n margin-left: 8px;\n}\n.ag-theme-material .ag-charts-settings-group-container {\n padding: 8px;\n}\n.ag-theme-material .ag-charts-data-group-container {\n padding: 8px 12px;\n}\n.ag-theme-material .ag-charts-data-group-container .ag-charts-data-group-item:not(.ag-charts-format-sub-level-group) {\n height: 32px;\n}\n.ag-theme-material .ag-charts-data-group-container .ag-list-item-hovered::after {\n content: \"\";\n position: absolute;\n left: 0;\n right: 0;\n height: 1px;\n background-color: #3f51b5;\n background-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material .ag-charts-data-group-container .ag-item-highlight-top::after {\n top: 0;\n}\n.ag-theme-material .ag-charts-data-group-container .ag-item-highlight-bottom::after {\n bottom: 0;\n}\n.ag-theme-material .ag-charts-format-top-level-group-container {\n margin-left: 16px;\n padding: 8px;\n}\n.ag-theme-material .ag-charts-format-top-level-group-item {\n margin: 8px 0;\n}\n.ag-theme-material .ag-charts-format-sub-level-group-container {\n padding: 16px 12px;\n padding-bottom: 2px;\n}\n.ag-theme-material .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 14px;\n}\n.ag-theme-material .ag-charts-group-container.ag-group-container-horizontal {\n padding: 8px;\n}\n.ag-theme-material .ag-chart-data-section,\n.ag-theme-material .ag-chart-format-section {\n display: -webkit-box;\n display: flex;\n margin: 0;\n}\n.ag-theme-material .ag-chart-menu-panel {\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa);\n}\n.ag-theme-material .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #e2e2e2;\n border-left-color: var(--ag-border-color, #e2e2e2);\n}\n\n.ag-theme-material .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #e2e2e2;\n border-right-color: var(--ag-border-color, #e2e2e2);\n}\n\n.ag-theme-material .ag-date-time-list-page-title {\n -webkit-box-flex: 1;\n flex-grow: 1;\n text-align: center;\n}\n.ag-theme-material .ag-date-time-list-page-column-label {\n text-align: center;\n}\n.ag-theme-material .ag-date-time-list-page-entry {\n text-align: center;\n}\n.ag-theme-material .ag-checkbox-input-wrapper {\n font-family: \"agGridMaterial\";\n font-size: 18px;\n line-height: 18px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 18px;\n height: 18px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 2px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n}\n.ag-theme-material .ag-checkbox-input-wrapper input, .ag-theme-material .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-material .ag-checkbox-input-wrapper:focus-within, .ag-theme-material .ag-checkbox-input-wrapper:active {\n outline: none;\n -webkit-box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n}\n.ag-theme-material .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-material .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #333;\n color: var(--ag-checkbox-unchecked-color, #333);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-material .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #ff4081;\n color: var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-material .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #333;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, #333));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-material .ag-toggle-button-input-wrapper {\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n width: 36px;\n height: 18px;\n background-color: #333;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, #333));\n border-radius: 9px;\n position: relative;\n -webkit-box-flex: 0;\n flex: none;\n border: 1px solid;\n border-color: #333;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #333));\n}\n.ag-theme-material .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%;\n}\n.ag-theme-material .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n -webkit-box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n}\n.ag-theme-material .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-material .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #ff4081;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081)));\n border-color: #ff4081;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081)));\n}\n.ag-theme-material .ag-toggle-button-input-wrapper::before {\n content: \" \";\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n -webkit-box-sizing: border-box;\n box-sizing: border-box;\n height: 18px;\n width: 18px;\n background-color: #fff;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #fff));\n border-radius: 9px;\n -webkit-transition: left 100ms;\n transition: left 100ms;\n border: 1px solid;\n border-color: #333;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #333)));\n}\n.ag-theme-material .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 18px );\n border-color: #ff4081;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081)));\n}\n.ag-theme-material .ag-radio-button-input-wrapper {\n font-family: \"agGridMaterial\";\n font-size: 18px;\n line-height: 18px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 18px;\n height: 18px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 2px;\n display: inline-block;\n vertical-align: middle;\n -webkit-box-flex: 0;\n flex: none;\n border-radius: 18px;\n}\n.ag-theme-material .ag-radio-button-input-wrapper input, .ag-theme-material .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%;\n}\n.ag-theme-material .ag-radio-button-input-wrapper:focus-within, .ag-theme-material .ag-radio-button-input-wrapper:active {\n outline: none;\n -webkit-box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n}\n.ag-theme-material .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5;\n}\n.ag-theme-material .ag-radio-button-input-wrapper::after {\n content: \"\\f126\";\n color: #333;\n color: var(--ag-checkbox-unchecked-color, #333);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-material .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f127\";\n color: #ff4081;\n color: var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none;\n}\n.ag-theme-material input[class^=ag-][type=range] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible;\n}\n.ag-theme-material input[class^=ag-][type=range]::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #e2e2e2;\n background-color: var(--ag-border-color, #e2e2e2);\n border-radius: 0px;\n border-radius: 2px;\n}\n.ag-theme-material input[class^=ag-][type=range]::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #e2e2e2;\n background-color: var(--ag-border-color, #e2e2e2);\n border-radius: 0px;\n border-radius: 2px;\n}\n.ag-theme-material input[class^=ag-][type=range]::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #e2e2e2;\n background-color: var(--ag-border-color, #e2e2e2);\n border-radius: 0px;\n border-radius: 2px;\n color: transparent;\n width: calc(100% - 2px);\n}\n.ag-theme-material input[class^=ag-][type=range]::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 18px;\n height: 18px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #333;\n border-color: var(--ag-checkbox-unchecked-color, #333);\n border-radius: 18px;\n -webkit-transform: translateY(-7.5px);\n transform: translateY(-7.5px);\n}\n.ag-theme-material input[class^=ag-][type=range]::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 18px;\n height: 18px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #333;\n border-color: var(--ag-checkbox-unchecked-color, #333);\n border-radius: 18px;\n}\n.ag-theme-material input[class^=ag-][type=range]::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 18px;\n height: 18px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #333;\n border-color: var(--ag-checkbox-unchecked-color, #333);\n border-radius: 18px;\n}\n.ag-theme-material input[class^=ag-][type=range]:focus {\n outline: none;\n}\n.ag-theme-material input[class^=ag-][type=range]:focus::-webkit-slider-thumb {\n -webkit-box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n border-color: #ff4081;\n border-color: var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081));\n}\n.ag-theme-material input[class^=ag-][type=range]:focus::-ms-thumb {\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n border-color: #ff4081;\n border-color: var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081));\n}\n.ag-theme-material input[class^=ag-][type=range]:focus::-moz-ag-range-thumb {\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n border-color: #ff4081;\n border-color: var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081));\n}\n.ag-theme-material input[class^=ag-][type=range]:active::-webkit-slider-runnable-track {\n background-color: #3f51b5;\n background-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material input[class^=ag-][type=range]:active::-moz-ag-range-track {\n background-color: #3f51b5;\n background-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material input[class^=ag-][type=range]:active::-ms-track {\n background-color: #3f51b5;\n background-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5));\n}\n.ag-theme-material input[class^=ag-][type=range]:disabled {\n opacity: 0.5;\n}\n.ag-theme-material .ag-filter-toolpanel-header,\n.ag-theme-material .ag-filter-toolpanel-search,\n.ag-theme-material .ag-status-bar,\n.ag-theme-material .ag-header-row,\n.ag-theme-material .ag-panel-title-bar-title,\n.ag-theme-material .ag-side-button-button,\n.ag-theme-material .ag-multi-filter-group-title-bar {\n font-size: 12px;\n font-weight: 600;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)));\n}\n.ag-theme-material .ag-tab {\n height: 36px;\n}\n.ag-theme-material .ag-tabs-header,\n.ag-theme-material .ag-column-drop-horizontal {\n background-color: #eee;\n background-color: var(--ag-subheader-background-color, #eee);\n}\n.ag-theme-material .ag-tabs-body {\n padding: 4px 0;\n}\n.ag-theme-material .ag-tabs-body .ag-menu-list {\n padding-top: 0;\n padding-bottom: 0;\n}\n.ag-theme-material .ag-header-cell, .ag-theme-material .ag-header-group-cell {\n -webkit-transition: background-color 0.5s;\n transition: background-color 0.5s;\n}\n.ag-theme-material .ag-row-last:not(.ag-row-first) .ag-cell-inline-editing {\n bottom: 0;\n}\n.ag-theme-material .ag-cell-inline-editing {\n padding: 8px;\n height: 72px;\n border-color: #e2e2e2 !important;\n border-color: var(--ag-border-color, #e2e2e2) !important;\n}\n.ag-theme-material .ag-has-focus .ag-cell-inline-editing {\n border-color: #3f51b5 !important;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-primary-color, #3f51b5)) !important;\n}\n.ag-theme-material .ag-side-button-button {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n}\n.ag-theme-material .ag-column-drop-vertical {\n border-bottom: solid 1px;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2);\n padding-top: 8px;\n}\n.ag-theme-material .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none;\n}\n.ag-theme-material .ag-column-drop-vertical-cell {\n margin-left: 0;\n}\n.ag-theme-material .ag-column-drop-vertical-empty-message {\n font-size: 12px;\n font-weight: 600;\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n}\n.ag-theme-material .ag-ltr .ag-column-drop-vertical-empty-message {\n padding-left: 34px;\n padding-right: 8px;\n}\n\n.ag-theme-material .ag-rtl .ag-column-drop-vertical-empty-message {\n padding-right: 34px;\n padding-left: 8px;\n}\n\n.ag-theme-material .ag-status-bar {\n border: solid 1px;\n border-color: #e2e2e2;\n border-color: var(--ag-border-color, #e2e2e2);\n}\n.ag-theme-material .ag-column-panel-column-select {\n border-top: solid 1px;\n border-top-color: #e2e2e2;\n border-top-color: var(--ag-border-color, #e2e2e2);\n}\n.ag-theme-material .ag-column-select, .ag-theme-material .ag-column-select-header {\n border-bottom: solid 1px;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2);\n}\n.ag-theme-material .ag-column-select-header {\n height: 56px;\n}\n.ag-theme-material .ag-group-title-bar {\n padding: 6px 8px;\n}\n.ag-theme-material .ag-charts-format-sub-level-group-title-bar {\n padding: 4px 8px;\n}\n.ag-theme-material .ag-chart-data-section,\n.ag-theme-material .ag-chart-format-section {\n padding-bottom: 4px;\n}\n.ag-theme-material .ag-group-toolbar {\n background-color: rgba(238, 238, 238, 0.5);\n}\n.ag-theme-material input[class^=ag-]:not([type]),\n.ag-theme-material input[class^=ag-][type=text],\n.ag-theme-material input[class^=ag-][type=number],\n.ag-theme-material input[class^=ag-][type=tel],\n.ag-theme-material input[class^=ag-][type=date],\n.ag-theme-material input[class^=ag-][type=datetime-local],\n.ag-theme-material textarea[class^=ag-] {\n background: transparent;\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87));\n font-family: inherit;\n font-size: inherit;\n height: 40px;\n padding-bottom: 8px;\n border-width: 0;\n border-bottom: 2px solid;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2);\n}\n.ag-theme-material input[class^=ag-]:focus:not([type]),\n.ag-theme-material input[class^=ag-][type=text]:focus,\n.ag-theme-material input[class^=ag-][type=number]:focus,\n.ag-theme-material input[class^=ag-][type=tel]:focus,\n.ag-theme-material input[class^=ag-][type=date]:focus,\n.ag-theme-material input[class^=ag-][type=datetime-local]:focus,\n.ag-theme-material textarea[class^=ag-]:focus {\n border-bottom: 2px solid;\n border-bottom-color: #3f51b5;\n border-bottom-color: var(--ag-material-primary-color, #3f51b5);\n outline: none;\n -webkit-box-shadow: none;\n box-shadow: none;\n}\n.ag-theme-material input[class^=ag-]:not([type])::-webkit-input-placeholder, .ag-theme-material input[class^=ag-][type=text]::-webkit-input-placeholder, .ag-theme-material input[class^=ag-][type=number]::-webkit-input-placeholder, .ag-theme-material input[class^=ag-][type=tel]::-webkit-input-placeholder, .ag-theme-material input[class^=ag-][type=date]::-webkit-input-placeholder, .ag-theme-material input[class^=ag-][type=datetime-local]::-webkit-input-placeholder, .ag-theme-material textarea[class^=ag-]::-webkit-input-placeholder {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n}\n.ag-theme-material input[class^=ag-]:not([type])::-moz-placeholder, .ag-theme-material input[class^=ag-][type=text]::-moz-placeholder, .ag-theme-material input[class^=ag-][type=number]::-moz-placeholder, .ag-theme-material input[class^=ag-][type=tel]::-moz-placeholder, .ag-theme-material input[class^=ag-][type=date]::-moz-placeholder, .ag-theme-material input[class^=ag-][type=datetime-local]::-moz-placeholder, .ag-theme-material textarea[class^=ag-]::-moz-placeholder {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n}\n.ag-theme-material input[class^=ag-]:not([type])::placeholder,\n.ag-theme-material input[class^=ag-][type=text]::placeholder,\n.ag-theme-material input[class^=ag-][type=number]::placeholder,\n.ag-theme-material input[class^=ag-][type=tel]::placeholder,\n.ag-theme-material input[class^=ag-][type=date]::placeholder,\n.ag-theme-material input[class^=ag-][type=datetime-local]::placeholder,\n.ag-theme-material textarea[class^=ag-]::placeholder {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n}\n.ag-theme-material input[class^=ag-]:disabled:not([type]),\n.ag-theme-material input[class^=ag-][type=text]:disabled,\n.ag-theme-material input[class^=ag-][type=number]:disabled,\n.ag-theme-material input[class^=ag-][type=tel]:disabled,\n.ag-theme-material input[class^=ag-][type=date]:disabled,\n.ag-theme-material input[class^=ag-][type=datetime-local]:disabled,\n.ag-theme-material textarea[class^=ag-]:disabled {\n border-bottom: 1px solid;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2);\n}\n.ag-theme-material input[class^=ag-]:invalid:not([type]),\n.ag-theme-material input[class^=ag-][type=text]:invalid,\n.ag-theme-material input[class^=ag-][type=number]:invalid,\n.ag-theme-material input[class^=ag-][type=tel]:invalid,\n.ag-theme-material input[class^=ag-][type=date]:invalid,\n.ag-theme-material input[class^=ag-][type=datetime-local]:invalid,\n.ag-theme-material textarea[class^=ag-]:invalid {\n border-width: 0;\n border-bottom: 1px solid;\n border-bottom-color: #e02525;\n border-bottom-color: var(--ag-invalid-color, #e02525);\n color: #e02525;\n color: var(--ag-invalid-color, #e02525);\n}\n.ag-theme-material .ag-standard-button {\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background-color: transparent;\n border: 0;\n color: #3f51b5;\n color: var(--ag-material-primary-color, #3f51b5);\n font-family: inherit;\n font-size: inherit;\n margin: 0;\n padding: 0;\n text-transform: uppercase;\n}\n.ag-theme-material .ag-standard-button:disabled {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n background-color: var(--ag-input-disabled-background-color);\n border-color: var(--ag-input-disabled-border-color);\n}\n.ag-theme-material .ag-dnd-ghost {\n font-size: 12px;\n font-weight: 600;\n}\n.ag-theme-material .ag-filter-toolpanel-header {\n height: 32px;\n}\n.ag-theme-material .ag-filter-toolpanel-group-level-0-header {\n height: 56px;\n}\n.ag-theme-material .ag-layout-auto-height .ag-center-cols-clipper, .ag-theme-material .ag-layout-auto-height .ag-center-cols-container, .ag-theme-material .ag-layout-print .ag-center-cols-clipper, .ag-theme-material .ag-layout-print .ag-center-cols-container {\n min-height: 150px;\n}\n.ag-theme-material .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 60px;\n}\n.ag-theme-material .ag-picker-field-wrapper:focus {\n -webkit-box-shadow: 0 0 0 1px #3f51b5;\n box-shadow: 0 0 0 1px #3f51b5;\n}\n", ""]); // Exports module.exports = exports; /***/ }), -/* 246 */ +/* 299 */ /***/ (function(module, exports, __webpack_require__) { -var api = __webpack_require__(225); - var content = __webpack_require__(247); +var api = __webpack_require__(278); + var content = __webpack_require__(300); content = content.__esModule ? content.default : content; @@ -48835,24 +57780,24 @@ var update = api(content, options); module.exports = content.locals || {}; /***/ }), -/* 247 */ +/* 300 */ /***/ (function(module, exports, __webpack_require__) { // Imports -var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227); +var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(280); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, "@font-face {\n font-family: \"agGridAlpine\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABNkAAsAAAAAIqAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlMAAAReYc5joU9TLzIAAANcAAAAQAAAAFZWUVJ5Y21hcAAAA5wAAAHqAAAFgHCsDfxnbHlmAAAFiAAACesAABCUC9Ir6mhlYWQAAA90AAAANAAAADZ2zsSBaGhlYQAAD6gAAAAeAAAAJAfSBC5obXR4AAAPyAAAABcAAAEou4D/+2xvY2EAAA/gAAAAbwAAAJbPsst2bWF4cAAAEFAAAAAfAAAAIAFgAHNuYW1lAAAQcAAAATUAAAJG5xgJvXBvc3QAABGoAAABuQAAApPSPvKNeJx9k81SE1EQhc9kQgwJBkREjREU//GPYX4yJiGQMAFisXDhwoUbXGhpUa54Atc+gOUD+BQ+geXSlQ/gA1g+gN/tTAyyIFOZubf79Onuc/vKk1TRmroqZDv7z1U7PDh6r7qKGv2c//jaO3z75kDl8Q5f0b5lef4f1bSiFzrSN0/ea+9zoeQX/K6/73/wP/k/5IO6pkegq1rnCRXxDhQrUVOpCiphC1k/UQu0z7tt1nktaso8mQa6QM6QmIExruqpbmkOnr7x9LQJKuZxnD3euzy3NXsKItUd+BOq2cDqWBvUeU7T2qHGHnV0iG7hncO3ReaAmD6+PrX5hiqajnt6SeS89eYikxwX8w+1bfvAdkuoMEa14W/C7/gek3Vsb5IpIuIh7Amobq7hKv8q3hhMQGzHNHPRSyAjKoy1zMp1FtHZjG7C/kyvdJ+47TymZyqOer5H9RN73/hS8hy3duDaBfuAGiZWdyJ3yRVoiL/CSWV6p4/6oq/6rp/6pd/gF8kSWQebcG+dqsw0+p1EZ3jb/6yu0zOcxUnU/4gKfTdNmxDfIFfQZZvB57SJWQdYY8NX4XT4jGpS9Jpi8gLLG2Etsd9gH4Ku5dPY4jlrOg+YATcBdbRY5+2YRvOWsr9MtFuN6rpoarXguWSn5TR1N2nWdm7m3SnX0fkK34DOEtNnD+9VLI5pYmlYVErVjmMNf0q1k2yuqgZVRcxA2SZraLcgI9N1+hhVEumG3YChTdUKFST5jVzQeau+k5/UguFCi/JQIshvcmyauUnuU5ubit2/LKNqzAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMb0GmMDCC5ADUogpqeJy11IdSWkEYxfE/RdNM79X0jgJiQIogIMhjmO6Y4pju5CnzJt8LxJzlnjyAmcnO/Fh2udy9O3fPB8wABXkqRcgXyZHab83mpvMFjk7ni/zSeI7D5PW9xBY77EV5f1+zJTbZZjdy09HfltPVc1zjPs80WqNClxZ9aoyp0tHsKm0GNKizzhJNlhkyYYUeIzb0/7xWLzLLIa16RM9xTPc7zglOcorTnOEs5zjPBS5yictc4apWu84N5rnJLW5zh7vc0/oPeMgjHvNE+ynp9wUWKesBZzlYWzvg9alVuq1+bVztaLftQaOujTaXh5OV3mjjH272H9pc+ij89GhCepuZtNtNq8hz68oLa8lL68srq8lrG8sbq8pb68iWpROybavyztry3gbywRry0eqyY+uya0vyyZry2Zbliw3lq6W9f7MV+W49+WEj2TO9wMhlUlYinyH1hUzKVhQzKV8xk9GZJkynmzCdc8J04glLGQxTCghLby9MySBMGSFMaSFMuSFMCSJMWSJMqSJM+SJMSSNMmSNM6SNMOSRMiSRM2SRMKSVMeSVMySVMGSVMaSZMuSZMCSdMWSdMqSdM+SdMlYAw1QTCVB0IU50gTBWDMNUOwlRFCEt1MyxlJmz6/AsZUr+YIfXlDOU/rrOgigAAeJzFF21sU9f1nntjvzgJSRx/vJgQg/3ivNSxwxL7+dkx2JAEEmhIqWpYCqMhMCbWdFppM7EBbsd+dEVV1apS6A/yY9O2oFVaQEOb+sFKtZaRqh/qVLQf/fixdkxkXbNRodIZ3mXnXttpApnW/Zr93rnn3nt8zrnnni8TIPihcyxKqgmBgEdVPAEjYOoBOsdrCgW4yu9HeJxFs4VCJlMoCHLbzes3r7NP2afEhr+qIx7SRIhLURXdtJkChhAwVaAuXcBPnn028uqrNIMg8iwfHR4eXidXInKBPrFgMnzv8DD/YiE9qiWEsh7WQypRjmo6Y07VhJPds7nLaX4GrqZnuQ2uz6ZhCx5F0k6wCeImq/CnQcWu2N2qV/V2mQkzEddb9VaXoqOSqBnqBlcPjI6YqZQ5MvpRGRnpPn68e2JCQjaxaEsi1uvlXYTk/yOTle6tFjFF3l3MqekxjyZG+G0+fzafh4P5PFtmvY0XeJAfK+t5mV0mLuITtx2sBY/T7YdYoCsDhjPeAQ4wVVDZD2587o/58WFVcrTm+N+GZmBqiF3G+aLNG5+Dd+gCTN21mL+6NH+GznUb9yetizRyO2fr4oMLeTLJ0xlwhpbiizxZ1S18i4vfvZVv0Xbs++yb6L+VpJEQByiqA5i5Euzi6jxub1fCENdGP+Ej3Xu5BZmZmQunq6t9dd7ODZ3eOh/8Hn6axg3+KqydmcksW+ZvavUFOzuDvtAKv2BfIWVEMa6K91NHSCjgDNg0Z8ylOdPg1Jwsaj1FD/DN8q5eyhdoLM+PiZsq3lbJ7+lp5GFDHSm6DxyEFL+AYcii/AKfKcVj8Tw/ZOfwND7SLC1v92CUBFSJuL1oqATaqVVzoQ70NK/ROnNwNc8NoTK8gVADbsAb7OXOoPUC7b+nU7NeEHu0X+u09tH+Ugw+zZ4WvuYANJfiAB3dBa7Cvb18Cnb08pN8qhd2IKCJRVPYgSTkljgGXUEb6Aqw9TKQYYsIZLjObbMY1IvPHkKBioq2moEk5qGzkIRUduHZn8A4aCIdZK3ga6qJWJcfVoJSCyIp2ZUOuhrMDKg499NYl6nbtWAHGHFTVxNI6VbUhNlBg9C4NjKwfWT75HgzY+6+aDRi7hr7+uT4iooKz9BotM+9fPTowN2b0mGjfVM4UJlsuWdT2D0w1OLbc/RJ+nP87R19h7dWVZu7tI5IIgbQd2hrddWafY7me7rW7zVbuleG+9uN9t1Jd3gg1zKQ3omLC/SvxdwRRf3RpYUyUtdQhpZOQlHh1WDDTfR23ETvpxX9R/f4UPhTR0eXo2r8/IrxyV9J5ZslsqICfhzeFA5v2iYA+My961FkEV7aerhPaFtVGidRp4GwBKWYG0PbK2QZaqR4FKduBGyqxzRMNlZ4qUBPWdPvZ9+jc4XJszBcyGbffy8z+T4p50J6jc7hvTnkbeiKKnISvfbKK+lCgRu5HBjnzqVlbakhNcU4QfpynIjc0URWEo3opJ2sJsTUjJi64A39lznWqbPZ7EsSWm/9p0khX/xkS2OmNKI6lfPnv1UnAlgdQ/i6UI6Br46vWFNwDODIxoSPWm9LViiCnuIziMFv+Aw9IOXyzVmUleXHUIVMJrOEzVzo61iA0WZXpMngYC5Hz0iT8RpyWxxhscYw1ANsfTF0YIsII+qf7eZn+Jnu2XKMTNDzWJ8aSQQlxDOQBkMr+pHEOkDF1BzSPBg6tBbaARHpaz8LrtGmplK7k8ndqakpbU3wORjiv4aDEgdtfhOuamntruTIQyPJu7S0kptCuFGs7D4wkpQ2vXmTzco8fotNA5gTRXG0ic4BlbCJBqQ0F/mSLh8cPHbNvEbbzWsmJpQ3IW4NCrgL5/QT3OFvDg5CvBUxfMy1g4OD4zjic+2PEC/XkOfYc6iFU+bhmAfQKTEZagbogPWSHxsG2sP5h1g07+W8B+gHWTj4oVxjLn7sA7k2n2++9Fe0vzH/LWb08gspvOd8piz/HfZOUf682HlFsvNC0X/KmgilimL/VNZkviZMF/OiSG8qwPfSnKchxaI4dkOy5E+XWL3sz0SmVbG0KaL5oJeuXImcPx+RkPrl8JiE82cr9jEBzKZLdzIQF2isy6tCB0CwVQc/eNyCcKm+hvdEI4Nbdqb2t/NosAW2IALvBlvE4lJtDh/ZuWUwEm0J8mj7fv73liC8274/JdfK+j2Adc6LfqOjfhrmQrui3VLkAl1etz3YGk+AMHDAiLHGU8vWbV237JQsaQMC8g+cPl/Q5wPDej4HP8mxsVBHRwir3z5JcyLY2ag14mM10BMiKRTv8Ag7TIKlKpMoflWzVQxZAMWOhkZTKfY6NLkuegm0eitaBgQFliDVG/MiqsPdz2D2tjmau1ebeyvranwNqhv8nnUb9gNQ5vZE1eN/icAll6Omsn4y0dblhOWVKoVKOlFZVV1X21B/ER55xlFdXVfTVu2oHl3ub2xyNdTyj1Zsq9lnt/mM9q+p1ciBPlVf76r1TtYy1sT/anfrjfGG4xUVoFQ2XBTHqZJnmmbTGImrSBtZTzaSO0mO7CSj5Ft4Rj9VG1gtVSpCHVSnrgw1W2wBpxcrqZmwuVVRmAzpVorucWO90lQ58UrDhNxqzMDaGzPMMKBFYpioPTG9A/SQXVM8MbMVcw1ztm0IA6oU3tDGP+YffzmDZjhkXfjHnBanDqsSaFxbBS9WRbblIo7wxrZxR2TbtkjVupau5X6wXocjhwHy2fidSYBDWfjdIUGP5kiFHz2X7H+U/XJJ/s1ydsN63e5A8rm3nPUoDA5DnWTueLCtv506IjmUAzbF5Q37NyYfeXmz8ei/EqGR7JEjQaRmAEfy8MhtcSkzMp1O8wuQSnP6WVp0a92cLOxn3eSOcoTVC7dZJcxWLyKMBQWUYdYldkrB9fj4gd6+vt4D41Bfxh7/zq4dhmkaO3a9V0bYZbHB/7mY+MaRRUQSKcWT0KUG4z0htJEFoZj49f9Btb6He3sfflyAvq+mJZ0r0SMofGWFb6t9iopFV6TABf8BZT85241/BovnG2Rjsq7KTkbkQPyXG5AdSTEXWh/T09ZWTNYZmJUL/GSWzllvl2UxekLcmssBl6AO6ugJrH5Dpfs+wZjYc9DiKmP8Cr+yeA97V2xtsWTKXy/Ns0hQ2vsFc8l+X/TYJtwPX/Ra5/mfe6BJYH+AlT0luijtFSd04WnOyoLTc9+8faJ0ulgfdOzS6WeyLECKTmOdEC65INePYUXykC6RS0XpB4/Xrqj4pwodAOM5Jnpmz5c9ghFPmCoSqviYQF8rNgFmeG08m9y95xu5Suv5H3UPlDuFns7tKx8aGTgZt/rpa9gOaJEN1Wub9qxJjSSncvDA0cZvr0vJbkHr3GzbnrsPKemLhPwbDwYCEQB4nGNgZGBgAOLsD0FR8fw2Xxm4mV8ABaI4H+9rgNH/f///zfyW+S1QJQcDE5BkAACRug+HeJxjYGRgYH7BwAAi///+/5v5LQMjAyrwAgCe2QcHAAB4nGNgYGBgfgHC/39D6KGH6QEAIHUuCwB4nGNgAAIphiCGDIZFDHcYvjGqMQYwVjGuYTzH+IhJhMmMyYcpgekAMxezBrMDcxfzIeZbzJ9YTFiKWGawbGK5wfKKlY01jHUK6z+2JWw72P6xR7Dnsfexz2Ffxb6D/Rj7LfYX7H84vEiHANyaI6IAeJxjYGRgYPBiSGfgYQABJiDmAkIGhv9gPgMAGzsB1AB4nHWRPU7DQBCFnxMniBghJCREx1Y0SM5PQZEuFHGfIgWdE68dR7bXWm8ipeMYnIBjUHIETsEheDFTREjZ1a6/+fbNNAZwgy94OC4PV+19XB1csPrjLulW2Cc/CPcQ4Em4T/8sPKB9EQ7YWXKC51/S3ONNuINrvAt36T+EffKncA93+Bbu0/8ID7D0fOEAj95rnEU2T2ZFnVd6obNdEdtTdcpLbZvcVGocjk51pCttY6cTtTqoZp9NnEtVak2p5qZyuiiMqq3Z6rULN87V0+EwFR+uTYkYGSJY5EgwQ4GaVEFjwZNhRxPz9VzqnF/yWDSsDGuFMUKMzqYjnqrtiOH4TdixwoF3gz17JrQOKeuUGcO/ojBvJx/TBbehqdu3Lc2aPsSm7aoxxZA7/ZcPmeKkXwK+aWkAAAB4nG2S6W7bMBCE/cWSI9tpk7ptet/3obbpfaf3kT4FQ9EyEYkUSMp28vRl4yBAgO4fzgwWs7MLdpY6ixp0/l9bLNElIaXHMhl9BgxZ4RjHWWWNE4w4ySlOs84ZznKO81zgIpe4zBWuco3r3OAmt7jNHe5yj/s84CE5j3jMEzZ4yjOe84KXvOI1b3jLO97zgY9s8onPfOEr3/jOD37yi99s8aczFGXpVCmCtqYnnLMz3xVe9qQwUlXZ4sk3UjkRLqzJiZI723ae7wNVrB8K2hQqKFdrI4IaHcqtOehckbayLm90JG45krY2fiCtCU7IoIpE2mY3lc56nxTKy0zNGxE9i77aVbmvhJ90I+qNdRXHpGPtfEhKp5u0dLZtktgQkkqNQ6/SJs5brqwotCmzWsx1rfdUUivTZjHfghk1D4mxRg2NDbmoKjtTRdpEF9VttEkbPbUha5yaatv6NRfNbL7dhmBNbsfj1aOCSZ0uJyHxYqoGvo52eWFn5gD+izVcwP22bIFj6hDPMQpOqaP36+9LtlEma81iHwQlDkVAYzHM8EgqJuywzTx+g4KaloZdxuwx7XT+AvL3sQsAAAA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n\n.ag-icon {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n\n.ag-icon-aggregation:before {\n content: \"\\f101\"; }\n\n.ag-icon-arrows:before {\n content: \"\\f102\"; }\n\n.ag-icon-asc:before {\n content: \"\\f103\"; }\n\n.ag-icon-cancel:before {\n content: \"\\f104\"; }\n\n.ag-icon-chart:before {\n content: \"\\f105\"; }\n\n.ag-icon-color-picker:before {\n content: \"\\f109\"; }\n\n.ag-icon-columns:before {\n content: \"\\f10a\"; }\n\n.ag-icon-contracted:before {\n content: \"\\f10b\"; }\n\n.ag-icon-copy:before {\n content: \"\\f10c\"; }\n\n.ag-icon-cross:before {\n content: \"\\f10d\"; }\n\n.ag-icon-desc:before {\n content: \"\\f10e\"; }\n\n.ag-icon-expanded:before {\n content: \"\\f10f\"; }\n\n.ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n\n.ag-icon-eye:before {\n content: \"\\f111\"; }\n\n.ag-icon-filter:before {\n content: \"\\f112\"; }\n\n.ag-icon-first:before {\n content: \"\\f113\"; }\n\n.ag-icon-grip:before {\n content: \"\\f114\"; }\n\n.ag-icon-group:before {\n content: \"\\f115\"; }\n\n.ag-icon-last:before {\n content: \"\\f116\"; }\n\n.ag-icon-left:before {\n content: \"\\f117\"; }\n\n.ag-icon-linked:before {\n content: \"\\f118\"; }\n\n.ag-icon-loading:before {\n content: \"\\f119\"; }\n\n.ag-icon-maximize:before {\n content: \"\\f11a\"; }\n\n.ag-icon-menu:before {\n content: \"\\f11b\"; }\n\n.ag-icon-minimize:before {\n content: \"\\f11c\"; }\n\n.ag-icon-next:before {\n content: \"\\f11d\"; }\n\n.ag-icon-none:before {\n content: \"\\f11e\"; }\n\n.ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n\n.ag-icon-paste:before {\n content: \"\\f120\"; }\n\n.ag-icon-pin:before {\n content: \"\\f121\"; }\n\n.ag-icon-pivot:before {\n content: \"\\f122\"; }\n\n.ag-icon-previous:before {\n content: \"\\f123\"; }\n\n.ag-icon-right:before {\n content: \"\\f126\"; }\n\n.ag-icon-save:before {\n content: \"\\f127\"; }\n\n.ag-icon-small-down:before {\n content: \"\\f128\"; }\n\n.ag-icon-small-left:before {\n content: \"\\f129\"; }\n\n.ag-icon-small-right:before {\n content: \"\\f12a\"; }\n\n.ag-icon-small-up:before {\n content: \"\\f12b\"; }\n\n.ag-icon-tick:before {\n content: \"\\f12c\"; }\n\n.ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n\n.ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n\n.ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n\n.ag-icon-unlinked:before {\n content: \"\\f130\"; }\n\n.ag-icon-row-drag:before {\n content: \"\\f114\"; }\n\n.ag-right-arrow:before {\n content: \"\\f117\"; }\n\n.ag-right-arrow:before {\n content: \"\\f126\"; }\n\n", ""]); +exports.push([module.i, "@font-face {\n font-family: \"agGridAlpine\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABWoAAsAAAAAJ9AAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAmYAAAR2ZcBn9U9TLzIAAANwAAAAQQAAAFZWUVMIY21hcAAAA7QAAAIcAAAFnIMq5ipnbHlmAAAF0AAAC80AABVszjC1ZWhlYWQAABGgAAAANAAAADZ2zsSBaGhlYQAAEdQAAAAeAAAAJAfSBDFobXR4AAAR9AAAABcAAAE0xzj/+2xvY2EAABIMAAAAdQAAAJwYJx3EbWF4cAAAEoQAAAAfAAAAIAFjAKpuYW1lAAASpAAAATUAAAJG5xgJvXBvc3QAABPcAAAByQAAAqgIzxhUeJx9lEtyElEUhv+mm0gCJilFjRhjovEVXzF2uhuaRx4QEDJwYFkOnMSyyrKKcsQ6XIAryNAVuAAHrsAFOHDo2PK7h0ZMBuEWze3z+M9//3Mu8iTNaVNN5doHhy81PzwafVRFgcYf5/9/7w0/vD9SYfKGL7DfgrygpHnd1GuN9M2b90beca7sV/xX/jv/s//F/yWfqFU9JrqobVakmGeoRFXVlCqnGWwR+7oaRPs8m2a9oKvKm6ernpaoGZHTM8QN9XVPi+B0DKetPaISlsNs8xyw7mvhjIgUlDy+be1gDVBkBU3qKmtWz2HZhkmL/Ab+i9Tcp3ZIVgdfB3Z5LE32LV2Ck8sITNWe3ugpfndSh1LNchK+kQ7sPbS3NTSZRDXBqVHLYW/BYGKvgReTsQl6lajdTNEN3SK7Bk4btJZl1y17jcgYbgl9CeycMVxLWmf/Qm/pRREW45y2aTpW4CHsp/aO4aV6dMLaAmtA7BM4TK2uPw+oFdKVGPQlfEN90rG+6rt+6Kd+64/O6TJ1YjvDHuj7Z2pTQMHT0V28zX9Wd9YZZuB01MmIWU5eM3UifL1MQ1etyMmcOgn7EGti8XPwdPFd2KT0I6BGaHVdp/OsHd4jos9n09lglUzpHlOwYBPct1moMKNbum6I4zlM0XoZRLcb86uYbg3wrlnfnLruhi3am7sLrt8VurPCb8gJq6bTId5VLA5parlhWSnsHcYz/Cmsp9Ucq2VYhbqLz81Y325Hl0rrnGfMJNYduxl9m6/bMKhmN7VMDx37VtaxKxYXWZbHP0GY3fDEtHMz3YGbm4/BX0ArchMAAHicY2BkmsY4gYGVgYGpimkPAwNDD4RmfMBgyMgEFGVgZWbACgLSXFMYDjDofjRifgHkRjG/BZnCwAiSAwDkfwr5AAAAeJy11AdSG0EQheFfgSxwIOecEWCCySCiEHAJnCkcKJw5h8/me/QJ8Bt1+wC4ylv1qXdGq92ZWr0GaoCczEkesvVkdEYmq9lMdT5HY3U+z2+NC9ST1XmRK264s6X7e80WueSaW8tUR3+PjK4u0McEzzU6YoUDdjlmjXNWKbHBPnucsMUmp7pmh3XKnLHNIRUu9Pu0irzWWEudntuglTTpjs208JgntNJGOx100kU3PfTqWf0MMMgQw4wwyhjjevokU0wzw6x2U2SeBRb1/TOWWNYia3nYcfTA69OxcrB7vHa+WtKO9062NrXZnfXy2fZh5eIfbvYfjkL6yP2K0Tnpjbq028uwIi/CgbwMu/IqHMvrsCZvQrrn27Aq70JJrsKGXId9eR/25EM4kY9hSz6FTbkJp3Ib0j/vc9iRL2FdvoayfAtn8j1sy49wKD9DRe6CXqBlXMqLZR2p5lzKl+VdypjVuJQ9q3WkWudItd6RaoMj1UaXMmlNjlQLLr1Ja3ak2uJI9ZFTdrCgFGFBecKeOiULa3XKGNbmlDas3Sl3WIdTArFOpyxiXU6pxLqd8on1OCUV63XKLNbnlF6s3ynH2IBTorFBp+xiQ04px4ad8o6NOCUfG3XqAdiYUzfAxp36Ajbh1CGwSadegU05dQ1s2ql/YDMu9UubdSknNufUXbCiU5/B5p06DrbgqutfdOpCWFA/wgLLfwB3H6YceJztWHtwVNUZv9852b179/2+WUI22b3ZXNjshib7uEkWdkMSSMAQcVwwQDFEikONtqK0KBAR/2hNHavjDPgH6Uw7bcPUmUZaph0VKk6VEkeldqTtDOof1dKSqmlxGLGBvfQ7Z3dDAqnaPzttsnvej+98z9+3Agj4R6ZoXLAIAoR8sugLpUKaGiJTunV6Gi7qd2F5kMZz09PZ7PQ0W264evnqZfoR/Ugw4C6H4BOqBMEjyqKqGTRWRrCgMmt6VFZ+8PTTsZdfJlksYk/rg/39/e18JMYHyGOzOv0b+vv1T2evR7LYpbSDdggS3iNrroRL1iQ43DaZP5/Rj+pH4WJmUjfA5ckMrNGPCoSvP0APCF6hFreHRaNo9Mp+2d+spbV0Uq1X6z2iioQidUgfXNwxOKC1tmoDg++VGwNtBw+2HTjAS3pgzhRvFF4tz2LJrivx0Y4tkfMy4VLUhE9hNfxyePj48DDsGh6mtsJpZOgufUQo0Xmenhc8QoBxP2wHn8sbhESoOQspV7IRJNBkkOmDVz4JJoL4oWZeF6b0v/VNwFgfPY/9OZNXPgF/3ykYu3nu+fL851MU9g2nP144Q2I3nlw4c+/sMyk/0xVyReY7F8+k5uvOLQ5+/fpzi7yjD9CvoD6ZhEpBkECUJaBaDRiZ6Hxef3M6xcRGPtAH2rbqBchOTJw6YrEEHP6mFU1+RwB+DT/I4IT+MiybmMjabMGq+kC4qSkciCwMsuMr+B1x1POifByCEAm5QgbFlfAorgy4FBeNF54gO/TVXFbHhqdJYlgfYZIqSqukh+QInmFAGgmqD+yCVv0UmgWN66f0iZJ9FN/zMD2BrwkI1ZzzRh9qbUjmDa8fGZVGPtUrHqSBHNGtSlMeLg7rKUYyvIalAnoKXqMvNoULz5PuW5uUwvNsjnQrTYVtpLtkE0/SJ5muSYDsEiVQUV3gImzo1MdgY6d+WB/rhI1YkPScLmzEJbjdKAhXr9Cv0Q8FJ2pItdAjPCx8D6lF81ANswilSgrlLBtlfwY8Ea+dKOHGilQySxLNQfB5jeF6tREU3IAq0JzWstDsl712HMHhVDLdHKQJJr9GUBtJMgu4i5Q2FffUgF8OEjTFtNaEm4Pg9TnATsKNsITidj+9R7zzXoPep2qaStKqtvKo3gEjBKjBeZboA5I76HXKXqfZYKsMeeQ6j9lmqjB5HfJCq1zrNxKT3fwzd9hf7bI5JbtJNDmsLr/F7fRWudw1fnely2S2iRUGR9BttBjcbovNbV7aECWUmCwmA0kR0eywGkmCgtltIn81ffMRA2lRr/yWEzPy5pXv0Ad+H5BchSf/aK0JekzuqtqIL5yq9y5U3ZLDbPN5k821Df7KSrPD7ggs9jssEbfFbgm4rLLb7jIZRU+oMeKx+Sp9TrPF4fbYJItERdEgeqq/e+y4ZDGaRZvZIJ2RHCbJLp12SGanW/i/7P6rZTcnnoEqou9R0Xrpch7QYA3+Y0CDy7phEsMbrCn5rznyXvW5stZYmEumE83+GsgRJjq/z+sAGUVkh3D9EhCZMtSnkp8toviGmyTR4HW4PM6l7Wa70WZyeHx9eatZcnvdFf23VUguHPks5k48OGS3WfxOT+XGjQ63weC0uqrvedDhc9slybhvt9FkdDnc/ytvnBNDIui4RRljzgS0IL46Di3QmpsdQx5DPFElNArLmJ5ocpoZbQ0+ChjYMipGtDJAm5VxIIgWreFYmNmtpsppZouinNYaSRgql8V61g+sH91ZTam3Kx6PaZuHbhvdubCiwtc3GO/yLhjc33PLqkw01bAqGjK11N26Kurt6asL3LH/cfIj3Lu4a89as0XbrDTG0glYsXutxbx0m1R9a/PyrVpdW020uyHVsKXFG+3J1/VkNuHgLPrtiMHiSD9CA0YLJzWSJaWXcE8BBpxEH4OT6FJIRff+OwJ49xP7BxcgZfrJhTtHf8ppr+aNhRXw7eiqaHTVOlZAQNu6HK8slufW7ulixJpL9SjS1BPlRQm7DCHvRcGGFIk+0aWmQgbZp6U0OjR9bJo8Wxh/O3eWTE2PHof+6Vzu7bPZ0be5yHhxiUyh3LjVaqooM2xHLr30UmZ6Wk/l85A6cSLDMbNVsBbxBq4v4w2GwaqEGkERVKFBWCIImpJKyLO+kc/pI/4+nssd42XhjX/XmR4u/uVKdbZUIzmmmfdfT5MAiPoj+PXgPSn8qvhlYyLWIazpENPRwml+FF5BntUnsAW/0CfIDn6vvjqHd+X0ESQhm83OwzMP6jomFsizC5xlsCufJ0c5y3TrXL9oYphJY3BGDdHlZT/IfCIJTrYxyN82WbaRA+QkZiABtBLBgxEqAymlqEe8hdYgI8aNKD4WuuzQANjgyqb8MLxUGRtr3dLSsqV1bExZGn4G+vSfwy7eBuXaJFxUMsrNLQP3DbTcjK1ofgyrlWxoy46BFs7Xq1fpJMfE1/E1hPiSJRoGlhUhHQaWXJX6DHuSBb29I5e0S6RBu6QhOHsdkoVeVm7GPvkAZ/TXe3shWY8t/GjLent7d2KNn0u/g2QZjz9Dn0EqXBzTJnyAionAEj2lCph76CP9QDp0/V1MQDbo6PfIOznY9S4fox595B0+NuNzruksyiA1819Ex+UvtKKsh7Pl+9+kbxbvn7l2hpDczKWoQ2VKGFHFa/9QpmTGN44XfSNzcTLANzK6noFWGse6DVpKOnWOOnnuyaKnjGmCyBI5cu7ChdjJkzFekiCvvsXLmbcVc8IQ05V5s0JIsiZGERkaAQOICgwksYXz5Yh6RzzWu2ZT6/YGPR6ugzXYgLfCdWxwvpRRH9i0pjcWrwvr8Ybt+od1YXirYXsrHyvTdzfmDD4hKNQjfQqDWKIyN2EINfsZ/EqmgfE3lErQynF7+9p227M8O+jBUn/BFQiEAwFIFZ7Lw/fzdCjS2BjBPGIbX3Io3FSpVOKn4CaHuFsoyXAv3YMa28Z9W7r4L2v1WIFoRC4jn0SjA/mtsqQMWV6PbAG2CkOQ7E/4sanCLU+h+zZI1W1LtK32tupaCPraV2wHINTri8sH/xyDcx7JanKOphc1u2CBSSZgIgdMCJ/sbucZeOgpyWJxWBdZJMtg47KgT39v4TrrNqMhkGr4kmzB7eQJp9Nj94/aKa3S/2L0qpVJ98GKChBN7jOCmb9jnI6j9dUKi4TlwkrhJiEvbBIGhTvxXUEiu6mdiBWRRqIST5ZodYaQy48BVEsbvDILSCmuSqLqQ/wgKjLv+DkzIl45kVKNYiKlRQEZkUAH7UsgDlYjRkX0JbR6dDHUtWhFFJCe6IpF+vv6+9d6UA27C6f+PqUkiVQwAUkqtfCCObYuH5OiKxftlGLr1sXM7XXNC4JQeBX27gEYziVvagHYnYNf7WbrkRet0X0nWrr30Z/Me341710pvGqUcPnUGy4nXgZ7wMEPl+5d1N1ApFge7wGEqP5ocGXLQy+uTu37ZzoykNu7N4yrKcDeYXjoBlvknpiMZ/RT0JrRyccZlu226cLs3wO8wuKyVTmZttQytjmZVdEwh2ms38xmSgb16M4dnV1dnTt2grPcevSezRtTmpbauPlsuUHPswn9H3MXX9k7ZxFvlGyI0WJFG08zanggKPp79T8grev+zs77H2VF1xejkkyV1mMx/YUJviEXEGUMtuy3j7m/aPHMYLKNZQbXsGEvHeJxlSMZ5v8A93JEUvSDhffJkcJadNRZmOQD+uEcmSqcLt9JySEmPY8E58ABDnIIY19fSe6HKGVzEimOUqpf0C/MnUPsivRgwOS75z+zuKA092Pq4b+bsN8qNLgLPu0snNT/1AFVrPUbqOkorYuTTvZCD77mOA82HbfP8ClOxouxgeVL5GMeEqCVjGOMYKo5y88PCW7BLySYH/XxVNdvFOUssExWQcNOMMzsmwUSkmlNxpUyfjQgrxQxgBZdlswhAFj85byp8NwjbT1lpNDRtL7mvoGew8lCN3mFYYLYCsuyqjuWtg60jOXh7v2VX21vLYKFptWG9fnbcSV54V8PFbSvAAAAeJxjYGRgYADiJZeya+P5bb4ycDO/AApEcT7e1wCj///+/5v5LfNboEoOBiYgyQAAoN8P3nicY2BkYGB+wcAAIv///v+b+S0DIwMq8AUAntwHCgAAeJxjYGBgYH4Bwv9/Q+ihjekBAG/aMMwAeJxjYAACKYYghiyGJQz7GN4xSjA6MZYwTmNcxXiH8R/THeZdzFdY3Fh2sJxh1WEtY53Cuob1G5semxtbHNsitgfsbOwK7G7sEewl7Ec4mDjSOHk4FTjTOA9w3uL8xcXBJcalwmXE5cYVwpXBtY10CAAggCv3AAAAeJxjYGRgYPBlmMfAwwACTEDMBYQMDP/BfAYAIOsCDgB4nHWRPU7DQBCFnxMniBghJCREx1Y0SM5PQZEuFHGfIgWdE68dR7bXWm8ipeMYnIBjUHIETsEheDFTREjZ1a6/+fbNNAZwgy94OC4PV+19XB1csPrjLulW2Cc/CPcQ4Em4T/8sPKB9EQ7YWXKC51/S3ONNuINrvAt36T+EffKncA93+Bbu0/8ID7D0fOEAj95rnEU2T2ZFnVd6obNdEdtTdcpLbZvcVGocjk51pCttY6cTtTqoZp9NnEtVak2p5qZyuiiMqq3Z6rULN87V0+EwFR+uTYkYGSJY5EgwQ4GaVEFjwZNhRxPz9VzqnF/yWDSsDGuFMUKMzqYjnqrtiOH4TdixwoF3gz17JrQOKeuUGcO/ojBvJx/TBbehqdu3Lc2aPsSm7aoxxZA7/ZcPmeKkXwK+aWkAAAB4nG2SB2/bMBSE/cWS7dhp46ZtuvceapvuvXeb/geGomUiEimQlO3k15e1gwAB+gASd4eHe8cHtpZai+q3/l+bLNEmIaVDlx7L9BmwwiEOs8qQI6xxlGMcZ50TnOQUpznDWc5xngtc5BKXucJVrnGdG9zkFre5w10y7nGfB2zwkEc85glPecZzXvCSV7zmDW95x3s+8JFPfOYLX/nGd37wk1/8ZpM/rYEoCqcKEbQ1HeGcnfq28LIjhZGqTOVYuDCUYyW3t+wsmwOVr+8L2uQqKFdpI4Ja25cbs9e5Im1pXVbrSFw3kqYyvi+tCU7IoPJE2nonlc5635Z+ksaTbSS58jJVsxigO7+zjZ6a1SLOypfVjsp8Kfy4HVFnpMs4Ph1p50NSOF2nhbNNncSGkJRqFDqlNjFHt7Qi16boVWKmK72rkkqZphdzL5hRs5AYa9TA2JCJsrRTlad1dFHtWpu01hMberVTE20bP3TRzGZbTQjWZHY0Wj0omNTpYhwSLyaq76tol+V2avbgv1iDBZy39RY4pg5xTWvBKXVwr8tzydbK9BqzeA+CAocioLEYpngkJWO22WIW/0ZORUPNDhNG7LZafwFegLa2AAAA\") format(\"woff\");\n font-weight: normal;\n font-style: normal;\n}\n.ag-icon {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n\n.ag-icon-aggregation::before {\n content: \"\\f101\";\n}\n\n.ag-icon-arrows::before {\n content: \"\\f102\";\n}\n\n.ag-icon-asc::before {\n content: \"\\f103\";\n}\n\n.ag-icon-cancel::before {\n content: \"\\f104\";\n}\n\n.ag-icon-chart::before {\n content: \"\\f105\";\n}\n\n.ag-icon-color-picker::before {\n content: \"\\f109\";\n}\n\n.ag-icon-columns::before {\n content: \"\\f10a\";\n}\n\n.ag-icon-contracted::before {\n content: \"\\f10b\";\n}\n\n.ag-icon-copy::before {\n content: \"\\f10c\";\n}\n\n.ag-icon-cross::before {\n content: \"\\f10d\";\n}\n\n.ag-icon-csv::before {\n content: \"\\f10e\";\n}\n\n.ag-icon-desc::before {\n content: \"\\f10f\";\n}\n\n.ag-icon-excel::before {\n content: \"\\f110\";\n}\n\n.ag-icon-expanded::before {\n content: \"\\f111\";\n}\n\n.ag-icon-eye-slash::before {\n content: \"\\f112\";\n}\n\n.ag-icon-eye::before {\n content: \"\\f113\";\n}\n\n.ag-icon-filter::before {\n content: \"\\f114\";\n}\n\n.ag-icon-first::before {\n content: \"\\f115\";\n}\n\n.ag-icon-grip::before {\n content: \"\\f116\";\n}\n\n.ag-icon-group::before {\n content: \"\\f117\";\n}\n\n.ag-icon-last::before {\n content: \"\\f118\";\n}\n\n.ag-icon-left::before {\n content: \"\\f119\";\n}\n\n.ag-icon-linked::before {\n content: \"\\f11a\";\n}\n\n.ag-icon-loading::before {\n content: \"\\f11b\";\n}\n\n.ag-icon-maximize::before {\n content: \"\\f11c\";\n}\n\n.ag-icon-menu::before {\n content: \"\\f11d\";\n}\n\n.ag-icon-minimize::before {\n content: \"\\f11e\";\n}\n\n.ag-icon-next::before {\n content: \"\\f11f\";\n}\n\n.ag-icon-none::before {\n content: \"\\f120\";\n}\n\n.ag-icon-not-allowed::before {\n content: \"\\f121\";\n}\n\n.ag-icon-paste::before {\n content: \"\\f122\";\n}\n\n.ag-icon-pin::before {\n content: \"\\f123\";\n}\n\n.ag-icon-pivot::before {\n content: \"\\f124\";\n}\n\n.ag-icon-previous::before {\n content: \"\\f125\";\n}\n\n.ag-icon-right::before {\n content: \"\\f128\";\n}\n\n.ag-icon-save::before {\n content: \"\\f129\";\n}\n\n.ag-icon-small-down::before {\n content: \"\\f12a\";\n}\n\n.ag-icon-small-left::before {\n content: \"\\f12b\";\n}\n\n.ag-icon-small-right::before {\n content: \"\\f12c\";\n}\n\n.ag-icon-small-up::before {\n content: \"\\f12d\";\n}\n\n.ag-icon-tick::before {\n content: \"\\f12e\";\n}\n\n.ag-icon-tree-closed::before {\n content: \"\\f12f\";\n}\n\n.ag-icon-tree-indeterminate::before {\n content: \"\\f130\";\n}\n\n.ag-icon-tree-open::before {\n content: \"\\f131\";\n}\n\n.ag-icon-unlinked::before {\n content: \"\\f132\";\n}\n\n.ag-icon-row-drag::before {\n content: \"\\f116\";\n}\n\n.ag-left-arrow::before {\n content: \"\\f119\";\n}\n\n.ag-right-arrow::before {\n content: \"\\f128\";\n}\n", ""]); // Exports module.exports = exports; /***/ }), -/* 248 */ +/* 301 */ /***/ (function(module, exports, __webpack_require__) { -var api = __webpack_require__(225); - var content = __webpack_require__(249); +var api = __webpack_require__(278); + var content = __webpack_require__(302); content = content.__esModule ? content.default : content; @@ -48872,24 +57817,24 @@ var update = api(content, options); module.exports = content.locals || {}; /***/ }), -/* 249 */ +/* 302 */ /***/ (function(module, exports, __webpack_require__) { // Imports -var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227); +var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(280); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, "@font-face {\n font-family: \"agGridBalham\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABX4AAsAAAAAJ8wAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlEAAAReXgFf/09TLzIAAANcAAAAPgAAAFZWTFJaY21hcAAAA5wAAAHtAAAFgFIH7gFnbHlmAAAFjAAADLgAABYYNphscGhlYWQAABJEAAAALwAAADZ2zsSBaGhlYQAAEnQAAAAbAAAAJAfTBC1obXR4AAASkAAAABIAAAEUp/gAAGxvY2EAABKkAAAAZAAAAIwBFQakbWF4cAAAEwgAAAAfAAAAIAFbAHNuYW1lAAATKAAAATUAAAJG0OP3eXBvc3QAABRgAAABlwAAAlqez14KeJx9k09yElEQxr9hCBKISYwxloga/0bjOAwM/yQQCFKWZWXhwoULN3GhpZVylRO49gCWB/AUnsBy6coDeADLA/jrZpCYRXjFzJvur7/+ul8/BZJKSrSr3OTx/nMtHx4cvVdFeU1/5j++Dw7fvjlQcfaFL+/vooLwj5Z1Qy90pG+BgtfB51whzIW74X74IfwU/lAIalMx6LIesGLVeEZkr6uhVDkVsMXsm2qBDnm23bqmC1pwz1AjrZMzJmbkjNt6qptahWfgPH31QCUs4+zzHLNuaeUURKrb8NdR08VqrFUyrGpRe2jso6NDdAvvCr4dMkfEDPANdA68ofLexyd6iaI1r80i6xku4R/TZfuO/KvMmqHa8DfgN74tss7sDTLViLgHex3Uw6yH27pGdAOePmwdj256dBlkDYWJrrKzympUtkT9PT3TK8+6m8X0vYvTmrdQP7cPnC+l2uPWDlxjsHfRMLfaidwhV6QJ/pI2eL/TR33RV33XT/3Sb53B2sVrFfTg3jm1M0X6dxI9xNv+Z7VKC5zPSdT/iEXqbnhvYnyjrIOWrYxO603CPsKaOL6ETsMPUZNyGnlyRJ63hnWB1eU7Bn02m8YWa8n7PGIGbAIqdKfB05im85bS4Usw2W6qa8O71YLnop+W9dRu0rJ/2czbKVfAXOYdUVnd+/MI7xUsxjS3VD0qRbVx3MefonaezVRVUdX02bXJmvgtGJJpkzqmSmrcXLsBE5+q6yioZzdyndMw9Z3spM47LvaoAM1RdpMT75lN8gBtNhXjv2nbY10AAAB4nGNgZMpnnMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVFgEqgRRAAAy9AKRgAAeJy102dSWzEUhuHXhW56TaN3Y2wwvRkb/rAM0hlSGNKZrDI70QZCvnPPyQLITDTz+Ls6o6srjSygDSjImhQhXySHtd+q5rJ6ge6sXuSX+iU6yeu5whU33KXa/b2qFS655jblst7fltPoEk9ZZEe9I811oKdjqrT0xh4b7LPLCXU2OWWdbWo0OGeLQ5qc6f28vl7UGtvp0He7tJIezdhLH/0MMMgQw4wwyhjjTPCYJ/raM42ZZIppZpjVuDnmWdAalvTcwzIr+l1Vr6wFtvOwdvTA8dbWDnaOq63Knna7e1Lf1Ea3a43zrcPm2T9M9h9ayX4KP6N3gZ2ms91eBvt/PA8H8iLYyb4Mx/IqVOV1aMmbYPO+DXtyFTbkOuzLu7Ar78OJfAh1+Rg25Sacym1Yl09hWz6HmnwJDfkazuVb2JLv4VB+hKbcBR1gyjm7KynvsCw4u1up6Ox+pTZn9y61Oyw7HJadDssuh2W3s/uYehyWJWcnmXodln0Oy36H5YDDctBhOeSwHHZYjjgsRx2WYw7LcYflhMPykdPdJAXdUlLQfSUF3VxSyPY16bCcclhOOyxnHJazDss5l+133mG1BYfVFh1WW3JYbdlhtRWXzbPqsrWVHTZ2zWFjKy4bs+6w96oum7PmKP8BU32drwAAAHic7RhpcBvVeb+3lmRZsm5pJdk6V4ety9YdS/Zu7MTGdu7DCRlC0jQHDTFH0tAwIYJCaCAhDDSZcEwzFDoDGZgpw7TTDNMmpUMZMFNi0hQ6JTD9AbQNaRtCyXQGFy393molxybl+l1pd9/33vve9773ve96j2EZ/LHPss8yHJNm1jMMeAlnYQ1E0xROkSixCqQYUgXVRlDbbZwXuKawAEULm4JohA+qVXyetzs45a/WyH97Np+1B6K5YqGIuIViIRKl/3yANXcMxqCpCWKDHdJ70nvTNfBIfwvPAWCbSI4HL3j5HNHpEF65de5/4CFxCqw6v9fg0JlanEZ/xMBNidJ+aNLYDf0Gu1rt9XVbPAC72KevRBo8cm2gEF77+JIfXF8nrUzDslMia7ToHQ691dI+4Gh1egycSazouuwhm75bbzWa250hm5+fR0UFsrweYR9hfAxj5TTRIqcJmOUiag7IRTFglgvOPDGcOHw4MQytM0vpY6X+5pXbG/2tynzkZdbGNGNFmYeHN/clz5xJ7hPI0X2JM2cS+6Q5lC2Zt23sNsbGdDJ5xA/S7bDRrcnQfcjRfdBkaN1Ge+R9KdAeK9JFykg/WoRLW1aPZbLZzNjq1+rAlrGRoVg8HhsaeYYCEENo7MnkU08ln5S/7LYZ6DIgzESXIenj+gj8Mg2enawTIQ2jQ5lmzTx9i1k7f7pSOb9z5we33EK2SteR4erzU1PTYz5gzzFWJsogmU4IpiBvzgmQDWS8YDfbDMAGggYKeWmbQHtToAGUH7C56vfTK7q7V6RJreyqVjwZDz5kr1x2SOteyz4KN01jpOUR7E88aU91D37wIXfj5yPEzDwKN8/mKf7VeWIDaBdfxlF/9SXS++XsSKlhWV1m8MJAfXo+0GBJdSVOcpcRp5PdNYsL9tzlvbQcms2BIodb2U2MCjXWyTBa0HBaYIs+qPkGmyNTyFNFJH+X1pc2SlUQJiZeeU6ncxkd6cG0w+iCF+GJMnZIv4W+iQmhtdXbFnEF0+mgK9zupeSb5DmSrEHRGSPDhHlz1qq8QN/jovgrQTghitVTgvA2yVQnp9+GHZPDrAr5RB6p3pND0sXE++8n4FKtVNayCO3JyvBMN52lLsByQ6gsekEEHNhSwK4Izi7vuT2A7eSnl+Ij8dhIghbxkcinkUJB/khNc2MjcTgiXRfOV7APsjJCXDqFH5IpRKSXKCr0RgqSnljiw3ExH57m+2XyMrUVmGG1l5kj8V9uZjN9iOKbssSq+BBYWPMhMDFbLrh1Gi2QQygM6SKYyJ+odExgQhSVLJtjbAkl08MsZMaYdYhfKGYxfNSiAOXMANGa7y/KXgbZ5AxgBDlY0KpaFmiuCAKIkCI4ppClgrVpwqgpqJwZEVBbUsAHNcCv32pZ+/SdoVazpc3tj/QlRhY8s2zl/GVpk1Wr05lMCbE3IXQv5CCybMmGzWsdtvbSSO+mcgLu6V7AgXfnkR8v4Esj5c2luDTpjl8V74om3LHhWFeUfJRm2cX3Xt0e9MbaAy4kHLbY7N3lVW0pm9PutffF+xIP+67OkzVCn83uVbe0x8ubyiMl6ff+NXkyfGMfGwxiS+9I6WxHF1J0J6JdcSymdfUYyzNtTIopo6TkCKuISH25eDBWcgZSl05NIhqUBioZSgmViqOSQLv1AIqGWi1UG/JYcMP1N+1YszSjyEL8zTgsvP9GnyKLZXfyVADDpQ2l0oadG3p6NvwxNrxyOCZ/WL6x+MUh3mCcW1qtLHxsU5NI+sYHawv3uG9ZQlfr60ESNTp/gBglEiO1ouF7kmwS8wn0gqCs0wOaYkFZbKQPAiqbkjPYi/maahTybBI6nQNFZ/MJAAIaZ2HA1Um2V081yxCqSK2XnIt2e8rdbq3+uwfHdpR0za50n7c7NCiate50n6c7tLdrRUe3p5R2a80KP2RK1mdtXaNVZt5MPlG0WvqW0FBsh6SHS4y+tgZyoeFfrLiaNoz4vOzbuximyOez3GVv+EvqU7IvmvZIV65MVWo/USkFpUR2mmfkaXm0uT6mnxlkRr5uxmZFblQYc8Kzym+Ymx2tVGCX9Ar0SPsbkB6hS9IoHP9m6Vj1n4IgiMrbiGfTe1jz1tTLk7jisf8sCHWvXf037mBdD3ewbSg5M913dMh061muGMXVFqMkKsJ+aZd4QDoLkcnJdAXelbyVNHlQOCEcgAhEpLOTGdyBTJ3WdowDMWa1rNMoVg0KGN0blWpBhHwkmkY9NwCqtBdzXhHVFVXdGpSxsJF6u5TSQUfbsAOb07Ldy1R44sRYGWhraWkf96zoCOU0aofLomctYVO70WDi43t6Yr7xpNPDxTbFFnm2dXHtXNzbDJqwy66z0CHxInA2C+hYC29ot7Xo5qUinWRQq1e1Le+MeLZ5rK2tfRF+yG1h+bAlZI9u7E6H4m2c0b8tdU855QOtH6neXe72e7U6lW9TkkOqVoNxScqTt8ljAtbQtcn0Eqvp/zK5kkxqNnofe9/n/AZDrYzGaRW+ssXhW1TqGoTRaoWbJxIT8GJiIgGuqanq5NTUAoTJOmxF77FuyocAPokMWsU6LPGZeHpq2j6qpMqoGTwyWH3UQDThLsDsoPgP9q2hHct2wO+UcuIsS8vHaoWS4yTJ6/X8G9A66n82WX0APbDygktEexDrex/EmCbPp0ykTAuvN8kT/bA237/easJiO7zwFju0ffkOZewzmLvV7LKejaA51w43UDqYevts6mA//KIfobe7DsLSvfFTp+J74WR1Ek7WYJyZ0rmL3cU4mAQzh5kr5yAMUFXjHLLaoa5R7SoKhKNVjVrRQwxEsm4hGm2NRrpACw45BnWBwwcgjyoUOTlyccUITF27atkNLfpYZNHI81dfO69vLiFh/4339S8dnn+NVhuOLF98cvFYjG9uXjM0uvqCX61e0jcwmktHYbf0YXa8M2Y0W08O9HRI+0I6p7tQWq4Vchm7w/KZj/0eyaWPrdt8zdI5+bDdIfQ8tnL1aP/GgkgSsfuXji1akoqrYslVI2PLHownX+0bGaoEQxqV2wG3SQ+b2sKRXKn8GvE6pH3iof55nUmVwHZ29Arlz1qUfR1nb0Pt62B6UTLy4U8+ENr5zyf/vCbjsKmDkVwBAsEINhXKYA/ksxkHIqrJdr3B5Vvlcxn0lWBPEB+4VCunzC5X0OUCnaR3h0JuEXYJ7nCY9VhsToPFYnDaLIgkjSqDjuPH7PQ78ak+HnbBcXeoUgm5pVFXuOGz9yDPQYxuDNSzxgLuAS1EoNuloXkD9TRoTzS98IEmgquC2v4VOUdWTi1h2SEgTSqtp9RV3Nhs1LssnA289rmD38HsgrXZk9xDGDj+YtXqm01HCx0ZM7ibOQLN5Ehzi85osJjegNsPYS5l1HfotLoNbq+zzWoxSO+2j+k3q1WufLyb0yEF8oDJZDU4jhpYtk36q9oWdeYsD2Gk0zRb3qDLabksbvtxJ/qZIWYBs5K5htnAbPkfsTtgdsgXJyoavn2Y5tUsw46JoIavXTk4ZMGEbVw2H1VrsvliDFAiWUw87Fmq3WE1r7FnixHenv2iwA67q698eAGjrrbaDBiD/fDLlsTYyoQ2NtSxU5sYG0u0zA1l3F6ovgp7bgOoiLkFmAnsFuHkboqP4uiJ3fHCnKvu+MJQ/2n1VbUW0S+cMptwMrgNjDJx7c0dV8WJNrES5wGVxuqIeYfm3P7r0fwdnxTC68U9e4I0IQDYU4HbG/pxDs+19H5Dud0wUXXwU3GYZt1uBGmdXkIV4NK9O7fPmz9/3vadYKpD9+7asrHU21vauOUCAuUyAuw52iFdnIkszMChQG/9vF/nRfha3My6e5FxviqL8NwVblW+Mt/S6NjMkZTY7FyJ5lfo/DEwcZg0oWePstulswdEaRfsFw+kK5IX3q2kJycx4zp7gGZLB2iaNDmp0BnHnKAVvTID5gDm2TYHOhk8Gavqnp51Vp9fkQ6S4WBa+vl46fTp0vhKJPUOhKR36CkfQu3j5dOny+NwuHHfpiKH5XM6KXJFtkm6KKd6ZAtN3xFgZuMBPRNjvpqopfV31coGzov1Mz+HONKhn+HRd4AcQSB5Dww0aCWJje6yFWVwQg6AVqFx93QDO477Hsf8m7EGMdHG0wxGHXpYRS+LscWK+Y2XoMOKaqbzoSjQzIeTTZteltZgGqT4Y4SECPkRzDlPVDIkTZwnphTncSz/9saQkBT4rTFnQNNsdwtJeKJzsQebzElX1yqL2exD2OdXO9o2zmG34WAVOSpNfIAEQU2OQvE8kW7FVAbxfTIhfZsp1R4abUNCo36ZjoNVZRIda5CO6Fu1tiNdxhX+FyXYf3Z4nGNgZGBgAOJNb47Mjue3+crAzfwCKBDF+XhfA4JmYGB+CRJn4GBgAvEAeqIMgAB4nGNgZGBgfsHAACH//2d+ycDIgApcAXBnBQgAeJxjYGBgYH4xdDA9AADYnCd6AAB4nGNgAIIZDBcYnjE6MEYxLmF8xaTBFMVUw9THdIPpEzMHswzzBhYNlgKWLpYrrEGsOayT2GTYlrE9Ymdgl2K3YI9hf8PhxrGBM4xzDhcTlxpXAFcKVxlXF9cMbh7SIQDoHxaseJxjYGRgYHBlSGfgYQABJiDmAkIGhv9gPgMAGrQBzwB4nHWPP07DMBjFX2haRIsQEhJiwxMLUvpnYOjYodk7dGBzGydtlcSR41bqxjE4Acdg5AicgkPwEr6hQqotOT///N4nBcAtvhCgWQGu27NZF7jk7Y87pDvhkPwo3MUAz8I9+hfhPu1MeMBmwQlBeEXzgDfhC9zgXbhD/yEckj+Fu7jHt3CP/ke4j2UQCg/wFLzqLHbbZKbzjS4WJtvn2p2qU14aV29tqcbR6FTHpjROe5Oo1VHVh2zifapSZws1t6U3eW5V5ezOrH208b6aDoep+GhtC2hkiOGwRcI/18ix4VlgAcOXPe+ar+dS5/ySbYea3qKEwhgRRmfTMdNl29Dw/CZsrHDkWePAzoTWI+U9ZcayoTBvJzfpnNvSVO3bjmZNH3F206owxZA7/ZePmOKkX1qXaMkAAAB4nG2R6W7bMBCE/cWSrThp47ptet/3obbpfadX+h40RclEJFIgKR95+hJ1ESBA9w9nBsvZWbK30VvXqPf/OmCDPgkpA4ZkbDJii21OcZodxpxhwlnOcZ5dLnCRS1zmCle5xnVucJNb3OYOd7nHfR7wkEc85glPyXnGc16wx0te8Zo3vOUd7/nARz7xmS98ZZ9vfOcHP/nFAb97W6KqnKpE0NYMhHN24fvCy4EURqo6lTPhwljOlDyc2mX+F6hi91jQplBBuUYbEdTkWO7Mv85taWvr8lZH4oaRdI3xI2lNcEIGVSTStqtUOut9UigvM7VsRfQsNtVK5b4WftaPaFDqOo5JS+18SCqn27RytmuT2BCSWpVhUGsT52XrI98b1lYU2lRZI5a60UcqaZTpshh0zYw1asvYkIu6tgtVpG10Uv1Wm7TVcxvGLl63+bQLwZrcluXOScGkTlezkHgxVyPfRJe8sAuTrWFMFuLKk+CUOvlGWWfWERFUOBQBjcWwwCOpmXHIlGX8zYKGjpYVJUfMe70/6zKeWwA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n\n.ag-icon {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n\n.ag-icon-aggregation:before {\n content: \"\\f101\"; }\n\n.ag-icon-arrows:before {\n content: \"\\f102\"; }\n\n.ag-icon-asc:before {\n content: \"\\f103\"; }\n\n.ag-icon-cancel:before {\n content: \"\\f104\"; }\n\n.ag-icon-chart:before {\n content: \"\\f105\"; }\n\n.ag-icon-color-picker:before {\n content: \"\\f109\"; }\n\n.ag-icon-columns:before {\n content: \"\\f10a\"; }\n\n.ag-icon-contracted:before {\n content: \"\\f10b\"; }\n\n.ag-icon-copy:before {\n content: \"\\f10c\"; }\n\n.ag-icon-cross:before {\n content: \"\\f10d\"; }\n\n.ag-icon-desc:before {\n content: \"\\f10e\"; }\n\n.ag-icon-expanded:before {\n content: \"\\f10f\"; }\n\n.ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n\n.ag-icon-eye:before {\n content: \"\\f111\"; }\n\n.ag-icon-filter:before {\n content: \"\\f112\"; }\n\n.ag-icon-first:before {\n content: \"\\f113\"; }\n\n.ag-icon-grip:before {\n content: \"\\f114\"; }\n\n.ag-icon-group:before {\n content: \"\\f115\"; }\n\n.ag-icon-last:before {\n content: \"\\f116\"; }\n\n.ag-icon-left:before {\n content: \"\\f117\"; }\n\n.ag-icon-linked:before {\n content: \"\\f118\"; }\n\n.ag-icon-loading:before {\n content: \"\\f119\"; }\n\n.ag-icon-maximize:before {\n content: \"\\f11a\"; }\n\n.ag-icon-menu:before {\n content: \"\\f11b\"; }\n\n.ag-icon-minimize:before {\n content: \"\\f11c\"; }\n\n.ag-icon-next:before {\n content: \"\\f11d\"; }\n\n.ag-icon-none:before {\n content: \"\\f11e\"; }\n\n.ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n\n.ag-icon-paste:before {\n content: \"\\f120\"; }\n\n.ag-icon-pin:before {\n content: \"\\f121\"; }\n\n.ag-icon-pivot:before {\n content: \"\\f122\"; }\n\n.ag-icon-previous:before {\n content: \"\\f123\"; }\n\n.ag-icon-right:before {\n content: \"\\f126\"; }\n\n.ag-icon-save:before {\n content: \"\\f127\"; }\n\n.ag-icon-small-down:before {\n content: \"\\f128\"; }\n\n.ag-icon-small-left:before {\n content: \"\\f129\"; }\n\n.ag-icon-small-right:before {\n content: \"\\f12a\"; }\n\n.ag-icon-small-up:before {\n content: \"\\f12b\"; }\n\n.ag-icon-tick:before {\n content: \"\\f12c\"; }\n\n.ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n\n.ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n\n.ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n\n.ag-icon-unlinked:before {\n content: \"\\f130\"; }\n\n.ag-icon-row-drag:before {\n content: \"\\f114\"; }\n\n.ag-right-arrow:before {\n content: \"\\f117\"; }\n\n.ag-right-arrow:before {\n content: \"\\f126\"; }\n\n", ""]); +exports.push([module.i, "@font-face {\n font-family: \"agGridBalham\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABgoAAsAAAAALEgAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAmMAAAR2YfRkQU9TLzIAAANsAAAAQQAAAFZWUFLwY21hcAAAA7AAAAIMAAAFnGSNxkJnbHlmAAAFvAAADpIAABo4y6JNTGhlYWQAABRQAAAANAAAADZ2zcSBaGhlYQAAFIQAAAAaAAAAJAfQBDFobXR4AAAUoAAAABoAAAEgs7L//WxvY2EAABS8AAAAawAAAJJHu0GKbWF4cAAAFSgAAAAfAAAAIAFeAKpuYW1lAAAVSAAAATUAAAJG0OP3eXBvc3QAABaAAAABqAAAAm9qOX49eJx9lM1SE1EQhc8wAYFEoDQqRkRQ/IvKMD8Zk/CTkJBoWS5cWJYLN1hWWVZRrngOH8AnYOkT+AAufAIfwIVL15ZfdwaDLMitTO50n+4+fW7fKJA0qw3taGJv+Pyl5g72Dz+qppJGH/Of3AcHH97va/r4DV/Jf6cVlCqa00291qG+BXPBYXA0UQ1r4avwXfg5/BL+UghqReugy1TcUKyEZ6RUmRrKNaEpbDH7x2qCDnm23HpBVzXpnp76WqRmTEzfM9b1THe0QJ6u5+loG1TKspwdnkPWXc2fgch1j/wZbDaxllBkmf2WqprRHiw7MGkT38R/kZo71I6I6uLrwm4SS4t9W5fgZBElV/Wp3ugRfuvUsmRFTMo31q6/R/5WZh2jWuRpUMty12FwbG9QNSHiIdkzUFuFonVUL+NNwUTEtl1Biy6DTOCWapWd9ZnAtaI1MC/01qvuFjEd13SkQB32Y3vX8+V0ftLaJtcQ7AM4jK12PvepFWngXS2COdAnHemrvuuHfuq3/uicLlMn8R62yb5zpjbTKHga3cPb+me1XqeYgdOo/xEzdN5wdWJ8/UJDq1amM1MnZR9hTR0/C0/D92CTcx4lakRe1056krXJewz6fDGdTVbFle4zBfM+wQOfhRoTlui6ZxzNYY7WS2S03YhfzXVrku+an5upazdswd/sLth51zj/ZX4jOsxcpyd4V7BYprHlhkflsLcc6/hzWI+rGaslWGU+0TZjA78dPSrdop8Rk0S3/WYMfL7WYJAVN7XKGRr7dnFiVxwXe1TAP0FU3PDUtbOZ7sLN5mP4F/iHapMAeJxjYGSqZ5zAwMrAwFTFtIeBgaEHQjM+YDBkZAKKMrAyM2AFAWmuKQwHGHQ/GjG/AHKjmN8wsABpRpAcANz2CuAAAAB4nLXUZ1IbQRCG4VeBKIEDOeNEVkAgssjhh0+BM4UDhTPn8Nl8jz4B/ma7fQBc5al61Duzo9FMrb4F2oCCLEkR8p3kdEUur9FcNl6gOxsv8lv9Mp3kdV3hgiturHF7q9EK51xybbms97flNLvMODOsqbdHjRab7NPglDrbrLLDFge62+SIZTZY4ZAT1tnlmDN9P+2iqD2206Hf7dJOSlqxh17u84A++hlgkCGGGWGUMf3WBJNMMa15j3jME57yTPNmmGWOeRZ0XWJRpyppzwtUtcl27tb27jg/tVprc79xWt/WibcO1po67MbK4cn67vHZPyz2H1o5fRR+Re856Ym6dNrzUJMXoSUvw6a8CvvyOjTkTTiVt6Eu78K2XIRVuQw78j5syYdwIB9D+ld9Ck25CkdyHZblc9iQL2FFvoZD+RZO5HtYlx9hV36GY7kJeoCWcykvlnekWnApX1Z0KWPW5lL2rN2Raocj1U5Hql2OVLtdyqSVHKmWXXqS1uNItdeR6j2n7GBBKcKCsoE9dEoW1ueUMazfKW3YgFPusEGnBGJDTlnEhp1SiY045RMbdUoqNuaUWWzcKb3YhFOOsUmnRGNTLjvvtFPKsaC8Y0HJx4LeAVjQ2wAL2XlnHKnOOlKdc6Q670h1wZHqosvWWXLZ3iqOdL/q0vvVai6bU3cpY7bssjUbjuofQy2jW3ic7VlrkBzVde5ze2d6et7d04+Z2Z33a3deu/OWZnd79EDL7gr0YldCBqQoEnKwVhgpwsJCC7ZwBBI4JlIBdkXxq8qmoCouJ65QlC3ZKeKCpYIWhUAShCs/sBML4mAcq1LljaaVc3t6VlqhAPa/VLLT3ff07XvPPfecc8/57l2GZfCP/Q77HUZlSsx2hoEwUUXWTbieVJFkiE8jjaQlbvWAVZbUMKg9KQ0aIluETDoRt1oStYSsqObPyhk/uVKryLFMtVFvYNt6o57O0F8txgr9a7LQ0wPZNf36T/WfXnmDkP7z1DIAtodUExCGcKJKHA6kp+5a8V/wZGsBfI5o2K04vHa/J5p2qwst/Rj0cLJ7pVu2WsORITEEcJB95nqsIWS8raqnbv/6+j/6VJe1OQzLLrRYj+hUFKdP7FuluPwht+ptzToG5aTkHHL6PEKfPylFE6upqsDQ15fZLzMRhvGpXKahcjHBKDJCzCgaMcEoVGFuPH/yZH4cXEtL/dfm+xvXr1/87jLHIy+yEmPDF3OcBLxxtPDaa4WjGjl1NP/aa/mj+jIqliHbHnYPIzEDTA3bx6k5JGqaMrVDldqBK9N3iX4x7FKnX3zIFzkj/0wDLu7eMl2uVMrTW17pErunJ8ayuVx2bOJZSkAWqelvFb797cK3jCe7Z0lzg9CWNjco/dfdHvhkFmX2s36kOMaBOq0ICXo3KnLi3OzsuwcOvHPvveQu/ZNkvP38woLR/PJlfFxg32F8TIZBNgMQL0JNqGpQiZXDIAuSG9hY3E2pMK3T6NcicID6A7ba/lzplqGhW0qkUw62Z0PlEF7kIaPs17e9UvkKfPpKi5LRg/1mqBRqH8YHXuQL+PgVtix/Be65Vqbcx5eJjeG6+CiJVrZ/TEY+Why9OG64y2X8Q1kuGLIw0B0+EVsUyXI9SapXMaeDHblGCvbC1V9pOXatBKY972N3MRb0WD/D8MCpPLCNCHRig6SU6zXqiOTf9O3NnXobtLm5l77rcAQ8SmlNSfEE4AX4xjB+0P8GRufmNJcr3JsOxEuleCDVF6bse4wxCqzb9BkPw6QSQsVn3kDv51qtH2ja6VarfVbT3iLl9vyVe3Edk5OsBeVEGanfkxP6+/mf/SwPFzulOZebcT35mAQzREfpKnB4UaksRkEkFKyp46c0jm7YXI5hPfnzi7mJXHYiT4vcRPpSul43HnrPiuxEDp7QP5mqzeI3qBgNcvpZfJByPa3/mDaFkXRddxIxN55r1VJX5H6RvEjXCixZtVctRxK9eplZGebyJfZu9heMF2cSYsaZzzF/hr3p8rd0pEcvqNfYRA2EmGpVcTK+lOQmON2eWlUjFTpZyRpPZ4pAp4tuU6axvayo1K3iWF2r1sthtkJti6mhSKgOymFidur0iYCihklDxYBT0qgCJdkDboI6HWSxu8Lu5XbfY9HXZRqNDKlnGmPf01fBMQKsxXue6Nt5MSx5Vclrt7j8MZ+a9Nldth6b5FH7nGpUsRKb2/4XYlwJCS4v77ZxNo9TUByiV+oVxIgi+gWb3cX1WDxh0eqwiKLDJdpHclnCEpvDZiE1wtk9TiupsGAXbeTnts8csZBlmUuvGsIcO3fpOHvfGwFeaD/+j85I2GcTe6MpOV5LS30ZkffYXbJULUdzit9v97g9gQHF40iJDrcjIDhV0S3YrJwvVkz5XLJf9todHtHn4h08y3EWzhf64x+c5h1WO+eyW/jXeY+Nd/PzHt7uFamp/992/3tttzR3m5igQnxm7oabOrkb5joxbYmdJz7Sxg2avKv1SlmJQItQkymy5AHEaGjXeHoQOOoE6Vr1w01T2LqW5yySR/B5R1bY3VaXzeOT10057bwoiT23bunhBaz5MKXOfXaP2+VQvD7/Jz7hES0Wr1MI7f2sRxbdPG998JDVZhU8IvN/ZI5L8gqmPo4HcgKTif4+eMk/0eziBS82sRi55Wm2iZllOXMTM81sw/b1RgXhdwdF08juhkwHOzcMlIZhXnWDBwywTV+tRkKqNkCDFhQJ9ql31juXMlZtpdwCY1Un4hwktt8l3v7M55MuQewNRtOj+Ym1z26cumFjyevjHQ6vN98ayWtDN6mQ3rh+x523K1Jfc2Jk13AeHh5aq0L4wBNfW5toTgzf2czp88HcjbnBTD6YHc8OZsivSiy77pFb++LhbF8sgIxToiSXmpt7i5JfDsujudH8U5Fba2SrNirJYau9Lze8a3iiqf9ddGuNjN89ysbjWDMy0TzfP4gcg/nMYA6LK7n+aTbB9DJFZhg1ZexQTBVZr1YP7jVUN+lqp6MRrtxxlSJgUFOpJhD3hIAGQUQ90F7Ux9q9n/r0/q0byqYuWn89Azd98e6IqYuNn09QBYw3dzSbOw7sWL58xz9kx6fGs8aDTSxOfl0y4fasaG4xJz69q6dFRmfWdCYeCt67ns42shxZdPj8PWQpkyzpFNR1TGxTwP0Yokgw5xkCrlE3J5sehZhFMvdccqPWcQ1cOgUY8K9q+G2nAQhw/vqqwADZ1z5rMyh0kc5XciEzFBoeCvLOP3xsen/TYQuURsNDyTUtgQ+WRkNDqSODU9iiWQrygikPWTD8me96tEVICOQ3plfrv6ctOraiO+Ei4+zMgby3iM98OJte3DElDGw8yDCNRK2iXnWnPuJ9wcByVxDd9V8WZjt/LbPUzBLFsS3Z59ZwzY0yK5k1Rgz6rXa8PpTGgpg9dU35O+5tT83OwkH9JViuH1uknEhd1Cfhud9tO9v+d03TWubNMB+wYQftUpRMcibi/WdN66Le9n+iBbt+uJ/tRc0J1O4IaKnpWbWRwdlieMy04Jh+sHVcPw/p+fnSLLyth2dL5HHttHYc0pDWz8+X0QLlLq99iKOzzBbDp1GtHCoYwxvVar0FtXSmhH7uBnTpMDSwRqOhzxc3WmEljXZF8wPtLeEHrC4Z697gkiB+3GvEeu32vpnQLf3JKmdVAqKTFVPePo/bm8gdXp6NzBT8ITW7K3tzaM+g2qfmwjbgUgHZIdIuuQaokggOVky4+yS7Y3UxnSVreKeld9NAOrQn5HO5RtOJsaDIJlJiUs7sHColc72qJ7qn+PBwMQJ8FLl+YXgoGuYdlsiugopcfW7P+mKoJhl9Yr7kHYXSep+364+Pso9+YI0w1KMoprfgbXgX3g3znUMaPVS7Zy4/By/k5/IQWFhozy8srEWabMNaXCnbFiJI4JUvowdswxKvuWcWrvhCm7QRWbpwtx2hzsClBgF3Eo1fsG+O7d+4H/7WLOfOs7T8aqcw90MF8mp3rw7oCd0fW2h/CaONeUOghbZvdW0fx/htjGcOZA4Lr/YYA/1JZ7z/eLMHi33wozfZsX2b9pt9n8V9XscHuwgKXbdzEALNx4pvnS8+thL+aiVSbw0+Bhseyp09m3sIzrTn4UyHphga+RxhDzIKRp8G02LWMlPIj7qaqhhul0kb3tXQiEpfOavphxh0qW9hK1qZQcTBg2KE20FATAJGp3pDNYK02kjDwh2bN+61O7Ppmyeev/WO1aMrCElF73505YbxG27j+VR607oz66azCZtt69jkU1Grdf3oqslqKQOH9F9WZgayCFHOrFrerx9NOvzBenMTr1XLsiJejrCfIdXS09vuvG3DslpKVlrLvjq1ZXLlznqL5LNf3DB98/pizpItbJ6Y3vh4rvDy6MTYbDzJWYIK3K8/5e1NpavN4VdIWNGPtk6sXD1QsGjsQP+INnzZvngGM8Pej97Xz4ygZoyDIuPwSE588KAgwZUVujmo1iGG4Euo1odBjtUoOBMkK9nndAcimyMBt3M2vjyOF1zslAtCIBAPBMChO4PJZLAFB7VgKsWGRMnvFkW3XxKxkT5pdnoOH4I/6ser/fVUAJ4LJmdnk0F9MpBajE+HDZmbKHEXIdXRCFhQY3E0QdIwg4uJ5tEIcGmcEnSs11CVioGhYOMJID0WPtQcbOx0N0NRCMsr1vwB5lBWkgvqkxge/8XHO23eU/X+sgBBm0rARp6w4VbALXpfhwdOIGLwOPsdvGNHcTQs62/3TTvvtFoCtdyQ6sDu5Eter8+tnHKzbK/+r1Yp46+KT2Iw52zi64z9qrwURe2vZMYM77yN2cHs/h9yU0xQjINVC01PEYQxndUgI9DhEp0jScVQRkpSK7WMlavUGllARVQwscoV6tEpa4KTK410Qq58WOKCQ+2XfvkeZhW+bQPMMVH4vj0/PZXns2P9B/j89HTeviJZDoah/TIcvh9gtlVdi5nuUAvOHKLtURfLsw/+aNmND35oKrvUftnKY/P3zgpeHAzuB4/BnL+n/8Yc4fNTOA7gdkvJhseWPfDDydqDv6mntrcOH47ThAdweBYeWPQJeu5Fzz/N008v9YIoVYf3mtPPuLG5oF/g4iMH9q2+4YbV+w6At0s9cnD3zubISHPn7veQGB5Ggr1AP+jvL22sLWlDiZHumurKov1W0lxzNmu0+bgiwnevc+r6seXWJ6eX9qTMrsUCFD9gwMdkpCIowGieYffp54+39INwrHW8NKuH4e3Z0vw8IorzxykaOE5hwPy8yYeeT7swEjO4z0Mcae77BEs3urP+9vO3lOJkPF7SvzfTPHeuOTOFrH4CSf0n9BQQkn0zw+fODc/AycXzeAs5aZzj0QMKtkd/34AyZDeFp0gw17YDemaGeCzfga1HOuVimxe6Z4IqttFP/CVu0VeRJ5AoPAyrFnkViESt7EMdnDaSnk9bjKV72Rm0ew7xJeOLI5BEtI6Zhm7GMLJiPvEhpgkTBDMZ7goGygBFO6qxtOk/Uzq0cW7zNCFJQv4Ulr1LLAalz71LvEU1pGz6/Z1JraAl7sr6Y5xNDmoF+MbAuhBWCYXA4GZRECJIR6JWpXfnMnYPdraQU/rcO8gQrOQUNN4l+n0IX7B9xGDk7PUW+5KTvchoMmrwUVhLOd+/Ffm0Iptv7y8N4wz/G4A9L1cAAHicY2BkYGAAYgWvvDnx/DZfGbiZXwAFojgf72uA0f/////D/IL5DVAlBwMTkGQAAHb/DvN4nGNgZGBgfsHAACL//wezGRlQgQcAdFMFCgAAeJxjYGBgYH6BDf//j8C41AwspgcAANyGMDUAAHicY2AAghkMFxieMTowRjEuYXzFpMEUxVTD1Md0g+kT8wWWdSxHWM1YV7DuYQtgO8EuwK7FXsL+iYOHw4hjD8cPTjFOA04/ziIuJq4YrgPcadxreIR4zHgSeEp42nhm8azglSEdAgCdlRu1AHicY2BkYGDwYJjHwMMAAkxAzAWEDAz/wXwGACBkAgkAeJx1jz9OwzAYxV9oWkSLEBISYsMTC1L6Z2Do2KHZO3RgcxsnbZXEkeNW6sYxOAHHYOQInIJD8BK+oUKqLTk///zeJwXALb4QoFkBrtuzWRe45O2PO6Q74ZD8KNzFAM/CPfoX4T7tTHjAZsEJQXhF84A34Qvc4F24Q/8hHJI/hbu4x7dwj/5HuI9lEAoP8BS86ix222Sm840uFibb59qdqlNeGldvbanG0ehUx6Y0TnuTqNVR1Yds4n2qUmcLNbelN3luVeXszqx9tPG+mg6HqfhobQtoZIjhsEXCP9fIseFZYAHDlz3vmq/nUuf8km2Hmt6ihMIYEUZn0zHTZdvQ8PwmbKxw5FnjwM6E1iPlPWXGsqEwbyc36Zzb0lTt245mTR9xdtOqMMWQO/2Xj5jipF9al2jJAAAAeJxtkQdv2zAQhf3Fku3YaeO6bbr3Hmrr7p3upj+DpmiZiEQKJOWRX18iLgIE6AE8vPdwvHu4a2201tFv/T/22KBNQkqHLj026TNgixOcZJshpxhxmjOcZYdznOcCF7nEZa5wlWtc5wY3ucVt7nCXe9znAQ95xGMynvCUZ4x5zgte8orXvOEt73jPBz7yic/s8oWvfOM7P/jJL36zx5/WQBSFU4UI2pqOcM4ufFt42ZHCSFWmciZcGMqZkvsTu8wOgcp3jgRtchWUq7QRQY2O5Mb8q9yStrQuq3UkrhtJUxnfl9YEJ2RQeSJtvUqls963pZ+n8WXjJFdepmoZDXQPczbuqWUt4qx8U61U5kvhZ+2IOlNdxvHpVDsfksLpOi2cbeokFoSkVNPQKbWJPrqlFbk2Ra8SS13pA5VUyjS96HvNjDVqYGzIRFnahcrTOjZQ7VqbtNZzG4YufrfZpAnBmsxOp9vHBZM6XcxC4sVc9X0Vu2S5XZjeGkZDIW5gFJxSx1fWa8zaIIIChyKgsRgWeCQlM/aZsIwnzqloqFkxZ8pBq/UXq/Gj5g==\") format(\"woff\");\n font-weight: normal;\n font-style: normal;\n}\n.ag-icon {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n\n.ag-icon-aggregation::before {\n content: \"\\f101\";\n}\n\n.ag-icon-arrows::before {\n content: \"\\f102\";\n}\n\n.ag-icon-asc::before {\n content: \"\\f103\";\n}\n\n.ag-icon-cancel::before {\n content: \"\\f104\";\n}\n\n.ag-icon-chart::before {\n content: \"\\f105\";\n}\n\n.ag-icon-color-picker::before {\n content: \"\\f109\";\n}\n\n.ag-icon-columns::before {\n content: \"\\f10a\";\n}\n\n.ag-icon-contracted::before {\n content: \"\\f10b\";\n}\n\n.ag-icon-copy::before {\n content: \"\\f10c\";\n}\n\n.ag-icon-cross::before {\n content: \"\\f10d\";\n}\n\n.ag-icon-csv::before {\n content: \"\\f10e\";\n}\n\n.ag-icon-desc::before {\n content: \"\\f10f\";\n}\n\n.ag-icon-excel::before {\n content: \"\\f110\";\n}\n\n.ag-icon-expanded::before {\n content: \"\\f111\";\n}\n\n.ag-icon-eye-slash::before {\n content: \"\\f112\";\n}\n\n.ag-icon-eye::before {\n content: \"\\f113\";\n}\n\n.ag-icon-filter::before {\n content: \"\\f114\";\n}\n\n.ag-icon-first::before {\n content: \"\\f115\";\n}\n\n.ag-icon-grip::before {\n content: \"\\f116\";\n}\n\n.ag-icon-group::before {\n content: \"\\f117\";\n}\n\n.ag-icon-last::before {\n content: \"\\f118\";\n}\n\n.ag-icon-left::before {\n content: \"\\f119\";\n}\n\n.ag-icon-linked::before {\n content: \"\\f11a\";\n}\n\n.ag-icon-loading::before {\n content: \"\\f11b\";\n}\n\n.ag-icon-maximize::before {\n content: \"\\f11c\";\n}\n\n.ag-icon-menu::before {\n content: \"\\f11d\";\n}\n\n.ag-icon-minimize::before {\n content: \"\\f11e\";\n}\n\n.ag-icon-next::before {\n content: \"\\f11f\";\n}\n\n.ag-icon-none::before {\n content: \"\\f120\";\n}\n\n.ag-icon-not-allowed::before {\n content: \"\\f121\";\n}\n\n.ag-icon-paste::before {\n content: \"\\f122\";\n}\n\n.ag-icon-pin::before {\n content: \"\\f123\";\n}\n\n.ag-icon-pivot::before {\n content: \"\\f124\";\n}\n\n.ag-icon-previous::before {\n content: \"\\f125\";\n}\n\n.ag-icon-right::before {\n content: \"\\f128\";\n}\n\n.ag-icon-save::before {\n content: \"\\f129\";\n}\n\n.ag-icon-small-down::before {\n content: \"\\f12a\";\n}\n\n.ag-icon-small-left::before {\n content: \"\\f12b\";\n}\n\n.ag-icon-small-right::before {\n content: \"\\f12c\";\n}\n\n.ag-icon-small-up::before {\n content: \"\\f12d\";\n}\n\n.ag-icon-tick::before {\n content: \"\\f12e\";\n}\n\n.ag-icon-tree-closed::before {\n content: \"\\f12f\";\n}\n\n.ag-icon-tree-indeterminate::before {\n content: \"\\f130\";\n}\n\n.ag-icon-tree-open::before {\n content: \"\\f131\";\n}\n\n.ag-icon-unlinked::before {\n content: \"\\f132\";\n}\n\n.ag-icon-row-drag::before {\n content: \"\\f116\";\n}\n\n.ag-left-arrow::before {\n content: \"\\f119\";\n}\n\n.ag-right-arrow::before {\n content: \"\\f128\";\n}\n", ""]); // Exports module.exports = exports; /***/ }), -/* 250 */ +/* 303 */ /***/ (function(module, exports, __webpack_require__) { -var api = __webpack_require__(225); - var content = __webpack_require__(251); +var api = __webpack_require__(278); + var content = __webpack_require__(304); content = content.__esModule ? content.default : content; @@ -48909,24 +57854,24 @@ var update = api(content, options); module.exports = content.locals || {}; /***/ }), -/* 251 */ +/* 304 */ /***/ (function(module, exports, __webpack_require__) { // Imports -var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227); +var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(280); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, "@font-face {\n font-family: \"agGridClassic\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABOsAAsAAAAAJiwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlIAAAReYchjok9TLzIAAANcAAAAQQAAAFZWVlJ+Y21hcAAAA6AAAAHtAAAFgHClDfdnbHlmAAAFkAAACi0AABQQq+8lqmhlYWQAAA/AAAAANAAAADZ2z8SBaGhlYQAAD/QAAAAeAAAAJAfTBChobXR4AAAQFAAAABoAAAEou4L/4mxvY2EAABAwAAAAbwAAAJb7HvWgbWF4cAAAEKAAAAAfAAAAIAFgAHhuYW1lAAAQwAAAATMAAAJS8kTiWnBvc3QAABH0AAABtgAAApcplp2DeJx9k0lyE0EQRX+rZSMPyGDMZMRkRpsh3O5BjSTLltzyQHjBggULNmYBAeFg5ROw5gAEB+AUnIBgyYoDcACCA/Ay1UbGC6tC1VWZP3/+yspSIGlSy+qqUmzuPld9f+/gveZV1fBn/qPrYP/tmz3VDnf4qv6tKQj/qK4FvdCBvgUKXgefK+NhJeyGu+GH8FP4QyGoG3oMekorjFgJc6RUmZrKVdE4tpj1E7VAh8xtt87qgsbcU2ig8+SMiRk445Ke6o7OwNN3np7WQKUM4+wxbzHuauYERK578GeoWcVqrA10ntWENtHYQ0eH6BbeGXzrZI6I6eProy10VNXruK2XRM762SwyK3Ep/1gbvo9894AqHKLa8DfhN75Fsh7am2RKiHgEewaqW9Zwif8U3hRMRGzHa2bR10AmKEx1nZWdLOFk07oN+zO98qwbZUzPqzg88yLqR/a+8+XkOWrtwLUF9iEaRla7kfvkirSDf5KbKvROH/VFX/VdP/VLv3UK6ypeO8Ea3OsnVqZG/Y6jC7ztf1Y76Th3fhz1P2KCcze9NjG+QVlByzaFTqtNyjrCmjp+Ep2GL1CTU68qOSLPm2AdY6yyj0GfLruxxZj2Og/oAeuAeWqxwmxMw37L2V+GyVZDXRe9Wi14LvltWU3tJdV9Zz1vtzxPna/wjThZ5vXZxnsVizGNLA2PylFtHMv4c9SOspmqBqoSeqDmnbXjr6Ag003OMVSS6Ja/gB3vqgUUZOWLnNM5V98pb2rOcbFHBWiOypeces2sk/tos67Y+gsvGGrHAAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMnxi4gDQjSA4A1QYKdAAAAHictdQHTltBFIXh3wXTTEnvvRc6hGp6XQbpiBREOsoqs5O7gZBzPScLIFJG+nw9o+c3b/R8LtAB1OSp1KFap0KO31qttNdr9LTX6/zSvEkXVX0fYo8DjmL0+FirQ+yyz2FU2rO/o6Krm1zlPs80W2GMJeZZZZItxmlpdZEF1phhmg0mmGOKdXaYZZlNtvX7qnav6xkbdGrfbj1Jr+7YRz8DDHKaM5zlHOe5wEUucZkr2u0a17nBTW5xmzvc5Z72f8BDHvGYJzrPkD6HNRvRAzY42Vg54fU5xpbmVye3xls67cLazLQOOje1vjO7vLn9Dzf7D6OZH7Wfnu2Qb7PI0+7amDy3JXlh8/LSVuWVTcpr25I3Ni5vrSV7lv+QfVuUd7Yg721NPtiMfLRpObANObQJ+WRz8tmm5Iuty1fLs3+zWfluy/LDNuXI9AKjUmRWolqQtVZktqJeZL6io8jcRaMga2dB1q6CrN0FWXuKzGP0FmRtFvkmo68ga39B1oGCrIMFWU8VyhJhShVhyhdhShphyhxhSh9hyiFhSiRhyiZhSilhyithSi5hyjBhSjNhyjVhSjhhyjphSj1hyj9h6gSEqScQpu5AmPoEYeoRhKl3EKb+QVj2zbDMTFj7muGCrCNF+56jBSN/AHzNoH4AAAB4nO1Ye2xT1xm/37nEN87D8bUdXwezwLWJDZQCtmNfO4FATIgdQhLWGwhrt0DSGJHHpgaawFRatBIVVrXbHxXTWCiPabMHo9MgSH1IGxJMa6b+sbBJFZVK2/HHVNjI6JZ2k8W97DvHjzyggPrntBufe17fPec73/md3/edcMDhw4f4fs7IcSBLglwuW3mZD+mj+/ZBQtv//vtkhPxuYiIFe2EvijD5T/lPuUVYCQpeRRK8oswyRRZZJokyywQZLrXFxscbNwPf1oh5m65txjzWpuu0PdYGhF9k/LIuWm/czOXm3Mq/whViRfAaMYlu+NkbCeiG7sTZU2TPGz3QrR/vOavdzMmTSTLJFTN51AW1QX3IZOOFsdiFC7GxC41jUJ8rjTVe4Ao47q6O67rBWTk35+Ue41ZyXIHsWgFBsboOArK/EspFmwl42WXAgh1bQtjlgYDorgqUu3nM+T7N5qpx4Y/83VUjyzWyZjY7HGZyW5Qk7ReqCi2qmmpvJ66Ii3yGL/xpZfjifySJmig6HCL5hyjpY/q1ZBJO6jtw2Vm9bjK9luJ6coq4p5UrmKOTALheK9/HdHDldbo1Q5teffLf1aev8zdyKuRU2jJTk3f0ot/XH4YTc/XwPpoevByUH6jFX/Tz0PoQHfTSJN3OWfM/2uwPmvkhk9L14qL38T2IjELOwXEIOskIvLIQDAL+ldvsOEu11+Mlf9O31zyta1A3Pv7ur4uLK8rsvg0+e1kFXIJTtdihX4Y14+N1paWVTk+Fy+dzVVQtqKTDG9gcR/gjOJuAWC3DtUkcV1WOZsPEz8nhlH6ej+rnk7OydAofaEniA620zGV1v5HF8spHsxYghsvdQXcwEAzw/RmLadaMBcmkZmaWoZbT30uxJ2NBS9aCk1kLWlFCJLdw2y5QlVJMFfaK8lG2ShH1CYhy0I0sIYsyH5TFQJCMJvWSJEyp+hi0pPQxlYyyehrrp7AxzeV54Hn+eXqujYDbIRgB2UCBKbAM65PspU8OgwVfpG9WFSxYncElhxmXiAFkLDrAz0+eTejH9eMJ+C4xaVNYOQFdCe6r4p7u2oPQ9wO95GGoH0smp233Lq9wFZyPW43zK1IoYJfskgkBicwGobUQdLsQk17rCuI1CJUg2RXJgMikfyEUUFgJ5UGu9qyNHnpucNvSb9cF6xeZ9D+taPYW1T0WfvzAX0PfXF3UUO17pVX9uv9bT3ZtrYus9D85BFc3N5os9kq5uHY5b1qyyjLvieaDa3Z5GgJLiuFAEQG1wGBy6tcM4W1Bf7zhabujeN2CImN1VZ1/40ub9KO+TqskLZwfaHf+b65FQjwv4UK4FroORg1ZXUNYpm12Jac0QcB4qzxrwE3lJBRR4A5dQdvw/hd/uJ8q+Y0933umoXpdZ/euZ3Zs3ciULWnctbc3VgQboagtFAtVLQl5VvPlvNr84nBLW0nJRs8af/NI85Yz/vg2JWwwKP4eq2RfVBF+qjrUWcOXLlgGhcXzm22FAuEyPMo4px95DT2+VQbRG/SVB4Iq45Qk34/eZ3sq3d6elSV30I/yLDoQ3SI6Fq8gwVqVmC9fDqfTZFIvgSm94dIlrFDxkuxZvziL05zcwmmvqiDT5BI8pCwjH6WSyTT7ISN8WQlOJpMTSUaCJ+/NUKWC7Lovcl/jZK4KPenjlIcYsSLvZSk2n0R3UAZ3Ofr0TKrCBKeQYdFGyLY0p0zF8h3t0JqdjqnD96tovqSaxiytklhas6hwqh15TFXn2rTKLQaARicCuaOq2m1m1PQMi2b46iS/lfGVhIRHQzTYebpHPw7dPWdIDZw8nYmDzlCyJXe/uPsF/y/+n1w1159BpaGMuiwvYs+j4AEL+RkqsdUElQQb6sCDnUGfhxaxC6segXVTOSlgpx95q70+KsbkK0muuxL82KmEvB7yQsRmWxIeibQ2b2rZbcMnEi+qsAARyTxDhdNmCTY1OQ8usFidRgepWFpoL7JbwBpp2dTcGhkJL0FxSzkU2QuXOUhpsdFptToPOpuaghabs8IwjzcTsFQUxSN0XJyptfkozkQru9kAcaPZFPQXWgzznfGmkM3qHHHG406jaHY5lhYSg5nOxFQaCR9FcUuZQAqXOlxmo1BEBUecVluoKe6cb7AU+oMmszHOVjHzvBxBFC9kjCUgLJGs0FciYyE8cfPQYwaUoNctlJPY0eGjV6/iK5kv/Pjl7u6Xu8lvZjXSgvZWN+3i5s2KPZchNz5a5CmwoBYU5E5JeXDseevjmG80fAyuxT7xvR5+/SEBqFYX+2jVMRR//pOYD/O8H5qOVViUAtnEH7nzWz6aSelMNEJjEfrJV12bwsJ2XCIlnAev7bmPYquOKaNQHfuYKv2wtaWza3sNTXJMOZa/L7yKZ7KA7jA9jfAUO4ngzxFb5hw6+T9zpdN3EBY7SDDamwAveBO9vQn9A/2DRC8514ctWOrTX+rDNuzry8YSd1ksYeMWcwEaS9ATZqZOYxF1EWb0CKECemYDflqk8eVKehyZTzSU0+MIU4efHYxu2BAdfFb/bGgw2tAQHRyCCe3NUH00Nti1XYlI0rJ4qH49VjrDEcAafxOlh/TbQ7up9O4hMON3Gz7X3lwmSRGls3swFl0XaspUugbj0fpQDvdR9BMCcjiL2DBMC0iUKTFyo6y2M51Mqfp5FaZ4h5Ygo2qK8l/eVjTewxq4RckteN0KpVQy2Xkurarpc50wha5jvDed7oWwmuHnPE5k9Khhbu39kUIDBAaVWvRHwQKMIBExfOYeyg4mPaFWSuL0BjAHN9p3DlDcHEjx67R3SKUo/adk9eBgbcnFklqaDUxo10mjdA+CyO1kBkIkhiT9tkOE1ZkPMt+VkljyBbwzzMYR85Tk1Tk4IjMwQG9zbGPNFAaL6I6bKQwEBgsb7XHRejXtgalD+d0uyyHgMNvwiLK96zpuNj6dXfff7C10a693d1Lhzm4UViKz8biUxTD3w6PEVGQ+g4GS3nk8VtwJ3BvcGdyX+0LyUAZ+VKXrOSW/v37P4T3r2euR1dR3NGQ/Wb8nj60TWX/oVfACoMhBcvCXCejSTyROa38gsTOZUP50Ks/fA4jjUs5OYxh07XmeKcj+uyKAAH5L9blI3OXTxwZqJiZqBtrRCX8Ii/UP6Y0NFi8YqJ2YqB2A16bxTUbp6BhBpchP9DG8sJzPc8koYp/QO4pIYwS8nrRoO+f2kUz4wNdjwDU2Z0wj0CCjJSOR7UvyMYorI0HG4ZPaFf294YvwNrmiXYHgEJam9YrTnaVHABXTdiI4aXM+LnBzMa4D+dtumxsXLATalo0KQn6Jt/vz3t5gw96sr6dfCKxNAooH8LgyFbufPCEIHTNCgA7BKrQaDNvQn1MH2yHYBBemDuqm0cVvMxhaUaJjhivvEATiWG4y3fmpyWPCnO80ef54r0zL7FHgV7MnablXjTufL8cRcTgc1VuKw//fJvfa5L+BscYKAAAAeJxjYGRgYABi/jvPp8Xz23xl4GZ+ARSI4ny8rwFG///2/xvzZ+ZPQJUcDExAkgEAoUMP6XicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AIAnloHAgAAeJxjYGBgYH5Ba/z/G+3M/f+NgQ4AAPv8MfAAAHicY2AAAgmGIIYshhaGC4wijCGMPYz7GF8xGTGFMVUwTWC6wGzGPIf5BwsfiwZLCcsOlgssL1gnsB5iE2EzYGtim8K2jZ2HXYvdhX0Z+w72fxwRHAUcszhWcGzjOMJxieMZxxfOOi4O0iEAtgsblgB4nGNgZGBg8GLIYeBhAAEmIOYCQgaG/2A+AwAbuAHZAHicfZC9TsMwFIVP+odoBaoEYmAyCwtS+rPRtVKzd+ieJnaaKo2D41bqznPwBDxHn4OnYObEeCkStSXnu9899w4BMMQJAZoT4Ma9zWnhitUvt0n3njvkJ89dDBB67tG/eu7jBQvPA9zhjRuCzjXNI949t3CLD89t+k/PHfLJcxcP+PLco//23McqGHoe4DlQcRaZPJ0XcV3nyVJm+yI2Z+6sWElT57oUk3B85iNZShNbmYr1UdSHbGqtEsronVjo0sqi0KIyeisTG26srWajkfI+TPQOMTJEMMiRYo6Cdc2bI8ESkr29c+ZC7v/OihuMY40SAhP+9/GFfMR86WZiWH5Tzqxx5FvjwKkprYVirZjR2JEWbneTLng1TeV6W5qEPsTGTVWYYcSr/uRDprjpB8WrbRMAeJxtkmdv2zAURX1iyVbstEnTNt17D7VN994z/RUMRctEJFIgKY/8+rJxGiBA36dzHx7uu3xgZ6mzqEHn/7XFEl0SUnr0yVhmwJAVjnCUVdY4xjrHOcFJNjjFac5wlnOc5wIXucRlrnCVa1znBje5xW3ucJd73CfnAQ95xCaPecJTnvGcF7zkFa95w1ve8Z4PfOQTn/nCV77xnR/85Bdb/O4MRVk6VYqgrekJ5+zUd4WXPSmMVFUqx8KFNTlWcmfbzvI9UMXGQUObQgXlam1EUOsH7dbsT65IW1mXNzoK14+irY0fSGuCEzKoIpG2mafSWe+TQnmZqVkjomexrOYq95Xw4+EB5ZvdyL2RruLKdKSdD0npdJOWzrZNEkdCUqlR6FXaxN39yopCmzKrxUzXelcltTJtFrMulFGzkBhr1NDYkIuqslNVpE10Ud1Gm7TRExuyxqmJtq1fc9HM5tttCNbkdjRaPdwwqdPlOCReTNTA19EuL+zU7OPfWMMF7o1lC46pQzzNenBKHb5l1prFKwb/IN9EUOJQBDQWwxSPpGLMDtvM4lcoqGlpmDNil0mn8wcxorJdAAA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n\n.ag-icon {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n\n.ag-icon-aggregation:before {\n content: \"\\f101\"; }\n\n.ag-icon-arrows:before {\n content: \"\\f102\"; }\n\n.ag-icon-asc:before {\n content: \"\\f103\"; }\n\n.ag-icon-cancel:before {\n content: \"\\f104\"; }\n\n.ag-icon-chart:before {\n content: \"\\f105\"; }\n\n.ag-icon-color-picker:before {\n content: \"\\f109\"; }\n\n.ag-icon-columns:before {\n content: \"\\f10a\"; }\n\n.ag-icon-contracted:before {\n content: \"\\f10b\"; }\n\n.ag-icon-copy:before {\n content: \"\\f10c\"; }\n\n.ag-icon-cross:before {\n content: \"\\f10d\"; }\n\n.ag-icon-desc:before {\n content: \"\\f10e\"; }\n\n.ag-icon-expanded:before {\n content: \"\\f10f\"; }\n\n.ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n\n.ag-icon-eye:before {\n content: \"\\f111\"; }\n\n.ag-icon-filter:before {\n content: \"\\f112\"; }\n\n.ag-icon-first:before {\n content: \"\\f113\"; }\n\n.ag-icon-grip:before {\n content: \"\\f114\"; }\n\n.ag-icon-group:before {\n content: \"\\f115\"; }\n\n.ag-icon-last:before {\n content: \"\\f116\"; }\n\n.ag-icon-left:before {\n content: \"\\f117\"; }\n\n.ag-icon-linked:before {\n content: \"\\f118\"; }\n\n.ag-icon-loading:before {\n content: \"\\f119\"; }\n\n.ag-icon-maximize:before {\n content: \"\\f11a\"; }\n\n.ag-icon-menu:before {\n content: \"\\f11b\"; }\n\n.ag-icon-minimize:before {\n content: \"\\f11c\"; }\n\n.ag-icon-next:before {\n content: \"\\f11d\"; }\n\n.ag-icon-none:before {\n content: \"\\f11e\"; }\n\n.ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n\n.ag-icon-paste:before {\n content: \"\\f120\"; }\n\n.ag-icon-pin:before {\n content: \"\\f121\"; }\n\n.ag-icon-pivot:before {\n content: \"\\f122\"; }\n\n.ag-icon-previous:before {\n content: \"\\f123\"; }\n\n.ag-icon-right:before {\n content: \"\\f126\"; }\n\n.ag-icon-save:before {\n content: \"\\f127\"; }\n\n.ag-icon-small-down:before {\n content: \"\\f128\"; }\n\n.ag-icon-small-left:before {\n content: \"\\f129\"; }\n\n.ag-icon-small-right:before {\n content: \"\\f12a\"; }\n\n.ag-icon-small-up:before {\n content: \"\\f12b\"; }\n\n.ag-icon-tick:before {\n content: \"\\f12c\"; }\n\n.ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n\n.ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n\n.ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n\n.ag-icon-unlinked:before {\n content: \"\\f130\"; }\n\n.ag-icon-row-drag:before {\n content: \"\\f114\"; }\n\n.ag-right-arrow:before {\n content: \"\\f117\"; }\n\n.ag-right-arrow:before {\n content: \"\\f126\"; }\n\n", ""]); +exports.push([module.i, "@font-face {\n font-family: \"agGridClassic\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABXwAAsAAAAAKrgAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAmMAAAR2Zoxou09TLzIAAANsAAAAQQAAAFZWVlMSY21hcAAAA7AAAAIbAAAFnIlT7KJnbHlmAAAFzAAADBkAABg4HeN0mGhlYWQAABHoAAAANAAAADZ2z8SBaGhlYQAAEhwAAAAeAAAAJAfTBCxobXR4AAASPAAAABgAAAE4yyH/7GxvY2EAABJUAAAAdgAAAJ5JCULobWF4cAAAEswAAAAfAAAAIAFkAKpuYW1lAAAS7AAAATMAAAJS8kTiWnBvc3QAABQgAAABzQAAArBhTs2TeJx9lMtOU1EUhv/DaREoAlG8pCIiGi+oiMrxXHpoy6WH1tbEgTEOnGBMjAlxxHP4AD4BQ5/AB3DgE/gADhw6Nn5r9WCFAey03Xtd/vXvf62NAklTWlNTYzvF4KVm9vcOPqquioZ/5v9/H+x/eL+niaMTvor/TiioTGtGy3qtA30LZoKD4HBsPqyHr8J34efwS/hLIVFLWiW6pqesWAnfkVJlaijXmMaxxew34BOymmq59RyMqu7pqqfL1IzJ6Tniip7xmQOncJyOtolKWYbZ4XvAuqfZUyJy3Qc/g80m1gqKLKJJrnlNgp4Q01Sb/Cb+89TcoXaEv8BXwK6KpcW+rQtwsoyKq9rVGz3Bbzc1lKzMSfnE2vVz5Kc1NDmKaoHToJZhr8LgyN6gakLGY9AzorZKRVd0k+wGOB3Q2p694dnLRCZwS3WDnd0zges08Zle6K1X3S1zOq7pUIFV2I/shePlenjM2gZrQOwjOIys1p8H1IrUx1+jV4X29UmH+qrv+qGf+q0/OqOL1En8Dtug75yqzQQKnozu4m39s9pdx5mBk1HHIya5ecPVifH1Sg2tWo2bmTop+whr6vFT8LT4Lmxy+lGhRuR1rdNV1ibnmOiz5XQ2WdOudI8pmPUJ7vss1HWHvi064nAOc7S+CqLthvyuuG5N8Ba8b6auvbA5P9lbsH7XmdVr/EbcMHOdnuO9jsWQRpYlz8phbxjr+HNYj6oZqwVYresuPpuxvr+OLpVucZ8hk4QIexl9n6/bMMjKlzpPD419u+zYJY+LPSvgP0FUvvDUtbOZLuBm8zH4C3G+c6UAeJxjYGSazTiBgZWBgamKaQ8DA0MPhGZ8wGDIyAQUZWBlZsAKAtJcUxgOMOh+NGJ+AeRGMX9i4ALSjCA5AOaCCwgAAAB4nLXUB1IbQRCF4V+BLMA22eQcBQaTcxAiHwJnCgcKZ87hs/kefQL8Rt0+AK7yVn3bO1Or3ZlavQaqgJzMSB6ytWR0RSar2UxlPkd9ZT7Pb40L1JLVdZErbrizhft7zRa55Jpby1RGf4+M7i7QwxjLGh2yxAE7lFnlXDN7rLPPLkdsssEJK2yzxjFnbFHilAv9Pq0irzVWU6P31mklDXpiI0084jEttNJGOx100kW33tRLH/0MMMgQw4wwyjgTTDLFtHZSZJY5njHPgs7PNVrUIqt52HH4wPvTsXSwU149X97TjnePNje02e2147Ot0unFPzzsPxyFdMr9itEZ6Yu6tNvLsCQvwoG8DDvyKpTldViVN+Fc3ob0b3gX9uQqrMt12Jf3YVc+hCP5GDblU9iQm3Ait2FFPodt+RLW5Gs4lm8h7f172JIfoSQ/w6ncBX1Ay7iUF8s6Us25lC/Lu5Qxq3Ipe1btSLXGkWqtI9U6R6r1LmXSGhypFlz6ktboSLXJkWqzU3awoBRhQXnCnjglC2txyhjW6pQ2rM0pd1i7UwKxDqcsYp1OqcS6nPKJPXVKKtbtlFmsxym9WK9TjrE+p0Rj/U7ZxgacUo4NOuUdG3JKPjbs1AOwEadugI069QVszKlDYONOvQKbcKkv2qRLebApp96BTTv1FGzGqa9gRac+g806dRxszlXuCepC2LyrPHPBsfgHpKymyQB4nO1Ye2wUxxnfmfXt3t57d+92zxycvXf4FkNico+99QMMGOOzcWzTnIMJaQ04GMWYRDEESJqktAElJErSShFVqUmAqj0XmlQFI+XRBxKpGleRGqePNKnyKn+0Sdq4pHXS6uRb+s3eww8ooPSfVu3Zu/P6Zuabb34z3+9bClHwo5P0IMVRFFJkVvEpIq3QSWN4717Un7v/9dfxAfzT8fERtBftBRFT/n36faoSChqr6jKr8oqZ6ApvJjKvmAmroHNdqbGxlnWIXgdpap2RW9cCaZdhkPpUF8J0JdcFVS1dlzblu1LFOdfTj1FWKLAqBw8fRt9+th/1ob7+Z47jXc9uRX3G01ufyX1YlMcTeIKym/KgC2gD+uCJljOjqTNnUqNnWkbRqmJutOUMZaGoiwas6wNKpMKUSi2hllKURQnVII1PNKK4EgsiH+91IVoJMZCRoCYJTREU58NVcV+YhpTenhOV+lCoXsEfwUupV3Iej9/vwRd4Wc59N51GHen0SHc3DtWF8Mfwgv+cG17012U+x/N+P4//wsvGqPF2JoOOGZth2bP0WgzrKSoSnlbOMkcnFsF6RZnebioRKik1MUOdAWPi74kT59fSHxSVKCp180xdXjRsP1t1EB1dRM3VRb02XWhFU66oyO+N06jzKloYzgzZ0lnzX9vsV5r5KpOS9cKi76G3AjqslJ+iAHgyh2i9AjEs/Pm8EsySUCMq/pOxqf42I4cax8Ze/oHdXu6WomuikrscnUPHG6DBeAktHxtrdDqDgUh5KBoNlVfND5LhGXOOQ/QhmI0FvLphbTJFVfnAbPDQc1J03DhNNxmnM7OS7Aj8UEcGfqiT5KmC7h8UbLX02qyFAMe+sBbW4lqcHgwRi4Hl8hYkljMtQyxnvDJi/vIWFAoWnChYUAQJHn8E23aGqDRCUUV9mugmc5U86BPnFS0MN4XCK7Sm8HEND2cMRwZNpo1R1DFijKbxsFnOQvk4VGap0l3wAP0AOdscgu1gOQQ3go4mkbDHmDBfxsQeJMALb59VRAIU8za/OEXfSf+Z8oB1FlCt1Jepp2DoCOykZYZF6LCGQEFGlhqQWOV14XCopkxLNOI4saWXCUXUGhSGDt4giiX1RhSTZGLgEFRriWQsSMcJPmqQWoOJuWNBXOiU71OBJDmI4WZK6tFGsj9enxu5MGzPUhq6S/Qd7La7LEanqusqTqp6y6jRhB7BiLZ4foeNTZwQ9Hpkr8dmcfoVUV4o2pzWMqvXLc93yJUSg60u2ykhJC3gnR7OZWWtbgcv2QWPN8ALFZLg5602J1tmcQcFxm4RBLtTsC1bshjT2Gq3WrCGWZvbweA4jWyCFf/RuudBC65Vp141lXlkfOpR+p7flHN87mu/dVQERasQqKzyhbSId74qcG6b0+dNxCqXSH6/ze1yl1dLbnuVYHfZy3mHLLh4K8OKSk2V6PT5fR6b3S2ITs7O0SxrYcUFT/zwR5ydsbFOm4X7Nee2ci7uF27O5hGo/+/df/XeFf34QdOP83FgC+TgfufYM/3G08bT/ehe7MpNQuEo2tIPomVz9rrtqvusQ2skkYzHpAq0ApNtk3xeN5Jhe1woFFmKWAKEiJa48vZcf0s7x1q8bl70LFtpczFOq1v0dXY7bJzgFco29JRxPNRcybBj9w66nHbJI/o3bnQLFovHwS+44163T3BxHLPvi4yV4d2mTf4X1vjZeAPxelfy3k8YjquxhtFMZtr3vEzrVDkVpZbB/LqcjEuyJLvAoQM7RMkVSAuHwKerYg1WGTaIZEmXGWJp+EuCgGl1FeSRkoisaHr4vqEN1Xc0aqsqXcYva9pVW+OS2uv3/SH5+WW25kT0sc7052Jf2LhlfWPd0tjG3eiNdS0uQQoq9obraNeiG4Sym9r3L7890hxfZEf7bBilLYwrYLzN1G7QYq3Nt0l++8r5Ni5R1Rhb+9CNxuForyjLFfPi3YHptcjgQxdRSVgLWYdJRwq6JiFP6iS9qDS5ldSqyHIUJnIyiOhoiqyga8/9D371fqLkLbu+cldzYmVv3+13bV6/1lTW0XL73oGUDa1Ftq5kKlm1KBlZRvvodPuDezq6HI61keWx9gPtN5+MtW7QaxlGj20VZamyvPbWRLK3nnbOX4ys9nntXiuLqTx3M3nODuBSEGmICuJVLeqLa2mTx2ToQWC9m0ay3d0FWTwF/J02oxI+zAOhVVkZrUhjz0sv1WazeMJwoEmj+dw5KBBxR4FfnJ3FowJUxTSb14HdFB90lbwCHGgkk8ma/8BC/lUOHctkxjMm8Tp2aQIqWQrrPgtnW6GqqGrqesJ9TDIHXKtA60oPH9YUFPZBLJF/quBBx4HVgY2A4ZGUsCMz3dyNOgvTmerQg2kwXyadhSSbxqlsTkij493AndLp/xg95uxtVZiPIxKdsXgqnc5dMDc3O2Nn8z7jGL3e9BkykD0SoqJtJ/Je4iSuR8dO5OPAk4Ro4oufXvyU/hv9VypBDeZPB+MmdB08txrR4aCDc5bztS4UxFDRiIhb16IRkoUmcv+yZjORk+MS6aQm1CgRM+WDuNgM5AEa9aQawV+q83oX1R6o62y/sWOnF351rbZyAWEelzHlAa+gtbUF9s8XxADnx+XVVskmCUis67ixvbPuQO0iEBd8yCZZF/ux084FRDGwP9DWpgneQDlTBoMgodzWWkfGhZk62w/DTKSw0xyglfO4tJhVYOYFWtuSXjFwINDaGuB4T8hfbcWMh8xkqnSg9jCIC24WW6v9IQ/H2ojggYDoTba1BuYxgjWmuTxcq7mKmef2EJymCvPmZOF4wKUJcQLcnHBMYPMgWojrmhpmfTh1eM/hN96AV6aU+cajfX2P9uEfz6okmdzzfaTJ9IEzY9zoNUberBnUIx3ucFm/cuz90bup6HDtEfR26r3oU7VPXSUAzzWm3rnhCIg/8F4qCmnJh0zHaWaEhgoPfWjqJ3RT/snmIzEShxX9+2dZm25+toAlkovvymu7753UDUf0YZRIvUuUvtrasoW1PQkmOaIfKX0veRzOpIXsMDmN6FbzJKJY8YLNn8MA/SvKOf0NxuRvMhoe6EcqUvsHBvqNN403+wfwqe1QA7ntxkPboQ7athd4wEWwxYeUl1pIxQkPICfMQ5xXJXFVHvBMSQs5s/EYyZLYeik5jqZvBt5NTufkwbuHmtasaRq62/h491BTc3PT0G40nnsuuaopNbRlk14ny4vbtFWrodBbW+eXF9MfgvBu48LunUR4527kgW5rPsk9t1iW6/TevqFU08pkW76wZai1aVWyhPsmehB2252PViFEjcvkpoSoldxq27KZkbRxOo0maX+uHw+nR8j992/2RaU4GUoozMthVg3r5DrGE72nsul09lQvmgT3NzaQzQ6g2nTex5QwpgArqKVWXB5lhOSYMGsAn6pZIPIm7DL/Dc881OR0i8QBkC8nczCXu3Mfwdy+EXpl7kUc5OV/OBuGhhocZx1msmM8dx63yJegD1/I5OGHU3DBv+Dn0TLHjH5OnMp8iZfnYND09vjxORjEM/BTDVImKDwEQpUELR4CIdaElJe0hEyiTFrQ5MMlpLiL6DlogqVO37TlPAAFfr1bLo+Umwkuzvf1EuHePhDW62ZjudrkYZfDsmyqSGArmYAm34oiIuHpNShhho2XhfPDQ0WNzhd1fGT1roO7Vpuva9bS2Nxc6LJ613T8dbTgS1Wdg0fR8P7v9aMtxtH+E7mf49TJfCh2YqSE40HAsZOSCA8DWlC6oyyFT71xAPDz6WgIt4aixuiO+vHx+h3d4MDfQguNt8iXLrRw/o6G8fGGHejJaXzjYTI6sMAR/E1jFA8bp0v30DBgH5NvOzzhF2gSdeS2zW3DeepBrwLSODpnTA4RgtKRlyi0ZegUwRUHATuiM7nXjFf2nEUv4NdyryFtN+Sm9WolO0uOACiW2wbgJNUlThGmUlQP3P2Sdy6nqECkrsAokjGZlmIlpsB4obXAE0gP1qyTEcEDioTyBSmGb2LZnhn0oYcV2U6G2QBcgDjnHtbLhuDpIS4e6MEGhukEiZ4ZNKCHZbH/Opdr6luuiAtSutcVefVSmY7Zo6Dvz56k41I1pj65DkaE4WBU1QnD/xPnjHQ0AAAAeJxjYGRgYADiY81JvPH8Nl8ZuJlfAAWiOB/va4DR/7/9/8b8mfkTUCUHAxOQZAAAhKEPOXicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AMAnl4HBgAAeJxjYGBgYH5Bb/z/Gy3NZqADAAB/FDOneJxjYAACCYYghiyGFoYLjGKMYYx9jAcY3zCZMEUwVTFHsJix+LEcYDViLWK9wWbC5sWWwraB7Qu7BXsAewaHAIcTxxSODZxMnCKcZpw9nKs4T3A+4nLhCuOaw/WNm4/bgtuNO4Q7ibuAu4V7Eo8M6RAAslkbZAAAeJxjYGRgYPBjmMfAwwACTEDMBYQMDP/BfAYAIQYCDwB4nH2QvU7DMBSFT/qHaAWqBGJgMgsLUvqz0bVSs3foniZ2miqNg+NW6s5z8AQ8R5+Dp2DmxHgpErUl57vfPfcOATDECQGaE+DGvc1p4YrVL7dJ95475CfPXQwQeu7Rv3ru4wULzwPc4Y0bgs41zSPePbdwiw/PbfpPzx3yyXMXD/jy3KP/9tzHKhh6HuA5UHEWmTydF3Fd58lSZvsiNmfurFhJU+e6FJNwfOYjWUoTW5mK9VHUh2xqrRLK6J1Y6NLKotCiMnorExturK1mo5HyPkz0DjEyRDDIkWKOgnXNmyPBEpK9vXPmQu7/zoobjGONEgIT/vfxhXzEfOlmYlh+U86sceRb48CpKa2FYq2Y0diRFm53ky54NU3leluahD7Exk1VmGHEq/7kQ6a46QfFq20TAHicbZIHb9swEIX9xZKt2GmTpm269x5q6+6990h/A0PRMhGZFEjKdvLry9pBgQA9gIf3Dod37w5sLbUW0Wv9PzZZok1CSocuGcv06LPCAQ6yyhqHWOcwRzjKBsc4zglOcorTnOEs5zjPBS5yictc4SrXuM4NbnKL2+Tc4S73GHCfBzzkEY95wlOe8ZwXvOQVr3nDW97xng985BOf+cJXvvGdH/zkF5v8bvVFWTpViqCt6Qjn7NS3hZcdKYxUVSpHwoU1OVJye8vO8jlQxca/gjaFCsqNtRFBrf8rN2avc0Xayrq81pG4biTN2PietCY4IYMqEmnrnVQ6631b+kkaXz5ICuVlqmbRQHee80GmZrWIs4pltaNyXwk/akfUGeoqjk+H2vmQlE7XaelsU3fnOSrFxpBUahg6lTbRT7eyotCmzMZipsd6VyVjZZos+l8wo2YhMdaovrEhF1Vlp6pI66iiuvOcD9q1NmmtJzZktVMTbRu/5qKozbeaEKzJ7XC4ur9gUqfLUUi8mKieH0fZvLBTswf/2usv4LwtW+CmTkI823pwSu2/c9aYxTYIShyKgMZimOKRVIzYZotZ/CMFYxpqdpgwZLfV+gPpZLiDAAAA\") format(\"woff\");\n font-weight: normal;\n font-style: normal;\n}\n.ag-icon {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n\n.ag-icon-aggregation::before {\n content: \"\\f101\";\n}\n\n.ag-icon-arrows::before {\n content: \"\\f102\";\n}\n\n.ag-icon-asc::before {\n content: \"\\f103\";\n}\n\n.ag-icon-cancel::before {\n content: \"\\f104\";\n}\n\n.ag-icon-chart::before {\n content: \"\\f105\";\n}\n\n.ag-icon-color-picker::before {\n content: \"\\f109\";\n}\n\n.ag-icon-columns::before {\n content: \"\\f10a\";\n}\n\n.ag-icon-contracted::before {\n content: \"\\f10b\";\n}\n\n.ag-icon-copy::before {\n content: \"\\f10c\";\n}\n\n.ag-icon-cross::before {\n content: \"\\f10d\";\n}\n\n.ag-icon-csv::before {\n content: \"\\f10e\";\n}\n\n.ag-icon-desc::before {\n content: \"\\f10f\";\n}\n\n.ag-icon-excel::before {\n content: \"\\f110\";\n}\n\n.ag-icon-expanded::before {\n content: \"\\f111\";\n}\n\n.ag-icon-eye-slash::before {\n content: \"\\f112\";\n}\n\n.ag-icon-eye::before {\n content: \"\\f113\";\n}\n\n.ag-icon-filter::before {\n content: \"\\f114\";\n}\n\n.ag-icon-first::before {\n content: \"\\f115\";\n}\n\n.ag-icon-grip::before {\n content: \"\\f116\";\n}\n\n.ag-icon-group::before {\n content: \"\\f117\";\n}\n\n.ag-icon-last::before {\n content: \"\\f118\";\n}\n\n.ag-icon-left::before {\n content: \"\\f119\";\n}\n\n.ag-icon-linked::before {\n content: \"\\f11a\";\n}\n\n.ag-icon-loading::before {\n content: \"\\f11b\";\n}\n\n.ag-icon-maximize::before {\n content: \"\\f11c\";\n}\n\n.ag-icon-menu::before {\n content: \"\\f11d\";\n}\n\n.ag-icon-minimize::before {\n content: \"\\f11e\";\n}\n\n.ag-icon-next::before {\n content: \"\\f11f\";\n}\n\n.ag-icon-none::before {\n content: \"\\f120\";\n}\n\n.ag-icon-not-allowed::before {\n content: \"\\f121\";\n}\n\n.ag-icon-paste::before {\n content: \"\\f122\";\n}\n\n.ag-icon-pin::before {\n content: \"\\f123\";\n}\n\n.ag-icon-pivot::before {\n content: \"\\f124\";\n}\n\n.ag-icon-previous::before {\n content: \"\\f125\";\n}\n\n.ag-icon-right::before {\n content: \"\\f128\";\n}\n\n.ag-icon-save::before {\n content: \"\\f129\";\n}\n\n.ag-icon-small-down::before {\n content: \"\\f12a\";\n}\n\n.ag-icon-small-left::before {\n content: \"\\f12b\";\n}\n\n.ag-icon-small-right::before {\n content: \"\\f12c\";\n}\n\n.ag-icon-small-up::before {\n content: \"\\f12d\";\n}\n\n.ag-icon-tick::before {\n content: \"\\f12e\";\n}\n\n.ag-icon-tree-closed::before {\n content: \"\\f12f\";\n}\n\n.ag-icon-tree-indeterminate::before {\n content: \"\\f130\";\n}\n\n.ag-icon-tree-open::before {\n content: \"\\f131\";\n}\n\n.ag-icon-unlinked::before {\n content: \"\\f132\";\n}\n\n.ag-icon-row-drag::before {\n content: \"\\f116\";\n}\n\n.ag-left-arrow::before {\n content: \"\\f119\";\n}\n\n.ag-right-arrow::before {\n content: \"\\f128\";\n}\n", ""]); // Exports module.exports = exports; /***/ }), -/* 252 */ +/* 305 */ /***/ (function(module, exports, __webpack_require__) { -var api = __webpack_require__(225); - var content = __webpack_require__(253); +var api = __webpack_require__(278); + var content = __webpack_require__(306); content = content.__esModule ? content.default : content; @@ -48946,14 +57891,14 @@ var update = api(content, options); module.exports = content.locals || {}; /***/ }), -/* 253 */ +/* 306 */ /***/ (function(module, exports, __webpack_require__) { // Imports -var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227); +var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(280); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, "@font-face {\n font-family: \"agGridMaterial\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABGsAAsAAAAAIJAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlEAAAReYPJi3U9TLzIAAANcAAAAPgAAAFZWTFJvY21hcAAAA5wAAAHsAAAFgGqPB0pnbHlmAAAFiAAACFEAAA58peGl1GhlYWQAAA3cAAAALwAAADZ2zcSBaGhlYQAADgwAAAAWAAAAJAfRBDJobXR4AAAOJAAAABIAAAEkt5gAAGxvY2EAAA44AAAAbQAAAJSyFLU8bWF4cAAADqgAAAAfAAAAIAFcAEluYW1lAAAOyAAAATIAAAJebBQ2inBvc3QAAA/8AAABrgAAAom3/2OGeJx9k09yElEQxr9hCCYBk6gRFVFT8X/UOM4MTIBIQBApKwsXLly4iQstrZSrnMC1B7A8gKfwBJZLVx7AA1gewF83g5gswhQz73V//fXX/fopkLSoSF0VhqPd51ra3zt4r5qKmvzM//862H/7Zk/z0x2+on/nFYR/tKR1vdCBvgUKXgefC6WwEHbD3fBD+Cn8oRDUmjZBl/WAJ1bCO1KqhprKVFAJW8x6Sy3QIe+2W0+rqjn3DDTUWXLGxAydcUNPdU0r8PSdp0ctAzhT5+zxHvFc1/IxiEw34G+gZhursdbReUoLeozGHjo6RLfwruDbIXNETB9fH22ho4rex7Fe6h42q80iGzku5R/rke8j31XowhTVhr8Jv/FtknVqb5IpIeIu7A1QD/MebugK0U14erB1PHrLoysgExSmuszKKkuorEKH2nqmV0SWUTGJ6XkXJzXfQv3M3ne+TLcPWTtwjcDeQcPMaidyk1xWewK+yv6dPuqLvuq7fuqXfoOvkiXxCrpw7xzbmQX6dxQ9wNv+Z7VKT3AWR1GHEYvU3fTexPiGeQctWwWf9SZlHWFNHV+G0/AD1GScxhyTF3neBGuJ/Tb7GPRSPo0tnpPe5yEzYBNQo5Mxb2OazFtGhy8QbauJrnPerRY85/20rKd2k5Z9ZzNvp1zj1C/yjais4f15gvcSFmOaWeoelaHaOO7jz1A7y2aq6qhKfXZtssZ+CwZkWqOOiZJEV/0GjH2q1lHQyG/kqs64+k5+UquOiz0qoBNRfpNT75lNch9tNhWjv/VfaSwAAAB4nGNgZGphnMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVFgEqgRRAAA0p8KWwAAeJy11AduVDEUheF/SkILvbcUSK+T3ntlGaFHoUShR6ySndwNEM4dHxYQJCx9c8d+nvdsPZ8BWoCaDEsdqnUqZPut0UpzvMbF5nidX+q3cZ6qvo9wwBEn0Tg91egI+xxyHJVm72+raHYbj+hlRr01GqywwDqT7DDOEtMss8gGs7q+xQTzTLHJHnOsss2ufl/V0+u0ck5PvaB1XNL9LnOFq1zjOje4yS1uc4e73OM+D3iopz3WnHY66KSLp5rXTY9W0Ec/AwwypB21ab2jjGmBrZytrZ1xfrbGysL65M74kna7uDE7o43OT23uza1u7/7Dzf5Da8uP2k/3npFvs1iTfWvIc1uRF7YgL21dXtmkvLYdeWPj8taW5MCm5dCW5Z0tynvbkA82Kx8tT9eRbcmxTcgnm5fPNiVfbFO+2p58szn5bqvyw7blxPQCo1JkVqJakLVWZLaiXmS+oqXQmSZMp5swnXPCdOIJywyGKQWE5dsLUzIIU0YIU1oIUx4IU4IIU5YIU6oIU74IU9IIU+YIU/oIUw4JUyIJUzYJU0oJU14JU3IJa+6rvSBrR0HWzoKsXQVZnxRKPWHN/XYXZO0pyNpbkLWvIGt/QdaBgqyDBVmHCrIOF/kfGiNFc/2jRWYpxgpyrFEw9gcVSJ+veJzFV21MW+cVvue9xTcmEOKAffECduyLfWkwrsy1udgGwlcCisrHZCdaG1LTdIG0sBjaVF2WoX1okyK1ayqt9Efzp9GkizSpTVv+pNOUVCxVmfrHUfNrYmzqn+GsQ1RCreTGVzvnxTbhY1Kn/Rjc933PfT/OPee8z/mwAAL+sTWxR9gvCOCxV4LdE/HoqoetmRVQZX4FG+byvXvQIHYncrnEbCYjCI/RGfED8QPBIlQKNcJhPKlFNFXSJCUiyRHNp9oVu2ZXFbsi6wrcMNKLi+k26lj/Yjo9z9/Zz7CfJyqxmDbSOlLIlssj9qA8+wShWtZtmk3WYT6WTa7GzQXYiGfNMvg2G4dBFJvvnRPnUIYjeNQrWSRLjeyQHS16q94aVv2qv1pSJVVXdVmXJdiYeTalR6N66tkvikQq9tZbsbk53otz25Y4kf9zcRV74f/zTZF/s1asRUqie6rWbAo1XbMrmdnZB5cuZV9+mT1vTrCB/K1cTijJuSquCtWCk27WewDsthoXaJ6WTojYwkGwgi6DLF5++LVLc+EjlvMxv2Y+GFoCY0hcxfdtiw+/BsfQp2AMb+cv781fRCDt4v6b/H0W2M05f3/6UZ4i52nz2Hx78UWeYvkOvpuT6Z18C7b7sfhDoQwRVSsIVpBkK4i6Gyx0dfYaR0trhK6N/dNMxZ4z89C5tPTp+/v3O6scoeMhR5UTFuFGHBfMP0HH0lJnZaXrsN/pDYW8Tl+di9hbS5jdvJ8qbpPDgltQ6K4iCjUJWwSbjE23a5GywrwN27xh5PhTGM2xwhu7buTHcUwahQlcwafoJ+waW0O9BFRJQi95M3b7dizH1uJ37sRzJdz8XLyDmjuFen5LFjt6lEfmRI0DjdqKNvUr1R6bh71vViihJGzMmhFSDz7DXgEzAp+Jt0Pe/EesPxFS8h/RGutXQvnzrL/gr4RNih+Iey6KrKtibTybLT7sr4+8bPdxPGNTbKoEYjd3chgkJ4dvzbIsOvwOPZG7rrLXY7lc7DZbiOdy8TulmPEUWxXa8SXIFK9FUlu1FtkF8gFAUldwQpEtitevKi6mtehEq0HAJdkiabTZIWvsTSnYp3ri8uBTEyMDJ16ok0+1DfmsvZLt6FDfPqsnvK9Xaj6uNhzp7x3A9ck6//fPWB/71eP1jUfC1h5m83UoTseg5nZf7O845xn0abWHjh4H1e3vVKpOfI+mx7pGq2sa6/xFXJLMhxAnjTySoKwoMQaSTtBRNr/oDUK4E1pcUHMARK+FoBr2wwaXre6FEwPvIFFfj8RI4GQgcPIH1AUao9GRaJT9g77Xf9HtLo7mZGEHdiDSnpFoESOTaN9CbPEhHikHAHovRm7DXGZr+WuYBSpyCbiRSJjLyVJ8Yd/we7HSzeh4N4AxiX3z8cd4MWYkmYQIATFHZwu+3cNm+Hco03jKKD5058fZ24U2k5hP0DYL3/uMWI5UuWAT7IheN51BMzQBCaejTXCo5h6FmUdBM2msHxzo8vPgMB/MI2FWpOlvhYICDFI3ND29gmM6fz+dnqbpXXpUE3pVD+rxFVcDXkkm2QJXA5XYmZ8AEyVGURXV2IQrDBJ0mSsbMxfMhVi2aN859gnmi1ohgF9AUeMQUTCuYVTjVBBkNIUPU2aLi5GKSHQCRrrfedsVw4iOtbWNRQ1Daff+HobMD+EVToNSWoQNJa4Mt6VeTLUNK3EpaWB/gmbGZlJtxbhajvaUuR0xLWHikCXM0hFMVGRAHbO2qOkRVZHsLHB+ePyNN8aHz0+XiPHR7u7RbvaTbZNEmFe6aalgl0lxkjSuxtudRdgcEicTwh4Y01Fd/o93yPdtNiwvkplEouDza8I9OqkjLw6hDMfGnrxsBbzO0r4ivy24io/kbI8Q/A9ZG8JEUiCAIABGCkCM1dDGvXK42dMceHLwTPRCk9nsbYBBJOBzbwNN7pXSzdSZwScDzQ1es7npgvllgxc+b7oQ5XNFnaYwTjvwflSUTwkCxjBlR5D2tDhqLF5/uBU8Ng1V1sTam5VdI12VN3lIHqDeXLY5nV6nEyL5W0l4JylO+oJBH0bv83zPdW+oVqnFB210fXa2iI0usROlqKJMourVwKM41S8qnHlVffVvEHC51ttPr59qv+yCVpyBv5v3Xa7L7afWT7evu7bqjf+dj7VUW27mUI/gE5qEJwRN0DE2edBX0BSdVA24qC44AIBug/bw+PinsOTUfLz8onlyKR0bRRm3Vl+vudnbfMz/yzAQK33wR/OLY8fUiYmb+P6l2nWsccK8gqRjZWXFMNq2Drg5A7Ab8GvzynvHuujI/BNqFxLgp8RsbKu5aoTHiyg7SCg7QtA6SCgTvdRzqLXQSgFgVy/N9Pb19c5cgoNF6uqPzj4d0fXI02f/UiTEVVow17dvfvjTbZs4UcAUyVKBNmwlaXjA2Qws6n8hWt9Lvb0vXaWu77tJydYK+7HLfWeBd8VWSUbPx5zyaM3Pa4RsDIt/VvCZSfwF4tisFZWSr5TpHHY2dJD8rcSma5gLU7FMJjaVpB800GAu8xKnoW4qnsnEp+C3pZrqE3aWuAMWVA2ZDBulXzzFtbMYxxmXjebZ3b3WEOyvZTJ0VtjFEwtunKf1LX2fEyuKtQ2ocPHd+CpsxCDxbiyLY7G+Yq5iXM1Qjc9cyRLvNXZtswak4qiQq9jrVAlu1YBzaCfKoy0UWyjNgN1hkWQsqBEMEtakVCjZt/JRJIyFEW6U8dGB3d1MOPrRjvCxtrFzo8l9+Vu/jA0Us1JP6LT7xdTAfDjfz+5i6lECx/d3HD7XHk21GUmY+kXt811RnpmU0Mmy08lncCf7gyD8G975gHwAAAB4nGNgZGBgAOLNefk58fw2Xxm4mV8ABaI4H+9rQNAMDMwvQOIMHAxMIB4AThwLfgB4nGNgZGBgfsHAgEQyMqACTwBFgwMNAAB4nGNgYGBgfjF0MT0AAODAKyYAAHicY2AAAikGD4Y4hhkMlxjeMMowujEWMC5ivMP4jkmByYopgCmJaQ8zA7MMswmzF3MD8wzmDcyfWFRYjFi8WCJYilgOsTKwqrB6sC5jfcPmxhbD1sY2hW0R2wa2fWwX2O6xfWC3Ix0CAAMJHZwAAAB4nGNgZGBg8GSwZeBkAAEmIOYCQgaG/2A+AwAWwQGmAHicfZA9asNAEIWf/BdiQwiEuFKxEEgTkH9Kk9qCgBsX7mVrJcustWK1NvgGOUhOkEOkzEFyijytt7ELz8LwvTdvplgAj/hBgKYCPLjeVAt3VGduk549d8gvnrsYYOK5R//dcx9v+PA8wBMOvBB07umE+PTcYv7Lc5v+t+cO+ddzF0P8ee4hDOC5j1UQeh7gNTBJHpsiXSRWmiJRS5kfVHJlXqqVNHWhSzGJxpeDWJbSkFOxPon6mE+tzURm9F7MdWmlUlpURu/kxkZba6vZaJR5P9roPRLkiGFQIMWCykI6lUBhSc75F4rK3Ezemq0c11QaJQT/P8L45kZMLp0++ym31jix1zhyb0rXIqPOmNHYk+buepNWfJpO5WY7Ohv6EbZuq8IMI77sKh8xxUv/NPJv3gAAeJxtkQdv2zAQhf3Fki3baeO6bbr3Hmqb7r1X+i9oipaJSKRAUR759WXtIECAHnDgew+Hd4OtjdY6+q3/xy4btImI6dAloUefAZsc4zhbDDnBiJOc4jTbnOEs5zjPBS5yictc4SrXuM4NbnKL29zhLve4zwMekvKIxzxhh6c84zkveMkrXvOGt7zjPR/4yCc+84WvfOM7P/jJL36zy5/WQOS5U7nw2pqOcM7O67aoZUcKI1WRrJ90J5ZT4fxQTpXcG9tFugIq2z4UtMmUV67URng1OpQbc1C5KW1hXVrpQFw3kKY0dV9a452QXmWRtNUyls7WdZSpWiZqUYngmfXUUqV1IeppO6DORBehTTzRrvZR7nQV5842VRQKfFSoie8U2oR+3cKKTJs8KcVCl3pfRaUyTRLmWzNjjRoY61NRFHausrgKBqpdaROHDAtXemb90AUTm44b761J7WSydVQwsdP51Ee1mKl+XQavNLNzcwD/jTNYw1VZssZhWh/OMPJOqaN3660kWymTNGa9B4Ich8KjsRjm1EgKpuwxZhE+P6OkoWLJhH1mrdZfDrCtIAAA\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n\n.ag-icon {\n font-family: \"agGridMaterial\";\n font-size: 18px;\n line-height: 18px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n\n.ag-icon-aggregation:before {\n content: \"\\f101\"; }\n\n.ag-icon-arrows:before {\n content: \"\\f102\"; }\n\n.ag-icon-asc:before {\n content: \"\\f103\"; }\n\n.ag-icon-cancel:before {\n content: \"\\f104\"; }\n\n.ag-icon-chart:before {\n content: \"\\f105\"; }\n\n.ag-icon-color-picker:before {\n content: \"\\f109\"; }\n\n.ag-icon-columns:before {\n content: \"\\f10a\"; }\n\n.ag-icon-contracted:before {\n content: \"\\f10b\"; }\n\n.ag-icon-copy:before {\n content: \"\\f10c\"; }\n\n.ag-icon-cross:before {\n content: \"\\f10d\"; }\n\n.ag-icon-desc:before {\n content: \"\\f10e\"; }\n\n.ag-icon-expanded:before {\n content: \"\\f10f\"; }\n\n.ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n\n.ag-icon-eye:before {\n content: \"\\f111\"; }\n\n.ag-icon-filter:before {\n content: \"\\f112\"; }\n\n.ag-icon-first:before {\n content: \"\\f113\"; }\n\n.ag-icon-grip:before {\n content: \"\\f114\"; }\n\n.ag-icon-group:before {\n content: \"\\f115\"; }\n\n.ag-icon-last:before {\n content: \"\\f116\"; }\n\n.ag-icon-left:before {\n content: \"\\f117\"; }\n\n.ag-icon-linked:before {\n content: \"\\f118\"; }\n\n.ag-icon-loading:before {\n content: \"\\f119\"; }\n\n.ag-icon-maximize:before {\n content: \"\\f11a\"; }\n\n.ag-icon-menu:before {\n content: \"\\f11b\"; }\n\n.ag-icon-minimize:before {\n content: \"\\f11c\"; }\n\n.ag-icon-next:before {\n content: \"\\f11d\"; }\n\n.ag-icon-none:before {\n content: \"\\f11e\"; }\n\n.ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n\n.ag-icon-paste:before {\n content: \"\\f120\"; }\n\n.ag-icon-pin:before {\n content: \"\\f121\"; }\n\n.ag-icon-pivot:before {\n content: \"\\f122\"; }\n\n.ag-icon-previous:before {\n content: \"\\f123\"; }\n\n.ag-icon-right:before {\n content: \"\\f126\"; }\n\n.ag-icon-save:before {\n content: \"\\f127\"; }\n\n.ag-icon-small-down:before {\n content: \"\\f128\"; }\n\n.ag-icon-small-left:before {\n content: \"\\f129\"; }\n\n.ag-icon-small-right:before {\n content: \"\\f12a\"; }\n\n.ag-icon-small-up:before {\n content: \"\\f12b\"; }\n\n.ag-icon-tick:before {\n content: \"\\f12c\"; }\n\n.ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n\n.ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n\n.ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n\n.ag-icon-unlinked:before {\n content: \"\\f130\"; }\n\n.ag-icon-row-drag:before {\n content: \"\\f114\"; }\n\n.ag-right-arrow:before {\n content: \"\\f117\"; }\n\n.ag-right-arrow:before {\n content: \"\\f126\"; }\n\n", ""]); +exports.push([module.i, "@font-face {\n font-family: \"agGridMaterial\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABPwAAsAAAAAJjAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAmMAAAR2ZOVnMk9TLzIAAANsAAAAQQAAAFZWUFMDY21hcAAAA7AAAAIRAAAFnH0V34BnbHlmAAAFxAAACj0AABO8Q1oUYmhlYWQAABAEAAAAMQAAADZ2zsSBaGhlYQAAEDgAAAAWAAAAJAfRBDVobXR4AAAQUAAAABIAAAEww1AAAGxvY2EAABBkAAAAcwAAAJoHSQMCbWF4cAAAENgAAAAfAAAAIAFfAKpuYW1lAAAQ+AAAATIAAAJebBQ2inBvc3QAABIsAAABwgAAAqTvU9OHeJx9lEtyElEUhv+mm0gCklSMGjFq1PhCjZpO09DhYUIHAjpwYFkOnMSyyrKKcsQ6XIAryNAVuAAHrsAFOHDo2PK7h0ZMBuEWl3vP4z//eVzkSVrQY7WVS3vPX6o8Ohx/VEWBJh+n///sjT68P1RhekMX2G9BXlBSWTf0WmN988re2DvKrfgV/5X/zv/sf/F/ycdqXZtYF7XNilRjDxWrroYS5TSHLOK8oybWPnvLpMswypump74uETPCp2+IVQ11R0vgpIbT1S5WMcthdtmHrLtaPMUi0T3w67DpIA2oyFVq0tR5zesAll3Obfyb6M8Rc4/YIV4puhR2eSQtzm1dgJPzCKyqB3rDvmyZOpR65hPzjbRv99BuRdbUqgVOg1gO+wkMpvIGUWt4PAK9jtXTrKJV3cS7AU4XtLZ575h3Ecsa3GL6ElieNbiWtMHphd7qIRb7mU/XajqpwH3Yz+Sp4SV6cEzaBmuI7SYcZlLXnyqxQg0sq1UkI33Skb7qu37op37rj85Qpw56l8Mu6Hun1qZABU9a99C2/kldrnPMwEmr4xbzZN6w6kTo+lkNXbQimbnqxJxDpLHZL8DT2fdgk9CPgBihxXWdzrM63COsz2bT2WSVrNJ9er9oEzywWagwgVtMlUOczGFCra+A6E4Tfpetbk3w1qxvrrruhS3Zzb0F1+8KfbjGb0iGdavTM7TXkTikmWTdvBLYO4wt9AmsZ9EcqzVYbdtEuxkb2OvoEWmDfCZMarptL2Ng83ULBvXspa7oorFvZx1bNbvIvDz+CcLshcdWOzfTKdzcfAz/Au6DcHUAeJxjYGSaxDiBgZWBgamKaQ8DA0MPhGZ8wGDIyAQUZWBlZsAKAtJcUxgOMOh+NGJ+AeRGMb9hYAHSjCA5AOMfCvMAAAB4nLXUB1IbQRCF4V+BLMC2MDknR9kgBCIHIUDAKXCmcKBw5hw+m+/RJ8Bv1O0D4Cpv1afeGa12Z7T1GmgBcvJU8pBtJ6MzMlnNZprzOTqb83l+a1ygnazOS5xzybWVb240W+KMC64s0xz9PTK6usAo86xotM8Se2xR1+iECjussss2B6yzxhHLbFLlkGM2qNHgVL9Pq8hrja206bkdWkmX7thND3e4S5E++hlgkCGGGdGTxhhngkmmdN00M8wyp6cXecBDHvGYJ9pPiWc81/cLLFLWIlu53bF/y+vTsbS3VV85qexox9sH62va7Gb18Hij1jj9h5v9h6OQPnK/YpQWVQppt2dhSV6EPXkZtuRVqMvrkN76m3Aib0NF3oUdOQ+rchF25X3Ylg/hQD6GdfkU1uQyHMlVWJbPYVO+hKp8DYfyLRzL97AhP0JNfoaGXAf9V5ZxKS+WdaSacylflncpY9biUvas1ZFqmyPVdkeqHY5UO13KpHU5Ui249Cat25FqjyPVXqfsYEEpwoJygt1zShZWdMoY1ueUNuy+U+6wfqcEYgNOWcQGnVKJDTnlExt2Sio24pRZbNQpvdiYU46xcadEYxOuud9Jp5RjU055x6adko/NOPUAbNapG2BzrrnfeacOgQX1Ciyoa2BB/QML6iRYSL3TQsqMBfUZLKjjYKG5/gVHqouOVMuO8h8D8KVRAAAAeJztWH1sG+UZv+e92Ofz99m+O3tN7NgX+0qTGsXn88V2miZN2mSMpJ1sOvpFCqwtkNK0UAaFRTDEpDJGizTCH6BJoEmONAkGyz9lQy3qQHRC2lzRMQl13cQ/JIxFRYpAMvVtz3ux04ZmjP2JtuTe9557P557Pn73Ps9jBhj8IwvsJsbFMBAXPSDG9bihxsmC6Qaf+SksmhfPn4cOdqBUq5WmqlWGaaF72NfY1xg742FCzBrcqemaymmconOyriVVURE1UVVERTYUeKkyefbsZA/tyPDZyckZ65k8iv0MpUpnJyuTBlLI1pKH3YTyOBgmKBuCJsgGzBTmy3NFcxYWi/OmDb6YL8Ioim2tnWanUYZ23Jrg7Jw9JEuylDFyRi6rptRUkFM51VAN2ZA5WDxy+7iRzxvjt3/YJMYLzz1XmJ62enZ6xZRF1H/fnMWevs56Z5gNI8VRmwU1QaHN0ESlOjX18dGj8w88QO42D5CR+qlazTKvtWeOnWOCTIRaOeEFUQhFQYtn+kAXsmngwZBBZo9d+SyqRfFinda9vmB+PHYOKmPsHD6vmLzyGUhj70Bl60r+8ur8WXTqddyfrl8gXddzrl84fC1P1uIpxIXkanyRJ+v8Et+lwckv823Y7iH2+4wNvRtmGB44mQfWiIGduk4MSZmcTt1G/m6OF+4069B37tw7r7pcEZ/Uvblb8kXgLLxUxAnzd7Dh3Lk+jye6JhVJdHcnIsnWKGXPL+NnyT8+yyZrmBijUF/pCm0cNh2bjM0QNd3WGBewzVQqNetq3M29jSfyQqW+H+/lSmMAZ/BqYpacJAuoF4MqcYjYZwunTxdqZKF45kyxtoybx9gzluatlpfsIqI7LltESEKj5tCmKTYuxMmrplvpLsPilKlT7eBd2ps6vMue7k7UXyfDpW6l/jodJMNKd30fGV7+dig26beMuLdEkQ2VDRfn55sX+cs1D/gFM/+8wh5iP2H8aKk2ZoR5jPk57sZPR7VdIxir6IgB2S5LRQgmQ16iJNIteraPaJkoiCF7IqWmQcENCI9MzuiDjCSHvDiCw3o2l4myGvVtGtQ0yfYB7iKNTUt7YiDJUYLC5oxu3ByFkOgDL0mk4UYWt0vsvdz+wzZzTDUMleRUY8usuQmeJMDa/B8Qc5wPREN+OeR32jzheFDuCDo9jhZHyCe3uuV2yU4cXudrgYTUJnj8vNfBOXxuQXIF/KE1QiAmBcKCw+nhWmy+aMDusgUCLk/A2du5jrDE4XLYiE44p89tJxoLzoCDfOT4weM20qNe+aMlzJPVKz9hH/pThBfqz/zZHYsGHYE17UkxoadCrWqA9zk9Yiibae+UwmGnz+uL3CD5XMmAy+uKCG454BUcdi4YTyeDHjEs+p0uXyDo4V08y3E2Lth24rdv8C67k/M4bfwF3ufgvfwffLzTH6Cu/r/vvrm+WxHn8FsVFEHlgB2wAh2M0kAHX5i2eQx6NN6u8PO3/6OPDRr6sjktI8VgI6Euk8SQD2R0jRcSqRuBoyBI6dmvds36Hd/hOVvIJwT9vf1Or93j8AXFsbLbyQdCgZZbv9fCCzjyVUY9d2zC63FJ/mB4505fwGbzu4W2e4/5xICX5+2PPmx32AWfZY//BR1Xxgk8nZHRiUKtVjhNZou1WvHMMi52kDmmiA9p1MDOqagkqiV7AUlDwQFFtqNqqhLFT9igNH6LOCXbOY0ulmTyLJceUuNFeXTHgW0jW+5plW/pGUvyg5ywbmzIwcezjkFu/Wa1o314cATnJ1pT393FtzxxQ9va9ixPhOQGJSKNarHYoeENd8RHk1o4sG4zqLFUn+Lb8i06vLd/dzC0tjUV/YbKzC7LHMDcYK2VPaKsKDEmj31goGwpFk+w7NKB5gU2YafpSTYFi5ZwrfdsGXkRibY2JLZ13dTVddOttOtam89vy+fJR/SNw4disebdnGiswA5YumZbvinHBGKikU8mMQehOThgxoaZc8W8SBbqJzELd9dK8FKpZF4sL+eU5HMLSzxFk4F4AsxDyedvvolgMvVyGXSafNTo3kY+t4kcsd5DM/24jeaEA/X95PlGO1KaKTXiCq69jXUi5WQERsSsNUb3oBk6gQpn0MAR14NWFoWZv0LDAhkGCdO8GZDMj2eQMN2T9O8STQRhlHZjhw9fwvtk/cLk5GE6fJ0eQZqxqHHU41NLDXiwXCazlhqoxHXnJhYqmDmrqMbSUQmj9Ngk0fmCOWvOFuab9p0mb2ONEGa68A0oahF0BXNZDF0WlQYZTZHEkmXJ1Z2AVB9gwPtFolepVPJ7e3r25isVpTfxSxgzfw0PUlpRludgUSkqW3vG7xvv2aoUuXIF+y10ZO+R8Z5mLu1Ee8qWHbEUwWJB5rBK0rE4oQY0sGpiNUNXFU4kXfu27n/mmf1b9x1eJvbvHhjYPUAeXjFICfORATrVsMsEO0E1DqJ3pxA2AXaixKyCMQPVtf7Rh9a6pYblXblaKjXOqQXmPN1pIC8LQlULG6vyEhp4naLrmvyuwpW9pk6LM+l/U6lBlpL0IIA04AGuAk1O6MLV6jZz0/qum0d35e/qNNcnOmAUCXgv0UEHVyvjzPFdozd3re9ImOs77zI/6UjAe5135a2xpk4HMTeX0D8qyqfQ1IZTVibmSjwj0bwnm4O4oKHKGhv+lad/W7/3FSsRH7Fy9ItCJJKIRECvnyrDi2V2IplOJzFn32eteSHRHVbCeKGNXpiaamKjn+1DKXy0elCNIFiZO61ZVdj1lPrUX6ErGr3cu/3yLb3HopDDEfibeSEaPdZ7y+XtvZevqXtoTb5U7yioR5rJMDmmgGdKHDGOKvTRyi1KazgvAMId9Ygnl16FyBO1pFUsy3SKfg0GNnpAxLS2Ni1Gnrfu9X9UKujmIXjD/HDjRvXAAfV9HPhE7d+49sABM4S0dOnSpUql5+qWmMUCxAr82HzklY39uGktvD9zo9pPSXiaFlOVFXVyiLmhiRI/RUk7hYafooRNWGGfPmfoTAMgx48eGRwaGjxyFPxN6vi9e3bqhqHv3PNBk2Dn6IR5eeXiKz9cscgiGpigsrgRszkqjXVgLJ0L6n8h2tD9g4P3H6fd0NeTkiw01mNX+9oCX3c2cjJ+uRgTrv3NxMov5wsw2rA1PS88iHqrvleWsW4zLEwICPD6qdIStM3Zg4VqtXCwTH8Qgg7zolWXdrQeLFarxYPws+X85m2yh3IHLII7qlWym/5i1Jzbg+cwsWSj4+St1eYQ9D+tVule5jqeiE0cp/NX9b2TdTfzKVDh0MvFOVgsQOnlwjzemzUxiTbPxSr9XYZEy8u8F8jJpbqdJmSNWENO0Or9at0+jXaicTBDzwaxUTZxch/QqohTZI0mOuLVeIJVkyHjQhkvA8hbVrww1m3IbuzZe8fusqN+6vHCSDOmbOreHrtvfGQmWx8mb2HkULo2uzasuaM3P95TKcPBH4Xv7s9bgUXpvsm2vXwbriS/Qan+BR+vOg4AAAB4nGNgZGBgAGKpH/rO8fw2Xxm4mV8ABaI4H+9rQND//zC/YH4DVMnBwAQkGQBX3Q0FAAAAeJxjYGRgYH7BwIBEMjKgAh8ARYYDEAAAeJxjYGBgYH4xPDA9AAANeC3nAAB4nGNgAAIpBg+GOIYZDJsYHjHyMJoxZjAuYtzC+IyJgeke8x7mSywuLNtYTrAqsdawHmC9w/qFjYvNgS2CrYBtE9sTtk/sXOwS7EbsTewH2J9wuHH0cDzj+MOpxmnC6cQZwBnHWcBZxzmB8x7pEAB+RDEmAHicY2BkYGDwYZjHwMkAAkxAzAWEDAz/wXwGACCLAgoAeJx9kD1qw0AQhZ/8F2JDCIS4UrEQSBOQf0qT2oKAGxfuZWsly6y1YrU2+AY5SE6QQ6TMQXKKPK23sQvPwvC9N2+mWACP+EGApgI8uN5UC3dUZ26Tnj13yC+euxhg4rlH/91zH2/48DzAEw68EHTu6YT49Nxi/stzm/635w7513MXQ/x57iEM4LmPVRB6HuA1MEkemyJdJFaaIlFLmR9UcmVeqpU0daFLMYnGl4NYltKQU7E+ifqYT63NRGb0Xsx1aaVSWlRG7+TGRltrq9lolHk/2ug9EuSIYVAgxYLKQjqVQGFJzvkXisrcTN6arRzXVBolBP8/wvjmRkwunT77KbfWOLHXOHJvStcio86Y0diT5u56k1Z8mk7lZjs6G/oRtm6rwgwjvuwqHzHFS/808m/eAAB4nG2SB2/bMBCF/cWS7dhpk6Ztuvceauvune6Z/giGomUiEimQlO3k15e1gwABegCJ9x7uju8ObC21FtFv/T+2WKJNQkqHLj2W6TNghSMcZZU1jrHOcU5wkg1OcZoznOUc57nARS5xmStc5RrXucFNbnGbO9zlHvfJeMBDHjHkMU94yjOe84KXvOI1b3jLO96zyQc+8onPfOEr3/jOD37yi99s8ac1EEXhVCGCtqYjnLNT3xZedqQwUpWpHAsX1uRYyZ1tO8vmQOUbB4I2uQrKVdqIoNYP5MbsZ65IW1qX1ToS142kqYzvS2uCEzKoPJG23k2ls963pZ+k8WTDJFdepmoWDXTndzbsqVkt4lv5stpVmS+FHw8OUDZsR9wZ6TJaSUfa+ZAUTtdp4WxTJzElJKUahU6pTfTULa3ItSl6lZjpSu+ppFKm6cUZFsxYowbGhkyUpZ2qPK1jA9WutUlrPbFhzcVym203IViT2dFo9bBgUqeLcUi8mKi+r2KXLLdTsw//GRks4Dytt8DRZ4hLWg9OqcNbXZ5Ltlam15jFBAgKHIqAxmKY4pGUjNlhm1n8FzkVDTW7TBix12r9BZxqtRIAAA==\") format(\"woff\");\n font-weight: normal;\n font-style: normal;\n}\n.ag-icon {\n font-family: \"agGridMaterial\";\n font-size: 18px;\n line-height: 18px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n\n.ag-icon-aggregation::before {\n content: \"\\f101\";\n}\n\n.ag-icon-arrows::before {\n content: \"\\f102\";\n}\n\n.ag-icon-asc::before {\n content: \"\\f103\";\n}\n\n.ag-icon-cancel::before {\n content: \"\\f104\";\n}\n\n.ag-icon-chart::before {\n content: \"\\f105\";\n}\n\n.ag-icon-color-picker::before {\n content: \"\\f109\";\n}\n\n.ag-icon-columns::before {\n content: \"\\f10a\";\n}\n\n.ag-icon-contracted::before {\n content: \"\\f10b\";\n}\n\n.ag-icon-copy::before {\n content: \"\\f10c\";\n}\n\n.ag-icon-cross::before {\n content: \"\\f10d\";\n}\n\n.ag-icon-csv::before {\n content: \"\\f10e\";\n}\n\n.ag-icon-desc::before {\n content: \"\\f10f\";\n}\n\n.ag-icon-excel::before {\n content: \"\\f110\";\n}\n\n.ag-icon-expanded::before {\n content: \"\\f111\";\n}\n\n.ag-icon-eye-slash::before {\n content: \"\\f112\";\n}\n\n.ag-icon-eye::before {\n content: \"\\f113\";\n}\n\n.ag-icon-filter::before {\n content: \"\\f114\";\n}\n\n.ag-icon-first::before {\n content: \"\\f115\";\n}\n\n.ag-icon-grip::before {\n content: \"\\f116\";\n}\n\n.ag-icon-group::before {\n content: \"\\f117\";\n}\n\n.ag-icon-last::before {\n content: \"\\f118\";\n}\n\n.ag-icon-left::before {\n content: \"\\f119\";\n}\n\n.ag-icon-linked::before {\n content: \"\\f11a\";\n}\n\n.ag-icon-loading::before {\n content: \"\\f11b\";\n}\n\n.ag-icon-maximize::before {\n content: \"\\f11c\";\n}\n\n.ag-icon-menu::before {\n content: \"\\f11d\";\n}\n\n.ag-icon-minimize::before {\n content: \"\\f11e\";\n}\n\n.ag-icon-next::before {\n content: \"\\f11f\";\n}\n\n.ag-icon-none::before {\n content: \"\\f120\";\n}\n\n.ag-icon-not-allowed::before {\n content: \"\\f121\";\n}\n\n.ag-icon-paste::before {\n content: \"\\f122\";\n}\n\n.ag-icon-pin::before {\n content: \"\\f123\";\n}\n\n.ag-icon-pivot::before {\n content: \"\\f124\";\n}\n\n.ag-icon-previous::before {\n content: \"\\f125\";\n}\n\n.ag-icon-right::before {\n content: \"\\f128\";\n}\n\n.ag-icon-save::before {\n content: \"\\f129\";\n}\n\n.ag-icon-small-down::before {\n content: \"\\f12a\";\n}\n\n.ag-icon-small-left::before {\n content: \"\\f12b\";\n}\n\n.ag-icon-small-right::before {\n content: \"\\f12c\";\n}\n\n.ag-icon-small-up::before {\n content: \"\\f12d\";\n}\n\n.ag-icon-tick::before {\n content: \"\\f12e\";\n}\n\n.ag-icon-tree-closed::before {\n content: \"\\f12f\";\n}\n\n.ag-icon-tree-indeterminate::before {\n content: \"\\f130\";\n}\n\n.ag-icon-tree-open::before {\n content: \"\\f131\";\n}\n\n.ag-icon-unlinked::before {\n content: \"\\f132\";\n}\n\n.ag-icon-row-drag::before {\n content: \"\\f116\";\n}\n\n.ag-left-arrow::before {\n content: \"\\f119\";\n}\n\n.ag-right-arrow::before {\n content: \"\\f128\";\n}\n", ""]); // Exports module.exports = exports; diff --git a/client/dist/ag-grid-community.min.js b/client/dist/ag-grid-community.min.js index 9d76c9bc..376f642c 100644 --- a/client/dist/ag-grid-community.min.js +++ b/client/dist/ag-grid-community.min.js @@ -1,8 +1,8 @@ /** - * @ag-grid-community/all-modules - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components - * @version v23.2.0 + * @ag-grid-community/all-modules - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue + * @version v27.1.0 * @link http://www.ag-grid.com/ * @license MIT */ -// @ag-grid-community/all-modules v23.2.0 -!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.agGrid=t():e.agGrid=t()}(window,(function(){return function(e){var t={};function o(r){if(t[r])return t[r].exports;var a=t[r]={i:r,l:!1,exports:{}};return e[r].call(a.exports,a,a.exports,o),a.l=!0,a.exports}return o.m=e,o.c=t,o.d=function(e,t,r){o.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:r})},o.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},o.t=function(e,t){if(1&t&&(e=o(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var r=Object.create(null);if(o.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var a in e)o.d(r,a,function(t){return e[t]}.bind(null,a));return r},o.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return o.d(t,"a",t),t},o.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},o.p="",o(o.s=150)}([function(e,t,o){"use strict";o.d(t,"a",(function(){return p})),o.d(t,"g",(function(){return c})),o.d(t,"f",(function(){return re})),o.d(t,"b",(function(){return ae})),o.d(t,"d",(function(){return ee})),o.d(t,"c",(function(){return ne})),o.d(t,"e",(function(){return ie}));var r={};o.r(r),o.d(r,"stringToArray",(function(){return c}));var a={};o.r(a),o.d(a,"getNameOfClass",(function(){return f})),o.d(a,"findLineByLeastSquares",(function(){return m})),o.d(a,"cssStyleObjectToMarkup",(function(){return b})),o.d(a,"message",(function(){return v})),o.d(a,"bindCellRendererToHtmlElement",(function(){return y}));var n={};o.r(n),o.d(n,"stopPropagationForAgGrid",(function(){return O})),o.d(n,"isStopPropagationForAgGrid",(function(){return R})),o.d(n,"isEventSupported",(function(){return T})),o.d(n,"getCellCompForEvent",(function(){return P})),o.d(n,"addChangeListener",(function(){return D})),o.d(n,"getTarget",(function(){return N})),o.d(n,"isElementInEventPath",(function(){return F})),o.d(n,"createEventPath",(function(){return M})),o.d(n,"addAgGridEventPath",(function(){return I})),o.d(n,"getEventPath",(function(){return G})),o.d(n,"addSafePassiveEventListener",(function(){return L}));var i={};o.r(i),o.d(i,"fuzzyCheckStrings",(function(){return V})),o.d(i,"fuzzySuggestions",(function(){return W})),o.d(i,"get_bigrams",(function(){return j})),o.d(i,"string_distances",(function(){return H})),o.d(i,"string_weighted_distances",(function(){return B}));var l={};o.r(l),o.d(l,"keys",(function(){return K}));var g={};o.r(g),o.d(g,"normalizeWheel",(function(){return q})),o.d(g,"isLeftClick",(function(){return Q})),o.d(g,"areEventsNear",(function(){return Z}));var s={};o.r(s),o.d(s,"sortRowNodesByOrder",(function(){return J})),o.d(s,"traverseNodesWithKey",(function(){return $}));var p=function(){function e(e,t,o,r){void 0===r&&(r=1),this.r=Math.min(1,Math.max(0,e||0)),this.g=Math.min(1,Math.max(0,t||0)),this.b=Math.min(1,Math.max(0,o||0)),this.a=Math.min(1,Math.max(0,r||0))}return e.fromString=function(t){if(t.indexOf("#")>=0)return e.fromHexString(t);var o=e.nameToHex[t];if(o)return e.fromHexString(o);if(t.indexOf("rgb")>=0)return e.fromRgbaString(t);throw new Error("Invalid color string: '"+t+"'")},e.fromHexString=function(t){var o=t.match(e.hexRe);if(o)return new e((r=parseInt(o[1],16))/255,(a=parseInt(o[2],16))/255,(n=parseInt(o[3],16))/255,(i=void 0!==o[4]?parseInt(o[4],16):255)/255);if(o=t.match(e.shortHexRe)){var r=parseInt(o[1],16),a=parseInt(o[2],16),n=parseInt(o[3],16),i=void 0!==o[4]?parseInt(o[4],16):15;return new e((r+=16*r)/255,(a+=16*a)/255,(n+=16*n)/255,(i+=16*i)/255)}throw new Error("Malformed hexadecimal color string: '"+t+"'")},e.fromRgbaString=function(t){var o=t.match(e.rgbRe);if(o)return new e(+o[1]/255,+o[2]/255,+o[3]/255);if(o=t.match(e.rgbaRe))return new e(+o[1]/255,+o[2]/255,+o[3]/255,+o[4]);throw new Error("Malformed rgb/rgba color string: '"+t+"'")},e.fromArray=function(t){if(4===t.length)return new e(t[0],t[1],t[2],t[3]);if(3===t.length)return new e(t[0],t[1],t[2]);throw new Error("The given array should contain 3 or 4 color components (numbers).")},e.fromHSB=function(t,o,r,a){void 0===a&&(a=1);var n=e.HSBtoRGB(t,o,r);return new e(n[0],n[1],n[2],a)},e.padHex=function(e){return 1===e.length?"0"+e:e},e.prototype.toHexString=function(){var t="#"+e.padHex(Math.round(255*this.r).toString(16))+e.padHex(Math.round(255*this.g).toString(16))+e.padHex(Math.round(255*this.b).toString(16));return this.a<1&&(t+=e.padHex(Math.round(255*this.a).toString(16))),t},e.prototype.toRgbaString=function(e){void 0===e&&(e=3);var t=[Math.round(255*this.r),Math.round(255*this.g),Math.round(255*this.b)],o=Math.pow(10,e);return 1!==this.a?(t.push(Math.round(this.a*o)/o),"rgba("+t.join(", ")+")"):"rgb("+t.join(", ")+")"},e.prototype.toString=function(){return 1===this.a?this.toHexString():this.toRgbaString()},e.prototype.toHSB=function(){return e.RGBtoHSB(this.r,this.g,this.b)},e.RGBtoHSB=function(e,t,o){var r=Math.min(e,t,o),a=Math.max(e,t,o),n=NaN;if(r!==a){var i=a-r,l=(a-e)/i,g=(a-t)/i,s=(a-o)/i;n=e===a?s-g:t===a?2+l-s:4+g-l,(n/=6)<0&&(n+=1)}return[360*n,0!==a?(a-r)/a:0,a]},e.HSBtoRGB=function(e,t,o){isNaN(e)&&(e=0),e=(e%360+360)%360/360;var r=0,a=0,n=0;if(0===t)r=a=n=o;else{var i=6*(e-Math.floor(e)),l=i-Math.floor(i),g=o*(1-t),s=o*(1-t*l),p=o*(1-t*(1-l));switch(i>>0){case 0:r=o,a=p,n=g;break;case 1:r=s,a=o,n=g;break;case 2:r=g,a=o,n=p;break;case 3:r=g,a=s,n=o;break;case 4:r=p,a=g,n=o;break;case 5:r=o,a=g,n=s}}return[r,a,n]},e.prototype.derive=function(t,o,r,a){var n=e.RGBtoHSB(this.r,this.g,this.b),i=n[2];0==i&&r>1&&(i=.05);var l=((n[0]+t)%360+360)%360,g=Math.max(Math.min(n[1]*o,1),0);i=Math.max(Math.min(i*r,1),0);var s=Math.max(Math.min(this.a*a,1),0),p=e.HSBtoRGB(l,g,i);return p.push(s),e.fromArray(p)},e.prototype.brighter=function(){return this.derive(0,1,1/.7,1)},e.prototype.darker=function(){return this.derive(0,1,.7,1)},e.hexRe=/\s*#([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})?\s*$/,e.shortHexRe=/\s*#([0-9a-fA-F])([0-9a-fA-F])([0-9a-fA-F])([0-9a-fA-F])?\s*$/,e.rgbRe=/\s*rgb\((\d+),\s*(\d+),\s*(\d+)\)\s*/,e.rgbaRe=/\s*rgba\((\d+),\s*(\d+),\s*(\d+),\s*([.\d]+)\)\s*/,e.nameToHex=Object.freeze({aliceblue:"#F0F8FF",antiquewhite:"#FAEBD7",aqua:"#00FFFF",aquamarine:"#7FFFD4",azure:"#F0FFFF",beige:"#F5F5DC",bisque:"#FFE4C4",black:"#000000",blanchedalmond:"#FFEBCD",blue:"#0000FF",blueviolet:"#8A2BE2",brown:"#A52A2A",burlywood:"#DEB887",cadetblue:"#5F9EA0",chartreuse:"#7FFF00",chocolate:"#D2691E",coral:"#FF7F50",cornflowerblue:"#6495ED",cornsilk:"#FFF8DC",crimson:"#DC143C",cyan:"#00FFFF",darkblue:"#00008B",darkcyan:"#008B8B",darkgoldenrod:"#B8860B",darkgray:"#A9A9A9",darkgreen:"#006400",darkgrey:"#A9A9A9",darkkhaki:"#BDB76B",darkmagenta:"#8B008B",darkolivegreen:"#556B2F",darkorange:"#FF8C00",darkorchid:"#9932CC",darkred:"#8B0000",darksalmon:"#E9967A",darkseagreen:"#8FBC8F",darkslateblue:"#483D8B",darkslategray:"#2F4F4F",darkslategrey:"#2F4F4F",darkturquoise:"#00CED1",darkviolet:"#9400D3",deeppink:"#FF1493",deepskyblue:"#00BFFF",dimgray:"#696969",dimgrey:"#696969",dodgerblue:"#1E90FF",firebrick:"#B22222",floralwhite:"#FFFAF0",forestgreen:"#228B22",fuchsia:"#FF00FF",gainsboro:"#DCDCDC",ghostwhite:"#F8F8FF",gold:"#FFD700",goldenrod:"#DAA520",gray:"#808080",green:"#008000",greenyellow:"#ADFF2F",grey:"#808080",honeydew:"#F0FFF0",hotpink:"#FF69B4",indianred:"#CD5C5C",indigo:"#4B0082",ivory:"#FFFFF0",khaki:"#F0E68C",lavender:"#E6E6FA",lavenderblush:"#FFF0F5",lawngreen:"#7CFC00",lemonchiffon:"#FFFACD",lightblue:"#ADD8E6",lightcoral:"#F08080",lightcyan:"#E0FFFF",lightgoldenrodyellow:"#FAFAD2",lightgray:"#D3D3D3",lightgreen:"#90EE90",lightgrey:"#D3D3D3",lightpink:"#FFB6C1",lightsalmon:"#FFA07A",lightseagreen:"#20B2AA",lightskyblue:"#87CEFA",lightslategray:"#778899",lightslategrey:"#778899",lightsteelblue:"#B0C4DE",lightyellow:"#FFFFE0",lime:"#00FF00",limegreen:"#32CD32",linen:"#FAF0E6",magenta:"#FF00FF",maroon:"#800000",mediumaquamarine:"#66CDAA",mediumblue:"#0000CD",mediumorchid:"#BA55D3",mediumpurple:"#9370DB",mediumseagreen:"#3CB371",mediumslateblue:"#7B68EE",mediumspringgreen:"#00FA9A",mediumturquoise:"#48D1CC",mediumvioletred:"#C71585",midnightblue:"#191970",mintcream:"#F5FFFA",mistyrose:"#FFE4E1",moccasin:"#FFE4B5",navajowhite:"#FFDEAD",navy:"#000080",oldlace:"#FDF5E6",olive:"#808000",olivedrab:"#6B8E23",orange:"#FFA500",orangered:"#FF4500",orchid:"#DA70D6",palegoldenrod:"#EEE8AA",palegreen:"#98FB98",paleturquoise:"#AFEEEE",palevioletred:"#DB7093",papayawhip:"#FFEFD5",peachpuff:"#FFDAB9",peru:"#CD853F",pink:"#FFC0CB",plum:"#DDA0DD",powderblue:"#B0E0E6",purple:"#800080",rebeccapurple:"#663399",red:"#FF0000",rosybrown:"#BC8F8F",royalblue:"#4169E1",saddlebrown:"#8B4513",salmon:"#FA8072",sandybrown:"#F4A460",seagreen:"#2E8B57",seashell:"#FFF5EE",sienna:"#A0522D",silver:"#C0C0C0",skyblue:"#87CEEB",slateblue:"#6A5ACD",slategray:"#708090",slategrey:"#708090",snow:"#FFFAFA",springgreen:"#00FF7F",steelblue:"#4682B4",tan:"#D2B48C",teal:"#008080",thistle:"#D8BFD8",tomato:"#FF6347",turquoise:"#40E0D0",violet:"#EE82EE",wheat:"#F5DEB3",white:"#FFFFFF",whitesmoke:"#F5F5F5",yellow:"#FFFF00",yellowgreen:"#9ACD32"}),e}();function c(e,t){void 0===t&&(t=",");for(var o,r,a,n=[],i=function(e){return"\r"===e||"\n"===e},l=!1,g=function(g,s,p){var c=e[p-1],d=e[p],u=e[p+1],h=function(){n[g]||(n[g]=[]),n[g][s]||(n[g][s]="")};if(h(),'"'===d){if(l)return'"'===u?(n[g][s]+='"',p++):l=!1,o=g,r=s,a=p,"continue";if(void 0===c||c===t||i(c))return l=!0,o=g,r=s,a=p,"continue"}if(!l){if(d===t)return s++,h(),o=g,r=s,a=p,"continue";if(i(d))return s=0,g++,h(),"\r"===d&&"\n"===u&&p++,o=g,r=s,a=p,"continue"}n[g][s]+=d,o=g,r=s,a=p},s=0,p=0,c=0;c1?o[1]:""}function m(e){var t=e.length,o=0;if(t<=1)return e;for(var r=0;r
'),document.body&&document.body.appendChild(o)}o.insertBefore(t,o.children[0])}function y(e,t){e.then((function(e){var o=e.getGui();null!=o&&("object"==typeof o?t.appendChild(o):t.innerHTML=o)}))}var w=o(17),x=o(25),C=o(26),k=["touchstart","touchend","touchmove","touchcancel"],A=["mouseover","mouseout","mouseenter","mouseleave"],E={};function O(e){e.__ag_Grid_Stop_Propagation=!0}function R(e){return!0===e.__ag_Grid_Stop_Propagation}var S,T=(S={select:"input",change:"input",submit:"form",reset:"form",error:"img",load:"img",abort:"img"},function(e){if("boolean"==typeof E[e])return E[e];var t=document.createElement(S[e]||"div"),o=(e="on"+e)in t;return o||(t.setAttribute(e,"return;"),o="function"==typeof t[e]),t=null,E[e]=o});function P(e,t){for(var o=N(t);o;){var r=e.getDomData(o,"cellComp");if(r)return r;o=o.parentElement}return null}function D(e,t){e.addEventListener("changed",t),e.addEventListener("paste",t),e.addEventListener("input",t),e.addEventListener("keydown",t),e.addEventListener("keyup",t)}function N(e){var t=e;return t.target||t.srcElement}function F(e,t){return!(!t||!e)&&G(t).indexOf(e)>=0}function M(e){for(var t=[],o=N(e);o;)t.push(o),o=o.parentElement;return t}function I(e){e.__agGridEventPath=G(e)}function G(e){var t=e;return t.deepPath?t.deepPath():t.path?t.path:t.composedPath?t.composedPath():t.__agGridEventPath?t.__agGridEventPath:M(e)}function L(e,t,o,r){var a=Object(w.includes)(k,o)?{passive:!0}:void 0;Object(w.includes)(A,o)?e&&e.addEventListenerOutsideAngular&&e.addEventListenerOutsideAngular(t,o,r,a):t.addEventListener(o,r,a)}var _=o(42);function V(e,t,o){var r={},a=e.filter((function(e){return!t.some((function(t){return t===e}))}));return a.length>0&&a.forEach((function(e){return r[e]=W(e,o)})),r}function W(e,t,o,r){var a=r?B:H,n=t.map((function(t){return{value:t,relevance:a(e.toLowerCase(),t.toLocaleLowerCase())}}));return n.sort((function(e,t){return t.relevance-e.relevance})),o&&(n=n.filter((function(e){return 0!==e.relevance}))),n.map((function(e){return e.value}))}function j(e){var t,o,r,a=e.toLowerCase(),n=new Array(a.length-1);for(t=o=0,r=n.length;o<=r;t=o+=1)n[t]=a.slice(t,t+2);return n}function H(e,t){if(0===e.length&&0===t.length)return 0;var o,r,a=j(e),n=j(t),i=a.length+n.length,l=0;for(o=0,r=a.length;o0?2*l/i:0}function B(e,t){for(var o=e.replace(/\s/g,""),r=t.replace(/\s/g,""),a=0,n=0,i=0;i0){r=!0;break}r&&e.sort(o)}}function $(e,t){var o=[];!function e(r){r.forEach((function(r){if(r.group||r.hasChildren()){o.push(r.key);var a=o.join("|");t(r,a),e(r.childrenAfterGroup),o.pop()}}))}(e)}var ee,te=o(135),oe=function(){return(oe=Object.assign||function(e){for(var t,o=1,r=arguments.length;o> creating ag-Application Context"),this.createBeans();var o=this.getBeanInstances();this.wireBeans(o),this.logger.log(">> ag-Application Context ready - component is alive")}}return e.prototype.getBeanInstances=function(){return r.f.values(this.beanWrappers).map((function(e){return e.beanInstance}))},e.prototype.createBean=function(e,t){if(!e)throw Error("Can't wire to bean since it is null");return this.wireBeans([e],t),e},e.prototype.wireBeans=function(e,t){this.autoWireBeans(e),this.methodWireBeans(e),this.callLifeCycleMethods(e,"preConstructMethods"),r.f.exists(t)&&e.forEach(t),this.callLifeCycleMethods(e,"postConstructMethods")},e.prototype.createBeans=function(){var e=this;this.contextParams.beanClasses.forEach(this.createBeanWrapper.bind(this)),r.f.iterateObject(this.beanWrappers,(function(t,o){var r;o.bean.__agBeanMetaData&&o.bean.__agBeanMetaData.autowireMethods&&o.bean.__agBeanMetaData.autowireMethods.agConstructor&&(r=o.bean.__agBeanMetaData.autowireMethods.agConstructor);var a,n,i=e.getBeansForParameters(r,o.bean.name),l=(a=o.bean,n=[null].concat(i),new(a.bind.apply(a,n)));o.beanInstance=l}));var t=Object.keys(this.beanWrappers).join(", ");this.logger.log("created beans: "+t)},e.prototype.createBeanWrapper=function(e){var t=e.__agBeanMetaData;if(!t){var o=void 0;return o=e.prototype.constructor?e.prototype.constructor.name:""+e,void console.error("context item "+o+" is not a bean")}var r={bean:e,beanInstance:null,beanName:t.beanName};this.beanWrappers[t.beanName]=r},e.prototype.autoWireBeans=function(e){var t=this;e.forEach((function(e){t.forEachMetaDataInHierarchy(e,(function(o,r){var a=o.agClassAttributes;a&&a.forEach((function(o){var a=t.lookupBeanInstance(r,o.beanName,o.optional);e[o.attributeName]=a}))}))}))},e.prototype.methodWireBeans=function(e){var t=this;e.forEach((function(e){t.forEachMetaDataInHierarchy(e,(function(o,a){r.f.iterateObject(o.autowireMethods,(function(o,r){if("agConstructor"!==o){var n=t.getBeansForParameters(r,a);e[o].apply(e,n)}}))}))}))},e.prototype.forEachMetaDataInHierarchy=function(e,t){for(var o=Object.getPrototypeOf(e);null!=o;){var r=o.constructor;if(r.hasOwnProperty("__agBeanMetaData"))t(r.__agBeanMetaData,this.getBeanName(r));o=Object.getPrototypeOf(o)}},e.prototype.getBeanName=function(e){if(e.__agBeanMetaData&&e.__agBeanMetaData.beanName)return e.__agBeanMetaData.beanName;var t=e.toString();return t.substring(9,t.indexOf("("))},e.prototype.getBeansForParameters=function(e,t){var o=this,a=[];return e&&r.f.iterateObject(e,(function(e,r){var n=o.lookupBeanInstance(t,r);a[Number(e)]=n})),a},e.prototype.lookupBeanInstance=function(e,t,o){if(void 0===o&&(o=!1),"context"===t)return this;if(this.contextParams.providedBeanInstances&&this.contextParams.providedBeanInstances.hasOwnProperty(t))return this.contextParams.providedBeanInstances[t];var r=this.beanWrappers[t];return r?r.beanInstance:(o||console.error("ag-Grid: unable to find bean reference "+t+" while initialising "+e),null)},e.prototype.callLifeCycleMethods=function(e,t){var o=this;e.forEach((function(e){o.callLifeCycleMethodsOneBean(e,t)}))},e.prototype.callLifeCycleMethodsOneBean=function(e,t,o){var r={};this.forEachMetaDataInHierarchy(e,(function(e){var a=e[t];a&&a.forEach((function(e){e!=o&&(r[e]=!0)}))})),Object.keys(r).forEach((function(t){return e[t]()}))},e.prototype.getBean=function(e){return this.lookupBeanInstance("getBean",e,!0)},e.prototype.destroy=function(){if(!this.destroyed){this.logger.log(">> Shutting down ag-Application Context");var e=this.getBeanInstances();this.destroyBeans(e),this.contextParams.providedBeanInstances=null,this.destroyed=!0,this.logger.log(">> ag-Application Context shut down - component is dead")}},e.prototype.destroyBean=function(e){e&&this.destroyBeans([e])},e.prototype.destroyBeans=function(e){var t=this;return e?(e.forEach((function(e){t.callLifeCycleMethodsOneBean(e,"preDestroyMethods","destroy"),e.destroy&&e.destroy()})),[]):[]},e}();function n(e,t,o){var r=u(e.constructor);r.preConstructMethods||(r.preConstructMethods=[]),r.preConstructMethods.push(t)}function i(e,t,o){var r=u(e.constructor);r.postConstructMethods||(r.postConstructMethods=[]),r.postConstructMethods.push(t)}function l(e,t,o){var r=u(e.constructor);r.preDestroyMethods||(r.preDestroyMethods=[]),r.preDestroyMethods.push(t)}function g(e){return function(t){u(t).beanName=e}}function s(e){return function(t,o,r){c(t,e,!1,t,o,null)}}function p(e){return function(t,o,r){c(t,e,!0,t,o,null)}}function c(e,t,o,r,a,n){if(null!==t)if("number"!=typeof n){var i=u(e.constructor);i.agClassAttributes||(i.agClassAttributes=[]),i.agClassAttributes.push({attributeName:a,beanName:t,optional:o})}else console.error("ag-Grid: Autowired should be on an attribute");else console.error("ag-Grid: Autowired name should not be null")}function d(e){return function(t,o,r){var a,n="function"==typeof t?t:t.constructor;if("number"==typeof r){var i=void 0;o?(a=u(n),i=o):(a=u(n),i="agConstructor"),a.autowireMethods||(a.autowireMethods={}),a.autowireMethods[i]||(a.autowireMethods[i]={}),a.autowireMethods[i][r]=e}}}function u(e){return e.hasOwnProperty("__agBeanMetaData")||(e.__agBeanMetaData={}),e.__agBeanMetaData}},function(e,t,o){"use strict";o.d(t,"a",(function(){return r}));var r=function(){function e(){}return e.STEP_EVERYTHING=0,e.STEP_FILTER=1,e.STEP_SORT=2,e.STEP_MAP=3,e.STEP_AGGREGATE=4,e.STEP_PIVOT=5,e.ROW_BUFFER_SIZE=10,e.LAYOUT_INTERVAL=500,e.BATCH_WAIT_MILLIS=50,e.EXPORT_TYPE_DRAG_COPY="dragCopy",e.EXPORT_TYPE_CLIPBOARD="clipboard",e.EXPORT_TYPE_EXCEL="excel",e.EXPORT_TYPE_CSV="csv",e.KEY_BACKSPACE=8,e.KEY_TAB=9,e.KEY_NEW_LINE=10,e.KEY_ENTER=13,e.KEY_SHIFT=16,e.KEY_ESCAPE=27,e.KEY_SPACE=32,e.KEY_LEFT=37,e.KEY_UP=38,e.KEY_RIGHT=39,e.KEY_DOWN=40,e.KEY_DELETE=46,e.KEY_A=65,e.KEY_C=67,e.KEY_V=86,e.KEY_D=68,e.KEY_Z=90,e.KEY_Y=89,e.KEY_F2=113,e.KEY_PAGE_UP=33,e.KEY_PAGE_DOWN=34,e.KEY_PAGE_HOME=36,e.KEY_PAGE_END=35,e.ROW_MODEL_TYPE_INFINITE="infinite",e.ROW_MODEL_TYPE_VIEWPORT="viewport",e.ROW_MODEL_TYPE_CLIENT_SIDE="clientSide",e.ROW_MODEL_TYPE_SERVER_SIDE="serverSide",e.DEPRECATED_ROW_MODEL_TYPE_NORMAL="normal",e.ALWAYS="always",e.ONLY_WHEN_GROUPING="onlyWhenGrouping",e.PINNED_TOP="top",e.PINNED_BOTTOM="bottom",e.DOM_LAYOUT_NORMAL="normal",e.DOM_LAYOUT_PRINT="print",e.DOM_LAYOUT_AUTO_HEIGHT="autoHeight",e.GROUP_AUTO_COLUMN_ID="ag-Grid-AutoColumn",e.SOURCE_PASTE="paste",e.PINNED_RIGHT="right",e.PINNED_LEFT="left",e.SORT_ASC="asc",e.SORT_DESC="desc",e}()},function(e,t,o){"use strict";o.r(t),function(e){var r=o(132);o.d(t,"ColumnFactory",(function(){return r.a}));var a=o(77);o.d(t,"ColumnController",(function(){return a.a}));var n=o(76);o.d(t,"ColumnKeyCreator",(function(){return n.a}));var i=o(79);o.d(t,"ColumnUtils",(function(){return i.a}));var l=o(80);o.d(t,"DisplayedGroupCreator",(function(){return l.a}));var g=o(78);o.d(t,"GroupInstanceIdCreator",(function(){return g.a}));var s=o(37);o.d(t,"ComponentUtil",(function(){return s.a}));var p=o(74);o.d(t,"ColDefUtil",(function(){return p.a}));var c=o(50);o.d(t,"UserComponentRegistry",(function(){return c.b}));var d=o(44);o.d(t,"UserComponentFactory",(function(){return d.b}));var u=o(140);o.d(t,"initialiseAgGridWithAngular1",(function(){return u.a}));var h=o(141);o.d(t,"initialiseAgGridWithWebComponents",(function(){return h.a}));var f=o(6);o.d(t,"BeanStub",(function(){return f.a}));var m=o(1);o.d(t,"Context",(function(){return m.c})),o.d(t,"Autowired",(function(){return m.a})),o.d(t,"PostConstruct",(function(){return m.e})),o.d(t,"PreConstruct",(function(){return m.f})),o.d(t,"Optional",(function(){return m.d})),o.d(t,"Bean",(function(){return m.b})),o.d(t,"Qualifier",(function(){return m.h})),o.d(t,"PreDestroy",(function(){return m.g}));var b=o(5);o.d(t,"QuerySelector",(function(){return b.c})),o.d(t,"GuiListener",(function(){return b.b})),o.d(t,"RefSelector",(function(){return b.d})),o.d(t,"GridListener",(function(){return b.a}));var v=o(13);o.d(t,"DragAndDropService",(function(){return v.a})),o.d(t,"DragSourceType",(function(){return v.b})),o.d(t,"HorizontalDirection",(function(){return v.c})),o.d(t,"VerticalDirection",(function(){return v.d}));var y=o(102);o.d(t,"DragService",(function(){return y.a}));var w=o(12);o.d(t,"Column",(function(){return w.a}));var x=o(20);o.d(t,"ColumnGroup",(function(){return x.a}));var C=o(19);o.d(t,"OriginalColumnGroup",(function(){return C.a}));var k=o(16);o.d(t,"RowNode",(function(){return k.a}));var A=o(92);o.d(t,"FilterManager",(function(){return A.a}));var E=o(39);o.d(t,"ProvidedFilter",(function(){return E.a}));var O=o(14);o.d(t,"SimpleFilter",(function(){return O.b}));var R=o(21);o.d(t,"ScalarFilter",(function(){return R.a}));var S=o(57);o.d(t,"NumberFilter",(function(){return S.a}));var T=o(58);o.d(t,"TextFilter",(function(){return T.a}));var P=o(52);o.d(t,"DateFilter",(function(){return P.a}));var D=o(129);o.d(t,"GridPanel",(function(){return D.a}));var N=o(110);o.d(t,"ScrollVisibleService",(function(){return N.a}));var F=o(105);o.d(t,"MouseEventService",(function(){return F.a}));var M=o(91);o.d(t,"BodyDropPivotTarget",(function(){return M.a}));var I=o(89);o.d(t,"BodyDropTarget",(function(){return I.a}));var G=o(60);o.d(t,"CssClassApplier",(function(){return G.a}));var L=o(68);o.d(t,"HeaderContainer",(function(){return L.a}));var _=o(88);o.d(t,"HeaderRootComp",(function(){return _.a}));var V=o(31);o.d(t,"HeaderRowComp",(function(){return V.a}));var W=o(99);o.d(t,"HorizontalResizeService",(function(){return W.a}));var j=o(90);o.d(t,"MoveColumnController",(function(){return j.a}));var H=o(101);o.d(t,"StandardMenuFactory",(function(){return H.a}));var B=o(142);o.d(t,"TabbedLayout",(function(){return B.a}));var z=o(143);o.d(t,"simpleHttpRequest",(function(){return z.a}));var U=o(117);o.d(t,"ResizeObserverService",(function(){return U.a}));var Y=o(83);o.d(t,"LargeTextCellEditor",(function(){return Y.a}));var K=o(87);o.d(t,"PopupEditorWrapper",(function(){return K.a}));var q=o(82);o.d(t,"PopupSelectCellEditor",(function(){return q.a}));var Q=o(81);o.d(t,"PopupTextCellEditor",(function(){return Q.a}));var Z=o(56);o.d(t,"SelectCellEditor",(function(){return Z.a}));var X=o(45);o.d(t,"TextCellEditor",(function(){return X.a}));var J=o(54);o.d(t,"AnimateShowChangeCellRenderer",(function(){return J.a}));var $=o(55);o.d(t,"AnimateSlideCellRenderer",(function(){return $.a}));var ee=o(46);o.d(t,"GroupCellRenderer",(function(){return ee.a}));var te=o(41);o.d(t,"SetLeftFeature",(function(){return te.a}));var oe=o(98);o.d(t,"AutoWidthCalculator",(function(){return oe.a}));var re=o(107);o.d(t,"CellRendererFactory",(function(){return re.a}));var ae=o(53);o.d(t,"CheckboxSelectionComponent",(function(){return ae.a}));var ne=o(35);o.d(t,"CellComp",(function(){return ne.a}));var ie=o(47);o.d(t,"RowComp",(function(){return ie.a}));var le=o(86);o.d(t,"RowRenderer",(function(){return le.a}));var ge=o(108);o.d(t,"ValueFormatterService",(function(){return ge.a}));var se=o(127);o.d(t,"PinnedRowModel",(function(){return se.a}));var pe=o(59);o.d(t,"ChangedPath",(function(){return pe.a}));var ce=o(49);o.d(t,"RowNodeBlock",(function(){return ce.a}));var de=o(144);o.d(t,"RowNodeBlockLoader",(function(){return de.a}));var ue=o(145);o.d(t,"RowNodeCache",(function(){return ue.a}));var he=o(112);o.d(t,"PaginationProxy",(function(){return he.a}));var fe=o(111);o.d(t,"StylingService",(function(){return fe.a}));var me=o(22);o.d(t,"AgAbstractField",(function(){return me.a}));var be=o(36);o.d(t,"AgCheckbox",(function(){return be.a}));var ve=o(61);o.d(t,"AgRadioButton",(function(){return ve.a}));var ye=o(124);o.d(t,"AgToggleButton",(function(){return ye.a}));var we=o(64);o.d(t,"AgInputTextField",(function(){return we.a}));var xe=o(119);o.d(t,"AgInputTextArea",(function(){return xe.a}));var Ce=o(121);o.d(t,"AgInputNumberField",(function(){return Ce.a}));var ke=o(122);o.d(t,"AgInputRange",(function(){return ke.a}));var Ae=o(131);o.d(t,"AgSelect",(function(){return Ae.a}));var Ee=o(120);o.d(t,"AgSlider",(function(){return Ee.a}));var Oe=o(123);o.d(t,"AgAngleSelect",(function(){return Oe.a}));var Re=o(130);o.d(t,"AgColorPicker",(function(){return Re.a}));var Se=o(118);o.d(t,"AgGroupComponent",(function(){return Se.a}));var Te=o(62);o.d(t,"AgDialog",(function(){return Te.a}));var Pe=o(63);o.d(t,"AgPanel",(function(){return Pe.a}));var De=o(7);o.d(t,"Component",(function(){return De.a}));var Ne=o(29);o.d(t,"ManagedFocusComponent",(function(){return Ne.a}));var Fe=o(33);o.d(t,"PopupComponent",(function(){return Fe.a}));var Me=o(97);o.d(t,"PopupService",(function(){return Me.a}));var Ie=o(24);o.d(t,"TouchListener",(function(){return Ie.a}));var Ge=o(146);o.d(t,"VirtualList",(function(){return Ge.a}));var Le=o(38);o.d(t,"CellRangeType",(function(){return Le.a})),o.d(t,"SelectionHandleType",(function(){return Le.b}));var _e=o(109);o.d(t,"VanillaFrameworkOverrides",(function(){return _e.a}));var Ve=o(106);o.d(t,"CellNavigationService",(function(){return Ve.a}));var We=o(114);o.d(t,"AlignedGridsService",(function(){return We.a}));var je=o(2);o.d(t,"Constants",(function(){return je.a}));var He=o(65);o.d(t,"Grid",(function(){return He.a}));var Be=o(94);o.d(t,"GridApi",(function(){return Be.a}));var ze=o(9);o.d(t,"Events",(function(){return ze.a}));var Ue=o(104);o.d(t,"FocusController",(function(){return Ue.a}));var Ye=o(147);o.d(t,"defaultGroupComparator",(function(){return Ye.a}));var Ke=o(15);o.d(t,"GridOptionsWrapper",(function(){return Ke.a}));var qe=o(23);o.d(t,"EventService",(function(){return qe.a}));var Qe=o(116);o.d(t,"SelectableService",(function(){return Qe.a}));var Ze=o(100);o.d(t,"GridCore",(function(){return Ze.a}));var Xe=o(48);o.d(t,"Logger",(function(){return Xe.a})),o.d(t,"LoggerFactory",(function(){return Xe.b}));var Je=o(84);o.d(t,"SelectionController",(function(){return Je.a}));var $e=o(103);o.d(t,"SortController",(function(){return $e.a}));var et=o(96);o.d(t,"TemplateService",(function(){return et.a}));var tt=o(0);o.d(t,"Color",(function(){return tt.a})),o.d(t,"stringToArray",(function(){return tt.g})),o.d(t,"_",(function(){return tt.f})),o.d(t,"NumberSequence",(function(){return tt.b})),o.d(t,"PromiseStatus",(function(){return tt.d})),o.d(t,"Promise",(function(){return tt.c})),o.d(t,"Timer",(function(){return tt.e}));var ot=o(93);o.d(t,"ValueService",(function(){return ot.a}));var rt=o(113);o.d(t,"ValueCache",(function(){return rt.a}));var at=o(95);o.d(t,"ExpressionService",(function(){return at.a}));var nt=o(126);o.d(t,"CellPositionUtils",(function(){return nt.a}));var it=o(125);o.d(t,"RowPositionUtils",(function(){return it.a}));var lt=o(128);o.d(t,"HeaderPositionUtils",(function(){return lt.a}));var gt=o(34);o.d(t,"HeaderNavigationService",(function(){return gt.b})),o.d(t,"HeaderNavigationDirection",(function(){return gt.a}));var st=o(32);o.d(t,"PropertyKeys",(function(){return st.a}));var pt=o(85);o.d(t,"ColumnApi",(function(){return pt.a}));var ct=o(148);o.d(t,"BaseComponentWrapper",(function(){return ct.a}));var dt=o(115);o.d(t,"Environment",(function(){return dt.a}));var ut=o(40);o.d(t,"TooltipFeature",(function(){return ut.a}));var ht=o(149);o.d(t,"ChartType",(function(){return ht.a})),o.d(t,"LegendPosition",(function(){return ht.b}));var ft=o(10);o.d(t,"ModuleNames",(function(){return ft.a}));var mt=o(11);o.d(t,"ModuleRegistry",(function(){return mt.a}));o(4);var bt=void 0===e?{}:e;bt.HTMLElement="undefined"==typeof HTMLElement?{}:HTMLElement,bt.HTMLButtonElement="undefined"==typeof HTMLButtonElement?{}:HTMLButtonElement,bt.HTMLSelectElement="undefined"==typeof HTMLSelectElement?{}:HTMLSelectElement,bt.HTMLInputElement="undefined"==typeof HTMLInputElement?{}:HTMLInputElement,bt.Node="undefined"==typeof Node?{}:Node,bt.MouseEvent="undefined"==typeof MouseEvent?{}:MouseEvent}.call(this,o(151))},function(e,t,o){"use strict";var r=o(9);o.d(t,"a",(function(){return r.a}))},function(e,t,o){"use strict";function r(e){return n.bind(this,e)}function a(e){return n.bind(this,"[ref="+e+"]")}function n(e,t,o,r){null!==e?"number"!=typeof r?p(t,"querySelectors",{attributeName:o,querySelector:e}):console.error("ag-Grid: QuerySelector should be on an attribute"):console.error("ag-Grid: QuerySelector selector should not be null")}function i(e){return l.bind(this,e)}function l(e,t,o){null!=e?p(t,"gridListenerMethods",{methodName:o,eventName:e}):console.error("ag-Grid: GridListener eventName is missing")}function g(e,t){return s.bind(this,e,t)}function s(e,t,o,r){null!=t?p(o,"guiListenerMethods",{methodName:r,eventName:t,ref:e}):console.error("ag-Grid: GuiListener eventName is missing")}function p(e,t,o){var r=function(e,t){e.__agComponentMetaData||(e.__agComponentMetaData={});e.__agComponentMetaData[t]||(e.__agComponentMetaData[t]={});return e.__agComponentMetaData[t]}(e,e.constructor.name);r[t]||(r[t]=[]),r[t].push(o)}o.d(t,"c",(function(){return r})),o.d(t,"d",(function(){return a})),o.d(t,"a",(function(){return i})),o.d(t,"b",(function(){return g}))},function(e,t,o){"use strict";o.d(t,"a",(function(){return l}));var r=o(23),a=o(1),n=o(0),i=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},l=function(){function e(){var e=this;this.destroyFunctions=[],this.destroyed=!1,this.getContext=function(){return e.context},this.isAlive=function(){return!e.destroyed}}return e.prototype.getFrameworkOverrides=function(){return this.frameworkOverrides},e.prototype.destroy=function(){this.destroyFunctions.forEach((function(e){return e()})),this.destroyFunctions.length=0,this.destroyed=!0,this.dispatchEvent({type:e.EVENT_DESTROYED})},e.prototype.addEventListener=function(e,t){this.localEventService||(this.localEventService=new r.a),this.localEventService.addEventListener(e,t)},e.prototype.removeEventListener=function(e,t){this.localEventService&&this.localEventService.removeEventListener(e,t)},e.prototype.dispatchEventAsync=function(e){var t=this;window.setTimeout((function(){return t.dispatchEvent(e)}),0)},e.prototype.dispatchEvent=function(e){this.localEventService&&this.localEventService.dispatchEvent(e)},e.prototype.addManagedListener=function(e,t,o){var r=this;if(!this.destroyed){e instanceof HTMLElement?n.f.addSafePassiveEventListener(this.getFrameworkOverrides(),e,t,o):e.addEventListener(t,o);var a=function(){return e.removeEventListener(t,o),r.destroyFunctions=r.destroyFunctions.filter((function(e){return e!==a})),null};return this.destroyFunctions.push(a),a}},e.prototype.addDestroyFunc=function(e){this.isAlive()?this.destroyFunctions.push(e):e()},e.prototype.createManagedBean=function(e,t){var o=this.createBean(e,t);return this.addDestroyFunc(this.destroyBean.bind(this,e,t)),o},e.prototype.createBean=function(e,t,o){return(t||this.getContext()).createBean(e,o)},e.prototype.destroyBean=function(e,t){return(t||this.getContext()).destroyBean(e)},e.prototype.destroyBeans=function(e,t){var o=this;return e&&e.forEach((function(e){return o.destroyBean(e,t)})),[]},e.EVENT_DESTROYED="destroyed",i([Object(a.a)("frameworkOverrides")],e.prototype,"frameworkOverrides",void 0),i([Object(a.a)("context")],e.prototype,"context",void 0),i([Object(a.a)("eventService")],e.prototype,"eventService",void 0),i([a.g],e.prototype,"destroy",null),e}()},function(e,t,o){"use strict";o.d(t,"a",(function(){return p}));var r,a=o(1),n=o(6),i=o(0),l=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),g=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},s=new i.b,p=function(e){function t(t){var o=e.call(this)||this;return o.annotatedGuiListeners=[],o.displayed=!0,o.visible=!0,o.compId=s.next(),t&&o.setTemplate(t),o}return l(t,e),t.prototype.getCompId=function(){return this.compId},t.prototype.createChildComponentsFromTags=function(e,t){var o=this,r=i.f.copyNodeList(e.childNodes);i.f.forEach(r,(function(r){if(r instanceof HTMLElement){var a=o.createComponentFromElement(r,(function(e){o.copyAttributesFromNode(r,e.getGui())}),t);if(a){if(a.addItems&&r.children.length){o.createChildComponentsFromTags(r);var n=Array.prototype.slice.call(r.children);a.addItems(n)}o.swapComponentForNode(a,e,r)}else r.childNodes&&o.createChildComponentsFromTags(r)}}))},t.prototype.createComponentFromElement=function(e,t,o){var r=e.nodeName,a=o?o[e.getAttribute("ref")]:void 0,n=this.agStackComponentsRegistry.getComponentClass(r);if(n){var i=new n(a);return this.createBean(i,null,t),i}return null},t.prototype.copyAttributesFromNode=function(e,t){i.f.iterateNamedNodeMap(e.attributes,(function(e,o){return t.setAttribute(e,o)}))},t.prototype.swapComponentForNode=function(e,t,o){var r=e.getGui();t.replaceChild(r,o),t.insertBefore(document.createComment(o.nodeName),r),this.addDestroyFunc(this.destroyBean.bind(this,e)),this.swapInComponentForQuerySelectors(e,o)},t.prototype.swapInComponentForQuerySelectors=function(e,t){var o=this;this.iterateOverQuerySelectors((function(r){o[r.attributeName]===t&&(o[r.attributeName]=e)}))},t.prototype.iterateOverQuerySelectors=function(e){for(var t=Object.getPrototypeOf(this);null!=t;){var o=t.__agComponentMetaData,r=t.constructor.name;o&&o[r]&&o[r].querySelectors&&i.f.forEach(o[r].querySelectors,(function(t){return e(t)})),t=Object.getPrototypeOf(t)}},t.prototype.setTemplate=function(e,t){var o=i.f.loadTemplate(e);this.setTemplateFromElement(o,t)},t.prototype.setTemplateFromElement=function(e,t){this.eGui=e,this.eGui.__agComponent=this,this.addAnnotatedGuiEventListeners(),this.wireQuerySelectors(),this.getContext()&&this.createChildComponentsFromTags(this.getGui(),t)},t.prototype.createChildComponentsPreConstruct=function(){this.getGui()&&this.createChildComponentsFromTags(this.getGui())},t.prototype.wireQuerySelectors=function(){var e=this;if(this.eGui){var t=this;this.iterateOverQuerySelectors((function(o){var r=e.eGui.querySelector(o.querySelector);r&&(t[o.attributeName]=r.__agComponent||r)}))}},t.prototype.addAnnotatedGuiEventListeners=function(){var e=this;if(this.removeAnnotatedGuiEventListeners(),this.eGui){var t=this.getAgComponentMetaData("guiListenerMethods");t&&(this.annotatedGuiListeners||(this.annotatedGuiListeners=[]),t.forEach((function(t){var o=e.getRefElement(t.ref);if(o){var r=e[t.methodName].bind(e);o.addEventListener(t.eventName,r),e.annotatedGuiListeners.push({eventName:t.eventName,listener:r,element:o})}})))}},t.prototype.addAnnotatedGridEventListeners=function(){var e=this,t=this.getAgComponentMetaData("gridListenerMethods");t&&t.forEach((function(t){var o=e[t.methodName].bind(e);e.addManagedListener(e.eventService,t.eventName,o)}))},t.prototype.getAgComponentMetaData=function(e){for(var t=[],o=Object.getPrototypeOf(this);null!=o;){var r=o.__agComponentMetaData,a=o.constructor.name;if(void 0===a){var n=/function\s([^(]{1,})\(/.exec(o.constructor.toString());n&&n.length>1&&(a=n[1].trim())}r&&r[a]&&r[a][e]&&(t=t.concat(r[a][e])),o=Object.getPrototypeOf(o)}return t},t.prototype.removeAnnotatedGuiEventListeners=function(){this.annotatedGuiListeners&&(i.f.forEach(this.annotatedGuiListeners,(function(e){e.element.removeEventListener(e.eventName,e.listener)})),this.annotatedGuiListeners=[])},t.prototype.getGui=function(){return this.eGui},t.prototype.getFocusableElement=function(){return this.eGui},t.prototype.setParentComponent=function(e){this.parentComponent=e},t.prototype.getParentComponent=function(){return this.parentComponent},t.prototype.setGui=function(e){this.eGui=e},t.prototype.queryForHtmlElement=function(e){return this.eGui.querySelector(e)},t.prototype.queryForHtmlInputElement=function(e){return this.eGui.querySelector(e)},t.prototype.appendChild=function(e,t){if(t||(t=this.eGui),i.f.isNodeOrElement(e))t.appendChild(e);else{var o=e;t.appendChild(o.getGui()),this.addDestroyFunc(this.destroyBean.bind(this,o))}},t.prototype.isDisplayed=function(){return this.displayed},t.prototype.setVisible=function(e){e!==this.visible&&(this.visible=e,i.f.setVisible(this.eGui,e))},t.prototype.setDisplayed=function(e){if(e!==this.displayed){this.displayed=e,i.f.setDisplayed(this.eGui,e);var o={type:t.EVENT_DISPLAYED_CHANGED,visible:this.displayed};this.dispatchEvent(o)}},t.prototype.destroy=function(){this.removeAnnotatedGuiEventListeners(),e.prototype.destroy.call(this)},t.prototype.addGuiEventListener=function(e,t){var o=this;this.eGui.addEventListener(e,t),this.addDestroyFunc((function(){return o.eGui.removeEventListener(e,t)}))},t.prototype.addCssClass=function(e){i.f.addCssClass(this.eGui,e)},t.prototype.removeCssClass=function(e){i.f.removeCssClass(this.eGui,e)},t.prototype.addOrRemoveCssClass=function(e,t){i.f.addOrRemoveCssClass(this.eGui,e,t)},t.prototype.getAttribute=function(e){var t=this.eGui;return t?t.getAttribute(e):null},t.prototype.getRefElement=function(e){return this.queryForHtmlElement('[ref="'+e+'"]')},t.EVENT_DISPLAYED_CHANGED="displayedChanged",g([Object(a.a)("agStackComponentsRegistry")],t.prototype,"agStackComponentsRegistry",void 0),g([a.f],t.prototype,"createChildComponentsPreConstruct",null),g([a.e],t.prototype,"addAnnotatedGridEventListeners",null),t}(n.a)},function(e,t,o){"use strict";o.r(t),o.d(t,"addCssClass",(function(){return i})),o.d(t,"removeCssClass",(function(){return l})),o.d(t,"addOrRemoveCssClass",(function(){return g})),o.d(t,"radioCssClass",(function(){return s})),o.d(t,"containsClass",(function(){return p})),o.d(t,"setDisplayed",(function(){return c})),o.d(t,"setVisible",(function(){return d})),o.d(t,"setDisabled",(function(){return u})),o.d(t,"isElementChildOfClass",(function(){return h})),o.d(t,"getElementSize",(function(){return f})),o.d(t,"getInnerHeight",(function(){return m})),o.d(t,"getInnerWidth",(function(){return b})),o.d(t,"getAbsoluteHeight",(function(){return v})),o.d(t,"getAbsoluteWidth",(function(){return y})),o.d(t,"getScrollLeft",(function(){return w})),o.d(t,"setScrollLeft",(function(){return x})),o.d(t,"clearElement",(function(){return C})),o.d(t,"removeElement",(function(){return k})),o.d(t,"removeFromParent",(function(){return A})),o.d(t,"isVisible",(function(){return E})),o.d(t,"loadTemplate",(function(){return O})),o.d(t,"appendHtml",(function(){return R})),o.d(t,"getElementAttribute",(function(){return S})),o.d(t,"offsetHeight",(function(){return T})),o.d(t,"offsetWidth",(function(){return P})),o.d(t,"ensureDomOrder",(function(){return D})),o.d(t,"setDomChildOrder",(function(){return N})),o.d(t,"insertTemplateWithDomOrder",(function(){return F})),o.d(t,"prependDC",(function(){return M})),o.d(t,"addStylesToElement",(function(){return I})),o.d(t,"isHorizontalScrollShowing",(function(){return G})),o.d(t,"isVerticalScrollShowing",(function(){return L})),o.d(t,"setElementWidth",(function(){return _})),o.d(t,"setFixedWidth",(function(){return V})),o.d(t,"setElementHeight",(function(){return W})),o.d(t,"setFixedHeight",(function(){return j})),o.d(t,"formatSize",(function(){return H})),o.d(t,"isNode",(function(){return B})),o.d(t,"isElement",(function(){return z})),o.d(t,"isNodeOrElement",(function(){return U})),o.d(t,"copyNodeList",(function(){return Y})),o.d(t,"iterateNamedNodeMap",(function(){return K})),o.d(t,"setCheckboxState",(function(){return q}));var r=o(25),a=o(18),n=o(66);function i(e,t){if(t&&0!==t.length){if(!(t.indexOf(" ")>=0)){if(e.classList)e.classList.add(t);else if(e.className&&e.className.length>0){var o=e.className.split(" ");o.indexOf(t)<0&&(o.push(t),e.setAttribute("class",o.join(" ")))}else e.setAttribute("class",t);return e}t.split(" ").forEach((function(t){return i(e,t)}))}}function l(e,t){if(e.classList)e.classList.remove(t);else if(e.className&&e.className.length>0){var o=e.className.split(" ").filter((function(e){return e!==t})).join(" ");e.setAttribute("class",o)}}function g(e,t,o){o?i(e,t):l(e,t)}function s(e,t,o){for(var r=e.parentElement.firstChild;r;)t&&g(r,t,r===e),o&&g(r,o,r!==e),r=r.nextSibling}function p(e,t){if(e.classList)return e.classList.contains(t);if(e.className){var o=e.className===t,r=e.className.indexOf(" "+t+" ")>=0,a=0===e.className.indexOf(t+" "),n=e.className.lastIndexOf(" "+t)===e.className.length-t.length-1;return o||r||a||n}return!1}function c(e,t){g(e,"ag-hidden",!t)}function d(e,t){g(e,"ag-invisible",!t)}function u(e,t){t?e.setAttribute("disabled",""):e.removeAttribute("disabled")}function h(e,t,o){for(var r=0;e;){if(p(e,t))return!0;if(e=e.parentElement,o&&++r>o)break}return!1}function f(e){var t=window.getComputedStyle(e),o=t.height,r=t.width,a=t.paddingTop,n=t.paddingRight,i=t.paddingBottom,l=t.paddingLeft,g=t.marginTop,s=t.marginRight,p=t.marginBottom,c=t.marginLeft,d=t.boxSizing;return{height:parseFloat(o),width:parseFloat(r),paddingTop:parseFloat(a),paddingRight:parseFloat(n),paddingBottom:parseFloat(i),paddingLeft:parseFloat(l),marginTop:parseFloat(g),marginRight:parseFloat(s),marginBottom:parseFloat(p),marginLeft:parseFloat(c),boxSizing:d}}function m(e){var t=f(e);return"border-box"===t.boxSizing?t.height-t.paddingTop-t.paddingBottom:t.height}function b(e){var t=f(e);return"border-box"===t.boxSizing?t.width-t.paddingLeft-t.paddingRight:t.width}function v(e){var t=f(e),o=t.marginBottom+t.marginTop;return Math.ceil(e.offsetHeight+o)}function y(e){var t=f(e),o=t.marginLeft+t.marginRight;return Math.ceil(e.offsetWidth+o)}function w(e,t){var o=e.scrollLeft;return t&&(o=Math.abs(o),Object(r.isBrowserChrome)()&&(o=e.scrollWidth-e.clientWidth-o)),o}function x(e,t,o){o&&((Object(r.isBrowserSafari)()||Object(r.isBrowserChrome)())&&(t=e.scrollWidth-e.clientWidth-t),Object(r.isBrowserFirefox)()&&(t*=-1)),e.scrollLeft=t}function C(e){for(;e&&e.firstChild;)e.removeChild(e.firstChild)}function k(e,t){A(e.querySelector(t))}function A(e){e&&e.parentNode&&e.parentNode.removeChild(e)}function E(e){return null!==e.offsetParent}function O(e){var t=document.createElement("div");return t.innerHTML=(e||"").trim(),t.firstChild}function R(e,t){e.lastChild?e.insertAdjacentHTML("afterbegin",t):e.innerHTML=t}function S(e,t){return e.attributes&&e.attributes[t]?e.attributes[t].value:null}function T(e){return e&&e.clientHeight?e.clientHeight:0}function P(e){return e&&e.clientWidth?e.clientWidth:0}function D(e,t,o){o&&o.nextSibling===t||(o?o.nextSibling?e.insertBefore(t,o.nextSibling):e.appendChild(t):e.firstChild&&e.firstChild!==t&&e.insertAdjacentElement("afterbegin",t))}function N(e,t){for(var o=0;o=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(){function e(e,t,o,a){this.moving=!1,this.menuVisible=!1,this.filterActive=!1,this.eventService=new r.a,this.rowGroupActive=!1,this.pivotActive=!1,this.aggregationActive=!1,this.colDef=e,this.userProvidedColDef=t,this.visible=!e.hide,this.sort=e.sort,this.sortedAt=e.sortedAt,this.colId=o,this.primary=a}return e.prototype.setColDef=function(e,t){this.colDef=e,this.userProvidedColDef=t},e.prototype.getUserProvidedColDef=function(){return this.userProvidedColDef},e.prototype.setParent=function(e){this.parent=e},e.prototype.getParent=function(){return this.parent},e.prototype.setOriginalParent=function(e){this.originalParent=e},e.prototype.getOriginalParent=function(){return this.originalParent},e.prototype.initialise=function(){this.setPinned(this.colDef.pinned);var e=this.gridOptionsWrapper.getMinColWidth(),t=this.gridOptionsWrapper.getMaxColWidth();this.colDef.minWidth?this.minWidth=this.colDef.minWidth:this.minWidth=e,this.colDef.maxWidth?this.maxWidth=this.colDef.maxWidth:this.maxWidth=t,this.colDef.flex&&(this.flex=this.colDef.flex),this.resetActualWidth();var o=this.gridOptionsWrapper.isSuppressFieldDotNotation();this.fieldContainsDots=a.f.exists(this.colDef.field)&&this.colDef.field.indexOf(".")>=0&&!o,this.tooltipFieldContainsDots=a.f.exists(this.colDef.tooltipField)&&this.colDef.tooltipField.indexOf(".")>=0&&!o,this.validate()},e.prototype.resetActualWidth=function(){this.actualWidth=this.columnUtils.calculateColInitialWidth(this.colDef)},e.prototype.isEmptyGroup=function(){return!1},e.prototype.isRowGroupDisplayed=function(e){if(a.f.missing(this.colDef)||a.f.missing(this.colDef.showRowGroup))return!1;var t=!0===this.colDef.showRowGroup,o=this.colDef.showRowGroup===e;return t||o},e.prototype.getUniqueId=function(){return this.getId()},e.prototype.isPrimary=function(){return this.primary},e.prototype.isFilterAllowed=function(){var e=!!this.colDef.filter||!!this.colDef.filterFramework;return this.primary&&e},e.prototype.isFieldContainsDots=function(){return this.fieldContainsDots},e.prototype.isTooltipFieldContainsDots=function(){return this.tooltipFieldContainsDots},e.prototype.validate=function(){var e=this.colDef;function t(e,t,o){a.f.doOnce((function(){o?console.warn(e,o):a.f.doOnce((function(){return console.warn(e)}),t)}),t)}if(!g.a.isRegistered(l.a.RowGroupingModule)){["enableRowGroup","rowGroup","rowGroupIndex","enablePivot","enableValue","pivot","pivotIndex","aggFunc"].forEach((function(o){a.f.exists(e[o])&&(g.a.isPackageBased()?t("ag-Grid: "+o+" is only valid in ag-grid-enterprise, your column definition should not have "+o,"ColumnRowGroupingMissing"+o):t("ag-Grid: "+o+" is only valid with ag-Grid Enterprise Module "+l.a.RowGroupingModule+" - your column definition should not have "+o,"ColumnRowGroupingMissing"+o))}))}if(g.a.isRegistered(l.a.RichSelectModule)||"agRichSelect"!==this.colDef.cellEditor&&"agRichSelectCellEditor"!==this.colDef.cellEditor||(g.a.isPackageBased()?t("ag-Grid: "+this.colDef.cellEditor+" can only be used with ag-grid-enterprise","ColumnRichSelectMissing"):t("ag-Grid: "+this.colDef.cellEditor+" can only be used with ag-Grid Enterprise Module "+l.a.RichSelectModule,"ColumnRichSelectMissing")),g.a.isRegistered(l.a.DateTimeCellEditorModule)||"agRichSelect"!==this.colDef.cellEditor&&"agDateTimeCellEditor"!==this.colDef.cellEditor||(g.a.isPackageBased()?t("ag-Grid: "+this.colDef.cellEditor+" can only be used with ag-grid-enterprise","ColumnDateTimeMissing"):t("ag-Grid: "+this.colDef.cellEditor+" can only be used with ag-Grid Enterprise Module "+l.a.DateTimeCellEditorModule,"ColumnDateTimeMissing")),this.gridOptionsWrapper.isTreeData()){["rowGroup","rowGroupIndex","pivot","pivotIndex"].forEach((function(o){a.f.exists(e[o])&&t("ag-Grid: "+o+" is not possible when doing tree data, your column definition should not have "+o,"TreeDataCannotRowGroup")}))}a.f.exists(this.colDef.width)&&"number"!=typeof this.colDef.width&&t("ag-Grid: colDef.width should be a number, not "+typeof this.colDef.width,"ColumnCheck_asdfawef"),a.f.get(this,"colDef.cellRendererParams.restrictToOneGroup",null)&&t("ag-Grid: Since ag-grid 11.0.0 cellRendererParams.restrictToOneGroup is deprecated. You should use showRowGroup","ColumnCheck_sksldjf"),a.f.get(this,"colDef.cellRendererParams.keyMap",null)&&t("ag-Grid: Since ag-grid 11.0.0 cellRendererParams.keyMap is deprecated. You should use colDef.keyCreator","ColumnCheck_ieiruhgdf"),a.f.get(this,"colDef.cellRendererParams.keyMap",null)&&t("ag-Grid: Since ag-grid 11.0.0 cellRendererParams.keyMap is deprecated. You should use colDef.keyCreator","ColumnCheck_uitolghj"),e.floatingCellRenderer&&(t("ag-Grid: since v11, floatingCellRenderer is now pinnedRowCellRenderer","ColumnCheck_soihwewe"),this.colDef.pinnedRowCellRenderer=e.floatingCellRenderer),e.floatingRendererFramework&&(t("ag-Grid: since v11, floatingRendererFramework is now pinnedRowCellRendererFramework","ColumnCheck_zdkiouhwer"),this.colDef.pinnedRowCellRendererFramework=e.floatingRendererFramework),e.floatingRendererParams&&(console.warn("ag-Grid: since v11, floatingRendererParams is now pinnedRowCellRendererParams","ColumnCheck_retiuhjs"),this.colDef.pinnedRowCellRendererParams=e.floatingRendererParams),e.floatingValueFormatter&&(t("ag-Grid: since v11, floatingValueFormatter is now pinnedRowValueFormatter","ColumnCheck_qwroeihjdf"),this.colDef.pinnedRowValueFormatter=e.floatingValueFormatter),e.cellFormatter&&(t("ag-Grid: since v12, cellFormatter is now valueFormatter","ColumnCheck_eoireknml"),a.f.missing(this.colDef.valueFormatter)&&(this.colDef.valueFormatter=e.cellFormatter)),e.headerCellTemplate&&t("ag-Grid: since v15, headerCellTemplate is gone, use header component instead.","ColumnCheck_eroihxcm"),e.headerCellRenderer&&t("ag-Grid: since v15, headerCellRenderer is gone, use header component instead.","ColumnCheck_terteuh"),e.volatile&&t("ag-Grid: since v16, colDef.volatile is gone, please check refresh docs on how to refresh specific cells.","ColumnCheck_weoihjxcv"),e.suppressSorting&&(t("ag-Grid: since v20, colDef.suppressSorting is gone, instead use colDef.sortable=false.","ColumnCheck_43ljrer",this.colDef),this.colDef.sortable=!1),e.suppressFilter&&(t("ag-Grid: since v20, colDef.suppressFilter is gone, instead use colDef.filter=false.","ColumnCheck_erlkhfdm",this.colDef),this.colDef.filter=!1),e.suppressResize&&(t("ag-Grid: since v20, colDef.suppressResize is gone, instead use colDef.resizable=false.","ColumnCheck_weoihjxcv",this.colDef),this.colDef.resizable=!1),e.tooltip&&(t("ag-Grid: since v20.1, colDef.tooltip is gone, instead use colDef.tooltipValueGetter.","ColumnCheck_adslknjwef",this.colDef),this.colDef.tooltipValueGetter=e.tooltip),e.suppressToolPanel&&(t("ag-Grid: since v22, colDef.suppressToolPanel is gone, instead use suppressColumnsToolPanel / suppressFiltersToolPanel.","ColumnCheck_weihjlsjkdf",this.colDef),this.colDef.suppressColumnsToolPanel=!0)},e.prototype.addEventListener=function(e,t){this.eventService.addEventListener(e,t)},e.prototype.removeEventListener=function(e,t){this.eventService.removeEventListener(e,t)},e.prototype.createIsColumnFuncParams=function(e){return{node:e,data:e.data,column:this,colDef:this.colDef,context:this.gridOptionsWrapper.getContext(),api:this.gridOptionsWrapper.getApi(),columnApi:this.gridOptionsWrapper.getColumnApi()}},e.prototype.isSuppressNavigable=function(e){if("boolean"==typeof this.colDef.suppressNavigable)return this.colDef.suppressNavigable;if("function"==typeof this.colDef.suppressNavigable){var t=this.createIsColumnFuncParams(e);return(0,this.colDef.suppressNavigable)(t)}return!1},e.prototype.isCellEditable=function(e){return!(e.group&&!this.gridOptionsWrapper.isEnableGroupEdit())&&this.isColumnFunc(e,this.colDef.editable)},e.prototype.isRowDrag=function(e){return this.isColumnFunc(e,this.colDef.rowDrag)},e.prototype.isDndSource=function(e){return this.isColumnFunc(e,this.colDef.dndSource)},e.prototype.isCellCheckboxSelection=function(e){return this.isColumnFunc(e,this.colDef.checkboxSelection)},e.prototype.isSuppressPaste=function(e){return this.isColumnFunc(e,this.colDef?this.colDef.suppressPaste:null)},e.prototype.isResizable=function(){return!0===this.colDef.resizable},e.prototype.isColumnFunc=function(e,t){return"boolean"==typeof t?t:"function"==typeof t&&t(this.createIsColumnFuncParams(e))},e.prototype.setMoving=function(t,o){void 0===o&&(o="api"),this.moving=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_MOVING_CHANGED,o))},e.prototype.createColumnEvent=function(e,t){return{api:this.gridApi,columnApi:this.columnApi,type:e,column:this,columns:[this],source:t}},e.prototype.isMoving=function(){return this.moving},e.prototype.getSort=function(){return this.sort},e.prototype.setSort=function(t,o){void 0===o&&(o="api"),this.sort!==t&&(this.sort=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_SORT_CHANGED,o)))},e.prototype.setMenuVisible=function(t,o){void 0===o&&(o="api"),this.menuVisible!==t&&(this.menuVisible=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_MENU_VISIBLE_CHANGED,o)))},e.prototype.isMenuVisible=function(){return this.menuVisible},e.prototype.isSortAscending=function(){return this.sort===i.a.SORT_ASC},e.prototype.isSortDescending=function(){return this.sort===i.a.SORT_DESC},e.prototype.isSortNone=function(){return a.f.missing(this.sort)},e.prototype.isSorting=function(){return a.f.exists(this.sort)},e.prototype.getSortedAt=function(){return this.sortedAt},e.prototype.setSortedAt=function(e){this.sortedAt=e},e.prototype.setAggFunc=function(e){this.aggFunc=e},e.prototype.getAggFunc=function(){return this.aggFunc},e.prototype.getLeft=function(){return this.left},e.prototype.getOldLeft=function(){return this.oldLeft},e.prototype.getRight=function(){return this.left+this.actualWidth},e.prototype.setLeft=function(t,o){void 0===o&&(o="api"),this.oldLeft=this.left,this.left!==t&&(this.left=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_LEFT_CHANGED,o)))},e.prototype.isFilterActive=function(){return this.filterActive},e.prototype.setFilterActive=function(t,o,r){void 0===o&&(o="api"),this.filterActive!==t&&(this.filterActive=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_FILTER_ACTIVE_CHANGED,o)));var n=this.createColumnEvent(e.EVENT_FILTER_CHANGED,o);r&&a.f.mergeDeep(n,r),this.eventService.dispatchEvent(n)},e.prototype.setPinned=function(e){!0===e||e===i.a.PINNED_LEFT?this.pinned=i.a.PINNED_LEFT:e===i.a.PINNED_RIGHT?this.pinned=i.a.PINNED_RIGHT:this.pinned=null},e.prototype.setFirstRightPinned=function(t,o){void 0===o&&(o="api"),this.firstRightPinned!==t&&(this.firstRightPinned=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_FIRST_RIGHT_PINNED_CHANGED,o)))},e.prototype.setLastLeftPinned=function(t,o){void 0===o&&(o="api"),this.lastLeftPinned!==t&&(this.lastLeftPinned=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_LAST_LEFT_PINNED_CHANGED,o)))},e.prototype.isFirstRightPinned=function(){return this.firstRightPinned},e.prototype.isLastLeftPinned=function(){return this.lastLeftPinned},e.prototype.isPinned=function(){return this.pinned===i.a.PINNED_LEFT||this.pinned===i.a.PINNED_RIGHT},e.prototype.isPinnedLeft=function(){return this.pinned===i.a.PINNED_LEFT},e.prototype.isPinnedRight=function(){return this.pinned===i.a.PINNED_RIGHT},e.prototype.getPinned=function(){return this.pinned},e.prototype.setVisible=function(t,o){void 0===o&&(o="api");var r=!0===t;this.visible!==r&&(this.visible=r,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_VISIBLE_CHANGED,o)))},e.prototype.isVisible=function(){return this.visible},e.prototype.getColDef=function(){return this.colDef},e.prototype.getColumnGroupShow=function(){return this.colDef.columnGroupShow},e.prototype.getColId=function(){return this.colId},e.prototype.getId=function(){return this.getColId()},e.prototype.getDefinition=function(){return this.colDef},e.prototype.getActualWidth=function(){return this.actualWidth},e.prototype.createBaseColDefParams=function(e){return{node:e,data:e.data,colDef:this.colDef,column:this,api:this.gridOptionsWrapper.getApi(),columnApi:this.gridOptionsWrapper.getColumnApi(),context:this.gridOptionsWrapper.getContext()}},e.prototype.getColSpan=function(e){if(a.f.missing(this.colDef.colSpan))return 1;var t=this.createBaseColDefParams(e),o=this.colDef.colSpan(t);return Math.max(o,1)},e.prototype.getRowSpan=function(e){if(a.f.missing(this.colDef.rowSpan))return 1;var t=this.createBaseColDefParams(e),o=this.colDef.rowSpan(t);return Math.max(o,1)},e.prototype.setActualWidth=function(t,o){void 0===o&&(o="api"),null!=this.minWidth&&(t=Math.max(t,this.minWidth)),null!=this.maxWidth&&(t=Math.min(t,this.maxWidth)),this.actualWidth!==t&&(this.flex&&"flex"!==o&&(this.flex=0),this.actualWidth=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_WIDTH_CHANGED,o)))},e.prototype.isGreaterThanMax=function(e){return null!=this.maxWidth&&e>this.maxWidth},e.prototype.getMinWidth=function(){return this.minWidth},e.prototype.getMaxWidth=function(){return this.maxWidth},e.prototype.getFlex=function(){return this.flex||0},e.prototype.setFlex=function(e){this.flex!==e&&(this.flex=e)},e.prototype.setMinimum=function(e){void 0===e&&(e="api"),this.setActualWidth(this.minWidth,e)},e.prototype.setRowGroupActive=function(t,o){void 0===o&&(o="api"),this.rowGroupActive!==t&&(this.rowGroupActive=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_ROW_GROUP_CHANGED,o)))},e.prototype.isRowGroupActive=function(){return this.rowGroupActive},e.prototype.setPivotActive=function(t,o){void 0===o&&(o="api"),this.pivotActive!==t&&(this.pivotActive=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_PIVOT_CHANGED,o)))},e.prototype.isPivotActive=function(){return this.pivotActive},e.prototype.isAnyFunctionActive=function(){return this.isPivotActive()||this.isRowGroupActive()||this.isValueActive()},e.prototype.isAnyFunctionAllowed=function(){return this.isAllowPivot()||this.isAllowRowGroup()||this.isAllowValue()},e.prototype.setValueActive=function(t,o){void 0===o&&(o="api"),this.aggregationActive!==t&&(this.aggregationActive=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_VALUE_CHANGED,o)))},e.prototype.isValueActive=function(){return this.aggregationActive},e.prototype.isAllowPivot=function(){return!0===this.colDef.enablePivot},e.prototype.isAllowValue=function(){return!0===this.colDef.enableValue},e.prototype.isAllowRowGroup=function(){return!0===this.colDef.enableRowGroup},e.prototype.getMenuTabs=function(e){var t=this.getColDef().menuTabs;return null==t&&(t=e),t},e.prototype.isLockPosition=function(){return console.warn("ag-Grid: since v21, col.isLockPosition() should not be used, please use col.getColDef().lockPosition instead."),!!this.colDef&&!!this.colDef.lockPosition},e.prototype.isLockVisible=function(){return console.warn("ag-Grid: since v21, col.isLockVisible() should not be used, please use col.getColDef().lockVisible instead."),!!this.colDef&&!!this.colDef.lockVisible},e.prototype.isLockPinned=function(){return console.warn("ag-Grid: since v21, col.isLockPinned() should not be used, please use col.getColDef().lockPinned instead."),!!this.colDef&&!!this.colDef.lockPinned},e.EVENT_MOVING_CHANGED="movingChanged",e.EVENT_LEFT_CHANGED="leftChanged",e.EVENT_WIDTH_CHANGED="widthChanged",e.EVENT_LAST_LEFT_PINNED_CHANGED="lastLeftPinnedChanged",e.EVENT_FIRST_RIGHT_PINNED_CHANGED="firstRightPinnedChanged",e.EVENT_VISIBLE_CHANGED="visibleChanged",e.EVENT_FILTER_CHANGED="filterChanged",e.EVENT_FILTER_ACTIVE_CHANGED="filterActiveChanged",e.EVENT_SORT_CHANGED="sortChanged",e.EVENT_MENU_VISIBLE_CHANGED="menuVisibleChanged",e.EVENT_ROW_GROUP_CHANGED="columnRowGroupChanged",e.EVENT_PIVOT_CHANGED="columnPivotChanged",e.EVENT_VALUE_CHANGED="columnValueChanged",s([Object(n.a)("gridOptionsWrapper")],e.prototype,"gridOptionsWrapper",void 0),s([Object(n.a)("columnUtils")],e.prototype,"columnUtils",void 0),s([Object(n.a)("columnApi")],e.prototype,"columnApi",void 0),s([Object(n.a)("gridApi")],e.prototype,"gridApi",void 0),s([Object(n.a)("context")],e.prototype,"context",void 0),s([n.e],e.prototype,"initialise",null),e}()},function(e,t,o){"use strict";o.d(t,"b",(function(){return a})),o.d(t,"d",(function(){return n})),o.d(t,"c",(function(){return i})),o.d(t,"a",(function(){return d}));var r,a,n,i,l=o(6),g=o(1),s=o(0),p=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),c=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i};!function(e){e[e.ToolPanel=0]="ToolPanel",e[e.HeaderCell=1]="HeaderCell",e[e.RowDrag=2]="RowDrag",e[e.ChartPanel=3]="ChartPanel"}(a||(a={})),function(e){e[e.Up=0]="Up",e[e.Down=1]="Down"}(n||(n={})),function(e){e[e.Left=0]="Left",e[e.Right=1]="Right"}(i||(i={}));var d=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.dragSourceAndParamsList=[],t.dropTargets=[],t}var o;return p(t,e),o=t,t.prototype.init=function(){this.ePinnedIcon=s.f.createIcon("columnMovePin",this.gridOptionsWrapper,null),this.eHideIcon=s.f.createIcon("columnMoveHide",this.gridOptionsWrapper,null),this.eMoveIcon=s.f.createIcon("columnMoveMove",this.gridOptionsWrapper,null),this.eLeftIcon=s.f.createIcon("columnMoveLeft",this.gridOptionsWrapper,null),this.eRightIcon=s.f.createIcon("columnMoveRight",this.gridOptionsWrapper,null),this.eGroupIcon=s.f.createIcon("columnMoveGroup",this.gridOptionsWrapper,null),this.eAggregateIcon=s.f.createIcon("columnMoveValue",this.gridOptionsWrapper,null),this.ePivotIcon=s.f.createIcon("columnMovePivot",this.gridOptionsWrapper,null),this.eDropNotAllowedIcon=s.f.createIcon("dropNotAllowed",this.gridOptionsWrapper,null)},t.prototype.addDragSource=function(e,t){void 0===t&&(t=!1);var o={eElement:e.eElement,dragStartPixels:e.dragStartPixels,onDragStart:this.onDragStart.bind(this,e),onDragStop:this.onDragStop.bind(this),onDragging:this.onDragging.bind(this)};this.dragSourceAndParamsList.push({params:o,dragSource:e}),this.dragService.addDragSource(o,t)},t.prototype.removeDragSource=function(e){var t=s.f.find(this.dragSourceAndParamsList,(function(t){return t.dragSource===e}));t&&(this.dragService.removeDragSource(t.params),s.f.removeFromArray(this.dragSourceAndParamsList,t))},t.prototype.clearDragSourceParamsList=function(){var e=this;this.dragSourceAndParamsList.forEach((function(t){return e.dragService.removeDragSource(t.params)})),this.dragSourceAndParamsList.length=0},t.prototype.nudge=function(){this.dragging&&this.onDragging(this.eventLastTime,!0)},t.prototype.onDragStart=function(e,t){this.dragging=!0,this.dragSource=e,this.eventLastTime=t,this.dragItem=this.dragSource.getDragItem(),this.lastDropTarget=this.dragSource.dragSourceDropTarget,this.dragSource.onDragStarted&&this.dragSource.onDragStarted(),this.createGhost()},t.prototype.onDragStop=function(e){if(this.eventLastTime=null,this.dragging=!1,this.dragSource.onDragStopped&&this.dragSource.onDragStopped(),this.lastDropTarget&&this.lastDropTarget.onDragStop){var t=this.createDropTargetEvent(this.lastDropTarget,e,null,null,!1);this.lastDropTarget.onDragStop(t)}this.lastDropTarget=null,this.dragItem=null,this.removeGhost()},t.prototype.onDragging=function(e,t){var o=this.getHorizontalDirection(e),r=this.getVerticalDirection(e);this.eventLastTime=e,this.positionGhost(e);var a=s.f.find(this.dropTargets,this.isMouseOnDropTarget.bind(this,e));if(a!==this.lastDropTarget)this.leaveLastTargetIfExists(e,o,r,t),this.enterDragTargetIfExists(a,e,o,r,t),this.lastDropTarget=a;else if(a&&a.onDragging){var n=this.createDropTargetEvent(a,e,o,r,t);a.onDragging(n)}},t.prototype.enterDragTargetIfExists=function(e,t,o,r,a){if(e){if(e.onDragEnter){var n=this.createDropTargetEvent(e,t,o,r,a);e.onDragEnter(n)}this.setGhostIcon(e.getIconName?e.getIconName():null)}},t.prototype.leaveLastTargetIfExists=function(e,t,o,r){if(this.lastDropTarget){if(this.lastDropTarget.onDragLeave){var a=this.createDropTargetEvent(this.lastDropTarget,e,t,o,r);this.lastDropTarget.onDragLeave(a)}this.setGhostIcon(null)}},t.prototype.getAllContainersFromDropTarget=function(e){var t=[e.getContainer()],o=e.getSecondaryContainers?e.getSecondaryContainers():null;return o&&(t=t.concat(o)),t},t.prototype.isMouseOnDropTarget=function(e,t){var o=!1;return this.getAllContainersFromDropTarget(t).filter((function(e){return e})).forEach((function(t){var r=t.getBoundingClientRect();if(0!==r.width&&0!==r.height){var a=e.clientX>=r.left&&e.clientX<=r.right,n=e.clientY>=r.top&&e.clientY<=r.bottom;a&&n&&(o=!0)}})),o&&t.isInterestedIn(this.dragSource.type)},t.prototype.addDropTarget=function(e){this.dropTargets.push(e)},t.prototype.removeDropTarget=function(e){this.dropTargets=this.dropTargets.filter((function(t){return t.getContainer()!==e.getContainer()}))},t.prototype.hasExternalDropZones=function(){return this.dropTargets.some((function(e){return e.external}))},t.prototype.findExternalZone=function(e){var t=this.dropTargets.filter((function(e){return e.external}));return s.f.find(t,(function(t){return t.getContainer()===e.getContainer()}))},t.prototype.getHorizontalDirection=function(e){var t=this.eventLastTime.clientX,o=e.clientX;return t===o?null:t>o?i.Left:i.Right},t.prototype.getVerticalDirection=function(e){var t=this.eventLastTime.clientY,o=e.clientY;return t===o?null:t>o?n.Up:n.Down},t.prototype.createDropTargetEvent=function(e,t,o,r,a){var n=e.getContainer(),i=n.getBoundingClientRect(),l=this.gridApi,g=this.columnApi,s=this.dragItem,p=this.dragSource;return{event:t,x:t.clientX-i.left,y:t.clientY-i.top,vDirection:r,hDirection:o,dragSource:p,fromNudge:a,dragItem:s,api:l,columnApi:g,dropZoneTarget:n}},t.prototype.positionGhost=function(e){var t=this.eGhost,o=t.getBoundingClientRect().height,r=s.f.getBodyWidth()-2,a=s.f.getBodyHeight()-2,n=e.pageY-o/2,i=e.pageX-10,l=this.gridOptionsWrapper.getDocument(),g=window.pageYOffset||l.documentElement.scrollTop,p=window.pageXOffset||l.documentElement.scrollLeft;r>0&&i+t.clientWidth>r+p&&(i=r+p-t.clientWidth),i<0&&(i=0),a>0&&n+t.clientHeight>a+g&&(n=a+g-t.clientHeight),n<0&&(n=0),t.style.left=i+"px",t.style.top=n+"px"},t.prototype.removeGhost=function(){this.eGhost&&this.eGhostParent&&this.eGhostParent.removeChild(this.eGhost),this.eGhost=null},t.prototype.createGhost=function(){this.eGhost=s.f.loadTemplate(o.GHOST_TEMPLATE);var e=this.environment.getTheme().theme;e&&s.f.addCssClass(this.eGhost,e),this.eGhostIcon=this.eGhost.querySelector(".ag-dnd-ghost-icon"),this.setGhostIcon(null);var t=this.eGhost.querySelector(".ag-dnd-ghost-label"),r=this.dragSource.dragItemName;s.f.isFunction(r)&&(r=r()),t.innerHTML=s.f.escape(r),this.eGhost.style.height="25px",this.eGhost.style.top="20px",this.eGhost.style.left="20px";var a=this.gridOptionsWrapper.getDocument();this.eGhostParent=a.querySelector("body"),this.eGhostParent?this.eGhostParent.appendChild(this.eGhost):console.warn("ag-Grid: could not find document body, it is needed for dragging columns")},t.prototype.setGhostIcon=function(e,t){var r;switch(void 0===t&&(t=!1),s.f.clearElement(this.eGhostIcon),e||(e=this.dragSource.defaultIconName||o.ICON_NOT_ALLOWED),e){case o.ICON_PINNED:r=this.ePinnedIcon;break;case o.ICON_MOVE:r=this.eMoveIcon;break;case o.ICON_LEFT:r=this.eLeftIcon;break;case o.ICON_RIGHT:r=this.eRightIcon;break;case o.ICON_GROUP:r=this.eGroupIcon;break;case o.ICON_AGGREGATE:r=this.eAggregateIcon;break;case o.ICON_PIVOT:r=this.ePivotIcon;break;case o.ICON_NOT_ALLOWED:r=this.eDropNotAllowedIcon;break;case o.ICON_HIDE:r=this.eHideIcon}s.f.addOrRemoveCssClass(this.eGhostIcon,"ag-shake-left-to-right",t),r===this.eHideIcon&&this.gridOptionsWrapper.isSuppressDragLeaveHidesColumns()||r&&this.eGhostIcon.appendChild(r)},t.ICON_PINNED="pinned",t.ICON_MOVE="move",t.ICON_LEFT="left",t.ICON_RIGHT="right",t.ICON_GROUP="group",t.ICON_AGGREGATE="aggregate",t.ICON_PIVOT="pivot",t.ICON_NOT_ALLOWED="notAllowed",t.ICON_HIDE="hide",t.GHOST_TEMPLATE='
\n \n
\n
',c([Object(g.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),c([Object(g.a)("dragService")],t.prototype,"dragService",void 0),c([Object(g.a)("environment")],t.prototype,"environment",void 0),c([Object(g.a)("columnApi")],t.prototype,"columnApi",void 0),c([Object(g.a)("gridApi")],t.prototype,"gridApi",void 0),c([g.e],t.prototype,"init",null),c([g.g],t.prototype,"clearDragSourceParamsList",null),t=o=c([Object(g.b)("dragAndDropService")],t)}(l.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return a})),o.d(t,"b",(function(){return h}));var r,a,n=o(5),i=o(137),l=o(39),g=o(0),s=o(17),p=o(8),c=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),d=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i};!function(e){e[e.One=0]="One",e[e.Two=1]="Two"}(a||(a={}));var u={filterOoo:"Filter...",empty:"Choose One",equals:"Equals",notEqual:"Not equal",lessThan:"Less than",greaterThan:"Greater than",inRange:"In range",inRangeStart:"From",inRangeEnd:"To",lessThanOrEqual:"Less than or equals",greaterThanOrEqual:"Greater than or equals",contains:"Contains",notContains:"Not contains",startsWith:"Starts with",endsWith:"Ends with",andCondition:"AND",orCondition:"OR"},h=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return c(t,e),t.prototype.showValueFrom=function(e){return!this.doesFilterHaveHiddenInput(e)&&e!==t.EMPTY},t.prototype.showValueTo=function(e){return e===t.IN_RANGE},t.prototype.onFloatingFilterChanged=function(e,t){this.setTypeFromFloatingFilter(e),this.setValueFromFloatingFilter(t),this.onUiChanged(!0)},t.prototype.setTypeFromFloatingFilter=function(e){this.eType1.setValue(e),this.eType2.setValue(this.optionsFactory.getDefaultOption()),this.eJoinOperatorAnd.setValue(!0)},t.prototype.getModelFromUi=function(){return this.isConditionUiComplete(a.One)?this.isAllowTwoConditions()&&this.isConditionUiComplete(a.Two)?{filterType:this.getFilterType(),operator:this.getJoinOperator(),condition1:this.createCondition(a.One),condition2:this.createCondition(a.Two)}:this.createCondition(a.One):null},t.prototype.getCondition1Type=function(){return this.eType1.getValue()},t.prototype.getCondition2Type=function(){return this.eType2.getValue()},t.prototype.getJoinOperator=function(){return!0===this.eJoinOperatorOr.getValue()?"OR":"AND"},t.prototype.areModelsEqual=function(e,t){if(!e&&!t)return!0;if(!e&&t||e&&!t)return!1;var o,r=!e.operator,a=!t.operator;if(!r&&a||r&&!a)return!1;if(r){var n=e,i=t;o=this.areSimpleModelsEqual(n,i)}else{var l=e,g=t;o=l.operator===g.operator&&this.areSimpleModelsEqual(l.condition1,g.condition1)&&this.areSimpleModelsEqual(l.condition2,g.condition2)}return o},t.prototype.setModelIntoUi=function(e){if(e.operator){var t=e,o="OR"===t.operator;this.eJoinOperatorAnd.setValue(!o),this.eJoinOperatorOr.setValue(o),this.eType1.setValue(t.condition1.type),this.eType2.setValue(t.condition2.type),this.setConditionIntoUi(t.condition1,a.One),this.setConditionIntoUi(t.condition2,a.Two)}else{var r=e;this.eJoinOperatorAnd.setValue(!0),this.eJoinOperatorOr.setValue(!1),this.eType1.setValue(r.type),this.eType2.setValue(this.optionsFactory.getDefaultOption()),this.setConditionIntoUi(r,a.One),this.setConditionIntoUi(null,a.Two)}return g.c.resolve()},t.prototype.doesFilterPass=function(e){var t=this.getModel();if(t.operator){var o=t,r=this.individualConditionPasses(e,o.condition1),a=this.individualConditionPasses(e,o.condition2);return"AND"===o.operator?r&&a:r||a}var n=t;return this.individualConditionPasses(e,n)},t.prototype.setParams=function(t){e.prototype.setParams.call(this,t),this.optionsFactory=new i.a,this.optionsFactory.init(t,this.getDefaultFilterOptions()),this.allowTwoConditions=!t.suppressAndOrCondition,this.putOptionsIntoDropdown(),this.addChangedListeners()},t.prototype.putOptionsIntoDropdown=function(){var e=this,t=this.optionsFactory.getFilterOptions();Object(s.forEach)(t,(function(t){var o,r;if("string"==typeof t)o=t,r=e.translate(o);else{o=t.displayKey;var a=e.optionsFactory.getCustomOption(o);r=a?a.displayName:e.translate(o)}var n=function(){return{value:o,text:r}};e.eType1.addOption(n()),e.eType2.addOption(n())}));var o=t.length<=1;this.eType1.setDisabled(o),this.eType2.setDisabled(o)},t.prototype.isAllowTwoConditions=function(){return this.allowTwoConditions},t.prototype.createBodyTemplate=function(){return'\n \n '+this.createValueTemplate(a.One)+'\n
\n \n \n
\n \n '+this.createValueTemplate(a.Two)},t.prototype.getCssIdentifier=function(){return"simple-filter"},t.prototype.updateUiVisibility=function(){var e=this.isConditionUiComplete(a.One),t=this.allowTwoConditions&&e;Object(p.setDisplayed)(this.eCondition2Body,t),Object(p.setDisplayed)(this.eType2.getGui(),t),Object(p.setDisplayed)(this.eJoinOperatorPanel,t)},t.prototype.resetUiToDefaults=function(e){var t="ag-simple-filter-and-or-"+this.getCompId(),o=this.optionsFactory.getDefaultOption();return this.eType1.setValue(o,e),this.eType2.setValue(o,e),this.eJoinOperatorAnd.setValue(!0,e).setName(t).setLabel(this.translate("andCondition")),this.eJoinOperatorOr.setValue(!1,e).setName(t).setLabel(this.translate("orCondition")),g.c.resolve()},t.prototype.translate=function(e){return this.gridOptionsWrapper.getLocaleTextFunc()(e,u[e])},t.prototype.addChangedListeners=function(){var e=this,t=function(){return e.onUiChanged()};this.eType1.onValueChange(t),this.eType2.onValueChange(t),this.eJoinOperatorOr.onValueChange(t),this.eJoinOperatorAnd.onValueChange(t)},t.prototype.doesFilterHaveHiddenInput=function(e){var t=this.optionsFactory.getCustomOption(e);return t&&t.hideFilterInput},t.EMPTY="empty",t.EQUALS="equals",t.NOT_EQUAL="notEqual",t.LESS_THAN="lessThan",t.LESS_THAN_OR_EQUAL="lessThanOrEqual",t.GREATER_THAN="greaterThan",t.GREATER_THAN_OR_EQUAL="greaterThanOrEqual",t.IN_RANGE="inRange",t.CONTAINS="contains",t.NOT_CONTAINS="notContains",t.STARTS_WITH="startsWith",t.ENDS_WITH="endsWith",d([Object(n.d)("eOptions1")],t.prototype,"eType1",void 0),d([Object(n.d)("eOptions2")],t.prototype,"eType2",void 0),d([Object(n.d)("eJoinOperatorAnd")],t.prototype,"eJoinOperatorAnd",void 0),d([Object(n.d)("eJoinOperatorOr")],t.prototype,"eJoinOperatorOr",void 0),d([Object(n.d)("eCondition2Body")],t.prototype,"eCondition2Body",void 0),d([Object(n.d)("eJoinOperatorPanel")],t.prototype,"eJoinOperatorPanel",void 0),t}(l.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return v}));var r=o(23),a=o(2),n=o(37),i=o(1),l=o(32),g=o(74),s=o(9),p=o(136),c=o(10),d=o(11),u=o(0),h=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},f=function(e,t){return function(o,r){t(o,r,e)}},m=function(){for(var e=0,t=0,o=arguments.length;t0&&console.warn("ag-grid: to see all the valid "+r+" properties please check: "+a)},e.prototype.getDomData=function(e,t){var o=e[this.domDataKey];return o?o[t]:void 0},e.prototype.setDomData=function(e,t,o){var r=e[this.domDataKey];u.f.missing(r)&&(r={},e[this.domDataKey]=r),r[t]=o},e.prototype.isRowSelection=function(){return"single"===this.gridOptions.rowSelection||"multiple"===this.gridOptions.rowSelection},e.prototype.isRowDeselection=function(){return b(this.gridOptions.rowDeselection)},e.prototype.isRowSelectionMulti=function(){return"multiple"===this.gridOptions.rowSelection},e.prototype.isRowMultiSelectWithClick=function(){return b(this.gridOptions.rowMultiSelectWithClick)},e.prototype.getContext=function(){return this.gridOptions.context},e.prototype.isPivotMode=function(){return b(this.gridOptions.pivotMode)},e.prototype.isPivotTotals=function(){return b(this.gridOptions.pivotTotals)},e.prototype.getPivotColumnGroupTotals=function(){return this.gridOptions.pivotColumnGroupTotals},e.prototype.getPivotRowTotals=function(){return this.gridOptions.pivotRowTotals},e.prototype.isRowModelInfinite=function(){return this.gridOptions.rowModelType===a.a.ROW_MODEL_TYPE_INFINITE},e.prototype.isRowModelViewport=function(){return this.gridOptions.rowModelType===a.a.ROW_MODEL_TYPE_VIEWPORT},e.prototype.isRowModelServerSide=function(){return this.gridOptions.rowModelType===a.a.ROW_MODEL_TYPE_SERVER_SIDE},e.prototype.isRowModelDefault=function(){return u.f.missing(this.gridOptions.rowModelType)||this.gridOptions.rowModelType===a.a.ROW_MODEL_TYPE_CLIENT_SIDE||this.gridOptions.rowModelType===a.a.DEPRECATED_ROW_MODEL_TYPE_NORMAL},e.prototype.isFullRowEdit=function(){return"fullRow"===this.gridOptions.editType},e.prototype.isSuppressFocusAfterRefresh=function(){return b(this.gridOptions.suppressFocusAfterRefresh)},e.prototype.isSuppressBrowserResizeObserver=function(){return b(this.gridOptions.suppressBrowserResizeObserver)},e.prototype.isSuppressMaintainUnsortedOrder=function(){return b(this.gridOptions.suppressMaintainUnsortedOrder)},e.prototype.isSuppressClearOnFillReduction=function(){return b(this.gridOptions.suppressClearOnFillReduction)},e.prototype.isShowToolPanel=function(){return b(this.gridOptions.sideBar&&Array.isArray(this.getSideBar().toolPanels))},e.prototype.getSideBar=function(){return this.gridOptions.sideBar},e.prototype.isSuppressTouch=function(){return b(this.gridOptions.suppressTouch)},e.prototype.isSuppressRowTransform=function(){return b(this.gridOptions.suppressRowTransform)},e.prototype.isSuppressSetColumnStateEvents=function(){return b(this.gridOptions.suppressSetColumnStateEvents)},e.prototype.isAllowDragFromColumnsToolPanel=function(){return b(this.gridOptions.allowDragFromColumnsToolPanel)},e.prototype.useAsyncEvents=function(){return!b(this.gridOptions.suppressAsyncEvents)},e.prototype.isEnableCellChangeFlash=function(){return b(this.gridOptions.enableCellChangeFlash)},e.prototype.getCellFlashDelay=function(){return this.gridOptions.cellFlashDelay||500},e.prototype.getCellFadeDelay=function(){return this.gridOptions.cellFadeDelay||1e3},e.prototype.isGroupSelectsChildren=function(){var e=b(this.gridOptions.groupSelectsChildren);return e&&this.isTreeData()?(console.warn("ag-Grid: groupSelectsChildren does not work with tree data"),!1):e},e.prototype.isSuppressRowHoverHighlight=function(){return b(this.gridOptions.suppressRowHoverHighlight)},e.prototype.isGroupSelectsFiltered=function(){return b(this.gridOptions.groupSelectsFiltered)},e.prototype.isGroupHideOpenParents=function(){return b(this.gridOptions.groupHideOpenParents)},e.prototype.isGroupMultiAutoColumn=function(){return b(this.gridOptions.groupMultiAutoColumn)||b(this.gridOptions.groupHideOpenParents)},e.prototype.isGroupRemoveSingleChildren=function(){return b(this.gridOptions.groupRemoveSingleChildren)},e.prototype.isGroupRemoveLowestSingleChildren=function(){return b(this.gridOptions.groupRemoveLowestSingleChildren)},e.prototype.isGroupIncludeFooter=function(){return b(this.gridOptions.groupIncludeFooter)},e.prototype.isGroupIncludeTotalFooter=function(){return b(this.gridOptions.groupIncludeTotalFooter)},e.prototype.isGroupSuppressBlankHeader=function(){return b(this.gridOptions.groupSuppressBlankHeader)},e.prototype.isSuppressRowClickSelection=function(){return b(this.gridOptions.suppressRowClickSelection)},e.prototype.isSuppressCellSelection=function(){return b(this.gridOptions.suppressCellSelection)},e.prototype.isSuppressMultiSort=function(){return b(this.gridOptions.suppressMultiSort)},e.prototype.isMultiSortKeyCtrl=function(){return"ctrl"===this.gridOptions.multiSortKey},e.prototype.isGroupSuppressAutoColumn=function(){return b(this.gridOptions.groupSuppressAutoColumn)},e.prototype.isPivotSuppressAutoColumn=function(){return b(this.gridOptions.pivotSuppressAutoColumn)},e.prototype.isSuppressDragLeaveHidesColumns=function(){return b(this.gridOptions.suppressDragLeaveHidesColumns)},e.prototype.isSuppressScrollOnNewData=function(){return b(this.gridOptions.suppressScrollOnNewData)},e.prototype.isRowDragManaged=function(){return b(this.gridOptions.rowDragManaged)},e.prototype.isSuppressRowDrag=function(){return b(this.gridOptions.suppressRowDrag)},e.prototype.isSuppressMoveWhenRowDragging=function(){return b(this.gridOptions.suppressMoveWhenRowDragging)},e.prototype.isEnableMultiRowDragging=function(){return b(this.gridOptions.enableMultiRowDragging)},e.prototype.getDomLayout=function(){var e=this.gridOptions.domLayout||a.a.DOM_LAYOUT_NORMAL;return-1===[a.a.DOM_LAYOUT_PRINT,a.a.DOM_LAYOUT_AUTO_HEIGHT,a.a.DOM_LAYOUT_NORMAL].indexOf(e)?(u.f.doOnce((function(){return console.warn("ag-Grid: "+e+" is not valid for DOM Layout, valid values are "+a.a.DOM_LAYOUT_NORMAL+", "+a.a.DOM_LAYOUT_AUTO_HEIGHT+" and "+a.a.DOM_LAYOUT_PRINT)}),"warn about dom layout values"),a.a.DOM_LAYOUT_NORMAL):e},e.prototype.isSuppressHorizontalScroll=function(){return b(this.gridOptions.suppressHorizontalScroll)},e.prototype.isSuppressMaxRenderedRowRestriction=function(){return b(this.gridOptions.suppressMaxRenderedRowRestriction)},e.prototype.isExcludeChildrenWhenTreeDataFiltering=function(){return b(this.gridOptions.excludeChildrenWhenTreeDataFiltering)},e.prototype.isAlwaysShowVerticalScroll=function(){return b(this.gridOptions.alwaysShowVerticalScroll)},e.prototype.isSuppressLoadingOverlay=function(){return b(this.gridOptions.suppressLoadingOverlay)},e.prototype.isSuppressNoRowsOverlay=function(){return b(this.gridOptions.suppressNoRowsOverlay)},e.prototype.isSuppressFieldDotNotation=function(){return b(this.gridOptions.suppressFieldDotNotation)},e.prototype.getPinnedTopRowData=function(){return this.gridOptions.pinnedTopRowData},e.prototype.getPinnedBottomRowData=function(){return this.gridOptions.pinnedBottomRowData},e.prototype.isFunctionsPassive=function(){return b(this.gridOptions.functionsPassive)},e.prototype.isSuppressTabbing=function(){return b(this.gridOptions.suppressTabbing)},e.prototype.isSuppressChangeDetection=function(){return b(this.gridOptions.suppressChangeDetection)},e.prototype.isSuppressAnimationFrame=function(){return b(this.gridOptions.suppressAnimationFrame)},e.prototype.getQuickFilterText=function(){return this.gridOptions.quickFilterText},e.prototype.isCacheQuickFilter=function(){return b(this.gridOptions.cacheQuickFilter)},e.prototype.isUnSortIcon=function(){return b(this.gridOptions.unSortIcon)},e.prototype.isSuppressMenuHide=function(){return b(this.gridOptions.suppressMenuHide)},e.prototype.isEnterMovesDownAfterEdit=function(){return b(this.gridOptions.enterMovesDownAfterEdit)},e.prototype.isEnterMovesDown=function(){return b(this.gridOptions.enterMovesDown)},e.prototype.isUndoRedoCellEditing=function(){return b(this.gridOptions.undoRedoCellEditing)},e.prototype.getUndoRedoCellEditingLimit=function(){return this.gridOptions.undoRedoCellEditingLimit},e.prototype.getRowStyle=function(){return this.gridOptions.rowStyle},e.prototype.getRowClass=function(){return this.gridOptions.rowClass},e.prototype.getRowStyleFunc=function(){return this.gridOptions.getRowStyle},e.prototype.getRowClassFunc=function(){return this.gridOptions.getRowClass},e.prototype.rowClassRules=function(){return this.gridOptions.rowClassRules},e.prototype.getCreateChartContainerFunc=function(){return this.gridOptions.createChartContainer},e.prototype.getPopupParent=function(){return this.gridOptions.popupParent},e.prototype.getBlockLoadDebounceMillis=function(){return this.gridOptions.blockLoadDebounceMillis},e.prototype.getPostProcessPopupFunc=function(){return this.gridOptions.postProcessPopup},e.prototype.getDoesDataFlowerFunc=function(){return this.gridOptions.doesDataFlower},e.prototype.getPaginationNumberFormatterFunc=function(){return this.gridOptions.paginationNumberFormatter},e.prototype.getChildCountFunc=function(){return this.gridOptions.getChildCount},e.prototype.getDefaultGroupSortComparator=function(){return this.gridOptions.defaultGroupSortComparator},e.prototype.getIsFullWidthCellFunc=function(){return this.gridOptions.isFullWidthCell},e.prototype.getFullWidthCellRendererParams=function(){return this.gridOptions.fullWidthCellRendererParams},e.prototype.isEmbedFullWidthRows=function(){return b(this.gridOptions.embedFullWidthRows)||b(this.gridOptions.deprecatedEmbedFullWidthRows)},e.prototype.getSuppressKeyboardEventFunc=function(){return this.gridOptions.suppressKeyboardEvent},e.prototype.getBusinessKeyForNodeFunc=function(){return this.gridOptions.getBusinessKeyForNode},e.prototype.getApi=function(){return this.gridOptions.api},e.prototype.getColumnApi=function(){return this.gridOptions.columnApi},e.prototype.isImmutableData=function(){return b(this.gridOptions.immutableData)},e.prototype.isImmutableColumns=function(){return b(this.gridOptions.immutableColumns)},e.prototype.isEnsureDomOrder=function(){return b(this.gridOptions.ensureDomOrder)},e.prototype.isEnableCharts=function(){return!!b(this.gridOptions.enableCharts)&&d.a.assertRegistered(c.a.GridChartsModule,"enableCharts")},e.prototype.getColResizeDefault=function(){return this.gridOptions.colResizeDefault},e.prototype.isSingleClickEdit=function(){return b(this.gridOptions.singleClickEdit)},e.prototype.isSuppressClickEdit=function(){return b(this.gridOptions.suppressClickEdit)},e.prototype.isStopEditingWhenGridLosesFocus=function(){return b(this.gridOptions.stopEditingWhenGridLosesFocus)},e.prototype.getGroupDefaultExpanded=function(){return this.gridOptions.groupDefaultExpanded},e.prototype.getMaxConcurrentDatasourceRequests=function(){return this.gridOptions.maxConcurrentDatasourceRequests},e.prototype.getMaxBlocksInCache=function(){return this.gridOptions.maxBlocksInCache},e.prototype.getCacheOverflowSize=function(){return this.gridOptions.cacheOverflowSize},e.prototype.getPaginationPageSize=function(){return this.gridOptions.paginationPageSize},e.prototype.isPaginateChildRows=function(){return!!(this.isGroupSuppressRow()||this.isGroupRemoveSingleChildren()||this.isGroupRemoveLowestSingleChildren())||b(this.gridOptions.paginateChildRows)},e.prototype.getCacheBlockSize=function(){return this.gridOptions.cacheBlockSize},e.prototype.getInfiniteInitialRowCount=function(){return this.gridOptions.infiniteInitialRowCount},e.prototype.isPurgeClosedRowNodes=function(){return b(this.gridOptions.purgeClosedRowNodes)},e.prototype.isSuppressPaginationPanel=function(){return b(this.gridOptions.suppressPaginationPanel)},e.prototype.getRowData=function(){return this.gridOptions.rowData},e.prototype.isGroupUseEntireRow=function(e){return!e&&b(this.gridOptions.groupUseEntireRow)},e.prototype.isEnableRtl=function(){return b(this.gridOptions.enableRtl)},e.prototype.getAutoGroupColumnDef=function(){return this.gridOptions.autoGroupColumnDef},e.prototype.isGroupSuppressRow=function(){return b(this.gridOptions.groupSuppressRow)},e.prototype.getRowGroupPanelShow=function(){return this.gridOptions.rowGroupPanelShow},e.prototype.getPivotPanelShow=function(){return this.gridOptions.pivotPanelShow},e.prototype.isAngularCompileRows=function(){return b(this.gridOptions.angularCompileRows)},e.prototype.isAngularCompileFilters=function(){return b(this.gridOptions.angularCompileFilters)},e.prototype.isAngularCompileHeaders=function(){return b(this.gridOptions.angularCompileHeaders)},e.prototype.isDebug=function(){return b(this.gridOptions.debug)},e.prototype.getColumnDefs=function(){return this.gridOptions.columnDefs},e.prototype.getColumnTypes=function(){return this.gridOptions.columnTypes},e.prototype.getDatasource=function(){return this.gridOptions.datasource},e.prototype.getViewportDatasource=function(){return this.gridOptions.viewportDatasource},e.prototype.getServerSideDatasource=function(){return this.gridOptions.serverSideDatasource},e.prototype.isAccentedSort=function(){return b(this.gridOptions.accentedSort)},e.prototype.isEnableBrowserTooltips=function(){return b(this.gridOptions.enableBrowserTooltips)},e.prototype.isEnableCellExpressions=function(){return b(this.gridOptions.enableCellExpressions)},e.prototype.isEnableGroupEdit=function(){return b(this.gridOptions.enableGroupEdit)},e.prototype.isSuppressMiddleClickScrolls=function(){return b(this.gridOptions.suppressMiddleClickScrolls)},e.prototype.isPreventDefaultOnContextMenu=function(){return b(this.gridOptions.preventDefaultOnContextMenu)},e.prototype.isSuppressPreventDefaultOnMouseWheel=function(){return b(this.gridOptions.suppressPreventDefaultOnMouseWheel)},e.prototype.isSuppressColumnVirtualisation=function(){return b(this.gridOptions.suppressColumnVirtualisation)},e.prototype.isSuppressContextMenu=function(){return b(this.gridOptions.suppressContextMenu)},e.prototype.isAllowContextMenuWithControlKey=function(){return b(this.gridOptions.allowContextMenuWithControlKey)},e.prototype.isSuppressCopyRowsToClipboard=function(){return b(this.gridOptions.suppressCopyRowsToClipboard)},e.prototype.isCopyHeadersToClipboard=function(){return b(this.gridOptions.copyHeadersToClipboard)},e.prototype.isSuppressClipboardPaste=function(){return b(this.gridOptions.suppressClipboardPaste)},e.prototype.isSuppressLastEmptyLineOnPaste=function(){return b(this.gridOptions.suppressLastEmptyLineOnPaste)},e.prototype.isPagination=function(){return b(this.gridOptions.pagination)},e.prototype.isSuppressEnterpriseResetOnNewColumns=function(){return b(this.gridOptions.suppressEnterpriseResetOnNewColumns)},e.prototype.getProcessDataFromClipboardFunc=function(){return this.gridOptions.processDataFromClipboard},e.prototype.getAsyncTransactionWaitMillis=function(){return u.f.exists(this.gridOptions.asyncTransactionWaitMillis)?this.gridOptions.asyncTransactionWaitMillis:a.a.BATCH_WAIT_MILLIS},e.prototype.isSuppressMovableColumns=function(){return b(this.gridOptions.suppressMovableColumns)},e.prototype.isAnimateRows=function(){return!this.isEnsureDomOrder()&&b(this.gridOptions.animateRows)},e.prototype.isSuppressColumnMoveAnimation=function(){return b(this.gridOptions.suppressColumnMoveAnimation)},e.prototype.isSuppressAggFuncInHeader=function(){return b(this.gridOptions.suppressAggFuncInHeader)},e.prototype.isSuppressAggAtRootLevel=function(){return b(this.gridOptions.suppressAggAtRootLevel)},e.prototype.isEnableRangeSelection=function(){return d.a.isRegistered(c.a.RangeSelectionModule)&&b(this.gridOptions.enableRangeSelection)},e.prototype.isEnableRangeHandle=function(){return b(this.gridOptions.enableRangeHandle)},e.prototype.isEnableFillHandle=function(){return b(this.gridOptions.enableFillHandle)},e.prototype.getFillOperation=function(){return this.gridOptions.fillOperation},e.prototype.isSuppressMultiRangeSelection=function(){return b(this.gridOptions.suppressMultiRangeSelection)},e.prototype.isPaginationAutoPageSize=function(){return b(this.gridOptions.paginationAutoPageSize)},e.prototype.isRememberGroupStateWhenNewData=function(){return b(this.gridOptions.rememberGroupStateWhenNewData)},e.prototype.getIcons=function(){return this.gridOptions.icons},e.prototype.getAggFuncs=function(){return this.gridOptions.aggFuncs},e.prototype.getSortingOrder=function(){return this.gridOptions.sortingOrder},e.prototype.getAlignedGrids=function(){return this.gridOptions.alignedGrids},e.prototype.isMasterDetail=function(){return!!b(this.gridOptions.masterDetail)&&d.a.assertRegistered(c.a.MasterDetailModule,"masterDetail")},e.prototype.isKeepDetailRows=function(){return b(this.gridOptions.keepDetailRows)},e.prototype.getKeepDetailRowsCount=function(){return this.gridOptions.keepDetailRowsCount>0?this.gridOptions.keepDetailRowsCount:10},e.prototype.getIsRowMasterFunc=function(){return this.gridOptions.isRowMaster},e.prototype.getIsRowSelectableFunc=function(){return this.gridOptions.isRowSelectable},e.prototype.getGroupRowRendererParams=function(){return this.gridOptions.groupRowRendererParams},e.prototype.getOverlayLoadingTemplate=function(){return this.gridOptions.overlayLoadingTemplate},e.prototype.getOverlayNoRowsTemplate=function(){return this.gridOptions.overlayNoRowsTemplate},e.prototype.isSuppressAutoSize=function(){return b(this.gridOptions.suppressAutoSize)},e.prototype.isEnableCellTextSelection=function(){return b(this.gridOptions.enableCellTextSelection)},e.prototype.isSuppressParentsInRowNodes=function(){return b(this.gridOptions.suppressParentsInRowNodes)},e.prototype.isFunctionsReadOnly=function(){return b(this.gridOptions.functionsReadOnly)},e.prototype.isFloatingFilter=function(){return this.gridOptions.floatingFilter},e.prototype.isEnableCellTextSelect=function(){return b(this.gridOptions.enableCellTextSelection)},e.prototype.isEnableOldSetFilterModel=function(){return b(this.gridOptions.enableOldSetFilterModel)},e.prototype.getDefaultColDef=function(){return this.gridOptions.defaultColDef},e.prototype.getDefaultColGroupDef=function(){return this.gridOptions.defaultColGroupDef},e.prototype.getDefaultExportParams=function(){return this.gridOptions.defaultExportParams},e.prototype.isSuppressCsvExport=function(){return b(this.gridOptions.suppressCsvExport)},e.prototype.isAllowShowChangeAfterFilter=function(){return b(this.gridOptions.allowShowChangeAfterFilter)},e.prototype.isSuppressExcelExport=function(){return b(this.gridOptions.suppressExcelExport)},e.prototype.isSuppressMakeColumnVisibleAfterUnGroup=function(){return b(this.gridOptions.suppressMakeColumnVisibleAfterUnGroup)},e.prototype.getNodeChildDetailsFunc=function(){return this.gridOptions.getNodeChildDetails},e.prototype.getDataPathFunc=function(){return this.gridOptions.getDataPath},e.prototype.getIsServerSideGroupFunc=function(){return this.gridOptions.isServerSideGroup},e.prototype.getServerSideGroupKeyFunc=function(){return this.gridOptions.getServerSideGroupKey},e.prototype.getGroupRowAggNodesFunc=function(){return this.gridOptions.groupRowAggNodes},e.prototype.getContextMenuItemsFunc=function(){return this.gridOptions.getContextMenuItems},e.prototype.getMainMenuItemsFunc=function(){return this.gridOptions.getMainMenuItems},e.prototype.getChartToolbarItemsFunc=function(){return this.gridOptions.getChartToolbarItems},e.prototype.getRowNodeIdFunc=function(){return this.gridOptions.getRowNodeId},e.prototype.getNavigateToNextCellFunc=function(){return this.gridOptions.navigateToNextCell},e.prototype.getTabToNextCellFunc=function(){return this.gridOptions.tabToNextCell},e.prototype.isTreeData=function(){return!!b(this.gridOptions.treeData)&&d.a.assertRegistered(c.a.RowGroupingModule,"Tree Data")},e.prototype.isValueCache=function(){return b(this.gridOptions.valueCache)},e.prototype.isValueCacheNeverExpires=function(){return b(this.gridOptions.valueCacheNeverExpires)},e.prototype.isDeltaSort=function(){return b(this.gridOptions.deltaSort)},e.prototype.isAggregateOnlyChangedColumns=function(){return b(this.gridOptions.aggregateOnlyChangedColumns)},e.prototype.getProcessSecondaryColDefFunc=function(){return this.gridOptions.processSecondaryColDef},e.prototype.getProcessSecondaryColGroupDefFunc=function(){return this.gridOptions.processSecondaryColGroupDef},e.prototype.getSendToClipboardFunc=function(){return this.gridOptions.sendToClipboard},e.prototype.getProcessRowPostCreateFunc=function(){return this.gridOptions.processRowPostCreate},e.prototype.getProcessCellForClipboardFunc=function(){return this.gridOptions.processCellForClipboard},e.prototype.getProcessHeaderForClipboardFunc=function(){return this.gridOptions.processHeaderForClipboard},e.prototype.getProcessCellFromClipboardFunc=function(){return this.gridOptions.processCellFromClipboard},e.prototype.getViewportRowModelPageSize=function(){return e=this.gridOptions.viewportRowModelPageSize,t=5,e>0?e:t;var e,t},e.prototype.getViewportRowModelBufferSize=function(){return e=this.gridOptions.viewportRowModelBufferSize,t=5,e>=0?e:t;var e,t},e.prototype.isServerSideSortingAlwaysResets=function(){return b(this.gridOptions.serverSideSortingAlwaysResets)},e.prototype.getPostSortFunc=function(){return this.gridOptions.postSort},e.prototype.getProcessChartOptionsFunc=function(){return this.gridOptions.processChartOptions},e.prototype.getClipboardDeliminator=function(){return u.f.exists(this.gridOptions.clipboardDeliminator)?this.gridOptions.clipboardDeliminator:"\t"},e.prototype.setProperty=function(e,t,o){void 0===o&&(o=!1);var r=this.gridOptions,a=r[e];if(o||a!==t){r[e]=t;var n={type:e,currentValue:t,previousValue:a};this.propertyEventService.dispatchEvent(n)}},e.prototype.addLayoutElement=function(e){this.layoutElements.push(e),this.updateLayoutClasses()},e.prototype.updateLayoutClasses=function(){var e=this.getDomLayout(),t=e===a.a.DOM_LAYOUT_AUTO_HEIGHT,o=e===a.a.DOM_LAYOUT_PRINT,r=e===a.a.DOM_LAYOUT_NORMAL;this.layoutElements.forEach((function(e){u.f.addOrRemoveCssClass(e,"ag-layout-auto-height",t),u.f.addOrRemoveCssClass(e,"ag-layout-normal",r),u.f.addOrRemoveCssClass(e,"ag-layout-print",o)}))},e.prototype.addEventListener=function(e,o){t.checkEventDeprecation(e),this.propertyEventService.addEventListener(e,o)},e.checkEventDeprecation=function(e){"floatingRowDataChanged"===e&&console.warn("ag-Grid: floatingRowDataChanged is now called pinnedRowDataChanged")},e.prototype.removeEventListener=function(e,t){this.propertyEventService.removeEventListener(e,t)},e.prototype.isSkipHeaderOnAutoSize=function(){return!!this.gridOptions.skipHeaderOnAutoSize},e.prototype.getAutoSizePadding=function(){return this.gridOptions.autoSizePadding&&this.gridOptions.autoSizePadding>0?this.gridOptions.autoSizePadding:20},e.prototype.getHeaderHeight=function(){return"number"==typeof this.gridOptions.headerHeight?this.gridOptions.headerHeight:this.getFromTheme(25,"headerHeight")},e.prototype.getFloatingFiltersHeight=function(){return"number"==typeof this.gridOptions.floatingFiltersHeight?this.gridOptions.floatingFiltersHeight:this.getFromTheme(25,"headerHeight")},e.prototype.getGroupHeaderHeight=function(){return"number"==typeof this.gridOptions.groupHeaderHeight?this.gridOptions.groupHeaderHeight:this.getHeaderHeight()},e.prototype.getPivotHeaderHeight=function(){return"number"==typeof this.gridOptions.pivotHeaderHeight?this.gridOptions.pivotHeaderHeight:this.getHeaderHeight()},e.prototype.getPivotGroupHeaderHeight=function(){return"number"==typeof this.gridOptions.pivotGroupHeaderHeight?this.gridOptions.pivotGroupHeaderHeight:this.getGroupHeaderHeight()},e.prototype.isExternalFilterPresent=function(){return"function"==typeof this.gridOptions.isExternalFilterPresent&&this.gridOptions.isExternalFilterPresent()},e.prototype.doesExternalFilterPass=function(e){return"function"==typeof this.gridOptions.doesExternalFilterPass&&this.gridOptions.doesExternalFilterPass(e)},e.prototype.getTooltipShowDelay=function(){var e=this.gridOptions.tooltipShowDelay;return u.f.exists(e)?(e<0&&console.warn("ag-grid: tooltipShowDelay should not be lower than 0"),Math.max(200,e)):null},e.prototype.isTooltipMouseTrack=function(){return b(this.gridOptions.tooltipMouseTrack)},e.prototype.getDocument=function(){var e=null;return this.gridOptions.getDocument&&u.f.exists(this.gridOptions.getDocument)&&(e=this.gridOptions.getDocument()),e&&u.f.exists(e)?e:document},e.prototype.getMinColWidth=function(){if(this.gridOptions.minColWidth>t.MIN_COL_WIDTH)return this.gridOptions.minColWidth;var e=this.getFromTheme(null,"headerCellMinWidth");return Math.max(e,t.MIN_COL_WIDTH)},e.prototype.getMaxColWidth=function(){return this.gridOptions.maxColWidth&&this.gridOptions.maxColWidth>t.MIN_COL_WIDTH?this.gridOptions.maxColWidth:null},e.prototype.getColWidth=function(){return"number"!=typeof this.gridOptions.colWidth||this.gridOptions.colWidth=0;this.scrollWidth=e?this.gridOptions.scrollbarWidth:u.f.getScrollbarWidth()}return this.scrollWidth},e.prototype.checkForDeprecated=function(){var e=this,t=this.gridOptions;t.suppressUnSort&&console.warn("ag-grid: as of v1.12.4 suppressUnSort is not used. Please use sortingOrder instead."),t.suppressDescSort&&console.warn("ag-grid: as of v1.12.4 suppressDescSort is not used. Please use sortingOrder instead."),t.groupAggFields&&console.warn("ag-grid: as of v3 groupAggFields is not used. Please add appropriate agg fields to your columns."),t.groupHidePivotColumns&&console.warn("ag-grid: as of v3 groupHidePivotColumns is not used as pivot columns are now called rowGroup columns. Please refer to the documentation"),t.groupKeys&&console.warn("ag-grid: as of v3 groupKeys is not used. You need to set rowGroupIndex on the columns to group. Please refer to the documentation"),"boolean"==typeof t.groupDefaultExpanded&&console.warn("ag-grid: groupDefaultExpanded can no longer be boolean. for groupDefaultExpanded=true, use groupDefaultExpanded=9999 instead, to expand all the groups"),(t.onRowDeselected||t.rowDeselected)&&console.warn("ag-grid: since version 3.4 event rowDeselected no longer exists, please check the docs"),t.rowsAlreadyGrouped&&console.warn("ag-grid: since version 3.4 rowsAlreadyGrouped no longer exists, please use getNodeChildDetails() instead"),t.groupAggFunction&&console.warn("ag-grid: since version 4.3.x groupAggFunction is now called groupRowAggNodes"),t.checkboxSelection&&console.warn("ag-grid: since version 8.0.x checkboxSelection is not supported as a grid option. If you want this on all columns, use defaultColDef instead and set it there"),t.paginationInitialRowCount&&console.warn("ag-grid: since version 9.0.x paginationInitialRowCount is now called infiniteInitialRowCount"),t.infinitePageSize&&console.warn("ag-grid: since version 9.0.x infinitePageSize is now called cacheBlockSize"),t.infiniteBlockSize&&console.warn("ag-grid: since version 10.0.x infiniteBlockSize is now called cacheBlockSize"),t.maxPagesInCache&&console.warn("ag-grid: since version 10.0.x maxPagesInCache is now called maxBlocksInCache"),t.paginationOverflowSize&&console.warn("ag-grid: since version 10.0.x paginationOverflowSize is now called cacheOverflowSize"),t.suppressMenuFilterPanel&&console.warn("ag-grid: since version 11.0.x, use property colDef.menuTabs=['generalMenuTab','columnsMenuTab'] instead of suppressMenuFilterPanel=true"),t.suppressMenuMainPanel&&console.warn("ag-grid: since version 11.0.x, use property colDef.menuTabs=['filterMenuTab','columnsMenuTab'] instead of suppressMenuMainPanel=true"),t.suppressMenuColumnPanel&&console.warn("ag-grid: since version 11.0.x, use property colDef.menuTabs=['generalMenuTab','filterMenuTab'] instead of suppressMenuColumnPanel=true"),t.suppressUseColIdForGroups&&console.warn("ag-grid: since version 11.0.x, this is not in use anymore. You should be able to remove it from your definition"),t.groupSuppressRow&&console.warn("ag-grid: since version 18.2.x, 'groupSuppressRow' should not be used anymore. Instead remove row groups and perform custom sorting."),t.groupColumnDef&&console.warn("ag-grid: since version 11.0.x, groupColumnDef has been renamed, this property is now called autoGroupColumnDef. Please change your configuration accordingly"),t.slaveGrids&&console.warn("ag-grid: since version 12.x, slaveGrids has been renamed, this property is now called alignedGrids. Please change your configuration accordingly"),t.floatingTopRowData&&console.warn("ag-grid: since version 12.x, floatingTopRowData is now called pinnedTopRowData"),t.floatingBottomRowData&&console.warn("ag-grid: since version 12.x, floatingBottomRowData is now called pinnedBottomRowData"),t.paginationStartPage&&console.warn("ag-grid: since version 12.x, paginationStartPage is gone, please call api.paginationGoToPage("+t.paginationStartPage+") instead."),t.getHeaderCellTemplate&&console.warn("ag-grid: since version 15.x, getHeaderCellTemplate is gone, please check the header documentation on how to set header templates."),t.headerCellTemplate&&console.warn("ag-grid: since version 15.x, headerCellTemplate is gone, please check the header documentation on how to set header templates."),t.headerCellRenderer&&console.warn("ag-grid: since version 15.x, headerCellRenderer is gone, please check the header documentation on how to set header templates."),t.angularCompileHeaders&&console.warn("ag-grid: since version 15.x, angularCompileHeaders is gone, please see the getting started for Angular 1 docs to see how to do headers in Angular 1.x."),t.pivotTotals&&(console.warn("ag-grid: since version 18.x, pivotTotals has been removed, instead if using pivotTotals, set pivotColumnGroupTotals='before'|'after'."),t.pivotColumnGroupTotals="before"),"inMemory"===t.rowModelType&&(console.warn("ag-grid: since version 18.x, The In Memory Row Model has been renamed to the Client Side Row Model, set rowModelType='clientSide' instead."),t.rowModelType="clientSide"),"enterprise"===t.rowModelType&&(console.warn("ag-grid: since version 18.x, The Enterprise Row Model has been renamed to the Server Side Row Model, set rowModelType='serverSide' instead."),t.rowModelType="serverSide"),t.layoutInterval&&console.warn("ag-grid: since version 18.x, layoutInterval is no longer a property. This is because the grid now uses CSS Flex for layout."),t.gridAutoHeight&&(console.warn("ag-grid: since version 19.x, gridAutoHeight is gone, please use domLayout=autoHeight instead"),t.domLayout="autoHeight"),!0===t.showToolPanel&&(console.warn("ag-grid: since version 19.x, showToolPanel is gone, please specify toolPanel components. See https://www.ag-grid.com/javascript-grid-tool-panel/"),t.showToolPanel=void 0,t.sideBar=t.sideBar||!0),!1===t.showToolPanel&&(console.warn("ag-grid: since version 19.x, showToolPanel is gone, please specify toolPanel components. See https://www.ag-grid.com/javascript-grid-tool-panel/"),t.showToolPanel=void 0,t.sideBar=t.sideBar||!1);var o={toolPanelSuppressRowGroups:"suppressRowGroups",toolPanelSuppressValues:"suppressValues",toolPanelSuppressPivots:"suppressPivots",toolPanelSuppressPivotMode:"suppressPivotMode",toolPanelSuppressColumnFilter:"suppressColumnFilter",toolPanelSuppressColumnSelectAll:"suppressColumnSelectAll",toolPanelSuppressSideButtons:"suppressSideButtons",toolPanelSuppressColumnExpandAll:"suppressColumnExpandAll",contractColumnSelection:"contractColumnSelection"},r={};Object.keys(o).forEach((function(t){var a=o[t],n=e.gridOptions[t];if(void 0!==n){if("toolPanelSuppressSideButtons"===t)return void console.warn("ag-grid: since v19.0 toolPanelSuppressSideButtons has been completely removed. See https://www.ag-grid.com/javascript-grid-tool-panel/");console.warn("ag-grid: since v19.0 gridOptions."+t+" is deprecated, please use gridOptions.sideBar.toolPanel[columnsIndex].componentParams."+a),r[a]=n}})),Object.keys(r).length>0&&!u.f.exists(t.sideBar)&&(console.warn("ag-grid: since version 19.x, sideBar is mandatory if using toolPanel related properties. See https://www.ag-grid.com/javascript-grid-tool-panel/"),t.sideBar=!0),null!=t.sideBar&&(t.sideBar=p.a.parse(t.sideBar));var a=this.gridOptions.sideBar;if(Object.keys(r).length>0&&a&&a.toolPanels){var n=a.toolPanels.filter((function(e){return"columns"===e.id}));1===n.length&&u.f.mergeDeep(n[0],{componentParams:r})}t.enableStatusBar&&(console.warn("ag-grid: since version 19.x, enableStatusBar is gone, please specify statusBar components"),t.statusBar=t.statusBar||{components:[{component:"agAggregationComponent"}]}),t.alwaysShowStatusBar&&console.warn("ag-grid: since version 19.x, alwaysShowStatusBar is gone. Please specify a min-height on the ag-status-bar css class, eg .ag-status-bar {min-height: 35px; }"),(t.enableServerSideSorting||t.enableSorting)&&(console.warn("ag-Grid: since v20, grid options enableSorting and enableServerSideSorting are gone. Instead set sortable=true on the column definition for the columns sorting are allowed on. To migrate from gridOption.enableSorting=true, set gridOptions.defaultColDef.sortable=true"),t.defaultColDef||(t.defaultColDef={}),t.defaultColDef.sortable||(t.defaultColDef.sortable=!0)),(t.enableFilter||t.enableServerSideFilter)&&(console.warn("ag-Grid: since v20, grid options enableFilter and enableServerSideFilter are gone. Instead set filter=true (if not already specifying a specific filter) on the column definition for the columns filtering is allowed on. To migrate from gridOptions.enableFilter=true, set gridOptions.defaultColDef.filter=true. If you are explicitly setting specific filters for each column (ie colDef.filter is already set) the you don't need to do anything."),t.defaultColDef||(t.defaultColDef={}),t.defaultColDef.filter||(t.defaultColDef.filter=!0)),t.enableColResize&&(console.warn("ag-Grid: since v20, grid options enableColResize is gone. Instead set resizable=true on the column definition for the columns resizing are allowed on. To migrate from gridOption.enableColResize=true, set gridOptions.defaultColDef.resizable=true"),t.defaultColDef||(t.defaultColDef={}),t.defaultColDef.resizable||(t.defaultColDef.resizable=!0)),t.deprecatedEmbedFullWidthRows&&console.warn("ag-Grid: since v21.2, deprecatedEmbedFullWidthRows has been replaced with embedFullWidthRows."),t.suppressTabbing&&console.warn("ag-Grid: since v20.1, suppressTabbing is replaced with the more powerful grid callback suppressKeyboardEvent(params) which can suppress any keyboard event including tabbing."),t.doesDataFlower&&console.warn("ag-Grid: since v21.1, doesDataFlower is deprecated. Master/Detail is the new way for showing child data for a row and was introduced over a year ago. Please migrate your code to use master/detail instead."),t.enableOldSetFilterModel&&console.warn("ag-Grid: since v22.x, enableOldSetFilterModel is deprecated. Please move to the new Set Filter Model as the old one may not be supported in v23 onwards."),t.floatingFilter&&(console.warn("ag-Grid: since v23.1, floatingFilter on the gridOptions is deprecated. Please use floatingFilter on the colDef instead."),t.defaultColDef||(t.defaultColDef={}),null==t.defaultColDef.floatingFilter&&(t.defaultColDef.floatingFilter=!0));var i=function(e,o,r){null!=t[e]&&(console.warn("ag-grid: since version "+r+", '"+e+"' is deprecated / renamed, please use the new property name '"+o+"' instead."),null==t[o]&&(t[o]=t[e]))};i("batchUpdateWaitMillis","asyncTransactionWaitMillis","23.1.x"),i("deltaRowDataMode","immutableData","23.1.x"),i("deltaColumnMode","immutableColumns","23.1.x")},e.prototype.checkForViolations=function(){this.isTreeData()&&this.treeDataViolations()},e.prototype.treeDataViolations=function(){this.isRowModelDefault()&&u.f.missing(this.getDataPathFunc())&&console.warn("ag-Grid: property usingTreeData=true with rowModel=clientSide, but you did not provide getDataPath function, please provide getDataPath function if using tree data."),this.isRowModelServerSide()&&(u.f.missing(this.getIsServerSideGroupFunc())&&console.warn("ag-Grid: property usingTreeData=true with rowModel=serverSide, but you did not provide isServerSideGroup function, please provide isServerSideGroup function if using tree data."),u.f.missing(this.getServerSideGroupKeyFunc())&&console.warn("ag-Grid: property usingTreeData=true with rowModel=serverSide, but you did not provide getServerSideGroupKey function, please provide getServerSideGroupKey function if using tree data."))},e.prototype.getLocaleTextFunc=function(){if(this.gridOptions.localeTextFunc)return this.gridOptions.localeTextFunc;var e=this.gridOptions.localeText;return function(t,o){return e&&e[t]?e[t]:o}},e.prototype.globalEventHandler=function(e,t){var o=n.a.getCallbackForEvent(e);"function"==typeof this.gridOptions[o]&&this.gridOptions[o](t)},e.prototype.getRowHeightAsNumber=function(){return!this.gridOptions.rowHeight||u.f.missing(this.gridOptions.rowHeight)?this.getDefaultRowHeight():this.gridOptions.rowHeight&&this.isNumeric(this.gridOptions.rowHeight)?this.gridOptions.rowHeight:(console.warn("ag-Grid row height must be a number if not using standard row model"),this.getDefaultRowHeight())},e.prototype.getRowHeightForNode=function(e,t){if(void 0===t&&(t=!1),"function"==typeof this.gridOptions.getRowHeight){if(t)return{height:this.getDefaultRowHeight(),estimated:!0};var o={node:e,data:e.data,api:this.gridOptions.api,context:this.gridOptions.context},r=this.gridOptions.getRowHeight(o);if(null!=r)return{height:r,estimated:!1}}if(e.detail&&this.isMasterDetail())return this.isNumeric(this.gridOptions.detailRowHeight)?{height:this.gridOptions.detailRowHeight,estimated:!1}:{height:300,estimated:!1};var a=this.getDefaultRowHeight(),n=this.gridOptions.rowHeight&&this.isNumeric(this.gridOptions.rowHeight)?this.gridOptions.rowHeight:a,i=Math.min(a,n);if(this.columnController.isAutoRowHeightActive()){if(t)return{height:n,estimated:!0};var l=this.autoHeightCalculator.getPreferredHeightForRow(e);return{height:Math.max(l,i),estimated:!1}}return{height:n,estimated:!1}},e.prototype.isDynamicRowHeight=function(){return"function"==typeof this.gridOptions.getRowHeight},e.prototype.getListItemHeight=function(){return this.getFromTheme(20,"listItemHeight")},e.prototype.chartMenuPanelWidth=function(){return this.environment.chartMenuPanelWidth()},e.prototype.isNumeric=function(e){return!isNaN(e)&&"number"==typeof e},e.prototype.getFromTheme=function(e,t){var o=this.environment.getTheme().theme;return o&&0===o.indexOf("ag-theme")?this.environment.getSassVariable(o,t):e},e.prototype.getDefaultRowHeight=function(){return this.getFromTheme(25,"rowHeight")},e.MIN_COL_WIDTH=10,e.PROP_HEADER_HEIGHT="headerHeight",e.PROP_GROUP_REMOVE_SINGLE_CHILDREN="groupRemoveSingleChildren",e.PROP_GROUP_REMOVE_LOWEST_SINGLE_CHILDREN="groupRemoveLowestSingleChildren",e.PROP_PIVOT_HEADER_HEIGHT="pivotHeaderHeight",e.PROP_SUPPRESS_CLIPBOARD_PASTE="suppressClipboardPaste",e.PROP_GROUP_HEADER_HEIGHT="groupHeaderHeight",e.PROP_PIVOT_GROUP_HEADER_HEIGHT="pivotGroupHeaderHeight",e.PROP_FLOATING_FILTERS_HEIGHT="floatingFiltersHeight",e.PROP_SUPPRESS_ROW_CLICK_SELECTION="suppressRowClickSelection",e.PROP_SUPPRESS_ROW_DRAG="suppressRowDrag",e.PROP_SUPPRESS_MOVE_WHEN_ROW_DRAG="suppressMoveWhenRowDragging",e.PROP_POPUP_PARENT="popupParent",e.PROP_DOM_LAYOUT="domLayout",h([Object(i.a)("gridOptions")],e.prototype,"gridOptions",void 0),h([Object(i.a)("columnController")],e.prototype,"columnController",void 0),h([Object(i.a)("eventService")],e.prototype,"eventService",void 0),h([Object(i.a)("environment")],e.prototype,"environment",void 0),h([Object(i.a)("autoHeightCalculator")],e.prototype,"autoHeightCalculator",void 0),h([f(0,Object(i.h)("gridApi")),f(1,Object(i.h)("columnApi"))],e.prototype,"agWire",null),h([i.g],e.prototype,"destroy",null),h([i.e],e.prototype,"init",null),e=t=h([Object(i.b)("gridOptionsWrapper")],e)}()},function(e,t,o){"use strict";o.d(t,"a",(function(){return s}));var r=o(23),a=o(4),n=o(1),i=o(2),l=o(0),g=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},s=function(){function e(){this.childrenMapped={},this.selectable=!0,this.__objectId=e.OBJECT_ID_SEQUENCE++,this.alreadyRendered=!1,this.highlighted=null,this.selected=!1}return e.prototype.setData=function(e){var t=this.data;this.data=e,this.valueCache.onDataChanged(),this.updateDataOnDetailNode(),this.checkRowSelectable();var o=this.createDataChangedEvent(e,t,!1);this.dispatchLocalEvent(o)},e.prototype.updateDataOnDetailNode=function(){this.detailNode&&(this.detailNode.data=this.data)},e.prototype.createDataChangedEvent=function(t,o,r){return{type:e.EVENT_DATA_CHANGED,node:this,oldData:o,newData:t,update:r}},e.prototype.createLocalRowEvent=function(e){return{type:e,node:this}},e.prototype.updateData=function(e){var t=this.data;this.data=e,this.updateDataOnDetailNode(),this.checkRowSelectable(),this.updateDataOnDetailNode();var o=this.createDataChangedEvent(e,t,!0);this.dispatchLocalEvent(o)},e.prototype.getRowIndexString=function(){return this.rowPinned===i.a.PINNED_TOP?"t-"+this.rowIndex:this.rowPinned===i.a.PINNED_BOTTOM?"b-"+this.rowIndex:this.rowIndex.toString()},e.prototype.createDaemonNode=function(){var t=new e;return this.context.createBean(t),t.id=this.id,t.data=this.data,t.daemon=!0,t.selected=this.selected,t.level=this.level,t},e.prototype.setDataAndId=function(e,t){var o=l.f.exists(this.id)?this.createDaemonNode():null,r=this.data;this.data=e,this.updateDataOnDetailNode(),this.setId(t),this.selectionController.syncInRowNode(this,o),this.checkRowSelectable();var a=this.createDataChangedEvent(e,r,!1);this.dispatchLocalEvent(a)},e.prototype.checkRowSelectable=function(){var e=this.gridOptionsWrapper.getIsRowSelectableFunc(),t=e&&l.f.exists(this);this.setRowSelectable(!t||e(this))},e.prototype.setRowSelectable=function(t){this.selectable!==t&&(this.selectable=t,this.eventService&&this.eventService.dispatchEvent(this.createLocalRowEvent(e.EVENT_SELECTABLE_CHANGED)))},e.prototype.setId=function(t){var o=this.gridOptionsWrapper.getRowNodeIdFunc();o?this.data?(this.id=o(this.data),this.id&&this.id.startsWith&&this.id.startsWith(e.ID_PREFIX_ROW_GROUP)&&console.error("ag-Grid: Row ID's cannot start with "+e.ID_PREFIX_ROW_GROUP+", this is a reserved prefix for ag-Grid's row grouping feature.")):this.id=void 0:this.id=t},e.prototype.isPixelInRange=function(e){return e>=this.rowTop&&e0},e.prototype.isEmptyRowGroupNode=function(){return this.group&&l.f.missingOrEmpty(this.childrenAfterGroup)},e.prototype.dispatchCellChangedEvent=function(t,o,r){var a={type:e.EVENT_CELL_CHANGED,node:this,column:t,newValue:o,oldValue:r};this.dispatchLocalEvent(a)},e.prototype.resetQuickFilterAggregateText=function(){this.quickFilterAggregateText=null},e.prototype.isExpandable=function(){return this.hasChildren()||this.master},e.prototype.isSelected=function(){return this.footer?this.sibling.isSelected():this.selected},e.prototype.depthFirstSearch=function(e){this.childrenAfterGroup&&this.childrenAfterGroup.forEach((function(t){return t.depthFirstSearch(e)})),e(this)},e.prototype.calculateSelectedFromChildren=function(){var e,t=!1,o=!1,r=!1;if(this.childrenAfterGroup)for(var a=0;a0){this.selectionController.updateGroupsFromChildrenSelections();var c={type:a.a.EVENT_SELECTION_CHANGED,api:this.gridApi,columnApi:this.columnApi};this.mainEventService.dispatchEvent(c)}o&&this.selectionController.setLastSelectedNode(this)}return p},e.prototype.doRowRangeSelection=function(){var e=this.gridOptionsWrapper.isGroupSelectsChildren(),t=this.selectionController.getLastSelectedNode(),o=this.rowModel.getNodesInRangeForSelection(this,t),r=0;o.forEach((function(t){t.group&&e||t.selectThisNode(!0)&&r++})),this.selectionController.updateGroupsFromChildrenSelections();var n={type:a.a.EVENT_SELECTION_CHANGED,api:this.gridApi,columnApi:this.columnApi};return this.mainEventService.dispatchEvent(n),r},e.prototype.isParentOfNode=function(e){for(var t=this.parent;t;){if(t===e)return!0;t=t.parent}return!1},e.prototype.selectThisNode=function(t){var o=!this.selectable&&t,r=this.selected===t;if(o||r)return!1;this.selected=t,this.eventService&&this.dispatchLocalEvent(this.createLocalRowEvent(e.EVENT_ROW_SELECTED));var n=this.createGlobalRowEvent(a.a.EVENT_ROW_SELECTED);return this.mainEventService.dispatchEvent(n),!0},e.prototype.selectChildNodes=function(e,t){var o=t?this.childrenAfterFilter:this.childrenAfterGroup;if(!l.f.missing(o)){for(var r=0,a=0;a0}function l(e){if(e&&e.length)return e[e.length-1]}function g(e,t,o){return null==e&&null==t||null!=e&&null!=t&&e.length===t.length&&k(e,(function(e,r){return o?o(e,t[r]):t[r]===e}))}function s(e,t){return g(e,t)}function p(e,t){return g(e,t)}function c(e){return e.sort((function(e,t){return e-t}))}function d(e,t){if(e)for(var o=e.length-2;o>=0;o--){var r=e[o]===t,a=e[o+1]===t;r&&a&&e.splice(o+1,1)}}function u(e,t){var o=e.indexOf(t);o>=0&&e.splice(o,1)}function h(e,t){E(t,(function(t){return u(e,t)}))}function f(e,t,o){e.splice(o,0,t)}function m(e,t,o){if(null!=e&&null!=t)for(var r=t.length-1;r>=0;r--){f(e,t[r],o)}}function b(e,t,o){h(e,t),E(t.slice().reverse(),(function(t){return f(e,t,o)}))}function v(e,t){return e.indexOf(t)>-1}function y(e){return[].concat.apply([],e)}function w(e,t){null!=t&&null!=e&&E(t,(function(t){return e.push(t)}))}function x(e){return O(e,r.toStringOrNull)}function C(e,t){for(var o=0;ot?1:e=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},g=function(){function e(e,t,o,r){this.displayedChildren=[],this.localEventService=new a.a,this.groupId=t,this.instanceId=o,this.originalColumnGroup=e,this.pinned=r}return e.createUniqueId=function(e,t){return e+"_"+t},e.prototype.reset=function(){this.parent=null,this.children=null,this.displayedChildren=null},e.prototype.getParent=function(){return this.parent},e.prototype.setParent=function(e){this.parent=e},e.prototype.getUniqueId=function(){return e.createUniqueId(this.groupId,this.instanceId)},e.prototype.isEmptyGroup=function(){return 0===this.displayedChildren.length},e.prototype.isMoving=function(){var e=this.getOriginalColumnGroup().getLeafColumns();return!(!e||0===e.length)&&e.every((function(e){return e.isMoving()}))},e.prototype.checkLeft=function(){if(this.displayedChildren.forEach((function(t){t instanceof e&&t.checkLeft()})),this.displayedChildren.length>0)if(this.gridOptionsWrapper.isEnableRtl()){var t=i.f.last(this.displayedChildren).getLeft();this.setLeft(t)}else{var o=this.displayedChildren[0].getLeft();this.setLeft(o)}else this.setLeft(null)},e.prototype.getLeft=function(){return this.left},e.prototype.getOldLeft=function(){return this.oldLeft},e.prototype.setLeft=function(t){this.oldLeft=t,this.left!==t&&(this.left=t,this.localEventService.dispatchEvent(this.createAgEvent(e.EVENT_LEFT_CHANGED)))},e.prototype.getPinned=function(){return this.pinned},e.prototype.createAgEvent=function(e){return{type:e}},e.prototype.addEventListener=function(e,t){this.localEventService.addEventListener(e,t)},e.prototype.removeEventListener=function(e,t){this.localEventService.removeEventListener(e,t)},e.prototype.getGroupId=function(){return this.groupId},e.prototype.getInstanceId=function(){return this.instanceId},e.prototype.isChildInThisGroupDeepSearch=function(t){var o=!1;return this.children.forEach((function(r){t===r&&(o=!0),r instanceof e&&r.isChildInThisGroupDeepSearch(t)&&(o=!0)})),o},e.prototype.getActualWidth=function(){var e=0;return this.displayedChildren&&this.displayedChildren.forEach((function(t){e+=t.getActualWidth()})),e},e.prototype.isResizable=function(){if(!this.displayedChildren)return!1;var e=!1;return this.displayedChildren.forEach((function(t){t.isResizable()&&(e=!0)})),e},e.prototype.getMinWidth=function(){var e=0;return this.displayedChildren.forEach((function(t){e+=t.getMinWidth()})),e},e.prototype.addChild=function(e){this.children||(this.children=[]),this.children.push(e)},e.prototype.getDisplayedChildren=function(){return this.displayedChildren},e.prototype.getLeafColumns=function(){var e=[];return this.addLeafColumns(e),e},e.prototype.getDisplayedLeafColumns=function(){var e=[];return this.addDisplayedLeafColumns(e),e},e.prototype.getDefinition=function(){return this.originalColumnGroup.getColGroupDef()},e.prototype.getColGroupDef=function(){return this.originalColumnGroup.getColGroupDef()},e.prototype.isPadding=function(){return this.originalColumnGroup.isPadding()},e.prototype.isExpandable=function(){return this.originalColumnGroup.isExpandable()},e.prototype.isExpanded=function(){return this.originalColumnGroup.isExpanded()},e.prototype.setExpanded=function(e){this.originalColumnGroup.setExpanded(e)},e.prototype.addDisplayedLeafColumns=function(t){this.displayedChildren.forEach((function(o){o instanceof r.a?t.push(o):o instanceof e&&o.addDisplayedLeafColumns(t)}))},e.prototype.addLeafColumns=function(t){this.children.forEach((function(o){o instanceof r.a?t.push(o):o instanceof e&&o.addLeafColumns(t)}))},e.prototype.getChildren=function(){return this.children},e.prototype.getColumnGroupShow=function(){return this.originalColumnGroup.getColumnGroupShow()},e.prototype.getOriginalColumnGroup=function(){return this.originalColumnGroup},e.prototype.getPaddingLevel=function(){var e=this.getParent();return this.isPadding()&&e&&e.isPadding()?1+e.getPaddingLevel():0},e.prototype.calculateDisplayedColumns=function(){var t=this;this.displayedChildren=[];var o=this;if(this.isPadding())for(;o.getParent()&&o.isPadding();)o=o.getParent();o.originalColumnGroup.isExpandable()?this.children.forEach((function(r){switch(r.getColumnGroupShow()){case e.HEADER_GROUP_SHOW_OPEN:o.originalColumnGroup.isExpanded()&&t.displayedChildren.push(r);break;case e.HEADER_GROUP_SHOW_CLOSED:o.originalColumnGroup.isExpanded()||t.displayedChildren.push(r);break;default:r instanceof e&&r.isPadding()&&!r.displayedChildren.length||t.displayedChildren.push(r)}})):this.displayedChildren=this.children,this.localEventService.dispatchEvent(this.createAgEvent(e.EVENT_DISPLAYED_CHILDREN_CHANGED))},e.HEADER_GROUP_SHOW_OPEN="open",e.HEADER_GROUP_SHOW_CLOSED="closed",e.HEADER_GROUP_PADDING="padding",e.EVENT_LEFT_CHANGED="leftChanged",e.EVENT_DISPLAYED_CHILDREN_CHANGED="displayedChildrenChanged",l([Object(n.a)("gridOptionsWrapper")],e.prototype,"gridOptionsWrapper",void 0),e}()},function(e,t,o){"use strict";o.d(t,"a",(function(){return i}));var r,a=o(14),n=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),i=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return n(t,e),t.prototype.setParams=function(t){e.prototype.setParams.call(this,t),this.scalarFilterParams=t,this.checkDeprecatedParams()},t.prototype.checkDeprecatedParams=function(){this.scalarFilterParams.nullComparator&&(console.warn("ag-Grid: Since v21.0, the property filterParams.nullComparator is deprecated. Please use filterParams.includeBlanksInEquals, filterParams.includeBlanksInLessThan and filterParams.includeBlanksInGreaterThan instead."),this.scalarFilterParams.includeBlanksInEquals=this.scalarFilterParams.nullComparator.equals,this.scalarFilterParams.includeBlanksInLessThan=this.scalarFilterParams.nullComparator.lessThan,this.scalarFilterParams.includeBlanksInGreaterThan=this.scalarFilterParams.nullComparator.greaterThan)},t.prototype.nullComparator=function(e,o,r){if(null==r)switch(e){case t.EMPTY:return 0;case t.EQUALS:return this.scalarFilterParams.includeBlanksInEquals?0:1;case t.NOT_EQUAL:return this.scalarFilterParams.includeBlanksInEquals?1:0;case t.GREATER_THAN:case t.GREATER_THAN_OR_EQUAL:return this.scalarFilterParams.includeBlanksInGreaterThan?1:-1;case t.LESS_THAN:case t.LESS_THAN_OR_EQUAL:return this.scalarFilterParams.includeBlanksInLessThan?-1:1}return this.comparator()(o,r)},t.prototype.individualConditionPasses=function(e,o){var r=this.scalarFilterParams.valueGetter(e.node),a=this.mapRangeFromModel(o),n=a.from,i=a.to,l=o.type,g=this.optionsFactory.getCustomOption(l);if(g&&(null!=n||g.hideFilterInput))return g.test(n,r);var s=this.nullComparator(l,n,r);switch(l){case t.EQUALS:return 0===s;case t.NOT_EQUAL:return 0!==s;case t.GREATER_THAN:return s>0;case t.GREATER_THAN_OR_EQUAL:return s>=0;case t.LESS_THAN:return s<0;case t.LESS_THAN_OR_EQUAL:return s<=0;case t.IN_RANGE:var p=this.nullComparator(l,i,r);return this.scalarFilterParams.inRangeInclusive?s>=0&&p<=0:s>0&&p<0;default:throw new Error("Unexpected type of filter: "+l)}},t}(a.b)},function(e,t,o){"use strict";o.d(t,"a",(function(){return l}));var r,a=o(67),n=o(8),i=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),l=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.disabled=!1,t}return i(t,e),t.prototype.postConstruct=function(){e.prototype.postConstruct.call(this),Object(n.addCssClass)(this.getGui(),this.className)},t.prototype.onValueChange=function(e){var o=this;return this.addManagedListener(this,t.EVENT_CHANGED,(function(){return e(o.getValue())})),this},t.prototype.getWidth=function(){return this.getGui().clientWidth},t.prototype.setWidth=function(e){return Object(n.setFixedWidth)(this.getGui(),e),this},t.prototype.getValue=function(){return this.value},t.prototype.setValue=function(e,o){return this.value===e||(this.value=e,o||this.dispatchEvent({type:t.EVENT_CHANGED})),this},t.prototype.setDisabled=function(e){e=!!e;var t=this.getGui();return Object(n.setDisabled)(t,e),Object(n.addOrRemoveCssClass)(t,"ag-disabled",e),this.disabled=e,this},t.prototype.isDisabled=function(){return!!this.disabled},t.EVENT_CHANGED="valueChange",t}(a.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return i}));var r=o(1),a=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},n=function(e,t){return function(o,r){t(o,r,e)}},i=function(){function e(){this.allSyncListeners=new Map,this.allAsyncListeners=new Map,this.globalSyncListeners=new Set,this.globalAsyncListeners=new Set,this.asyncFunctionsQueue=[],this.scheduled=!1,this.firedEvents={}}return e.prototype.setBeans=function(e,t,o){if(void 0===o&&(o=null),this.logger=e.create("EventService"),o){var r=t.useAsyncEvents();this.addGlobalListener(o,r)}},e.prototype.getListeners=function(e,t){var o=t?this.allAsyncListeners:this.allSyncListeners,r=o.get(e);return r||(r=new Set,o.set(e,r)),r},e.prototype.addEventListener=function(e,t,o){void 0===o&&(o=!1),this.getListeners(e,o).add(t)},e.prototype.removeEventListener=function(e,t,o){void 0===o&&(o=!1),this.getListeners(e,o).delete(t)},e.prototype.addGlobalListener=function(e,t){void 0===t&&(t=!1),(t?this.globalAsyncListeners:this.globalSyncListeners).add(e)},e.prototype.removeGlobalListener=function(e,t){void 0===t&&(t=!1),(t?this.globalAsyncListeners:this.globalSyncListeners).delete(e)},e.prototype.dispatchEvent=function(e){this.dispatchToListeners(e,!0),this.dispatchToListeners(e,!1),this.firedEvents[e.type]=!0},e.prototype.dispatchEventOnce=function(e){this.firedEvents[e.type]||this.dispatchEvent(e)},e.prototype.dispatchToListeners=function(e,t){var o=this,r=e.type;this.getListeners(r,t).forEach((function(r){t?o.dispatchAsync((function(){return r(e)})):r(e)})),(t?this.globalAsyncListeners:this.globalSyncListeners).forEach((function(a){t?o.dispatchAsync((function(){return a(r,e)})):a(r,e)}))},e.prototype.dispatchAsync=function(e){this.asyncFunctionsQueue.push(e),this.scheduled||(window.setTimeout(this.flushAsyncQueue.bind(this),0),this.scheduled=!0)},e.prototype.flushAsyncQueue=function(){this.scheduled=!1;var e=this.asyncFunctionsQueue.slice();this.asyncFunctionsQueue=[],e.forEach((function(e){return e()}))},a([n(0,Object(r.h)("loggerFactory")),n(1,Object(r.h)("gridOptionsWrapper")),n(2,Object(r.h)("globalEventListener"))],e.prototype,"setBeans",null),e=a([Object(r.b)("eventService")],e)}()},function(e,t,o){"use strict";o.d(t,"a",(function(){return n}));var r=o(23),a=o(0),n=function(){function e(e,t){var o=this;void 0===t&&(t=!1),this.destroyFuncs=[],this.touching=!1,this.eventService=new r.a,this.eElement=e,this.preventMouseClick=t;var a=this.onTouchStart.bind(this),n=this.onTouchMove.bind(this),i=this.onTouchEnd.bind(this);this.eElement.addEventListener("touchstart",a,{passive:!0}),this.eElement.addEventListener("touchmove",n,{passive:!0}),this.eElement.addEventListener("touchend",i,{passive:!1}),this.destroyFuncs.push((function(){o.eElement.removeEventListener("touchstart",a,{passive:!0}),o.eElement.removeEventListener("touchmove",n,{passive:!0}),o.eElement.removeEventListener("touchend",i,{passive:!1})}))}return e.prototype.getActiveTouch=function(e){for(var t=0;t0)if(t-this.lastTapTime>e.DOUBLE_TAP_MILLIS){var o={type:e.EVENT_DOUBLE_TAP,touchStart:this.touchStart};this.eventService.dispatchEvent(o),this.lastTapTime=null}else this.lastTapTime=t;else this.lastTapTime=t},e.prototype.destroy=function(){this.destroyFuncs.forEach((function(e){return e()}))},e.EVENT_TAP="tap",e.EVENT_DOUBLE_TAP="doubleTap",e.EVENT_LONG_TAP="longTap",e.DOUBLE_TAP_MILLIS=500,e}()},function(e,t,o){"use strict";var r,a,n,i,l,g;function s(){return void 0===a&&(a=!!document.documentMode),a}function p(){return void 0===n&&(n=!s()&&!!window.StyleMedia),n}function c(){if(void 0===r){var e=window;r=Object.prototype.toString.call(e.HTMLElement).indexOf("Constructor")>0||(t=e.safari&&e.safari.pushNotification)&&"[object SafariRemoteNotification]"===t.toString()}var t;return r}function d(){if(void 0===i){var e=window;i=!!e.chrome&&(!!e.chrome.webstore||!!e.chrome.runtime)||/Chrome/.test(navigator.userAgent)&&/Google Inc/.test(navigator.vendor)}return i}function u(){if(void 0===l){var e=window;l=void 0!==e.InstallTrigger}return l}function h(){return void 0===g&&(g=(/iPad|iPhone|iPod/.test(navigator.platform)||"MacIntel"===navigator.platform&&navigator.maxTouchPoints>1)&&!window.MSStream),g}function f(e){if(!e)return null;var t=e.tabIndex,o=e.getAttribute("tabIndex");if(s()&&0===t&&null===e.getAttribute("tabIndex")){return!0==={a:!0,body:!0,button:!0,frame:!0,iframe:!0,img:!0,input:!0,isindex:!0,object:!0,select:!0,textarea:!0}[e.nodeName.toLowerCase()]?"0":null}return-1!==t||null!==o&&(""!==o||u())?t.toString():null}function m(){if(!document.body)return-1;var e=1e6,t=navigator.userAgent.toLowerCase().match(/firefox/)?6e6:1e9,o=document.createElement("div");for(document.body.appendChild(o);;){var r=2*e;if(o.style.height=r+"px",r>t||o.clientHeight!==r)break;e=r}return document.body.removeChild(o),e}function b(){var e=document.body,t=document.createElement("div");t.style.width=t.style.height="100px",t.style.opacity="0",t.style.overflow="scroll",t.style.msOverflowStyle="scrollbar",t.style.position="absolute",e.appendChild(t);var o=t.offsetWidth-t.clientWidth;return t.parentNode&&t.parentNode.removeChild(t),o}function v(){var e=["webkit","moz","o","ms"],t=document.createElement("div"),o=!1;document.getElementsByTagName("body")[0].appendChild(t),t.setAttribute("style",e.map((function(e){return"-"+e+"-overflow-scrolling: touch"})).concat("overflow-scrolling: touch").join(";"));var r=window.getComputedStyle(t);if("touch"===r.overflowScrolling&&(o=!0),!o)for(var a=0,n=e;a=0&&p<24&&g.setHours(p),c>=0&&c<60&&g.setMinutes(c),d>=0&&d<60&&g.setSeconds(d),g}},function(e,t,o){"use strict";var r,a=function(){return void 0===r&&(r=Boolean(window&&document&&document.all&&!window.atob)),r},n=function(){var e={};return function(t){if(void 0===e[t]){var o=document.querySelector(t);if(window.HTMLIFrameElement&&o instanceof window.HTMLIFrameElement)try{o=o.contentDocument.head}catch(e){o=null}e[t]=o}return e[t]}}(),i=[];function l(e){for(var t=-1,o=0;o=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.skipTabGuardFocus=!1,t}return g(t,e),t.prototype.postConstruct=function(){this.getFocusableElement()&&this.wireFocusManagement()},t.prototype.wireFocusManagement=function(){var e=this,o=this.getFocusableElement();l.f.addCssClass(o,t.FOCUS_MANAGED_CLASS),this.isFocusableContainer()&&(this.topTabGuard=this.createTabGuard("top"),this.bottomTabGuard=this.createTabGuard("bottom"),this.addTabGuards(),this.activateTabGuards(),this.forEachTabGuard((function(t){e.addManagedListener(t,"focus",e.onFocus.bind(e))}))),(this.onTabKeyDown||this.handleKeyDown)&&this.addKeyDownListeners(o),this.addManagedListener(o,"focusin",this.onFocusIn.bind(this)),this.addManagedListener(o,"focusout",this.onFocusOut.bind(this))},t.prototype.isFocusableContainer=function(){return!1},t.prototype.focusInnerElement=function(e){var t=this.focusController.findFocusableElements(this.getFocusableElement(),'.ag-tab-guard, :not([tabindex="-1"])');t.length&&t[e?t.length-1:0].focus()},t.prototype.onFocusIn=function(e){this.isFocusableContainer()&&this.deactivateTabGuards()},t.prototype.onFocusOut=function(e){this.isFocusableContainer()&&(this.getFocusableElement().contains(e.relatedTarget)||this.activateTabGuards())},t.prototype.forceFocusOutOfContainer=function(){this.activateTabGuards(),this.skipTabGuardFocus=!0,this.bottomTabGuard.focus()},t.prototype.appendChild=function(t,o){if(this.isFocusableContainer()){l.f.isNodeOrElement(t)||(t=t.getGui());var r=this.bottomTabGuard;r?r.insertAdjacentElement("beforebegin",t):e.prototype.appendChild.call(this,t,o)}else e.prototype.appendChild.call(this,t,o)},t.prototype.createTabGuard=function(e){var t=document.createElement("div");return t.classList.add("ag-tab-guard"),t.classList.add("ag-tab-guard-"+e),t},t.prototype.addTabGuards=function(){var e=this.getFocusableElement();e.insertAdjacentElement("afterbegin",this.topTabGuard),e.insertAdjacentElement("beforeend",this.bottomTabGuard)},t.prototype.forEachTabGuard=function(e){[this.topTabGuard,this.bottomTabGuard].forEach(e)},t.prototype.addKeyDownListeners=function(e){var t=this;this.addManagedListener(e,"keydown",(function(e){e.defaultPrevented||(e.keyCode===i.a.KEY_TAB&&t.onTabKeyDown?t.onTabKeyDown(e):t.handleKeyDown&&t.handleKeyDown(e))}))},t.prototype.onFocus=function(e){this.isFocusableContainer()&&(this.skipTabGuardFocus?this.skipTabGuardFocus=!1:this.focusInnerElement(e.target===this.bottomTabGuard))},t.prototype.activateTabGuards=function(){this.forEachTabGuard((function(e){return e.setAttribute("tabIndex","0")}))},t.prototype.deactivateTabGuards=function(){this.forEachTabGuard((function(e){return e.removeAttribute("tabindex")}))},t.FOCUS_MANAGED_CLASS="ag-focus-managed",s([Object(a.a)("focusController")],t.prototype,"focusController",void 0),s([a.e],t.prototype,"postConstruct",null),t}(n.a)},function(e,t,o){"use strict";o.r(t),o.d(t,"iterateObject",(function(){return n})),o.d(t,"cloneObject",(function(){return i})),o.d(t,"deepCloneObject",(function(){return l})),o.d(t,"getProperty",(function(){return g})),o.d(t,"setProperty",(function(){return s})),o.d(t,"copyPropertiesIfPresent",(function(){return p})),o.d(t,"copyPropertyIfPresent",(function(){return c})),o.d(t,"getAllKeysInObjects",(function(){return d})),o.d(t,"mergeDeep",(function(){return u})),o.d(t,"assign",(function(){return h})),o.d(t,"missingOrEmptyObject",(function(){return f})),o.d(t,"get",(function(){return m})),o.d(t,"set",(function(){return b})),o.d(t,"deepFreeze",(function(){return v})),o.d(t,"getValueUsingField",(function(){return y}));var r=o(18),a=o(17);function n(e,t){null!=e&&(Array.isArray(e)?Object(a.forEach)(e,(function(e,o){return t(""+o,e)})):Object(a.forEach)(Object.keys(e),(function(o){return t(o,e[o])})))}function i(e){for(var t={},o=Object.keys(e),r=0;r1;)if(null==(a=a[r.shift()]))return o;var n=a[r[0]];return null!=n?n:o}function b(e,t,o){if(null!=e){for(var r=t.split("."),a=e;r.length>1;)if(null==(a=a[r.shift()]))return;a[r[0]]=o}}function v(e){return Object.freeze(e),Object(a.forEach)(Object(r.values)(e),(function(e){null==e||"object"!=typeof e&&"function"!=typeof e||v(e)})),e}function y(e,t,o){if(t&&e){if(!o)return e[t];for(var a=t.split("."),n=e,i=0;i=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},C=function(e){function t(o,r,a){var n=e.call(this,t.TEMPLATE)||this;return n.removeChildListenersFuncs=[],n.column=o,n.dragSourceDropTarget=r,n.pinned=a,n}return w(t,e),t.prototype.postConstruct=function(){e.prototype.postConstruct.call(this),u.a.addHeaderClassesFromColDef(this.getComponentHolder(),this.getGui(),this.gridOptionsWrapper,null,this.column);var t=this.columnController.getDisplayNameForColumnGroup(this.column,"header");this.appendHeaderGroupComp(t),this.setupResize(),this.addClasses(),this.setupWidth(),this.addAttributes(),this.setupMovingCss(),this.setupTooltip(),this.createManagedBean(new m.a(this.column.getOriginalColumnGroup().getLeafColumns(),this.getGui())),this.createManagedBean(new f.a(this.column,this.getGui(),this.beans))},t.prototype.onFocusIn=function(e){if(!this.getGui().contains(e.relatedTarget)){var t=this.getParentComponent();this.beans.focusController.setFocusedHeader(t.getRowIndex(),this.getColumn())}},t.prototype.handleKeyDown=function(e){var t=document.activeElement===this.getGui();switch(e.keyCode){case d.a.KEY_ENTER:if(t){var o=this.getColumn();if(o.isExpandable()){var r=!o.isExpanded();this.columnController.setColumnGroupOpened(o.getOriginalColumnGroup(),r,"uiColumnExpanded")}}}},t.prototype.setupMovingCss=function(){var e=this;this.column.getOriginalColumnGroup().getLeafColumns().forEach((function(t){e.addManagedListener(t,p.a.EVENT_MOVING_CHANGED,e.onColumnMovingChanged.bind(e))})),this.onColumnMovingChanged()},t.prototype.getComponentHolder=function(){return this.column.getColGroupDef()},t.prototype.getTooltipText=function(){var e=this.getComponentHolder();return e&&e.headerTooltip},t.prototype.setupTooltip=function(){var e=this.getTooltipText();null!=e&&(this.gridOptionsWrapper.isEnableBrowserTooltips()?this.getGui().setAttribute("title",e):this.createManagedBean(new b.a(this,"headerGroup")))},t.prototype.onColumnMovingChanged=function(){y.f.addOrRemoveCssClass(this.getGui(),"ag-header-cell-moving",this.column.isMoving())},t.prototype.addAttributes=function(){this.getGui().setAttribute("col-id",this.column.getUniqueId())},t.prototype.appendHeaderGroupComp=function(e){var t=this,o={displayName:e,columnGroup:this.column,setExpanded:function(e){t.columnController.setColumnGroupOpened(t.column.getOriginalColumnGroup(),e,"gridInitializing")},api:this.gridApi,columnApi:this.columnApi,context:this.gridOptionsWrapper.getContext()};if(!e){for(var r=this.column,a=r.getLeafColumns();r.getParent()&&r.getParent().getLeafColumns().length===a.length;)r=r.getParent();var n=r.getColGroupDef();n&&(e=n.headerName),e||(e=a?this.columnController.getDisplayNameForColumn(a[0],"header",!0):"")}var i=this.afterHeaderCompCreated.bind(this,e);this.userComponentFactory.newHeaderGroupComponent(o).then(i)},t.prototype.afterHeaderCompCreated=function(e,t){var o=this;this.getGui().appendChild(t.getGui()),this.addDestroyFunc((function(){o.getContext().destroyBean(t)})),this.setupMove(t.getGui(),e)},t.prototype.addClasses=function(){var e=this.column.isPadding()?"no":"with";this.addCssClass("ag-header-group-cell-"+e+"-group")},t.prototype.setupMove=function(e,t){var o=this;if(e&&!this.isSuppressMoving()){var r=this.column.getOriginalColumnGroup().getLeafColumns(),a={type:h.b.HeaderCell,eElement:e,defaultIconName:h.a.ICON_HIDE,dragItemName:t,getDragItem:this.getDragItemForGroup.bind(this),dragSourceDropTarget:this.dragSourceDropTarget,onDragStarted:function(){return r.forEach((function(e){return e.setMoving(!0,"uiColumnDragged")}))},onDragStopped:function(){return r.forEach((function(e){return e.setMoving(!1,"uiColumnDragged")}))}};this.dragAndDropService.addDragSource(a,!0),this.addDestroyFunc((function(){return o.dragAndDropService.removeDragSource(a)}))}},t.prototype.getDragItemForGroup=function(){var e=this.column.getOriginalColumnGroup().getLeafColumns(),t={};e.forEach((function(e){return t[e.getId()]=e.isVisible()}));var o=[];return this.columnController.getAllDisplayedColumns().forEach((function(t){e.indexOf(t)>=0&&(o.push(t),y.f.removeFromArray(e,t))})),e.forEach((function(e){return o.push(e)})),{columns:o,visibleState:t}},t.prototype.isSuppressMoving=function(){var e=!1;return this.column.getLeafColumns().forEach((function(t){(t.getColDef().suppressMovable||t.getColDef().lockPosition)&&(e=!0)})),e||this.gridOptionsWrapper.isSuppressMovableColumns()},t.prototype.setupWidth=function(){this.addListenersToChildrenColumns(),this.addManagedListener(this.column,c.a.EVENT_DISPLAYED_CHILDREN_CHANGED,this.onDisplayedChildrenChanged.bind(this)),this.onWidthChanged(),this.addDestroyFunc(this.removeListenersOnChildrenColumns.bind(this))},t.prototype.onDisplayedChildrenChanged=function(){this.addListenersToChildrenColumns(),this.onWidthChanged()},t.prototype.addListenersToChildrenColumns=function(){var e=this;this.removeListenersOnChildrenColumns();var t=this.onWidthChanged.bind(this);this.column.getLeafColumns().forEach((function(o){o.addEventListener(p.a.EVENT_WIDTH_CHANGED,t),o.addEventListener(p.a.EVENT_VISIBLE_CHANGED,t),e.removeChildListenersFuncs.push((function(){o.removeEventListener(p.a.EVENT_WIDTH_CHANGED,t),o.removeEventListener(p.a.EVENT_VISIBLE_CHANGED,t)}))}))},t.prototype.removeListenersOnChildrenColumns=function(){this.removeChildListenersFuncs.forEach((function(e){return e()})),this.removeChildListenersFuncs=[]},t.prototype.onWidthChanged=function(){this.getGui().style.width=this.column.getActualWidth()+"px"},t.prototype.setupResize=function(){var e=this;if(this.eHeaderCellResize=this.getRefElement("agResize"),this.column.isResizable()){var t=this.horizontalResizeService.addResizeBar({eResizeBar:this.eHeaderCellResize,onResizeStart:this.onResizeStart.bind(this),onResizing:this.onResizing.bind(this,!1),onResizeEnd:this.onResizing.bind(this,!0)});if(this.addDestroyFunc(t),!this.gridOptionsWrapper.isSuppressAutoSize()){var o=this.gridOptionsWrapper.isSkipHeaderOnAutoSize();this.eHeaderCellResize.addEventListener("dblclick",(function(t){var r=[];e.column.getDisplayedLeafColumns().forEach((function(e){e.getColDef().suppressAutoSize||r.push(e.getColId())})),r.length>0&&e.columnController.autoSizeColumns(r,o,"uiColumnResized")}))}}else y.f.removeFromParent(this.eHeaderCellResize)},t.prototype.onResizeStart=function(e){var t=this,o=this.column.getDisplayedLeafColumns();this.resizeCols=o.filter((function(e){return e.isResizable()})),this.resizeStartWidth=0,this.resizeCols.forEach((function(e){return t.resizeStartWidth+=e.getActualWidth()})),this.resizeRatios=[],this.resizeCols.forEach((function(e){return t.resizeRatios.push(e.getActualWidth()/t.resizeStartWidth)}));var r=null;if(e&&(r=this.columnController.getDisplayedGroupAfter(this.column)),r){var a=r.getDisplayedLeafColumns();this.resizeTakeFromCols=a.filter((function(e){return e.isResizable()})),this.resizeTakeFromStartWidth=0,this.resizeTakeFromCols.forEach((function(e){return t.resizeTakeFromStartWidth+=e.getActualWidth()})),this.resizeTakeFromRatios=[],this.resizeTakeFromCols.forEach((function(e){return t.resizeTakeFromRatios.push(e.getActualWidth()/t.resizeTakeFromStartWidth)}))}else this.resizeTakeFromCols=null,this.resizeTakeFromStartWidth=null,this.resizeTakeFromRatios=null;y.f.addCssClass(this.getGui(),"ag-column-resizing")},t.prototype.onResizing=function(e,t){var o=[],r=this.normaliseDragChange(t);o.push({columns:this.resizeCols,ratios:this.resizeRatios,width:this.resizeStartWidth+r}),this.resizeTakeFromCols&&o.push({columns:this.resizeTakeFromCols,ratios:this.resizeTakeFromRatios,width:this.resizeTakeFromStartWidth-r}),this.columnController.resizeColumnSets(o,e,"uiColumnDragged"),e&&y.f.removeCssClass(this.getGui(),"ag-column-resizing")},t.prototype.normaliseDragChange=function(e){var t=e;return this.gridOptionsWrapper.isEnableRtl()?this.pinned!==d.a.PINNED_LEFT&&(t*=-1):this.pinned===d.a.PINNED_RIGHT&&(t*=-1),t},t.TEMPLATE='',x([Object(i.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),x([Object(i.a)("columnController")],t.prototype,"columnController",void 0),x([Object(i.a)("horizontalResizeService")],t.prototype,"horizontalResizeService",void 0),x([Object(i.a)("dragAndDropService")],t.prototype,"dragAndDropService",void 0),x([Object(i.a)("userComponentFactory")],t.prototype,"userComponentFactory",void 0),x([Object(i.a)("beans")],t.prototype,"beans",void 0),x([Object(i.a)("gridApi")],t.prototype,"gridApi",void 0),x([Object(i.a)("columnApi")],t.prototype,"columnApi",void 0),t}(v.a),k=o(5),A=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),E=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},O=function(e){function t(){return e.call(this,'\n ')||this}return A(t,e),t.prototype.destroy=function(){e.prototype.destroy.call(this)},t.prototype.init=function(e){this.params=e;var t=this.columnController.getDisplayNameForColumn(e.column,"header",!0);this.eFloatingFilterText.setDisabled(!0).setInputAriaLabel(t+" Filter Input")},t.prototype.onParentModelChanged=function(e){var t=this;e?this.params.parentFilterInstance((function(o){if(o.getModelAsString){var r=o.getModelAsString(e);t.eFloatingFilterText.setValue(r)}})):this.eFloatingFilterText.setValue("")},E([Object(k.d)("eFloatingFilterText")],t.prototype,"eFloatingFilterText",void 0),E([Object(i.a)("columnController")],t.prototype,"columnController",void 0),t}(n.a),R=o(10),S=o(11),T=o(8),P=o(133),D=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),N=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},F=function(e){function t(o,r){var a=e.call(this,t.TEMPLATE)||this;return a.column=o,a.pinned=r,a}return D(t,e),t.prototype.postConstruct=function(){e.prototype.postConstruct.call(this),this.setupFloatingFilter(),this.setupWidth(),this.setupLeftPositioning(),this.setupColumnHover(),this.createManagedBean(new m.a([this.column],this.getGui())),this.addManagedListener(this.eButtonShowMainFilter,"click",this.showParentFilter.bind(this))},t.prototype.onTabKeyDown=function(e){var t=document.activeElement,o=this.getGui();if(!(t===o)){e.preventDefault();var r=this.focusController.findNextFocusableElement(o,null,e.shiftKey);r?r.focus():o.focus()}},t.prototype.handleKeyDown=function(e){var t=document.activeElement,o=this.getGui(),r=t===o;switch(e.keyCode){case d.a.KEY_UP:case d.a.KEY_DOWN:r||e.preventDefault();case d.a.KEY_LEFT:case d.a.KEY_RIGHT:if(r)return;e.stopPropagation();case d.a.KEY_ENTER:r&&this.focusController.focusFirstFocusableElement(o)&&e.preventDefault();break;case d.a.KEY_ESCAPE:r||this.getGui().focus()}},t.prototype.onFocusIn=function(e){if(!this.getGui().contains(e.relatedTarget)){var t=this.getParentComponent();this.beans.focusController.setFocusedHeader(t.getRowIndex(),this.getColumn())}},t.prototype.setupFloatingFilter=function(){var e=this,t=this.column.getColDef();t.filter&&t.floatingFilter?(this.floatingFilterCompPromise=this.getFloatingFilterInstance(),this.floatingFilterCompPromise?this.floatingFilterCompPromise.then((function(t){t?(e.setupWithFloatingFilter(t),e.setupSyncWithFilter()):e.setupEmpty()})):this.setupEmpty()):this.setupEmpty()},t.prototype.setupLeftPositioning=function(){var e=new f.a(this.column,this.getGui(),this.beans);this.createManagedBean(e)},t.prototype.setupSyncWithFilter=function(){var e=this,t=function(t){var o=e.getFilterComponent().resolveNow(null,(function(e){return e.getModel()}));e.onParentModelChanged(o,t)};this.addManagedListener(this.column,p.a.EVENT_FILTER_CHANGED,t),this.filterManager.isFilterActive(this.column)&&t(null)},t.prototype.showParentFilter=function(){this.menuFactory.showMenuAfterButtonClick(this.column,this.eButtonShowMainFilter,"filterMenuTab",["filterMenuTab"])},t.prototype.setupColumnHover=function(){this.addManagedListener(this.eventService,g.a.EVENT_COLUMN_HOVER_CHANGED,this.onColumnHover.bind(this)),this.onColumnHover()},t.prototype.onColumnHover=function(){Object(T.addOrRemoveCssClass)(this.getGui(),"ag-column-hover",this.columnHoverService.isHovered(this.column))},t.prototype.setupWidth=function(){this.addManagedListener(this.column,p.a.EVENT_WIDTH_CHANGED,this.onColumnWidthChanged.bind(this)),this.onColumnWidthChanged()},t.prototype.onColumnWidthChanged=function(){this.getGui().style.width=this.column.getActualWidth()+"px"},t.prototype.setupWithFloatingFilter=function(e){var t=this,o=function(){t.getContext().destroyBean(e)};if(this.isAlive()){this.addDestroyFunc(o);var r=e.getGui();Object(T.addOrRemoveCssClass)(this.eFloatingFilterBody,"ag-floating-filter-body",!this.suppressFilterButton),Object(T.addOrRemoveCssClass)(this.eFloatingFilterBody,"ag-floating-filter-full-body",this.suppressFilterButton),Object(T.setDisplayed)(this.eButtonWrapper,!this.suppressFilterButton);var a=Object(P.createIconNoSpan)("filter",this.gridOptionsWrapper,this.column);this.eButtonShowMainFilter.appendChild(a),this.eFloatingFilterBody.appendChild(r),e.afterGuiAttached&&e.afterGuiAttached()}else o()},t.prototype.parentFilterInstance=function(e){this.getFilterComponent().then(e)},t.prototype.getFilterComponent=function(){return this.filterManager.getFilterComponent(this.column,"NO_UI")},t.prototype.getFloatingFilterInstance=function(){var e,o=this.column.getColDef();if("string"==typeof o.filter)e=t.filterToFloatingFilterNames[o.filter];else if(o.filterFramework);else if(!0===o.filter){e=S.a.isRegistered(R.a.SetFilterModule)?"agSetColumnFloatingFilter":"agTextColumnFloatingFilter"}var r=this.filterManager.createFilterParams(this.column,this.column.getColDef()),a=this.userComponentFactory.createFinalParams(o,"filter",r),n={api:this.gridApi,column:this.column,filterParams:a,currentParentModel:this.currentParentModel.bind(this),parentFilterInstance:this.parentFilterInstance.bind(this),onFloatingFilterChanged:this.onFloatingFilterChanged.bind(this),suppressFilterButton:!1};this.suppressFilterButton=!!o.floatingFilterComponentParams&&!!o.floatingFilterComponentParams.suppressFilterButton;var i=this.userComponentFactory.newFloatingFilterComponent(o,n,e);if(!i){var l=this.getFilterComponentPrototype(o);if(l&&l.prototype&&l.prototype.getModelAsString){var g=this.userComponentFactory.createUserComponentFromConcreteClass(O,n);i=y.c.resolve(g)}}return i},t.prototype.createDynamicParams=function(){return{column:this.column,colDef:this.column.getColDef(),api:this.gridApi,columnApi:this.columnApi}},t.prototype.getFilterComponentPrototype=function(e){var t=this.userComponentFactory.lookupComponentClassDef(e,"filter",this.createDynamicParams());return t?t.component:null},t.prototype.setupEmpty=function(){Object(T.setDisplayed)(this.eButtonWrapper,!1)},t.prototype.currentParentModel=function(){return this.getFilterComponent().resolveNow(null,(function(e){return e.getModel()}))},t.prototype.onParentModelChanged=function(e,t){this.floatingFilterCompPromise&&this.floatingFilterCompPromise.then((function(o){return o.onParentModelChanged(e,t)}))},t.prototype.onFloatingFilterChanged=function(){console.warn("ag-Grid: since version 21.x, how floating filters are implemented has changed. Instead of calling params.onFloatingFilterChanged(), get a reference to the main filter via params.parentFilterInstance() and then set a value on the parent filter directly.")},t.filterToFloatingFilterNames={set:"agSetColumnFloatingFilter",agSetColumnFilter:"agSetColumnFloatingFilter",number:"agNumberColumnFloatingFilter",agNumberColumnFilter:"agNumberColumnFloatingFilter",date:"agDateColumnFloatingFilter",agDateColumnFilter:"agDateColumnFloatingFilter",text:"agTextColumnFloatingFilter",agTextColumnFilter:"agTextColumnFloatingFilter"},t.TEMPLATE='',N([Object(i.a)("columnHoverService")],t.prototype,"columnHoverService",void 0),N([Object(i.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),N([Object(i.a)("userComponentFactory")],t.prototype,"userComponentFactory",void 0),N([Object(i.a)("gridApi")],t.prototype,"gridApi",void 0),N([Object(i.a)("columnApi")],t.prototype,"columnApi",void 0),N([Object(i.a)("filterManager")],t.prototype,"filterManager",void 0),N([Object(i.a)("menuFactory")],t.prototype,"menuFactory",void 0),N([Object(i.a)("beans")],t.prototype,"beans",void 0),N([Object(k.d)("eFloatingFilterBody")],t.prototype,"eFloatingFilterBody",void 0),N([Object(k.d)("eButtonWrapper")],t.prototype,"eButtonWrapper",void 0),N([Object(k.d)("eButtonShowMainFilter")],t.prototype,"eButtonShowMainFilter",void 0),t}(v.a),M=o(25),I=o(18),G=o(17),L=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),_=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i};!function(e){e[e.COLUMN_GROUP=0]="COLUMN_GROUP",e[e.COLUMN=1]="COLUMN",e[e.FLOATING_FILTER=2]="FLOATING_FILTER"}(a||(a={}));var V=function(e){function t(t,o,r,n){var i=e.call(this,'
')||this;i.headerComps={},i.dept=t,i.type=o,i.pinned=r,i.dropTarget=n;var l=a[o].toLowerCase().replace(/_/g,"-");return i.addCssClass("ag-header-row-"+l),Object(M.isBrowserSafari)()&&(i.getGui().style.transform="translateZ(0)"),i}return L(t,e),t.prototype.forEachHeaderElement=function(e){var t=this;Object.keys(this.headerComps).forEach((function(o){e(t.headerComps[o])}))},t.prototype.setRowIndex=function(e){this.rowIndex=e,this.getGui().setAttribute("aria-rowindex",(e+1).toString())},t.prototype.getRowIndex=function(){return this.rowIndex},t.prototype.getType=function(){return this.type},t.prototype.destroyAllChildComponents=function(){var e=Object.keys(this.headerComps);this.destroyChildComponents(e)},t.prototype.destroyChildComponents=function(e,t){var o=this;e.forEach((function(e){var r=o.headerComps[e];t&&!r.getColumn().isMoving()&&o.focusController.isHeaderWrapperFocused(r)||(o.getGui().removeChild(r.getGui()),o.destroyBean(r),delete o.headerComps[e])}))},t.prototype.onRowHeightChanged=function(){var e,t,o=this.columnController.getHeaderRowCount(),r=[],a=0;this.columnController.isPivotMode()?(e=this.gridOptionsWrapper.getPivotGroupHeaderHeight(),t=this.gridOptionsWrapper.getPivotHeaderHeight()):(this.columnController.hasFloatingFilters()&&(o++,a=1),e=this.gridOptionsWrapper.getGroupHeaderHeight(),t=this.gridOptionsWrapper.getHeaderHeight());for(var n=o-(1+a),i=0;i=0?Object(G.removeFromArray)(t,i):(a=e.createHeaderComp(r),e.headerComps[i]=a,n=a.getGui(),l.appendChild(n)),o.push(i)}})),this.destroyChildComponents(t,!0),this.gridOptionsWrapper.isEnsureDomOrder()){var r=o.map((function(t){return e.headerComps[t].getGui()}));Object(T.setDomChildOrder)(this.getGui(),r)}},t.prototype.createHeaderComp=function(e){var t;switch(this.type){case a.COLUMN:t=new s.a(e,this.dropTarget,this.pinned);break;case a.COLUMN_GROUP:t=new C(e,this.dropTarget,this.pinned);break;case a.FLOATING_FILTER:t=new F(e,this.pinned)}return this.createBean(t),t.setParentComponent(this),t},t.prototype.getHeaderComps=function(){return this.headerComps},_([Object(i.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),_([Object(i.a)("columnController")],t.prototype,"columnController",void 0),_([Object(i.a)("focusController")],t.prototype,"focusController",void 0),_([i.g],t.prototype,"destroyAllChildComponents",null),_([i.e],t.prototype,"init",null),t}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return a}));var r=function(){for(var e=0,t=0,o=arguments.length;t=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i};!function(e){e[e.UP=0]="UP",e[e.DOWN=1]="DOWN",e[e.LEFT=2]="LEFT",e[e.RIGHT=3]="RIGHT"}(a||(a={}));var d=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return p(t,e),t.prototype.registerGridComp=function(e){this.gridPanel=e},t.prototype.registerHeaderRoot=function(e){this.headerRoot=e},t.prototype.getHeaderRowCount=function(){return 0===this.headerRoot.getHeaderContainers().size?0:this.getHeaderContainer().getRowComps().length},t.prototype.getHeaderRowType=function(e){if(this.getHeaderRowCount())return this.getHeaderContainer().getRowComps()[e].getType()},t.prototype.getHeaderContainer=function(e){return void 0===e&&(e="center"),null===e&&(e="center"),this.headerRoot.getHeaderContainers().get(e)},t.prototype.navigateVertically=function(e,t){if(t||(t=this.focusController.getFocusedHeader()),!t)return!1;var o=t.headerRowIndex,r=t.column,n=this.getHeaderRowCount(),i=e===a.UP,l=i?o-1:o+1;if(l<0)return!1;if(l>=n)return this.focusController.focusGridView();var s,p=this.getHeaderRowType(o);if(p===g.b.COLUMN_GROUP){var c=r;s=i?r.getParent():c.getDisplayedChildren()[0]}else if(p===g.b.FLOATING_FILTER)s=r;else{c=r;s=i?c.getParent():c}return!!s&&(this.focusController.focusHeaderPosition({headerRowIndex:l,column:s}),!0)},t.prototype.navigateHorizontally=function(e,t){var o,r,n=this.focusController.getFocusedHeader();return e===a.LEFT!==this.gridOptionsWrapper.isEnableRtl()?(r="Before",o=this.headerPositionUtils.findHeader(n,r)):(r="After",o=this.headerPositionUtils.findHeader(n,r)),o?(this.focusController.focusHeaderPosition(o,r),!0):!t||this.focusNextHeaderRow(n,r)},t.prototype.focusNextHeaderRow=function(e,t){var o,r,a=e.headerRowIndex;if("Before"===t){if(0===a)return!1;r=a-1,o=this.headerPositionUtils.findColAtEdgeForHeaderRow(r,"end")}else r=a+1,o=this.headerPositionUtils.findColAtEdgeForHeaderRow(r,"start");return!!o&&(-1===o.headerRowIndex?this.focusController.focusGridView(o.column):this.focusController.focusHeaderPosition(o,t))},t.prototype.scrollToColumn=function(e,t){if(void 0===t&&(t="After"),!e.getPinned()){var o;if(e instanceof l.a){var r=e.getDisplayedLeafColumns();o="Before"===t?s.f.last(r):r[0]}else o=e;this.gridPanel.ensureColumnVisible(o),this.gridPanel.horizontallyScrollHeaderCenterAndFloatingCenter(),this.animationFrameService.flushAllFrames()}},c([Object(n.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),c([Object(n.a)("focusController")],t.prototype,"focusController",void 0),c([Object(n.a)("headerPositionUtils")],t.prototype,"headerPositionUtils",void 0),c([Object(n.a)("animationFrameService")],t.prototype,"animationFrameService",void 0),t=c([Object(n.b)("headerNavigationService")],t)}(i.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return S}));var r,a=o(2),n=o(4),i=o(7),l=o(53),g=o(38),s=o(1),p=o(16),c=o(13),d=o(9),u=o(6),h=o(0),f=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),m=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},b=function(e){function t(t,o,r,a){var n=e.call(this,'')||this;return n.rowNode=t,n.column=o,n.cellValue=r,n.beans=a,n}return f(t,e),t.prototype.postConstruct=function(){this.getGui().appendChild(h.f.createIconNoSpan("rowDrag",this.beans.gridOptionsWrapper,null)),this.addDragSource(),this.checkCompatibility();var e=this.beans.gridOptionsWrapper.isRowDragManaged()?new w(this,this.beans,this.rowNode,this.column):new y(this,this.beans,this.rowNode,this.column);this.createManagedBean(e,this.beans.context)},t.prototype.getSelectedCount=function(){if(!this.beans.gridOptionsWrapper.isEnableMultiRowDragging())return 1;var e=this.beans.selectionController.getSelectedNodes();return-1!==e.indexOf(this.rowNode)?e.length:1},t.prototype.checkCompatibility=function(){var e=this.beans.gridOptionsWrapper.isRowDragManaged();this.beans.gridOptionsWrapper.isTreeData()&&e&&h.f.doOnce((function(){return console.warn("ag-Grid: If using row drag with tree data, you cannot have rowDragManaged=true")}),"RowDragComp.managedAndTreeData")},t.prototype.addDragSource=function(){var e=this,t={rowNode:this.rowNode,columns:[this.column],defaultTextValue:this.cellValue},o=this.column.getColDef().rowDragText,r={type:c.b.RowDrag,eElement:this.getGui(),dragItemName:function(){var r=e.getSelectedCount();return o?o(t,r):1===r?e.cellValue:r+" rows"},getDragItem:function(){return t},dragStartPixels:0};this.beans.dragAndDropService.addDragSource(r,!0),this.addDestroyFunc((function(){return e.beans.dragAndDropService.removeDragSource(r)}))},m([s.e],t.prototype,"postConstruct",null),t}(i.a),v=function(e){function t(t,o,r){var a=e.call(this)||this;return a.parent=t,a.column=r,a.rowNode=o,a}return f(t,e),t.prototype.setDisplayedOrVisible=function(e){if(e)this.parent.setDisplayed(!1);else{var t=this.column.isRowDrag(this.rowNode);h.f.isFunction(this.column.getColDef().rowDrag)?(this.parent.setDisplayed(!0),this.parent.setVisible(t)):this.parent.setDisplayed(t)}},t}(u.a),y=function(e){function t(t,o,r,a){var n=e.call(this,t,r,a)||this;return n.beans=o,n}return f(t,e),t.prototype.postConstruct=function(){this.addManagedListener(this.beans.gridOptionsWrapper,"suppressRowDrag",this.onSuppressRowDrag.bind(this)),this.addManagedListener(this.rowNode,p.a.EVENT_DATA_CHANGED,this.workOutVisibility.bind(this)),this.addManagedListener(this.rowNode,p.a.EVENT_CELL_CHANGED,this.workOutVisibility.bind(this)),this.workOutVisibility()},t.prototype.onSuppressRowDrag=function(){this.workOutVisibility()},t.prototype.workOutVisibility=function(){var e=this.beans.gridOptionsWrapper.isSuppressRowDrag();this.setDisplayedOrVisible(e)},m([s.e],t.prototype,"postConstruct",null),t}(v),w=function(e){function t(t,o,r,a){var n=e.call(this,t,r,a)||this;return n.beans=o,n}return f(t,e),t.prototype.postConstruct=function(){this.addManagedListener(this.beans.eventService,d.a.EVENT_SORT_CHANGED,this.workOutVisibility.bind(this)),this.addManagedListener(this.beans.eventService,d.a.EVENT_FILTER_CHANGED,this.workOutVisibility.bind(this)),this.addManagedListener(this.beans.eventService,d.a.EVENT_COLUMN_ROW_GROUP_CHANGED,this.workOutVisibility.bind(this)),this.addManagedListener(this.rowNode,p.a.EVENT_DATA_CHANGED,this.workOutVisibility.bind(this)),this.addManagedListener(this.rowNode,p.a.EVENT_CELL_CHANGED,this.workOutVisibility.bind(this)),this.addManagedListener(this.beans.gridOptionsWrapper,"suppressRowDrag",this.onSuppressRowDrag.bind(this)),this.workOutVisibility()},t.prototype.onSuppressRowDrag=function(){this.workOutVisibility()},t.prototype.workOutVisibility=function(){var e=this.beans.gridPanel.getRowDragFeature(),t=e&&e.shouldPreventRowMove(),o=this.beans.gridOptionsWrapper.isSuppressRowDrag(),r=this.beans.dragAndDropService.hasExternalDropZones(),a=t&&!r||o;this.setDisplayedOrVisible(a)},m([s.e],t.prototype,"postConstruct",null),t}(v),x=o(87),C=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),k=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},A=function(e){function t(t,o,r,a,n){var i=e.call(this,'
')||this;return i.rowNode=t,i.column=o,i.cellValue=r,i.beans=a,i.eCell=n,i}return C(t,e),t.prototype.postConstruct=function(){this.getGui().appendChild(h.f.createIconNoSpan("rowDrag",this.beans.gridOptionsWrapper,null)),this.addDragSource(),this.checkVisibility()},t.prototype.addDragSource=function(){this.addGuiEventListener("dragstart",this.onDragStart.bind(this))},t.prototype.onDragStart=function(e){var t=this,o=this.column.getColDef().dndSourceOnRowDrag,r=h.f.isBrowserIE();r||e.dataTransfer.setDragImage(this.eCell,0,0);o?o({rowNode:this.rowNode,dragEvent:e}):function(){try{var o=JSON.stringify(t.rowNode.data);r?e.dataTransfer.setData("text",o):(e.dataTransfer.setData("application/json",o),e.dataTransfer.setData("text/plain",o))}catch(e){}}()},t.prototype.checkVisibility=function(){var e=this.column.isDndSource(this.rowNode);this.setDisplayed(e)},k([s.e],t.prototype,"postConstruct",null),t}(i.a),E=o(40),O=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),R=function(){return(R=Object.assign||function(e){for(var t,o=1,r=arguments.length;o",p="
"),t.push("'),t.push(s),h.f.exists(i,!0)&&t.push(i),t.push(p),t.push("
"),t.join("")},t.prototype.getStylesForRowSpanning=function(){return 1===this.rowSpan?"":"height: "+this.beans.gridOptionsWrapper.getRowHeightAsNumber()*this.rowSpan+"px; z-index: 1;"},t.prototype.afterAttached=function(){var e='[comp-id="'+this.getCompId()+'"]',t=this.eParentRow.querySelector(e);this.setGui(t),this.addDomData(),this.populateTemplate(),this.createCellRendererInstance(!0),this.angular1Compile(),this.refreshHandle(),h.f.exists(this.tooltip)&&!this.beans.gridOptionsWrapper.isEnableBrowserTooltips()&&this.createManagedBean(new E.a(this,"cell"),this.beans.context)},t.prototype.onColumnHover=function(){var e=this.beans.columnHoverService.isHovered(this.column);h.f.addOrRemoveCssClass(this.getGui(),"ag-column-hover",e)},t.prototype.onCellChanged=function(e){e.column===this.column&&this.refreshCell({})},t.prototype.getCellLeft=function(){return(this.beans.gridOptionsWrapper.isEnableRtl()&&this.colsSpanning?h.f.last(this.colsSpanning):this.column).getLeft()},t.prototype.getCellWidth=function(){return this.colsSpanning?this.colsSpanning.reduce((function(e,t){return e+t.getActualWidth()}),0):this.column.getActualWidth()},t.prototype.onFlashCells=function(e){var t=this.beans.cellPositionUtils.createId(this.cellPosition);e.cells[t]&&this.animateCell("highlight")},t.prototype.setupColSpan=function(){h.f.missing(this.getComponentHolder().colSpan)||(this.addManagedListener(this.beans.eventService,n.a.EVENT_DISPLAYED_COLUMNS_CHANGED,this.onDisplayColumnsChanged.bind(this)),this.addManagedListener(this.beans.eventService,n.a.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED,this.onWidthChanged.bind(this)),this.colsSpanning=this.getColSpanningList())},t.prototype.getColSpanningList=function(){var e=this.column.getColSpan(this.rowNode),t=[];if(1===e)t.push(this.column);else for(var o=this.column,r=this.column.getPinned(),a=0;o&&a0){var o=this.getRangeBorders();o.top&&e.push("ag-cell-range-top"),o.right&&e.push("ag-cell-range-right"),o.bottom&&e.push("ag-cell-range-bottom"),o.left&&e.push("ag-cell-range-left")}return this.selectionHandle&&e.push("ag-cell-range-handle"),e},t.prototype.onRowIndexChanged=function(){this.createGridCellVo(),this.onCellFocused(),this.onRangeSelectionChanged()},t.prototype.onRangeSelectionChanged=function(){var e=this.beans.rangeController;if(e){var t=this.cellPosition,o=this.rangeCount,r=e.getCellRangeCount(t),a=this.getGui();o!==r&&(h.f.addOrRemoveCssClass(a,"ag-cell-range-selected",0!==r),h.f.addOrRemoveCssClass(a,"ag-cell-range-selected-1",1===r),h.f.addOrRemoveCssClass(a,"ag-cell-range-selected-2",2===r),h.f.addOrRemoveCssClass(a,"ag-cell-range-selected-3",3===r),h.f.addOrRemoveCssClass(a,"ag-cell-range-selected-4",r>=4),this.rangeCount=r);var n=this.getHasChartRange();n!==this.hasChartRange&&(this.hasChartRange=n,h.f.addOrRemoveCssClass(a,"ag-cell-range-chart",this.hasChartRange)),this.updateRangeBorders(),h.f.addOrRemoveCssClass(a,"ag-cell-range-single-cell",this.isSingleCell()),this.refreshHandle()}},t.prototype.getHasChartRange=function(){var e=this.beans.rangeController;if(!this.rangeCount||!e)return!1;var t=e.getCellRanges();return t.length>0&&t.every((function(e){return h.f.includes([g.a.DIMENSION,g.a.VALUE],e.type)}))},t.prototype.shouldHaveSelectionHandle=function(){var e=this.beans,t=e.gridOptionsWrapper,o=e.rangeController,r=o.getCellRanges(),a=r.length;if(this.rangeCount<1||a<1)return!1;var n=h.f.last(r),i=this.getCellPosition(),l=1===a&&(t.isEnableFillHandle()||t.isEnableRangeHandle())&&!this.editingCell;if(this.hasChartRange){var s=r[0].type===g.a.DIMENSION&&o.isCellInSpecificRange(i,r[0]);h.f.addOrRemoveCssClass(this.getGui(),"ag-cell-range-chart-category",s),l=n.type===g.a.VALUE}return l&&null!=n.endRow&&o.isContiguousRange(n)&&o.isBottomRightCell(n,i)},t.prototype.addSelectionHandle=function(){var e=this.beans,t=e.gridOptionsWrapper,o=(e.context,e.rangeController),r=h.f.last(o.getCellRanges()).type,a=t.isEnableFillHandle()&&h.f.missing(r)?g.b.FILL:g.b.RANGE;this.selectionHandle&&this.selectionHandle.getType()!==a&&(this.selectionHandle=this.beans.context.destroyBean(this.selectionHandle)),this.selectionHandle||(this.selectionHandle=this.beans.selectionHandleFactory.createSelectionHandle(a)),this.selectionHandle.refresh(this)},t.prototype.updateRangeBordersIfRangeCount=function(){this.rangeCount>0&&(this.updateRangeBorders(),this.refreshHandle())},t.prototype.refreshHandle=function(){if(this.beans.rangeController){var e=this.shouldHaveSelectionHandle();this.selectionHandle&&!e&&(this.selectionHandle=this.beans.context.destroyBean(this.selectionHandle)),e&&this.addSelectionHandle(),h.f.addOrRemoveCssClass(this.getGui(),"ag-cell-range-handle",!!this.selectionHandle)}},t.prototype.updateRangeBorders=function(){var e=this.getRangeBorders(),t=this.isSingleCell(),o=!t&&e.top,r=!t&&e.right,a=!t&&e.bottom,n=!t&&e.left,i=this.getGui();h.f.addOrRemoveCssClass(i,"ag-cell-range-top",o),h.f.addOrRemoveCssClass(i,"ag-cell-range-right",r),h.f.addOrRemoveCssClass(i,"ag-cell-range-bottom",a),h.f.addOrRemoveCssClass(i,"ag-cell-range-left",n)},t.prototype.onFirstRightPinnedChanged=function(){var e=this.column.isFirstRightPinned();this.firstRightPinned!==e&&(this.firstRightPinned=e,h.f.addOrRemoveCssClass(this.getGui(),"ag-cell-first-right-pinned",e))},t.prototype.onLastLeftPinnedChanged=function(){var e=this.column.isLastLeftPinned();this.lastLeftPinned!==e&&(this.lastLeftPinned=e,h.f.addOrRemoveCssClass(this.getGui(),"ag-cell-last-left-pinned",e))},t.prototype.populateTemplate=function(){this.usingWrapper?(this.eParentOfValue=this.getRefElement("eCellValue"),this.eCellWrapper=this.getRefElement("eCellWrapper"),this.eCellValue=this.getRefElement("eCellValue"),this.includeRowDraggingComponent&&this.addRowDragging(),this.includeDndSourceComponent&&this.addDndSource(),this.includeSelectionComponent&&this.addSelectionCheckbox()):this.eParentOfValue=this.getGui()},t.prototype.getFrameworkOverrides=function(){return this.beans.frameworkOverrides},t.prototype.addRowDragging=function(){var e=this.beans.gridOptionsWrapper.isPagination(),t=this.beans.gridOptionsWrapper.isRowDragManaged(),o=this.beans.gridOptionsWrapper.isRowModelDefault();if(t){if(!o)return void h.f.doOnce((function(){return console.warn("ag-Grid: managed row dragging is only allowed in the Client Side Row Model")}),"CellComp.addRowDragging");if(e)return void h.f.doOnce((function(){return console.warn("ag-Grid: managed row dragging is not possible when doing pagination")}),"CellComp.addRowDragging")}var r=new b(this.rowNode,this.column,this.getValueToUse(),this.beans);this.createManagedBean(r,this.beans.context),this.eCellWrapper.insertBefore(r.getGui(),this.eParentOfValue)},t.prototype.addDndSource=function(){var e=new A(this.rowNode,this.column,this.getValueToUse(),this.beans,this.getGui());this.createManagedBean(e,this.beans.context),this.eCellWrapper.insertBefore(e.getGui(),this.eParentOfValue)},t.prototype.addSelectionCheckbox=function(){var e=this,t=new l.a;this.beans.context.createBean(t);var o=this.getComponentHolder().checkboxSelection;o="function"==typeof o?o:null,t.init({rowNode:this.rowNode,column:this.column,visibleFunc:o}),this.addDestroyFunc((function(){return e.beans.context.destroyBean(t)})),this.eCellWrapper.insertBefore(t.getGui(),this.eParentOfValue)},t.prototype.addDomData=function(){var e=this,o=this.getGui();this.beans.gridOptionsWrapper.setDomData(o,t.DOM_DATA_KEY_CELL_COMP,this),this.addDestroyFunc((function(){return e.beans.gridOptionsWrapper.setDomData(o,t.DOM_DATA_KEY_CELL_COMP,null)}))},t.prototype.isSingleCell=function(){var e=this.beans.rangeController;return 1===this.rangeCount&&e&&!e.isMoreThanOneCell()},t.prototype.onCellFocused=function(e){var t=this.beans.focusController.isCellFocused(this.cellPosition);t!==this.cellFocused&&(!this.beans.gridOptionsWrapper.isSuppressCellSelection()&&h.f.addOrRemoveCssClass(this.getGui(),"ag-cell-focus",t),this.cellFocused=t);if(t&&e&&e.forceBrowserFocus){var o=this.getFocusableElement();o.focus(),document.activeElement&&document.activeElement!==document.body||o.focus()}var r=this.beans.gridOptionsWrapper.isFullRowEdit();t||r||!this.editingCell||this.stopRowOrCellEdit()},t.prototype.stopRowOrCellEdit=function(e){void 0===e&&(e=!1),this.beans.gridOptionsWrapper.isFullRowEdit()?this.rowComp.stopRowEditing(e):this.stopEditing(e)},t.prototype.stopEditing=function(e){if(void 0===e&&(e=!1),this.editingCell)if(this.cellEditor){var t,o=this.getValue(),r=!1;if(!e)this.cellEditor.isCancelAfterEnd&&this.cellEditor.isCancelAfterEnd()||(t=this.cellEditor.getValue(),r=!0);if(this.editingCell=!1,this.cellEditor=this.beans.context.destroyBean(this.cellEditor),this.cellEditor=null,this.cellEditorInPopup&&this.hideEditorPopup)this.hideEditorPopup(),this.hideEditorPopup=null;else if(h.f.clearElement(this.getGui()),this.usingWrapper)this.getGui().appendChild(this.eCellWrapper);else if(this.cellRenderer){var a=this.cellRendererGui;a&&this.getGui().appendChild(a)}this.setInlineEditingClass(),this.refreshHandle(),r&&t!==o&&(this.suppressRefreshCell=!0,this.rowNode.setDataValue(this.column,t),this.suppressRefreshCell=!1),this.refreshCell({forceRefresh:!0,suppressFlash:!0});var i=this.createEvent(null,n.a.EVENT_CELL_EDITING_STOPPED);this.beans.eventService.dispatchEvent(i)}else this.editingCell=!1},t.DOM_DATA_KEY_CELL_COMP="cellComp",t.CELL_RENDERER_TYPE_NORMAL="cellRenderer",t.CELL_RENDERER_TYPE_PINNED="pinnedRowCellRenderer",t}(i.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return p}));var r,a=o(1),n=o(4),i=o(43),l=o(0),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(){var t=e.call(this)||this;return t.className="ag-checkbox",t.displayTag="input",t.inputType="checkbox",t.labelAlignment="right",t.selected=!1,t.readOnly=!1,t.passive=!1,t.setTemplate(t.TEMPLATE.replace(/%displayField%/g,t.displayTag)),t}return g(t,e),t.prototype.addInputListeners=function(){this.addManagedListener(this.eInput,"click",this.onCheckboxClick.bind(this))},t.prototype.getNextValue=function(){return void 0===this.selected||!this.selected},t.prototype.setPassive=function(e){this.passive=e},t.prototype.isReadOnly=function(){return this.readOnly},t.prototype.setReadOnly=function(e){l.f.addOrRemoveCssClass(this.eWrapper,"ag-disabled",e),this.eInput.disabled=e,this.readOnly=e},t.prototype.setDisabled=function(t){return l.f.addOrRemoveCssClass(this.eWrapper,"ag-disabled",t),e.prototype.setDisabled.call(this,t)},t.prototype.toggle=function(){var e=this.getNextValue();this.passive?this.dispatchChange(e):this.setValue(e)},t.prototype.getValue=function(){return this.isSelected()},t.prototype.setValue=function(e,t){return this.refreshSelectedClass(e),this.setSelected(e,t),this},t.prototype.setName=function(e){return this.getInputElement().name=e,this},t.prototype.isSelected=function(){return this.selected},t.prototype.setSelected=function(e,t){this.isSelected()!==e&&(this.selected="boolean"==typeof e?e:void 0,this.eInput.checked=this.selected,this.eInput.indeterminate=void 0===this.selected,t||this.dispatchChange(this.selected))},t.prototype.dispatchChange=function(e,o){this.dispatchEvent({type:t.EVENT_CHANGED,selected:e,event:o});var r=this.getInputElement(),a={type:n.a.EVENT_CHECKBOX_CHANGED,id:r.id,name:r.name,selected:e};this.eventService.dispatchEvent(a)},t.prototype.onCheckboxClick=function(e){this.selected=e.target.checked,this.refreshSelectedClass(this.selected),this.dispatchChange(this.selected,e)},t.prototype.refreshSelectedClass=function(e){l.f.addOrRemoveCssClass(this.eWrapper,"ag-checked",!0===e),l.f.addOrRemoveCssClass(this.eWrapper,"ag-indeterminate",null==e)},s([Object(a.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),t}(i.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return g}));var r=o(4),a=o(32),n=o(15),i=o(0),l=function(){for(var e=0,t=0,o=arguments.length;t=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},c=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.applyActive=!1,t.hidePopup=null,t.appliedModel=null,t}return s(t,e),t.prototype.onFilterChanged=function(){console.warn("ag-Grid: you should not call onFilterChanged() directly on the filter, please call\n gridApi.onFilterChanged() instead. onFilterChanged is not part of the exposed filter interface (it was\n a method that existed on an old version of the filters that was not intended for public use."),this.providedFilterParams.filterChangedCallback()},t.prototype.isFilterActive=function(){return!!this.appliedModel},t.prototype.postConstruct=function(){var e='\n
\n
\n '+this.createBodyTemplate()+"\n
\n
";this.setTemplate(e)},t.prototype.init=function(e){var t=this;this.setParams(e),this.resetUiToDefaults(!0).then((function(){t.updateUiVisibility(),t.setupOnBtApplyDebounce()}))},t.prototype.setParams=function(e){if(t.checkForDeprecatedParams(e),this.providedFilterParams=e,"keep"===e.newRowsAction)this.newRowsActionKeep=!0;else if("clear"===e.newRowsAction)this.newRowsActionKeep=!1;else{var o=[i.a.ROW_MODEL_TYPE_SERVER_SIDE,i.a.ROW_MODEL_TYPE_INFINITE];this.newRowsActionKeep=o.indexOf(this.rowModel.getType())>=0}this.applyActive=t.isUseApplyButton(e),this.createButtonPanel()},t.prototype.createButtonPanel=function(){var e=this,t=this.providedFilterParams.buttons;if(t&&!(t.length<1)){var o=this.gridOptionsWrapper.getLocaleTextFunc(),r=document.createElement("div");Object(l.addCssClass)(r,"ag-filter-apply-panel");new Set(t).forEach((function(t){return function(t){var a,n;switch(t){case"apply":a=o("applyFilter","Apply Filter"),n=function(t){return e.onBtApply(!1,!1,t)};break;case"clear":a=o("clearFilter","Clear Filter"),n=function(){return e.onBtClear()};break;case"reset":a=o("resetFilter","Reset Filter"),n=function(){return e.onBtReset()};break;case"cancel":a=o("cancelFilter","Cancel Filter"),n=function(t){e.onBtCancel(t)};break;default:return void console.warn("Unknown button type specified")}var i=Object(l.loadTemplate)(''+a+"");r.appendChild(i),e.addManagedListener(i,"click",n)}(t)})),this.getGui().appendChild(r)}},t.checkForDeprecatedParams=function(e){var t=e.buttons||[];if(!(t.length>0)){var o=e.applyButton,r=e.resetButton;e.clearButton&&(console.warn("ag-Grid: as of ag-Grid v23.2, filterParams.clearButton is deprecated. Please use filterParams.buttons instead"),t.push("clear")),r&&(console.warn("ag-Grid: as of ag-Grid v23.2, filterParams.resetButton is deprecated. Please use filterParams.buttons instead"),t.push("reset")),o&&(console.warn("ag-Grid: as of ag-Grid v23.2, filterParams.applyButton is deprecated. Please use filterParams.buttons instead"),t.push("apply")),e.apply&&(console.warn("ag-Grid: as of ag-Grid v21, filterParams.apply is deprecated. Please use filterParams.buttons instead"),t.push("apply")),e.buttons=t}},t.prototype.getDefaultDebounceMs=function(){return 0},t.prototype.setupOnBtApplyDebounce=function(){var e=t.getDebounceMs(this.providedFilterParams,this.getDefaultDebounceMs());this.onBtApplyDebounce=Object(g.debounce)(this.onBtApply.bind(this),e)},t.prototype.getModel=function(){return this.appliedModel},t.prototype.setModel=function(e){var t=this;return(e?this.setModelIntoUi(e):this.resetUiToDefaults()).then((function(){t.updateUiVisibility(),t.applyModel()}))},t.prototype.onBtCancel=function(e){var t=this;this.setModelIntoUi(this.getModel()).then((function(){t.onUiChanged(!1,"prevent"),t.providedFilterParams.closeOnApply&&t.close(e)}))},t.prototype.onBtClear=function(){var e=this;this.resetUiToDefaults().then((function(){return e.onUiChanged()}))},t.prototype.onBtReset=function(){this.onBtClear(),this.onBtApply()},t.prototype.applyModel=function(){var e=this.getModelFromUi();if(!this.isModelValid(e))return!1;var t=this.appliedModel;return this.appliedModel=e,!this.areModelsEqual(t,e)},t.prototype.isModelValid=function(e){return!0},t.prototype.onBtApply=function(e,t,o){void 0===e&&(e=!1),void 0===t&&(t=!1),this.applyModel()&&this.providedFilterParams.filterChangedCallback({afterFloatingFilter:e,afterDataChange:t}),this.providedFilterParams.closeOnApply&&!e&&this.applyActive&&this.close(o)},t.prototype.onNewRowsLoaded=function(){var e=this;this.newRowsActionKeep||this.resetUiToDefaults().then((function(){return e.appliedModel=null}))},t.prototype.close=function(e){if(this.hidePopup){var t,o=e,r=o&&o.key;"Enter"!==r&&"Space"!==r||(t={keyboardEvent:o}),this.hidePopup(t),this.hidePopup=null}},t.prototype.isNewRowsActionKeep=function(){return this.newRowsActionKeep},t.prototype.onUiChanged=function(e,t){if(void 0===e&&(e=!1),this.updateUiVisibility(),this.providedFilterParams.filterModifiedCallback(),this.applyActive){var o=this.isModelValid(this.getModelFromUi());Object(l.setDisabled)(this.getRefElement("applyFilterButton"),!o)}e&&!t||"immediately"===t?this.onBtApply(e):(this.applyActive||t)&&"debounce"!==t||this.onBtApplyDebounce()},t.prototype.afterGuiAttached=function(e){this.hidePopup=e.hidePopup},t.getDebounceMs=function(e,o){return t.isUseApplyButton(e)?(null!=e.debounceMs&&console.warn("ag-Grid: debounceMs is ignored when apply button is present"),0):null!=e.debounceMs?e.debounceMs:o},t.isUseApplyButton=function(e){return t.checkForDeprecatedParams(e),e.buttons&&e.buttons.indexOf("apply")>=0},t.prototype.destroy=function(){this.hidePopup=null,e.prototype.destroy.call(this)},p([Object(n.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),p([Object(n.a)("rowModel")],t.prototype,"rowModel",void 0),p([n.e],t.prototype,"postConstruct",null),t}(a.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return p}));var r,a,n=o(1),i=o(6),l=o(0),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i};!function(e){e[e.NOTHING=0]="NOTHING",e[e.WAITING_TO_SHOW=1]="WAITING_TO_SHOW",e[e.SHOWING=2]="SHOWING"}(a||(a={}));var p=function(e){function t(t,o){var r=e.call(this)||this;return r.DEFAULT_HIDE_TOOLTIP_TIMEOUT=1e4,r.SHOW_QUICK_TOOLTIP_DIFF=1e3,r.FADE_OUT_TOOLTIP_TIMEOUT=1e3,r.state=a.NOTHING,r.tooltipInstanceCount=0,r.tooltipMouseTrack=!1,r.parentComp=t,r.location=o,r}return g(t,e),t.prototype.postConstruct=function(){this.tooltipShowDelay=this.gridOptionsWrapper.getTooltipShowDelay()||2e3,this.tooltipMouseTrack=this.gridOptionsWrapper.isTooltipMouseTrack();var e=this.parentComp.getGui();this.addManagedListener(e,"mouseenter",this.onMouseEnter.bind(this)),this.addManagedListener(e,"mouseleave",this.onMouseLeave.bind(this)),this.addManagedListener(e,"mousemove",this.onMouseMove.bind(this)),this.addManagedListener(e,"mousedown",this.onMouseDown.bind(this))},t.prototype.destroy=function(){this.setToDoNothing(),e.prototype.destroy.call(this)},t.prototype.onMouseEnter=function(e){var t=this.isLastTooltipHiddenRecently()?200:this.tooltipShowDelay;this.showTooltipTimeoutId=window.setTimeout(this.showTooltip.bind(this),t),this.lastMouseEvent=e,this.state=a.WAITING_TO_SHOW},t.prototype.onMouseLeave=function(){this.setToDoNothing()},t.prototype.setToDoNothing=function(){this.state===a.SHOWING&&this.hideTooltip(),this.clearTimeouts(),this.state=a.NOTHING},t.prototype.onMouseMove=function(e){this.lastMouseEvent=e,this.tooltipMouseTrack&&this.state===a.SHOWING&&this.tooltipComp&&this.positionTooltipUnderLastMouseEvent()},t.prototype.onMouseDown=function(){this.setToDoNothing()},t.prototype.hideTooltip=function(){this.tooltipComp&&(this.destroyTooltipComp(),t.lastTooltipHideTime=(new Date).getTime()),this.state=a.NOTHING},t.prototype.destroyTooltipComp=function(){var e=this;l.f.addCssClass(this.tooltipComp.getGui(),"ag-tooltip-hiding");var t=this.tooltipPopupDestroyFunc,o=this.tooltipComp;window.setTimeout((function(){t(),e.getContext().destroyBean(o)}),this.FADE_OUT_TOOLTIP_TIMEOUT),this.tooltipPopupDestroyFunc=void 0,this.tooltipComp=void 0},t.prototype.isLastTooltipHiddenRecently=function(){return(new Date).getTime()-t.lastTooltipHideTime=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},c=function(e){function t(t,o,r,a){var n=e.call(this)||this;return n.columnOrGroup=t,n.eCell=o,n.ariaEl=n.eCell.querySelector("[role=columnheader]")||n.eCell,n.colsSpanning=a,n.beans=r,n.printLayout=r.gridOptionsWrapper.getDomLayout()===i.a.DOM_LAYOUT_PRINT,n}return s(t,e),t.prototype.setColsSpanning=function(e){this.colsSpanning=e,this.onLeftChanged()},t.prototype.getColumnOrGroup=function(){return this.beans.gridOptionsWrapper.isEnableRtl()&&this.colsSpanning?g.f.last(this.colsSpanning):this.columnOrGroup},t.prototype.postConstruct=function(){this.addManagedListener(this.columnOrGroup,a.a.EVENT_LEFT_CHANGED,this.onLeftChanged.bind(this)),this.setLeftFirstTime()},t.prototype.setLeftFirstTime=function(){var e=this.beans.gridOptionsWrapper.isSuppressColumnMoveAnimation(),t=g.f.exists(this.columnOrGroup.getOldLeft());this.beans.columnAnimationService.isActive()&&t&&!e?this.animateInLeft():this.onLeftChanged()},t.prototype.animateInLeft=function(){var e=this,t=this.getColumnOrGroup().getLeft(),o=this.getColumnOrGroup().getOldLeft();this.setLeft(o),this.actualLeft=t,this.beans.columnAnimationService.executeNextVMTurn((function(){e.actualLeft===t&&e.setLeft(t)}))},t.prototype.onLeftChanged=function(){var e=this.getColumnOrGroup(),t=e.getLeft();this.actualLeft=this.modifyLeftForPrintLayout(e,t),this.setLeft(this.actualLeft)},t.prototype.modifyLeftForPrintLayout=function(e,t){return this.printLayout?e.getPinned()===i.a.PINNED_LEFT?t:e.getPinned()===i.a.PINNED_RIGHT?this.beans.columnController.getPinnedLeftContainerWidth()+this.beans.columnController.getBodyContainerWidth()+t:this.beans.columnController.getPinnedLeftContainerWidth()+t:t},t.prototype.setLeft=function(e){if(g.f.exists(e)&&(this.eCell.style.left=e+"px"),this.columnOrGroup instanceof a.a){var t=this.beans.columnController.getAllDisplayedColumns().indexOf(this.columnOrGroup);this.ariaEl.setAttribute("aria-colindex",(t+1).toString())}else this.ariaEl.removeAttribute("aria-colindex")},p([l.e],t.prototype,"postConstruct",null),t}(n.a)},function(e,t,o){"use strict";o.r(t),o.d(t,"doOnce",(function(){return i})),o.d(t,"getFunctionParameters",(function(){return l})),o.d(t,"isFunction",(function(){return g})),o.d(t,"executeInAWhile",(function(){return s})),o.d(t,"executeNextVMTurn",(function(){return p})),o.d(t,"executeAfter",(function(){return c})),o.d(t,"debounce",(function(){return d})),o.d(t,"compose",(function(){return u})),o.d(t,"callIfPresent",(function(){return h}));var r=/((\/\/.*$)|(\/\*[\s\S]*?\*\/))/gm,a=/([^\s,]+)/g,n={};function i(e,t){n[t]||(e(),n[t]=!0)}function l(e){var t=e.toString().replace(r,"");return t.slice(t.indexOf("(")+1,t.indexOf(")")).match(a)||[]}function g(e){return!!(e&&e.constructor&&e.call&&e.apply)}function s(e){c(e,400)}function p(e){c(e,0)}function c(e,t){void 0===t&&(t=0),e.length>0&&window.setTimeout((function(){return e.forEach((function(e){return e()}))}),t)}function d(e,t,o){var r;return void 0===o&&(o=!1),function(){for(var a=[],n=0;n=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},s=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.config={},t.TEMPLATE='\n
\n \n \n
',t}return l(t,e),t.prototype.postConstruct=function(){e.prototype.postConstruct.call(this),this.setInputType(),Object(i.addCssClass)(this.eLabel,this.className+"-label"),Object(i.addCssClass)(this.eWrapper,this.className+"-input-wrapper"),Object(i.addCssClass)(this.eInput,this.className+"-input"),Object(i.addCssClass)(this.getGui(),"ag-input-field");var t=this.eInput.id?this.eInput.id:"ag-input-id-"+this.getCompId();this.eLabel.htmlFor=t,this.eInput.id=t;var o=this.config,r=o.width,a=o.value;null!=r&&this.setWidth(r),null!=a&&this.setValue(a),this.addInputListeners()},t.prototype.addInputListeners=function(){var e=this;this.addManagedListener(this.eInput,"input",(function(t){var o=t.target.value;e.setValue(o)}))},t.prototype.setInputType=function(){this.inputType&&this.eInput.setAttribute("type",this.inputType)},t.prototype.getInputElement=function(){return this.eInput},t.prototype.setInputWidth=function(e){return Object(i.setElementWidth)(this.eWrapper,e),this},t.prototype.setInputName=function(e){return this.getInputElement().setAttribute("name",e),this},t.prototype.getFocusableElement=function(){return this.eInput},t.prototype.setMaxLength=function(e){return this.eInput.maxLength=e,this},t.prototype.setInputPlaceholder=function(e){var t=this.eInput;return e?t.setAttribute("placeholder",e):t.removeAttribute("placeholder"),this},t.prototype.setDisabled=function(t){return Object(i.setDisabled)(this.eInput,t),e.prototype.setDisabled.call(this,t)},t.prototype.setInputAriaLabel=function(e){return this.eInput.setAttribute("aria-label",e),this},g([Object(a.d)("eLabel")],t.prototype,"eLabel",void 0),g([Object(a.d)("eWrapper")],t.prototype,"eWrapper",void 0),g([Object(a.d)("eInput")],t.prototype,"eInput",void 0),t}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return a})),o.d(t,"b",(function(){return R}));var r,a,n=o(1),i=o(50),l=o(0),g={propertyName:"dateComponent",isCellRenderer:function(){return!1}},s={propertyName:"headerComponent",isCellRenderer:function(){return!1}},p={propertyName:"headerGroupComponent",isCellRenderer:function(){return!1}},c={propertyName:"groupRowInnerRenderer",isCellRenderer:function(){return!0}},d={propertyName:"cellRenderer",isCellRenderer:function(){return!0}},u={propertyName:"pinnedRowCellRenderer",isCellRenderer:function(){return!0}},h={propertyName:"cellEditor",isCellRenderer:function(){return!1}},f={propertyName:"innerRenderer",isCellRenderer:function(){return!0}},m={propertyName:"loadingOverlayComponent",isCellRenderer:function(){return!1}},b={propertyName:"noRowsOverlayComponent",isCellRenderer:function(){return!1}},v={propertyName:"tooltipComponent",isCellRenderer:function(){return!1}},y={propertyName:"filter",isCellRenderer:function(){return!1}},w={propertyName:"floatingFilterComponent",isCellRenderer:function(){return!1}},x={propertyName:"toolPanel",isCellRenderer:function(){return!1}},C={propertyName:"statusPanel",isCellRenderer:function(){return!1}},k=o(6),A=o(30),E=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),O=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i};!function(e){e[e.DEFAULT=0]="DEFAULT",e[e.REGISTERED_BY_NAME=1]="REGISTERED_BY_NAME",e[e.HARDCODED=2]="HARDCODED"}(a||(a={}));var R=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return E(t,e),t.prototype.newDateComponent=function(e){return this.createAndInitUserComponent(this.gridOptions,e,g,"agDateInput")},t.prototype.newHeaderComponent=function(e){return this.createAndInitUserComponent(e.column.getColDef(),e,s,"agColumnHeader")},t.prototype.newHeaderGroupComponent=function(e){return this.createAndInitUserComponent(e.columnGroup.getColGroupDef(),e,p,"agColumnGroupHeader")},t.prototype.newFullWidthGroupRowInnerCellRenderer=function(e){return this.createAndInitUserComponent(this.gridOptions,e,c,null,!0)},t.prototype.newFullWidthCellRenderer=function(e,t,o){return this.createAndInitUserComponent(null,e,{propertyName:t,isCellRenderer:function(){return!0}},o)},t.prototype.newCellRenderer=function(e,t,o){return void 0===o&&(o=!1),this.createAndInitUserComponent(e,t,o?u:d,null,!0)},t.prototype.newCellEditor=function(e,t){return this.createAndInitUserComponent(e,t,h,"agCellEditor")},t.prototype.newInnerCellRenderer=function(e,t){return this.createAndInitUserComponent(e,t,f,null)},t.prototype.newLoadingOverlayComponent=function(e){return this.createAndInitUserComponent(this.gridOptions,e,m,"agLoadingOverlay")},t.prototype.newNoRowsOverlayComponent=function(e){return this.createAndInitUserComponent(this.gridOptions,e,b,"agNoRowsOverlay")},t.prototype.newTooltipComponent=function(e){return this.createAndInitUserComponent(e.colDef,e,v,"agTooltipComponent")},t.prototype.newFilterComponent=function(e,t,o,r){return this.createAndInitUserComponent(e,t,y,o,!1,r)},t.prototype.newSetFilterCellRenderer=function(e,t){return this.createAndInitUserComponent(e,t,d,null,!0)},t.prototype.newFloatingFilterComponent=function(e,t,o){return this.createAndInitUserComponent(e,t,w,o,!0)},t.prototype.newToolPanelComponent=function(e,t){return this.createAndInitUserComponent(e,t,x)},t.prototype.newStatusPanelComponent=function(e,t){return this.createAndInitUserComponent(e,t,C)},t.prototype.createAndInitUserComponent=function(e,t,o,r,a,n){void 0===a&&(a=!1),e||(e=this.gridOptions);var i=this.createComponentInstance(e,o,t,r,a);if(!i)return null;var g=i.componentInstance,s=this.createFinalParams(e,o.propertyName,t,i.paramsFromSelector);this.addReactHacks(s);var p=n?n(s,g):s,c=this.initComponent(g,p);return null==c?l.c.resolve(g):c.then((function(){return g}))},t.prototype.addReactHacks=function(e){var t=this.context.getBean("agGridReact");t&&(e.agGridReact=Object(A.cloneObject)(t));var o=this.context.getBean("frameworkComponentWrapper");o&&(e.frameworkComponentWrapper=o)},t.prototype.createUserComponentFromConcreteClass=function(e,t){var o=new e;return this.initComponent(o,t),o},t.prototype.lookupComponentClassDef=function(e,t,o,r){void 0===o&&(o=null);var n,i=null,l=null,g=null,s=null;if(null!=e){var p=e[t];null==p||!0===p||("string"==typeof p?i=p:"boolean"==typeof p||(this.agComponentUtils.doesImplementIComponent(p)?l=p:g=p)),s=e[t+"Framework"],n=e[t+"Selector"]}if(l&&s||i&&s||g&&s)throw Error("ag-grid: you are trying to specify: "+t+" twice as a component.");if(s&&!this.frameworkComponentWrapper)throw Error("ag-grid: you are specifying a framework component but you are not using a framework version of ag-grid for : "+t);if(n&&(i||l||g||s))throw Error("ag-grid: you can't specify both, the selector and the component of ag-grid for : "+t);if(s)return{componentFromFramework:!0,component:s,source:a.HARDCODED,paramsFromSelector:null};if(l)return{componentFromFramework:!1,component:l,source:a.HARDCODED,paramsFromSelector:null};if(g)return this.agComponentUtils.adaptFunction(t,g,!1,a.HARDCODED);var c,d=n?n(o):null;if(!(c=d&&d.component?d.component:i||r))return null;var u=this.lookupFromRegisteredComponents(t,c);return u?{componentFromFramework:u.componentFromFramework,component:u.component,source:u.source,paramsFromSelector:d?d.params:null}:null},t.prototype.lookupFromRegisteredComponents=function(e,t){var o=null!=t?t:e,r=this.userComponentRegistry.retrieve(o);return null==r?null:r.componentFromFramework?{component:r.component,componentFromFramework:!0,source:a.REGISTERED_BY_NAME,paramsFromSelector:null}:this.agComponentUtils.doesImplementIComponent(r.component)?{component:r.component,componentFromFramework:!1,source:r.source==i.a.REGISTERED?a.REGISTERED_BY_NAME:a.DEFAULT,paramsFromSelector:null}:this.agComponentUtils.adaptFunction(e,r.component,r.componentFromFramework,r.source==i.a.REGISTERED?a.REGISTERED_BY_NAME:a.DEFAULT)},t.prototype.createFinalParams=function(e,t,o,r){void 0===r&&(r=null);var a={};Object(A.mergeDeep)(a,o);var n=e?e[t+"Params"]:null;return null!=n&&("function"==typeof n?Object(A.mergeDeep)(a,n(o)):"object"==typeof n&&Object(A.mergeDeep)(a,n)),Object(A.mergeDeep)(a,r),a},t.prototype.createComponentInstance=function(e,t,o,r,a){var n,i=t.propertyName,l=this.lookupComponentClassDef(e,i,o,r);if(!l||!l.component){var g=e?e[i]:r,s=g||r;return a||console.error("Could not find component "+s+", did you forget to configure this component?"),null}if(l.componentFromFramework){var p=l.component,c=this.componentMetadataProvider.retrieve(i);n=this.frameworkComponentWrapper.wrap(p,c.mandatoryMethodList,c.optionalMethodList,t,r)}else n=new l.component;return{componentInstance:n,paramsFromSelector:l.paramsFromSelector}},t.prototype.initComponent=function(e,t){if(this.context.createBean(e),null!=e.init)return e.init(t)},O([Object(n.a)("gridOptions")],t.prototype,"gridOptions",void 0),O([Object(n.a)("agComponentUtils")],t.prototype,"agComponentUtils",void 0),O([Object(n.a)("componentMetadataProvider")],t.prototype,"componentMetadataProvider",void 0),O([Object(n.a)("userComponentRegistry")],t.prototype,"userComponentRegistry",void 0),O([Object(n.d)("frameworkComponentWrapper")],t.prototype,"frameworkComponentWrapper",void 0),t=O([Object(n.b)("userComponentFactory")],t)}(k.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return p}));var r,a=o(2),n=o(33),i=o(5),l=o(0),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(){return e.call(this,t.TEMPLATE)||this}return g(t,e),t.prototype.init=function(e){this.params=e;var t,o=this.eInput;e.cellStartedEdit?(this.focusAfterAttached=!0,e.keyPress===a.a.KEY_BACKSPACE||e.keyPress===a.a.KEY_DELETE?t="":e.charPress?t=e.charPress:(t=this.getStartValue(e),e.keyPress!==a.a.KEY_F2&&(this.highlightAllOnFocus=!0))):(this.focusAfterAttached=!1,t=this.getStartValue(e));l.f.exists(t)&&o.setValue(t,!0),this.addManagedListener(o.getGui(),"keydown",(function(e){var t=e.keyCode===a.a.KEY_PAGE_UP,o=e.keyCode===a.a.KEY_PAGE_DOWN;(t||o)&&e.preventDefault()}))},t.prototype.afterGuiAttached=function(){if(this.focusAfterAttached){var e=this.eInput;l.f.isBrowserSafari()||e.getFocusableElement().focus();var t=e.getInputElement();if(this.highlightAllOnFocus)t.select();else{var o=e.getValue(),r=l.f.exists(o)&&o.length||0;r&&t.setSelectionRange(r,r)}}},t.prototype.focusIn=function(){var e=this.eInput,t=e.getFocusableElement(),o=e.getInputElement();t.focus(),o.select()},t.prototype.focusOut=function(){var e=this.eInput.getInputElement();l.f.isBrowserIE()&&e.setSelectionRange(0,0)},t.prototype.getValue=function(){var e=this.eInput;return this.params.parseValue(e.getValue())},t.prototype.getStartValue=function(e){return e.useFormatter||e.column.getColDef().refData?e.formatValue(e.value):e.value},t.prototype.isPopup=function(){return!1},t.TEMPLATE='
',s([Object(i.d)("eInput")],t.prototype,"eInput",void 0),t}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return h}));var r,a=o(2),n=o(1),i=o(7),l=o(16),g=o(53),s=o(5),p=o(44),c=o(0),d=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),u=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},h=function(e){function t(){return e.call(this,t.TEMPLATE)||this}return d(t,e),t.prototype.init=function(e){this.params=e,this.gridOptionsWrapper.isGroupIncludeTotalFooter()&&this.assignBlankValueToGroupFooterCell(e);var t=this.isEmbeddedRowMismatch(),o=null==e.value,r=!1;if(this.gridOptionsWrapper.isGroupIncludeFooter()&&this.gridOptionsWrapper.isGroupHideOpenParents()){var a=e.node;if(a.footer)r=(e.colDef&&e.colDef.showRowGroup)!==(a.rowGroupColumn&&a.rowGroupColumn.getColId())}this.cellIsBlank=t||o||r,this.cellIsBlank||(this.setupDragOpenParents(),this.addExpandAndContract(),this.addCheckboxIfNeeded(),this.addValueElement(),this.setupIndent())},t.prototype.assignBlankValueToGroupFooterCell=function(e){e.value||-1!=e.node.level||(e.value="")},t.prototype.isEmbeddedRowMismatch=function(){if(!this.params.fullWidth||!this.gridOptionsWrapper.isEmbedFullWidthRows())return!1;var e=this.params.pinned===a.a.PINNED_LEFT,t=this.params.pinned===a.a.PINNED_RIGHT,o=!e&&!t;return this.gridOptionsWrapper.isEnableRtl()?this.columnController.isPinningLeft()?!t:!o:this.columnController.isPinningLeft()?!e:!o},t.prototype.setIndent=function(){if(!this.gridOptionsWrapper.isGroupHideOpenParents()){var e=this.params,t=e.node.uiLevel;e.padding>=0?this.setPaddingDeprecatedWay(t,e.padding):(this.indentClass&&this.removeCssClass(this.indentClass),this.indentClass="ag-row-group-indent-"+t,this.addCssClass(this.indentClass))}},t.prototype.setPaddingDeprecatedWay=function(e,t){c.f.doOnce((function(){return console.warn("ag-Grid: since v14.2, configuring padding for groupCellRenderer should be done with Sass variables and themes. Please see the ag-Grid documentation page for Themes, in particular the property $row-group-indent-size.")}),"groupCellRenderer->doDeprecatedWay");var o=e*t,r=this.getGui(),a=this.gridOptionsWrapper.isEnableRtl()?"paddingRight":"paddingLeft";r.style[a]=o+"px"},t.prototype.setupIndent=function(){var e=this.params.node;this.params.suppressPadding||(this.addManagedListener(e,l.a.EVENT_UI_LEVEL_CHANGED,this.setIndent.bind(this)),this.setIndent())},t.prototype.addValueElement=function(){var e=this.params,t=this.displayedGroup;t.footer?this.createFooterCell():t.hasChildren()||c.f.get(e.colDef,"cellRendererParams.innerRenderer",null)||c.f.get(e.colDef,"cellRendererParams.innerRendererFramework",null)?(this.createGroupCell(),t.hasChildren()&&this.addChildCount()):this.createLeafCell()},t.prototype.createFooterCell=function(){var e,t=this.params.footerValueGetter;if(t){var o=c.f.cloneObject(this.params);o.value=this.params.value,"function"==typeof t?e=t(o):"string"==typeof t?e=this.expressionService.evaluate(t,o):console.warn("ag-Grid: footerValueGetter should be either a function or a string (expression)")}else e="Total "+this.params.value;this.eValue.innerHTML=e},t.prototype.createGroupCell=function(){var e,t=this,o=this.params,r=this.displayedGroup.rowGroupColumn,a=r||o.column,n=this.params.value,i=a?this.valueFormatterService.formatValue(a,o.node,o.scope,n):null;o.valueFormatted=i,(e=o.fullWidth?this.useFullWidth(o):this.useInnerRenderer(this.params.colDef.cellRendererParams,a.getColDef(),o))&&e.then((function(e){t.innerCellRenderer=e}))},t.prototype.useInnerRenderer=function(e,t,o){var r=this,a=null,n=this.userComponentFactory.lookupComponentClassDef(e,"innerRenderer");if(n&&null!=n.component&&n.source!=p.a.DEFAULT)a=this.userComponentFactory.newInnerCellRenderer(e,o);else{var i=this.userComponentFactory.lookupComponentClassDef(t,"cellRenderer");a=i&&i.source!=p.a.DEFAULT?this.userComponentFactory.newCellRenderer(t,o):i&&i.source==p.a.DEFAULT&&c.f.get(t,"cellRendererParams.innerRenderer",null)?this.userComponentFactory.newInnerCellRenderer(t.cellRendererParams,o):this.userComponentFactory.newCellRenderer({},o)}return null!=a?a.then((function(e){null!=e?c.f.bindCellRendererToHtmlElement(a,r.eValue):r.eValue.innerText=null!=o.valueFormatted?o.valueFormatted:o.value})):this.eValue.innerText=null!=o.valueFormatted?o.valueFormatted:o.value,a},t.prototype.useFullWidth=function(e){var t=this.userComponentFactory.newFullWidthGroupRowInnerCellRenderer(e);return null!=t?c.f.bindCellRendererToHtmlElement(t,this.eValue):this.eValue.innerText=null!=e.valueFormatted?e.valueFormatted:e.value,t},t.prototype.addChildCount=function(){this.params.suppressCount||(this.addManagedListener(this.displayedGroup,l.a.EVENT_ALL_CHILDREN_COUNT_CHANGED,this.updateChildCount.bind(this)),this.updateChildCount())},t.prototype.updateChildCount=function(){var e=this.displayedGroup.allChildrenCount;this.eChildCount.innerHTML=e>=0?"("+e+")":""},t.prototype.createLeafCell=function(){c.f.exists(this.params.value)&&(this.eValue.innerText=this.params.valueFormatted?this.params.valueFormatted:this.params.value)},t.prototype.isUserWantsSelected=function(){var e=this.params.checkbox;return"function"==typeof e?e(this.params):!0===e},t.prototype.addCheckboxIfNeeded=function(){var e=this,t=this.displayedGroup,o=this.isUserWantsSelected()&&!t.footer&&!t.rowPinned&&!t.detail;if(o){var r=new g.a;this.getContext().createBean(r),r.init({rowNode:t,column:this.params.column}),this.eCheckbox.appendChild(r.getGui()),this.addDestroyFunc((function(){return e.getContext().destroyBean(r)}))}c.f.addOrRemoveCssClass(this.eCheckbox,"ag-invisible",!o)},t.prototype.addExpandAndContract=function(){var e=this.params,t=e.eGridCell,o=c.f.createIconNoSpan("groupExpanded",this.gridOptionsWrapper,null),r=c.f.createIconNoSpan("groupContracted",this.gridOptionsWrapper,null);this.eExpanded.appendChild(o),this.eContracted.appendChild(r),this.addManagedListener(this.eExpanded,"click",this.onExpandClicked.bind(this)),this.addManagedListener(this.eContracted,"click",this.onExpandClicked.bind(this)),this.addManagedListener(t,"keydown",this.onKeyDown.bind(this)),this.addManagedListener(e.node,l.a.EVENT_EXPANDED_CHANGED,this.showExpandAndContractIcons.bind(this)),this.showExpandAndContractIcons(),this.addManagedListener(this.displayedGroup,l.a.EVENT_ALL_CHILDREN_COUNT_CHANGED,this.onRowNodeIsExpandableChanged.bind(this)),this.addManagedListener(this.displayedGroup,l.a.EVENT_MASTER_CHANGED,this.onRowNodeIsExpandableChanged.bind(this)),this.gridOptionsWrapper.isEnableGroupEdit()||!this.isExpandable()||e.suppressDoubleClickExpand||this.addManagedListener(t,"dblclick",this.onCellDblClicked.bind(this))},t.prototype.onRowNodeIsExpandableChanged=function(){this.showExpandAndContractIcons(),this.setIndent()},t.prototype.onKeyDown=function(e){c.f.isKeyPressed(e,a.a.KEY_ENTER)&&!this.params.suppressEnterExpand&&(this.params.column&&this.params.column.isCellEditable(this.params.node)||(e.preventDefault(),this.onExpandOrContract()))},t.prototype.setupDragOpenParents=function(){var e=this.params.column,t=this.params.node;if(this.gridOptionsWrapper.isGroupHideOpenParents())if(t.hasChildren()){var o=t.rowGroupColumn;this.draggedFromHideOpenParents=!!o&&!e.isRowGroupDisplayed(o.getId())}else this.draggedFromHideOpenParents=!0;else this.draggedFromHideOpenParents=!1;if(this.draggedFromHideOpenParents)for(var r=t.parent;!c.f.missing(r);){if(r.rowGroupColumn&&e.isRowGroupDisplayed(r.rowGroupColumn.getId())){this.displayedGroup=r;break}r=r.parent}c.f.missing(this.displayedGroup)&&(this.displayedGroup=t)},t.prototype.onExpandClicked=function(e){c.f.isStopPropagationForAgGrid(e)||(c.f.stopPropagationForAgGrid(e),this.onExpandOrContract())},t.prototype.onCellDblClicked=function(e){c.f.isStopPropagationForAgGrid(e)||(c.f.isElementInEventPath(this.eExpanded,e)||c.f.isElementInEventPath(this.eContracted,e)||this.onExpandOrContract())},t.prototype.onExpandOrContract=function(){var e=this.displayedGroup;e.setExpanded(!e.expanded)},t.prototype.isExpandable=function(){var e=this.params.node,t=this.columnController.isPivotMode()&&e.leafGroup;return this.draggedFromHideOpenParents||e.isExpandable()&&!e.footer&&!t},t.prototype.showExpandAndContractIcons=function(){var e=this.params.node;if(this.isExpandable()){var t=!!this.draggedFromHideOpenParents||e.expanded;c.f.setDisplayed(this.eContracted,!t),c.f.setDisplayed(this.eExpanded,t)}else c.f.setDisplayed(this.eExpanded,!1),c.f.setDisplayed(this.eContracted,!1);var o=this.displayedGroup,r=this.columnController.isPivotMode()&&o.leafGroup,a=!o.isExpandable(),n=o.footer||a||r;this.addOrRemoveCssClass("ag-row-group",!n),this.addOrRemoveCssClass("ag-row-group-leaf-indent",n)},t.prototype.destroy=function(){this.getContext().destroyBean(this.innerCellRenderer),e.prototype.destroy.call(this)},t.prototype.refresh=function(){return!1},t.TEMPLATE='',u([Object(n.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),u([Object(n.a)("expressionService")],t.prototype,"expressionService",void 0),u([Object(n.a)("valueFormatterService")],t.prototype,"valueFormatterService",void 0),u([Object(n.a)("columnController")],t.prototype,"columnController",void 0),u([Object(n.a)("userComponentFactory")],t.prototype,"userComponentFactory",void 0),u([Object(s.d)("eExpanded")],t.prototype,"eExpanded",void 0),u([Object(s.d)("eContracted")],t.prototype,"eContracted",void 0),u([Object(s.d)("eCheckbox")],t.prototype,"eCheckbox",void 0),u([Object(s.d)("eValue")],t.prototype,"eValue",void 0),u([Object(s.d)("eChildCount")],t.prototype,"eChildCount",void 0),t}(i.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return h}));var r,a=o(35),n=o(16),i=o(4),l=o(7),g=o(2),s=o(10),p=o(11),c=o(0),d=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),u=function(){return(u=Object.assign||function(e){for(var t,o=1,r=arguments.length;o'),o.push(e),o.push("
"),o.join("")},t.prototype.getCellForCol=function(e){var t=this.cellComps[e.getColId()];return t?t.getGui():null},t.prototype.afterFlush=function(){this.initialised||(this.initialised=!0,this.executeProcessRowPostCreateFunc())},t.prototype.executeProcessRowPostCreateFunc=function(){var e=this.beans.gridOptionsWrapper.getProcessRowPostCreateFunc();e&&e({eRow:this.eBodyRow,ePinnedLeftRow:this.ePinnedLeftRow,ePinnedRightRow:this.ePinnedRightRow,node:this.rowNode,api:this.beans.gridOptionsWrapper.getApi(),rowIndex:this.rowNode.rowIndex,addRenderedRowListener:this.addEventListener.bind(this),columnApi:this.beans.gridOptionsWrapper.getColumnApi(),context:this.beans.gridOptionsWrapper.getContext()})},t.prototype.getInitialRowTopStyle=function(){if(this.printLayout)return"";var e=this.slideRowIn?this.roundRowTopToBounds(this.rowNode.oldRowTop):this.rowNode.rowTop,t=this.applyPaginationOffset(e),o=this.beans.maxDivHeightScaler.getRealPixelPosition(t);return this.beans.gridOptionsWrapper.isSuppressRowTransform()?"top: "+o+"px; ":"transform: translateY("+o+"px);"},t.prototype.getRowBusinessKey=function(){var e=this.beans.gridOptionsWrapper.getBusinessKeyForNodeFunc();if("function"==typeof e)return e(this.rowNode)},t.prototype.areAllContainersReady=function(){return 3===this.rowContainerReadyCount},t.prototype.lazyCreateCells=function(e,t){if(this.active){var o=this.createCells(e);t.innerHTML=o.template,this.callAfterRowAttachedOnCells(o.cellComps,t),this.rowContainerReadyCount++,this.areAllContainersReady()&&this.refreshNeeded&&this.refreshCells()}},t.prototype.createRowContainer=function(e,t,o){var r=this,a=this.useAnimationFrameForCreate,n=a?{cellComps:[],template:""}:this.createCells(t),i=this.createTemplate(n.template);e.appendRowTemplate(i,(function(){var i=e.getRowElement(r.getCompId());r.afterRowAttached(e,i),o(i),a?r.beans.taskQueue.createTask(r.lazyCreateCells.bind(r,t,i),r.rowNode.rowIndex,"createTasksP1"):(r.callAfterRowAttachedOnCells(n.cellComps,i),r.rowContainerReadyCount=3)}))},t.prototype.createChildScopeOrNull=function(e){if(!this.beans.gridOptionsWrapper.isAngularCompileRows())return null;var t=this.parentScope.$new();return t.data=u({},e),t.rowNode=this.rowNode,t.context=this.beans.gridOptionsWrapper.getContext(),this.addDestroyFunc((function(){t.$destroy(),t.data=null,t.rowNode=null,t.context=null})),t},t.prototype.setupRowContainers=function(){var e=this.rowNode.isFullWidthCell(),o=this.beans.doingMasterDetail&&this.rowNode.detail,r=this.beans.columnController.isPivotMode(),a=this.rowNode.group&&!this.rowNode.footer&&this.beans.gridOptionsWrapper.isGroupUseEntireRow(r);this.rowNode.stub?this.createFullWidthRows(t.LOADING_CELL_RENDERER,t.LOADING_CELL_RENDERER_COMP_NAME):o?this.createFullWidthRows(t.DETAIL_CELL_RENDERER,t.DETAIL_CELL_RENDERER_COMP_NAME):e?this.createFullWidthRows(t.FULL_WIDTH_CELL_RENDERER,null):a?this.createFullWidthRows(t.GROUP_ROW_RENDERER,t.GROUP_ROW_RENDERER_COMP_NAME):this.setupNormalRowContainers()},t.prototype.setupNormalRowContainers=function(){var e,t=this,o=[],r=[];this.printLayout?e=this.beans.columnController.getAllDisplayedColumns():(e=this.beans.columnController.getAllDisplayedCenterVirtualColumnsForRow(this.rowNode),o=this.beans.columnController.getDisplayedLeftColumnsForRow(this.rowNode),r=this.beans.columnController.getDisplayedRightColumnsForRow(this.rowNode)),this.createRowContainer(this.bodyContainerComp,e,(function(e){return t.eBodyRow=e})),this.createRowContainer(this.pinnedRightContainerComp,r,(function(e){return t.ePinnedRightRow=e})),this.createRowContainer(this.pinnedLeftContainerComp,o,(function(e){return t.ePinnedLeftRow=e}))},t.prototype.createFullWidthRows=function(e,t){var o=this;if(this.fullWidthRow=!0,this.embedFullWidth){if(this.createFullWidthRowContainer(this.bodyContainerComp,null,null,e,t,(function(e){o.eFullWidthRowBody=e}),(function(e){o.fullWidthRowComponentBody=e})),this.printLayout)return;this.createFullWidthRowContainer(this.pinnedLeftContainerComp,g.a.PINNED_LEFT,"ag-cell-last-left-pinned",e,t,(function(e){o.eFullWidthRowLeft=e}),(function(e){o.fullWidthRowComponentLeft=e})),this.createFullWidthRowContainer(this.pinnedRightContainerComp,g.a.PINNED_RIGHT,"ag-cell-first-right-pinned",e,t,(function(e){o.eFullWidthRowRight=e}),(function(e){o.fullWidthRowComponentRight=e}))}else this.createFullWidthRowContainer(this.fullWidthContainerComp,null,null,e,t,(function(e){o.eFullWidthRow=e}),(function(e){o.fullWidthRowComponent=e}))},t.prototype.setAnimateFlags=function(e){if(e){var t=c.f.exists(this.rowNode.oldRowTop);this.slideRowIn=t,this.fadeRowIn=!t}else this.slideRowIn=!1,this.fadeRowIn=!1},t.prototype.isEditing=function(){return this.editingRow},t.prototype.stopRowEditing=function(e){this.stopEditing(e)},t.prototype.isFullWidth=function(){return this.fullWidthRow},t.prototype.refreshFullWidth=function(){var e=this,t=function(t,o,r){if(!t||!o)return!0;if(!o.refresh)return!1;var a=e.createFullWidthParams(t,r);return o.refresh(a)},o=t(this.eFullWidthRow,this.fullWidthRowComponent,null),r=t(this.eFullWidthRowBody,this.fullWidthRowComponentBody,null),a=t(this.eFullWidthRowLeft,this.fullWidthRowComponentLeft,g.a.PINNED_LEFT),n=t(this.eFullWidthRowRight,this.fullWidthRowComponentRight,g.a.PINNED_RIGHT);return o&&r&&a&&n},t.prototype.addListeners=function(){this.addManagedListener(this.rowNode,n.a.EVENT_HEIGHT_CHANGED,this.onRowHeightChanged.bind(this)),this.addManagedListener(this.rowNode,n.a.EVENT_ROW_SELECTED,this.onRowSelected.bind(this)),this.addManagedListener(this.rowNode,n.a.EVENT_ROW_INDEX_CHANGED,this.onRowIndexChanged.bind(this)),this.addManagedListener(this.rowNode,n.a.EVENT_TOP_CHANGED,this.onTopChanged.bind(this)),this.addManagedListener(this.rowNode,n.a.EVENT_EXPANDED_CHANGED,this.onExpandedChanged.bind(this)),this.addManagedListener(this.rowNode,n.a.EVENT_DATA_CHANGED,this.onRowNodeDataChanged.bind(this)),this.addManagedListener(this.rowNode,n.a.EVENT_CELL_CHANGED,this.onRowNodeCellChanged.bind(this)),this.addManagedListener(this.rowNode,n.a.EVENT_HIGHLIGHT_CHANGED,this.onRowNodeHighlightChanged.bind(this)),this.addManagedListener(this.rowNode,n.a.EVENT_DRAGGING_CHANGED,this.onRowNodeDraggingChanged.bind(this));var e=this.beans.eventService;this.addManagedListener(e,i.a.EVENT_HEIGHT_SCALE_CHANGED,this.onTopChanged.bind(this)),this.addManagedListener(e,i.a.EVENT_DISPLAYED_COLUMNS_CHANGED,this.onDisplayedColumnsChanged.bind(this)),this.addManagedListener(e,i.a.EVENT_VIRTUAL_COLUMNS_CHANGED,this.onVirtualColumnsChanged.bind(this)),this.addManagedListener(e,i.a.EVENT_COLUMN_RESIZED,this.onColumnResized.bind(this)),this.addManagedListener(e,i.a.EVENT_CELL_FOCUSED,this.onCellFocusChanged.bind(this)),this.addManagedListener(e,i.a.EVENT_PAGINATION_CHANGED,this.onPaginationChanged.bind(this)),this.addManagedListener(e,i.a.EVENT_MODEL_UPDATED,this.onModelUpdated.bind(this)),this.addManagedListener(e,i.a.EVENT_COLUMN_MOVED,this.onColumnMoved.bind(this)),this.addListenersForCellComps()},t.prototype.addListenersForCellComps=function(){var e=this;this.addManagedListener(this.rowNode,n.a.EVENT_ROW_INDEX_CHANGED,(function(){e.forEachCellComp((function(e){return e.onRowIndexChanged()}))})),this.addManagedListener(this.rowNode,n.a.EVENT_CELL_CHANGED,(function(t){e.forEachCellComp((function(e){return e.onCellChanged(t)}))}))},t.prototype.onRowNodeDataChanged=function(e){this.forEachCellComp((function(t){return t.refreshCell({suppressFlash:!e.update,newData:!e.update})})),this.onRowSelected(),this.postProcessCss()},t.prototype.onRowNodeCellChanged=function(){this.postProcessCss()},t.prototype.postProcessCss=function(){this.postProcessStylesFromGridOptions(),this.postProcessClassesFromGridOptions(),this.postProcessRowClassRules(),this.postProcessRowDragging()},t.prototype.onRowNodeHighlightChanged=function(){var e=this.rowNode.highlighted;this.eAllRowContainers.forEach((function(t){c.f.removeCssClass(t,"ag-row-highlight-above"),c.f.removeCssClass(t,"ag-row-highlight-below"),e&&c.f.addCssClass(t,"ag-row-highlight-"+e)}))},t.prototype.onRowNodeDraggingChanged=function(){this.postProcessRowDragging()},t.prototype.postProcessRowDragging=function(){var e=this.rowNode.dragging;this.eAllRowContainers.forEach((function(t){return c.f.addOrRemoveCssClass(t,"ag-row-dragging",e)}))},t.prototype.onExpandedChanged=function(){var e=this.rowNode;this.eAllRowContainers.forEach((function(t){return c.f.addOrRemoveCssClass(t,"ag-row-group-expanded",e.expanded)})),this.eAllRowContainers.forEach((function(t){return c.f.addOrRemoveCssClass(t,"ag-row-group-contracted",!e.expanded)}))},t.prototype.onDisplayedColumnsChanged=function(){this.fullWidthRow||this.refreshCells()},t.prototype.destroyFullWidthComponents=function(){this.fullWidthRowComponent&&(this.beans.detailRowCompCache.addOrDestroy(this.rowNode,null,this.fullWidthRowComponent),this.fullWidthRowComponent=null),this.fullWidthRowComponentBody&&(this.beans.detailRowCompCache.addOrDestroy(this.rowNode,null,this.fullWidthRowComponentBody),this.fullWidthRowComponent=null),this.fullWidthRowComponentLeft&&(this.beans.detailRowCompCache.addOrDestroy(this.rowNode,g.a.PINNED_LEFT,this.fullWidthRowComponentLeft),this.fullWidthRowComponentLeft=null),this.fullWidthRowComponentRight&&(this.beans.detailRowCompCache.addOrDestroy(this.rowNode,g.a.PINNED_RIGHT,this.fullWidthRowComponentRight),this.fullWidthRowComponent=null)},t.prototype.getContainerForCell=function(e){switch(e){case g.a.PINNED_LEFT:return this.ePinnedLeftRow;case g.a.PINNED_RIGHT:return this.ePinnedRightRow;default:return this.eBodyRow}},t.prototype.onVirtualColumnsChanged=function(){this.fullWidthRow||this.refreshCells()},t.prototype.onColumnResized=function(){this.fullWidthRow||this.refreshCells()},t.prototype.refreshCells=function(){if(this.areAllContainersReady())if(this.beans.gridOptionsWrapper.isSuppressAnimationFrame()||this.printLayout)this.refreshCellsInAnimationFrame();else{if(this.columnRefreshPending)return;this.beans.taskQueue.createTask(this.refreshCellsInAnimationFrame.bind(this),this.rowNode.rowIndex,"createTasksP1")}else this.refreshNeeded=!0},t.prototype.refreshCellsInAnimationFrame=function(){if(this.active){var e,t,o;this.columnRefreshPending=!1,this.printLayout?(e=this.beans.columnController.getAllDisplayedColumns(),t=[],o=[]):(e=this.beans.columnController.getAllDisplayedCenterVirtualColumnsForRow(this.rowNode),t=this.beans.columnController.getDisplayedLeftColumnsForRow(this.rowNode),o=this.beans.columnController.getDisplayedRightColumnsForRow(this.rowNode)),this.insertCellsIntoContainer(this.eBodyRow,e),this.insertCellsIntoContainer(this.ePinnedLeftRow,t),this.insertCellsIntoContainer(this.ePinnedRightRow,o),this.elementOrderChanged=!1;var r=Object.keys(this.cellComps);e.forEach((function(e){return c.f.removeFromArray(r,e.getId())})),t.forEach((function(e){return c.f.removeFromArray(r,e.getId())})),o.forEach((function(e){return c.f.removeFromArray(r,e.getId())}));var a=r.filter(this.isCellEligibleToBeRemoved.bind(this));this.removeRenderedCells(a)}},t.prototype.onColumnMoved=function(){this.elementOrderChanged=!0},t.prototype.removeRenderedCells=function(e){var t=this;e.forEach((function(e){var o=t.cellComps[e];c.f.missing(o)||(o.detach(),o.destroy(),t.cellComps[e]=null)}))},t.prototype.isCellEligibleToBeRemoved=function(e){var t=this.beans.columnController.getAllDisplayedColumns(),o=this.cellComps[e];if(!o||this.isCellInWrongRow(o))return!0;var r=o.isEditing(),a=this.beans.focusController.isCellFocused(o.getCellPosition());if(r||a){var n=o.getColumn();return!(t.indexOf(n)>=0)}return!0},t.prototype.ensureCellInCorrectContainer=function(e){if(!this.printLayout){var t=e.getGui(),o=e.getColumn().getPinned(),r=this.getContainerForCell(o),a=e.getParentRow();a!==r&&(a&&a.removeChild(t),r.appendChild(t),e.setParentRow(r),this.elementOrderChanged=!0)}},t.prototype.isCellInWrongRow=function(e){var t=e.getColumn(),o=this.getContainerForCell(t.getPinned());return e.getParentRow()!==o},t.prototype.insertCellsIntoContainer=function(e,t){var o=this;if(e){var r=[],a=[];if(t.forEach((function(t){var n=t.getId(),i=o.cellComps[n];i?o.ensureCellInCorrectContainer(i):o.createNewCell(t,e,r,a)})),r.length>0&&(c.f.appendHtml(e,r.join("")),this.callAfterRowAttachedOnCells(a,e)),this.elementOrderChanged&&this.beans.gridOptionsWrapper.isEnsureDomOrder()){var n=t.map((function(e){return o.getCellForCol(e)}));c.f.setDomChildOrder(e,n)}}},t.prototype.addDomData=function(e){var o=this.beans.gridOptionsWrapper;o.setDomData(e,t.DOM_DATA_KEY_RENDERED_ROW,this),this.addDestroyFunc((function(){o.setDomData(e,t.DOM_DATA_KEY_RENDERED_ROW,null)}))},t.prototype.createNewCell=function(e,t,o,r){var n=new a.a(this.scope,this.beans,e,this.rowNode,this,!1,this.printLayout),i=n.getCreateTemplate();o.push(i),r.push(n),this.cellComps[e.getId()]=n,n.setParentRow(t),this.elementOrderChanged=!0},t.prototype.onMouseEvent=function(e,t){switch(e){case"dblclick":this.onRowDblClick(t);break;case"click":this.onRowClick(t);break;case"mousedown":this.onRowMouseDown(t)}},t.prototype.createRowEvent=function(e,t){return{type:e,node:this.rowNode,data:this.rowNode.data,rowIndex:this.rowNode.rowIndex,rowPinned:this.rowNode.rowPinned,context:this.beans.gridOptionsWrapper.getContext(),api:this.beans.gridOptionsWrapper.getApi(),columnApi:this.beans.gridOptionsWrapper.getColumnApi(),event:t}},t.prototype.createRowEventWithSource=function(e,t){var o=this.createRowEvent(e,t);return o.source=this,o},t.prototype.onRowDblClick=function(e){if(!c.f.isStopPropagationForAgGrid(e)){var t=this.createRowEventWithSource(i.a.EVENT_ROW_DOUBLE_CLICKED,e);this.beans.eventService.dispatchEvent(t)}},t.prototype.onRowMouseDown=function(e){this.lastMouseDownOnDragger=c.f.isElementChildOfClass(e.target,"ag-row-drag",3)},t.prototype.onRowClick=function(e){if(!(c.f.isStopPropagationForAgGrid(e)||this.lastMouseDownOnDragger)){var t=this.createRowEventWithSource(i.a.EVENT_ROW_CLICKED,e);this.beans.eventService.dispatchEvent(t);var o=e.ctrlKey||e.metaKey,r=e.shiftKey;if(!this.rowNode.group&&this.rowNode.selectable&&!this.rowNode.rowPinned&&this.beans.gridOptionsWrapper.isRowSelection()&&!this.beans.gridOptionsWrapper.isSuppressRowClickSelection()){var a=this.beans.gridOptionsWrapper.isRowMultiSelectWithClick(),n=this.beans.gridOptionsWrapper.isRowDeselection();if(this.rowNode.isSelected())a?this.rowNode.setSelectedParams({newValue:!1}):o?n&&this.rowNode.setSelectedParams({newValue:!1}):this.rowNode.setSelectedParams({newValue:!0,clearSelection:!0});else{var l=!a&&!o;this.rowNode.setSelectedParams({newValue:!0,clearSelection:l,rangeSelect:r})}}}},t.prototype.createFullWidthRowContainer=function(e,t,o,r,a,n,i){var l=this,g=this.createTemplate("",o);e.appendRowTemplate(g,(function(){var o=e.getRowElement(l.getCompId()),g=l.createFullWidthParams(o,t),c=function(e){if(l.isAlive()){var t=e.getGui();o.appendChild(t),i(e)}else l.beans.context.destroyBean(e)},d=l.beans.detailRowCompCache.get(l.rowNode,t);if(d)c(d);else{var u=l.beans.userComponentFactory.newFullWidthCellRenderer(g,r,a);if(!u){var h=p.a.isRegistered(s.a.MasterDetailModule);return void("agDetailCellRenderer"!==a||h?console.error("ag-Grid: fullWidthCellRenderer "+a+" not found"):console.warn("ag-Grid: cell renderer agDetailCellRenderer (for master detail) not found. Did you forget to include the master detail module?"))}u.then(c)}l.afterRowAttached(e,o),n(o),l.angular1Compile(o)}))},t.prototype.angular1Compile=function(e){this.scope&&this.beans.$compile(e)(this.scope)},t.prototype.createFullWidthParams=function(e,t){return{fullWidth:!0,data:this.rowNode.data,node:this.rowNode,value:this.rowNode.key,$scope:this.scope?this.scope:this.parentScope,$compile:this.beans.$compile,rowIndex:this.rowNode.rowIndex,api:this.beans.gridOptionsWrapper.getApi(),columnApi:this.beans.gridOptionsWrapper.getColumnApi(),context:this.beans.gridOptionsWrapper.getContext(),eGridCell:e,eParentOfValue:e,pinned:t,addRenderedRowListener:this.addEventListener.bind(this)}},t.prototype.getInitialRowClasses=function(e){var t=[],o=this.beans.gridOptionsWrapper.isTreeData(),r=this.rowNode;return c.f.exists(e)&&t.push(e),t.push("ag-row"),t.push(this.rowFocused?"ag-row-focus":"ag-row-no-focus"),this.fadeRowIn&&t.push("ag-opacity-zero"),t.push(this.rowIsEven?"ag-row-even":"ag-row-odd"),r.isRowPinned()&&t.push("ag-row-pinned"),r.isSelected()&&t.push("ag-row-selected"),r.group?(t.push("ag-row-group"),t.push("ag-row-level-"+r.level),r.footer&&t.push("ag-row-footer")):t.push("ag-row-level-"+(r.parent?r.parent.level+1:"0")),r.stub&&t.push("ag-row-loading"),this.fullWidthRow&&t.push("ag-full-width-row"),(o?r.allChildrenCount:r.group&&!r.footer)&&t.push(r.expanded?"ag-row-group-expanded":"ag-row-group-contracted"),r.dragging&&t.push("ag-row-dragging"),c.f.pushAll(t,this.processClassesFromGridOptions()),c.f.pushAll(t,this.preProcessRowClassRules()),t.push(this.printLayout?"ag-row-position-relative":"ag-row-position-absolute"),this.firstRowOnPage=this.isFirstRowOnPage(),this.lastRowOnPage=this.isLastRowOnPage(),this.firstRowOnPage&&t.push("ag-row-first"),this.lastRowOnPage&&t.push("ag-row-last"),t},t.prototype.isFirstRowOnPage=function(){return this.rowNode.rowIndex===this.beans.paginationProxy.getPageFirstRow()},t.prototype.isLastRowOnPage=function(){return this.rowNode.rowIndex===this.beans.paginationProxy.getPageLastRow()},t.prototype.onModelUpdated=function(){var e=this.isFirstRowOnPage(),t=this.isLastRowOnPage();this.firstRowOnPage!==e&&(this.firstRowOnPage=e,this.eAllRowContainers.forEach((function(t){return c.f.addOrRemoveCssClass(t,"ag-row-first",e)}))),this.lastRowOnPage!==t&&(this.lastRowOnPage=t,this.eAllRowContainers.forEach((function(e){return c.f.addOrRemoveCssClass(e,"ag-row-last",t)})))},t.prototype.preProcessRowClassRules=function(){var e=[];return this.processRowClassRules((function(t){e.push(t)}),(function(e){})),e},t.prototype.processRowClassRules=function(e,t){this.beans.stylingService.processClassRules(this.beans.gridOptionsWrapper.rowClassRules(),{value:void 0,colDef:void 0,data:this.rowNode.data,node:this.rowNode,rowIndex:this.rowNode.rowIndex,api:this.beans.gridOptionsWrapper.getApi(),columnApi:this.beans.gridOptionsWrapper.getColumnApi(),$scope:this.scope,context:this.beans.gridOptionsWrapper.getContext()},e,t)},t.prototype.stopEditing=function(e){if(void 0===e&&(e=!1),this.forEachCellComp((function(t){t.stopEditing(e)})),this.editingRow){if(!e){var t=this.createRowEvent(i.a.EVENT_ROW_VALUE_CHANGED);this.beans.eventService.dispatchEvent(t)}this.setEditingRow(!1)}},t.prototype.setEditingRow=function(e){this.editingRow=e,this.eAllRowContainers.forEach((function(t){return c.f.addOrRemoveCssClass(t,"ag-row-editing",e)}));var t=e?this.createRowEvent(i.a.EVENT_ROW_EDITING_STARTED):this.createRowEvent(i.a.EVENT_ROW_EDITING_STOPPED);this.beans.eventService.dispatchEvent(t)},t.prototype.startRowEditing=function(e,t,o){void 0===e&&(e=null),void 0===t&&(t=null),void 0===o&&(o=null),this.editingRow||(this.forEachCellComp((function(r){var a=r===o;a?r.startEditingIfEnabled(e,t,a):r.startEditingIfEnabled(null,null,a)})),this.setEditingRow(!0))},t.prototype.forEachCellComp=function(e){c.f.iterateObject(this.cellComps,(function(t,o){o&&e(o)}))},t.prototype.postProcessClassesFromGridOptions=function(){var e=this,t=this.processClassesFromGridOptions();t&&t.length&&t.forEach((function(t){e.eAllRowContainers.forEach((function(e){return c.f.addCssClass(e,t)}))}))},t.prototype.postProcessRowClassRules=function(){var e=this;this.processRowClassRules((function(t){e.eAllRowContainers.forEach((function(e){return c.f.addCssClass(e,t)}))}),(function(t){e.eAllRowContainers.forEach((function(e){return c.f.removeCssClass(e,t)}))}))},t.prototype.processClassesFromGridOptions=function(){var e=[],t=function(t){"string"==typeof t?e.push(t):Array.isArray(t)&&t.forEach((function(t){return e.push(t)}))},o=this.beans.gridOptionsWrapper.getRowClass();if(o){if("function"==typeof o)return void console.warn("ag-Grid: rowClass should not be a function, please use getRowClass instead");t(o)}var r=this.beans.gridOptionsWrapper.getRowClassFunc();r&&t(r({node:this.rowNode,data:this.rowNode.data,rowIndex:this.rowNode.rowIndex,context:this.beans.gridOptionsWrapper.getContext(),api:this.beans.gridOptionsWrapper.getApi()}));return e},t.prototype.preProcessStylesFromGridOptions=function(){var e=this.processStylesFromGridOptions();return c.f.cssStyleObjectToMarkup(e)},t.prototype.postProcessStylesFromGridOptions=function(){var e=this.processStylesFromGridOptions();this.eAllRowContainers.forEach((function(t){return c.f.addStylesToElement(t,e)}))},t.prototype.processStylesFromGridOptions=function(){var e=this.beans.gridOptionsWrapper.getRowStyle();if(!e||"function"!=typeof e){var t,o=this.beans.gridOptionsWrapper.getRowStyleFunc();if(o)t=o({data:this.rowNode.data,node:this.rowNode,api:this.beans.gridOptionsWrapper.getApi(),context:this.beans.gridOptionsWrapper.getContext(),$scope:this.scope});return c.f.assign({},e,t)}console.warn("ag-Grid: rowStyle should be an object of key/value styles, not be a function, use getRowStyle() instead")},t.prototype.createCells=function(e){var t=this,o=[],r=[];return e.forEach((function(e){var n=new a.a(t.scope,t.beans,e,t.rowNode,t,!1,t.printLayout),i=n.getCreateTemplate();o.push(i),r.push(n),t.cellComps[e.getId()]=n})),{template:o.join(""),cellComps:r}},t.prototype.onRowSelected=function(){var e=this.rowNode.isSelected();this.eAllRowContainers.forEach((function(t){return c.f.addOrRemoveCssClass(t,"ag-row-selected",e)}))},t.prototype.callAfterRowAttachedOnCells=function(e,t){var o=this;e.forEach((function(e){e.setParentRow(t),e.afterAttached(),o.editingRow&&e.startEditingIfEnabled()}))},t.prototype.afterRowAttached=function(e,t){var o=this;this.addDomData(t),this.removeSecondPassFuncs.push((function(){e.removeRowElement(t)})),this.removeFirstPassFuncs.push((function(){if(c.f.exists(o.rowNode.rowTop)){var e=o.roundRowTopToBounds(o.rowNode.rowTop);o.setRowTop(e)}else c.f.addCssClass(t,"ag-opacity-zero")})),this.eAllRowContainers.push(t),this.useAnimationFrameForCreate?this.beans.taskQueue.createTask(this.addHoverFunctionality.bind(this,t),this.rowNode.rowIndex,"createTasksP2"):this.addHoverFunctionality(t)},t.prototype.addHoverFunctionality=function(e){var t=this;this.active&&(this.addManagedListener(e,"mouseenter",(function(){return t.rowNode.onMouseEnter()})),this.addManagedListener(e,"mouseleave",(function(){return t.rowNode.onMouseLeave()})),this.addManagedListener(this.rowNode,n.a.EVENT_MOUSE_ENTER,(function(){t.beans.gridOptionsWrapper.isSuppressRowHoverHighlight()||c.f.addCssClass(e,"ag-row-hover")})),this.addManagedListener(this.rowNode,n.a.EVENT_MOUSE_LEAVE,(function(){c.f.removeCssClass(e,"ag-row-hover")})))},t.prototype.roundRowTopToBounds=function(e){var t=this.beans.gridPanel.getVScrollPosition(),o=this.applyPaginationOffset(t.top,!0)-100,r=this.applyPaginationOffset(t.bottom,!0)+100;return Math.min(Math.max(o,e),r)},t.prototype.getFrameworkOverrides=function(){return this.beans.frameworkOverrides},t.prototype.onRowHeightChanged=function(){if(c.f.exists(this.rowNode.rowHeight)){var e=this.rowNode.rowHeight+"px";this.eAllRowContainers.forEach((function(t){return t.style.height=e}))}},t.prototype.addEventListener=function(t,o){"renderedRowRemoved"!==t&&"rowRemoved"!==t||(t=i.a.EVENT_VIRTUAL_ROW_REMOVED,console.warn("ag-Grid: Since version 11, event renderedRowRemoved is now called "+i.a.EVENT_VIRTUAL_ROW_REMOVED)),e.prototype.addEventListener.call(this,t,o)},t.prototype.removeEventListener=function(t,o){"renderedRowRemoved"!==t&&"rowRemoved"!==t||(t=i.a.EVENT_VIRTUAL_ROW_REMOVED,console.warn("ag-Grid: Since version 11, event renderedRowRemoved and rowRemoved is now called "+i.a.EVENT_VIRTUAL_ROW_REMOVED)),e.prototype.removeEventListener.call(this,t,o)},t.prototype.destroy=function(t){(void 0===t&&(t=!1),this.active=!1,this.destroyFullWidthComponents(),t)?(this.removeFirstPassFuncs.forEach((function(e){return e()})),this.removeSecondPassFuncs.push(this.destroyContainingCells.bind(this))):(this.destroyContainingCells(),this.getAndClearDelayedDestroyFunctions().forEach((function(e){return e()})));var o=this.createRowEvent(i.a.EVENT_VIRTUAL_ROW_REMOVED);this.dispatchEvent(o),this.beans.eventService.dispatchEvent(o),e.prototype.destroy.call(this)},t.prototype.destroyContainingCells=function(){this.forEachCellComp((function(e){return e.destroy()})),this.destroyFullWidthComponents()},t.prototype.getAndClearDelayedDestroyFunctions=function(){var e=this.removeSecondPassFuncs;return this.removeSecondPassFuncs=[],e},t.prototype.onCellFocusChanged=function(){var e=this.beans.focusController.isRowFocused(this.rowNode.rowIndex,this.rowNode.rowPinned);e!==this.rowFocused&&(this.eAllRowContainers.forEach((function(t){return c.f.addOrRemoveCssClass(t,"ag-row-focus",e)})),this.eAllRowContainers.forEach((function(t){return c.f.addOrRemoveCssClass(t,"ag-row-no-focus",!e)})),this.rowFocused=e),!e&&this.editingRow&&this.stopEditing(!1)},t.prototype.onPaginationChanged=function(){var e=this.beans.paginationProxy.getCurrentPage();this.paginationPage!==e&&(this.paginationPage=e,this.onTopChanged())},t.prototype.onTopChanged=function(){this.setRowTop(this.rowNode.rowTop)},t.prototype.applyPaginationOffset=function(e,t){return void 0===t&&(t=!1),this.rowNode.isRowPinned()?e:e+this.beans.paginationProxy.getPixelOffset()*(t?1:-1)},t.prototype.setRowTop=function(e){if(!this.printLayout&&c.f.exists(e)){var t=this.applyPaginationOffset(e),o=this.beans.maxDivHeightScaler.getRealPixelPosition(t)+"px";this.beans.gridOptionsWrapper.isSuppressRowTransform()?this.eAllRowContainers.forEach((function(e){return e.style.top=o})):this.eAllRowContainers.forEach((function(e){return e.style.transform="translateY("+o+")"}))}},t.prototype.getAndClearNextVMTurnFunctions=function(){var e=this.createSecondPassFuncs;return this.createSecondPassFuncs=[],e},t.prototype.getRowNode=function(){return this.rowNode},t.prototype.getRenderedCellForColumn=function(e){var t=this,o=this.cellComps[e.getColId()];if(o)return o;var r=Object.keys(this.cellComps).map((function(e){return t.cellComps[e]})).filter((function(t){return t&&-1!==t.getColSpanningList().indexOf(e)}));return r.length?r[0]:void 0},t.prototype.onRowIndexChanged=function(){null!=this.rowNode.rowIndex&&(this.onCellFocusChanged(),this.updateRowIndexes())},t.prototype.updateRowIndexes=function(){var e=this,t=this.rowNode.getRowIndexString(),o=this.rowNode.rowIndex%2==0,r=this.rowIsEven!==o,a=this.beans.headerNavigationService.getHeaderRowCount();r&&(this.rowIsEven=o),this.eAllRowContainers.forEach((function(n){n.setAttribute("row-index",t),n.setAttribute("aria-rowindex",(a+e.rowNode.rowIndex+1).toString()),r&&(c.f.addOrRemoveCssClass(n,"ag-row-even",o),c.f.addOrRemoveCssClass(n,"ag-row-odd",!o))}))},t.prototype.ensureDomOrder=function(){[{el:this.getBodyRowElement(),ct:this.bodyContainerComp},{el:this.getPinnedLeftRowElement(),ct:this.pinnedLeftContainerComp},{el:this.getPinnedRightRowElement(),ct:this.pinnedRightContainerComp},{el:this.getFullWidthRowElement(),ct:this.fullWidthContainerComp}].forEach((function(e){e.el&&e.ct.ensureDomOrder(e.el)}))},t.prototype.getPinnedLeftRowElement=function(){return this.ePinnedLeftRow?this.ePinnedLeftRow:this.eFullWidthRowLeft},t.prototype.getPinnedRightRowElement=function(){return this.ePinnedRightRow?this.ePinnedRightRow:this.eFullWidthRowRight},t.prototype.getBodyRowElement=function(){return this.eBodyRow?this.eBodyRow:this.eFullWidthRowBody},t.prototype.getFullWidthRowElement=function(){return this.eFullWidthRow},t.DOM_DATA_KEY_RENDERED_ROW="renderedRow",t.FULL_WIDTH_CELL_RENDERER="fullWidthCellRenderer",t.GROUP_ROW_RENDERER="groupRowRenderer",t.GROUP_ROW_RENDERER_COMP_NAME="agGroupRowRenderer",t.LOADING_CELL_RENDERER="loadingCellRenderer",t.LOADING_CELL_RENDERER_COMP_NAME="agLoadingCellRenderer",t.DETAIL_CELL_RENDERER="detailCellRenderer",t.DETAIL_CELL_RENDERER_COMP_NAME="agDetailCellRenderer",t}(l.a)},function(e,t,o){"use strict";o.d(t,"b",(function(){return s})),o.d(t,"a",(function(){return p}));var r,a=o(1),n=o(6),i=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),l=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},g=function(e,t){return function(o,r){t(o,r,e)}},s=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return i(t,e),t.prototype.setBeans=function(e){this.logging=e.isDebug()},t.prototype.create=function(e){return new p(e,this.isLogging.bind(this))},t.prototype.isLogging=function(){return this.logging},l([g(0,Object(a.h)("gridOptionsWrapper"))],t.prototype,"setBeans",null),t=l([Object(a.b)("loggerFactory")],t)}(n.a),p=function(){function e(e,t){this.name=e,this.isLoggingFunc=t}return e.prototype.isLogging=function(){return this.isLoggingFunc()},e.prototype.log=function(e){this.isLoggingFunc()&&console.log("ag-Grid."+this.name+": "+e)},e}()},function(e,t,o){"use strict";o.d(t,"a",(function(){return p}));var r,a=o(0),n=o(16),i=o(1),l=o(6),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(o,r){var a=e.call(this)||this;return a.version=0,a.state=t.STATE_DIRTY,a.rowNodeCacheParams=r,a.blockNumber=o,a.startRow=o*r.blockSize,a.endRow=a.startRow+r.blockSize,a}return g(t,e),t.prototype.isAnyNodeOpen=function(e){var t=!1;return this.forEachNodeCallback((function(e){e.expanded&&(t=!0)}),e),t},t.prototype.forEachNodeCallback=function(e,t){for(var o=this.startRow;o0&&this.beans.rowRenderer.redrawRows(o)},t.prototype.destroyRowNodes=function(){var e=this;this.rowNodes.forEach((function(t){t.childrenCache&&(e.destroyBean(t.childrenCache),t.childrenCache=null),t.clearRowTop()}))},t.prototype.pageLoaded=function(e,o,r){e===this.version&&(this.state=t.STATE_LOADED,this.populateWithRowData(o)),r=a.f.cleanNumber(r);var n={type:t.EVENT_LOAD_COMPLETE,success:!0,page:this,lastRow:r};this.dispatchEvent(n)},t.EVENT_LOAD_COMPLETE="loadComplete",t.STATE_DIRTY="dirty",t.STATE_LOADING="loading",t.STATE_LOADED="loaded",t.STATE_FAILED="failed",s([i.g],t.prototype,"destroyRowNodes",null),t}(l.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return a})),o.d(t,"b",(function(){return me}));var r,a,n=o(45),i=o(1),l=o(52),g=o(7),s=o(12),p=o(24),c=o(5),d=o(4),u=o(0),h=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),f=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},m=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.lastMovingChanged=0,t}return h(t,e),t.prototype.destroy=function(){e.prototype.destroy.call(this)},t.prototype.init=function(e){var o=u.f.firstExistingValue(e.template,t.TEMPLATE);o=o&&o.trim?o.trim():o,this.setTemplate(o),this.params=e,this.setupTap(),this.setupIcons(e.column),this.setupMenu(),this.setupSort(),this.setupFilterIcon(),this.setupText(e.displayName)},t.prototype.setupText=function(e){var t=u.f.escape(e);this.eText&&(this.eText.innerHTML=t)},t.prototype.setupIcons=function(e){this.addInIcon("sortAscending",this.eSortAsc,e),this.addInIcon("sortDescending",this.eSortDesc,e),this.addInIcon("sortUnSort",this.eSortNone,e),this.addInIcon("menu",this.eMenu,e),this.addInIcon("filter",this.eFilter,e)},t.prototype.addInIcon=function(e,t,o){if(null!=t){var r=u.f.createIconNoSpan(e,this.gridOptionsWrapper,o);t.appendChild(r)}},t.prototype.setupTap=function(){var e=this,t=this.gridOptionsWrapper;if(!t.isSuppressTouch()){var o=new p.a(this.getGui(),!0),r=t.isSuppressMenuHide(),a=r&&u.f.exists(this.eMenu),n=a?new p.a(this.eMenu,!0):o;if(this.params.enableMenu){var i=a?"EVENT_TAP":"EVENT_LONG_TAP";this.addManagedListener(n,p.a[i],(function(o){t.getApi().showColumnMenuAfterMouseClick(e.params.column,o.touchStart)}))}if(this.params.enableSorting){this.addManagedListener(o,p.a.EVENT_TAP,(function(t){var o=t.touchStart.target;r&&e.eMenu.contains(o)||e.sortController.progressSort(e.params.column,!1,"uiColumnSorted")}))}this.addDestroyFunc((function(){return o.destroy()})),a&&this.addDestroyFunc((function(){return n.destroy()}))}},t.prototype.setupMenu=function(){var e=this;if(this.eMenu){var t=this.gridOptionsWrapper.isSuppressMenuHide();if(!this.params.enableMenu||u.f.isIOSUserAgent()&&!t)u.f.removeFromParent(this.eMenu);else{this.addManagedListener(this.eMenu,"click",(function(){return e.showMenu(e.eMenu)})),t||(this.eMenu.style.opacity="0");var o=this.eMenu.style;o.transition="opacity 0.2s, border 0.2s",o["-webkit-transition"]="opacity 0.2s, border 0.2s"}}},t.prototype.setActiveParent=function(e){this.gridOptionsWrapper.isSuppressMenuHide()||(this.eMenu.style.opacity=e?"1":"0")},t.prototype.showMenu=function(e){e||(e=this.eMenu),this.menuFactory.showMenuAfterButtonClick(this.params.column,e)},t.prototype.removeSortIcons=function(){u.f.removeFromParent(this.eSortAsc),u.f.removeFromParent(this.eSortDesc),u.f.removeFromParent(this.eSortNone),u.f.removeFromParent(this.eSortOrder)},t.prototype.setupSort=function(){var e=this;if(this.params.enableSorting){var t=this.gridOptionsWrapper.isMultiSortKeyCtrl();this.addManagedListener(this.params.column,s.a.EVENT_MOVING_CHANGED,(function(){e.lastMovingChanged=(new Date).getTime()})),this.eLabel&&this.addManagedListener(this.eLabel,"click",(function(o){var r=e.params.column.isMoving(),a=(new Date).getTime()-e.lastMovingChanged<50;if(!(r||a)){var n=t?o.ctrlKey||o.metaKey:o.shiftKey;e.params.progressSort(n)}})),this.addManagedListener(this.params.column,s.a.EVENT_SORT_CHANGED,this.onSortChanged.bind(this)),this.onSortChanged(),this.addManagedListener(this.eventService,d.a.EVENT_SORT_CHANGED,this.setMultiSortOrder.bind(this)),this.setMultiSortOrder()}else this.removeSortIcons()},t.prototype.onSortChanged=function(){if(u.f.addOrRemoveCssClass(this.getGui(),"ag-header-cell-sorted-asc",this.params.column.isSortAscending()),u.f.addOrRemoveCssClass(this.getGui(),"ag-header-cell-sorted-desc",this.params.column.isSortDescending()),u.f.addOrRemoveCssClass(this.getGui(),"ag-header-cell-sorted-none",this.params.column.isSortNone()),this.eSortAsc&&u.f.addOrRemoveCssClass(this.eSortAsc,"ag-hidden",!this.params.column.isSortAscending()),this.eSortDesc&&u.f.addOrRemoveCssClass(this.eSortDesc,"ag-hidden",!this.params.column.isSortDescending()),this.eSortNone){var e=!this.params.column.getColDef().unSortIcon&&!this.gridOptionsWrapper.isUnSortIcon();u.f.addOrRemoveCssClass(this.eSortNone,"ag-hidden",e||!this.params.column.isSortNone())}},t.prototype.setMultiSortOrder=function(){if(this.eSortOrder){var e=this.params.column,t=this.sortController.getColumnsWithSortingOrdered(),o=t.indexOf(e),r=t.length>1,a=e.isSorting()&&r;u.f.setDisplayed(this.eSortOrder,a),o>=0?this.eSortOrder.innerHTML=(o+1).toString():u.f.clearElement(this.eSortOrder)}},t.prototype.setupFilterIcon=function(){this.eFilter&&(this.addManagedListener(this.params.column,s.a.EVENT_FILTER_CHANGED,this.onFilterChanged.bind(this)),this.onFilterChanged())},t.prototype.onFilterChanged=function(){var e=this.params.column.isFilterActive();u.f.addOrRemoveCssClass(this.eFilter,"ag-hidden",!e)},t.TEMPLATE='
\n \n \n
',f([Object(i.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),f([Object(i.a)("sortController")],t.prototype,"sortController",void 0),f([Object(i.a)("menuFactory")],t.prototype,"menuFactory",void 0),f([Object(c.d)("eFilter")],t.prototype,"eFilter",void 0),f([Object(c.d)("eSortAsc")],t.prototype,"eSortAsc",void 0),f([Object(c.d)("eSortDesc")],t.prototype,"eSortDesc",void 0),f([Object(c.d)("eSortNone")],t.prototype,"eSortNone",void 0),f([Object(c.d)("eSortOrder")],t.prototype,"eSortOrder",void 0),f([Object(c.d)("eMenu")],t.prototype,"eMenu",void 0),f([Object(c.d)("eLabel")],t.prototype,"eLabel",void 0),f([Object(c.d)("eText")],t.prototype,"eText",void 0),t}(g.a),b=o(19),v=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),y=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},w=function(e){function t(){return e.call(this,t.TEMPLATE)||this}return v(t,e),t.prototype.destroy=function(){e.prototype.destroy.call(this)},t.prototype.init=function(e){this.params=e,this.setupLabel(),this.addGroupExpandIcon(),this.setupExpandIcons()},t.prototype.setupExpandIcons=function(){var e=this;this.addInIcon("columnGroupOpened","agOpened"),this.addInIcon("columnGroupClosed","agClosed");var t=function(t){if(!u.f.isStopPropagationForAgGrid(t)){var o=!e.params.columnGroup.isExpanded();e.columnController.setColumnGroupOpened(e.params.columnGroup.getOriginalColumnGroup(),o,"uiColumnExpanded")}};this.addTouchAndClickListeners(this.eCloseIcon,t),this.addTouchAndClickListeners(this.eOpenIcon,t);var o=function(e){u.f.stopPropagationForAgGrid(e)};this.addManagedListener(this.eCloseIcon,"dblclick",o),this.addManagedListener(this.eOpenIcon,"dblclick",o),this.addManagedListener(this.getGui(),"dblclick",t),this.updateIconVisibility();var r=this.params.columnGroup.getOriginalColumnGroup();this.addManagedListener(r,b.a.EVENT_EXPANDED_CHANGED,this.updateIconVisibility.bind(this)),this.addManagedListener(r,b.a.EVENT_EXPANDABLE_CHANGED,this.updateIconVisibility.bind(this))},t.prototype.addTouchAndClickListeners=function(e,t){var o=new p.a(e);this.addManagedListener(o,p.a.EVENT_TAP,t),this.addDestroyFunc((function(){return o.destroy()})),this.addManagedListener(e,"click",t)},t.prototype.updateIconVisibility=function(){if(this.params.columnGroup.isExpandable()){var e=this.params.columnGroup.isExpanded();u.f.setDisplayed(this.eOpenIcon,e),u.f.setDisplayed(this.eCloseIcon,!e)}else u.f.setDisplayed(this.eOpenIcon,!1),u.f.setDisplayed(this.eCloseIcon,!1)},t.prototype.addInIcon=function(e,t){var o=u.f.createIconNoSpan(e,this.gridOptionsWrapper,null);this.getRefElement(t).appendChild(o)},t.prototype.addGroupExpandIcon=function(){if(!this.params.columnGroup.isExpandable())return u.f.setDisplayed(this.eOpenIcon,!1),void u.f.setDisplayed(this.eCloseIcon,!1)},t.prototype.setupLabel=function(){var e=this.params.displayName;if(u.f.exists(e)){var t=u.f.escape(e);this.getRefElement("agLabel").innerHTML=t}},t.TEMPLATE='',y([Object(i.a)("columnController")],t.prototype,"columnController",void 0),y([Object(i.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),y([Object(c.d)("agOpened")],t.prototype,"eOpenIcon",void 0),y([Object(c.d)("agClosed")],t.prototype,"eCloseIcon",void 0),t}(g.a),x=o(46),C=o(54),k=o(55),A=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),E=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},O=function(e){function t(){return e.call(this,t.TEMPLATE)||this}return A(t,e),t.prototype.init=function(e){var t=u.f.createIconNoSpan("groupLoading",this.gridOptionsWrapper,null);this.eLoadingIcon.appendChild(t);var o=this.gridOptionsWrapper.getLocaleTextFunc();this.eLoadingText.innerText=o("loadingOoo","Loading")},t.prototype.refresh=function(e){return!1},t.TEMPLATE='
\n \n \n
',E([Object(i.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),E([Object(c.d)("eLoadingIcon")],t.prototype,"eLoadingIcon",void 0),E([Object(c.d)("eLoadingText")],t.prototype,"eLoadingText",void 0),t}(g.a),R=o(56),S=o(81),T=o(82),P=o(83),D=o(57),N=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),F=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},M=function(e){function t(){return e.call(this)||this}return N(t,e),t.prototype.destroy=function(){e.prototype.destroy.call(this)},t.prototype.init=function(e){var o=this.gridOptionsWrapper.getOverlayLoadingTemplate()?this.gridOptionsWrapper.getOverlayLoadingTemplate():t.DEFAULT_LOADING_OVERLAY_TEMPLATE,r=this.gridOptionsWrapper.getLocaleTextFunc(),a=o.replace("[LOADING...]",r("loadingOoo","Loading..."));this.setTemplate(a)},t.DEFAULT_LOADING_OVERLAY_TEMPLATE='[LOADING...]',F([Object(i.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),t}(g.a),I=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),G=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},L=function(e){function t(){return e.call(this)||this}return I(t,e),t.prototype.destroy=function(){e.prototype.destroy.call(this)},t.prototype.init=function(e){var o=this.gridOptionsWrapper.getOverlayNoRowsTemplate()?this.gridOptionsWrapper.getOverlayNoRowsTemplate():t.DEFAULT_NO_ROWS_TEMPLATE,r=this.gridOptionsWrapper.getLocaleTextFunc(),a=o.replace("[NO_ROWS_TO_SHOW]",r("noRowsToShow","No Rows To Show"));this.setTemplate(a)},t.DEFAULT_NO_ROWS_TEMPLATE='[NO_ROWS_TO_SHOW]',G([Object(i.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),t}(g.a),_=o(33),V=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),W=function(e){function t(){return e.call(this,'
')||this}return V(t,e),t.prototype.init=function(e){var t=e.value;this.getGui().innerHTML=t},t}(_.a),j=o(26),H=o(25),B=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),z=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},U=function(e){function t(){return e.call(this,'\n
\n \n
')||this}return B(t,e),t.prototype.destroy=function(){e.prototype.destroy.call(this)},t.prototype.init=function(e){var t=this;this.shouldUseBrowserDatePicker(e)&&(Object(H.isBrowserIE)()?console.warn("ag-grid: browserDatePicker is specified to true, but it is not supported in IE 11, reverting to plain text date picker"):this.eDateInput.getInputElement().type="date"),this.listener=e.onDateChanged,this.addManagedListener(this.eDateInput.getInputElement(),"input",(function(e){e.target===document.activeElement&&t.listener()}))},t.prototype.getDate=function(){return Object(j.parseDateTimeFromString)(this.eDateInput.getValue())},t.prototype.setDate=function(e){this.eDateInput.setValue(Object(j.serialiseDate)(e,!1))},t.prototype.setInputPlaceholder=function(e){this.eDateInput.setInputPlaceholder(e)},t.prototype.shouldUseBrowserDatePicker=function(e){return e.filterParams&&null!=e.filterParams.browserDatePicker?e.filterParams.browserDatePicker:Object(H.isBrowserChrome)()||Object(H.isBrowserFirefox)()},z([Object(c.d)("eDateInput")],t.prototype,"eDateInput",void 0),t}(g.a),Y=o(51),K=o(14),q=o(137),Q=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),Z=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return Q(t,e),t.prototype.getDefaultDebounceMs=function(){return 0},t.prototype.destroy=function(){e.prototype.destroy.call(this)},t.prototype.getTextFromModel=function(e){if(!e)return null;if(e.operator){var t=e,o=this.conditionToString(t.condition1),r=this.conditionToString(t.condition2);return o+" "+t.operator+" "+r}var a=e;return this.conditionToString(a)},t.prototype.isEventFromFloatingFilter=function(e){return e&&e.afterFloatingFilter},t.prototype.getLastType=function(){return this.lastType},t.prototype.setLastTypeFromModel=function(e){if(e){var t;if(e.operator)t=e.condition1;else t=e;this.lastType=t.type}else this.lastType=this.optionsFactory.getDefaultOption()},t.prototype.canWeEditAfterModelFromParentFilter=function(e){if(!e)return this.isTypeEditable(this.lastType);if(e.operator)return!1;var t=e;return this.isTypeEditable(t.type)},t.prototype.init=function(e){this.optionsFactory=new q.a,this.optionsFactory.init(e.filterParams,this.getDefaultFilterOptions()),this.lastType=this.optionsFactory.getDefaultOption();var t=this.isTypeEditable(this.lastType);this.setEditable(t)},t.prototype.doesFilterHaveHiddenInput=function(e){var t=this.optionsFactory.getCustomOption(e);return t&&t.hideFilterInput},t.prototype.isTypeEditable=function(e){return!this.doesFilterHaveHiddenInput(e)&&e&&e!==K.b.IN_RANGE&&e!==K.b.EMPTY},t}(g.a),X=o(39),J=o(8),$=o(42),ee=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),te=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},oe=function(e){function t(){return e.call(this,'\n ')||this}return ee(t,e),t.prototype.getDefaultFilterOptions=function(){return l.a.DEFAULT_FILTER_OPTIONS},t.prototype.conditionToString=function(e){return e.type===K.b.IN_RANGE?e.dateFrom+"-"+e.dateTo:null!=e.dateFrom?""+e.dateFrom:""+e.type},t.prototype.init=function(t){e.prototype.init.call(this,t),this.params=t,this.createDateComponent(),this.eReadOnlyText.setDisabled(!0).setInputAriaLabel("Date Filter Input")},t.prototype.setEditable=function(e){Object(J.setDisplayed)(this.eDateWrapper,e),Object(J.setDisplayed)(this.eReadOnlyText.getGui(),!e)},t.prototype.onParentModelChanged=function(t,o){if(!this.isEventFromFloatingFilter(o)){e.prototype.setLastTypeFromModel.call(this,t);var r=this.canWeEditAfterModelFromParentFilter(t);if(this.setEditable(r),r){if(t){var a=t;this.dateComp.setDate(Object(j.parseDateTimeFromString)(a.dateFrom))}else this.dateComp.setDate(null);this.eReadOnlyText.setValue("")}else this.eReadOnlyText.setValue(this.getTextFromModel(t)),this.dateComp.setDate(null)}},t.prototype.onDateChanged=function(){var e=this,t=this.dateComp.getDate(),o=Object(j.serialiseDate)(t);this.params.parentFilterInstance((function(t){t&&t.onFloatingFilterChanged(e.getLastType(),o)}))},t.prototype.createDateComponent=function(){var e=this,t=X.a.getDebounceMs(this.params.filterParams,this.getDefaultDebounceMs()),o={onDateChanged:Object($.debounce)(this.onDateChanged.bind(this),t),filterParams:this.params.column.getColDef().filterParams};this.dateComp=new Y.a(this.getContext(),this.userComponentFactory,o,this.eDateWrapper),this.addDestroyFunc((function(){return e.dateComp.destroy()}))},te([Object(i.a)("userComponentFactory")],t.prototype,"userComponentFactory",void 0),te([Object(c.d)("eReadOnlyText")],t.prototype,"eReadOnlyText",void 0),te([Object(c.d)("eDateWrapper")],t.prototype,"eDateWrapper",void 0),t}(Z),re=o(58),ae=o(2),ne=o(134),ie=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),le=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},ge=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return ie(t,e),t.prototype.postConstruct=function(){this.setTemplate('\n ')},t.prototype.getDefaultDebounceMs=function(){return 500},t.prototype.onParentModelChanged=function(e,t){if(!this.isEventFromFloatingFilter(t)){this.setLastTypeFromModel(e);var o=this.getTextFromModel(e);this.eFloatingFilterInput.setValue(o);var r=this.canWeEditAfterModelFromParentFilter(e);this.setEditable(r)}},t.prototype.init=function(t){e.prototype.init.call(this,t),this.params=t,this.applyActive=X.a.isUseApplyButton(this.params.filterParams);var o=X.a.getDebounceMs(this.params.filterParams,this.getDefaultDebounceMs()),r=Object($.debounce)(this.syncUpWithParentFilter.bind(this),o),a=this.eFloatingFilterInput.getGui();this.addManagedListener(a,"input",r),this.addManagedListener(a,"keypress",r),this.addManagedListener(a,"keydown",r);var n=t.column.getDefinition();n.filterParams&&n.filterParams.filterOptions&&1===n.filterParams.filterOptions.length&&"inRange"===n.filterParams.filterOptions[0]&&this.eFloatingFilterInput.setDisabled(!0);var i=this.columnController.getDisplayNameForColumn(t.column,"header",!0);this.eFloatingFilterInput.setInputAriaLabel(i+" Filter Input")},t.prototype.syncUpWithParentFilter=function(e){var t=this,o=this.eFloatingFilterInput.getValue(),r=Object(ne.isKeyPressed)(e,ae.a.KEY_ENTER);this.applyActive&&!r||this.params.parentFilterInstance((function(e){e&&e.onFloatingFilterChanged(t.getLastType(),o)}))},t.prototype.setEditable=function(e){this.eFloatingFilterInput.setDisabled(!e)},le([Object(i.a)("columnController")],t.prototype,"columnController",void 0),le([Object(c.d)("eFloatingFilterInput")],t.prototype,"eFloatingFilterInput",void 0),le([i.e],t.prototype,"postConstruct",null),t}(Z),se=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),pe=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return se(t,e),t.prototype.getDefaultFilterOptions=function(){return D.a.DEFAULT_FILTER_OPTIONS},t.prototype.conditionToString=function(e){return e.type==K.b.IN_RANGE?e.filter+"-"+e.filterTo:null!=e.filter?""+e.filter:""+e.type},t}(ge),ce=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),de=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return ce(t,e),t.prototype.conditionToString=function(e){return null!=e.filter?""+e.filter:""+e.type},t.prototype.getDefaultFilterOptions=function(){return re.a.DEFAULT_FILTER_OPTIONS},t}(ge),ue=o(6),he=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),fe=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i};!function(e){e[e.DEFAULT=0]="DEFAULT",e[e.REGISTERED=1]="REGISTERED"}(a||(a={}));var me=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.agGridDefaults={agDateInput:U,agColumnHeader:m,agColumnGroupHeader:w,agTextColumnFloatingFilter:de,agNumberColumnFloatingFilter:pe,agDateColumnFloatingFilter:oe,agAnimateShowChangeCellRenderer:C.a,agAnimateSlideCellRenderer:k.a,agGroupCellRenderer:x.a,agGroupRowRenderer:x.a,agLoadingCellRenderer:O,agCellEditor:n.a,agTextCellEditor:n.a,agSelectCellEditor:R.a,agPopupTextCellEditor:S.a,agPopupSelectCellEditor:T.a,agLargeTextCellEditor:P.a,agTextColumnFilter:re.a,agNumberColumnFilter:D.a,agDateColumnFilter:l.a,agLoadingOverlay:M,agNoRowsOverlay:L,agTooltipComponent:W},t.agDeprecatedNames={set:{newComponentName:"agSetColumnFilter",propertyHolder:"filter"},text:{newComponentName:"agTextColumnFilter",propertyHolder:"filter"},number:{newComponentName:"agNumberColumnFilter",propertyHolder:"filter"},date:{newComponentName:"agDateColumnFilter",propertyHolder:"filter"},group:{newComponentName:"agGroupCellRenderer",propertyHolder:"cellRenderer"},animateShowChange:{newComponentName:"agAnimateShowChangeCellRenderer",propertyHolder:"cellRenderer"},animateSlide:{newComponentName:"agAnimateSlideCellRenderer",propertyHolder:"cellRenderer"},select:{newComponentName:"agSelectCellEditor",propertyHolder:"cellEditor"},largeText:{newComponentName:"agLargeTextCellEditor",propertyHolder:"cellEditor"},popupSelect:{newComponentName:"agPopupSelectCellEditor",propertyHolder:"cellEditor"},popupText:{newComponentName:"agPopupTextCellEditor",propertyHolder:"cellEditor"},richSelect:{newComponentName:"agRichSelectCellEditor",propertyHolder:"cellEditor"},headerComponent:{newComponentName:"agColumnHeader",propertyHolder:"headerComponent"}},t.jsComponents={},t.frameworkComponents={},t}return he(t,e),t.prototype.init=function(){var e=this;null!=this.gridOptions.components&&Object.keys(this.gridOptions.components).forEach((function(t){e.registerComponent(t,e.gridOptions.components[t])})),null!=this.gridOptions.frameworkComponents&&Object.keys(this.gridOptions.frameworkComponents).forEach((function(t){e.registerFwComponent(t,e.gridOptions.frameworkComponents[t])}))},t.prototype.registerDefaultComponent=function(e,t){var o=this.translateIfDeprecated(e);this.agGridDefaults[o]?console.error("Trying to overwrite a default component. You should call registerComponent"):this.agGridDefaults[o]=t},t.prototype.registerComponent=function(e,t){var o=this.translateIfDeprecated(e);this.frameworkComponents[o]?console.error("Trying to register a component that you have already registered for frameworks: "+o):this.jsComponents[o]=t},t.prototype.registerFwComponent=function(e,t){var o=this.translateIfDeprecated(e);this.jsComponents[o]?console.error("Trying to register a component that you have already registered for plain javascript: "+o):this.frameworkComponents[o]=t},t.prototype.retrieve=function(e){var t=this.translateIfDeprecated(e);return this.frameworkComponents[t]?{componentFromFramework:!0,component:this.frameworkComponents[t],source:a.REGISTERED}:this.jsComponents[t]?{componentFromFramework:!1,component:this.jsComponents[t],source:a.REGISTERED}:this.agGridDefaults[t]?this.agGridDefaults[t]?{componentFromFramework:!1,component:this.agGridDefaults[t],source:a.DEFAULT}:null:(Object.keys(this.agGridDefaults).indexOf(t)<0&&console.warn("ag-Grid: Looking for component ["+t+"] but it wasn't found."),null)},t.prototype.translateIfDeprecated=function(e){var t=this.agDeprecatedNames[e];return null!=t?(u.f.doOnce((function(){console.warn("ag-grid. Since v15.0 component names have been renamed to be namespaced. You should rename "+t.propertyHolder+":"+e+" to "+t.propertyHolder+":"+t.newComponentName)}),"DEPRECATE_COMPONENT_"+e),t.newComponentName):e},fe([Object(i.a)("gridOptions")],t.prototype,"gridOptions",void 0),fe([i.e],t.prototype,"init",null),t=fe([Object(i.b)("userComponentRegistry")],t)}(ue.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return r}));var r=function(){function e(e,t,o,r){var a=this;this.alive=!0,this.context=e,t.newDateComponent(o).then((function(t){a.alive?(a.dateComp=t,r.appendChild(t.getGui()),t.afterGuiAttached&&t.afterGuiAttached(),a.tempValue&&t.setDate(a.tempValue)):e.destroyBean(t)}))}return e.prototype.destroy=function(){this.alive=!1,this.dateComp=this.context.destroyBean(this.dateComp)},e.prototype.getDate=function(){return this.dateComp?this.dateComp.getDate():this.tempValue},e.prototype.setDate=function(e){this.dateComp?this.dateComp.setDate(e):this.tempValue=e},e.prototype.setInputPlaceholder=function(e){this.dateComp&&this.dateComp.setInputPlaceholder&&this.dateComp.setInputPlaceholder(e)},e}()},function(e,t,o){"use strict";o.d(t,"a",(function(){return u}));var r,a=o(5),n=o(1),i=o(51),l=o(14),g=o(21),s=o(26),p=o(8),c=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),d=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},u=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return c(t,e),t.prototype.mapRangeFromModel=function(e){return{from:Object(s.parseDateTimeFromString)(e.dateFrom),to:Object(s.parseDateTimeFromString)(e.dateTo)}},t.prototype.setValueFromFloatingFilter=function(e){if(null!=e){var t=Object(s.parseDateTimeFromString)(e);this.dateCondition1FromComp.setDate(t)}else this.dateCondition1FromComp.setDate(null);this.dateCondition1ToComp.setDate(null),this.dateCondition2FromComp.setDate(null),this.dateCondition2ToComp.setDate(null)},t.prototype.setConditionIntoUi=function(e,t){var o=e?[Object(s.parseDateTimeFromString)(e.dateFrom),Object(s.parseDateTimeFromString)(e.dateTo)]:[null,null],r=o[0],a=o[1],n=this.getFromToComponents(t),i=n[0],l=n[1];i.setDate(r),l.setDate(a)},t.prototype.resetUiToDefaults=function(t){var o=this;return e.prototype.resetUiToDefaults.call(this,t).then((function(){o.dateCondition1FromComp.setDate(null),o.dateCondition1ToComp.setDate(null),o.dateCondition2FromComp.setDate(null),o.dateCondition2ToComp.setDate(null)}))},t.prototype.comparator=function(){return this.dateFilterParams.comparator?this.dateFilterParams.comparator:this.defaultComparator.bind(this)},t.prototype.defaultComparator=function(e,t){return null==t||te?1:0},t.prototype.setParams=function(t){e.prototype.setParams.call(this,t),this.dateFilterParams=t,this.createDateComponents()},t.prototype.createDateComponents=function(){var e=this,t={onDateChanged:function(){return e.onUiChanged()},filterParams:this.dateFilterParams};this.dateCondition1FromComp=new i.a(this.getContext(),this.userComponentFactory,t,this.eCondition1PanelFrom),this.dateCondition1ToComp=new i.a(this.getContext(),this.userComponentFactory,t,this.eCondition1PanelTo),this.dateCondition2FromComp=new i.a(this.getContext(),this.userComponentFactory,t,this.eCondition2PanelFrom),this.dateCondition2ToComp=new i.a(this.getContext(),this.userComponentFactory,t,this.eCondition2PanelTo),this.addDestroyFunc((function(){e.dateCondition1FromComp.destroy(),e.dateCondition1ToComp.destroy(),e.dateCondition2FromComp.destroy(),e.dateCondition2ToComp.destroy()}))},t.prototype.getDefaultFilterOptions=function(){return t.DEFAULT_FILTER_OPTIONS},t.prototype.createValueTemplate=function(e){var t=e===l.a.One?"1":"2";return'\n
\n
\n
\n
\n
\n
'},t.prototype.isConditionUiComplete=function(e){var t=e===l.a.One?this.getCondition1Type():this.getCondition2Type();if(t===l.b.EMPTY)return!1;if(this.doesFilterHaveHiddenInput(t))return!0;var o=this.getFromToComponents(e),r=o[0],a=o[1];return null!=r.getDate()&&(t!==l.b.IN_RANGE||null!=a.getDate())},t.prototype.areSimpleModelsEqual=function(e,t){return e.dateFrom===t.dateFrom&&e.dateTo===t.dateTo&&e.type===t.type},t.prototype.getFilterType=function(){return t.FILTER_TYPE},t.prototype.createCondition=function(e){var o=e===l.a.One?this.getCondition1Type():this.getCondition2Type(),r=this.getFromToComponents(e),a=r[0],n=r[1];return{dateFrom:Object(s.serialiseDate)(a.getDate()),dateTo:Object(s.serialiseDate)(n.getDate()),type:o,filterType:t.FILTER_TYPE}},t.prototype.resetPlaceholder=function(){var e=this.gridOptionsWrapper.getLocaleTextFunc()("dateFormatOoo","yyyy-mm-dd");this.dateCondition1FromComp.setInputPlaceholder(e),this.dateCondition1ToComp.setInputPlaceholder(e),this.dateCondition2FromComp.setInputPlaceholder(e),this.dateCondition2ToComp.setInputPlaceholder(e)},t.prototype.updateUiVisibility=function(){e.prototype.updateUiVisibility.call(this),this.resetPlaceholder();var t=this.getCondition1Type();Object(p.setDisplayed)(this.eCondition1PanelFrom,this.showValueFrom(t)),Object(p.setDisplayed)(this.eCondition1PanelTo,this.showValueTo(t));var o=this.getCondition2Type();Object(p.setDisplayed)(this.eCondition2PanelFrom,this.showValueFrom(o)),Object(p.setDisplayed)(this.eCondition2PanelTo,this.showValueTo(o))},t.prototype.getFromToComponents=function(e){return e===l.a.One?[this.dateCondition1FromComp,this.dateCondition1ToComp]:[this.dateCondition2FromComp,this.dateCondition2ToComp]},t.FILTER_TYPE="date",t.DEFAULT_FILTER_OPTIONS=[g.a.EQUALS,g.a.GREATER_THAN,g.a.LESS_THAN,g.a.NOT_EQUAL,g.a.IN_RANGE],d([Object(a.d)("eCondition1PanelFrom")],t.prototype,"eCondition1PanelFrom",void 0),d([Object(a.d)("eCondition1PanelTo")],t.prototype,"eCondition1PanelTo",void 0),d([Object(a.d)("eCondition2PanelFrom")],t.prototype,"eCondition2PanelFrom",void 0),d([Object(a.d)("eCondition2PanelTo")],t.prototype,"eCondition2PanelTo",void 0),d([Object(n.a)("userComponentFactory")],t.prototype,"userComponentFactory",void 0),t}(g.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return u}));var r,a=o(36),n=o(1),i=o(7),l=o(4),g=o(5),s=o(16),p=o(0),c=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),d=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},u=function(e){function t(){return e.call(this,'\n
\n \n
')||this}return c(t,e),t.prototype.onDataChanged=function(){this.onSelectionChanged()},t.prototype.onSelectableChanged=function(){this.showOrHideSelect()},t.prototype.onSelectionChanged=function(){var e=this.rowNode.isSelected();this.eCheckbox.setValue(e,!0)},t.prototype.onCheckedClicked=function(){var e=this.gridOptionsWrapper.isGroupSelectsFiltered();return this.rowNode.setSelectedParams({newValue:!1,groupSelectsFiltered:e})},t.prototype.onUncheckedClicked=function(e){var t=this.gridOptionsWrapper.isGroupSelectsFiltered();return this.rowNode.setSelectedParams({newValue:!0,rangeSelect:e.shiftKey,groupSelectsFiltered:t})},t.prototype.init=function(e){var t=this;this.rowNode=e.rowNode,this.column=e.column,this.onSelectionChanged(),this.addGuiEventListener("click",(function(e){return p.f.stopPropagationForAgGrid(e)})),this.addGuiEventListener("dblclick",(function(e){return p.f.stopPropagationForAgGrid(e)})),this.addManagedListener(this.eCheckbox,a.a.EVENT_CHANGED,(function(e){e.selected?t.onUncheckedClicked(e.event||{}):t.onCheckedClicked()})),this.addManagedListener(this.rowNode,s.a.EVENT_ROW_SELECTED,this.onSelectionChanged.bind(this)),this.addManagedListener(this.rowNode,s.a.EVENT_DATA_CHANGED,this.onDataChanged.bind(this)),this.addManagedListener(this.rowNode,s.a.EVENT_SELECTABLE_CHANGED,this.onSelectableChanged.bind(this)),this.isRowSelectableFunc=this.gridOptionsWrapper.getIsRowSelectableFunc(),(this.isRowSelectableFunc||this.checkboxCallbackExists())&&(this.addManagedListener(this.eventService,l.a.EVENT_DISPLAYED_COLUMNS_CHANGED,this.showOrHideSelect.bind(this)),this.showOrHideSelect()),this.eCheckbox.setInputAriaLabel("Toggle Row Selection")},t.prototype.showOrHideSelect=function(){var e=this.rowNode.selectable;e&&this.checkboxCallbackExists()&&(e=this.column.isCellCheckboxSelection(this.rowNode)),this.setDisplayed(e)},t.prototype.checkboxCallbackExists=function(){var e=this.column?this.column.getColDef():null;return e&&"function"==typeof e.checkboxSelection},d([Object(n.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),d([Object(g.d)("eCheckbox")],t.prototype,"eCheckbox",void 0),t}(i.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return s}));var r,a=o(1),n=o(7),i=o(0),l=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),g=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},s=function(e){function t(){var o=e.call(this,t.TEMPLATE)||this;return o.refreshCount=0,o}return l(t,e),t.prototype.init=function(e){this.eValue=this.queryForHtmlElement(".ag-value-change-value"),this.eDelta=this.queryForHtmlElement(".ag-value-change-delta"),this.refresh(e)},t.prototype.showDelta=function(e,t){var o=Math.abs(t),r=e.formatValue(o),a=i.f.exists(r)?r:o,n=t>=0;this.eDelta.innerHTML=n?"↑"+a:"↓"+a,i.f.addOrRemoveCssClass(this.eDelta,"ag-value-change-delta-up",n),i.f.addOrRemoveCssClass(this.eDelta,"ag-value-change-delta-down",!n)},t.prototype.setTimerToRemoveDelta=function(){var e=this;this.refreshCount++;var t=this.refreshCount;window.setTimeout((function(){t===e.refreshCount&&e.hideDeltaValue()}),2e3)},t.prototype.hideDeltaValue=function(){i.f.removeCssClass(this.eValue,"ag-value-change-value-highlight"),i.f.clearElement(this.eDelta)},t.prototype.refresh=function(e){var t=e.value;if(t!==this.lastValue&&(i.f.exists(e.valueFormatted)?this.eValue.innerHTML=e.valueFormatted:i.f.exists(e.value)?this.eValue.innerHTML=t:i.f.clearElement(this.eValue),!this.filterManager.isSuppressFlashingCellsBecauseFiltering())){if("number"==typeof t&&"number"==typeof this.lastValue){var o=t-this.lastValue;this.showDelta(e,o)}return this.lastValue&&i.f.addCssClass(this.eValue,"ag-value-change-value-highlight"),this.setTimerToRemoveDelta(),this.lastValue=t,!0}},t.TEMPLATE='',g([Object(a.a)("filterManager")],t.prototype,"filterManager",void 0),t}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return s}));var r,a=o(1),n=o(7),i=o(0),l=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),g=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},s=function(e){function t(){var o=e.call(this,t.TEMPLATE)||this;return o.refreshCount=0,o.eCurrent=o.queryForHtmlElement(".ag-value-slide-current"),o}return l(t,e),t.prototype.init=function(e){this.params=e,this.refresh(e)},t.prototype.addSlideAnimation=function(){var e=this;this.refreshCount++;var t=this.refreshCount;this.ePrevious&&this.getGui().removeChild(this.ePrevious),this.ePrevious=i.f.loadTemplate(''),this.ePrevious.innerHTML=this.eCurrent.innerHTML,this.getGui().insertBefore(this.ePrevious,this.eCurrent),window.setTimeout((function(){t===e.refreshCount&&i.f.addCssClass(e.ePrevious,"ag-value-slide-out-end")}),50),window.setTimeout((function(){t===e.refreshCount&&(e.getGui().removeChild(e.ePrevious),e.ePrevious=null)}),3e3)},t.prototype.refresh=function(e){var t=e.value;if(i.f.missing(t)&&(t=""),t!==this.lastValue&&!this.filterManager.isSuppressFlashingCellsBecauseFiltering())return this.addSlideAnimation(),this.lastValue=t,i.f.exists(e.valueFormatted)?this.eCurrent.innerHTML=e.valueFormatted:i.f.exists(e.value)?this.eCurrent.innerHTML=t:i.f.clearElement(this.eCurrent),!0},t.TEMPLATE='',g([Object(a.a)("filterManager")],t.prototype,"filterManager",void 0),t}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return p}));var r,a=o(1),n=o(33),i=o(5),l=o(0),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(){return e.call(this,'
')||this}return g(t,e),t.prototype.init=function(e){var t=this;this.focusAfterAttached=e.cellStartedEdit,l.f.missing(e.values)?console.warn("ag-Grid: no values found for select cellEditor"):(e.values.forEach((function(o){var r={value:o},a=t.valueFormatterService.formatValue(e.column,null,null,o),n=null!=a;r.text=n?a:o,t.eSelect.addOption(r)})),this.eSelect.setValue(e.value,!0),this.gridOptionsWrapper.isFullRowEdit()||this.eSelect.onValueChange((function(){return e.stopEditing()})))},t.prototype.afterGuiAttached=function(){this.focusAfterAttached&&this.eSelect.getFocusableElement().focus()},t.prototype.focusIn=function(){this.eSelect.getFocusableElement().focus()},t.prototype.getValue=function(){return this.eSelect.getValue()},t.prototype.isPopup=function(){return!1},s([Object(a.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),s([Object(a.a)("valueFormatterService")],t.prototype,"valueFormatterService",void 0),s([Object(i.d)("eSelect")],t.prototype,"eSelect",void 0),t}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return c}));var r,a=o(5),n=o(14),i=o(21),l=o(18),g=o(8),s=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),p=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},c=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return s(t,e),t.prototype.mapRangeFromModel=function(e){return{from:e.filter,to:e.filterTo}},t.prototype.getDefaultDebounceMs=function(){return 500},t.prototype.resetUiToDefaults=function(t){var o=this;return e.prototype.resetUiToDefaults.call(this,t).then((function(){[o.eValueFrom1,o.eValueFrom2,o.eValueTo1,o.eValueTo2].forEach((function(e){return e.setValue(null,t)})),o.resetPlaceholder()}))},t.prototype.setConditionIntoUi=function(e,t){var o=t===n.a.One,r=o?this.eValueFrom1:this.eValueFrom2,a=o?this.eValueTo1:this.eValueTo2;r.setValue(e?""+e.filter:null),a.setValue(e?""+e.filterTo:null)},t.prototype.setValueFromFloatingFilter=function(e){this.eValueFrom1.setValue(e),this.eValueFrom2.setValue(null),this.eValueTo1.setValue(null),this.eValueTo2.setValue(null)},t.prototype.comparator=function(){return function(e,t){return e===t?0:e\n \n \n
'},t.prototype.isConditionUiComplete=function(e){var t=e===n.a.One,o=t?this.getCondition1Type():this.getCondition2Type(),r=t?this.eValueFrom1:this.eValueFrom2,a=t?this.eValueTo1:this.eValueTo2,i=this.stringToFloat(r.getValue()),l=this.stringToFloat(a.getValue());return o!==n.b.EMPTY&&(!!this.doesFilterHaveHiddenInput(o)||(o===n.b.IN_RANGE?null!=i&&null!=l:null!=i))},t.prototype.areSimpleModelsEqual=function(e,t){return e.filter===t.filter&&e.filterTo===t.filterTo&&e.type===t.type},t.prototype.getFilterType=function(){return t.FILTER_TYPE},t.prototype.stringToFloat=function(e){if("number"==typeof e)return e;var t=Object(l.makeNull)(e);return t&&""===t.trim()&&(t=null),null!=t?parseFloat(t):null},t.prototype.createCondition=function(e){var o=e===n.a.One,r=o?this.getCondition1Type():this.getCondition2Type(),a=o?this.eValueFrom1:this.eValueFrom2,i=this.stringToFloat(a.getValue()),l=o?this.eValueTo1:this.eValueTo2,g=this.stringToFloat(l.getValue()),s={filterType:t.FILTER_TYPE,type:r};return this.doesFilterHaveHiddenInput(r)||(s.filter=i,s.filterTo=g),s},t.prototype.updateUiVisibility=function(){e.prototype.updateUiVisibility.call(this),this.resetPlaceholder();var t=this.showValueFrom(this.getCondition1Type());Object(g.setDisplayed)(this.eValueFrom1.getGui(),t);var o=this.showValueTo(this.getCondition1Type());Object(g.setDisplayed)(this.eValueTo1.getGui(),o);var r=this.showValueFrom(this.getCondition2Type());Object(g.setDisplayed)(this.eValueFrom2.getGui(),r);var a=this.showValueTo(this.getCondition2Type());Object(g.setDisplayed)(this.eValueTo2.getGui(),a)},t.FILTER_TYPE="number",t.DEFAULT_FILTER_OPTIONS=[i.a.EQUALS,i.a.NOT_EQUAL,i.a.LESS_THAN,i.a.LESS_THAN_OR_EQUAL,i.a.GREATER_THAN,i.a.GREATER_THAN_OR_EQUAL,i.a.IN_RANGE],p([Object(a.d)("eValueFrom1")],t.prototype,"eValueFrom1",void 0),p([Object(a.d)("eValueFrom2")],t.prototype,"eValueFrom2",void 0),p([Object(a.d)("eValueTo1")],t.prototype,"eValueTo1",void 0),p([Object(a.d)("eValueTo2")],t.prototype,"eValueTo2",void 0),t}(i.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return c}));var r,a=o(5),n=o(14),i=o(18),l=o(8),g=o(17),s=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),p=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},c=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return s(t,e),t.prototype.getDefaultDebounceMs=function(){return 500},t.prototype.getValue=function(e){var t=e.getValue();return(t=Object(i.makeNull)(t))&&""===t.trim()&&(t=null),t},t.prototype.addValueChangedListeners=function(){var e=this,t=function(){return e.onUiChanged()};this.eValue1.onValueChange(t),this.eValue2.onValueChange(t)},t.prototype.setParams=function(o){e.prototype.setParams.call(this,o),this.textFilterParams=o,this.comparator=this.textFilterParams.textCustomComparator||t.DEFAULT_COMPARATOR,this.formatter=this.textFilterParams.textFormatter||(1==this.textFilterParams.caseSensitive?t.DEFAULT_FORMATTER:t.DEFAULT_LOWERCASE_FORMATTER),this.addValueChangedListeners()},t.prototype.setConditionIntoUi=function(e,t){(t===n.a.One?this.eValue1:this.eValue2).setValue(e?e.filter:null)},t.prototype.createCondition=function(e){var o=e===n.a.One,r=o?this.getCondition1Type():this.getCondition2Type(),a=o?this.eValue1:this.eValue2,i=this.getValue(a),l={filterType:t.FILTER_TYPE,type:r};return this.doesFilterHaveHiddenInput(r)||(l.filter=i),l},t.prototype.getFilterType=function(){return t.FILTER_TYPE},t.prototype.areSimpleModelsEqual=function(e,t){return e.filter===t.filter&&e.type===t.type},t.prototype.resetUiToDefaults=function(t){var o=this;return e.prototype.resetUiToDefaults.call(this,t).then((function(){o.forEachInput((function(e){return e.setValue(null,t)})),o.resetPlaceholder()}))},t.prototype.resetPlaceholder=function(){var e=this.translate("filterOoo");this.forEachInput((function(t){return t.setInputPlaceholder(e)}))},t.prototype.forEachInput=function(e){Object(g.forEach)([this.eValue1,this.eValue2],e)},t.prototype.setValueFromFloatingFilter=function(e){this.eValue1.setValue(e),this.eValue2.setValue(null)},t.prototype.getDefaultFilterOptions=function(){return t.DEFAULT_FILTER_OPTIONS},t.prototype.createValueTemplate=function(e){var t=e===n.a.One?"1":"2";return'\n '},t.prototype.updateUiVisibility=function(){e.prototype.updateUiVisibility.call(this);var t=this.showValueFrom(this.getCondition1Type());Object(l.setDisplayed)(this.eValue1.getGui(),t);var o=this.showValueFrom(this.getCondition2Type());Object(l.setDisplayed)(this.eValue2.getGui(),o)},t.prototype.afterGuiAttached=function(t){e.prototype.afterGuiAttached.call(this,t),this.resetPlaceholder(),this.eValue1.getInputElement().focus()},t.prototype.isConditionUiComplete=function(e){var t=e===n.a.One,o=t?this.getCondition1Type():this.getCondition2Type();return o!==n.b.EMPTY&&(!!this.doesFilterHaveHiddenInput(o)||null!=this.getValue(t?this.eValue1:this.eValue2))},t.prototype.individualConditionPasses=function(e,t){var o=t.filter,r=t.type,a=this.textFilterParams.valueGetter(e.node),i=this.formatter(a),l=this.optionsFactory.getCustomOption(r);if(l&&(null!=o||l.hideFilterInput))return l.test(o,i);if(null==a)return r===n.b.NOT_EQUAL||r===n.b.NOT_CONTAINS;var g=this.formatter(o);return this.comparator(r,i,g)},t.FILTER_TYPE="text",t.DEFAULT_FILTER_OPTIONS=[n.b.CONTAINS,n.b.NOT_CONTAINS,n.b.EQUALS,n.b.NOT_EQUAL,n.b.STARTS_WITH,n.b.ENDS_WITH],t.DEFAULT_FORMATTER=function(e){return e},t.DEFAULT_LOWERCASE_FORMATTER=function(e){return null==e?null:e.toString().toLowerCase()},t.DEFAULT_COMPARATOR=function(e,o,r){switch(e){case t.CONTAINS:return o.indexOf(r)>=0;case t.NOT_CONTAINS:return-1===o.indexOf(r);case t.EQUALS:return o===r;case t.NOT_EQUAL:return o!=r;case t.STARTS_WITH:return 0===o.indexOf(r);case t.ENDS_WITH:var a=o.lastIndexOf(r);return a>=0&&a===o.length-r.length;default:return console.warn("invalid filter type "+e),!1}},p([Object(a.d)("eValue1")],t.prototype,"eValue1",void 0),p([Object(a.d)("eValue2")],t.prototype,"eValue2",void 0),t}(n.b)},function(e,t,o){"use strict";o.d(t,"a",(function(){return r}));var r=function(){function e(e,t){this.active=!0,this.nodeIdsToColumns={},this.mapToItems={},this.keepingColumns=e,this.pathRoot={rowNode:t,children:null},this.mapToItems[t.id]=this.pathRoot}return e.prototype.setInactive=function(){this.active=!1},e.prototype.isActive=function(){return this.active},e.prototype.depthFirstSearchChangedPath=function(e,t){if(e.children)for(var o=0;o=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(t){var o=e.call(this,t)||this;return o.RESIZE_TEMPLATE='
\n
\n
\n
\n
\n
\n
\n
\n
\n
',o.MAXIMIZE_BTN_TEMPLATE='
',o.resizable={},o.movable=!1,o.isMoving=!1,o.isMaximizable=!1,o.isMaximized=!1,o.maximizeListeners=[],o.resizeListenerDestroy=null,o.isResizing=!1,o.lastPosition={x:0,y:0,width:0,height:0},o}return g(t,e),t.prototype.postConstruct=function(){var t=this,o=this.getGui(),r=this.config,a=r.movable,n=r.resizable,i=r.maximizable;l.f.addCssClass(o,"ag-dialog"),this.moveElement=this.eTitleBar,e.prototype.postConstruct.call(this),this.addManagedListener(o,"focusin",(function(e){o.contains(e.relatedTarget)||t.popupService.bringPopupToFront(o)})),a&&this.setMovable(a),i&&this.setMaximizable(i),this.addResizers(),n&&this.setResizable(n)},t.prototype.renderComponent=function(){var e=this.getGui(),t=this.config,o=t.alwaysOnTop,r=t.modal;this.close=this.popupService.addPopup(r,e,!0,this.destroy.bind(this),void 0,o),e.focus()},t.prototype.addResizers=function(){var e=this.getGui();if(e){var t=(new DOMParser).parseFromString(this.RESIZE_TEMPLATE,"text/html").body;e.appendChild(t.firstChild),this.createMap()}},t.prototype.createMap=function(){var e=this.getGui();this.resizerMap={topLeft:{element:e.querySelector("[ref=eTopLeftResizer]")},top:{element:e.querySelector("[ref=eTopResizer]")},topRight:{element:e.querySelector("[ref=eTopRightResizer]")},right:{element:e.querySelector("[ref=eRightResizer]")},bottomRight:{element:e.querySelector("[ref=eBottomRightResizer]")},bottom:{element:e.querySelector("[ref=eBottomResizer]")},bottomLeft:{element:e.querySelector("[ref=eBottomLeftResizer]")},left:{element:e.querySelector("[ref=eLeftResizer]")}}},t.prototype.getResizerElement=function(e){return this.resizerMap[e].element},t.prototype.onResizeStart=function(e){this.isResizing=!0,this.updateDragStartPosition(e.clientX,e.clientY)},t.prototype.onResize=function(e,t){if(this.isResizing){var o=!!t.match(/left/i),r=!!t.match(/right/i),a=!!t.match(/top/i),n=!!t.match(/bottom/i),i=o||r,l=a||n,g=this.calculateMouseMovement({e:e,isLeft:o,isTop:a}),s=g.movementX,p=g.movementY,c=0,d=0;if(i&&s){var u=o?-1:1,h=this.getWidth(),f=h+s*u,m=!1;o&&(c=h-f,(this.position.x+c<=0||f<=this.minWidth)&&(m=!0,c=0)),m||this.setWidth(f)}if(l&&p){u=a?-1:1;var b=this.getHeight(),v=b+p*u,y=!1;a&&(d=b-v,(this.position.y+d<=0||v<=this.minHeight)&&(y=!0,d=0)),y||this.setHeight(v)}this.updateDragStartPosition(e.clientX,e.clientY),(c||d)&&this.offsetElement(this.position.x+c,this.position.y+d)}},t.prototype.onResizeEnd=function(){this.isResizing=!1;var e={type:"resize",api:this.gridOptionsWrapper.getApi(),columnApi:this.gridOptionsWrapper.getColumnApi()};this.dispatchEvent(e)},t.prototype.onMoveStart=function(e){this.isMoving=!0,this.updateDragStartPosition(e.clientX,e.clientY)},t.prototype.onMove=function(e){if(this.isMoving){var t=this.position,o=t.x,r=t.y,a=this.calculateMouseMovement({e:e,isTop:!0,anywhereWithin:!0,topBuffer:this.getHeight()-this.getBodyHeight()}),n=a.movementX,i=a.movementY;this.offsetElement(o+n,r+i),this.updateDragStartPosition(e.clientX,e.clientY)}},t.prototype.onMoveEnd=function(){this.isMoving=!1},t.prototype.toggleMaximize=function(){if(this.isMaximized){var e=this.lastPosition,t=e.x,o=e.y,r=e.width,a=e.height;this.setWidth(r),this.setHeight(a),this.offsetElement(t,o)}else this.lastPosition.width=this.getWidth(),this.lastPosition.height=this.getHeight(),this.lastPosition.x=this.position.x,this.lastPosition.y=this.position.y,this.offsetElement(0,0),this.setHeight("100%"),this.setWidth("100%");this.isMaximized=!this.isMaximized,this.refreshMaximizeIcon()},t.prototype.refreshMaximizeIcon=function(){l.f.addOrRemoveCssClass(this.maximizeIcon,"ag-hidden",this.isMaximized),l.f.addOrRemoveCssClass(this.minimizeIcon,"ag-hidden",!this.isMaximized)},t.prototype.clearMaximizebleListeners=function(){this.maximizeListeners.length&&(this.maximizeListeners.forEach((function(e){return e()})),this.maximizeListeners.length=0),this.resizeListenerDestroy&&(this.resizeListenerDestroy(),this.resizeListenerDestroy=null)},t.prototype.destroy=function(){this.setResizable(!1),this.setMovable(!1),this.maximizeButtonComp=this.destroyBean(this.maximizeButtonComp),this.clearMaximizebleListeners(),e.prototype.destroy.call(this)},t.prototype.setResizable=function(e){var t=this;"boolean"==typeof e&&(e={topLeft:e,top:e,topRight:e,right:e,bottomRight:e,bottom:e,bottomLeft:e,left:e}),Object.keys(e).forEach((function(o){var r=o,a=!!e[r],n=t.getResizerElement(r),i=t.resizerMap[r].dragSource||{eElement:n,onDragStart:t.onResizeStart.bind(t),onDragging:function(e){return t.onResize(e,r)},onDragStop:t.onResizeEnd.bind(t)};!!t.resizable[r]===a&&(t.isAlive()||a)||(a?(t.dragService.addDragSource(i),n.style.pointerEvents="all"):(t.dragService.removeDragSource(i),n.style.pointerEvents="none"),t.resizerMap[r].dragSource=a?i:void 0)}))},t.prototype.setMovable=function(e){if(e!==this.movable){this.movable=e;var t=this.moveElementDragListener||{eElement:this.moveElement,onDragStart:this.onMoveStart.bind(this),onDragging:this.onMove.bind(this),onDragStop:this.onMoveEnd.bind(this)};e?(this.dragService.addDragSource(t),this.moveElementDragListener=t):(this.dragService.removeDragSource(t),this.moveElementDragListener=void 0)}},t.prototype.setMaximizable=function(e){var t=this;if(!1===e)return this.clearMaximizebleListeners(),void(this.maximizeButtonComp&&(this.destroyBean(this.maximizeButtonComp),this.maximizeButtonComp=this.maximizeIcon=this.minimizeIcon=void 0));var o=this.eTitleBar;if(o&&e!==this.isMaximizable){var r=this.maximizeButtonComp=new i.a(this.MAXIMIZE_BTN_TEMPLATE);this.getContext().createBean(r);var a=r.getGui();a.appendChild(this.maximizeIcon=l.f.createIconNoSpan("maximize",this.gridOptionsWrapper)),l.f.addCssClass(this.maximizeIcon,"ag-panel-title-bar-button-icon"),a.appendChild(this.minimizeIcon=l.f.createIconNoSpan("minimize",this.gridOptionsWrapper)),l.f.addCssClass(this.minimizeIcon,"ag-panel-title-bar-button-icon"),l.f.addCssClass(this.minimizeIcon,"ag-hidden"),r.addManagedListener(a,"click",this.toggleMaximize.bind(this)),this.addTitleBarButton(r,0),this.maximizeListeners.push(this.addManagedListener(o,"dblclick",this.toggleMaximize.bind(this))),this.resizeListenerDestroy=this.addManagedListener(this,"resize",(function(){t.isMaximized=!1,t.refreshMaximizeIcon()}))}},s([Object(a.a)("dragService")],t.prototype,"dragService",void 0),t}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return p}));var r,a=o(5),n=o(1),i=o(7),l=o(0),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(o){var r=e.call(this,t.getTemplate(o))||this;return r.closable=!0,r.positioned=!1,r.dragStartPosition={x:0,y:0},r.position={x:0,y:0},r.size={width:void 0,height:void 0},r.config=o,r}return g(t,e),t.getTemplate=function(e){var t=e&&e.cssIdentifier||"default";return'
\n
\n \n
\n
\n
\n
'},t.prototype.postConstruct=function(){var e=this,t=this.config,o=t.component,r=t.closable,a=t.hideTitleBar,n=t.title,i=t.minWidth,g=t.width,s=t.minHeight,p=t.height,c=t.centered,d=t.x,u=t.y,h=this.getGui();o&&this.setBodyComponent(o),a?l.f.addCssClass(this.eTitleBar,"ag-hidden"):(n&&this.setTitle(n),this.setClosable(null!=r?r:this.closable)),this.addManagedListener(this.eTitleBar,"mousedown",(function(t){if(h.contains(t.relatedTarget)||h.contains(document.activeElement)||e.eTitleBarButtons.contains(t.target))t.preventDefault();else{var o=e.eContentWrapper.querySelector("button, [href], input, select, textarea, [tabindex]");o&&o.focus()}})),this.positioned||(this.minHeight=null!=s?s:250,this.minWidth=null!=i?i:250,this.popupParent=this.popupService.getPopupParent(),g&&this.setWidth(g),p&&this.setHeight(p),this.renderComponent&&this.renderComponent(),g&&p||this.refreshSize(),c?this.center():(d||u)&&this.offsetElement(d,u),this.positioned=!0,this.eContentWrapper.style.height="0")},t.prototype.renderComponent=function(){var e=this,t=this.getGui();t.focus(),this.close=function(){t.parentElement.removeChild(t),e.destroy()}},t.prototype.updateDragStartPosition=function(e,t){this.dragStartPosition={x:e,y:t}},t.prototype.calculateMouseMovement=function(e){var t=this.popupParent.getBoundingClientRect(),o=e.e,r=e.isLeft,a=e.isTop,n=e.anywhereWithin,i=e.topBuffer,l=o.clientX-this.dragStartPosition.x,g=o.clientY-this.dragStartPosition.y,s=this.getWidth(),p=this.getHeight(),c=t.left>=o.clientX&&this.position.x<=0||t.right<=o.clientX&&t.right<=this.position.x+t.left+s;return c||(c=r?l<0&&o.clientX>this.position.x+t.left||l>0&&o.clientXthis.position.x+t.left+s||l>0&&o.clientXthis.position.x+t.left+s||l>0&&o.clientX=o.clientY&&this.position.y<=0||t.bottom<=o.clientY&&t.bottom<=this.position.y+t.top+p||a&&(g<0&&o.clientY>this.position.y+t.top+(i||0)||g>0&&o.clientYthis.position.y+t.top+p||g>0&&o.clientYr.clientHeight&&(e=r.clientHeight-this.position.y)}this.size.height!==e&&(this.size.height=e,o?(t.style.maxHeight="unset",t.style.minHeight="unset"):l.f.setFixedHeight(t,e))},t.prototype.getWidth=function(){return this.size.width},t.prototype.setWidth=function(e){var t=this.getGui(),o=!1;if("string"==typeof e&&-1!==e.indexOf("%"))l.f.setFixedWidth(t,e),e=l.f.getAbsoluteWidth(t),o=!0;else{e=Math.max(this.minWidth,e);var r=t.offsetParent;r&&r.clientWidth&&e+this.position.x>r.clientWidth&&(e=r.clientWidth-this.position.x)}this.size.width!==e&&(this.size.width=e,o?(t.style.maxWidth="unset",t.style.minWidth="unset"):l.f.setFixedWidth(t,e))},t.prototype.center=function(){var e=this.getGui(),t=e.offsetParent.clientWidth/2-this.getWidth()/2,o=e.offsetParent.clientHeight/2-this.getHeight()/2;this.offsetElement(t,o)},t.prototype.setClosable=function(e){if(e!==this.closable&&(this.closable=e),e){var o=this.closeButtonComp=new i.a(t.CLOSE_BTN_TEMPLATE);this.getContext().createBean(o),(r=o.getGui()).appendChild(l.f.addCssClass(l.f.createIconNoSpan("close",this.gridOptionsWrapper),"ag-panel-title-bar-button-icon")),this.addTitleBarButton(o),o.addManagedListener(r,"click",this.onBtClose.bind(this))}else if(this.closeButtonComp){var r;(r=this.closeButtonComp.getGui()).parentElement.removeChild(r),this.closeButtonComp=this.destroyBean(this.closeButtonComp)}},t.prototype.setBodyComponent=function(e){e.setParentComponent(this),this.eContentWrapper.appendChild(e.getGui())},t.prototype.addTitleBarButton=function(e,t){var o=this.eTitleBarButtons,r=o.children,a=r.length;null==t&&(t=a),t=Math.max(0,Math.min(t,a));var n=e.getGui();l.f.addCssClass(n,"ag-panel-title-bar-button"),0===t?o.insertAdjacentElement("afterbegin",n):t===a?o.insertAdjacentElement("beforeend",n):r[t-1].insertAdjacentElement("afterend",n),e.setParentComponent(this)},t.prototype.getBodyHeight=function(){return l.f.getInnerHeight(this.eContentWrapper)},t.prototype.getBodyWidth=function(){return l.f.getInnerWidth(this.eContentWrapper)},t.prototype.setTitle=function(e){this.eTitle.innerText=e},t.prototype.onBtClose=function(){this.close()},t.prototype.destroy=function(){this.closeButtonComp&&(this.closeButtonComp=this.destroyBean(this.closeButtonComp));var t=this.getGui();t&&t.offsetParent&&this.close(),e.prototype.destroy.call(this)},t.CLOSE_BTN_TEMPLATE='
',s([Object(n.a)("popupService")],t.prototype,"popupService",void 0),s([Object(n.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),s([Object(a.d)("eContentWrapper")],t.prototype,"eContentWrapper",void 0),s([Object(a.d)("eTitleBar")],t.prototype,"eTitleBar",void 0),s([Object(a.d)("eTitleBarButtons")],t.prototype,"eTitleBarButtons",void 0),s([Object(a.d)("eTitle")],t.prototype,"eTitle",void 0),s([n.e],t.prototype,"postConstruct",null),t}(i.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return l}));var r,a=o(43),n=o(0),i=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),l=function(e){function t(t){var o=e.call(this)||this;return o.className="ag-text-field",o.displayTag="input",o.inputType="text",o.setTemplate(o.TEMPLATE.replace(/%displayField%/g,o.displayTag)),t&&(o.config=t),o}return i(t,e),t.prototype.setValue=function(t,o){var r=e.prototype.setValue.call(this,t,o);return this.eInput.value!==t&&(this.eInput.value=n.f.exists(t)?t:""),r},t}(a.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return At}));var r,a,n=o(15),i=o(84),l=o(85),g=o(77),s=o(86),p=o(88),c=o(92),d=o(93),u=o(23),h=o(129),f=o(94),m=o(132),b=o(80),v=o(95),y=o(96),w=o(97),x=o(48),C=o(79),k=o(98),A=o(99),E=o(1),O=o(100),R=o(101),S=o(13),T=o(102),P=o(103),D=o(104),N=o(105),F=o(106),M=o(4),I=o(107),G=o(108),L=o(36),_=o(61),V=o(109),W=o(110),j=o(111),H=o(6),B=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),z=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},U=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return B(t,e),t.prototype.setMouseOver=function(e){this.selectedColumns=e;var t={type:M.a.EVENT_COLUMN_HOVER_CHANGED,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(t)},t.prototype.clearMouseOver=function(){this.selectedColumns=null;var e={type:M.a.EVENT_COLUMN_HOVER_CHANGED,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(e)},t.prototype.isHovered=function(e){return this.selectedColumns&&this.selectedColumns.indexOf(e)>=0},z([Object(E.a)("columnApi")],t.prototype,"columnApi",void 0),z([Object(E.a)("gridApi")],t.prototype,"gridApi",void 0),t=z([Object(E.b)("columnHoverService")],t)}(H.a),Y=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),K=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},q=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.executeNextFuncs=[],t.executeLaterFuncs=[],t.active=!1,t.animationThreadCount=0,t}return Y(t,e),t.prototype.registerGridComp=function(e){this.gridPanel=e},t.prototype.isActive=function(){return this.active},t.prototype.start=function(){this.active||this.gridOptionsWrapper.isSuppressColumnMoveAnimation()||this.gridOptionsWrapper.isEnableRtl()||(this.ensureAnimationCssClassPresent(),this.active=!0)},t.prototype.finish=function(){this.active&&(this.flush(),this.active=!1)},t.prototype.executeNextVMTurn=function(e){this.active?this.executeNextFuncs.push(e):e()},t.prototype.executeLaterVMTurn=function(e){this.active?this.executeLaterFuncs.push(e):e()},t.prototype.ensureAnimationCssClassPresent=function(){var e=this;this.animationThreadCount++;var t=this.animationThreadCount;this.gridPanel.setColumnMovingCss(!0),this.executeLaterFuncs.push((function(){e.animationThreadCount===t&&e.gridPanel.setColumnMovingCss(!1)}))},t.prototype.flush=function(){var e=this.executeNextFuncs;this.executeNextFuncs=[];var t=this.executeLaterFuncs;this.executeLaterFuncs=[],0===e.length&&0===t.length||(window.setTimeout((function(){return e.forEach((function(e){return e()}))}),0),window.setTimeout((function(){return t.forEach((function(e){return e()}))}),300))},K([Object(E.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),t=K([Object(E.b)("columnAnimationService")],t)}(H.a),Q=o(12),Z=o(2),X=o(0),J=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),$=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},ee=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}var o;return J(t,e),o=t,t.prototype.createAutoGroupColumns=function(e){var t=this,o=[],r=this.gridOptionsWrapper.isTreeData(),a=this.gridOptionsWrapper.isGroupMultiAutoColumn();return r&&a&&(console.warn("ag-Grid: you cannot mix groupMultiAutoColumn with treeData, only one column can be used to display groups when doing tree data"),a=!1),a?e.forEach((function(e,r){o.push(t.createOneAutoGroupColumn(e,r))})):o.push(this.createOneAutoGroupColumn()),o},t.prototype.createOneAutoGroupColumn=function(e,t){var r,a=this.generateDefaultColDef(e);r=e?Z.a.GROUP_AUTO_COLUMN_ID+"-"+e.getId():o.GROUP_AUTO_COLUMN_BUNDLE_ID;var n=this.gridOptionsWrapper.getAutoGroupColumnDef();(X.f.mergeDeep(a,n),(a=this.columnFactory.mergeColDefs(a)).colId=r,this.gridOptionsWrapper.isTreeData())||X.f.missing(a.field)&&X.f.missing(a.valueGetter)&&X.f.missing(a.filterValueGetter)&&(a.filter=!1);t&&t>0&&(a.headerCheckboxSelection=!1);var i=new Q.a(a,null,r,!0);return this.context.createBean(i),i},t.prototype.generateDefaultColDef=function(e){var t=this.gridOptionsWrapper.getAutoGroupColumnDef(),o={headerName:this.gridOptionsWrapper.getLocaleTextFunc()("group","Group")};if(t&&(t.cellRenderer||t.cellRendererFramework)||(o.cellRenderer="agGroupCellRenderer"),e){var r=e.getColDef();X.f.assign(o,{headerName:this.columnController.getDisplayNameForColumn(e,"header"),headerValueGetter:r.headerValueGetter}),r.cellRenderer&&X.f.assign(o,{cellRendererParams:{innerRenderer:r.cellRenderer,innerRendererParams:r.cellRendererParams}}),o.showRowGroup=e.getColId()}else o.showRowGroup=!0;return o},t.GROUP_AUTO_COLUMN_BUNDLE_ID=Z.a.GROUP_AUTO_COLUMN_ID,$([Object(E.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),$([Object(E.a)("columnController")],t.prototype,"columnController",void 0),$([Object(E.a)("columnFactory")],t.prototype,"columnFactory",void 0),t=o=$([Object(E.b)("autoGroupColService")],t)}(H.a),te=o(112),oe=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),re=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},ae=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return oe(t,e),t.prototype.registerGridComp=function(e){this.gridPanel=e,this.addManagedListener(this.eventService,M.a.EVENT_BODY_HEIGHT_CHANGED,this.onBodyHeightChanged.bind(this)),this.addManagedListener(this.eventService,M.a.EVENT_SCROLL_VISIBILITY_CHANGED,this.onScrollVisibilityChanged.bind(this)),this.checkPageSize()},t.prototype.notActive=function(){return!this.gridOptionsWrapper.isPaginationAutoPageSize()},t.prototype.onScrollVisibilityChanged=function(){this.checkPageSize()},t.prototype.onBodyHeightChanged=function(){this.checkPageSize()},t.prototype.checkPageSize=function(){if(!this.notActive()){var e=this.gridOptionsWrapper.getRowHeightAsNumber(),t=this.gridPanel.getBodyHeight();if(t>0){var o=Math.floor(t/e);this.gridOptionsWrapper.setProperty("paginationPageSize",o)}}},re([Object(E.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),t=re([Object(E.b)("paginationAutoPageSizeService")],t)}(H.a),ne=o(113),ie=o(59),le=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),ge=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},se=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return le(t,e),t.prototype.init=function(){this.rowModel.getType()===Z.a.ROW_MODEL_TYPE_CLIENT_SIDE&&(this.clientSideRowModel=this.rowModel),this.addManagedListener(this.eventService,M.a.EVENT_CELL_VALUE_CHANGED,this.onCellValueChanged.bind(this))},t.prototype.onCellValueChanged=function(e){e.source!==Z.a.SOURCE_PASTE&&this.doChangeDetection(e.node,e.column)},t.prototype.doChangeDetection=function(e,t){if(!this.gridOptionsWrapper.isSuppressChangeDetection()){if(this.clientSideRowModel&&!e.isRowPinned()){var o=this.gridOptionsWrapper.isAggregateOnlyChangedColumns(),r=new ie.a(o,this.clientSideRowModel.getRootNode());r.addParentNode(e.parent,[t]),this.clientSideRowModel.doAggregate(r)}this.rowRenderer.refreshCells()}},ge([Object(E.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),ge([Object(E.a)("rowModel")],t.prototype,"rowModel",void 0),ge([Object(E.a)("rowRenderer")],t.prototype,"rowRenderer",void 0),ge([E.e],t.prototype,"init",null),t=ge([Object(E.b)("changeDetectionService")],t)}(H.a),pe=o(114),ce=o(44),de=o(50),ue=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),he=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},fe=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return ue(t,e),t.prototype.adaptFunction=function(e,t,o,r){if(null==t)return{component:null,componentFromFramework:o,source:r,paramsFromSelector:null};var a=this.componentMetadataProvider.retrieve(e);return a&&a.functionAdapter?{componentFromFramework:o,component:a.functionAdapter(t),source:r,paramsFromSelector:null}:null},t.prototype.adaptCellRendererFunction=function(e){return function(){function t(){}return t.prototype.refresh=function(e){return!1},t.prototype.getGui=function(){var t=e(this.params),o=typeof t;return"string"===o||"number"===o||"boolean"===o?X.f.loadTemplate(""+t+""):t},t.prototype.init=function(e){this.params=e},t}()},t.prototype.doesImplementIComponent=function(e){return!!e&&(e.prototype&&"getGui"in e.prototype)},he([Object(E.a)("componentMetadataProvider")],t.prototype,"componentMetadataProvider",void 0),t=he([Object(E.b)("agComponentUtils")],t)}(H.a),me=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),be=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},ve=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return me(t,e),t.prototype.postConstruct=function(){this.componentMetaData={dateComponent:{mandatoryMethodList:["getDate","setDate"],optionalMethodList:["afterGuiAttached","setInputPlaceholder"]},detailCellRenderer:{mandatoryMethodList:[],optionalMethodList:["refresh"]},headerComponent:{mandatoryMethodList:[],optionalMethodList:[]},headerGroupComponent:{mandatoryMethodList:[],optionalMethodList:[]},loadingCellRenderer:{mandatoryMethodList:[],optionalMethodList:[]},loadingOverlayComponent:{mandatoryMethodList:[],optionalMethodList:[]},noRowsOverlayComponent:{mandatoryMethodList:[],optionalMethodList:[]},floatingFilterComponent:{mandatoryMethodList:["onParentModelChanged"],optionalMethodList:["afterGuiAttached"]},floatingFilterWrapperComponent:{mandatoryMethodList:[],optionalMethodList:[]},cellRenderer:{mandatoryMethodList:[],optionalMethodList:["refresh","afterGuiAttached"],functionAdapter:this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)},cellEditor:{mandatoryMethodList:["getValue"],optionalMethodList:["isPopup","isCancelBeforeStart","isCancelAfterEnd","getPopupPosition","focusIn","focusOut","afterGuiAttached"]},innerRenderer:{mandatoryMethodList:[],optionalMethodList:["afterGuiAttached"],functionAdapter:this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)},fullWidthCellRenderer:{mandatoryMethodList:[],optionalMethodList:["refresh","afterGuiAttached"],functionAdapter:this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)},pinnedRowCellRenderer:{mandatoryMethodList:[],optionalMethodList:["refresh","afterGuiAttached"],functionAdapter:this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)},groupRowInnerRenderer:{mandatoryMethodList:[],optionalMethodList:["afterGuiAttached"],functionAdapter:this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)},groupRowRenderer:{mandatoryMethodList:[],optionalMethodList:["afterGuiAttached"],functionAdapter:this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)},filter:{mandatoryMethodList:["isFilterActive","doesFilterPass","getModel","setModel"],optionalMethodList:["afterGuiAttached","onNewRowsLoaded","getModelAsString","onFloatingFilterChanged"]},filterComponent:{mandatoryMethodList:["isFilterActive","doesFilterPass","getModel","setModel"],optionalMethodList:["afterGuiAttached","onNewRowsLoaded","getModelAsString","onFloatingFilterChanged"]},statusPanel:{mandatoryMethodList:[],optionalMethodList:["afterGuiAttached"]},toolPanel:{mandatoryMethodList:[],optionalMethodList:["refresh","afterGuiAttached"]},tooltipComponent:{mandatoryMethodList:[],optionalMethodList:[]}}},t.prototype.retrieve=function(e){return this.componentMetaData[e]},be([Object(E.a)("agComponentUtils")],t.prototype,"agComponentUtils",void 0),be([E.e],t.prototype,"postConstruct",null),t=be([Object(E.b)("componentMetadataProvider")],t)}(H.a),ye=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},we=function(){function e(){}return e.prototype.registerGridComp=function(e){this.gridPanel=e},e.prototype.postConstruct=function(){this.doingMasterDetail=this.gridOptionsWrapper.isMasterDetail()},ye([Object(E.a)("paginationProxy")],e.prototype,"paginationProxy",void 0),ye([Object(E.a)("context")],e.prototype,"context",void 0),ye([Object(E.a)("columnApi")],e.prototype,"columnApi",void 0),ye([Object(E.a)("gridApi")],e.prototype,"gridApi",void 0),ye([Object(E.a)("gridOptionsWrapper")],e.prototype,"gridOptionsWrapper",void 0),ye([Object(E.a)("expressionService")],e.prototype,"expressionService",void 0),ye([Object(E.a)("rowRenderer")],e.prototype,"rowRenderer",void 0),ye([Object(E.a)("$compile")],e.prototype,"$compile",void 0),ye([Object(E.a)("templateService")],e.prototype,"templateService",void 0),ye([Object(E.a)("valueService")],e.prototype,"valueService",void 0),ye([Object(E.a)("eventService")],e.prototype,"eventService",void 0),ye([Object(E.a)("columnController")],e.prototype,"columnController",void 0),ye([Object(E.a)("headerNavigationService")],e.prototype,"headerNavigationService",void 0),ye([Object(E.a)("columnAnimationService")],e.prototype,"columnAnimationService",void 0),ye([Object(E.d)("rangeController")],e.prototype,"rangeController",void 0),ye([Object(E.a)("focusController")],e.prototype,"focusController",void 0),ye([Object(E.d)("contextMenuFactory")],e.prototype,"contextMenuFactory",void 0),ye([Object(E.a)("cellRendererFactory")],e.prototype,"cellRendererFactory",void 0),ye([Object(E.a)("popupService")],e.prototype,"popupService",void 0),ye([Object(E.a)("valueFormatterService")],e.prototype,"valueFormatterService",void 0),ye([Object(E.a)("stylingService")],e.prototype,"stylingService",void 0),ye([Object(E.a)("columnHoverService")],e.prototype,"columnHoverService",void 0),ye([Object(E.a)("userComponentFactory")],e.prototype,"userComponentFactory",void 0),ye([Object(E.a)("animationFrameService")],e.prototype,"taskQueue",void 0),ye([Object(E.a)("dragAndDropService")],e.prototype,"dragAndDropService",void 0),ye([Object(E.a)("sortController")],e.prototype,"sortController",void 0),ye([Object(E.a)("filterManager")],e.prototype,"filterManager",void 0),ye([Object(E.a)("maxDivHeightScaler")],e.prototype,"maxDivHeightScaler",void 0),ye([Object(E.a)("frameworkOverrides")],e.prototype,"frameworkOverrides",void 0),ye([Object(E.a)("detailRowCompCache")],e.prototype,"detailRowCompCache",void 0),ye([Object(E.a)("cellPositionUtils")],e.prototype,"cellPositionUtils",void 0),ye([Object(E.a)("rowPositionUtils")],e.prototype,"rowPositionUtils",void 0),ye([Object(E.a)("selectionController")],e.prototype,"selectionController",void 0),ye([Object(E.d)("selectionHandleFactory")],e.prototype,"selectionHandleFactory",void 0),ye([E.e],e.prototype,"postConstruct",null),e=ye([Object(E.b)("beans")],e)}(),xe=o(115),Ce=o(9),ke=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),Ae=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},Ee=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.createTasksP1={list:[],sorted:!1},t.createTasksP2={list:[],sorted:!1},t.destroyTasks=[],t.ticking=!1,t.scrollGoingDown=!0,t.lastScrollTop=0,t.taskCount=0,t.cancelledTasks=new Set,t}return ke(t,e),t.prototype.setScrollTop=function(e){this.scrollGoingDown=e>this.lastScrollTop,this.lastScrollTop=e},t.prototype.init=function(){this.useAnimationFrame=!this.gridOptionsWrapper.isSuppressAnimationFrame()},t.prototype.verifyAnimationFrameOn=function(e){!1===this.useAnimationFrame&&console.warn("ag-Grid: AnimationFrameService."+e+" called but animation frames are off")},t.prototype.createTask=function(e,t,o){this.verifyAnimationFrameOn(o);var r={task:e,index:t,createOrder:++this.taskCount};this.addTaskToList(this[o],r),this.schedule()},t.prototype.cancelTask=function(e){this.cancelledTasks.add(e)},t.prototype.addTaskToList=function(e,t){e.list.push(t),e.sorted=!1},t.prototype.sortTaskList=function(e){if(!e.sorted){var t=this.scrollGoingDown?1:-1;e.list.sort((function(e,o){return e.index!==o.index?t*(o.index-e.index):o.createOrder-e.createOrder})),e.sorted=!0}},t.prototype.addDestroyTask=function(e){this.verifyAnimationFrameOn("createTasksP3"),this.destroyTasks.push(e),this.schedule()},t.prototype.executeFrame=function(e){this.verifyAnimationFrameOn("executeFrame");for(var t=this.createTasksP1,o=t.list,r=this.createTasksP2,a=r.list,n=this.destroyTasks,i=(new Date).getTime(),l=(new Date).getTime()-i,g=e<=0;g||l=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},Se=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.timeLastPageEventProcessed=0,t}return Oe(t,e),t.prototype.init=function(){this.scrollWidth=this.gridOptionsWrapper.getScrollbarWidth()},t.prototype.registerGridComp=function(e){this.gridPanel=e},t.prototype.handlePageScrollingKey=function(e){var t=e.which||e.keyCode,o=e.altKey,r=e.ctrlKey,a=this.mouseEventService.getCellPositionForEvent(e);if(!a)return!1;var n=!1;switch(t){case Z.a.KEY_PAGE_HOME:case Z.a.KEY_PAGE_END:r||o||(this.onHomeOrEndKey(t),n=!0);break;case Z.a.KEY_LEFT:case Z.a.KEY_RIGHT:r&&!o&&(this.onCtrlLeftOrRight(t,a),n=!0);break;case Z.a.KEY_UP:case Z.a.KEY_DOWN:r&&!o&&(this.onCtrlUpOrDown(t,a),n=!0);break;case Z.a.KEY_PAGE_DOWN:r||o||(this.onPageDown(a),n=!0);break;case Z.a.KEY_PAGE_UP:r||o||(this.onPageUp(a),n=!0)}return n&&e.preventDefault(),n},t.prototype.isTimeSinceLastPageEventToRecent=function(){return(new Date).getTime()-this.timeLastPageEventProcessed<100},t.prototype.setTimeLastPageEventProcessed=function(){this.timeLastPageEventProcessed=(new Date).getTime()},t.prototype.onPageDown=function(e){if(!this.isTimeSinceLastPageEventToRecent()){var t=this.gridPanel.getVScrollPosition(),o=t.bottom-t.top;this.gridPanel.isHorizontalScrollShowing()&&(o-=this.scrollWidth);var r=this.paginationProxy.getPixelOffset(),a=t.top+o,n=this.paginationProxy.getRowIndexAtPixel(a+r),i=this.paginationProxy.getRow(e.rowIndex).rowTop+o-r,l=this.paginationProxy.getRowIndexAtPixel(i+r),g=this.paginationProxy.getPageLastRow();l>g&&(l=g),n>g&&(n=g),this.navigateTo(n,"top",null,l,e.column),this.setTimeLastPageEventProcessed()}},t.prototype.onPageUp=function(e){if(!this.isTimeSinceLastPageEventToRecent()){var t=this.gridPanel.getVScrollPosition(),o=t.bottom-t.top;this.gridPanel.isHorizontalScrollShowing()&&(o-=this.scrollWidth);var r=this.paginationProxy.getPixelOffset(),a=t.top,n=this.paginationProxy.getRowIndexAtPixel(a+r),i=this.paginationProxy.getRow(e.rowIndex),l=i.rowTop+i.rowHeight-o-r,g=this.paginationProxy.getRowIndexAtPixel(l+r),s=this.paginationProxy.getPageFirstRow();g=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},De=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.scrollY=0,t.uiBodyHeight=0,t}return Te(t,e),t.prototype.postConstruct=function(){this.addManagedListener(this.eventService,Ce.a.EVENT_BODY_HEIGHT_CHANGED,this.updateOffset.bind(this)),this.scrollBarWidth=this.gridOptionsWrapper.getScrollbarWidth(),this.maxDivHeight=X.f.getMaxDivHeight()},t.prototype.registerGridComp=function(e){this.gridPanel=e},t.prototype.isScaling=function(){return this.scaling},t.prototype.getOffset=function(){return this.offset},t.prototype.updateOffset=function(){if(this.scaling){var e=this.gridPanel.getVScrollPosition().top,t=this.getUiBodyHeight();(e!==this.scrollY||t!==this.uiBodyHeight)&&(this.scrollY=e,this.uiBodyHeight=t,this.calculateOffset())}},t.prototype.calculateOffset=function(){this.uiContainerHeight=this.maxDivHeight,this.pixelsToShave=this.modelHeight-this.uiContainerHeight,this.maxScrollY=this.uiContainerHeight-this.uiBodyHeight;var e=this.scrollY/this.maxScrollY;this.setOffset(e*this.pixelsToShave)},t.prototype.clearOffset=function(){this.uiContainerHeight=this.modelHeight,this.pixelsToShave=0,this.setOffset(0)},t.prototype.setOffset=function(e){var t="number"==typeof e?Math.floor(e):null;this.offset!==t&&(this.offset=t,this.eventService.dispatchEvent({type:Ce.a.EVENT_HEIGHT_SCALE_CHANGED}))},t.prototype.setModelHeight=function(e){this.modelHeight=e,this.scaling=this.maxDivHeight>0&&e>this.maxDivHeight,this.scaling?this.calculateOffset():this.clearOffset()},t.prototype.getUiContainerHeight=function(){return this.uiContainerHeight},t.prototype.getRealPixelPosition=function(e){return e-this.offset},t.prototype.getUiBodyHeight=function(){var e=this.gridPanel.getVScrollPosition();return e.bottom-e.top},t.prototype.getScrollPositionForPixel=function(e){if(this.pixelsToShave<=0)return e;var t=e/(this.modelHeight-this.getUiBodyHeight());return this.maxScrollY*t},Pe([Object(E.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),Pe([E.e],t.prototype,"postConstruct",null),t=Pe([Object(E.b)("maxDivHeightScaler")],t)}(H.a),Ne=o(116),Fe=o(35),Me=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),Ie=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},Ge=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return Me(t,e),t.prototype.registerGridComp=function(e){this.gridPanel=e},t.prototype.getPreferredHeightForRow=function(e){var t=this;this.eDummyContainer||(this.eDummyContainer=document.createElement("div"),X.f.addCssClass(this.eDummyContainer,"ag-row ag-row-no-focus"));var o=this.gridPanel.getCenterContainer();o.appendChild(this.eDummyContainer);var r=[];this.columnController.getAllAutoRowHeightCols().filter((function(e){return e.isVisible()})).forEach((function(o){var a=new Fe.a(t.$scope,t.beans,o,e,null,!0,!1);a.setParentRow(t.eDummyContainer),r.push(a)}));var a=r.map((function(e){return e.getCreateTemplate()})).join(" ");this.eDummyContainer.innerHTML=a,r.forEach((function(e){return e.afterAttached()}));for(var n=0,i=0;in&&(n=l.offsetHeight)}return o.removeChild(this.eDummyContainer),r.forEach((function(e){e.detach(),e.destroy()})),X.f.clearElement(this.eDummyContainer),n},Ie([Object(E.a)("beans")],t.prototype,"beans",void 0),Ie([Object(E.a)("$scope")],t.prototype,"$scope",void 0),Ie([Object(E.a)("columnController")],t.prototype,"columnController",void 0),t=Ie([Object(E.b)("autoHeightCalculator")],t)}(H.a),Le=o(7),_e=o(5),Ve=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),We=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},je=function(e){function t(){var t=e.call(this)||this;return t.previousAndFirstButtonsDisabled=!1,t.nextButtonDisabled=!1,t.lastButtonDisabled=!1,t}return Ve(t,e),t.prototype.postConstruct=function(){var e=this.gridOptionsWrapper.isEnableRtl();this.setTemplate(this.getTemplate()),this.btFirst.insertAdjacentElement("afterbegin",X.f.createIconNoSpan(e?"last":"first",this.gridOptionsWrapper)),this.btPrevious.insertAdjacentElement("afterbegin",X.f.createIconNoSpan(e?"next":"previous",this.gridOptionsWrapper)),this.btNext.insertAdjacentElement("afterbegin",X.f.createIconNoSpan(e?"previous":"next",this.gridOptionsWrapper)),this.btLast.insertAdjacentElement("afterbegin",X.f.createIconNoSpan(e?"first":"last",this.gridOptionsWrapper)),this.rowModel.getType()===Z.a.ROW_MODEL_TYPE_SERVER_SIDE&&(this.serverSideRowModel=this.rowModel),this.gridOptionsWrapper.isPagination()&&!this.gridOptionsWrapper.isSuppressPaginationPanel()?(this.addManagedListener(this.eventService,M.a.EVENT_PAGINATION_CHANGED,this.onPaginationChanged.bind(this)),this.addManagedListener(this.btFirst,"click",this.onBtFirst.bind(this)),this.addManagedListener(this.btLast,"click",this.onBtLast.bind(this)),this.addManagedListener(this.btNext,"click",this.onBtNext.bind(this)),this.addManagedListener(this.btPrevious,"click",this.onBtPrevious.bind(this)),this.onPaginationChanged()):this.setDisplayed(!1)},t.prototype.onPaginationChanged=function(){this.enableOrDisableButtons(),this.updateRowLabels(),this.setCurrentPageLabel(),this.setTotalLabels()},t.prototype.onBtFirst=function(){this.previousAndFirstButtonsDisabled||this.paginationProxy.goToFirstPage()},t.prototype.setCurrentPageLabel=function(){var e=this.paginationProxy.getTotalPages()>0,t=this.paginationProxy.getCurrentPage(),o=e?t+1:0;this.lbCurrent.innerHTML=this.formatNumber(o)},t.prototype.formatNumber=function(e){var t=this.gridOptionsWrapper.getPaginationNumberFormatterFunc();return t?t({value:e}):X.f.formatNumberCommas(e)},t.prototype.getTemplate=function(){var e=this.gridOptionsWrapper.getLocaleTextFunc(),t=e("page","Page"),o=e("to","to"),r=e("of","of");return'
\n \n \n '+o+'\n \n '+r+'\n \n \n \n
\n \n
\n
\n \n
\n \n '+t+'\n \n '+r+'\n \n \n \n
\n \n
\n
\n \n
\n
\n
"},t.prototype.onBtNext=function(){this.nextButtonDisabled||this.paginationProxy.goToNextPage()},t.prototype.onBtPrevious=function(){this.previousAndFirstButtonsDisabled||this.paginationProxy.goToPreviousPage()},t.prototype.onBtLast=function(){this.lastButtonDisabled||this.paginationProxy.goToLastPage()},t.prototype.enableOrDisableButtons=function(){var e=this.paginationProxy.getCurrentPage(),t=this.paginationProxy.isLastPageFound(),o=this.paginationProxy.getTotalPages();this.previousAndFirstButtonsDisabled=0===e,X.f.addOrRemoveCssClass(this.btPrevious,"ag-disabled",this.previousAndFirstButtonsDisabled),X.f.addOrRemoveCssClass(this.btFirst,"ag-disabled",this.previousAndFirstButtonsDisabled);var r=this.isZeroPagesToDisplay(),a=t&&e===o-1;this.nextButtonDisabled=a||r,X.f.addOrRemoveCssClass(this.btNext,"ag-disabled",this.nextButtonDisabled),this.lastButtonDisabled=!t||r||e===o-1,X.f.addOrRemoveCssClass(this.btLast,"ag-disabled",this.lastButtonDisabled)},t.prototype.updateRowLabels=function(){var e,t,o=this.paginationProxy.getCurrentPage(),r=this.paginationProxy.getPageSize(),a=this.paginationProxy.isLastPageFound(),n=this.paginationProxy.isLastPageFound()?this.paginationProxy.getMasterRowCount():null;this.isZeroPagesToDisplay()?(e=0,t=0):(t=(e=r*o+1)+r-1,a&&t>n&&(t=n)),this.lbFirstRowOnPage.innerHTML=this.formatNumber(e),this.serverSideRowModel&&this.serverSideRowModel.isLoading()?this.lbLastRowOnPage.innerHTML="?":this.lbLastRowOnPage.innerHTML=this.formatNumber(t)},t.prototype.isZeroPagesToDisplay=function(){var e=this.paginationProxy.isLastPageFound(),t=this.paginationProxy.getTotalPages();return e&&0===t},t.prototype.setTotalLabels=function(){var e=this.paginationProxy.isLastPageFound(),t=this.paginationProxy.getTotalPages(),o=this.paginationProxy.isLastPageFound()?this.paginationProxy.getMasterRowCount():null;if(e)this.lbTotal.innerHTML=this.formatNumber(t),this.lbRecordCount.innerHTML=this.formatNumber(o);else{var r=this.gridOptionsWrapper.getLocaleTextFunc()("more","more");this.lbTotal.innerHTML=r,this.lbRecordCount.innerHTML=r}},We([Object(E.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),We([Object(E.a)("paginationProxy")],t.prototype,"paginationProxy",void 0),We([Object(E.a)("rowRenderer")],t.prototype,"rowRenderer",void 0),We([Object(E.a)("rowModel")],t.prototype,"rowModel",void 0),We([Object(_e.d)("btFirst")],t.prototype,"btFirst",void 0),We([Object(_e.d)("btPrevious")],t.prototype,"btPrevious",void 0),We([Object(_e.d)("btNext")],t.prototype,"btNext",void 0),We([Object(_e.d)("btLast")],t.prototype,"btLast",void 0),We([Object(_e.d)("lbRecordCount")],t.prototype,"lbRecordCount",void 0),We([Object(_e.d)("lbFirstRowOnPage")],t.prototype,"lbFirstRowOnPage",void 0),We([Object(_e.d)("lbLastRowOnPage")],t.prototype,"lbLastRowOnPage",void 0),We([Object(_e.d)("eSummaryPanel")],t.prototype,"eSummaryPanel",void 0),We([Object(_e.d)("lbCurrent")],t.prototype,"lbCurrent",void 0),We([Object(_e.d)("lbTotal")],t.prototype,"lbTotal",void 0),We([E.e],t.prototype,"postConstruct",null),t}(Le.a),He=o(117),Be=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),ze=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i};!function(e){e[e.Loading=0]="Loading",e[e.NoRows=1]="NoRows"}(a||(a={}));var Ue=function(e){function t(){var o=e.call(this,t.TEMPLATE)||this;return o.inProgress=!1,o.destroyRequested=!1,o}return Be(t,e),t.prototype.postConstruct=function(){this.gridOptionsWrapper.addLayoutElement(this.eOverlayWrapper),this.setDisplayed(!1)},t.prototype.setWrapperTypeClass=function(e){X.f.addOrRemoveCssClass(this.eOverlayWrapper,"ag-overlay-loading-wrapper",e===a.Loading),X.f.addOrRemoveCssClass(this.eOverlayWrapper,"ag-overlay-no-rows-wrapper",e===a.NoRows)},t.prototype.showLoadingOverlay=function(){var e=this.userComponentFactory.newLoadingOverlayComponent({api:this.gridOptionsWrapper.getApi()});this.showOverlay(e,a.Loading)},t.prototype.showNoRowsOverlay=function(){var e=this.userComponentFactory.newNoRowsOverlayComponent({api:this.gridOptionsWrapper.getApi()});this.showOverlay(e,a.NoRows)},t.prototype.showOverlay=function(e,t){var o=this;this.inProgress||(this.setWrapperTypeClass(t),this.destroyActiveOverlay(),this.inProgress=!0,e.then((function(e){o.inProgress=!1,o.eOverlayWrapper.appendChild(e.getGui()),o.activeOverlay=e,o.destroyRequested&&(o.destroyRequested=!1,o.destroyActiveOverlay())})),this.setDisplayed(!0))},t.prototype.destroyActiveOverlay=function(){this.inProgress?this.destroyRequested=!0:this.activeOverlay&&(this.activeOverlay=this.getContext().destroyBean(this.activeOverlay),X.f.clearElement(this.eOverlayWrapper))},t.prototype.hideOverlay=function(){this.destroyActiveOverlay(),this.setDisplayed(!1)},t.prototype.destroy=function(){this.destroyActiveOverlay(),e.prototype.destroy.call(this)},t.TEMPLATE='\n ',ze([Object(E.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),ze([Object(E.a)("userComponentFactory")],t.prototype,"userComponentFactory",void 0),ze([Object(_e.d)("eOverlayWrapper")],t.prototype,"eOverlayWrapper",void 0),ze([E.e],t.prototype,"postConstruct",null),t}(Le.a),Ye=o(118),Ke=o(62),qe=o(63),Qe=o(64),Ze=o(119),Xe=o(120),Je=o(130),$e=o(121),et=o(122),tt=o(131),ot=o(123),rt=o(124),at=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),nt=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},it=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.cacheItems=[],t}return at(t,e),t.prototype.postConstruct=function(){this.active=this.gridOptionsWrapper.isKeepDetailRows(),this.maxCacheSize=this.gridOptionsWrapper.getKeepDetailRowsCount()},t.prototype.addOrDestroy=function(e,t,o){if(!this.active||!e.detail)this.destroyFullWidthRow(o);else{var r=this.getCacheItem(e,!0);switch(t){case Z.a.PINNED_LEFT:this.destroyFullWidthRow(r.left),r.left=o;break;case Z.a.PINNED_RIGHT:this.destroyFullWidthRow(r.right),r.right=o;break;default:this.destroyFullWidthRow(r.center),r.center=o}this.cacheItems.sort((function(e,t){return t.lastAccessedTime-e.lastAccessedTime})),this.purgeCache(this.maxCacheSize)}},t.prototype.getCacheItem=function(e,t){var o;void 0===t&&(t=!1);for(var r=0;re&&(this.cacheItems.length=e)},t.prototype.get=function(e,t){if(e.detail){var o,r=this.getCacheItem(e);if(r)switch(t){case Z.a.PINNED_LEFT:r.left&&(o=r.left,r.left=void 0);break;case Z.a.PINNED_RIGHT:r.right&&(o=r.right,r.right=void 0);break;default:r.center&&(o=r.center,r.center=void 0)}return o}},t.prototype.destroy=function(){e.prototype.destroy.call(this),this.purgeCache(0)},nt([Object(E.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),nt([E.e],t.prototype,"postConstruct",null),nt([E.g],t.prototype,"destroy",null),t=nt([Object(E.b)("detailRowCompCache")],t)}(H.a),lt=o(125),gt=o(126),st=o(127),pt=o(11),ct=o(10),dt=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),ut=function(e){this.cellValueChanges=e},ht=function(e){function t(t,o,r){var a=e.call(this,t)||this;return a.initialRange=o,a.finalRange=r,a}return dt(t,e),t}(ut),ft=function(){function e(t){this.actionStack=[],this.maxStackSize=t||e.DEFAULT_STACK_SIZE,this.actionStack=new Array(this.maxStackSize)}return e.prototype.pop=function(){return this.actionStack.pop()},e.prototype.push=function(e){e.cellValueChanges&&e.cellValueChanges.length>0&&(this.actionStack.length===this.maxStackSize&&this.actionStack.shift(),this.actionStack.push(e))},e.prototype.clear=function(){this.actionStack=[]},e.DEFAULT_STACK_SIZE=10,e}(),mt=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),bt=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},vt=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.cellValueChanges=[],t.isCellEditing=!1,t.isRowEditing=!1,t.isPasting=!1,t.isFilling=!1,t.onCellValueChanged=function(e){if(t.isCellEditing||t.isRowEditing||t.isPasting||t.isFilling){var o=e.rowPinned,r=e.rowIndex,a=e.column,n=e.oldValue,i=e.value,l={rowPinned:o,rowIndex:r,columnId:a.getColId(),oldValue:n,newValue:i};t.cellValueChanges.push(l)}},t.clearStacks=function(){t.undoStack.clear(),t.redoStack.clear()},t}return mt(t,e),t.prototype.init=function(){if(this.gridOptionsWrapper.isUndoRedoCellEditing()){var e=this.gridOptionsWrapper.getUndoRedoCellEditingLimit();e<=0||(this.undoStack=new ft(e),this.redoStack=new ft(e),this.addRowEditingListeners(),this.addCellEditingListeners(),this.addPasteListeners(),this.addFillListeners(),this.addManagedListener(this.eventService,Ce.a.EVENT_CELL_VALUE_CHANGED,this.onCellValueChanged),this.addManagedListener(this.eventService,Ce.a.EVENT_MODEL_UPDATED,this.clearStacks),this.addManagedListener(this.eventService,Ce.a.EVENT_COLUMN_PIVOT_MODE_CHANGED,this.clearStacks),this.addManagedListener(this.eventService,Ce.a.EVENT_COLUMN_EVERYTHING_CHANGED,this.clearStacks),this.addManagedListener(this.eventService,Ce.a.EVENT_COLUMN_GROUP_OPENED,this.clearStacks),this.addManagedListener(this.eventService,Ce.a.EVENT_COLUMN_ROW_GROUP_CHANGED,this.clearStacks),this.addManagedListener(this.eventService,Ce.a.EVENT_COLUMN_MOVED,this.clearStacks),this.addManagedListener(this.eventService,Ce.a.EVENT_COLUMN_PINNED,this.clearStacks),this.addManagedListener(this.eventService,Ce.a.EVENT_COLUMN_VISIBLE,this.clearStacks),this.addManagedListener(this.eventService,Ce.a.EVENT_ROW_DRAG_END,this.clearStacks))}},t.prototype.undo=function(){if(this.undoStack){var e=this.undoStack.pop();e&&e.cellValueChanges&&(this.processAction(e,(function(e){return e.oldValue})),e instanceof ht?this.processRangeAndCellFocus(e.cellValueChanges,e.initialRange):this.processRangeAndCellFocus(e.cellValueChanges),this.redoStack.push(e))}},t.prototype.redo=function(){if(this.redoStack){var e=this.redoStack.pop();e&&e.cellValueChanges&&(this.processAction(e,(function(e){return e.newValue})),e instanceof ht?this.processRangeAndCellFocus(e.cellValueChanges,e.finalRange):this.processRangeAndCellFocus(e.cellValueChanges),this.undoStack.push(e))}},t.prototype.processAction=function(e,t){var o=this;e.cellValueChanges.forEach((function(e){var r=e.rowIndex,a=e.rowPinned,n=e.columnId,i={rowIndex:r,rowPinned:a},l=o.getRowNode(i);null!=l.rowTop&&l.setDataValue(n,t(e))}))},t.prototype.processRangeAndCellFocus=function(e,t){if(t){var o=t.startRow,r=t.endRow,a={rowPinned:o.rowPinned,rowIndex:o.rowIndex,columnId:t.startColumn.getColId()};this.setLastFocusedCell(a);var n={rowStartIndex:o.rowIndex,rowStartPinned:o.rowPinned,rowEndIndex:r.rowIndex,rowEndPinned:r.rowPinned,columnStart:t.startColumn,columns:t.columns};this.gridApi.addCellRange(n)}else{var i=e[0],l={rowIndex:i.rowIndex,rowPinned:i.rowPinned},g=this.getRowNode(l),s={rowPinned:i.rowPinned,rowIndex:g.rowIndex,columnId:i.columnId};this.setLastFocusedCell(s)}},t.prototype.setLastFocusedCell=function(e){var t=e.rowIndex,o=e.columnId,r=e.rowPinned;this.gridApi.ensureIndexVisible(t),this.gridApi.ensureColumnVisible(o),pt.a.isRegistered(ct.a.RangeSelectionModule)&&this.gridApi.clearRangeSelection(),this.focusController.setFocusedCell(t,o,r,!0)},t.prototype.addRowEditingListeners=function(){var e=this;this.addManagedListener(this.eventService,Ce.a.EVENT_ROW_EDITING_STARTED,(function(){e.isRowEditing=!0})),this.addManagedListener(this.eventService,Ce.a.EVENT_ROW_EDITING_STOPPED,(function(){var t=new ut(e.cellValueChanges);e.pushActionsToUndoStack(t),e.isRowEditing=!1}))},t.prototype.addCellEditingListeners=function(){var e=this;this.addManagedListener(this.eventService,Ce.a.EVENT_CELL_EDITING_STARTED,(function(){e.isCellEditing=!0})),this.addManagedListener(this.eventService,Ce.a.EVENT_CELL_EDITING_STOPPED,(function(){if(e.isCellEditing=!1,!e.isRowEditing&&!e.isPasting&&!e.isFilling){var t=new ut(e.cellValueChanges);e.pushActionsToUndoStack(t)}}))},t.prototype.addPasteListeners=function(){var e=this;this.addManagedListener(this.eventService,Ce.a.EVENT_PASTE_START,(function(){e.isPasting=!0})),this.addManagedListener(this.eventService,Ce.a.EVENT_PASTE_END,(function(){var t=new ut(e.cellValueChanges);e.pushActionsToUndoStack(t),e.isPasting=!1}))},t.prototype.addFillListeners=function(){var e=this;this.addManagedListener(this.eventService,Ce.a.EVENT_FILL_START,(function(){e.isFilling=!0})),this.addManagedListener(this.eventService,Ce.a.EVENT_FILL_END,(function(t){var o=new ht(e.cellValueChanges,t.initialRange,t.finalRange);e.pushActionsToUndoStack(o),e.isFilling=!1}))},t.prototype.pushActionsToUndoStack=function(e){this.undoStack.push(e),this.cellValueChanges=[],this.redoStack.clear()},t.prototype.getRowNode=function(e){switch(e.rowPinned){case Z.a.PINNED_TOP:return this.pinnedRowModel.getPinnedTopRowData()[e.rowIndex];case Z.a.PINNED_BOTTOM:return this.pinnedRowModel.getPinnedBottomRowData()[e.rowIndex];default:return this.rowModel.getRow(e.rowIndex)}},bt([Object(E.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),bt([Object(E.a)("focusController")],t.prototype,"focusController",void 0),bt([Object(E.a)("gridApi")],t.prototype,"gridApi",void 0),bt([Object(E.a)("rowModel")],t.prototype,"rowModel",void 0),bt([Object(E.a)("pinnedRowModel")],t.prototype,"pinnedRowModel",void 0),bt([E.e],t.prototype,"init",null),t=bt([Object(E.b)("undoRedoService")],t)}(H.a),yt=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),wt=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},xt=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.componentsMappedByName={},t}return yt(t,e),t.prototype.setupComponents=function(e){var t=this;e&&e.forEach((function(e){return t.addComponent(e)}))},t.prototype.addComponent=function(e){var t=e.componentName.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase().toUpperCase();this.componentsMappedByName[t]=e.componentClass},t.prototype.getComponentClass=function(e){return this.componentsMappedByName[e]},t=wt([Object(E.b)("agStackComponentsRegistry")],t)}(H.a),Ct=o(128),kt=o(34),At=function(){function e(e,t,o){if(e)if(t){var r=!!t.debug;this.gridOptions=t;var a=this.getRegisteredModules(o),n=this.createBeansList(a),i=this.createProvidedBeans(e,o);if(n){var l={providedBeanInstances:i,beanClasses:n,debug:r};this.logger=new x.a("ag-Grid",(function(){return t.debug}));var g=new x.a("Context",(function(){return l.debug}));this.context=new E.c(l,g),this.registerModuleUserComponents(a),this.registerStackComponents(a);var s=new(o&&o.rootComponent||O.a);this.context.createBean(s),this.setColumnsAndData(),this.dispatchGridReadyEvent(t);var p=pt.a.isRegistered(ct.a.EnterpriseCoreModule);this.logger.log("initialised successfully, enterprise = "+p)}}else console.error("ag-Grid: no gridOptions provided to the grid");else console.error("ag-Grid: no div element provided to the grid")}return e.prototype.registerStackComponents=function(e){var t=this.createAgStackComponentsList(e);this.context.getBean("agStackComponentsRegistry").setupComponents(t)},e.prototype.getRegisteredModules=function(e){var t=e?e.modules:null,o=pt.a.getRegisteredModules(),r=[],a={};function n(e,t){!function(t){a[t.moduleName]||(a[t.moduleName]=!0,r.push(t),pt.a.register(t,e))}(t),t.dependantModules&&t.dependantModules.forEach(n.bind(null,e))}return t&&t.forEach(n.bind(null,!0)),o&&o.forEach(n.bind(null,!pt.a.isPackageBased())),r},e.prototype.registerModuleUserComponents=function(e){var t=this.context.getBean("userComponentRegistry");this.extractModuleEntity(e,(function(e){return e.userComponents?e.userComponents:[]})).forEach((function(e){t.registerDefaultComponent(e.componentName,e.componentClass)}))},e.prototype.createProvidedBeans=function(e,t){var o=t?t.frameworkOverrides:null;X.f.missing(o)&&(o=new V.a);var r={gridOptions:this.gridOptions,eGridDiv:e,$scope:t?t.$scope:null,$compile:t?t.$compile:null,quickFilterOnScope:t?t.quickFilterOnScope:null,globalEventListener:t?t.globalEventListener:null,frameworkOverrides:o};return t&&t.providedBeanInstances&&X.f.assign(r,t.providedBeanInstances),r},e.prototype.createAgStackComponentsList=function(e){var t=[{componentName:"AgCheckbox",componentClass:L.a},{componentName:"AgRadioButton",componentClass:_.a},{componentName:"AgToggleButton",componentClass:rt.a},{componentName:"AgInputTextField",componentClass:Qe.a},{componentName:"AgInputTextArea",componentClass:Ze.a},{componentName:"AgInputNumberField",componentClass:$e.a},{componentName:"AgInputRange",componentClass:et.a},{componentName:"AgSelect",componentClass:tt.a},{componentName:"AgSlider",componentClass:Xe.a},{componentName:"AgAngleSelect",componentClass:ot.a},{componentName:"AgColorPicker",componentClass:Je.a},{componentName:"AgGridComp",componentClass:h.a},{componentName:"AgHeaderRoot",componentClass:p.a},{componentName:"AgPagination",componentClass:je},{componentName:"AgOverlayWrapper",componentClass:Ue},{componentName:"AgGroupComponent",componentClass:Ye.a},{componentName:"AgPanel",componentClass:qe.a},{componentName:"AgDialog",componentClass:Ke.a}],o=this.extractModuleEntity(e,(function(e){return e.agStackComponents?e.agStackComponents:[]}));return t=t.concat(o)},e.prototype.createBeansList=function(e){var t=this.getRowModelClass(e);if(t){var o=[t,we,lt.a,gt.a,Ct.a,ae,f.a,de.b,fe,ve,He.a,ce.b,De,Ge,I.a,A.a,st.a,T.a,b.a,u.a,n.a,w.a,i.a,c.a,g.a,kt.b,te.a,s.a,v.a,m.a,y.a,pe.a,Se,ne.a,d.a,x.b,C.a,k.a,R.a,S.a,l.a,D.a,N.a,xe.a,F.a,G.a,j.a,W.a,P.a,U,q,Ne.a,ee,se,Ee,it,vt,xt],r=this.extractModuleEntity(e,(function(e){return e.beans?e.beans:[]}));o.push.apply(o,r);var a=[];return o.forEach((function(e){a.indexOf(e)<0&&a.push(e)})),a}},e.prototype.extractModuleEntity=function(e,t){return[].concat.apply([],e.map(t))},e.prototype.setColumnsAndData=function(){var e=this.context.getBean("gridOptionsWrapper"),t=this.context.getBean("columnController"),o=e.getColumnDefs();X.f.exists(o)&&t.setColumnDefs(o,"gridInitializing"),this.context.getBean("rowModel").start()},e.prototype.dispatchGridReadyEvent=function(e){var t=this.context.getBean("eventService"),o={type:M.a.EVENT_GRID_READY,api:e.api,columnApi:e.columnApi};t.dispatchEvent(o)},e.prototype.getRowModelClass=function(e){var t=this.gridOptions.rowModelType;"enterprise"===t&&(console.warn("ag-Grid: enterprise rowModel deprecated. Should now be called server side row model instead."),t=Z.a.ROW_MODEL_TYPE_SERVER_SIDE),"normal"===t&&(console.warn("ag-Grid: normal rowModel deprecated. Should now be called client side row model instead."),t=Z.a.ROW_MODEL_TYPE_CLIENT_SIDE),t||(t=Z.a.ROW_MODEL_TYPE_CLIENT_SIDE);var o={};e.forEach((function(e){X.f.iterateObject(e.rowModels,(function(e,t){o[e]=t}))}));var r=o[t];return X.f.exists(r)?r:(t===Z.a.ROW_MODEL_TYPE_INFINITE&&console.error('ag-Grid: Row Model "Infinite" not found. Please ensure the '+ct.a.InfiniteRowModelModule+" is registered.';"),console.error("ag-Grid: could not find matching row model for rowModelType "+t),t===Z.a.ROW_MODEL_TYPE_VIEWPORT&&console.error('ag-Grid: Row Model "Viewport" not found. Please ensure the ag-Grid Enterprise Module '+ct.a.ViewportRowModelModule+" is registered.';"),t===Z.a.ROW_MODEL_TYPE_SERVER_SIDE&&console.error('ag-Grid: Row Model "Server Side" not found. Please ensure the ag-Grid Enterprise Module '+ct.a.ServerSideRowModelModule+" is registered.';"),void(t===Z.a.ROW_MODEL_TYPE_CLIENT_SIDE&&console.error('ag-Grid: Row Model "Client Side" not found. Please ensure the '+ct.a.ClientSideRowModelModule+" is registered.';")))},e.prototype.destroy=function(){this.gridOptions.api.destroy()},e}()},function(e,t,o){"use strict";o.r(t),o.d(t,"utf8_encode",(function(){return n})),o.d(t,"camelCaseToHyphen",(function(){return i})),o.d(t,"hyphenToCamelCase",(function(){return l})),o.d(t,"capitalise",(function(){return g})),o.d(t,"escape",(function(){return s})),o.d(t,"camelCaseToHumanText",(function(){return p}));var r=/[&<>"']/g,a={"&":"&","<":"<",">":">",'"':""","'":"'"};function n(e){var t=String.fromCharCode;function o(e,o){return t(e>>o&63|128)}function r(e){if(0==(4294967168&e))return t(e);var r="";return 0==(4294965248&e)?r=t(e>>6&31|192):0==(4294901760&e)?(!function(e){if(e>=55296&&e<=57343)throw Error("Lone surrogate U+"+e.toString(16).toUpperCase()+" is not a scalar value")}(e),r=t(e>>12&15|224),r+=o(e,6)):0==(4292870144&e)&&(r=t(e>>18&7|240),r+=o(e,12),r+=o(e,6)),r+=t(63&e|128)}for(var a=function(e){for(var t,o,r=[],a=0,n=e.length;a=55296&&t<=56319&&a1?e.substring(1,e.length):"")})).join(" ")}},function(e,t,o){"use strict";o.d(t,"a",(function(){return s}));var r,a=o(7),n=o(1),i=o(0),l=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),g=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},s=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.labelSeparator="",t.labelAlignment="left",t.config={},t.label="",t}return l(t,e),t.prototype.postConstruct=function(){i.f.addCssClass(this.getGui(),"ag-labeled"),i.f.addCssClass(this.eLabel,"ag-label");var e=this.config,t=e.labelSeparator,o=e.label,r=e.labelWidth,a=e.labelAlignment;null!=t&&this.setLabelSeparator(t),null!=o&&this.setLabel(o),null!=r&&this.setLabelWidth(r),this.setLabelAlignment(a||this.labelAlignment),this.refreshLabel()},t.prototype.refreshLabel=function(){this.eLabel.innerText=this.label+this.labelSeparator,i.f.addOrRemoveCssClass(this.eLabel,"ag-hidden",""===this.label)},t.prototype.setLabelSeparator=function(e){return this.labelSeparator===e||(this.labelSeparator=e,null!=this.label&&this.refreshLabel()),this},t.prototype.setLabel=function(e){return this.label===e||(this.label=e,this.refreshLabel()),this},t.prototype.setLabelAlignment=function(e){var t=this.getGui();return i.f.addOrRemoveCssClass(t,"ag-label-align-left","left"===e),i.f.addOrRemoveCssClass(t,"ag-label-align-right","right"===e),i.f.addOrRemoveCssClass(t,"ag-label-align-top","top"===e),this},t.prototype.setLabelWidth=function(e){return null==this.label||i.f.setElementWidth(this.eLabel,e),this},g([n.e],t.prototype,"postConstruct",null),t}(a.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return u}));var r,a=o(1),n=o(4),i=o(31),l=o(89),g=o(2),s=o(8),p=o(6),c=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),d=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},u=function(e){function t(t,o,r){var a=e.call(this)||this;return a.headerRowComps=[],a.eContainer=t,a.pinned=r,a.eViewport=o,a}return c(t,e),t.prototype.forEachHeaderElement=function(e){this.headerRowComps.forEach((function(t){return t.forEachHeaderElement(e)}))},t.prototype.init=function(){this.scrollWidth=this.gridOptionsWrapper.getScrollbarWidth(),this.addManagedListener(this.eventService,n.a.EVENT_COLUMN_VALUE_CHANGED,this.onColumnValueChanged.bind(this)),this.addManagedListener(this.eventService,n.a.EVENT_COLUMN_ROW_GROUP_CHANGED,this.onColumnRowGroupChanged.bind(this)),this.addManagedListener(this.eventService,n.a.EVENT_GRID_COLUMNS_CHANGED,this.onGridColumnsChanged.bind(this)),this.addManagedListener(this.eventService,n.a.EVENT_SCROLL_VISIBILITY_CHANGED,this.onScrollVisibilityChanged.bind(this)),this.addManagedListener(this.eventService,n.a.EVENT_COLUMN_RESIZED,this.onColumnResized.bind(this)),this.addManagedListener(this.eventService,n.a.EVENT_DISPLAYED_COLUMNS_CHANGED,this.onDisplayedColumnsChanged.bind(this))},t.prototype.onColumnRowGroupChanged=function(){this.onGridColumnsChanged()},t.prototype.onColumnValueChanged=function(){this.onGridColumnsChanged()},t.prototype.onColumnResized=function(){this.setWidthOfPinnedContainer()},t.prototype.onDisplayedColumnsChanged=function(){this.setWidthOfPinnedContainer()},t.prototype.onScrollVisibilityChanged=function(){this.setWidthOfPinnedContainer()},t.prototype.setWidthOfPinnedContainer=function(){var e=this.pinned===g.a.PINNED_LEFT,t=this.pinned===g.a.PINNED_RIGHT,o=this.columnController,r=this.gridOptionsWrapper.isEnableRtl();if(e||t){var a=o[e?"getPinnedLeftContainerWidth":"getPinnedRightContainerWidth"]();this.scrollVisibleService.isVerticalScrollShowing()&&(r&&e||!r&&t)&&(a+=this.scrollWidth),Object(s.setFixedWidth)(this.eContainer,a)}},t.prototype.getRowComps=function(){return this.headerRowComps},t.prototype.onGridColumnsChanged=function(){this.removeAndCreateAllRowComps()},t.prototype.removeAndCreateAllRowComps=function(){this.removeHeaderRowComps(),this.createHeaderRowComps()},t.prototype.refresh=function(){this.removeAndCreateAllRowComps()},t.prototype.setupDragAndDrop=function(e){var t=this.eViewport?this.eViewport:this.eContainer,o=new l.a(this.pinned,t);this.createManagedBean(o),o.registerGridComp(e)},t.prototype.removeHeaderRowComps=function(){var e=this;this.headerRowComps.forEach((function(t){return e.destroyBean(t)})),this.headerRowComps.length=0,Object(s.clearElement)(this.eContainer)},t.prototype.createHeaderRowComps=function(){for(var e=this.columnController.getHeaderRowCount(),t=0;t=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},g=function(e){function t(t,o){var r=e.call(this)||this;return r.columns=t,r.element=o,r}return i(t,e),t.prototype.postConstruct=function(){this.addMouseHoverListeners()},t.prototype.addMouseHoverListeners=function(){this.addManagedListener(this.element,"mouseout",this.onMouseOut.bind(this)),this.addManagedListener(this.element,"mouseover",this.onMouseOver.bind(this))},t.prototype.onMouseOut=function(){this.columnHoverService.clearMouseOver()},t.prototype.onMouseOver=function(){this.columnHoverService.setMouseOver(this.columns)},l([Object(n.a)("columnHoverService")],t.prototype,"columnHoverService",void 0),l([n.e],t.prototype,"postConstruct",null),t}(a.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return i}));var r,a=o(29),n=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),i=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return n(t,e),t.prototype.getColumn=function(){return this.column},t.prototype.getPinned=function(){return this.pinned},t}(a.a)},function(e,t,o){"use strict";o.r(t),o.d(t,"ClientSideRowModelModule",(function(){return S}));var r,a,n=o(3),i=function(){function e(t,o,r,a,n,i,l,g){this.nextId=0,this.allNodesMap={},this.rootNode=t,this.gridOptionsWrapper=o,this.context=r,this.eventService=a,this.columnController=n,this.gridApi=i,this.columnApi=l,this.selectionController=g,this.rootNode.group=!0,this.rootNode.level=-1,this.rootNode.id=e.ROOT_NODE_ID,this.rootNode.allLeafChildren=[],this.rootNode.childrenAfterGroup=[],this.rootNode.childrenAfterSort=[],this.rootNode.childrenAfterFilter=[],this.postConstruct()}return e.prototype.postConstruct=function(){this.getNodeChildDetails=this.gridOptionsWrapper.getNodeChildDetailsFunc(),this.suppressParentsInRowNodes=this.gridOptionsWrapper.isSuppressParentsInRowNodes(),this.doesDataFlower=this.gridOptionsWrapper.getDoesDataFlowerFunc(),this.isRowMasterFunc=this.gridOptionsWrapper.getIsRowMasterFunc(),this.doingTreeData=this.gridOptionsWrapper.isTreeData(),this.doingLegacyTreeData=!this.doingTreeData&&n._.exists(this.getNodeChildDetails),this.doingMasterDetail=this.gridOptionsWrapper.isMasterDetail(),this.getNodeChildDetails&&console.warn("ag-Grid: the callback nodeChildDetailsFunc() is now deprecated. The new way of doing\n tree data in ag-Grid was introduced in v14 (released November 2017). In the next\n major release of ag-Grid we will be dropping support for the old version of\n tree data. If you are reading this message, please go to the docs to see how\n to implement Tree Data without using nodeChildDetailsFunc().")},e.prototype.getCopyOfNodesMap=function(){return n._.cloneObject(this.allNodesMap)},e.prototype.getRowNode=function(e){return this.allNodesMap[e]},e.prototype.setRowData=function(t){if(this.rootNode.childrenAfterFilter=null,this.rootNode.childrenAfterGroup=null,this.rootNode.childrenAfterSort=null,this.rootNode.childrenMapped=null,this.nextId=0,this.allNodesMap={},!t)return this.rootNode.allLeafChildren=[],void(this.rootNode.childrenAfterGroup=[]);var o=this.recursiveFunction(t,this.rootNode,e.TOP_LEVEL);this.doingLegacyTreeData?(this.rootNode.childrenAfterGroup=o,this.setLeafChildren(this.rootNode)):this.rootNode.allLeafChildren=o},e.prototype.updateRowData=function(e,t){if(this.isLegacyTreeData())return null;var o={remove:[],update:[],add:[]},r=[];return this.executeAdd(e,o),this.executeRemove(e,o,r),this.executeUpdate(e,o,r),this.updateSelection(r),t&&n._.sortRowNodesByOrder(this.rootNode.allLeafChildren,t),o},e.prototype.updateSelection=function(e){var t=e.length>0;if(t&&e.forEach((function(e){e.setSelected(!1,!1,!0)})),this.selectionController.updateGroupsFromChildrenSelections(),t){var o={type:n.Events.EVENT_SELECTION_CHANGED,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(o)}},e.prototype.executeAdd=function(e,t){var o=this,r=e.add,a=e.addIndex;r&&("number"==typeof a&&a>=0?r.reverse().forEach((function(e){var r=o.addRowNode(e,a);t.add.push(r)})):r.forEach((function(e){var r=o.addRowNode(e);t.add.push(r)})))},e.prototype.executeRemove=function(e,t,o){var r=this,a=e.remove;if(a){var n={};a.forEach((function(e){var a=r.lookupRowNode(e);a&&(a.isSelected()&&o.push(a),a.clearRowTop(),n[a.id]=!0,delete r.allNodesMap[a.id],t.remove.push(a))})),this.rootNode.allLeafChildren=this.rootNode.allLeafChildren.filter((function(e){return!n[e.id]}))}},e.prototype.executeUpdate=function(t,o,r){var a=this,n=t.update;n&&n.forEach((function(t){var n=a.lookupRowNode(t);n&&(n.updateData(t),!n.selectable&&n.isSelected()&&r.push(n),a.setMasterForRow(n,t,e.TOP_LEVEL,!1),o.update.push(n))}))},e.prototype.addRowNode=function(t,o){var r=this.createNode(t,this.rootNode,e.TOP_LEVEL);return n._.exists(o)?n._.insertIntoArray(this.rootNode.allLeafChildren,r,o):this.rootNode.allLeafChildren.push(r),r},e.prototype.lookupRowNode=function(e){var t,o=this.gridOptionsWrapper.getRowNodeIdFunc();if(n._.exists(o)){var r=o(e);if(!(t=this.allNodesMap[r]))return console.error("ag-Grid: could not find row id="+r+", data item was not found for this id"),null}else if(!(t=n._.find(this.rootNode.allLeafChildren,(function(t){return t.data===e}))))return console.error("ag-Grid: could not find data item as object was not found",e),null;return t},e.prototype.recursiveFunction=function(e,t,o){var r=this;if("string"!=typeof e){var a=[];return e.forEach((function(e){var n=r.createNode(e,t,o);a.push(n)})),a}console.warn("ag-Grid: rowData must be an array, however you passed in a string. If you are loading JSON, make sure you convert the JSON string to JavaScript objects first")},e.prototype.createNode=function(e,t,o){var r=new n.RowNode;this.context.createBean(r);var a=this.doingLegacyTreeData?this.getNodeChildDetails(e):null;return a&&a.group?(r.group=!0,r.childrenAfterGroup=this.recursiveFunction(a.children,r,o+1),r.expanded=!0===a.expanded,r.field=a.field,r.key=a.key,this.setLeafChildren(r)):(r.group=!1,this.setMasterForRow(r,e,o,!0)),r.canFlower=r.master,t&&!this.suppressParentsInRowNodes&&(r.parent=t),r.level=o,r.setDataAndId(e,this.nextId.toString()),this.allNodesMap[r.id]&&console.warn("ag-grid: duplicate node id '"+r.id+"' detected from getRowNodeId callback, this could cause issues in your grid."),this.allNodesMap[r.id]=r,this.nextId++,r},e.prototype.setMasterForRow=function(e,t,o,r){if(this.doingTreeData)e.setMaster(!1),r&&(e.expanded=!1);else if(this.doesDataFlower?e.setMaster(this.doesDataFlower(t)):this.doingMasterDetail?this.isRowMasterFunc?e.setMaster(this.isRowMasterFunc(t)):e.setMaster(!0):e.setMaster(!1),r){var a=this.columnController.getRowGroupColumns(),n=o+(a?a.length:0);e.expanded=!!e.master&&this.isExpanded(n)}},e.prototype.isExpanded=function(e){var t=this.gridOptionsWrapper.getGroupDefaultExpanded();return-1===t||e=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i};!function(e){e[e.Normal=0]="Normal",e[e.AfterFilter=1]="AfterFilter",e[e.AfterFilterAndSort=2]="AfterFilterAndSort",e[e.PivotNodes=3]="PivotNodes"}(a||(a={}));var s=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return l(t,e),t.prototype.init=function(){var e=this.refreshModel.bind(this,{step:n.Constants.STEP_EVERYTHING}),t=this.refreshModel.bind(this,{step:n.Constants.STEP_EVERYTHING,afterColumnsChanged:!0,keepRenderedRows:!0});this.addManagedListener(this.eventService,n.Events.EVENT_COLUMN_EVERYTHING_CHANGED,t),this.addManagedListener(this.eventService,n.Events.EVENT_COLUMN_ROW_GROUP_CHANGED,e),this.addManagedListener(this.eventService,n.Events.EVENT_COLUMN_VALUE_CHANGED,this.onValueChanged.bind(this)),this.addManagedListener(this.eventService,n.Events.EVENT_COLUMN_PIVOT_CHANGED,this.refreshModel.bind(this,{step:n.Constants.STEP_PIVOT})),this.addManagedListener(this.eventService,n.Events.EVENT_ROW_GROUP_OPENED,this.onRowGroupOpened.bind(this)),this.addManagedListener(this.eventService,n.Events.EVENT_FILTER_CHANGED,this.onFilterChanged.bind(this)),this.addManagedListener(this.eventService,n.Events.EVENT_SORT_CHANGED,this.onSortChanged.bind(this)),this.addManagedListener(this.eventService,n.Events.EVENT_COLUMN_PIVOT_MODE_CHANGED,e);var o=this.refreshModel.bind(this,{step:n.Constants.STEP_MAP,keepRenderedRows:!0,animate:!0});this.addManagedListener(this.gridOptionsWrapper,n.GridOptionsWrapper.PROP_GROUP_REMOVE_SINGLE_CHILDREN,o),this.addManagedListener(this.gridOptionsWrapper,n.GridOptionsWrapper.PROP_GROUP_REMOVE_LOWEST_SINGLE_CHILDREN,o),this.rootNode=new n.RowNode,this.nodeManager=new i(this.rootNode,this.gridOptionsWrapper,this.getContext(),this.eventService,this.columnController,this.gridApi,this.columnApi,this.selectionController),this.createBean(this.rootNode)},t.prototype.start=function(){var e=this.gridOptionsWrapper.getRowData();e&&this.setRowData(e)},t.prototype.ensureRowHeightsValid=function(e,t,o,r){var a,n=!1;do{a=!1;for(var i=this.getRowIndexAtPixel(e),l=this.getRowIndexAtPixel(t),g=Math.max(i,o),s=Math.min(l,r),p=g;p<=s;p++){var c=this.getRow(p);if(c.rowHeightEstimated){var d=this.gridOptionsWrapper.getRowHeightForNode(c);c.setRowHeight(d.height),a=!0,n=!0}}a&&this.setRowTops()}while(a);return n},t.prototype.setRowTops=function(){for(var e=0,t=0;t0;)t=t.childrenAfterSort[0];return t.rowIndex},t.prototype.getRowBounds=function(e){if(n._.missing(this.rowsToDisplay))return null;var t=this.rowsToDisplay[e];return t?{rowTop:t.rowTop,rowHeight:t.rowHeight}:null},t.prototype.onRowGroupOpened=function(){var e=this.gridOptionsWrapper.isAnimateRows();this.refreshModel({step:n.Constants.STEP_MAP,keepRenderedRows:!0,animate:e})},t.prototype.onFilterChanged=function(e){if(!e.afterDataChange){var t=this.gridOptionsWrapper.isAnimateRows();this.refreshModel({step:n.Constants.STEP_FILTER,keepRenderedRows:!0,animate:t})}},t.prototype.onSortChanged=function(){var e=this.gridOptionsWrapper.isAnimateRows();this.refreshModel({step:n.Constants.STEP_SORT,keepRenderedRows:!0,animate:e,keepEditingRows:!0})},t.prototype.getType=function(){return n.Constants.ROW_MODEL_TYPE_CLIENT_SIDE},t.prototype.onValueChanged=function(){this.columnController.isPivotActive()?this.refreshModel({step:n.Constants.STEP_PIVOT}):this.refreshModel({step:n.Constants.STEP_AGGREGATE})},t.prototype.createChangePath=function(e){var t=n._.missingOrEmpty(e),o=new n.ChangedPath(!1,this.rootNode);return(t||this.gridOptionsWrapper.isTreeData())&&o.setInactive(),o},t.prototype.refreshModel=function(e){var t=this,o=this.createChangePath(e.rowNodeTransactions);switch(e.step){case n.Constants.STEP_EVERYTHING:this.doRowGrouping(e.groupState,e.rowNodeTransactions,e.rowNodeOrder,o,e.afterColumnsChanged);case n.Constants.STEP_FILTER:this.doFilter(o);case n.Constants.STEP_PIVOT:this.doPivot(o);case n.Constants.STEP_AGGREGATE:this.doAggregate(o);case n.Constants.STEP_SORT:this.doSort(e.rowNodeTransactions,o);case n.Constants.STEP_MAP:this.doRowsToDisplay()}this.resetRowTops(this.rootNode,o),this.setRowTops();var r={type:n.Events.EVENT_MODEL_UPDATED,api:this.gridApi,columnApi:this.columnApi,animate:e.animate,keepRenderedRows:e.keepRenderedRows,newData:e.newData,newPage:!1};this.eventService.dispatchEvent(r),this.$scope&&window.setTimeout((function(){t.$scope.$apply()}),0)},t.prototype.isEmpty=function(){var e;return e=n._.exists(this.gridOptionsWrapper.getNodeChildDetailsFunc())?n._.missing(this.rootNode.childrenAfterGroup)||0===this.rootNode.childrenAfterGroup.length:n._.missing(this.rootNode.allLeafChildren)||0===this.rootNode.allLeafChildren.length,n._.missing(this.rootNode)||e||!this.columnController.isReady()},t.prototype.isRowsToRender=function(){return n._.exists(this.rowsToDisplay)&&this.rowsToDisplay.length>0},t.prototype.getNodesInRangeForSelection=function(e,t){var o,r=!t,a=!1,n=[],i=this.gridOptionsWrapper.isGroupSelectsChildren();return this.forEachNodeAfterFilterAndSort((function(l){var g=r&&!a;if(r||l!==t&&l!==e||(r=!0),!(l.group&&i)){var s=r&&!a,p=l.isParentOfNode(o);(s||p)&&n.push(l)}g&&(l!==t&&l!==e||(a=!0,o=l===t?t:e))})),n},t.prototype.setDatasource=function(e){console.error("ag-Grid: should never call setDatasource on clientSideRowController")},t.prototype.getTopLevelNodes=function(){return this.rootNode?this.rootNode.childrenAfterGroup:null},t.prototype.getRootNode=function(){return this.rootNode},t.prototype.getRow=function(e){return this.rowsToDisplay[e]},t.prototype.isRowPresent=function(e){return this.rowsToDisplay.indexOf(e)>=0},t.prototype.getRowIndexAtPixel=function(e){if(this.isEmpty())return-1;var t=0,o=this.rowsToDisplay.length-1;if(e<=0)return 0;if(n._.last(this.rowsToDisplay).rowTop<=e)return this.rowsToDisplay.length-1;for(;;){var r=Math.floor((t+o)/2),a=this.rowsToDisplay[r];if(this.isRowInPixel(a,e))return r;a.rowTope&&(o=r-1)}},t.prototype.isRowInPixel=function(e,t){var o=e.rowTop,r=e.rowTop+e.rowHeight;return o<=t&&r>t},t.prototype.getCurrentPageHeight=function(){if(this.rowsToDisplay&&this.rowsToDisplay.length>0){var e=n._.last(this.rowsToDisplay);return e.rowTop+e.rowHeight}return 0},t.prototype.forEachLeafNode=function(e){this.rootNode.allLeafChildren&&this.rootNode.allLeafChildren.forEach((function(t,o){return e(t,o)}))},t.prototype.forEachNode=function(e){this.recursivelyWalkNodesAndCallback(this.rootNode.childrenAfterGroup,e,a.Normal,0)},t.prototype.forEachNodeAfterFilter=function(e){this.recursivelyWalkNodesAndCallback(this.rootNode.childrenAfterFilter,e,a.AfterFilter,0)},t.prototype.forEachNodeAfterFilterAndSort=function(e){this.recursivelyWalkNodesAndCallback(this.rootNode.childrenAfterSort,e,a.AfterFilterAndSort,0)},t.prototype.forEachPivotNode=function(e){this.recursivelyWalkNodesAndCallback([this.rootNode],e,a.PivotNodes,0)},t.prototype.recursivelyWalkNodesAndCallback=function(e,t,o,r){if(!e)return r;for(var n=0;n0&&window.setTimeout((function(){t.forEach((function(e){return e()}))}),0)},t.prototype.updateRowData=function(e,t){this.valueCache.onDataChanged();var o=this.nodeManager.updateRowData(e,t);return this.commonUpdateRowData([o],t),o},t.prototype.commonUpdateRowData=function(e,t){this.refreshModel({step:n.Constants.STEP_EVERYTHING,rowNodeTransactions:e,rowNodeOrder:t,keepRenderedRows:!0,animate:!0,keepEditingRows:!0});var o={type:n.Events.EVENT_ROW_DATA_UPDATED,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(o)},t.prototype.doRowsToDisplay=function(){this.rowsToDisplay=this.flattenStage.execute({rowNode:this.rootNode})},t.prototype.onRowHeightChanged=function(){this.refreshModel({step:n.Constants.STEP_MAP,keepRenderedRows:!0,keepEditingRows:!0})},t.prototype.resetRowHeights=function(){this.forEachNode((function(e){e.setRowHeight(null),e.detailNode&&e.detailNode.setRowHeight(null)})),this.onRowHeightChanged()},g([Object(n.Autowired)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),g([Object(n.Autowired)("columnController")],t.prototype,"columnController",void 0),g([Object(n.Autowired)("filterManager")],t.prototype,"filterManager",void 0),g([Object(n.Autowired)("$scope")],t.prototype,"$scope",void 0),g([Object(n.Autowired)("selectionController")],t.prototype,"selectionController",void 0),g([Object(n.Autowired)("valueService")],t.prototype,"valueService",void 0),g([Object(n.Autowired)("valueCache")],t.prototype,"valueCache",void 0),g([Object(n.Autowired)("columnApi")],t.prototype,"columnApi",void 0),g([Object(n.Autowired)("gridApi")],t.prototype,"gridApi",void 0),g([Object(n.Autowired)("filterStage")],t.prototype,"filterStage",void 0),g([Object(n.Autowired)("sortStage")],t.prototype,"sortStage",void 0),g([Object(n.Autowired)("flattenStage")],t.prototype,"flattenStage",void 0),g([Object(n.Optional)("groupStage")],t.prototype,"groupStage",void 0),g([Object(n.Optional)("aggregationStage")],t.prototype,"aggregationStage",void 0),g([Object(n.Optional)("pivotStage")],t.prototype,"pivotStage",void 0),g([n.PostConstruct],t.prototype,"init",null),t=g([Object(n.Bean)("rowModel")],t)}(n.BeanStub),p=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),c=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},d=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return p(t,e),t.prototype.execute=function(e){var t=e.rowNode,o=e.changedPath;this.filterService.filter(o),this.selectableService.updateSelectableAfterFiltering(t)},c([Object(n.Autowired)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),c([Object(n.Autowired)("selectableService")],t.prototype,"selectableService",void 0),c([Object(n.Autowired)("filterService")],t.prototype,"filterService",void 0),t=c([Object(n.Bean)("filterStage")],t)}(n.BeanStub),u=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),h=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},f=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return u(t,e),t.prototype.execute=function(e){var t=this.sortController.getSortForRowController(),o=n._.exists(t)&&t.length>0,r=o&&n._.exists(e.rowNodeTransactions)&&this.gridOptionsWrapper.isDeltaSort(),a=r?this.calculateDirtyNodes(e.rowNodeTransactions):null,i=this.columnController.getValueColumns(),l=n._.missingOrEmpty(i);this.sortService.sort(t,o,r,a,e.changedPath,l)},t.prototype.calculateDirtyNodes=function(e){var t={},o=function(e){e&&e.forEach((function(e){return t[e.id]=!0}))};return e.forEach((function(e){o(e.add),o(e.update),o(e.remove)})),t},h([Object(n.Autowired)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),h([Object(n.Autowired)("sortService")],t.prototype,"sortService",void 0),h([Object(n.Autowired)("sortController")],t.prototype,"sortController",void 0),h([Object(n.Autowired)("columnController")],t.prototype,"columnController",void 0),t=h([Object(n.Bean)("sortStage")],t)}(n.BeanStub),m=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),b=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},v=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return m(t,e),t.prototype.execute=function(e){var t=e.rowNode,o=[],r={value:0},a=this.columnController.isPivotMode(),n=a&&t.leafGroup,i=n?[t]:t.childrenAfterSort;return this.recursivelyAddToRowsToDisplay(i,o,r,a,0),!n&&o.length>0&&this.gridOptionsWrapper.isGroupIncludeTotalFooter()&&(this.ensureFooterNodeExists(t),this.addRowNodeToRowsToDisplay(t.sibling,o,r,0)),o},t.prototype.recursivelyAddToRowsToDisplay=function(e,t,o,r,a){if(!n._.missingOrEmpty(e))for(var i=this.gridOptionsWrapper.isGroupSuppressRow(),l=this.gridOptionsWrapper.isGroupHideOpenParents(),g=this.gridOptionsWrapper.isGroupRemoveSingleChildren(),s=!g&&this.gridOptionsWrapper.isGroupRemoveLowestSingleChildren(),p=0;p=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},x=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return y(t,e),t.prototype.init=function(){this.postSortFunc=this.gridOptionsWrapper.getPostSortFunc()},t.prototype.sort=function(e,t,o,r,a,n){var i=this;a.forEachChangedNodeDepthFirst((function(l){if(i.pullDownGroupDataForHideOpenParents(l.childrenAfterFilter,!0),t){var g=o?i.doDeltaSort(l,e,r,a,n):i.doFullSort(l,e);l.childrenAfterSort=g.map((function(e){return e.rowNode}))}else l.childrenAfterSort=l.childrenAfterFilter.slice(0);i.updateChildIndexes(l),i.postSortFunc&&i.postSortFunc(l.childrenAfterSort)})),this.updateGroupDataForHiddenOpenParents(a)},t.prototype.doFullSort=function(e,t){var o=e.childrenAfterFilter.map(this.mapNodeToSortedNode.bind(this));return o.sort(this.compareRowNodes.bind(this,t)),o},t.prototype.mapNodeToSortedNode=function(e,t){return{currentPos:t,rowNode:e}},t.prototype.doDeltaSort=function(e,t,o,r,a){var n=e.childrenAfterSort.filter((function(e){var t=!o[e.id],n=a||r.canSkip(e);return t&&n})).map(this.mapNodeToSortedNode.bind(this)),i={};n.forEach((function(e){return i[e.rowNode.id]=e.rowNode}));var l=e.childrenAfterFilter.filter((function(e){return!i[e.id]})).map(this.mapNodeToSortedNode.bind(this));return l.sort(this.compareRowNodes.bind(this,t)),0===l.length?n:0===n.length?l:this.mergeSortedArrays(t,n,l)},t.prototype.mergeSortedArrays=function(e,t,o){for(var r=[],a=0,n=0;a=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},A=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return C(t,e),t.prototype.postConstruct=function(){this.doingTreeData=this.gridOptionsWrapper.isTreeData()},t.prototype.filter=function(e){var t=this.filterManager.isAnyFilterPresent();this.filterNodes(t,e)},t.prototype.filterNodes=function(e,t){var o=this,r=function(t,r){t.hasChildren()?(t.childrenAfterFilter=e&&!r?t.childrenAfterGroup.filter((function(e){var t=e.childrenAfterFilter&&e.childrenAfterFilter.length>0,r=e.data&&o.filterManager.doesRowPassFilter(e);return t||r})):t.childrenAfterGroup,o.setAllChildrenCount(t)):(t.childrenAfterFilter=t.childrenAfterGroup,t.setAllChildrenCount(null))};if(this.doingTreeDataFiltering()){var a=function(e,t){if(e.childrenAfterGroup)for(var n=0;n=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},R=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return E(t,e),t.prototype.postConstruct=function(){this.rowModel.getType()===n.Constants.ROW_MODEL_TYPE_CLIENT_SIDE&&(this.clientSideRowModel=this.rowModel)},t.prototype.createTransactionForRowData=function(e){if(n._.missing(this.clientSideRowModel))console.error("ag-Grid: ImmutableService only works with ClientSideRowModel");else{var t=this.gridOptionsWrapper.getRowNodeIdFunc();if(t&&!n._.missing(t)){var o={remove:[],update:[],add:[]},r=this.clientSideRowModel.getCopyOfNodesMap(),a=this.gridOptionsWrapper.isSuppressMaintainUnsortedOrder()?null:{};return n._.exists(e)&&e.forEach((function(e,n){var i=t(e),l=r[i];(a&&(a[i]=n),l)?(l.data!==e&&o.update.push(e),r[i]=void 0):o.add.push(e)})),n._.iterateObject(r,(function(e,t){t&&o.remove.push(t.data)})),[o,a]}console.error("ag-Grid: ImmutableService requires getRowNodeId() callback to be implemented, your row data need IDs!")}},O([Object(n.Autowired)("rowModel")],t.prototype,"rowModel",void 0),O([Object(n.Autowired)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),O([n.PostConstruct],t.prototype,"postConstruct",null),t=O([Object(n.Bean)("immutableService")],t)}(n.BeanStub),S={moduleName:n.ModuleNames.ClientSideRowModelModule,beans:[d,f,v,x,A,R],rowModels:{clientSide:s}}},function(e,t,o){"use strict";o.r(t),o.d(t,"CsvExportModule",(function(){return A})),o.d(t,"BaseCreator",(function(){return u})),o.d(t,"CsvCreator",(function(){return h})),o.d(t,"Downloader",(function(){return m})),o.d(t,"GridSerializer",(function(){return s})),o.d(t,"RowType",(function(){return a})),o.d(t,"BaseGridSerializingSession",(function(){return g})),o.d(t,"ZipContainer",(function(){return k})),o.d(t,"XmlFactory",(function(){return y}));var r,a,n=o(3),i=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),l=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},g=function(){function e(e){var t=e.columnController,o=e.valueService,r=e.gridOptionsWrapper,a=e.processCellCallback,n=e.processHeaderCallback,i=e.processGroupHeaderCallback,l=e.processRowGroupCallback;this.columnController=t,this.valueService=o,this.gridOptionsWrapper=r,this.processCellCallback=a,this.processHeaderCallback=n,this.processGroupHeaderCallback=i,this.processRowGroupCallback=l}return e.prototype.prepare=function(e){this.firstGroupColumn=n._.find(e,(function(e){return!!e.getColDef().showRowGroup}))},e.prototype.extractHeaderValue=function(e){var t=this.getHeaderName(this.processHeaderCallback,e);return null!=t?t:""},e.prototype.extractRowCellValue=function(e,t,o,r){var a;a=r&&r.group&&(e===this.firstGroupColumn||0===t&&this.gridOptionsWrapper.isGroupUseEntireRow(this.columnController.isPivotMode()))?this.createValueForGroupNode(r):this.valueService.getValue(e,r);var n=this.processCell(r,e,a,this.processCellCallback,o);return null!=n?n:""},e.prototype.getHeaderName=function(e,t){return e?e({column:t,api:this.gridOptionsWrapper.getApi(),columnApi:this.gridOptionsWrapper.getColumnApi(),context:this.gridOptionsWrapper.getContext()}):this.columnController.getDisplayNameForColumn(t,"csv",!0)},e.prototype.createValueForGroupNode=function(e){if(this.processRowGroupCallback)return this.processRowGroupCallback({node:e,api:this.gridOptionsWrapper.getApi(),columnApi:this.gridOptionsWrapper.getColumnApi(),context:this.gridOptionsWrapper.getContext()});for(var t=[e.key];e.parent;)e=e.parent,t.push(e.key);return t.reverse().join(" -> ")},e.prototype.processCell=function(e,t,o,r,a){return r?r({column:t,node:e,value:o,api:this.gridOptionsWrapper.getApi(),columnApi:this.gridOptionsWrapper.getColumnApi(),context:this.gridOptionsWrapper.getContext(),type:a}):o},e}(),s=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return i(t,e),t.prototype.serialize=function(e,t){void 0===t&&(t={});var o=t.shouldRowBeSkipped||function(){return!1},r=this.gridOptionsWrapper.getApi(),a=this.gridOptionsWrapper.getColumnApi(),i=this.gridOptionsWrapper.isGroupRemoveSingleChildren(),l=this.gridOptionsWrapper.isGroupRemoveLowestSingleChildren(),g=this.gridOptionsWrapper.getContext(),s=this.columnController.isPivotMode(),p=this.rowModel.getType()===n.Constants.ROW_MODEL_TYPE_CLIENT_SIDE,c=!p&&t.onlySelected,d=[];if(d=n._.existsAndNotEmpty(t.columnKeys)?this.columnController.getGridColumns(t.columnKeys):t.allColumns&&!s?(d=this.gridOptionsWrapper.isTreeData()?this.columnController.getGridColumns([n.Constants.GROUP_AUTO_COLUMN_ID]):[]).concat(this.columnController.getAllPrimaryColumns()||[]):this.columnController.getAllDisplayedColumns(),t.customHeader&&e.addCustomContent(t.customHeader),e.prepare(d),t.columnGroups){var u=new n.GroupInstanceIdCreator,h=this.displayedGroupCreator.createDisplayedGroups(d,this.columnController.getGridBalancedTree(),u,null);this.recursivelyAddHeaderGroups(h,e,t.processGroupHeaderCallback)}if(!t.skipHeader){var f=e.onNewHeaderRow();d.forEach((function(e,t){f.onColumn(e,t,void 0)}))}(this.pinnedRowModel.forEachPinnedTopRow(m),s)?this.rowModel.forEachPivotNode?this.rowModel.forEachPivotNode(m):this.rowModel.forEachNode(m):t.onlySelectedAllPages||c?this.selectionController.getSelectedNodes().forEach((function(e){m(e)})):p?this.rowModel.forEachNodeAfterFilterAndSort(m):this.rowModel.forEachNode(m);function m(n){var s=l&&n.leafGroup,p=1===n.allChildrenCount&&(i||s);if((!n.group||!t.skipGroups&&!p)&&((!t.skipFooters||!n.footer)&&(!t.onlySelected||n.isSelected())&&(!t.skipPinnedTop||"top"!==n.rowPinned)&&(!t.skipPinnedBottom||"bottom"!==n.rowPinned)&&(!(-1===n.level)||n.leafGroup)&&!o({node:n,api:r,context:g}))){var c=e.onNewBodyRow();if(d.forEach((function(e,t){c.onColumn(e,t,n)})),t.getCustomContentBelowRow){var u=t.getCustomContentBelowRow({node:n,api:r,columnApi:a,context:g});u&&e.addCustomContent(u)}}}return this.pinnedRowModel.forEachPinnedBottomRow(m),t.customFooter&&e.addCustomContent(t.customFooter),e.parse()},t.prototype.recursivelyAddHeaderGroups=function(e,t,o){var r=[];e.forEach((function(e){var t=e;t.getChildren&&t.getChildren().forEach((function(e){return r.push(e)}))})),e.length>0&&e[0]instanceof n.ColumnGroup&&this.doAddHeaderHeader(t,e,o),r&&r.length>0&&this.recursivelyAddHeaderGroups(r,t,o)},t.prototype.doAddHeaderHeader=function(e,t,o){var r=this,a=e.onNewHeaderGroupingRow(),n=0;t.forEach((function(e){var t,i=e;t=o?o({columnGroup:i,api:r.gridOptionsWrapper.getApi(),columnApi:r.gridOptionsWrapper.getColumnApi(),context:r.gridOptionsWrapper.getContext()}):r.columnController.getDisplayNameForColumnGroup(i,"header"),a.onColumn(t||"",n++,i.getLeafColumns().length-1)}))},l([Object(n.Autowired)("displayedGroupCreator")],t.prototype,"displayedGroupCreator",void 0),l([Object(n.Autowired)("columnController")],t.prototype,"columnController",void 0),l([Object(n.Autowired)("rowModel")],t.prototype,"rowModel",void 0),l([Object(n.Autowired)("pinnedRowModel")],t.prototype,"pinnedRowModel",void 0),l([Object(n.Autowired)("selectionController")],t.prototype,"selectionController",void 0),l([Object(n.Autowired)("columnFactory")],t.prototype,"columnFactory",void 0),l([Object(n.Autowired)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),t=l([Object(n.Bean)("gridSerializer")],t)}(n.BeanStub);!function(e){e[e.HEADER_GROUPING=0]="HEADER_GROUPING",e[e.HEADER=1]="HEADER",e[e.BODY=2]="BODY"}(a||(a={}));var p=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),c=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},d=function(e){function t(t){var o=e.call(this,t)||this;o.isFirstLine=!0,o.result="";var r=t.suppressQuotes,a=t.columnSeparator;return o.suppressQuotes=r,o.columnSeparator=a,o}return p(t,e),t.prototype.addCustomContent=function(e){var t=this;e&&("string"==typeof e?(/^\s*\n/.test(e)||this.beginNewLine(),e=e.replace(/\r?\n/g,"\r\n"),this.result+=e):e.forEach((function(e){t.beginNewLine(),e.forEach((function(e,o){0!==o&&(t.result+=t.columnSeparator),t.result+=t.putInQuotes(e.data.value||""),e.mergeAcross&&t.appendEmptyCells(e.mergeAcross)}))})))},t.prototype.onNewHeaderGroupingRow=function(){return this.beginNewLine(),{onColumn:this.onNewHeaderGroupingRowColumn.bind(this)}},t.prototype.onNewHeaderGroupingRowColumn=function(e,t,o){0!=t&&(this.result+=this.columnSeparator),this.result+=this.putInQuotes(e),this.appendEmptyCells(o)},t.prototype.appendEmptyCells=function(e){for(var t=1;t<=e;t++)this.result+=this.columnSeparator+this.putInQuotes("")},t.prototype.onNewHeaderRow=function(){return this.beginNewLine(),{onColumn:this.onNewHeaderRowColumn.bind(this)}},t.prototype.onNewHeaderRowColumn=function(e,t,o){0!=t&&(this.result+=this.columnSeparator),this.result+=this.putInQuotes(this.extractHeaderValue(e))},t.prototype.onNewBodyRow=function(){return this.beginNewLine(),{onColumn:this.onNewBodyRowColumn.bind(this)}},t.prototype.onNewBodyRowColumn=function(e,t,o){0!=t&&(this.result+=this.columnSeparator),this.result+=this.putInQuotes(this.extractRowCellValue(e,t,n.Constants.EXPORT_TYPE_CSV,o))},t.prototype.putInQuotes=function(e){return this.suppressQuotes?e:null==e?'""':("string"==typeof e?t=e:"function"==typeof e.toString?t=e.toString():(console.warn("unknown value type during csv conversion"),t=""),'"'+t.replace(/"/g,'""')+'"');var t},t.prototype.parse=function(){return this.result},t.prototype.beginNewLine=function(){this.isFirstLine||(this.result+="\r\n"),this.isFirstLine=!1},t}(g),u=function(){function e(){}return e.prototype.setBeans=function(e){this.beans=e},e.prototype.export=function(e){if(this.isExportSuppressed())return console.warn("ag-grid: Export cancelled. Export is not allowed as per your configuration."),"";var t=this.getMergedParamsAndData(e),o=t.mergedParams,r=t.data,a=o&&o.fileName&&0!==o.fileName.length?o.fileName:this.getDefaultFileName();return-1===a.indexOf(".")&&(a=a+"."+this.getDefaultFileExtension()),this.beans.downloader.download(a,this.packageFile(r)),r},e.prototype.getData=function(e){return this.getMergedParamsAndData(e).data},e.prototype.getMergedParamsAndData=function(e){var t=this.mergeDefaultParams(e);return{mergedParams:t,data:this.beans.gridSerializer.serialize(this.createSerializingSession(t),t)}},e.prototype.mergeDefaultParams=function(e){var t=this.beans.gridOptionsWrapper.getDefaultExportParams(),o={};return n._.assign(o,t),n._.assign(o,e),o},e.prototype.packageFile=function(e){return new Blob(["\ufeff",e],{type:window.navigator.msSaveOrOpenBlob?this.getMimeType():"octet/stream"})},e}(),h=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return p(t,e),t.prototype.postConstruct=function(){this.setBeans({downloader:this.downloader,gridSerializer:this.gridSerializer,gridOptionsWrapper:this.gridOptionsWrapper})},t.prototype.exportDataAsCsv=function(e){return this.export(e)},t.prototype.getDataAsCsv=function(e){return this.getData(e)},t.prototype.getMimeType=function(){return"text/csv;charset=utf-8;"},t.prototype.getDefaultFileName=function(){return"export.csv"},t.prototype.getDefaultFileExtension=function(){return"csv"},t.prototype.createSerializingSession=function(e){var t=this.columnController,o=this.valueService,r=this.gridOptionsWrapper,a=e.processCellCallback,n=e.processHeaderCallback,i=e.processGroupHeaderCallback,l=e.processRowGroupCallback,g=e.suppressQuotes,s=e.columnSeparator;return new d({columnController:t,valueService:o,gridOptionsWrapper:r,processCellCallback:a||void 0,processHeaderCallback:n||void 0,processGroupHeaderCallback:i||void 0,processRowGroupCallback:l||void 0,suppressQuotes:g||!1,columnSeparator:s||","})},t.prototype.isExportSuppressed=function(){return this.gridOptionsWrapper.isSuppressCsvExport()},c([Object(n.Autowired)("columnController")],t.prototype,"columnController",void 0),c([Object(n.Autowired)("valueService")],t.prototype,"valueService",void 0),c([Object(n.Autowired)("downloader")],t.prototype,"downloader",void 0),c([Object(n.Autowired)("gridSerializer")],t.prototype,"gridSerializer",void 0),c([Object(n.Autowired)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),c([n.PostConstruct],t.prototype,"postConstruct",null),t=c([Object(n.Bean)("csvCreator")],t)}(u),f=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},m=function(){function e(){}return e.prototype.download=function(e,t){if(window.navigator.msSaveOrOpenBlob)window.navigator.msSaveOrOpenBlob(t,e);else{var o=document.createElement("a"),r=window.URL.createObjectURL(t);o.setAttribute("href",r),o.setAttribute("download",e),o.style.display="none",document.body.appendChild(o),o.dispatchEvent(new MouseEvent("click",{bubbles:!1,cancelable:!0,view:window})),document.body.removeChild(o),window.setTimeout((function(){window.URL.revokeObjectURL(r)}),0)}},e=f([Object(n.Bean)("downloader")],e)}(),b=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),v=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},y=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return b(t,e),t.prototype.createHeader=function(e){void 0===e&&(e={});var t=["version"];return e.version||(e.version="1.0"),e.encoding&&t.push("encoding"),e.standalone&&t.push("standalone"),""},t.prototype.createXml=function(e,t){var o=this,r="";e.properties&&(e.properties.prefixedAttributes&&e.properties.prefixedAttributes.forEach((function(e){Object.keys(e.map).forEach((function(a){r+=o.returnAttributeIfPopulated(e.prefix+a,e.map[a],t)}))})),e.properties.rawMap&&Object.keys(e.properties.rawMap).forEach((function(a){r+=o.returnAttributeIfPopulated(a,e.properties.rawMap[a],t)})));var a="<"+e.name+r;return e.children||null!=e.textNode?null!=e.textNode?a+">"+e.textNode+"\r\n":(a+=">\r\n",e.children&&e.children.forEach((function(e){a+=o.createXml(e,t)})),a+"\r\n"):a+"/>\r\n"},t.prototype.returnAttributeIfPopulated=function(e,t,o){if(!t&&""!==t&&0!==t)return"";var r=t;return"boolean"==typeof t&&o&&(r=o(t))," "+e+'="'+r+'"'},t=v([Object(n.Bean)("xmlFactory")],t)}(n.BeanStub),w=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),x=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},C=[0,1996959894,-301047508,-1727442502,124634137,1886057615,-379345611,-1637575261,249268274,2044508324,-522852066,-1747789432,162941995,2125561021,-407360249,-1866523247,498536548,1789927666,-205950648,-2067906082,450548861,1843258603,-187386543,-2083289657,325883990,1684777152,-43845254,-1973040660,335633487,1661365465,-99664541,-1928851979,997073096,1281953886,-715111964,-1570279054,1006888145,1258607687,-770865667,-1526024853,901097722,1119000684,-608450090,-1396901568,853044451,1172266101,-589951537,-1412350631,651767980,1373503546,-925412992,-1076862698,565507253,1454621731,-809855591,-1195530993,671266974,1594198024,-972236366,-1324619484,795835527,1483230225,-1050600021,-1234817731,1994146192,31158534,-1731059524,-271249366,1907459465,112637215,-1614814043,-390540237,2013776290,251722036,-1777751922,-519137256,2137656763,141376813,-1855689577,-429695999,1802195444,476864866,-2056965928,-228458418,1812370925,453092731,-2113342271,-183516073,1706088902,314042704,-1950435094,-54949764,1658658271,366619977,-1932296973,-69972891,1303535960,984961486,-1547960204,-725929758,1256170817,1037604311,-1529756563,-740887301,1131014506,879679996,-1385723834,-631195440,1141124467,855842277,-1442165665,-586318647,1342533948,654459306,-1106571248,-921952122,1466479909,544179635,-1184443383,-832445281,1591671054,702138776,-1328506846,-942167884,1504918807,783551873,-1212326853,-1061524307,-306674912,-1698712650,62317068,1957810842,-355121351,-1647151185,81470997,1943803523,-480048366,-1805370492,225274430,2053790376,-468791541,-1828061283,167816743,2097651377,-267414716,-2029476910,503444072,1762050814,-144550051,-2140837941,426522225,1852507879,-19653770,-1982649376,282753626,1742555852,-105259153,-1900089351,397917763,1622183637,-690576408,-1580100738,953729732,1340076626,-776247311,-1497606297,1068828381,1219638859,-670225446,-1358292148,906185462,1090812512,-547295293,-1469587627,829329135,1181335161,-882789492,-1134132454,628085408,1382605366,-871598187,-1156888829,570562233,1426400815,-977650754,-1296233688,733239954,1555261956,-1026031705,-1244606671,752459403,1541320221,-1687895376,-328994266,1969922972,40735498,-1677130071,-351390145,1913087877,83908371,-1782625662,-491226604,2075208622,213261112,-1831694693,-438977011,2094854071,198958881,-2032938284,-237706686,1759359992,534414190,-2118248755,-155638181,1873836001,414664567,-2012718362,-15766928,1711684554,285281116,-1889165569,-127750551,1634467795,376229701,-1609899400,-686959890,1308918612,956543938,-1486412191,-799009033,1231636301,1047427035,-1362007478,-640263460,1088359270,936918e3,-1447252397,-558129467,1202900863,817233897,-1111625188,-893730166,1404277552,615818150,-1160759803,-841546093,1423857449,601450431,-1285129682,-1000256840,1567103746,711928724,-1274298825,-1022587231,1510334235,755167117],k=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.folders=[],t.files=[],t.addFolder=function(e){t.folders.push({path:e,created:new Date})},t}return w(t,e),t.prototype.addFolders=function(e){e.forEach(this.addFolder)},t.prototype.addFile=function(e,t){this.files.push({path:e,created:new Date,content:t})},t.prototype.clearStream=function(){this.folders=[],this.files=[]},t.prototype.getContent=function(e){void 0===e&&(e="application/zip");var t=this.buildFileStream(),o=this.buildUint8Array(t);return this.clearStream(),new Blob([o],{type:e})},t.prototype.buildFileStream=function(e){void 0===e&&(e="");for(var t=this.folders.concat(this.files),o=t.length,r="",a=0,n=0,i=0,l=t;i>>8^C[255&(t^o)];return-1^t},t.prototype.convertTime=function(e){var t=e.getHours();return t<<=6,t|=e.getMinutes(),t<<=5,t|=e.getSeconds()/2},t.prototype.convertDate=function(e){var t=e.getFullYear()-1980;return t<<=4,t|=e.getMonth()+1,t<<=5,t|=e.getDate()},t=x([Object(n.Bean)("zipContainer")],t)}(n.BeanStub),A={moduleName:n.ModuleNames.CsvExportModule,beans:[h,m,y,s,k]}},function(e,t,o){"use strict";o.r(t),o.d(t,"InfiniteRowModelModule",(function(){return f}));var r,a=o(3),n=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),i=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},l=function(e){function t(t,o){var r=e.call(this,t,o)||this;return r.cacheParams=o,r}return n(t,e),t.prototype.getDisplayIndexStart=function(){return this.getBlockNumber()*this.cacheParams.blockSize},t.prototype.getDisplayIndexEnd=function(){return this.getDisplayIndexStart()+this.cacheParams.blockSize},t.prototype.createBlankRowNode=function(t){var o=e.prototype.createBlankRowNode.call(this,t);return o.uiLevel=0,this.setIndexAndTopOnRowNode(o,t),o},t.prototype.setDataAndId=function(e,t,o){a._.exists(t)?e.setDataAndId(t,o.toString()):e.setDataAndId(void 0,void 0)},t.prototype.setRowNode=function(t,o){e.prototype.setRowNode.call(this,t,o),this.setIndexAndTopOnRowNode(o,t)},t.prototype.init=function(){e.prototype.init.call(this,{context:this.getContext(),rowRenderer:this.rowRenderer})},t.prototype.getNodeIdPrefix=function(){return null},t.prototype.getRow=function(e){return this.getRowUsingLocalIndex(e)},t.prototype.setIndexAndTopOnRowNode=function(e,t){e.setRowIndex(t),e.rowTop=this.cacheParams.rowHeight*t},t.prototype.loadFromDatasource=function(){var e=this,t={startRow:this.getStartRow(),endRow:this.getEndRow(),successCallback:this.pageLoaded.bind(this,this.getVersion()),failCallback:this.pageLoadFailed.bind(this),sortModel:this.cacheParams.sortModel,filterModel:this.cacheParams.filterModel,context:this.gridOptionsWrapper.getContext()};a._.missing(this.cacheParams.datasource.getRows)?console.warn("ag-Grid: datasource is missing getRows method"):window.setTimeout((function(){e.cacheParams.datasource.getRows(t)}),0)},i([Object(a.Autowired)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),i([Object(a.Autowired)("rowRenderer")],t.prototype,"rowRenderer",void 0),i([a.PostConstruct],t.prototype,"init",null),t}(a.RowNodeBlock),g=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e,t){return function(o,r){t(o,r,e)}},c=function(e){function t(t){return e.call(this,t)||this}return g(t,e),t.prototype.setBeans=function(e){this.logger=e.create("InfiniteCache")},t.prototype.moveItemsDown=function(e,t,o){for(var r=e.getStartRow(),a=t+o,n=e.getEndRow()-1;n>=r;n--)if(!(n=r&&l=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},h=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return d(t,e),t.prototype.getRowBounds=function(e){return{rowHeight:this.rowHeight,rowTop:this.rowHeight*e}},t.prototype.ensureRowHeightsValid=function(e,t,o,r){return!1},t.prototype.init=function(){var e=this;this.gridOptionsWrapper.isRowModelInfinite()&&(this.rowHeight=this.gridOptionsWrapper.getRowHeightAsNumber(),this.addEventListeners(),this.addDestroyFunc((function(){return e.destroyCache()})))},t.prototype.start=function(){this.setDatasource(this.gridOptionsWrapper.getDatasource())},t.prototype.destroyDatasource=function(){this.datasource&&(this.getContext().destroyBean(this.datasource),this.rowRenderer.datasourceChanged(),this.datasource=null)},t.prototype.isLastRowFound=function(){return!!this.infiniteCache&&this.infiniteCache.isMaxRowFound()},t.prototype.addEventListeners=function(){this.addManagedListener(this.eventService,a.Events.EVENT_FILTER_CHANGED,this.onFilterChanged.bind(this)),this.addManagedListener(this.eventService,a.Events.EVENT_SORT_CHANGED,this.onSortChanged.bind(this)),this.addManagedListener(this.eventService,a.Events.EVENT_COLUMN_EVERYTHING_CHANGED,this.onColumnEverything.bind(this))},t.prototype.onFilterChanged=function(){this.reset()},t.prototype.onSortChanged=function(){this.reset()},t.prototype.onColumnEverything=function(){(!this.cacheParams||this.isSortModelDifferent())&&this.reset()},t.prototype.isSortModelDifferent=function(){return!a._.jsonEquals(this.cacheParams.sortModel,this.sortController.getSortModel())},t.prototype.getType=function(){return a.Constants.ROW_MODEL_TYPE_INFINITE},t.prototype.setDatasource=function(e){this.destroyDatasource(),this.datasource=e,e&&(this.checkForDeprecated(),this.reset())},t.prototype.checkForDeprecated=function(){var e=this.datasource;a._.exists(e.maxConcurrentRequests)&&console.error("ag-Grid: since version 5.1.x, maxConcurrentRequests is replaced with grid property maxConcurrentDatasourceRequests"),a._.exists(e.maxPagesInCache)&&console.error("ag-Grid: since version 5.1.x, maxPagesInCache is replaced with grid property maxPagesInPaginationCache"),a._.exists(e.overflowSize)&&console.error("ag-Grid: since version 5.1.x, overflowSize is replaced with grid property paginationOverflowSize"),a._.exists(e.blockSize)&&console.error("ag-Grid: since version 5.1.x, pageSize/blockSize is replaced with grid property infinitePageSize")},t.prototype.isEmpty=function(){return a._.missing(this.infiniteCache)},t.prototype.isRowsToRender=function(){return a._.exists(this.infiniteCache)},t.prototype.getNodesInRangeForSelection=function(e,t){return this.infiniteCache?this.infiniteCache.getRowNodesInRange(e,t):[]},t.prototype.reset=function(){if(!a._.missing(this.datasource)){a._.exists(this.gridOptionsWrapper.getRowNodeIdFunc())||this.selectionController.reset(),this.resetCache();var e=this.createModelUpdatedEvent();this.eventService.dispatchEvent(e)}},t.prototype.createModelUpdatedEvent=function(){return{type:a.Events.EVENT_MODEL_UPDATED,api:this.gridApi,columnApi:this.columnApi,newPage:!1,newData:!1,keepRenderedRows:!1,animate:!1}},t.prototype.resetCache=function(){this.destroyCache();var e=this.gridOptionsWrapper.getMaxConcurrentDatasourceRequests(),t=this.gridOptionsWrapper.getBlockLoadDebounceMillis();this.rowNodeBlockLoader=new a.RowNodeBlockLoader(e,t),this.getContext().createBean(this.rowNodeBlockLoader),this.cacheParams={datasource:this.datasource,filterModel:this.filterManager.getFilterModel(),sortModel:this.sortController.getSortModel(),rowNodeBlockLoader:this.rowNodeBlockLoader,maxConcurrentRequests:e,overflowSize:this.gridOptionsWrapper.getCacheOverflowSize(),initialRowCount:this.gridOptionsWrapper.getInfiniteInitialRowCount(),maxBlocksInCache:this.gridOptionsWrapper.getMaxBlocksInCache(),blockSize:this.gridOptionsWrapper.getCacheBlockSize(),rowHeight:this.gridOptionsWrapper.getRowHeightAsNumber(),lastAccessedSequence:new a.NumberSequence},this.cacheParams.maxConcurrentRequests&&this.cacheParams.maxConcurrentRequests>=1||(this.cacheParams.maxConcurrentRequests=2),this.cacheParams.blockSize&&this.cacheParams.blockSize>=1||(this.cacheParams.blockSize=100),this.cacheParams.initialRowCount>=1||(this.cacheParams.initialRowCount=1),this.cacheParams.overflowSize>=1||(this.cacheParams.overflowSize=1),this.infiniteCache=new c(this.cacheParams),this.getContext().createBean(this.infiniteCache),this.infiniteCache.addEventListener(a.RowNodeCache.EVENT_CACHE_UPDATED,this.onCacheUpdated.bind(this))},t.prototype.destroyCache=function(){this.infiniteCache&&(this.infiniteCache=this.destroyBean(this.infiniteCache)),this.rowNodeBlockLoader&&(this.rowNodeBlockLoader=this.destroyBean(this.rowNodeBlockLoader))},t.prototype.onCacheUpdated=function(){var e=this.createModelUpdatedEvent();this.eventService.dispatchEvent(e)},t.prototype.getRow=function(e){return this.infiniteCache?this.infiniteCache.getRow(e):null},t.prototype.getRowNode=function(e){var t=null;return this.forEachNode((function(o){o.id===e&&(t=o)})),t},t.prototype.forEachNode=function(e){this.infiniteCache&&this.infiniteCache.forEachNodeDeep(e,new a.NumberSequence)},t.prototype.getCurrentPageHeight=function(){return this.getRowCount()*this.rowHeight},t.prototype.getTopLevelRowCount=function(){return this.getRowCount()},t.prototype.getTopLevelRowDisplayedIndex=function(e){return e},t.prototype.getRowIndexAtPixel=function(e){if(0!==this.rowHeight){var t=Math.floor(e/this.rowHeight),o=this.getRowCount()-1;return t>o?o:t}return 0},t.prototype.getRowCount=function(){return this.infiniteCache?this.infiniteCache.getVirtualRowCount():0},t.prototype.updateRowData=function(e){a._.exists(e.remove)||a._.exists(e.update)?console.warn("ag-Grid: updateRowData for InfiniteRowModel does not support remove or update, only add"):a._.missing(e.addIndex)?console.warn("ag-Grid: updateRowData for InfiniteRowModel requires add and addIndex to be set"):this.infiniteCache&&this.infiniteCache.insertItemsAtIndex(e.addIndex,e.add)},t.prototype.isRowPresent=function(e){return!1},t.prototype.refreshCache=function(){this.infiniteCache&&this.infiniteCache.refreshCache()},t.prototype.purgeCache=function(){this.infiniteCache&&this.infiniteCache.purgeCache()},t.prototype.getVirtualRowCount=function(){return this.infiniteCache?this.infiniteCache.getVirtualRowCount():null},t.prototype.isMaxRowFound=function(){if(this.infiniteCache)return this.infiniteCache.isMaxRowFound()},t.prototype.setVirtualRowCount=function(e,t){this.infiniteCache&&this.infiniteCache.setVirtualRowCount(e,t)},t.prototype.getBlockState=function(){return this.rowNodeBlockLoader?this.rowNodeBlockLoader.getBlockState():null},u([Object(a.Autowired)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),u([Object(a.Autowired)("filterManager")],t.prototype,"filterManager",void 0),u([Object(a.Autowired)("sortController")],t.prototype,"sortController",void 0),u([Object(a.Autowired)("selectionController")],t.prototype,"selectionController",void 0),u([Object(a.Autowired)("gridApi")],t.prototype,"gridApi",void 0),u([Object(a.Autowired)("columnApi")],t.prototype,"columnApi",void 0),u([Object(a.Autowired)("rowRenderer")],t.prototype,"rowRenderer",void 0),u([a.PostConstruct],t.prototype,"init",null),u([a.PreDestroy],t.prototype,"destroyDatasource",null),t=u([Object(a.Bean)("rowModel")],t)}(a.BeanStub),f={moduleName:a.ModuleNames.InfiniteRowModelModule,rowModels:{infinite:h}}},function(e,t,o){"use strict";o.d(t,"a",(function(){return a}));var r=function(){for(var e=0,t=0,o=arguments.length;t>>=8;return o}function s(e){return"number"!=typeof e?"":p(Math.round(100*e)/100)}function p(e){return"number"!=typeof e?"":e.toString().replace(/(\d)(?=(\d{3})+(?!\d))/g,"$1,")}function c(e){return null==e?null:e.reduce((function(e,t){return e+t}),0)}o.r(t),o.d(t,"padStart",(function(){return r})),o.d(t,"createArrayOfNumbers",(function(){return a})),o.d(t,"isNumeric",(function(){return n})),o.d(t,"getMaxSafeInteger",(function(){return i})),o.d(t,"cleanNumber",(function(){return l})),o.d(t,"decToHex",(function(){return g})),o.d(t,"formatNumberTwoDecimalPlacesAndCommas",(function(){return s})),o.d(t,"formatNumberCommas",(function(){return p})),o.d(t,"sum",(function(){return c}))},function(e,t,o){"use strict";o.d(t,"a",(function(){return a}));var r=o(0),a=function(){function e(){this.existingKeys={}}return e.prototype.addExistingKeys=function(e){for(var t=0;t=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},m=function(e,t){return function(o,r){t(o,r,e)}},b=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.primaryHeaderRowCount=0,t.secondaryHeaderRowCount=0,t.secondaryColumnsPresent=!1,t.gridHeaderRowCount=0,t.displayedLeftColumns=[],t.displayedRightColumns=[],t.displayedCenterColumns=[],t.allDisplayedColumns=[],t.allDisplayedVirtualColumns=[],t.allDisplayedCenterVirtualColumns=[],t.rowGroupColumns=[],t.valueColumns=[],t.pivotColumns=[],t.ready=!1,t.autoGroupsNeedBuilding=!1,t.forceRecreateAutoGroups=!1,t.pivotMode=!1,t.bodyWidth=0,t.leftWidth=0,t.rightWidth=0,t.bodyWidthDirty=!0,t.flexActive=!1,t}return h(t,e),t.prototype.init=function(){this.suppressColumnVirtualisation=this.gridOptionsWrapper.isSuppressColumnVirtualisation();var e=this.gridOptionsWrapper.isPivotMode();this.isPivotSettingAllowed(e)&&(this.pivotMode=e),this.usingTreeData=this.gridOptionsWrapper.isTreeData(),this.addManagedListener(this.gridOptionsWrapper,"autoGroupColumnDef",this.onAutoGroupColumnDefChanged.bind(this))},t.prototype.onAutoGroupColumnDefChanged=function(){this.autoGroupsNeedBuilding=!0,this.forceRecreateAutoGroups=!0,this.updateGridColumns(),this.updateDisplayedColumns("gridOptionsChanged")},t.prototype.setColumnDefs=function(e,t){void 0===t&&(t="api");var o=!!this.columnDefs;this.columnDefs=e,this.valueCache.expire(),this.autoGroupsNeedBuilding=!0;var r=this.primaryColumns,a=this.columnFactory.createColumnTree(e,!0,r);this.primaryColumnTree=a.columnTree,this.primaryHeaderRowCount=a.treeDept+1,this.primaryColumns=this.getColumnsFromTree(this.primaryColumnTree),this.extractRowGroupColumns(t,r),this.extractPivotColumns(t,r),this.createValueColumns(t,r),this.ready=!0,this.updateGridColumns(),this.updateDisplayedColumns(t),this.checkDisplayedVirtualColumns(),this.gridOptionsWrapper.isImmutableColumns()&&o&&this.resetColumnState(!0,t);var n={type:i.a.EVENT_COLUMN_EVERYTHING_CHANGED,api:this.gridApi,columnApi:this.columnApi,source:t};this.eventService.dispatchEvent(n);var l={type:i.a.EVENT_NEW_COLUMNS_LOADED,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(l),this.flexActive=this.getDisplayedCenterColumns().some((function(e){return!!e.getFlex()}))},t.prototype.isAutoRowHeightActive=function(){return this.autoRowHeightColumns&&this.autoRowHeightColumns.length>0},t.prototype.getAllAutoRowHeightCols=function(){return this.autoRowHeightColumns},t.prototype.setVirtualViewportLeftAndRight=function(){this.gridOptionsWrapper.isEnableRtl()?(this.viewportLeft=this.bodyWidth-this.scrollPosition-this.scrollWidth,this.viewportRight=this.bodyWidth-this.scrollPosition):(this.viewportLeft=this.scrollPosition,this.viewportRight=this.scrollWidth+this.scrollPosition)},t.prototype.getDisplayedColumnsStartingAt=function(e){for(var t=e,o=[];null!=t;)o.push(t),t=this.getDisplayedColAfter(t);return o},t.prototype.checkDisplayedVirtualColumns=function(){if(null!=this.displayedCenterColumns){var e=this.allDisplayedVirtualColumns.map((function(e){return e.getId()})).join("#");if(this.updateVirtualSets(),e!==this.allDisplayedVirtualColumns.map((function(e){return e.getId()})).join("#")){var t={type:i.a.EVENT_VIRTUAL_COLUMNS_CHANGED,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(t)}}},t.prototype.setVirtualViewportPosition=function(e,t){(e!==this.scrollWidth||t!==this.scrollPosition||this.bodyWidthDirty)&&(this.scrollWidth=e,this.scrollPosition=t,this.bodyWidthDirty=!0,this.setVirtualViewportLeftAndRight(),this.ready&&this.checkDisplayedVirtualColumns())},t.prototype.isPivotMode=function(){return this.pivotMode},t.prototype.isPivotSettingAllowed=function(e){return!e||!this.gridOptionsWrapper.isTreeData()||(console.warn("ag-Grid: Pivot mode not available in conjunction Tree Data i.e. 'gridOptions.treeData: true'"),!1)},t.prototype.setPivotMode=function(e,t){if(void 0===t&&(t="api"),e!==this.pivotMode&&this.isPivotSettingAllowed(this.pivotMode)){this.pivotMode=e,this.autoGroupsNeedBuilding=!0,this.updateGridColumns(),this.updateDisplayedColumns(t);var o={type:i.a.EVENT_COLUMN_PIVOT_MODE_CHANGED,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(o)}},t.prototype.getSecondaryPivotColumn=function(e,t){if(!this.secondaryColumnsPresent||!this.secondaryColumns)return null;var o=this.getPrimaryColumn(t),r=null;return this.secondaryColumns.forEach((function(t){var a=t.getColDef().pivotKeys,n=t.getColDef().pivotValueColumn;Object(d.areEqual)(a,e)&&n===o&&(r=t)})),r},t.prototype.setBeans=function(e){this.logger=e.create("ColumnController")},t.prototype.setFirstRightAndLastLeftPinned=function(e){var t,o;this.gridOptionsWrapper.isEnableRtl()?(t=this.displayedLeftColumns?this.displayedLeftColumns[0]:null,o=this.displayedRightColumns?u.f.last(this.displayedRightColumns):null):(t=this.displayedLeftColumns?u.f.last(this.displayedLeftColumns):null,o=this.displayedRightColumns?this.displayedRightColumns[0]:null),this.gridColumns.forEach((function(r){r.setLastLeftPinned(r===t,e),r.setFirstRightPinned(r===o,e)}))},t.prototype.autoSizeColumns=function(e,t,o){var r=this;void 0===o&&(o="api"),this.animationFrameService.flushAllFrames();var a=[],n=-1;for(null==t&&(t=this.gridOptionsWrapper.isSkipHeaderOnAutoSize());0!==n;)n=0,this.actionOnGridColumns(e,(function(e){if(a.indexOf(e)>=0)return!1;var i=r.autoWidthCalculator.getPreferredWidthForColumn(e,t);if(i>0){var l=r.normaliseColumnWidth(e,i);e.setActualWidth(l,o),a.push(e),n++}return!0}),o);if(a.length){var l={type:i.a.EVENT_COLUMN_RESIZED,columns:a,column:1===a.length?a[0]:null,finished:!0,api:this.gridApi,columnApi:this.columnApi,source:"autosizeColumns"};this.eventService.dispatchEvent(l)}},t.prototype.autoSizeColumn=function(e,t,o){void 0===o&&(o="api"),e&&this.autoSizeColumns([e],t,o)},t.prototype.autoSizeAllColumns=function(e,t){void 0===t&&(t="api");var o=this.getAllDisplayedColumns();this.autoSizeColumns(o,e,t)},t.prototype.getColumnsFromTree=function(e){var t=[],o=function(e){for(var r=0;r=0},t.prototype.getAllDisplayedColumns=function(){return this.allDisplayedColumns},t.prototype.getAllDisplayedVirtualColumns=function(){return this.allDisplayedVirtualColumns},t.prototype.getDisplayedLeftColumnsForRow=function(e){return this.colSpanActive?this.getDisplayedColumnsForRow(e,this.displayedLeftColumns):this.displayedLeftColumns},t.prototype.getDisplayedRightColumnsForRow=function(e){return this.colSpanActive?this.getDisplayedColumnsForRow(e,this.displayedRightColumns):this.displayedRightColumns},t.prototype.getDisplayedColumnsForRow=function(e,t,o,r){for(var a,n=[],i=null,l=function(l){var g,s=t[l],p=t.length-l,c=Math.min(s.getColSpan(e),p),d=[s];if(c>1){for(var u=c-1,h=1;h<=u;h++)d.push(t[l+h]);l+=u}if(o?(g=!1,d.forEach((function(e){o(e)&&(g=!0)}))):g=!0,g){if(0===n.length&&i)!!r&&r(s)&&n.push(i);n.push(s)}i=s,a=l},g=0;gt.viewportLeft}))},t.prototype.isColumnInViewport=function(e){var t=e.getLeft(),o=e.getLeft()+e.getActualWidth(),r=this.viewportLeft-200,a=this.viewportRight+200;return!(ta&&o>a)},t.prototype.getPinnedLeftContainerWidth=function(){return this.getWidthOfColsInList(this.displayedLeftColumns)},t.prototype.getPinnedRightContainerWidth=function(){return this.getWidthOfColsInList(this.displayedRightColumns)},t.prototype.updatePrimaryColumnList=function(e,t,o,r,a,n){var i=this;if(void 0===n&&(n="api"),e&&!u.f.missingOrEmpty(e)){var l=!1;if(e.forEach((function(e){var a=i.getPrimaryColumn(e);if(a){if(o){if(t.indexOf(a)>=0)return;t.push(a)}else{if(t.indexOf(a)<0)return;u.f.removeFromArray(t,a)}r(a),l=!0}})),l){this.autoGroupsNeedBuilding&&this.updateGridColumns(),this.updateDisplayedColumns(n);var g={type:a,columns:t,column:1===t.length?t[0]:null,api:this.gridApi,columnApi:this.columnApi,source:n};this.eventService.dispatchEvent(g)}}},t.prototype.setRowGroupColumns=function(e,t){void 0===t&&(t="api"),this.autoGroupsNeedBuilding=!0,this.setPrimaryColumnList(e,this.rowGroupColumns,i.a.EVENT_COLUMN_ROW_GROUP_CHANGED,this.setRowGroupActive.bind(this),t)},t.prototype.setRowGroupActive=function(e,t,o){e!==t.isRowGroupActive()&&(t.setRowGroupActive(e,o),e||this.gridOptionsWrapper.isSuppressMakeColumnVisibleAfterUnGroup()||t.setVisible(!0,o))},t.prototype.addRowGroupColumn=function(e,t){void 0===t&&(t="api"),e&&this.addRowGroupColumns([e],t)},t.prototype.addRowGroupColumns=function(e,t){void 0===t&&(t="api"),this.autoGroupsNeedBuilding=!0,this.updatePrimaryColumnList(e,this.rowGroupColumns,!0,this.setRowGroupActive.bind(this,!0),i.a.EVENT_COLUMN_ROW_GROUP_CHANGED,t)},t.prototype.removeRowGroupColumns=function(e,t){void 0===t&&(t="api"),this.autoGroupsNeedBuilding=!0,this.updatePrimaryColumnList(e,this.rowGroupColumns,!1,this.setRowGroupActive.bind(this,!1),i.a.EVENT_COLUMN_ROW_GROUP_CHANGED,t)},t.prototype.removeRowGroupColumn=function(e,t){void 0===t&&(t="api"),e&&this.removeRowGroupColumns([e],t)},t.prototype.addPivotColumns=function(e,t){void 0===t&&(t="api"),this.updatePrimaryColumnList(e,this.pivotColumns,!0,(function(e){return e.setPivotActive(!0,t)}),i.a.EVENT_COLUMN_PIVOT_CHANGED,t)},t.prototype.setPivotColumns=function(e,t){void 0===t&&(t="api"),this.setPrimaryColumnList(e,this.pivotColumns,i.a.EVENT_COLUMN_PIVOT_CHANGED,(function(e,o){o.setPivotActive(e,t)}),t)},t.prototype.addPivotColumn=function(e,t){void 0===t&&(t="api"),this.addPivotColumns([e],t)},t.prototype.removePivotColumns=function(e,t){void 0===t&&(t="api"),this.updatePrimaryColumnList(e,this.pivotColumns,!1,(function(e){return e.setPivotActive(!1,t)}),i.a.EVENT_COLUMN_PIVOT_CHANGED,t)},t.prototype.removePivotColumn=function(e,t){void 0===t&&(t="api"),this.removePivotColumns([e],t)},t.prototype.setPrimaryColumnList=function(e,t,o,r,a){var n=this;t.length=0,u.f.exists(e)&&e.forEach((function(e){var o=n.getPrimaryColumn(e);o&&t.push(o)})),this.primaryColumns.forEach((function(e){var o=t.indexOf(e)>=0;r(o,e)})),this.autoGroupsNeedBuilding&&this.updateGridColumns(),this.updateDisplayedColumns(a);var i={type:o,columns:t,column:1===t.length?t[0]:null,api:this.gridApi,columnApi:this.columnApi,source:a};this.eventService.dispatchEvent(i)},t.prototype.setValueColumns=function(e,t){void 0===t&&(t="api"),this.setPrimaryColumnList(e,this.valueColumns,i.a.EVENT_COLUMN_VALUE_CHANGED,this.setValueActive.bind(this),t)},t.prototype.setValueActive=function(e,t,o){if(e!==t.isValueActive()&&(t.setValueActive(e,o),e&&!t.getAggFunc())){var r=this.aggFuncService.getDefaultAggFunc(t);t.setAggFunc(r)}},t.prototype.addValueColumns=function(e,t){void 0===t&&(t="api"),this.updatePrimaryColumnList(e,this.valueColumns,!0,this.setValueActive.bind(this,!0),i.a.EVENT_COLUMN_VALUE_CHANGED,t)},t.prototype.addValueColumn=function(e,t){void 0===t&&(t="api"),e&&this.addValueColumns([e],t)},t.prototype.removeValueColumn=function(e,t){void 0===t&&(t="api"),this.removeValueColumns([e],t)},t.prototype.removeValueColumns=function(e,t){void 0===t&&(t="api"),this.updatePrimaryColumnList(e,this.valueColumns,!1,this.setValueActive.bind(this,!1),i.a.EVENT_COLUMN_VALUE_CHANGED,t)},t.prototype.normaliseColumnWidth=function(e,t){return t0?a+=e.getMaxWidth():n=!1})),o>=r&&(!n||o<=a)},t.prototype.resizeColumnSets=function(e,t,o){if(!e||e.every(this.checkMinAndMaxWidthsForSet.bind(this))){var r=[],a=[];e.forEach((function(e){var t=e.width,n=e.columns,i=e.ratios,l={},g={};n.forEach((function(e){return a.push(e)}));for(var s=!0,p=0,c=function(){if(++p>1e3)return console.error("ag-Grid: infinite loop in resizeColumnSets"),"break";s=!1;var e=[],o=[],r=0,a=t;n.forEach((function(t,n){if(g[t.getId()])a-=l[t.getId()];else{e.push(t);var s=i[n];r+=s,o.push(s)}}));var c=1/r;e.forEach((function(o,r){var n;r===e.length-1?n=a:(n=Math.round(i[r]*t*c),a-=n),n0&&n>o.getMaxWidth()&&(n=o.getMaxWidth(),g[o.getId()]=!0,s=!0),l[o.getId()]=n}))};s;){if("break"===c())break}n.forEach((function(e){var t=l[e.getId()];e.getActualWidth()!==t&&(e.setActualWidth(t,o),r.push(e))}))}));var n=r.length>0;if(n&&(this.setLeftValues(o),this.updateBodyWidths(),this.checkDisplayedVirtualColumns()),n||t){var l={type:i.a.EVENT_COLUMN_RESIZED,columns:a,column:1===a.length?a[0]:null,finished:t,api:this.gridApi,columnApi:this.columnApi,source:o};this.eventService.dispatchEvent(l)}}else if(t){var g=e&&e.length>0?e[0].columns:null,s={type:i.a.EVENT_COLUMN_RESIZED,columns:g,column:g&&1===g.length?g[0]:null,finished:t,api:this.gridApi,columnApi:this.columnApi,source:o};this.eventService.dispatchEvent(s)}},t.prototype.setColumnAggFunc=function(e,t,o){if(void 0===o&&(o="api"),e){e.setAggFunc(t);var r={type:i.a.EVENT_COLUMN_VALUE_CHANGED,columns:[e],column:e,api:this.gridApi,columnApi:this.columnApi,source:o};this.eventService.dispatchEvent(r)}},t.prototype.moveRowGroupColumn=function(e,t,o){void 0===o&&(o="api");var r=this.rowGroupColumns[e];this.rowGroupColumns.splice(e,1),this.rowGroupColumns.splice(t,0,r);var a={type:i.a.EVENT_COLUMN_ROW_GROUP_CHANGED,columns:this.rowGroupColumns,column:1===this.rowGroupColumns.length?this.rowGroupColumns[0]:null,api:this.gridApi,columnApi:this.columnApi,source:o};this.eventService.dispatchEvent(a)},t.prototype.moveColumns=function(e,t,o){if(void 0===o&&(o="api"),this.columnAnimationService.start(),t>this.gridColumns.length-e.length)return console.warn("ag-Grid: tried to insert columns in invalid location, toIndex = "+t),void console.warn("ag-Grid: remember that you should not count the moving columns when calculating the new index");var r=this.getGridColumns(e);if(!!this.doesMovePassRules(r,t)){u.f.moveInArray(this.gridColumns,r,t),this.updateDisplayedColumns(o);var a={type:i.a.EVENT_COLUMN_MOVED,columns:r,column:1===r.length?r[0]:null,toIndex:t,api:this.gridApi,columnApi:this.columnApi,source:o};this.eventService.dispatchEvent(a),this.columnAnimationService.finish()}},t.prototype.doesMovePassRules=function(e,t){var o=this.gridColumns.slice();return u.f.moveInArray(o,e,t),!!this.doesMovePassMarryChildren(o)&&!!this.doesMovePassLockedPositions(o)},t.prototype.doesMovePassLockedPositions=function(e){var t=!1,o=!0;return e.forEach((function(e){e.getColDef().lockPosition?t&&(o=!1):t=!0})),o},t.prototype.doesMovePassMarryChildren=function(e){var t=!0;return this.columnUtils.depthFirstOriginalTreeSearch(null,this.gridBalancedTree,(function(o){if(o instanceof g.a){var r=o;if(r.getColGroupDef()&&r.getColGroupDef().marryChildren){var a=[];r.getLeafColumns().forEach((function(t){var o=e.indexOf(t);a.push(o)})),Math.max.apply(Math,a)-Math.min.apply(Math,a)>r.getLeafColumns().length-1&&(t=!1)}}})),t},t.prototype.moveColumn=function(e,t,o){void 0===o&&(o="api"),this.moveColumns([e],t,o)},t.prototype.moveColumnByIndex=function(e,t,o){void 0===o&&(o="api");var r=this.gridColumns[e];this.moveColumn(r,t,o)},t.prototype.getBodyContainerWidth=function(){return this.bodyWidth},t.prototype.getContainerWidth=function(e){switch(e){case c.a.PINNED_LEFT:return this.leftWidth;case c.a.PINNED_RIGHT:return this.rightWidth;default:return this.bodyWidth}},t.prototype.updateBodyWidths=function(){var e=this.getWidthOfColsInList(this.displayedCenterColumns),t=this.getWidthOfColsInList(this.displayedLeftColumns),o=this.getWidthOfColsInList(this.displayedRightColumns);if(this.bodyWidthDirty=this.bodyWidth!==e,this.bodyWidth!==e||this.leftWidth!==t||this.rightWidth!==o){this.bodyWidth=e,this.leftWidth=t,this.rightWidth=o;var r={type:i.a.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(r)}},t.prototype.getValueColumns=function(){return this.valueColumns?this.valueColumns:[]},t.prototype.getPivotColumns=function(){return this.pivotColumns?this.pivotColumns:[]},t.prototype.isPivotActive=function(){return this.pivotColumns&&this.pivotColumns.length>0&&this.pivotMode},t.prototype.getRowGroupColumns=function(){return this.rowGroupColumns?this.rowGroupColumns:[]},t.prototype.getDisplayedCenterColumns=function(){return this.displayedCenterColumns},t.prototype.getDisplayedLeftColumns=function(){return this.displayedLeftColumns},t.prototype.getDisplayedRightColumns=function(){return this.displayedRightColumns},t.prototype.getDisplayedColumns=function(e){switch(e){case c.a.PINNED_LEFT:return this.getDisplayedLeftColumns();case c.a.PINNED_RIGHT:return this.getDisplayedRightColumns();default:return this.getDisplayedCenterColumns()}},t.prototype.getAllPrimaryColumns=function(){return this.primaryColumns?this.primaryColumns.slice():null},t.prototype.getSecondaryColumns=function(){return this.secondaryColumns?this.secondaryColumns.slice():null},t.prototype.getAllColumnsForQuickFilter=function(){return this.columnsForQuickFilter},t.prototype.getAllGridColumns=function(){return this.gridColumns},t.prototype.isEmpty=function(){return u.f.missingOrEmpty(this.gridColumns)},t.prototype.isRowGroupEmpty=function(){return u.f.missingOrEmpty(this.rowGroupColumns)},t.prototype.setColumnVisible=function(e,t,o){void 0===o&&(o="api"),this.setColumnsVisible([e],t,o)},t.prototype.setColumnsVisible=function(e,t,o){var r=this;void 0===o&&(o="api"),this.columnAnimationService.start(),this.actionOnGridColumns(e,(function(e){return e.isVisible()!==t&&(e.setVisible(t,o),!0)}),o,(function(){return{type:i.a.EVENT_COLUMN_VISIBLE,visible:t,column:null,columns:null,api:r.gridApi,columnApi:r.columnApi,source:o}})),this.columnAnimationService.finish()},t.prototype.setColumnPinned=function(e,t,o){void 0===o&&(o="api"),e&&this.setColumnsPinned([e],t,o)},t.prototype.setColumnsPinned=function(e,t,o){var r,a=this;(void 0===o&&(o="api"),"print"!==this.gridOptionsWrapper.getDomLayout())?(this.columnAnimationService.start(),r=!0===t||t===c.a.PINNED_LEFT?c.a.PINNED_LEFT:t===c.a.PINNED_RIGHT?c.a.PINNED_RIGHT:null,this.actionOnGridColumns(e,(function(e){return e.getPinned()!==r&&(e.setPinned(r),!0)}),o,(function(){return{type:i.a.EVENT_COLUMN_PINNED,pinned:r,column:null,columns:null,api:a.gridApi,columnApi:a.columnApi,source:o}})),this.columnAnimationService.finish()):console.warn("Changing the column pinning status is not allowed with domLayout='print'")},t.prototype.actionOnGridColumns=function(e,t,o,r){var a=this;if(!u.f.missingOrEmpty(e)){var n=[];if(e.forEach((function(e){var o=a.getGridColumn(e);o&&(!1!==t(o)&&n.push(o))})),n.length&&(this.updateDisplayedColumns(o),u.f.exists(r)&&r)){var i=r();i.columns=n,i.column=1===n.length?n[0]:null,this.eventService.dispatchEvent(i)}}},t.prototype.getDisplayedColBefore=function(e){var t=this.getAllDisplayedColumns(),o=t.indexOf(e);return o>0?t[o-1]:null},t.prototype.getDisplayedColAfter=function(e){var t=this.getAllDisplayedColumns(),o=t.indexOf(e);return o0},t.prototype.isPinningRight=function(){return this.displayedRightColumns.length>0},t.prototype.getPrimaryAndSecondaryAndAutoColumns=function(){var e=this.primaryColumns?this.primaryColumns.slice(0):[];return this.groupAutoColumns&&u.f.exists(this.groupAutoColumns)&&this.groupAutoColumns.forEach((function(t){return e.push(t)})),this.secondaryColumnsPresent&&this.secondaryColumns&&this.secondaryColumns.forEach((function(t){return e.push(t)})),e},t.prototype.createStateItemFromColumn=function(e){var t=e.isRowGroupActive()?this.rowGroupColumns.indexOf(e):null,o=e.isPivotActive()?this.pivotColumns.indexOf(e):null,r=e.isValueActive()?e.getAggFunc():null;return{colId:e.getColId(),hide:!e.isVisible(),aggFunc:r,width:e.getActualWidth(),pivotIndex:o,pinned:e.getPinned(),rowGroupIndex:t,flex:e.getFlex()}},t.prototype.getColumnState=function(){if(u.f.missing(this.primaryColumns))return[];var e=this.primaryColumns.map(this.createStateItemFromColumn.bind(this)),t=(this.groupAutoColumns?this.groupAutoColumns.map(this.createStateItemFromColumn.bind(this)):[]).concat(e);return this.pivotMode||this.orderColumnStateList(t),t},t.prototype.orderColumnStateList=function(e){var t=this.gridColumns.map((function(e){return e.getColId()}));e.sort((function(e,o){return t.indexOf(e.colId)-t.indexOf(o.colId)}))},t.prototype.resetColumnState=function(e,t){void 0===e&&(e=!1),void 0===t&&(t="api");var o=this.getColumnsFromTree(this.primaryColumnTree),r=[],a=1e3,n=1e3;o&&o.forEach((function(e){var t=e.getColDef().rowGroupIndex,o=e.getColDef().rowGroup,i=e.getColDef().pivotIndex,l=e.getColDef().pivot,g={colId:e.getColId(),aggFunc:e.getColDef().aggFunc,hide:e.getColDef().hide,pinned:e.getColDef().pinned,rowGroupIndex:t,pivotIndex:e.getColDef().pivotIndex,width:e.getColDef().width};u.f.missing(t)&&o&&(g.rowGroupIndex=a++),u.f.missing(i)&&l&&(g.pivotIndex=n++),r.push(g)})),this.setColumnState(r,e,t)},t.prototype.setColumnState=function(e,t,o){var r=this;if(void 0===t&&(t=!1),void 0===o&&(o="api"),u.f.missingOrEmpty(this.primaryColumns))return!1;var a=this.getColumnState();this.autoGroupsNeedBuilding=!0;var n=this.primaryColumns.slice();this.rowGroupColumns=[],this.valueColumns=[],this.pivotColumns=[];var l=!0,g={},s={},p=[];if(e&&(e.forEach((function(e){if(u.f.exists(r.getAutoColumn(e.colId)))p.push(e);else{var t=r.getPrimaryColumn(e.colId);t?(r.syncColumnWithStateItem(t,e,g,s,o),u.f.removeFromArray(n,t)):(console.warn("ag-grid: column "+e.colId+" not found"),l=!1)}})),this.flexActive&&this.refreshFlexedColumns(void 0,void 0,!0)),n.forEach(this.syncColumnWithNoState.bind(this)),this.rowGroupColumns.sort(this.sortColumnListUsingIndexes.bind(this,g)),this.pivotColumns.sort(this.sortColumnListUsingIndexes.bind(this,s)),this.updateGridColumns(),p.forEach((function(e){var t=r.getAutoColumn(e.colId);r.syncColumnWithStateItem(t,e,g,s,o)})),e){var c=e.map((function(e){return e.colId}));this.gridColumns.sort((function(e,t){return c.indexOf(e.getId())-c.indexOf(t.getId())}))}if(this.putFixedColumnsFirst(),this.updateDisplayedColumns(o),!t){var d={type:i.a.EVENT_COLUMN_EVERYTHING_CHANGED,api:this.gridApi,columnApi:this.columnApi,source:o};this.eventService.dispatchEvent(d)}return this.raiseColumnEvents(a,o),l},t.prototype.raiseColumnEvents=function(e,t){var o=this;if(!this.gridOptionsWrapper.isSuppressSetColumnStateEvents()){var r=this.getColumnState(),a=function(a,n,i){if(!Object(d.areEqual)(e.map(n).sort(),r.map(n).sort())){var l={type:a,columns:i,column:1===i.length?i[0]:null,api:o.gridApi,columnApi:o.columnApi,source:t};o.eventService.dispatchEvent(l)}},n=function(t){var r=[],a={};return e.forEach((function(e){a[e.colId]=e})),o.gridColumns.forEach((function(e){var o=a[e.getColId()];o&&!t(o,e)||r.push(e)})),r};a(i.a.EVENT_COLUMN_VALUE_CHANGED,(function(e){return e.colId+"-"+e.aggFunc}),this.valueColumns);a(i.a.EVENT_COLUMN_PIVOT_CHANGED,(function(e){return e.colId+"-"+e.pivotIndex}),this.pivotColumns);a(i.a.EVENT_COLUMN_ROW_GROUP_CHANGED,(function(e){return e.colId+"-"+e.rowGroupIndex}),this.rowGroupColumns);this.raiseColumnPinnedEvent(n((function(e,t){return e.pinned!==t.getPinned()})),t);var l=n((function(e,t){return e.hide===t.isVisible()}));this.raiseColumnVisibleEvent(l,t);this.raiseColumnResizeEvent(n((function(e,t){return e.width!==t.getActualWidth()})),t),this.raiseColumnMovedEvent(e,t)}},t.prototype.raiseColumnPinnedEvent=function(e,t){if(e.length){var o={type:i.a.EVENT_COLUMN_PINNED,pinned:null,columns:e,column:null,api:this.gridApi,columnApi:this.columnApi,source:t};this.eventService.dispatchEvent(o)}},t.prototype.raiseColumnVisibleEvent=function(e,t){if(e.length){var o={type:i.a.EVENT_COLUMN_VISIBLE,visible:void 0,columns:e,column:null,api:this.gridApi,columnApi:this.columnApi,source:t};this.eventService.dispatchEvent(o)}},t.prototype.raiseColumnResizeEvent=function(e,t){if(e.length){var o={type:i.a.EVENT_COLUMN_RESIZED,columns:e,column:null,finished:!0,api:this.gridApi,columnApi:this.columnApi,source:t};this.eventService.dispatchEvent(o)}},t.prototype.raiseColumnMovedEvent=function(e,t){for(var o=[],r=this.getColumnState(),a=function(t){var a=e[t],i=r[t];if(!a||i.hide)return"continue";if(a.colId!==i.colId){var l=u.f.find(n.allDisplayedColumns,(function(e){return e.getColId()===i.colId}));o.push(l)}},n=this,l=0;l=n&&e.setActualWidth(t.width,a),"string"==typeof t.aggFunc?(e.setAggFunc(t.aggFunc),e.setValueActive(!0,a),this.valueColumns.push(e)):(u.f.exists(t.aggFunc)&&console.warn("ag-Grid: stateItem.aggFunc must be a string. if using your own aggregation functions, register the functions first before using them in get/set state. This is because it is intended for the column state to be stored and retrieved as simple JSON."),e.setAggFunc(null),e.setValueActive(!1,a)),"number"==typeof t.rowGroupIndex?(this.rowGroupColumns.push(e),e.setRowGroupActive(!0,a),o[e.getId()]=t.rowGroupIndex):e.setRowGroupActive(!1,a),"number"==typeof t.pivotIndex?(this.pivotColumns.push(e),e.setPivotActive(!0,a),r[e.getId()]=t.pivotIndex):e.setPivotActive(!1,a)}},t.prototype.getGridColumns=function(e){return this.getColumns(e,this.getGridColumn.bind(this))},t.prototype.getColumns=function(e,t){var o=[];return e&&e.forEach((function(e){var r=t(e);r&&o.push(r)})),o},t.prototype.getColumnWithValidation=function(e){if(null==e)return null;var t=this.getGridColumn(e);return t||console.warn("ag-Grid: could not find column "+e),t},t.prototype.getPrimaryColumn=function(e){return this.getColumn(e,this.primaryColumns)},t.prototype.getGridColumn=function(e){return this.getColumn(e,this.gridColumns)},t.prototype.getColumn=function(e,t){if(!e)return null;for(var o=0;o=0})),g=this.primaryColumns.filter((function(t){return!e||e.indexOf(t)<0}));i.forEach((function(e){return o(e,!1)}));var s=[];return g.forEach((function(e){"number"==typeof r(e.getColDef())&&s.push(e)})),s.sort((function(e,t){var o=r(e.getColDef()),a=r(t.getColDef());return o===a?0:o=0)return;s.push(e)}})),s.forEach((function(e){return o(e,!0)})),l.concat(s)},t.prototype.extractPivotColumns=function(e,t){this.pivotColumns=this.extractColumns(t,this.pivotColumns,(function(t,o){return t.setPivotActive(o,e)}),(function(e){return e.pivotIndex}),(function(e){return e.pivot}))},t.prototype.resetColumnGroupState=function(e){void 0===e&&(e="api");var t=[];this.columnUtils.depthFirstOriginalTreeSearch(null,this.primaryColumnTree,(function(e){if(e instanceof g.a){var o={groupId:e.getGroupId(),open:e.getColGroupDef().openByDefault};t.push(o)}})),this.setColumnGroupState(t,e)},t.prototype.getColumnGroupState=function(){var e=[];return this.columnUtils.depthFirstOriginalTreeSearch(null,this.gridBalancedTree,(function(t){if(t instanceof g.a){var o=t;e.push({groupId:o.getGroupId(),open:o.isExpanded()})}})),e},t.prototype.setColumnGroupState=function(e,t){var o=this;void 0===t&&(t="api"),this.columnAnimationService.start();var r=[];e.forEach((function(e){var t=e.groupId,a=e.open,n=o.getOriginalColumnGroup(t);n&&n.isExpanded()!==a&&(o.logger.log("columnGroupOpened("+n.getGroupId()+","+a+")"),n.setExpanded(a),r.push(n))})),this.updateGroupsAndDisplayedColumns(t),this.setFirstRightAndLastLeftPinned(t),r.forEach((function(e){var t={type:i.a.EVENT_COLUMN_GROUP_OPENED,columnGroup:e,api:o.gridApi,columnApi:o.columnApi};o.eventService.dispatchEvent(t)})),this.columnAnimationService.finish()},t.prototype.setColumnGroupOpened=function(e,t,o){var r;void 0===o&&(o="api"),r=e instanceof g.a?e.getId():e,this.setColumnGroupState([{groupId:r,open:t}],o)},t.prototype.getOriginalColumnGroup=function(e){if(e instanceof g.a)return e;"string"!=typeof e&&console.error("ag-Grid: group key must be a string");var t=null;return this.columnUtils.depthFirstOriginalTreeSearch(null,this.gridBalancedTree,(function(o){if(o instanceof g.a){var r=o;r.getId()===e&&(t=r)}})),t},t.prototype.calculateColumnsForDisplay=function(){var e=this;return this.pivotMode&&!this.secondaryColumnsPresent?this.gridColumns.filter((function(t){var o=e.groupAutoColumns&&u.f.includes(e.groupAutoColumns,t),r=e.valueColumns&&u.f.includes(e.valueColumns,t);return o||r})):this.gridColumns.filter((function(t){return e.groupAutoColumns&&u.f.includes(e.groupAutoColumns,t)||t.isVisible()}))},t.prototype.checkColSpanActiveInCols=function(e){var t=!1;return e.forEach((function(e){u.f.exists(e.getColDef().colSpan)&&(t=!0)})),t},t.prototype.calculateColumnsForGroupDisplay=function(){var e=this;this.groupDisplayColumns=[];var t=function(t){var o=t.getColDef();o&&u.f.exists(o.showRowGroup)&&e.groupDisplayColumns.push(t)};this.gridColumns.forEach(t),this.groupAutoColumns&&this.groupAutoColumns.forEach(t)},t.prototype.getGroupDisplayColumns=function(){return this.groupDisplayColumns},t.prototype.updateDisplayedColumns=function(e){var t=this.calculateColumnsForDisplay();this.buildDisplayedTrees(t),this.calculateColumnsForGroupDisplay(),this.updateGroupsAndDisplayedColumns(e),this.setFirstRightAndLastLeftPinned(e)},t.prototype.isSecondaryColumnsPresent=function(){return this.secondaryColumnsPresent},t.prototype.setSecondaryColumns=function(e,t){void 0===t&&(t="api");var o=e&&e.length>0;if(o||this.secondaryColumnsPresent){if(o){this.processSecondaryColumnDefinitions(e);var r=this.columnFactory.createColumnTree(e,!1);this.secondaryBalancedTree=r.columnTree,this.secondaryHeaderRowCount=r.treeDept+1,this.secondaryColumns=this.getColumnsFromTree(this.secondaryBalancedTree),this.secondaryColumnsPresent=!0}else this.secondaryBalancedTree=null,this.secondaryHeaderRowCount=-1,this.secondaryColumns=null,this.secondaryColumnsPresent=!1;this.updateGridColumns(),this.updateDisplayedColumns(t)}},t.prototype.processSecondaryColumnDefinitions=function(e){var t=this.gridOptionsWrapper.getProcessSecondaryColDefFunc(),o=this.gridOptionsWrapper.getProcessSecondaryColGroupDefFunc();if(t||o){var r=function(e){e.forEach((function(e){if(u.f.exists(e.children)){var a=e;o&&o(a),r(a.children)}else{t&&t(e)}}))};e&&r(e)}},t.prototype.updateGridColumns=function(){this.gridColsArePrimary&&(this.lastPrimaryOrder=this.gridColumns),this.secondaryColumns&&this.secondaryBalancedTree?(this.gridBalancedTree=this.secondaryBalancedTree.slice(),this.gridHeaderRowCount=this.secondaryHeaderRowCount,this.gridColumns=this.secondaryColumns.slice(),this.gridColsArePrimary=!1):(this.gridBalancedTree=this.primaryColumnTree.slice(),this.gridHeaderRowCount=this.primaryHeaderRowCount,this.gridColumns=this.primaryColumns.slice(),this.gridColsArePrimary=!0,this.orderGridColsLikeLastPrimary()),this.addAutoGroupToGridColumns(),this.autoRowHeightColumns=this.gridColumns.filter((function(e){return e.getColDef().autoHeight})),this.putFixedColumnsFirst(),this.setupQuickFilterColumns(),this.clearDisplayedColumns(),this.colSpanActive=this.checkColSpanActiveInCols(this.gridColumns);var e={type:i.a.EVENT_GRID_COLUMNS_CHANGED,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(e)},t.prototype.orderGridColsLikeLastPrimary=function(){var e=this;if(!u.f.missing(this.lastPrimaryOrder)){var t=!0;if(this.gridColumns.forEach((function(o){e.lastPrimaryOrder.indexOf(o)>=0&&(t=!1)})),!t){var o=this.lastPrimaryOrder.filter((function(t){return e.gridColumns.indexOf(t)>=0})),r=this.gridColumns.filter((function(e){return o.indexOf(e)<0})),a=o.slice();r.forEach((function(e){var t=e.getOriginalParent();if(t){for(var o=[];!o.length&&t;){t.getLeafColumns().forEach((function(e){var t=a.indexOf(e)>=0,r=o.indexOf(e)<0;t&&r&&o.push(e)})),t=t.getOriginalParent()}if(o.length){var r=o.map((function(e){return a.indexOf(e)})),n=Math.max.apply(Math,r);u.f.insertIntoArray(a,e,n+1)}else a.push(e)}else a.push(e)})),this.gridColumns=a}}},t.prototype.isPrimaryColumnGroupsPresent=function(){return this.primaryHeaderRowCount>1},t.prototype.setupQuickFilterColumns=function(){this.groupAutoColumns?this.columnsForQuickFilter=this.primaryColumns.concat(this.groupAutoColumns):this.columnsForQuickFilter=this.primaryColumns},t.prototype.putFixedColumnsFirst=function(){var e=this.gridColumns.filter((function(e){return e.getColDef().lockPosition})),t=this.gridColumns.filter((function(e){return!e.getColDef().lockPosition}));this.gridColumns=e.concat(t)},t.prototype.addAutoGroupToGridColumns=function(){if(this.createGroupAutoColumnsIfNeeded(),!u.f.missing(this.groupAutoColumns)){this.gridColumns=this.groupAutoColumns?this.groupAutoColumns.concat(this.gridColumns):this.gridColumns;var e=this.columnFactory.createForAutoGroups(this.groupAutoColumns,this.gridBalancedTree);this.gridBalancedTree=e.concat(this.gridBalancedTree)}},t.prototype.clearDisplayedColumns=function(){this.displayedLeftColumnTree=[],this.displayedRightColumnTree=[],this.displayedCentreColumnTree=[],this.displayedLeftHeaderRows={},this.displayedRightHeaderRows={},this.displayedCentreHeaderRows={},this.displayedLeftColumns=[],this.displayedRightColumns=[],this.displayedCenterColumns=[],this.allDisplayedColumns=[],this.allDisplayedVirtualColumns=[]},t.prototype.updateGroupsAndDisplayedColumns=function(e){this.updateOpenClosedVisibilityInColumnGroups(),this.updateDisplayedColumnsFromTrees(e),this.updateVirtualSets(),this.refreshFlexedColumns(void 0,void 0,!0),this.updateBodyWidths();var t={type:i.a.EVENT_DISPLAYED_COLUMNS_CHANGED,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(t)},t.prototype.updateDisplayedColumnsFromTrees=function(e){this.addToDisplayedColumns(this.displayedLeftColumnTree,this.displayedLeftColumns),this.addToDisplayedColumns(this.displayedCentreColumnTree,this.displayedCenterColumns),this.addToDisplayedColumns(this.displayedRightColumnTree,this.displayedRightColumns),this.setupAllDisplayedColumns(),this.setLeftValues(e)},t.prototype.setupAllDisplayedColumns=function(){this.gridOptionsWrapper.isEnableRtl()?this.allDisplayedColumns=this.displayedRightColumns.concat(this.displayedCenterColumns).concat(this.displayedLeftColumns):this.allDisplayedColumns=this.displayedLeftColumns.concat(this.displayedCenterColumns).concat(this.displayedRightColumns)},t.prototype.setLeftValues=function(e){this.setLeftValuesOfColumns(e),this.setLeftValuesOfGroups()},t.prototype.setLeftValuesOfColumns=function(e){var t=this,o=this.primaryColumns.slice(0),r=this.gridOptionsWrapper.isEnableRtl();[this.displayedLeftColumns,this.displayedRightColumns,this.displayedCenterColumns].forEach((function(a){if(r){var n=t.getWidthOfColsInList(a);a.forEach((function(t){n-=t.getActualWidth(),t.setLeft(n,e)}))}else{var i=0;a.forEach((function(t){t.setLeft(i,e),i+=t.getActualWidth()}))}u.f.removeAllFromArray(o,a)})),o.forEach((function(t){t.setLeft(null,e)}))},t.prototype.setLeftValuesOfGroups=function(){[this.displayedLeftColumnTree,this.displayedRightColumnTree,this.displayedCentreColumnTree].forEach((function(e){e.forEach((function(e){e instanceof a.a&&e.checkLeft()}))}))},t.prototype.addToDisplayedColumns=function(e,t){t.length=0,this.columnUtils.depthFirstDisplayedColumnTreeSearch(e,(function(e){e instanceof n.a&&t.push(e)}))},t.prototype.updateDisplayedCenterVirtualColumns=function(){this.suppressColumnVirtualisation?this.allDisplayedCenterVirtualColumns=this.displayedCenterColumns:this.allDisplayedCenterVirtualColumns=this.filterOutColumnsWithinViewport(),this.allDisplayedVirtualColumns=this.allDisplayedCenterVirtualColumns.concat(this.displayedLeftColumns).concat(this.displayedRightColumns);var e={};return this.allDisplayedVirtualColumns.forEach((function(t){e[t.getId()]=!0})),e},t.prototype.getVirtualHeaderGroupRow=function(e,t){var o;switch(e){case c.a.PINNED_LEFT:o=this.displayedLeftHeaderRows[t];break;case c.a.PINNED_RIGHT:o=this.displayedRightHeaderRows[t];break;default:o=this.displayedCentreHeaderRows[t]}return u.f.missing(o)&&(o=[]),o},t.prototype.updateDisplayedVirtualGroups=function(e){this.displayedLeftHeaderRows={},this.displayedRightHeaderRows={},this.displayedCentreHeaderRows={};var t=function(o,r,a){for(var i=!1,l=0;ls.getMaxWidth()&&(c=s.getMaxWidth()),c){s.setActualWidth(c,t),u.f.removeFromArray(a,s),r.push(s);continue e}i[g]=Math.round(p)}break}var d=n;a.forEach((function(e,o){e.setActualWidth(Math.min(i[o],d),t),d-=i[o]})),this.setLeftValues(t),o||(this.updateBodyWidths(),this.fireResizedEventForColumns(a,t))}else this.flexActive=!1}},t.prototype.sizeColumnsToFit=function(e,t,o){void 0===t&&(t="sizeColumnsToFit");var r=this.getAllDisplayedColumns();if(!(e<=0)&&r.length){var a=[],n=[];r.forEach((function(e){!0===e.getColDef().suppressSizeToFit?n.push(e):a.push(e)}));var i=a.slice(0),l=!1,g=function(e){u.f.removeFromArray(a,e),n.push(e)};for(a.forEach((function(e){return e.resetActualWidth()}));!l;){l=!0;var s=e-this.getWidthOfColsInList(n);if(s<=0)a.forEach((function(e){e.setMinimum(t)}));else for(var p=s/this.getWidthOfColsInList(a),c=s,d=a.length-1;d>=0;d--){var h=a[d],f=Math.round(h.getActualWidth()*p);if(f0||this.usingTreeData)&&!t&&!e&&!o){var r=this.autoGroupColService.createAutoGroupColumns(this.rowGroupColumns);(!this.autoColsEqual(r,this.groupAutoColumns)||this.forceRecreateAutoGroups)&&(this.groupAutoColumns=r)}else this.groupAutoColumns=null}},t.prototype.autoColsEqual=function(e,t){return Object(d.areEqual)(e,t,(function(e,t){return e.getColId()===t.getColId()}))},t.prototype.getWidthOfColsInList=function(e){return e.reduce((function(e,t){return e+t.getActualWidth()}),0)},t.prototype.getGridBalancedTree=function(){return this.gridBalancedTree},t.prototype.hasFloatingFilters=function(){var e=this.gridOptionsWrapper.getDefaultColDef();return null!=e&&!0===e.floatingFilter||null!=this.columnDefs&&this.columnDefs.some((function(e){return!0===e.floatingFilter}))},t.prototype.getFirstDisplayedColumn=function(){var e=this.gridOptionsWrapper.isEnableRtl(),t=["getDisplayedLeftColumns","getDisplayedCenterColumns","getDisplayedRightColumns"];e&&t.reverse();for(var o=0;o=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},c=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return s(t,e),t.prototype.calculateColInitialWidth=function(e){var t=this.gridOptionsWrapper,o=null!=e.minWidth?e.minWidth:t.getMinColWidth(),r=null!=e.maxWidth?e.maxWidth:t.getMaxColWidth()||l.f.getMaxSafeInteger(),a=null!=e.width?e.width:t.getColWidth();return Math.max(Math.min(a,r),o)},t.prototype.getOriginalPathForColumn=function(e,t){var o=[],r=!1,a=function(t,i){for(var l=0;l=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},c=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return s(t,e),t.prototype.createDisplayedGroups=function(e,t,o,r,a){var n,i,g=this,s=[],p=this.mapOldGroupsById(a);return e.forEach((function(e){for(var a=g.getOriginalPathForColumn(t,e),c=[],d=!i,u=0;u=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(){return e.call(this,t.TEMPLATE)||this}return g(t,e),t.prototype.init=function(e){this.params=e,this.focusAfterAttached=e.cellStartedEdit,this.eTextArea.setMaxLength(e.maxLength||200).setCols(e.cols||60).setRows(e.rows||10),l.f.exists(e.value)&&this.eTextArea.setValue(e.value.toString(),!0),this.addGuiEventListener("keydown",this.onKeyDown.bind(this))},t.prototype.onKeyDown=function(e){var t=e.which||e.keyCode;(t==a.a.KEY_LEFT||t==a.a.KEY_UP||t==a.a.KEY_RIGHT||t==a.a.KEY_DOWN||e.shiftKey&&t==a.a.KEY_ENTER)&&e.stopPropagation()},t.prototype.afterGuiAttached=function(){this.focusAfterAttached&&this.eTextArea.getFocusableElement().focus()},t.prototype.getValue=function(){return this.params.parseValue(this.eTextArea.getValue())},t.TEMPLATE='
\n \n
',s([Object(i.d)("eTextArea")],t.prototype,"eTextArea",void 0),t}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return u}));var r,a=o(1),n=o(6),i=o(4),l=o(2),g=o(59),s=o(0),p=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),c=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},d=function(e,t){return function(o,r){t(o,r,e)}},u=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return p(t,e),t.prototype.setBeans=function(e){this.logger=e.create("SelectionController"),this.reset(),this.gridOptionsWrapper.isRowModelDefault()&&this.addManagedListener(this.eventService,i.a.EVENT_ROW_DATA_CHANGED,this.reset.bind(this))},t.prototype.init=function(){this.groupSelectsChildren=this.gridOptionsWrapper.isGroupSelectsChildren(),this.addManagedListener(this.eventService,i.a.EVENT_ROW_SELECTED,this.onRowSelected.bind(this))},t.prototype.setLastSelectedNode=function(e){this.lastSelectedNode=e},t.prototype.getLastSelectedNode=function(){return this.lastSelectedNode},t.prototype.getSelectedNodes=function(){var e=[];return s.f.iterateObject(this.selectedNodes,(function(t,o){o&&e.push(o)})),e},t.prototype.getSelectedRows=function(){var e=[];return s.f.iterateObject(this.selectedNodes,(function(t,o){o&&o.data&&e.push(o.data)})),e},t.prototype.removeGroupsFromSelection=function(){var e=this;s.f.iterateObject(this.selectedNodes,(function(t,o){o&&o.group&&(e.selectedNodes[o.id]=void 0)}))},t.prototype.updateGroupsFromChildrenSelections=function(e){if(this.gridOptionsWrapper.isGroupSelectsChildren()&&this.rowModel.getType()===l.a.ROW_MODEL_TYPE_CLIENT_SIDE){var t=this.rowModel.getRootNode();e||(e=new g.a(!0,t)).setInactive(),e.forEachChangedNodeDepthFirst((function(e){e!==t&&e.calculateSelectedFromChildren()}))}},t.prototype.getNodeForIdIfSelected=function(e){return this.selectedNodes[e]},t.prototype.clearOtherNodes=function(e){var t=this,o={},r=0;return s.f.iterateObject(this.selectedNodes,(function(a,n){if(n&&n.id!==e.id){var i=t.selectedNodes[n.id];r+=i.setSelectedParams({newValue:!1,clearSelection:!1,suppressFinishActions:!0}),t.groupSelectsChildren&&n.parent&&(o[n.parent.id]=n.parent)}})),s.f.iterateObject(o,(function(e,t){t.calculateSelectedFromChildren()})),r},t.prototype.onRowSelected=function(e){var t=e.node;this.groupSelectsChildren&&t.group||(t.isSelected()?this.selectedNodes[t.id]=t:this.selectedNodes[t.id]=void 0)},t.prototype.syncInRowNode=function(e,t){this.syncInOldRowNode(e,t),this.syncInNewRowNode(e)},t.prototype.syncInOldRowNode=function(e,t){s.f.exists(t)&&e.id!==t.id&&(s.f.exists(this.selectedNodes[t.id])&&(this.selectedNodes[t.id]=t))},t.prototype.syncInNewRowNode=function(e){s.f.exists(this.selectedNodes[e.id])?(e.setSelectedInitialValue(!0),this.selectedNodes[e.id]=e):e.setSelectedInitialValue(!1)},t.prototype.reset=function(){this.logger.log("reset"),this.selectedNodes={},this.lastSelectedNode=null},t.prototype.getBestCostNodeSelection=function(){if(this.rowModel.getType()===l.a.ROW_MODEL_TYPE_CLIENT_SIDE){var e=this.rowModel.getTopLevelNodes();if(null!==e){var t=[];return function e(o){for(var r=0,a=o.length;r=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},n=function(){function e(){}return e.prototype.sizeColumnsToFit=function(e){void 0===e&&console.error("ag-Grid: missing parameter to columnApi.sizeColumnsToFit(gridWidth)"),this.columnController.sizeColumnsToFit(e,"api")},e.prototype.setColumnGroupOpened=function(e,t){this.columnController.setColumnGroupOpened(e,t,"api")},e.prototype.getColumnGroup=function(e,t){return this.columnController.getColumnGroup(e,t)},e.prototype.getOriginalColumnGroup=function(e){return this.columnController.getOriginalColumnGroup(e)},e.prototype.getDisplayNameForColumn=function(e,t){return this.columnController.getDisplayNameForColumn(e,t)||""},e.prototype.getDisplayNameForColumnGroup=function(e,t){return this.columnController.getDisplayNameForColumnGroup(e,t)||""},e.prototype.getColumn=function(e){return this.columnController.getPrimaryColumn(e)},e.prototype.setColumnState=function(e){return this.columnController.setColumnState(e,!1,"api")},e.prototype.getColumnState=function(){return this.columnController.getColumnState()},e.prototype.resetColumnState=function(){this.columnController.resetColumnState(!1,"api")},e.prototype.getColumnGroupState=function(){return this.columnController.getColumnGroupState()},e.prototype.setColumnGroupState=function(e){this.columnController.setColumnGroupState(e,"api")},e.prototype.resetColumnGroupState=function(){this.columnController.resetColumnGroupState("api")},e.prototype.isPinning=function(){return this.columnController.isPinningLeft()||this.columnController.isPinningRight()},e.prototype.isPinningLeft=function(){return this.columnController.isPinningLeft()},e.prototype.isPinningRight=function(){return this.columnController.isPinningRight()},e.prototype.getDisplayedColAfter=function(e){return this.columnController.getDisplayedColAfter(e)},e.prototype.getDisplayedColBefore=function(e){return this.columnController.getDisplayedColBefore(e)},e.prototype.setColumnVisible=function(e,t){this.columnController.setColumnVisible(e,t,"api")},e.prototype.setColumnsVisible=function(e,t){this.columnController.setColumnsVisible(e,t,"api")},e.prototype.setColumnPinned=function(e,t){this.columnController.setColumnPinned(e,t,"api")},e.prototype.setColumnsPinned=function(e,t){this.columnController.setColumnsPinned(e,t,"api")},e.prototype.getAllColumns=function(){return this.columnController.getAllPrimaryColumns()},e.prototype.getAllGridColumns=function(){return this.columnController.getAllGridColumns()},e.prototype.getDisplayedLeftColumns=function(){return this.columnController.getDisplayedLeftColumns()},e.prototype.getDisplayedCenterColumns=function(){return this.columnController.getDisplayedCenterColumns()},e.prototype.getDisplayedRightColumns=function(){return this.columnController.getDisplayedRightColumns()},e.prototype.getAllDisplayedColumns=function(){return this.columnController.getAllDisplayedColumns()},e.prototype.getAllDisplayedVirtualColumns=function(){return this.columnController.getAllDisplayedVirtualColumns()},e.prototype.moveColumn=function(e,t){"number"==typeof e?(console.warn("ag-Grid: you are using moveColumn(fromIndex, toIndex) - moveColumn takes a column key and a destination index, not two indexes, to move with indexes use moveColumnByIndex(from,to) instead"),this.columnController.moveColumnByIndex(e,t,"api")):this.columnController.moveColumn(e,t,"api")},e.prototype.moveColumnByIndex=function(e,t){this.columnController.moveColumnByIndex(e,t,"api")},e.prototype.moveColumns=function(e,t){this.columnController.moveColumns(e,t,"api")},e.prototype.moveRowGroupColumn=function(e,t){this.columnController.moveRowGroupColumn(e,t)},e.prototype.setColumnAggFunc=function(e,t){this.columnController.setColumnAggFunc(e,t)},e.prototype.setColumnWidth=function(e,t,o){void 0===o&&(o=!0),this.columnController.setColumnWidths([{key:e,newWidth:t}],!1,o)},e.prototype.setColumnWidths=function(e,t){void 0===t&&(t=!0),this.columnController.setColumnWidths(e,!1,t)},e.prototype.setPivotMode=function(e){this.columnController.setPivotMode(e)},e.prototype.isPivotMode=function(){return this.columnController.isPivotMode()},e.prototype.getSecondaryPivotColumn=function(e,t){return this.columnController.getSecondaryPivotColumn(e,t)},e.prototype.setValueColumns=function(e){this.columnController.setValueColumns(e,"api")},e.prototype.getValueColumns=function(){return this.columnController.getValueColumns()},e.prototype.removeValueColumn=function(e){this.columnController.removeValueColumn(e,"api")},e.prototype.removeValueColumns=function(e){this.columnController.removeValueColumns(e,"api")},e.prototype.addValueColumn=function(e){this.columnController.addValueColumn(e,"api")},e.prototype.addValueColumns=function(e){this.columnController.addValueColumns(e,"api")},e.prototype.setRowGroupColumns=function(e){this.columnController.setRowGroupColumns(e,"api")},e.prototype.removeRowGroupColumn=function(e){this.columnController.removeRowGroupColumn(e,"api")},e.prototype.removeRowGroupColumns=function(e){this.columnController.removeRowGroupColumns(e,"api")},e.prototype.addRowGroupColumn=function(e){this.columnController.addRowGroupColumn(e,"api")},e.prototype.addRowGroupColumns=function(e){this.columnController.addRowGroupColumns(e,"api")},e.prototype.getRowGroupColumns=function(){return this.columnController.getRowGroupColumns()},e.prototype.setPivotColumns=function(e){this.columnController.setPivotColumns(e,"api")},e.prototype.removePivotColumn=function(e){this.columnController.removePivotColumn(e,"api")},e.prototype.removePivotColumns=function(e){this.columnController.removePivotColumns(e,"api")},e.prototype.addPivotColumn=function(e){this.columnController.addPivotColumn(e,"api")},e.prototype.addPivotColumns=function(e){this.columnController.addPivotColumns(e,"api")},e.prototype.getPivotColumns=function(){return this.columnController.getPivotColumns()},e.prototype.getLeftDisplayedColumnGroups=function(){return this.columnController.getLeftDisplayedColumnGroups()},e.prototype.getCenterDisplayedColumnGroups=function(){return this.columnController.getCenterDisplayedColumnGroups()},e.prototype.getRightDisplayedColumnGroups=function(){return this.columnController.getRightDisplayedColumnGroups()},e.prototype.getAllDisplayedColumnGroups=function(){return this.columnController.getAllDisplayedColumnGroups()},e.prototype.autoSizeColumn=function(e,t){return this.columnController.autoSizeColumn(e,t,"api")},e.prototype.autoSizeColumns=function(e,t){return this.columnController.autoSizeColumns(e,t,"api")},e.prototype.autoSizeAllColumns=function(e){this.columnController.autoSizeAllColumns(e,"api")},e.prototype.setSecondaryColumns=function(e){this.columnController.setSecondaryColumns(e,"api")},e.prototype.getSecondaryColumns=function(){return this.columnController.getSecondaryColumns()},e.prototype.getPrimaryColumns=function(){return this.columnController.getAllPrimaryColumns()},e.prototype.columnGroupOpened=function(e,t){console.error("ag-Grid: columnGroupOpened no longer exists, use setColumnGroupOpened"),this.setColumnGroupOpened(e,t)},e.prototype.hideColumns=function(e,t){console.error("ag-Grid: hideColumns is deprecated, use setColumnsVisible"),this.columnController.setColumnsVisible(e,!t,"api")},e.prototype.hideColumn=function(e,t){console.error("ag-Grid: hideColumn is deprecated, use setColumnVisible"),this.columnController.setColumnVisible(e,!t,"api")},e.prototype.setState=function(e){return console.error("ag-Grid: setState is deprecated, use setColumnState"),this.setColumnState(e)},e.prototype.getState=function(){return console.error("ag-Grid: getState is deprecated, use getColumnState"),this.getColumnState()},e.prototype.resetState=function(){console.error("ag-Grid: resetState is deprecated, use resetColumnState"),this.resetColumnState()},e.prototype.getAggregationColumns=function(){return console.error("ag-Grid: getAggregationColumns is deprecated, use getValueColumns"),this.columnController.getValueColumns()},e.prototype.removeAggregationColumn=function(e){console.error("ag-Grid: removeAggregationColumn is deprecated, use removeValueColumn"),this.columnController.removeValueColumn(e,"api")},e.prototype.removeAggregationColumns=function(e){console.error("ag-Grid: removeAggregationColumns is deprecated, use removeValueColumns"),this.columnController.removeValueColumns(e,"api")},e.prototype.addAggregationColumn=function(e){console.error("ag-Grid: addAggregationColumn is deprecated, use addValueColumn"),this.columnController.addValueColumn(e,"api")},e.prototype.addAggregationColumns=function(e){console.error("ag-Grid: addAggregationColumns is deprecated, use addValueColumns"),this.columnController.addValueColumns(e,"api")},e.prototype.setColumnAggFunction=function(e,t){console.error("ag-Grid: setColumnAggFunction is deprecated, use setColumnAggFunc"),this.columnController.setColumnAggFunc(e,t,"api")},e.prototype.getDisplayNameForCol=function(e){return console.error("ag-Grid: getDisplayNameForCol is deprecated, use getDisplayNameForColumn"),this.getDisplayNameForColumn(e,null)},a([Object(r.a)("columnController")],e.prototype,"columnController",void 0),e=a([Object(r.b)("columnApi")],e)}()},function(e,t,o){"use strict";o.d(t,"a",(function(){return m}));var r,a=o(15),n=o(47),i=o(12),l=o(4),g=o(2),s=o(35),p=o(1),c=o(6),d=o(0),u=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),h=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},f=function(e,t){return function(o,r){t(o,r,e)}},m=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.destroyFuncsForColumnListeners=[],t.rowCompsByIndex={},t.floatingTopRowComps=[],t.floatingBottomRowComps=[],t.refreshInProgress=!1,t}return u(t,e),t.prototype.registerGridCore=function(e){this.gridCore=e},t.prototype.getGridCore=function(){return this.gridCore},t.prototype.agWire=function(e){this.logger=e.create("RowRenderer")},t.prototype.registerGridComp=function(e){this.gridPanel=e,this.rowContainers=this.gridPanel.getRowContainers(),this.addManagedListener(this.eventService,l.a.EVENT_PAGINATION_CHANGED,this.onPageLoaded.bind(this)),this.addManagedListener(this.eventService,l.a.EVENT_PINNED_ROW_DATA_CHANGED,this.onPinnedRowDataChanged.bind(this)),this.addManagedListener(this.eventService,l.a.EVENT_DISPLAYED_COLUMNS_CHANGED,this.onDisplayedColumnsChanged.bind(this)),this.addManagedListener(this.eventService,l.a.EVENT_BODY_SCROLL,this.redrawAfterScroll.bind(this)),this.addManagedListener(this.eventService,l.a.EVENT_BODY_HEIGHT_CHANGED,this.redrawAfterScroll.bind(this)),this.addManagedListener(this.gridOptionsWrapper,a.a.PROP_DOM_LAYOUT,this.onDomLayoutChanged.bind(this)),this.registerCellEventListeners(),this.printLayout=this.gridOptionsWrapper.getDomLayout()===g.a.DOM_LAYOUT_PRINT,this.embedFullWidthRows=this.printLayout||this.gridOptionsWrapper.isEmbedFullWidthRows(),this.redrawAfterModelUpdate()},t.prototype.registerCellEventListeners=function(){var e=this;this.addManagedListener(this.eventService,l.a.EVENT_CELL_FOCUSED,(function(t){e.forEachCellComp((function(e){return e.onCellFocused(t)}))})),this.addManagedListener(this.eventService,l.a.EVENT_FLASH_CELLS,(function(t){e.forEachCellComp((function(e){return e.onFlashCells(t)}))})),this.addManagedListener(this.eventService,l.a.EVENT_COLUMN_HOVER_CHANGED,(function(){e.forEachCellComp((function(e){return e.onColumnHover()}))})),this.addManagedListener(this.eventService,l.a.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED,(function(){e.printLayout&&e.forEachCellComp((function(e){return e.onLeftChanged()}))})),this.gridOptionsWrapper.isEnableRangeSelection()&&(this.addManagedListener(this.eventService,l.a.EVENT_RANGE_SELECTION_CHANGED,(function(){e.forEachCellComp((function(e){return e.onRangeSelectionChanged()}))})),this.addManagedListener(this.eventService,l.a.EVENT_COLUMN_MOVED,(function(){e.forEachCellComp((function(e){return e.updateRangeBordersIfRangeCount()}))})),this.addManagedListener(this.eventService,l.a.EVENT_COLUMN_PINNED,(function(){e.forEachCellComp((function(e){return e.updateRangeBordersIfRangeCount()}))})),this.addManagedListener(this.eventService,l.a.EVENT_COLUMN_VISIBLE,(function(){e.forEachCellComp((function(e){return e.updateRangeBordersIfRangeCount()}))}))),this.refreshListenersToColumnsForCellComps(),this.addManagedListener(this.eventService,l.a.EVENT_GRID_COLUMNS_CHANGED,this.refreshListenersToColumnsForCellComps.bind(this)),this.addDestroyFunc(this.removeGridColumnListeners.bind(this))},t.prototype.removeGridColumnListeners=function(){this.destroyFuncsForColumnListeners.forEach((function(e){return e()})),this.destroyFuncsForColumnListeners.length=0},t.prototype.refreshListenersToColumnsForCellComps=function(){var e=this;this.removeGridColumnListeners();var t=this.columnController.getAllGridColumns();t&&t.forEach((function(t){var o=function(o){e.forEachCellComp((function(e){e.getColumn()===t&&o(e)}))},r=function(){o((function(e){return e.onLeftChanged()}))},a=function(){o((function(e){return e.onWidthChanged()}))},n=function(){o((function(e){return e.onFirstRightPinnedChanged()}))},l=function(){o((function(e){return e.onLastLeftPinnedChanged()}))};t.addEventListener(i.a.EVENT_LEFT_CHANGED,r),t.addEventListener(i.a.EVENT_WIDTH_CHANGED,a),t.addEventListener(i.a.EVENT_FIRST_RIGHT_PINNED_CHANGED,n),t.addEventListener(i.a.EVENT_LAST_LEFT_PINNED_CHANGED,l),e.destroyFuncsForColumnListeners.push((function(){t.removeEventListener(i.a.EVENT_LEFT_CHANGED,r),t.removeEventListener(i.a.EVENT_WIDTH_CHANGED,a),t.removeEventListener(i.a.EVENT_FIRST_RIGHT_PINNED_CHANGED,n),t.removeEventListener(i.a.EVENT_LAST_LEFT_PINNED_CHANGED,l)}))}))},t.prototype.onDomLayoutChanged=function(){var e=this.gridOptionsWrapper.getDomLayout()===g.a.DOM_LAYOUT_PRINT,t=e||this.gridOptionsWrapper.isEmbedFullWidthRows(),o=t!==this.embedFullWidthRows||this.printLayout!==e;this.printLayout=e,this.embedFullWidthRows=t,o&&this.redrawAfterModelUpdate()},t.prototype.datasourceChanged=function(){this.firstRenderedRow=0,this.lastRenderedRow=-1;var e=Object.keys(this.rowCompsByIndex);this.removeRowComps(e)},t.prototype.onPageLoaded=function(e){d.f.missing(e)&&(e={type:l.a.EVENT_MODEL_UPDATED,api:this.gridApi,columnApi:this.columnApi,animate:!1,keepRenderedRows:!1,newData:!1,newPage:!1}),this.onModelUpdated(e)},t.prototype.getAllCellsForColumn=function(e){var t=[];function o(o,r){var a=r.getCellForCol(e);a&&t.push(a)}return d.f.iterateObject(this.rowCompsByIndex,o),d.f.iterateObject(this.floatingBottomRowComps,o),d.f.iterateObject(this.floatingTopRowComps,o),t},t.prototype.refreshFloatingRowComps=function(){this.refreshFloatingRows(this.floatingTopRowComps,this.pinnedRowModel.getPinnedTopRowData(),this.rowContainers.floatingTopPinnedLeft,this.rowContainers.floatingTopPinnedRight,this.rowContainers.floatingTop,this.rowContainers.floatingTopFullWidth),this.refreshFloatingRows(this.floatingBottomRowComps,this.pinnedRowModel.getPinnedBottomRowData(),this.rowContainers.floatingBottomPinnedLeft,this.rowContainers.floatingBottomPinnedRight,this.rowContainers.floatingBottom,this.rowContainers.floatingBottomFullWidth)},t.prototype.refreshFloatingRows=function(e,t,o,r,a,i){var l=this;e.forEach((function(e){e.destroy()})),e.length=0,t&&t.forEach((function(t){var g=new n.a(l.$scope,a,o,r,i,t,l.beans,!1,!1,l.printLayout,l.embedFullWidthRows);g.init(),e.push(g)})),this.flushContainers(e)},t.prototype.onPinnedRowDataChanged=function(){this.redrawAfterModelUpdate({recycleRows:!0})},t.prototype.onModelUpdated=function(e){var t={recycleRows:e.keepRenderedRows,animate:e.animate,newData:e.newData,newPage:e.newPage,onlyBody:!0};this.redrawAfterModelUpdate(t)},t.prototype.getRenderedIndexesForRowNodes=function(e){var t=[];return d.f.missing(e)||d.f.iterateObject(this.rowCompsByIndex,(function(o,r){var a=r.getRowNode();e.indexOf(a)>=0&&t.push(o)})),t},t.prototype.redrawRows=function(e){if(e&&0!=e.length){var t=this.getRenderedIndexesForRowNodes(e);this.removeRowComps(t),this.redrawAfterModelUpdate({recycleRows:!0})}},t.prototype.getCellToRestoreFocusToAfterRefresh=function(e){var t=e.suppressKeepFocus?null:this.focusController.getFocusCellToUseAfterRefresh();if(d.f.missing(t))return null;var o=document.activeElement,r=this.gridOptionsWrapper.getDomData(o,s.a.DOM_DATA_KEY_CELL_COMP);return d.f.missing(r)?null:t},t.prototype.redrawAfterModelUpdate=function(e){void 0===e&&(e={}),this.getLockOnRefresh();var t=this.getCellToRestoreFocusToAfterRefresh(e);this.sizeContainerToPageHeight(),this.scrollToTopIfNewData(e);var o=!this.printLayout&&e.recycleRows,r=e.animate&&this.gridOptionsWrapper.isAnimateRows(),a=this.binRowComps(o);this.redraw(a,r),e.onlyBody||this.refreshFloatingRowComps(),this.restoreFocusedCell(t),this.releaseLockOnRefresh()},t.prototype.scrollToTopIfNewData=function(e){var t=e.newData||e.newPage,o=this.gridOptionsWrapper.isSuppressScrollOnNewData();t&&!o&&this.gridPanel.scrollToTop()},t.prototype.sizeContainerToPageHeight=function(){var e=[this.rowContainers.body,this.rowContainers.fullWidth,this.rowContainers.pinnedLeft,this.rowContainers.pinnedRight];if(this.printLayout)e.forEach((function(e){return e.setHeight(null)}));else{var t=this.paginationProxy.getCurrentPageHeight();0===t&&(t=1),this.maxDivHeightScaler.setModelHeight(t);var o=this.maxDivHeightScaler.getUiContainerHeight();e.forEach((function(e){return e.setHeight(o)}))}},t.prototype.getLockOnRefresh=function(){if(this.refreshInProgress)throw new Error("ag-Grid: cannot get grid to draw rows when it is in the middle of drawing rows. Your code probably called a grid API method while the grid was in the render stage. To overcome this, put the API call into a timeout, eg instead of api.refreshView(), call setTimeout(function(){api.refreshView(),0}). To see what part of your code that caused the refresh check this stacktrace.");this.refreshInProgress=!0},t.prototype.releaseLockOnRefresh=function(){this.refreshInProgress=!1},t.prototype.restoreFocusedCell=function(e){e&&this.focusController.setFocusedCell(e.rowIndex,e.column,e.rowPinned,!0)},t.prototype.stopEditing=function(e){void 0===e&&(e=!1),this.forEachRowComp((function(t,o){o.stopEditing(e)}))},t.prototype.forEachCellComp=function(e){this.forEachRowComp((function(t,o){return o.forEachCellComp(e)}))},t.prototype.forEachRowComp=function(e){d.f.iterateObject(this.rowCompsByIndex,e),d.f.iterateObject(this.floatingTopRowComps,e),d.f.iterateObject(this.floatingBottomRowComps,e)},t.prototype.addRenderedRowListener=function(e,t,o){var r=this.rowCompsByIndex[t];r&&r.addEventListener(e,o)},t.prototype.flashCells=function(e){void 0===e&&(e={});var t=e.flashDelay,o=e.fadeDelay;this.forEachCellCompFiltered(e.rowNodes,e.columns,(function(e){return e.flashCell({flashDelay:t,fadeDelay:o})}))},t.prototype.refreshCells=function(e){void 0===e&&(e={});var t={forceRefresh:e.force,newData:!1,suppressFlash:e.suppressFlash};this.forEachCellCompFiltered(e.rowNodes,e.columns,(function(e){return e.refreshCell(t)}))},t.prototype.getCellRendererInstances=function(e){var t=[];return this.forEachCellCompFiltered(e.rowNodes,e.columns,(function(e){var o=e.getCellRenderer();o&&t.push(o)})),t},t.prototype.getCellEditorInstances=function(e){var t=[];return this.forEachCellCompFiltered(e.rowNodes,e.columns,(function(e){var o=e.getCellEditor();o&&t.push(o)})),t},t.prototype.getEditingCells=function(){var e=[];return this.forEachCellComp((function(t){if(t.isEditing()){var o=t.getCellPosition();e.push(o)}})),e},t.prototype.forEachCellCompFiltered=function(e,t,o){var r,a,n=this;d.f.exists(e)&&(r={top:{},bottom:{},normal:{}},e.forEach((function(e){e.rowPinned===g.a.PINNED_TOP?r.top[e.id]=!0:e.rowPinned===g.a.PINNED_BOTTOM?r.bottom[e.id]=!0:r.normal[e.id]=!0}))),d.f.exists(t)&&(a={},t.forEach((function(e){var t=n.columnController.getGridColumn(e);d.f.exists(t)&&(a[t.getId()]=!0)})));var i=function(e){var t=e.getRowNode(),n=t.id,i=t.rowPinned;if(d.f.exists(r))if(i===g.a.PINNED_BOTTOM){if(!r.bottom[n])return}else if(i===g.a.PINNED_TOP){if(!r.top[n])return}else if(!r.normal[n])return;e.forEachCellComp((function(e){var t=e.getColumn().getId();a&&!a[t]||o(e)}))};d.f.iterateObject(this.rowCompsByIndex,(function(e,t){i(t)})),this.floatingTopRowComps&&this.floatingTopRowComps.forEach(i),this.floatingBottomRowComps&&this.floatingBottomRowComps.forEach(i)},t.prototype.destroy=function(){var t=Object.keys(this.rowCompsByIndex);this.removeRowComps(t),e.prototype.destroy.call(this)},t.prototype.binRowComps=function(e){var t,o=this,r={};return e?(t=[],d.f.iterateObject(this.rowCompsByIndex,(function(e,a){var n=a.getRowNode();d.f.exists(n.id)?(r[n.id]=a,delete o.rowCompsByIndex[e]):t.push(e)}))):t=Object.keys(this.rowCompsByIndex),this.removeRowComps(t),r},t.prototype.removeRowComps=function(e){var t=this;e.forEach((function(e){t.rowCompsByIndex[e].destroy(),delete t.rowCompsByIndex[e]}))},t.prototype.redrawAfterScroll=function(){this.getLockOnRefresh(),this.redraw(null,!1,!0),this.releaseLockOnRefresh()},t.prototype.removeRowCompsNotToDraw=function(e){var t={};e.forEach((function(e){return t[e]=!0}));var o=Object.keys(this.rowCompsByIndex).filter((function(e){return!t[e]}));this.removeRowComps(o)},t.prototype.calculateIndexesToDraw=function(e){var t=this,o=d.f.createArrayOfNumbers(this.firstRenderedRow,this.lastRenderedRow),r=function(e,r){var a=Number(e);(at.lastRenderedRow)&&t.doNotUnVirtualiseRow(r)&&o.push(a)};return d.f.iterateObject(this.rowCompsByIndex,r),d.f.iterateObject(e,r),o.sort((function(e,t){return e-t})),o},t.prototype.redraw=function(e,t,o){var r=this;void 0===t&&(t=!1),void 0===o&&(o=!1),this.maxDivHeightScaler.updateOffset(),this.workOutFirstAndLastRowsToRender();var a=this.calculateIndexesToDraw(e);this.removeRowCompsNotToDraw(a),this.printLayout&&(t=!1);var n=[],i=[];a.forEach((function(a){var l=r.createOrUpdateRowComp(a,e,t,o);d.f.exists(l)&&(i.push(l),d.f.pushAll(n,l.getAndClearNextVMTurnFunctions()))})),this.flushContainers(i),d.f.executeNextVMTurn(n),o&&!this.gridOptionsWrapper.isSuppressAnimationFrame()&&!this.printLayout?this.beans.taskQueue.addDestroyTask(this.destroyRowComps.bind(this,e,t)):this.destroyRowComps(e,t),this.checkAngularCompile(),this.gridPanel.updateRowCount()},t.prototype.flushContainers=function(e){d.f.iterateObject(this.rowContainers,(function(e,t){t&&t.flushRowTemplates()})),e.forEach((function(e){return e.afterFlush()}))},t.prototype.onDisplayedColumnsChanged=function(){var e=this.columnController.isPinningLeft(),t=this.columnController.isPinningRight();(this.pinningLeft!==e||t!==this.pinningRight)&&(this.pinningLeft=e,this.pinningRight=t,this.embedFullWidthRows&&this.redrawFullWidthEmbeddedRows())},t.prototype.redrawFullWidthEmbeddedRows=function(){var e=[];d.f.iterateObject(this.rowCompsByIndex,(function(t,o){if(o.isFullWidth()){var r=o.getRowNode().rowIndex;e.push(r.toString())}})),this.refreshFloatingRowComps(),this.removeRowComps(e),this.redrawAfterScroll()},t.prototype.refreshFullWidthRows=function(){var e=[];d.f.iterateObject(this.rowCompsByIndex,(function(t,o){if(o.isFullWidth()&&!o.refreshFullWidth()){var r=o.getRowNode().rowIndex;e.push(r.toString())}})),this.removeRowComps(e),this.redrawAfterScroll()},t.prototype.createOrUpdateRowComp=function(e,t,o,r){var a,n=this.rowCompsByIndex[e];if(n||(a=this.paginationProxy.getRow(e),d.f.exists(a)&&d.f.exists(t)&&t[a.id]&&a.alreadyRendered&&(n=t[a.id],t[a.id]=null)),!n){if(a||(a=this.paginationProxy.getRow(e)),!d.f.exists(a))return;n=this.createRowComp(a,o,r)}else n.ensureDomOrder();return a&&(a.alreadyRendered=!0),this.rowCompsByIndex[e]=n,n},t.prototype.destroyRowComps=function(e,t){var o=[];d.f.iterateObject(e,(function(e,r){r&&(r.destroy(t),d.f.pushAll(o,r.getAndClearDelayedDestroyFunctions()))})),d.f.executeInAWhile(o)},t.prototype.checkAngularCompile=function(){var e=this;this.gridOptionsWrapper.isAngularCompileRows()&&window.setTimeout((function(){e.$scope.$apply()}),0)},t.prototype.workOutFirstAndLastRowsToRender=function(){var e,t,o=this;if(this.paginationProxy.isRowsToRender())if(this.printLayout)e=this.paginationProxy.getPageFirstRow(),t=this.paginationProxy.getPageLastRow();else{var r=this.paginationProxy.getPixelOffset(),a=this.maxDivHeightScaler.getOffset(),n=this.gridPanel.getVScrollPosition(),i=n.top,s=n.bottom,p=this.gridOptionsWrapper.getRowBufferInPixels(),c=i+r+a-p,d=s+r+a+p;this.ensureAllRowsInRangeHaveHeightsCalculated(c,d);var u=this.paginationProxy.getRowIndexAtPixel(c),h=this.paginationProxy.getRowIndexAtPixel(d),f=this.paginationProxy.getPageFirstRow(),m=this.paginationProxy.getPageLastRow();um&&(h=m),e=u,t=h}else e=0,t=-1;var b=this.gridOptionsWrapper.getDomLayout()===g.a.DOM_LAYOUT_NORMAL,v=this.gridOptionsWrapper.isSuppressMaxRenderedRowRestriction(),y=Math.max(this.gridOptionsWrapper.getRowBuffer(),500);b&&!v&&t-e>y&&(t=e+y);var w=e!==this.firstRenderedRow,x=t!==this.lastRenderedRow;if(w||x){this.firstRenderedRow=e,this.lastRenderedRow=t;var C={type:l.a.EVENT_VIEWPORT_CHANGED,firstRow:e,lastRow:t,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(C)}if(this.paginationProxy.isRowsToRender()){var k={type:l.a.EVENT_FIRST_DATA_RENDERED,firstRow:e,lastRow:t,api:this.gridApi,columnApi:this.columnApi};window.setTimeout((function(){return o.eventService.dispatchEventOnce(k)}),50)}},t.prototype.ensureAllRowsInRangeHaveHeightsCalculated=function(e,t){this.paginationProxy.ensureRowHeightsValid(e,t,-1,-1)&&(this.sizeContainerToPageHeight(),this.maxDivHeightScaler.updateOffset())},t.prototype.getFirstVirtualRenderedRow=function(){return this.firstRenderedRow},t.prototype.getLastVirtualRenderedRow=function(){return this.lastRenderedRow},t.prototype.doNotUnVirtualiseRow=function(e){var t=e.getRowNode(),o=this.focusController.isRowNodeFocused(t),r=e.isEditing(),a=t.detail;return!!(o||r||a)&&!!this.paginationProxy.isRowPresent(t)},t.prototype.createRowComp=function(e,t,o){var r=this.gridOptionsWrapper.isSuppressAnimationFrame(),a=o&&!r&&!this.printLayout,i=new n.a(this.$scope,this.rowContainers.body,this.rowContainers.pinnedLeft,this.rowContainers.pinnedRight,this.rowContainers.fullWidth,e,this.beans,t,a,this.printLayout,this.embedFullWidthRows);return i.init(),i},t.prototype.getRenderedNodes=function(){var e=this.rowCompsByIndex;return Object.keys(e).map((function(t){return e[t].getRowNode()}))},t.prototype.navigateToNextCell=function(e,t,o,r){for(var a=o,n=!1;a&&(a===o||!this.isValidNavigateCell(a));)this.gridOptionsWrapper.isEnableRtl()?t===g.a.KEY_LEFT&&(a=this.getLastCellOfColSpan(a)):t===g.a.KEY_RIGHT&&(a=this.getLastCellOfColSpan(a)),a=this.cellNavigationService.getNextCellToFocus(t,a),n=d.f.missing(a);if(n&&e.keyCode===g.a.KEY_UP&&(a={rowIndex:-1,rowPinned:null,column:o.column}),r){var i=this.gridOptionsWrapper.getNavigateToNextCellFunc();if(d.f.exists(i)){var l=i({key:t,previousCellPosition:o,nextCellPosition:a||null,event:e});d.f.exists(l)?(l.floating&&(d.f.doOnce((function(){console.warn("ag-Grid: tabToNextCellFunc return type should have attributes: rowIndex, rowPinned, column. However you had 'floating', maybe you meant 'rowPinned'?")}),"no floating in userCell"),l.rowPinned=l.floating),a={rowPinned:l.rowPinned,rowIndex:l.rowIndex,column:l.column}):a=null}}if(a)if(a.rowIndex<0){var s=this.beans.headerNavigationService.getHeaderRowCount();this.focusController.focusHeaderPosition({headerRowIndex:s+a.rowIndex,column:o.column})}else{this.ensureCellVisible(a);var p=this.getComponentForCell(a);p&&(a=p.getCellPosition(),this.ensureCellVisible(a),this.focusController.setFocusedCell(a.rowIndex,a.column,a.rowPinned,!0),this.rangeController&&this.rangeController.setRangeToCell(a))}},t.prototype.isValidNavigateCell=function(e){var t=this.rowPositionUtils.getRowNode(e);if(t.detail||t.isFullWidthCell())return!1;if(!t.group)return!0;var o=this.columnController.isPivotMode();return!this.gridOptionsWrapper.isGroupUseEntireRow(o)},t.prototype.getLastCellOfColSpan=function(e){var t=this.getComponentForCell(e);if(!t)return e;var o=t.getColSpanningList();return 1===o.length?e:{rowIndex:e.rowIndex,column:d.f.last(o),rowPinned:e.rowPinned}},t.prototype.ensureCellVisible=function(e){d.f.missing(e.rowPinned)&&this.gridPanel.ensureIndexVisible(e.rowIndex),e.column.isPinned()||this.gridPanel.ensureColumnVisible(e.column),this.gridPanel.horizontallyScrollHeaderCenterAndFloatingCenter(),this.animationFrameService.flushAllFrames()},t.prototype.startEditingCell=function(e,t,o){var r=this.getComponentForCell(e);r&&r.startRowOrCellEdit(t,o)},t.prototype.getComponentForCell=function(e){var t;switch(e.rowPinned){case g.a.PINNED_TOP:t=this.floatingTopRowComps[e.rowIndex];break;case g.a.PINNED_BOTTOM:t=this.floatingBottomRowComps[e.rowIndex];break;default:t=this.rowCompsByIndex[e.rowIndex]}return t?t.getRenderedCellForColumn(e.column):null},t.prototype.getRowNode=function(e){switch(e.rowPinned){case g.a.PINNED_TOP:return this.pinnedRowModel.getPinnedTopRowData()[e.rowIndex];case g.a.PINNED_BOTTOM:return this.pinnedRowModel.getPinnedBottomRowData()[e.rowIndex];default:return this.rowModel.getRow(e.rowIndex)}},t.prototype.onTabKeyDown=function(e,t){var o=t.shiftKey;if(this.moveToCellAfter(e,o))t.preventDefault();else if(t.shiftKey){0===e.getCellPosition().rowIndex&&(t.preventDefault(),this.focusController.focusHeaderPosition({headerRowIndex:this.beans.headerNavigationService.getHeaderRowCount()-1,column:d.f.last(this.columnController.getAllDisplayedColumns())}))}},t.prototype.tabToNextCell=function(e){var t=this.focusController.getFocusedCell();if(d.f.missing(t))return!1;var o=this.getComponentForCell(t);return!d.f.missing(o)&&this.moveToCellAfter(o,e)},t.prototype.moveToCellAfter=function(e,t){return e.isEditing()?this.gridOptionsWrapper.isFullRowEdit()?this.moveToNextEditingRow(e,t):this.moveToNextEditingCell(e,t):this.moveToNextCellNotEditing(e,t)},t.prototype.moveToNextEditingCell=function(e,t){var o=e.getCellPosition();e.stopEditing();var r=this.findNextCellToFocusOn(o,t,!0),a=d.f.exists(r);return a&&(r.startEditingIfEnabled(null,null,!0),r.focusCell(!1)),a},t.prototype.moveToNextEditingRow=function(e,t){var o=e.getCellPosition(),r=this.findNextCellToFocusOn(o,t,!0),a=d.f.exists(r);return a&&this.moveEditToNextCellOrRow(e,r),a},t.prototype.moveToNextCellNotEditing=function(e,t){var o=e.getCellPosition(),r=this.findNextCellToFocusOn(o,t,!1),a=d.f.exists(r);return a&&r.focusCell(!0),a},t.prototype.moveEditToNextCellOrRow=function(e,t){var o=e.getCellPosition(),r=t.getCellPosition();if(o.rowIndex===r.rowIndex&&o.rowPinned===r.rowPinned)e.setFocusOutOnEditor(),t.setFocusInOnEditor();else{var a=e.getRenderedRow(),n=t.getRenderedRow();e.setFocusOutOnEditor(),a.stopEditing(),n.startRowEditing(),t.setFocusInOnEditor()}t.focusCell()},t.prototype.findNextCellToFocusOn=function(e,t,o){for(var r=e;;){t||(r=this.getLastCellOfColSpan(r)),r=this.cellNavigationService.getNextTabbedCell(r,t);var a=this.gridOptionsWrapper.getTabToNextCellFunc();if(d.f.exists(a)){var n=a({backwards:t,editing:o,previousCellPosition:e,nextCellPosition:r||null});d.f.exists(n)?(n.floating&&(d.f.doOnce((function(){console.warn("ag-Grid: tabToNextCellFunc return type should have attributes: rowIndex, rowPinned, column. However you had 'floating', maybe you meant 'rowPinned'?")}),"no floating in userCell"),n.rowPinned=n.floating),r={rowIndex:n.rowIndex,column:n.column,rowPinned:n.rowPinned}):r=null}if(!r)return null;if(o){var i=this.lookupRowNodeForCell(r);if(!r.column.isCellEditable(i))continue}d.f.missing(r.rowPinned)&&this.gridPanel.ensureIndexVisible(r.rowIndex),r.column.isPinned()||this.gridPanel.ensureColumnVisible(r.column),this.gridPanel.horizontallyScrollHeaderCenterAndFloatingCenter(),this.animationFrameService.flushAllFrames();var l=this.getComponentForCell(r);if(!d.f.missing(l)&&!l.isSuppressNavigable())return this.rangeController&&this.rangeController.setRangeToCell(r),l}},t.prototype.lookupRowNodeForCell=function(e){return e.rowPinned===g.a.PINNED_TOP?this.pinnedRowModel.getPinnedTopRow(e.rowIndex):e.rowPinned===g.a.PINNED_BOTTOM?this.pinnedRowModel.getPinnedBottomRow(e.rowIndex):this.paginationProxy.getRow(e.rowIndex)},h([Object(p.a)("paginationProxy")],t.prototype,"paginationProxy",void 0),h([Object(p.a)("columnController")],t.prototype,"columnController",void 0),h([Object(p.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),h([Object(p.a)("$scope")],t.prototype,"$scope",void 0),h([Object(p.a)("pinnedRowModel")],t.prototype,"pinnedRowModel",void 0),h([Object(p.a)("rowModel")],t.prototype,"rowModel",void 0),h([Object(p.a)("loggerFactory")],t.prototype,"loggerFactory",void 0),h([Object(p.a)("focusController")],t.prototype,"focusController",void 0),h([Object(p.a)("cellNavigationService")],t.prototype,"cellNavigationService",void 0),h([Object(p.a)("columnApi")],t.prototype,"columnApi",void 0),h([Object(p.a)("gridApi")],t.prototype,"gridApi",void 0),h([Object(p.a)("beans")],t.prototype,"beans",void 0),h([Object(p.a)("maxDivHeightScaler")],t.prototype,"maxDivHeightScaler",void 0),h([Object(p.a)("animationFrameService")],t.prototype,"animationFrameService",void 0),h([Object(p.a)("rowPositionUtils")],t.prototype,"rowPositionUtils",void 0),h([Object(p.d)("rangeController")],t.prototype,"rangeController",void 0),h([f(0,Object(p.h)("loggerFactory"))],t.prototype,"agWire",null),t=h([Object(p.b)("rowRenderer")],t)}(c.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return s}));var r,a=o(33),n=o(1),i=o(0),l=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),g=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},s=function(e){function t(t){var o=e.call(this,'
')||this;return o.getGuiCalledOnChild=!1,o.cellEditor=t,o}return l(t,e),t.prototype.onKeyDown=function(e){i.f.isUserSuppressingKeyboardEvent(this.gridOptionsWrapper,e,this.params.node,this.params.column,!0)||this.params.onKeyDown(e)},t.prototype.getGui=function(){return this.getGuiCalledOnChild||(this.appendChild(this.cellEditor.getGui()),this.getGuiCalledOnChild=!0),e.prototype.getGui.call(this)},t.prototype.init=function(o){var r=this;this.params=o,this.gridOptionsWrapper.setDomData(this.getGui(),t.DOM_KEY_POPUP_EDITOR_WRAPPER,!0),this.addDestroyFunc((function(){return r.destroyBean(r.cellEditor)})),this.addManagedListener(e.prototype.getGui.call(this),"keydown",this.onKeyDown.bind(this))},t.prototype.afterGuiAttached=function(){this.cellEditor.afterGuiAttached&&this.cellEditor.afterGuiAttached()},t.prototype.getValue=function(){return this.cellEditor.getValue()},t.prototype.isCancelBeforeStart=function(){if(this.cellEditor.isCancelBeforeStart)return this.cellEditor.isCancelBeforeStart()},t.prototype.isCancelAfterEnd=function(){if(this.cellEditor.isCancelAfterEnd)return this.cellEditor.isCancelAfterEnd()},t.prototype.getPopupPosition=function(){if(this.cellEditor.getPopupPosition)return this.cellEditor.getPopupPosition()},t.prototype.focusIn=function(){this.cellEditor.focusIn&&this.cellEditor.focusIn()},t.prototype.focusOut=function(){this.cellEditor.focusOut&&this.cellEditor.focusOut()},t.DOM_KEY_POPUP_EDITOR_WRAPPER="popupEditorWrapper",g([Object(n.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),t}(a.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return m}));var r,a=o(15),n=o(1),i=o(68),l=o(4),g=o(5),s=o(2),p=o(8),c=o(29),d=o(34),u=o(0),h=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),f=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},m=function(e){function t(){var o=e.call(this,t.TEMPLATE)||this;return o.headerContainers=new Map,o}return h(t,e),t.prototype.postConstruct=function(){var t=this;e.prototype.postConstruct.call(this),this.printLayout=this.gridOptionsWrapper.getDomLayout()===s.a.DOM_LAYOUT_PRINT,this.gridApi.registerHeaderRootComp(this),this.autoWidthCalculator.registerHeaderRootComp(this),this.registerHeaderContainer(new i.a(this.eHeaderContainer,this.eHeaderViewport,null),"center"),this.registerHeaderContainer(new i.a(this.ePinnedLeftHeader,null,s.a.PINNED_LEFT),"left"),this.registerHeaderContainer(new i.a(this.ePinnedRightHeader,null,s.a.PINNED_RIGHT),"right"),this.headerContainers.forEach((function(e){return t.createManagedBean(e)})),this.headerNavigationService.registerHeaderRoot(this),this.addManagedListener(this.eventService,l.a.EVENT_COLUMN_VALUE_CHANGED,this.refreshHeader.bind(this)),this.addManagedListener(this.gridOptionsWrapper,a.a.PROP_DOM_LAYOUT,this.onDomLayoutChanged.bind(this)),this.addManagedListener(this.eventService,l.a.EVENT_COLUMN_PIVOT_MODE_CHANGED,this.onPivotModeChanged.bind(this)),this.onPivotModeChanged(),this.addPreventHeaderScroll(),this.columnController.isReady()&&this.refreshHeader()},t.prototype.registerGridComp=function(e){this.gridPanel=e,this.headerContainers.forEach((function(t){return t.setupDragAndDrop(e)}))},t.prototype.registerHeaderContainer=function(e,t){this.headerContainers.set(t,e)},t.prototype.onTabKeyDown=function(e){var t=this.gridOptionsWrapper.isEnableRtl(),o=e.shiftKey!==t?d.a.LEFT:d.a.RIGHT;(this.headerNavigationService.navigateHorizontally(o,!0)||this.focusController.focusNextGridCoreContainer(e.shiftKey))&&e.preventDefault()},t.prototype.handleKeyDown=function(e){var t;switch(e.keyCode){case s.a.KEY_LEFT:t=d.a.LEFT;case s.a.KEY_RIGHT:u.f.exists(t)||(t=d.a.RIGHT),this.headerNavigationService.navigateHorizontally(t);break;case s.a.KEY_UP:t=d.a.UP;case s.a.KEY_DOWN:u.f.exists(t)||(t=d.a.DOWN),this.headerNavigationService.navigateVertically(t)&&e.preventDefault();break;default:return}},t.prototype.onFocusOut=function(e){var t=e.relatedTarget,o=this.getGui();!t&&o.contains(document.activeElement)||o.contains(t)||this.focusController.clearFocusedHeader()},t.prototype.onDomLayoutChanged=function(){var e=this.gridOptionsWrapper.getDomLayout()===s.a.DOM_LAYOUT_PRINT;this.printLayout!==e&&(this.printLayout=e,this.refreshHeader())},t.prototype.setHorizontalScroll=function(e){this.eHeaderContainer.style.transform="translateX("+e+"px)"},t.prototype.forEachHeaderElement=function(e){this.headerContainers.forEach((function(t){return t.forEachHeaderElement(e)}))},t.prototype.refreshHeader=function(){this.headerContainers.forEach((function(e){return e.refresh()}))},t.prototype.onPivotModeChanged=function(){var e=this.columnController.isPivotMode();Object(p.addOrRemoveCssClass)(this.getGui(),"ag-pivot-on",e),Object(p.addOrRemoveCssClass)(this.getGui(),"ag-pivot-off",!e)},t.prototype.setHeight=function(e){var t=e+1+"px";this.getGui().style.height=t,this.getGui().style.minHeight=t},t.prototype.addPreventHeaderScroll=function(){var e=this;this.addManagedListener(this.eHeaderViewport,"scroll",(function(){var t=e.eHeaderViewport.scrollLeft;0!==t&&(e.gridPanel.scrollHorizontally(t),e.eHeaderViewport.scrollLeft=0)}))},t.prototype.getHeaderContainers=function(){return this.headerContainers},t.prototype.setHeaderContainerWidth=function(e){this.eHeaderContainer.style.width=e+"px"},t.prototype.setLeftVisible=function(e){Object(p.setDisplayed)(this.ePinnedLeftHeader,e)},t.prototype.setRightVisible=function(e){Object(p.setDisplayed)(this.ePinnedRightHeader,e)},t.TEMPLATE='',f([Object(g.d)("ePinnedLeftHeader")],t.prototype,"ePinnedLeftHeader",void 0),f([Object(g.d)("ePinnedRightHeader")],t.prototype,"ePinnedRightHeader",void 0),f([Object(g.d)("eHeaderContainer")],t.prototype,"eHeaderContainer",void 0),f([Object(g.d)("eHeaderViewport")],t.prototype,"eHeaderViewport",void 0),f([Object(n.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),f([Object(n.a)("columnController")],t.prototype,"columnController",void 0),f([Object(n.a)("gridApi")],t.prototype,"gridApi",void 0),f([Object(n.a)("autoWidthCalculator")],t.prototype,"autoWidthCalculator",void 0),f([Object(n.a)("headerNavigationService")],t.prototype,"headerNavigationService",void 0),t}(c.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return u}));var r,a,n=o(13),i=o(1),l=o(90),g=o(91),s=o(2),p=o(6),c=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),d=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i};!function(e){e[e.ColumnMove=0]="ColumnMove",e[e.Pivot=1]="Pivot"}(a||(a={}));var u=function(e){function t(t,o){var r=e.call(this)||this;return r.dropListeners={},r.pinned=t,r.eContainer=o,r}return c(t,e),t.prototype.registerGridComp=function(e){switch(this.gridPanel=e,this.moveColumnController.registerGridComp(e),this.pinned){case s.a.PINNED_LEFT:this.eSecondaryContainers=this.gridPanel.getDropTargetLeftContainers();break;case s.a.PINNED_RIGHT:this.eSecondaryContainers=this.gridPanel.getDropTargetRightContainers();break;default:this.eSecondaryContainers=this.gridPanel.getDropTargetBodyContainers()}},t.prototype.isInterestedIn=function(e){return e===n.b.HeaderCell||e===n.b.ToolPanel&&this.gridOptionsWrapper.isAllowDragFromColumnsToolPanel()},t.prototype.getSecondaryContainers=function(){return this.eSecondaryContainers},t.prototype.getContainer=function(){return this.eContainer},t.prototype.init=function(){this.moveColumnController=this.createBean(new l.a(this.pinned,this.eContainer));var e=new g.a(this.pinned);this.createBean(e),this.dropListeners[a.ColumnMove]=this.moveColumnController,this.dropListeners[a.Pivot]=e,this.dragAndDropService.addDropTarget(this)},t.prototype.getIconName=function(){return this.currentDropListener.getIconName()},t.prototype.getDropType=function(e){return this.columnController.isPivotMode()&&e.dragSource.type===n.b.ToolPanel?a.Pivot:a.ColumnMove},t.prototype.onDragEnter=function(e){var t=this.getDropType(e);this.currentDropListener=this.dropListeners[t],this.currentDropListener.onDragEnter(e)},t.prototype.onDragLeave=function(e){this.currentDropListener.onDragLeave(e)},t.prototype.onDragging=function(e){this.currentDropListener.onDragging(e)},t.prototype.onDragStop=function(e){this.currentDropListener.onDragStop(e)},d([Object(i.a)("dragAndDropService")],t.prototype,"dragAndDropService",void 0),d([Object(i.a)("columnController")],t.prototype,"columnController",void 0),d([Object(i.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),d([i.e],t.prototype,"init",null),t}(p.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return g}));var r=o(1),a=o(2),n=o(13),i=o(0),l=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},g=function(){function e(e,t){this.needToMoveLeft=!1,this.needToMoveRight=!1,this.pinned=e,this.eContainer=t,this.centerContainer=!i.f.exists(e)}return e.prototype.registerGridComp=function(e){this.gridPanel=e},e.prototype.init=function(){this.logger=this.loggerFactory.create("MoveColumnController")},e.prototype.getIconName=function(){return this.pinned?n.a.ICON_PINNED:n.a.ICON_MOVE},e.prototype.onDragEnter=function(e){var t=e.dragItem.columns;if(e.dragSource.type===n.b.ToolPanel)this.setColumnsVisible(t,!0,"uiColumnDragged");else{var o=e.dragItem.visibleState,r=t.filter((function(e){return o[e.getId()]}));this.setColumnsVisible(r,!0,"uiColumnDragged")}this.setColumnsPinned(t,this.pinned,"uiColumnDragged"),this.onDragging(e,!0)},e.prototype.onDragLeave=function(e){if(!this.gridOptionsWrapper.isSuppressDragLeaveHidesColumns()&&!e.fromNudge){var t=e.dragSource.getDragItem().columns;this.setColumnsVisible(t,!1,"uiColumnDragged")}this.ensureIntervalCleared()},e.prototype.setColumnsVisible=function(e,t,o){if(void 0===o&&(o="api"),e){var r=e.filter((function(e){return!e.getColDef().lockVisible}));this.columnController.setColumnsVisible(r,t,o)}},e.prototype.setColumnsPinned=function(e,t,o){if(void 0===o&&(o="api"),e){var r=e.filter((function(e){return!e.getColDef().lockPinned}));this.columnController.setColumnsPinned(r,t,o)}},e.prototype.onDragStop=function(){this.ensureIntervalCleared()},e.prototype.normaliseX=function(e){this.gridOptionsWrapper.isEnableRtl()&&(e=this.eContainer.clientWidth-e);return this.centerContainer&&(e+=this.gridPanel.getCenterViewportScrollLeft()),e},e.prototype.checkCenterForScrolling=function(e){if(this.centerContainer){var t=this.gridPanel.getCenterViewportScrollLeft(),o=t+this.gridPanel.getCenterWidth();this.gridOptionsWrapper.isEnableRtl()?(this.needToMoveRight=eo-50):(this.needToMoveLeft=eo-50),this.needToMoveLeft||this.needToMoveRight?this.ensureIntervalStarted():this.ensureIntervalCleared()}},e.prototype.onDragging=function(e,t){var o=this;if(void 0===t&&(t=!1),this.lastDraggingEvent=e,!i.f.missing(e.hDirection)){var r=this.normaliseX(e.x);t||this.checkCenterForScrolling(r);var a=this.normaliseDirection(e.hDirection),n=e.dragSource.type,l=e.dragSource.getDragItem().columns;l=l.filter((function(e){return!e.getColDef().lockPinned||e.getPinned()==o.pinned})),this.attemptMoveColumns(n,l,a,r,t)}},e.prototype.normaliseDirection=function(e){if(!this.gridOptionsWrapper.isEnableRtl())return e;switch(e){case n.c.Left:return n.c.Right;case n.c.Right:return n.c.Left;default:console.error("ag-Grid: Unknown direction "+e)}},e.prototype.calculateOldIndex=function(e){var t=this.columnController.getAllGridColumns(),o=i.f.sortNumerically(e.map((function(e){return t.indexOf(e)}))),r=o[0];return i.f.last(o)-r!==o.length-1?null:r},e.prototype.attemptMoveColumns=function(e,t,o,r,a){var i=o===n.c.Left,l=o===n.c.Right,g=this.calculateValidMoves(t,l,r),s=this.calculateOldIndex(t);if(0!==g.length){var p=g[0],c=null!==s&&!a;if(e==n.b.HeaderCell&&(c=null!==s),c){if(i&&p>=s)return;if(l&&p<=s)return}for(var d=0;d0){for(var u=0;u0){var h=g[p-1];r=s.indexOf(h)+1}else-1===(r=s.indexOf(g[0]))&&(r=0);var f=[r];if(t)for(var m=r+1,b=n.length-1;m<=b;)f.push(m),m++;else{m=r,b=n.length-1;for(var v=n[m];m<=b&&this.isColumnHidden(a,v);)m++,f.push(m),v=n[m];m=r-1;for(;m>=0;)f.push(m),m--}return f},e.prototype.isColumnHidden=function(e,t){return e.indexOf(t)<0},e.prototype.ensureIntervalStarted=function(){this.movingIntervalId||(this.intervalCount=0,this.failedMoveAttempts=0,this.movingIntervalId=window.setInterval(this.moveInterval.bind(this),100),this.needToMoveLeft?this.dragAndDropService.setGhostIcon(n.a.ICON_LEFT,!0):this.dragAndDropService.setGhostIcon(n.a.ICON_RIGHT,!0))},e.prototype.ensureIntervalCleared=function(){this.moveInterval&&(window.clearInterval(this.movingIntervalId),this.movingIntervalId=null,this.dragAndDropService.setGhostIcon(n.a.ICON_MOVE))},e.prototype.moveInterval=function(){var e,t;if(this.intervalCount++,(e=10+5*this.intervalCount)>100&&(e=100),this.needToMoveLeft?t=this.gridPanel.scrollHorizontally(-e):this.needToMoveRight&&(t=this.gridPanel.scrollHorizontally(e)),0!==t)this.onDragging(this.lastDraggingEvent),this.failedMoveAttempts=0;else{this.failedMoveAttempts++;var o=this.lastDraggingEvent.dragItem.columns.filter((function(e){return!e.getColDef().lockPinned}));if(o.length>0&&(this.dragAndDropService.setGhostIcon(n.a.ICON_PINNED),this.failedMoveAttempts>7)){var r=this.needToMoveLeft?a.a.PINNED_LEFT:a.a.PINNED_RIGHT;this.setColumnsPinned(o,r,"uiColumnDragged"),this.dragAndDropService.nudge()}}},l([Object(r.a)("loggerFactory")],e.prototype,"loggerFactory",void 0),l([Object(r.a)("columnController")],e.prototype,"columnController",void 0),l([Object(r.a)("dragAndDropService")],e.prototype,"dragAndDropService",void 0),l([Object(r.a)("gridOptionsWrapper")],e.prototype,"gridOptionsWrapper",void 0),l([r.e],e.prototype,"init",null),e}()},function(e,t,o){"use strict";o.d(t,"a",(function(){return i}));var r=o(13),a=o(1),n=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},i=function(){function e(e){this.columnsToAggregate=[],this.columnsToGroup=[],this.columnsToPivot=[],this.pinned=e}return e.prototype.onDragEnter=function(e){var t=this;(this.clearColumnsList(),this.gridOptionsWrapper.isFunctionsReadOnly())||e.dragItem.columns.forEach((function(e){e.isPrimary()&&(e.isAnyFunctionActive()||(e.isAllowValue()?t.columnsToAggregate.push(e):e.isAllowRowGroup()?t.columnsToGroup.push(e):e.isAllowRowGroup()&&t.columnsToPivot.push(e)))}))},e.prototype.getIconName=function(){return this.columnsToAggregate.length+this.columnsToGroup.length+this.columnsToPivot.length>0?this.pinned?r.a.ICON_PINNED:r.a.ICON_MOVE:null},e.prototype.onDragLeave=function(e){this.clearColumnsList()},e.prototype.clearColumnsList=function(){this.columnsToAggregate.length=0,this.columnsToGroup.length=0,this.columnsToPivot.length=0},e.prototype.onDragging=function(e){},e.prototype.onDragStop=function(e){this.columnsToAggregate.length>0&&this.columnController.addValueColumns(this.columnsToAggregate,"toolPanelDragAndDrop"),this.columnsToGroup.length>0&&this.columnController.addRowGroupColumns(this.columnsToGroup,"toolPanelDragAndDrop"),this.columnsToPivot.length>0&&this.columnController.addPivotColumns(this.columnsToPivot,"toolPanelDragAndDrop")},n([Object(a.a)("columnController")],e.prototype,"columnController",void 0),n([Object(a.a)("gridOptionsWrapper")],e.prototype,"gridOptionsWrapper",void 0),e}()},function(e,t,o){"use strict";o.d(t,"a",(function(){return b}));var r,a=o(0),n=o(1),i=o(4),l=o(10),g=o(11),s=o(17),p=o(6),c=o(135),d=o(18),u=o(30),h=o(8),f=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),m=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},b=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.allFilters=new Map,t.quickFilter=null,t.quickFilterParts=null,t.processingFilterChange=!1,t}var o;return f(t,e),o=t,t.prototype.init=function(){this.addManagedListener(this.eventService,i.a.EVENT_ROW_DATA_CHANGED,this.onNewRowsLoaded.bind(this)),this.addManagedListener(this.eventService,i.a.EVENT_NEW_COLUMNS_LOADED,this.onNewColumnsLoaded.bind(this)),this.quickFilter=this.parseQuickFilter(this.gridOptionsWrapper.getQuickFilterText()),this.setQuickFilterParts(),this.allowShowChangeAfterFilter=this.gridOptionsWrapper.isAllowShowChangeAfterFilter(),this.checkExternalFilter()},t.prototype.setQuickFilterParts=function(){this.quickFilterParts=this.quickFilter?this.quickFilter.split(" "):null},t.prototype.setFilterModel=function(e){var t=this,o=[];if(e){var r=Object(c.convertToSet)(Object.keys(e));this.allFilters.forEach((function(a,n){var i=e[n];o.push(t.setModelOnFilterWrapper(a.filterPromise,i)),r.delete(n)})),r.forEach((function(r){var a=t.columnController.getPrimaryColumn(r);if(a){var n=t.getOrCreateFilterWrapper(a,"NO_UI");o.push(t.setModelOnFilterWrapper(n.filterPromise,e[r]))}else console.warn("Warning ag-grid setFilterModel - no column found for colId "+r)}))}else this.allFilters.forEach((function(e){o.push(t.setModelOnFilterWrapper(e.filterPromise,null))}));a.c.all(o).then((function(){return t.onFilterChanged()}))},t.prototype.setModelOnFilterWrapper=function(e,t){return new a.c((function(o){e.then((function(e){"function"!=typeof e.setModel&&(console.warn("Warning ag-grid - filter missing setModel method, which is needed for setFilterModel"),o());var r=e.setModel(t);null==r?o():r.then((function(){return o()}))}))}))},t.prototype.getFilterModel=function(){var e={};return this.allFilters.forEach((function(t,o){var r=t.filterPromise.resolveNow(null,(function(e){return e}));if(null==r)return null;if("function"==typeof r.getModel){var a=r.getModel();Object(d.exists)(a)&&(e[o]=a)}else console.warn("Warning ag-grid - filter API missing getModel method, which is needed for getFilterModel")})),e},t.prototype.isAdvancedFilterPresent=function(){return this.advancedFilterPresent},t.prototype.setAdvancedFilterPresent=function(){var e=!1;this.allFilters.forEach((function(t){e||t.filterPromise.resolveNow(!1,(function(e){return e.isFilterActive()}))&&(e=!0)})),this.advancedFilterPresent=e},t.prototype.updateFilterFlagInColumns=function(e,t){this.allFilters.forEach((function(o){var r=o.filterPromise.resolveNow(!1,(function(e){return e.isFilterActive()}));o.column.setFilterActive(r,e,t)}))},t.prototype.isAnyFilterPresent=function(){return this.isQuickFilterPresent()||this.advancedFilterPresent||this.externalFilterPresent},t.prototype.doesFilterPass=function(e,t){var o=e.data,r=!0;return this.allFilters.forEach((function(a){if(r&&null!=a){var n=a.filterPromise.resolveNow(void 0,(function(e){return e}));if(null!=n&&n!==t&&n.isFilterActive()){if(!n.doesFilterPass)throw new Error("Filter is missing method doesFilterPass");r=n.doesFilterPass({node:e,data:o})}}})),r},t.prototype.parseQuickFilter=function(e){return Object(d.exists)(e)?this.gridOptionsWrapper.isRowModelDefault()?e.toUpperCase():(console.warn("ag-grid: quick filtering only works with the Client-Side Row Model"),null):null},t.prototype.setQuickFilter=function(e){var t=this.parseQuickFilter(e);this.quickFilter!==t&&(this.quickFilter=t,this.setQuickFilterParts(),this.onFilterChanged())},t.prototype.checkExternalFilter=function(){this.externalFilterPresent=this.gridOptionsWrapper.isExternalFilterPresent()},t.prototype.onFilterChanged=function(e,t){this.setAdvancedFilterPresent(),this.updateFilterFlagInColumns("filterChanged",t),this.checkExternalFilter(),this.allFilters.forEach((function(t){t.filterPromise.then((function(t){t!==e&&t.onAnyFilterChanged&&t.onAnyFilterChanged()}))}));var o={type:i.a.EVENT_FILTER_CHANGED,api:this.gridApi,columnApi:this.columnApi};t&&Object(u.mergeDeep)(o,t),this.processingFilterChange=!0,this.eventService.dispatchEvent(o),this.processingFilterChange=!1},t.prototype.isSuppressFlashingCellsBecauseFiltering=function(){return!this.allowShowChangeAfterFilter&&this.processingFilterChange},t.prototype.isQuickFilterPresent=function(){return null!==this.quickFilter},t.prototype.doesRowPassOtherFilters=function(e,t){return this.doesRowPassFilter(t,e)},t.prototype.doesRowPassQuickFilterNoCache=function(e,t){var o=this,r=this.columnController.getAllColumnsForQuickFilter();return Object(s.some)(r,(function(r){var a=o.getQuickFilterTextForColumn(r,e);return Object(d.exists)(a)&&a.indexOf(t)>=0}))},t.prototype.doesRowPassQuickFilterCache=function(e,t){return e.quickFilterAggregateText||this.aggregateRowForQuickFilter(e),e.quickFilterAggregateText.indexOf(t)>=0},t.prototype.doesRowPassQuickFilter=function(e){var t=this,o=this.gridOptionsWrapper.isCacheQuickFilter();return Object(s.every)(this.quickFilterParts,(function(r){return o?t.doesRowPassQuickFilterCache(e,r):t.doesRowPassQuickFilterNoCache(e,r)}))},t.prototype.doesRowPassFilter=function(e,t){return!(this.isQuickFilterPresent()&&!this.doesRowPassQuickFilter(e))&&(!(this.externalFilterPresent&&!this.gridOptionsWrapper.doesExternalFilterPass(e))&&!(this.advancedFilterPresent&&!this.doesFilterPass(e,t)))},t.prototype.getQuickFilterTextForColumn=function(e,t){var o=this.valueService.getValue(e,t,!0),r=e.getColDef();if(r.getQuickFilterText){var a={value:o,node:t,data:t.data,column:e,colDef:r,context:this.gridOptionsWrapper.getContext()};o=r.getQuickFilterText(a)}return Object(d.exists)(o)?o.toString().toUpperCase():null},t.prototype.aggregateRowForQuickFilter=function(e){var t=this,r=[],a=this.columnController.getAllColumnsForQuickFilter();Object(s.forEach)(a,(function(o){var a=t.getQuickFilterTextForColumn(o,e);Object(d.exists)(a)&&r.push(a)})),e.quickFilterAggregateText=r.join(o.QUICK_FILTER_SEPARATOR)},t.prototype.onNewRowsLoaded=function(e){this.allFilters.forEach((function(e){e.filterPromise.then((function(e){e.onNewRowsLoaded&&e.onNewRowsLoaded()}))})),this.updateFilterFlagInColumns(e),this.setAdvancedFilterPresent()},t.prototype.createValueGetter=function(e){var t=this;return function(o){return t.valueService.getValue(e,o,!0)}},t.prototype.getFilterComponent=function(e,t){return this.getOrCreateFilterWrapper(e,t).filterPromise},t.prototype.isFilterActive=function(e){var t=this.cachedFilter(e);return t&&t.filterPromise.resolveNow(!1,(function(e){return e.isFilterActive()}))},t.prototype.getOrCreateFilterWrapper=function(e,t){var o=this.cachedFilter(e);return o?"NO_UI"!==t&&this.putIntoGui(o,t):(o=this.createFilterWrapper(e,t),this.allFilters.set(e.getColId(),o)),o},t.prototype.cachedFilter=function(e){return this.allFilters.get(e.getColId())},t.prototype.createFilterInstance=function(e,t){var o,r=this,a=g.a.isRegistered(l.a.SetFilterModule)?"agSetColumnFilter":"agTextColumnFilter",n=Object(u.cloneObject)(e.getColDef()),s=this.createFilterParams(e,n,t);s.filterModifiedCallback=function(){var t={type:i.a.EVENT_FILTER_MODIFIED,api:r.gridApi,columnApi:r.columnApi,column:e,filterInstance:o};r.eventService.dispatchEvent(t)};var p=this.userComponentFactory.newFilterComponent(n,s,a,(function(e,t){return Object(u.assign)(e,{doesRowPassOtherFilter:function(e){return r.doesRowPassOtherFilters(t,e)},filterChangedCallback:function(e){return r.onFilterChanged(t,e)}})}));return p&&p.then((function(e){return o=e})),p},t.prototype.createFilterParams=function(e,t,o){void 0===o&&(o=null);var r={api:this.gridOptionsWrapper.getApi(),column:e,colDef:t,rowModel:this.rowModel,filterChangedCallback:null,filterModifiedCallback:null,valueGetter:this.createValueGetter(e),context:this.gridOptionsWrapper.getContext(),doesRowPassOtherFilter:null};return o&&(r.$scope=o),r},t.prototype.createFilterWrapper=function(e,t){var o={column:e,filterPromise:null,scope:null,compiledElement:null,guiPromise:a.c.resolve(null)};return o.scope=this.gridOptionsWrapper.isAngularCompileFilters()?this.$scope.$new():null,o.filterPromise=this.createFilterInstance(e,o.scope),o.filterPromise&&this.putIntoGui(o,t),o},t.prototype.putIntoGui=function(e,t){var o=this,r=document.createElement("div");r.className="ag-filter",e.guiPromise=new a.c((function(a){e.filterPromise.then((function(n){var l=n.getGui();if(Object(d.exists)(l)||console.warn("getGui method from filter returned "+l+", it should be a DOM element or an HTML template string."),"string"==typeof l&&(l=Object(h.loadTemplate)(l)),r.appendChild(l),e.scope){var g=o.$compile(r)(e.scope);e.compiledElement=g,window.setTimeout((function(){return e.scope.$apply()}),0)}a(r),o.eventService.dispatchEvent({type:i.a.EVENT_FILTER_OPENED,column:e.column,source:t,eGui:r,api:o.gridApi,columnApi:o.columnApi})}))}))},t.prototype.onNewColumnsLoaded=function(){var e=this,t=!1;this.allFilters.forEach((function(o){!e.columnController.getPrimaryColumn(o.column)&&(t=!0,e.disposeFilterWrapper(o,"filterDestroyed"))})),t&&this.onFilterChanged()},t.prototype.destroyFilter=function(e,t){void 0===t&&(t="api");var o=this.allFilters.get(e.getColId());o&&(this.disposeFilterWrapper(o,t),this.onFilterChanged())},t.prototype.disposeFilterWrapper=function(e,t){var o=this;e.filterPromise.then((function(r){r.setModel(null),o.getContext().destroyBean(r),e.column.setFilterActive(!1,t),e.scope&&(e.compiledElement&&e.compiledElement.remove(),e.scope.$destroy()),o.allFilters.delete(e.column.getColId())}))},t.prototype.destroy=function(){var t=this;e.prototype.destroy.call(this),this.allFilters.forEach((function(e){return t.disposeFilterWrapper(e,"filterDestroyed")}))},t.QUICK_FILTER_SEPARATOR="\n",m([Object(n.a)("$compile")],t.prototype,"$compile",void 0),m([Object(n.a)("$scope")],t.prototype,"$scope",void 0),m([Object(n.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),m([Object(n.a)("valueService")],t.prototype,"valueService",void 0),m([Object(n.a)("columnController")],t.prototype,"columnController",void 0),m([Object(n.a)("rowModel")],t.prototype,"rowModel",void 0),m([Object(n.a)("columnApi")],t.prototype,"columnApi",void 0),m([Object(n.a)("gridApi")],t.prototype,"gridApi",void 0),m([Object(n.a)("userComponentFactory")],t.prototype,"userComponentFactory",void 0),m([n.e],t.prototype,"init",null),m([n.g],t.prototype,"destroy",null),t=o=m([Object(n.b)("filterManager")],t)}(p.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return p}));var r,a=o(1),n=o(4),i=o(0),l=o(6),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.initialised=!1,t}return g(t,e),t.prototype.init=function(){this.cellExpressions=this.gridOptionsWrapper.isEnableCellExpressions(),this.initialised=!0},t.prototype.getValue=function(e,t,o,r){if(void 0===o&&(o=!1),void 0===r&&(r=!1),this.initialised||this.init(),t){var a,n=e.getColDef(),l=n.field,g=e.getId(),s=t.data,p=t.groupData&&void 0!==t.groupData[g],c=!r&&t.aggData&&void 0!==t.aggData[g];if(o&&n.filterValueGetter?a=this.executeFilterValueGetter(n.filterValueGetter,s,e,t):this.gridOptionsWrapper.isTreeData()&&c?a=t.aggData[g]:this.gridOptionsWrapper.isTreeData()&&n.valueGetter?a=this.executeValueGetter(n.valueGetter,s,e,t):this.gridOptionsWrapper.isTreeData()&&l&&s?a=i.f.getValueUsingField(s,l,e.isFieldContainsDots()):p?a=t.groupData[g]:c?a=t.aggData[g]:n.valueGetter?a=this.executeValueGetter(n.valueGetter,s,e,t):l&&s&&(a=i.f.getValueUsingField(s,l,e.isFieldContainsDots())),this.cellExpressions&&"string"==typeof a&&0===a.indexOf("=")){var d=a.substring(1);a=this.executeValueGetter(d,s,e,t)}return a}},t.prototype.setValue=function(e,t,o,r){var a=this.columnController.getPrimaryColumn(t);if(e&&a){i.f.missing(e.data)&&(e.data={});var l=a.getColDef(),g=l.field,s=l.newValueHandler,p=l.valueSetter;if(i.f.missing(g)&&i.f.missing(s)&&i.f.missing(p))console.warn("ag-Grid: you need either field or valueSetter set on colDef for editing to work");else{var c,d={node:e,data:e.data,oldValue:this.getValue(a,e),newValue:o,colDef:a.getColDef(),column:a,api:this.gridOptionsWrapper.getApi(),columnApi:this.gridOptionsWrapper.getColumnApi(),context:this.gridOptionsWrapper.getContext()};if(d.newValue=o,void 0===(c=s&&i.f.exists(s)?s(d):i.f.exists(p)?this.expressionService.evaluate(p,d):this.setValueUsingField(e.data,g,o,a.isFieldContainsDots()))&&(c=!0),c){e.resetQuickFilterAggregateText(),this.valueCache.onDataChanged(),d.newValue=this.getValue(a,e);var u=a.getColDef().onCellValueChanged;"function"==typeof u&&setTimeout((function(){return u(d)}),0);var h={type:n.a.EVENT_CELL_VALUE_CHANGED,event:null,rowIndex:e.rowIndex,rowPinned:e.rowPinned,column:d.column,api:d.api,colDef:d.colDef,columnApi:d.columnApi,context:d.context,data:e.data,node:e,oldValue:d.oldValue,newValue:d.newValue,value:d.newValue,source:r};this.eventService.dispatchEvent(h)}}}},t.prototype.setValueUsingField=function(e,t,o,r){if(!t)return!1;if(r)for(var a=t.split("."),n=e;a.length>0&&n;){var i=a.shift();0===a.length?n[i]=o:n=n[i]}else e[t]=o;return!0},t.prototype.executeFilterValueGetter=function(e,t,o,r){var a={data:t,node:r,column:o,colDef:o.getColDef(),api:this.gridOptionsWrapper.getApi(),columnApi:this.gridOptionsWrapper.getColumnApi(),context:this.gridOptionsWrapper.getContext(),getValue:this.getValueCallback.bind(this,r)};return this.expressionService.evaluate(e,a)},t.prototype.executeValueGetter=function(e,t,o,r){var a=o.getId(),n=this.valueCache.getValue(r,a);if(void 0!==n)return n;var i={data:t,node:r,column:o,colDef:o.getColDef(),api:this.gridOptionsWrapper.getApi(),columnApi:this.gridOptionsWrapper.getColumnApi(),context:this.gridOptionsWrapper.getContext(),getValue:this.getValueCallback.bind(this,r)},l=this.expressionService.evaluate(e,i);return this.valueCache.setValue(r,a,l),l},t.prototype.getValueCallback=function(e,t){var o=this.columnController.getPrimaryColumn(t);return o?this.getValue(o,e):null},t.prototype.getKeyForNode=function(e,t){var o=this.getValue(e,t),r=e.getColDef().keyCreator,a=r?r({value:o}):o;return"string"==typeof a||null==a||"[object Object]"===(a=String(a))&&i.f.doOnce((function(){console.warn("ag-Grid: a column you are grouping or pivoting by has objects as values. If you want to group by complex objects then either a) use a colDef.keyCreator (se ag-Grid docs) or b) to toString() on the object to return a key")}),"getKeyForNode - warn about [object,object]"),a},s([Object(a.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),s([Object(a.a)("expressionService")],t.prototype,"expressionService",void 0),s([Object(a.a)("columnController")],t.prototype,"columnController",void 0),s([Object(a.a)("valueCache")],t.prototype,"valueCache",void 0),s([a.e],t.prototype,"init",null),t=s([Object(a.b)("valueService")],t)}(l.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return p}));var r=o(15),a=o(2),n=o(1),i=o(10),l=o(11),g=o(0),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(){function e(){this.detailGridInfoMap={},this.destroyCalled=!1}return e.prototype.registerGridComp=function(e){this.gridPanel=e},e.prototype.registerGridCore=function(e){this.gridCore=e},e.prototype.registerHeaderRootComp=function(e){this.headerRootComp=e},e.prototype.init=function(){switch(this.rowModel.getType()){case a.a.ROW_MODEL_TYPE_CLIENT_SIDE:this.clientSideRowModel=this.rowModel;break;case a.a.ROW_MODEL_TYPE_INFINITE:this.infiniteRowModel=this.rowModel;break;case a.a.ROW_MODEL_TYPE_SERVER_SIDE:this.serverSideRowModel=this.rowModel}},e.prototype.__getAlignedGridService=function(){return this.alignedGridsService},e.prototype.addDetailGridInfo=function(e,t){this.detailGridInfoMap[e]=t},e.prototype.removeDetailGridInfo=function(e){this.detailGridInfoMap[e]=void 0},e.prototype.getDetailGridInfo=function(e){return this.detailGridInfoMap[e]},e.prototype.forEachDetailGridInfo=function(e){var t=0;g.f.iterateObject(this.detailGridInfoMap,(function(o,r){g.f.exists(r)&&(e(r,t),t++)}))},e.prototype.getDataAsCsv=function(e){if(l.a.assertRegistered(i.a.CsvExportModule,"api.getDataAsCsv"))return this.csvCreator.getDataAsCsv(e)},e.prototype.exportDataAsCsv=function(e){l.a.assertRegistered(i.a.CsvExportModule,"api.exportDataAsCSv")&&this.csvCreator.exportDataAsCsv(e)},e.prototype.getDataAsExcel=function(e){if(l.a.assertRegistered(i.a.ExcelExportModule,"api.getDataAsExcel"))return this.excelCreator.getDataAsExcelXml(e)},e.prototype.exportDataAsExcel=function(e){l.a.assertRegistered(i.a.ExcelExportModule,"api.exportDataAsExcel")&&this.excelCreator.exportDataAsExcel(e)},e.prototype.setEnterpriseDatasource=function(e){console.warn("ag-grid: since version 18.x, api.setEnterpriseDatasource() should be replaced with api.setServerSideDatasource()"),this.setServerSideDatasource(e)},e.prototype.setServerSideDatasource=function(e){this.gridOptionsWrapper.isRowModelServerSide()?this.rowModel.setDatasource(e):console.warn("ag-Grid: you can only use an enterprise datasource when gridOptions.rowModelType is '"+a.a.ROW_MODEL_TYPE_SERVER_SIDE+"'")},e.prototype.setDatasource=function(e){this.gridOptionsWrapper.isRowModelInfinite()?this.rowModel.setDatasource(e):console.warn("ag-Grid: you can only use a datasource when gridOptions.rowModelType is '"+a.a.ROW_MODEL_TYPE_INFINITE+"'")},e.prototype.setViewportDatasource=function(e){this.gridOptionsWrapper.isRowModelViewport()?this.rowModel.setViewportDatasource(e):console.warn("ag-Grid: you can only use a viewport datasource when gridOptions.rowModelType is '"+a.a.ROW_MODEL_TYPE_VIEWPORT+"'")},e.prototype.setRowData=function(e){if(this.gridOptionsWrapper.isRowModelDefault())if(this.gridOptionsWrapper.isImmutableData()){var t=this.immutableService.createTransactionForRowData(e);if(!t)return;var o=t[0],r=t[1];this.clientSideRowModel.updateRowData(o,r),this.rowRenderer.refreshFullWidthRows()}else this.selectionController.reset(),this.clientSideRowModel.setRowData(e);else console.warn("cannot call setRowData unless using normal row model")},e.prototype.setFloatingTopRowData=function(e){console.warn("ag-Grid: since v12, api.setFloatingTopRowData() is now api.setPinnedTopRowData()"),this.setPinnedTopRowData(e)},e.prototype.setFloatingBottomRowData=function(e){console.warn("ag-Grid: since v12, api.setFloatingBottomRowData() is now api.setPinnedBottomRowData()"),this.setPinnedBottomRowData(e)},e.prototype.getFloatingTopRowCount=function(){return console.warn("ag-Grid: since v12, api.getFloatingTopRowCount() is now api.getPinnedTopRowCount()"),this.getPinnedTopRowCount()},e.prototype.getFloatingBottomRowCount=function(){return console.warn("ag-Grid: since v12, api.getFloatingBottomRowCount() is now api.getPinnedBottomRowCount()"),this.getPinnedBottomRowCount()},e.prototype.getFloatingTopRow=function(e){return console.warn("ag-Grid: since v12, api.getFloatingTopRow() is now api.getPinnedTopRow()"),this.getPinnedTopRow(e)},e.prototype.getFloatingBottomRow=function(e){return console.warn("ag-Grid: since v12, api.getFloatingBottomRow() is now api.getPinnedBottomRow()"),this.getPinnedBottomRow(e)},e.prototype.setPinnedTopRowData=function(e){this.pinnedRowModel.setPinnedTopRowData(e)},e.prototype.setPinnedBottomRowData=function(e){this.pinnedRowModel.setPinnedBottomRowData(e)},e.prototype.getPinnedTopRowCount=function(){return this.pinnedRowModel.getPinnedTopRowCount()},e.prototype.getPinnedBottomRowCount=function(){return this.pinnedRowModel.getPinnedBottomRowCount()},e.prototype.getPinnedTopRow=function(e){return this.pinnedRowModel.getPinnedTopRow(e)},e.prototype.getPinnedBottomRow=function(e){return this.pinnedRowModel.getPinnedBottomRow(e)},e.prototype.setColumnDefs=function(e,t){void 0===t&&(t="api"),this.columnController.setColumnDefs(e,t)},e.prototype.setAutoGroupColumnDef=function(e,t){void 0===t&&(t="api"),this.gridOptionsWrapper.setProperty("autoGroupColumnDef",e,!0)},e.prototype.expireValueCache=function(){this.valueCache.expire()},e.prototype.getVerticalPixelRange=function(){return this.gridPanel.getVScrollPosition()},e.prototype.getHorizontalPixelRange=function(){return this.gridPanel.getHScrollPosition()},e.prototype.setAlwaysShowVerticalScroll=function(e){this.gridOptionsWrapper.setProperty("alwaysShowVerticalScroll",e)},e.prototype.refreshToolPanel=function(){this.gridCore.refreshSideBar()},e.prototype.refreshCells=function(e){void 0===e&&(e={}),Array.isArray(e)?console.warn("since ag-Grid v11.1, refreshCells() now takes parameters, please see the documentation."):this.rowRenderer.refreshCells(e)},e.prototype.flashCells=function(e){void 0===e&&(e={}),this.rowRenderer.flashCells(e)},e.prototype.redrawRows=function(e){void 0===e&&(e={}),e&&e.rowNodes?this.rowRenderer.redrawRows(e.rowNodes):this.rowRenderer.redrawAfterModelUpdate()},e.prototype.timeFullRedraw=function(e){void 0===e&&(e=1);var t=0,o=0,r=0,a=this;!function n(){var i=(new Date).getTime();a.rowRenderer.redrawAfterModelUpdate();var l=(new Date).getTime();window.setTimeout((function(){var a=(new Date).getTime(),g=l-i,s=a-l;console.log("duration: processing = "+g+"ms, reflow = "+s+"ms"),t++,o+=g,r+=s,t=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},g=function(e,t){return function(o,r){t(o,r,e)}},s=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.expressionToFunctionCache={},t}return i(t,e),t.prototype.setBeans=function(e){this.logger=e.create("ExpressionService")},t.prototype.evaluate=function(e,t){if("function"==typeof e)return e(t);if("string"==typeof e){var o=e;return this.evaluateExpression(o,t)}console.error("ag-Grid: value should be either a string or a function",e)},t.prototype.evaluateExpression=function(e,t){try{return this.createExpressionFunction(e)(t.value,t.context,t.oldValue,t.newValue,t.value,t.node,t.data,t.colDef,t.rowIndex,t.api,t.columnApi,t.getValue,t.column,t.columnGroup)}catch(o){return console.log("Processing of the expression failed"),console.log("Expression = "+e),console.log("Params =",t),console.log("Exception = "+o),null}},t.prototype.createExpressionFunction=function(e){if(this.expressionToFunctionCache[e])return this.expressionToFunctionCache[e];var t=this.createFunctionBody(e),o=new Function("x, ctx, oldValue, newValue, value, node, data, colDef, rowIndex, api, columnApi, getValue, column, columnGroup",t);return this.expressionToFunctionCache[e]=o,o},t.prototype.createFunctionBody=function(e){return e.indexOf("return")>=0?e:"return "+e+";"},l([g(0,Object(a.h)("loggerFactory"))],t.prototype,"setBeans",null),t=l([Object(a.b)("expressionService")],t)}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return g}));var r,a=o(1),n=o(6),i=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),l=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},g=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.templateCache={},t.waitingCallbacks={},t}return i(t,e),t.prototype.getTemplate=function(e,t){var o=this.templateCache[e];if(o)return o;var r=this.waitingCallbacks[e],a=this;if(!r){r=[],this.waitingCallbacks[e]=r;var n=new XMLHttpRequest;n.onload=function(){a.handleHttpResult(this,e)},n.open("GET",e),n.send()}return t&&r.push(t),null},t.prototype.handleHttpResult=function(e,t){if(200===e.status&&null!==e.response){this.templateCache[t]=e.response||e.responseText;for(var o=this.waitingCallbacks[t],r=0;r=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},c=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.popupList=[],t}return s(t,e),t.prototype.init=function(){var e=this;this.addManagedListener(this.eventService,i.a.EVENT_KEYBOARD_FOCUS,(function(){e.popupList.forEach((function(e){g.f.addCssClass(e.element,"ag-keyboard-focus")}))})),this.addManagedListener(this.eventService,i.a.EVENT_MOUSE_FOCUS,(function(){e.popupList.forEach((function(e){g.f.removeCssClass(e.element,"ag-keyboard-focus")}))}))},t.prototype.registerGridCore=function(e){this.gridCore=e},t.prototype.getPopupParent=function(){var e=this.gridOptionsWrapper.getPopupParent();return e||this.gridCore.getRootGui()},t.prototype.positionPopupForMenu=function(e){var t=e.eventSource.getBoundingClientRect(),o=this.getParentRect(),r=this.keepYWithinBounds(e,t.top-o.top),a=e.ePopup.clientWidth>0?e.ePopup.clientWidth:200;e.ePopup.style.minWidth=a+"px";var n,i=o.right-o.left-a;function l(){return t.right-o.left-2}function g(){return t.left-o.left-a}this.gridOptionsWrapper.isEnableRtl()?((n=g())<0&&(n=l()),n>i&&(n=0)):((n=l())>i&&(n=g()),n<0&&(n=0)),e.ePopup.style.left=n+"px",e.ePopup.style.top=r+"px"},t.prototype.positionPopupUnderMouseEvent=function(e){var t=this.calculatePointerAlign(e.mouseEvent),o=t.x,r=t.y,a=e.ePopup,n=e.nudgeX,i=e.nudgeY;this.positionPopup({ePopup:a,x:o,y:r,nudgeX:n,nudgeY:i,keepWithinBounds:!0}),this.callPostProcessPopup(e.type,e.ePopup,null,e.mouseEvent,e.column,e.rowNode)},t.prototype.calculatePointerAlign=function(e){var t=this.getParentRect();return{x:e.clientX-t.left,y:e.clientY-t.top}},t.prototype.positionPopupUnderComponent=function(e){var t=e.eventSource.getBoundingClientRect(),o=e.alignSide||"left",r=this.getParentRect(),a=t.left-r.left;"right"===o&&(a-=e.ePopup.offsetWidth-t.width),this.positionPopup({ePopup:e.ePopup,minWidth:e.minWidth,minHeight:e.minHeight,nudgeX:e.nudgeX,nudgeY:e.nudgeY,x:a,y:t.top-r.top+t.height,keepWithinBounds:e.keepWithinBounds}),this.callPostProcessPopup(e.type,e.ePopup,e.eventSource,null,e.column,e.rowNode)},t.prototype.positionPopupOverComponent=function(e){var t=e.eventSource.getBoundingClientRect(),o=this.getParentRect();this.positionPopup({ePopup:e.ePopup,minWidth:e.minWidth,nudgeX:e.nudgeX,nudgeY:e.nudgeY,x:t.left-o.left,y:t.top-o.top,keepWithinBounds:e.keepWithinBounds}),this.callPostProcessPopup(e.type,e.ePopup,e.eventSource,null,e.column,e.rowNode)},t.prototype.callPostProcessPopup=function(e,t,o,r,a,n){var i=this.gridOptionsWrapper.getPostProcessPopupFunc();i&&i({column:a,rowNode:n,ePopup:t,type:e,eventSource:o,mouseEvent:r})},t.prototype.positionPopup=function(e){var t=e.x,o=e.y;e.nudgeX&&(t+=e.nudgeX),e.nudgeY&&(o+=e.nudgeY),e.keepWithinBounds&&(t=this.keepXWithinBounds(e,t),o=this.keepYWithinBounds(e,o)),e.ePopup.style.left=t+"px",e.ePopup.style.top=o+"px"},t.prototype.getActivePopups=function(){return this.popupList.map((function(e){return e.element}))},t.prototype.getParentRect=function(){var e=this.getPopupParent(),t=this.gridOptionsWrapper.getDocument();e===t.body&&(e=t.documentElement);var o=getComputedStyle(e),r=e.getBoundingClientRect();return{top:r.top+parseFloat(o.borderTopWidth)||0,left:r.left+parseFloat(o.borderLeftWidth)||0,right:r.right+parseFloat(o.borderRightWidth)||0,bottom:r.bottom+parseFloat(o.borderBottomWidth)||0}},t.prototype.keepYWithinBounds=function(e,t){var o=this.gridOptionsWrapper.getDocument(),r=o.documentElement,a=this.getPopupParent(),n=a.getBoundingClientRect(),i=o.documentElement.getBoundingClientRect(),l=a===o.body,s=Math.min(200,n.height),p=0;e.minHeight&&e.minHeight0&&(s=e.ePopup.clientHeight,p=g.f.getAbsoluteHeight(e.ePopup)-s);var c=l?g.f.getAbsoluteHeight(r)+r.scrollTop:n.height;l&&(c-=Math.abs(i.top-n.top));var d=c-s-p;return Math.min(Math.max(t,0),Math.abs(d))},t.prototype.keepXWithinBounds=function(e,t){var o=this.gridOptionsWrapper.getDocument(),r=o.documentElement,a=this.getPopupParent(),n=a.getBoundingClientRect(),i=o.documentElement.getBoundingClientRect(),l=a===o.body,s=e.ePopup,p=Math.min(200,n.width),c=0;e.minWidth&&e.minWidth0&&(p=s.offsetWidth,s.style.minWidth=p+"px",c=g.f.getAbsoluteWidth(s)-p);var d=l?g.f.getAbsoluteWidth(r)+r.scrollLeft:n.width;l&&(d-=Math.abs(i.left-n.left));var u=d-p-c;return Math.min(Math.max(t,0),Math.abs(u))},t.prototype.addAsModalPopup=function(e,t,o,r){return this.addPopup(!0,e,t,o,r)},t.prototype.addPopup=function(e,t,o,r,n,l){var s=this,p=this.gridOptionsWrapper.getDocument();if(!p)return console.warn("ag-grid: could not find the document, document is empty"),function(){};var c=g.f.findIndex(this.popupList,(function(e){return e.element===t}));if(-1!==c)return this.popupList[c].hideFunc;var d=this.getPopupParent();d.appendChild(t),t.style.top="0px",t.style.left="0px";var u=document.createElement("div"),h=this.environment.getTheme().theme;h&&g.f.addCssClass(u,h),g.f.addCssClass(u,"ag-popup"),g.f.addCssClass(t,this.gridOptionsWrapper.isEnableRtl()?"ag-rtl":"ag-ltr"),g.f.addCssClass(t,"ag-popup-child"),u.appendChild(t),d.appendChild(u),l?this.setAlwaysOnTop(u,!0):this.bringPopupToFront(u);var f=!1,m=function(e){var t=e.which||e.keyCode;if(u.contains(document.activeElement))switch(t){case a.a.KEY_ESCAPE:y({keyboardEvent:e})}},b=function(e){y({mouseEvent:e})},v=function(e){y({touchEvent:e})},y=function(e){void 0===e&&(e={});var o=e.mouseEvent,a=e.touchEvent,l=e.keyboardEvent;s.isEventFromCurrentPopup({mouseEvent:o,touchEvent:a},t)||s.isEventSameChainAsOriginalEvent({originalMouseEvent:n,mouseEvent:o,touchEvent:a})||f||(f=!0,d.removeChild(u),p.removeEventListener("keydown",m),p.removeEventListener("mousedown",b),p.removeEventListener("touchstart",v),p.removeEventListener("contextmenu",b),s.eventService.removeEventListener(i.a.EVENT_DRAG_STARTED,b),r&&r(o||a||l),s.popupList=s.popupList.filter((function(e){return e.element!==t})))};return window.setTimeout((function(){o&&p.addEventListener("keydown",m),e&&(p.addEventListener("mousedown",b),s.eventService.addEventListener(i.a.EVENT_DRAG_STARTED,b),p.addEventListener("touchstart",v),p.addEventListener("contextmenu",b))}),0),this.popupList.push({element:t,hideFunc:y}),y},t.prototype.isEventFromCurrentPopup=function(e,t){var o=e.mouseEvent,r=e.touchEvent,a=o||r;if(!a)return!1;var n=g.f.findIndex(this.popupList,(function(e){return e.element===t}));if(-1===n)return!1;for(var i=n;i=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return g(t,e),t.prototype.registerGridComp=function(e){this.gridPanel=e},t.prototype.registerHeaderRootComp=function(e){this.headerRootComp=e},t.prototype.getPreferredWidthForColumn=function(e,t){var o=this.getHeaderCellForColumn(e);if(!o)return-1;var r=document.createElement("span");r.style.position="fixed";var a=this.gridPanel.getCenterContainer();a.appendChild(r),this.putRowCellsIntoDummyContainer(e,r),t||this.cloneItemIntoDummy(o,r);var n=r.offsetWidth;return a.removeChild(r),n+this.gridOptionsWrapper.getAutoSizePadding()},t.prototype.getHeaderCellForColumn=function(e){var t=null;return this.headerRootComp.forEachHeaderElement((function(o){if(o instanceof n.a){var r=o;r.getColumn()===e&&(t=r)}})),t?t.getGui():null},t.prototype.putRowCellsIntoDummyContainer=function(e,t){var o=this;this.rowRenderer.getAllCellsForColumn(e).forEach((function(e){return o.cloneItemIntoDummy(e,t)}))},t.prototype.cloneItemIntoDummy=function(e,t){var o=e.cloneNode(!0);o.style.width="",o.style.position="static",o.style.left="";var r=document.createElement("div");i.f.containsClass(o,"ag-header-cell")&&(i.f.addCssClass(r,"ag-header"),i.f.addCssClass(r,"ag-header-row"),r.style.position="static"),r.style.display="table-row",r.appendChild(o),t.appendChild(r)},s([Object(a.a)("rowRenderer")],t.prototype,"rowRenderer",void 0),s([Object(a.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),t=s([Object(a.b)("autoWidthCalculator")],t)}(l.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return g}));var r,a=o(1),n=o(6),i=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),l=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},g=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return i(t,e),t.prototype.addResizeBar=function(e){var t=this,o={dragStartPixels:e.dragStartPixels||0,eElement:e.eResizeBar,onDragStart:this.onDragStart.bind(this,e),onDragStop:this.onDragStop.bind(this,e),onDragging:this.onDragging.bind(this,e)};this.dragService.addDragSource(o,!0);return function(){return t.dragService.removeDragSource(o)}},t.prototype.onDragStart=function(e,t){this.dragStartX=t.clientX,this.setResizeIcons();var o=t instanceof MouseEvent&&!0===t.shiftKey;e.onResizeStart(o)},t.prototype.setResizeIcons=function(){this.oldBodyCursor=this.eGridDiv.style.cursor,this.oldMsUserSelect=this.eGridDiv.style.msUserSelect,this.oldWebkitUserSelect=this.eGridDiv.style.webkitUserSelect,this.eGridDiv.style.cursor="ew-resize",this.eGridDiv.style.msUserSelect="none",this.eGridDiv.style.webkitUserSelect="none"},t.prototype.onDragStop=function(e,t){e.onResizeEnd(this.resizeAmount),this.resetIcons()},t.prototype.resetIcons=function(){this.eGridDiv.style.cursor=this.oldBodyCursor,this.eGridDiv.style.msUserSelect=this.oldMsUserSelect,this.eGridDiv.style.webkitUserSelect=this.oldWebkitUserSelect},t.prototype.onDragging=function(e,t){this.resizeAmount=t.clientX-this.dragStartX,e.onResizing(this.resizeAmount)},l([Object(a.a)("dragService")],t.prototype,"dragService",void 0),l([Object(a.a)("eGridDiv")],t.prototype,"eGridDiv",void 0),t=l([Object(a.b)("horizontalResizeService")],t)}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return h}));var r,a=o(1),n=o(5),i=o(4),l=o(136),g=o(10),s=o(11),p=o(29),c=o(0),d=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),u=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},h=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return d(t,e),t.prototype.postConstruct=function(){var t=this;this.logger=this.loggerFactory.create("GridCore");var o=this.createTemplate();if(this.setTemplate(o),[this.gridApi,this.rowRenderer,this.popupService,this.focusController].forEach((function(e){return e.registerGridCore(t)})),s.a.isRegistered(g.a.ClipboardModule)&&this.clipboardService.registerGridCore(this),this.gridOptionsWrapper.addLayoutElement(this.getGui()),this.eGridDiv.appendChild(this.getGui()),this.addDestroyFunc((function(){t.eGridDiv.removeChild(t.getGui())})),this.$scope){var r=this.$scope.$watch(this.quickFilterOnScope,(function(e){return t.filterManager.setQuickFilter(e)}));this.addDestroyFunc(r)}this.addRtlSupport(),this.logger.log("ready"),this.gridOptionsWrapper.addLayoutElement(this.eRootWrapperBody);var a=this.resizeObserverService.observeResize(this.eGridDiv,this.onGridSizeChanged.bind(this));this.addDestroyFunc((function(){return a()}));var n=this.getGui();this.addManagedListener(this.eventService,i.a.EVENT_KEYBOARD_FOCUS,(function(){c.f.addCssClass(n,"ag-keyboard-focus")})),this.addManagedListener(this.eventService,i.a.EVENT_MOUSE_FOCUS,(function(){c.f.removeCssClass(n,"ag-keyboard-focus")})),e.prototype.postConstruct.call(this)},t.prototype.getFocusableElement=function(){return this.eRootWrapperBody},t.prototype.createTemplate=function(){var e=s.a.isRegistered(g.a.SideBarModule),t=s.a.isRegistered(g.a.StatusBarModule);return'
\n '+(s.a.isRegistered(g.a.RowGroupingModule)?"":"")+'\n
\n \n '+(e?'':"")+"\n
\n "+(t?'':"")+"\n \n "+(s.a.isRegistered(g.a.EnterpriseCoreModule)?"":"")+"\n
"},t.prototype.isFocusableContainer=function(){return!0},t.prototype.getFocusableContainers=function(){var e=[this.gridPanel.getGui()];return this.sideBarComp&&e.push(this.sideBarComp.getGui()),e.filter((function(e){return c.f.isVisible(e)}))},t.prototype.focusNextInnerContainer=function(e){var t=this.getFocusableContainers(),o=c.f.findIndex(t,(function(e){return e.contains(document.activeElement)}))+(e?-1:1);return!(o<0||o>=t.length)&&(0===o?this.focusGridHeader():this.focusController.focusFirstFocusableElement(t[o]))},t.prototype.focusInnerElement=function(e){var t=this.getFocusableContainers();return e&&t.length>1?this.focusController.focusFirstFocusableElement(c.f.last(t)):this.focusGridHeader()},t.prototype.focusGridHeader=function(){var e=this.columnController.getAllDisplayedColumns()[0];return!!e&&(e.getParent()&&(e=this.columnController.getColumnGroupAtLevel(e,0)),this.focusController.focusHeaderPosition({headerRowIndex:0,column:e}),!0)},t.prototype.onGridSizeChanged=function(){var e={type:i.a.EVENT_GRID_SIZE_CHANGED,api:this.gridApi,columnApi:this.columnApi,clientWidth:this.eGridDiv.clientWidth,clientHeight:this.eGridDiv.clientHeight};this.eventService.dispatchEvent(e)},t.prototype.addRtlSupport=function(){var e=this.gridOptionsWrapper.isEnableRtl()?"ag-rtl":"ag-ltr";c.f.addCssClass(this.getGui(),e)},t.prototype.getRootGui=function(){return this.getGui()},t.prototype.isSideBarVisible=function(){return!!this.sideBarComp&&this.sideBarComp.isDisplayed()},t.prototype.setSideBarVisible=function(e){this.sideBarComp?this.sideBarComp.setDisplayed(e):e&&console.warn("ag-Grid: sideBar is not loaded")},t.prototype.setSideBarPosition=function(e){this.sideBarComp?this.sideBarComp.setSideBarPosition(e):console.warn("ag-Grid: sideBar is not loaded")},t.prototype.closeToolPanel=function(){this.sideBarComp?this.sideBarComp.close():console.warn("ag-Grid: toolPanel is only available in ag-Grid Enterprise")},t.prototype.getSideBar=function(){return this.gridOptions.sideBar},t.prototype.getToolPanelInstance=function(e){if(this.sideBarComp)return this.sideBarComp.getToolPanelInstance(e);console.warn("ag-Grid: toolPanel is only available in ag-Grid Enterprise")},t.prototype.refreshSideBar=function(){this.sideBarComp&&this.sideBarComp.refresh()},t.prototype.setSideBar=function(e){this.sideBarComp&&(this.eRootWrapperBody.removeChild(this.sideBarComp.getGui()),this.gridOptions.sideBar=l.a.parse(e),this.sideBarComp.reset(),this.eRootWrapperBody.appendChild(this.sideBarComp.getGui()))},t.prototype.getOpenedToolPanel=function(){return this.sideBarComp?this.sideBarComp.openedItem():null},t.prototype.openToolPanel=function(e){this.sideBarComp?this.sideBarComp.openToolPanel(e):console.warn("ag-Grid: toolPanel is only available in ag-Grid Enterprise")},t.prototype.isToolPanelShowing=function(){return this.sideBarComp.isToolPanelShowing()},t.prototype.destroy=function(){this.logger.log("Grid DOM removed"),e.prototype.destroy.call(this)},t.prototype.ensureNodeVisible=function(e,t){if(void 0===t&&(t=null),this.doingVirtualPaging)throw new Error("Cannot use ensureNodeVisible when doing virtual paging, as we cannot check rows that are not in memory");for(var o=this.rowModel.getRowCount(),r="function"==typeof e,a=-1,n=0;n=0&&this.gridPanel.ensureIndexVisible(a,t)},u([Object(a.a)("gridOptions")],t.prototype,"gridOptions",void 0),u([Object(a.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),u([Object(a.a)("rowModel")],t.prototype,"rowModel",void 0),u([Object(a.a)("resizeObserverService")],t.prototype,"resizeObserverService",void 0),u([Object(a.a)("rowRenderer")],t.prototype,"rowRenderer",void 0),u([Object(a.a)("filterManager")],t.prototype,"filterManager",void 0),u([Object(a.a)("eGridDiv")],t.prototype,"eGridDiv",void 0),u([Object(a.a)("$scope")],t.prototype,"$scope",void 0),u([Object(a.a)("quickFilterOnScope")],t.prototype,"quickFilterOnScope",void 0),u([Object(a.a)("popupService")],t.prototype,"popupService",void 0),u([Object(a.a)("columnController")],t.prototype,"columnController",void 0),u([Object(a.a)("loggerFactory")],t.prototype,"loggerFactory",void 0),u([Object(a.a)("columnApi")],t.prototype,"columnApi",void 0),u([Object(a.a)("gridApi")],t.prototype,"gridApi",void 0),u([Object(a.d)("clipboardService")],t.prototype,"clipboardService",void 0),u([Object(n.d)("gridPanel")],t.prototype,"gridPanel",void 0),u([Object(n.d)("sideBar")],t.prototype,"sideBarComp",void 0),u([Object(n.d)("rootWrapperBody")],t.prototype,"eRootWrapperBody",void 0),t}(p.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return p}));var r,a=o(1),n=o(6),i=o(2),l=o(0),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return g(t,e),t.prototype.hideActiveMenu=function(){this.hidePopup&&this.hidePopup()},t.prototype.showMenuAfterMouseEvent=function(e,t){var o=this;this.showPopup(e,(function(r){o.popupService.positionPopupUnderMouseEvent({column:e,type:"columnMenu",mouseEvent:t,ePopup:r})}),t.target)},t.prototype.showMenuAfterButtonClick=function(e,t){var o=this;this.showPopup(e,(function(r){o.popupService.positionPopupUnderComponent({type:"columnMenu",eventSource:t,ePopup:r,keepWithinBounds:!0,column:e})}),t)},t.prototype.showPopup=function(e,t,o){var r,a=this,n=this.filterManager.getOrCreateFilterWrapper(e,"COLUMN_MENU"),i=document.createElement("div");l.f.addCssClass(i,"ag-menu"),this.tabListener=this.addManagedListener(i,"keydown",(function(e){return a.trapFocusWithin(e,i)})),n.guiPromise.then((function(e){return i.appendChild(e)}));var g=function(e){"horizontal"===e.direction&&r()};this.eventService.addEventListener("bodyScroll",g);r=this.popupService.addAsModalPopup(i,!0,(function(t){a.eventService.removeEventListener("bodyScroll",g),e.setMenuVisible(!1,"contextMenu");var r=t instanceof KeyboardEvent;if(a.tabListener&&(a.tabListener=a.tabListener()),r&&o&&l.f.isVisible(o)){var n=a.focusController.findTabbableParent(o);n&&n.focus()}})),t(i),n.filterPromise.then((function(e){if(e.afterGuiAttached){var t={hidePopup:r};e.afterGuiAttached(t)}})),this.hidePopup=r,e.setMenuVisible(!0,"contextMenu")},t.prototype.trapFocusWithin=function(e,t){e.keyCode===i.a.KEY_TAB&&(this.focusController.findNextFocusableElement(t,!1,e.shiftKey)||(e.preventDefault(),e.shiftKey?this.focusController.focusLastFocusableElement(t):this.focusController.focusFirstFocusableElement(t)))},t.prototype.isMenuEnabled=function(e){return e.isFilterAllowed()},s([Object(a.a)("filterManager")],t.prototype,"filterManager",void 0),s([Object(a.a)("popupService")],t.prototype,"popupService",void 0),s([Object(a.a)("focusController")],t.prototype,"focusController",void 0),t=s([Object(a.b)("menuFactory")],t)}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return p}));var r,a=o(1),n=o(4),i=o(0),l=o(6),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.dragEndFunctions=[],t.dragSources=[],t}return g(t,e),t.prototype.init=function(){this.logger=this.loggerFactory.create("DragService")},t.prototype.removeAllListeners=function(){this.dragSources.forEach(this.removeListener.bind(this)),this.dragSources.length=0},t.prototype.removeListener=function(e){var t=e.dragSource.eElement,o=e.mouseDownListener;if(t.removeEventListener("mousedown",o),e.touchEnabled){var r=e.touchStartListener;t.removeEventListener("touchstart",r,{passive:!0})}},t.prototype.removeDragSource=function(e){var t=i.f.find(this.dragSources,(function(t){return t.dragSource===e}));t&&(this.removeListener(t),i.f.removeFromArray(this.dragSources,t))},t.prototype.setNoSelectToBody=function(e){var t=this.gridOptionsWrapper.getDocument().querySelector("body");i.f.exists(t)&&i.f.addOrRemoveCssClass(t,"ag-unselectable",e)},t.prototype.addDragSource=function(e,t){void 0===t&&(t=!1);var o=this.onMouseDown.bind(this,e);e.eElement.addEventListener("mousedown",o);var r=null,a=this.gridOptionsWrapper.isSuppressTouch();t&&!a&&(r=this.onTouchStart.bind(this,e),e.eElement.addEventListener("touchstart",r,{passive:!1})),this.dragSources.push({dragSource:e,mouseDownListener:o,touchStartListener:r,touchEnabled:t})},t.prototype.onTouchStart=function(e,t){var o=this;this.currentDragParams=e,this.dragging=!1;var r=t.touches[0];this.touchLastTime=r,this.touchStart=r,t.cancelable&&t.preventDefault();var a=function(t){return o.onTouchUp(t,e.eElement)},n=e.eElement,i=[{target:n,type:"touchmove",listener:function(t){return o.onTouchMove(t,e.eElement)},options:{passive:!0}},{target:n,type:"touchend",listener:a,options:{passive:!0}},{target:n,type:"touchcancel",listener:a,options:{passive:!0}}];this.addTemporaryEvents(i),0===e.dragStartPixels&&this.onCommonMove(r,this.touchStart,e.eElement)},t.prototype.onMouseDown=function(e,t){var o=this,r=t;if(!(e.skipMouseEvent&&e.skipMouseEvent(t)||r._alreadyProcessedByDragService||(r._alreadyProcessedByDragService=!0,0!==t.button))){this.currentDragParams=e,this.dragging=!1,this.mouseStartEvent=t;var a=this.gridOptionsWrapper.getDocument();this.setNoSelectToBody(!0);var n=[{target:a,type:"mousemove",listener:function(t,r){return o.onMouseMove(t,e.eElement)}},{target:a,type:"mouseup",listener:function(t,r){return o.onMouseUp(t,e.eElement)}},{target:a,type:"contextmenu",listener:function(e){return e.preventDefault()}}];this.addTemporaryEvents(n),0===e.dragStartPixels&&this.onMouseMove(t,e.eElement)}},t.prototype.addTemporaryEvents=function(e){e.forEach((function(e){var t=e.target,o=e.type,r=e.listener,a=e.options;t.addEventListener(o,r,a)})),this.dragEndFunctions.push((function(){e.forEach((function(e){var t=e.target,o=e.type,r=e.listener,a=e.options;t.removeEventListener(o,r,a)}))}))},t.prototype.isEventNearStartEvent=function(e,t){var o=this.currentDragParams.dragStartPixels,r=i.f.exists(o)?o:4;return i.f.areEventsNear(e,t,r)},t.prototype.getFirstActiveTouch=function(e){for(var t=0;t=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.getSortModel=function(){return t.getColumnsWithSortingOrdered().map((function(e){return{colId:e.getColId(),sort:e.getSort()}}))},t}var o;return g(t,e),o=t,t.prototype.progressSort=function(e,t,o){void 0===o&&(o="api");var r=this.getNextSortDirection(e);this.setSortForColumn(e,r,t,o)},t.prototype.setSortForColumn=function(e,t,o,r){if(void 0===r&&(r="api"),t!==i.a.SORT_ASC&&t!==i.a.SORT_DESC&&(t=null),e.setSort(t,r),e.getSort()){var a=Number((new Date).valueOf());e.setSortedAt(a)}else e.setSortedAt(null);o&&!this.gridOptionsWrapper.isSuppressMultiSort()||this.clearSortBarThisColumn(e,r),this.dispatchSortChangedEvents()},t.prototype.onSortChanged=function(){this.dispatchSortChangedEvents()},t.prototype.dispatchSortChangedEvents=function(){var e={type:l.a.EVENT_SORT_CHANGED,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(e)},t.prototype.clearSortBarThisColumn=function(e,t){this.columnController.getPrimaryAndSecondaryAndAutoColumns().forEach((function(o){o!==e&&o.setSort(void 0,t)}))},t.prototype.getNextSortDirection=function(e){var t;if(t=e.getColDef().sortingOrder?e.getColDef().sortingOrder:this.gridOptionsWrapper.getSortingOrder()?this.gridOptionsWrapper.getSortingOrder():o.DEFAULT_SORTING_ORDER,!Array.isArray(t)||t.length<=0)return console.warn("ag-grid: sortingOrder must be an array with at least one element, currently it's "+t),null;var r,a=t.indexOf(e.getSort()),n=a<0,i=a==t.length-1;return r=n||i?t[0]:t[a+1],o.DEFAULT_SORTING_ORDER.indexOf(r)<0?(console.warn("ag-grid: invalid sort type "+r),null):r},t.prototype.setSortModel=function(e,t){var o=this;void 0===t&&(t="api");var r=e&&e.length>0;this.columnController.getPrimaryAndSecondaryAndAutoColumns().forEach((function(a){var n=null,i=-1;if(r&&a.getColDef().sortable)for(var l=0;l=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},d=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.keyboardFocusActive=!1,t}var o;return p(t,e),o=t,t.prototype.init=function(){var e=this.gridOptionsWrapper.getDocument(),t=this.clearFocusedCell.bind(this);this.addManagedListener(this.eventService,i.a.EVENT_COLUMN_PIVOT_MODE_CHANGED,t),this.addManagedListener(this.eventService,i.a.EVENT_COLUMN_EVERYTHING_CHANGED,this.onColumnEverythingChanged.bind(this)),this.addManagedListener(this.eventService,i.a.EVENT_COLUMN_GROUP_OPENED,t),this.addManagedListener(this.eventService,i.a.EVENT_COLUMN_ROW_GROUP_CHANGED,t),this.addManagedListener(e,"keydown",this.activateKeyboardMode.bind(this)),this.addManagedListener(e,"mousedown",this.activateMouseMode.bind(this))},t.prototype.registerGridCore=function(e){this.gridCore=e},t.prototype.onColumnEverythingChanged=function(){if(this.focusedCellPosition){var e=this.focusedCellPosition.column,t=this.columnController.getGridColumn(e.getId());e!==t&&this.clearFocusedCell()}},t.prototype.isKeyboardFocus=function(){return this.keyboardFocusActive},t.prototype.activateMouseMode=function(){this.keyboardFocusActive=!1,this.eventService.dispatchEvent({type:i.a.EVENT_MOUSE_FOCUS})},t.prototype.activateKeyboardMode=function(){this.keyboardFocusActive=!0,this.eventService.dispatchEvent({type:i.a.EVENT_KEYBOARD_FOCUS})},t.prototype.getFocusCellToUseAfterRefresh=function(){return this.gridOptionsWrapper.isSuppressFocusAfterRefresh()||!this.focusedCellPosition?null:this.getGridCellForDomElement(document.activeElement)?this.focusedCellPosition:null},t.prototype.getGridCellForDomElement=function(e){for(var t=e;t;){var o=this.gridOptionsWrapper.getDomData(t,l.a.DOM_DATA_KEY_CELL_COMP);if(o)return o.getCellPosition();t=t.parentNode}return null},t.prototype.clearFocusedCell=function(){this.focusedCellPosition=null,this.onCellFocused(!1)},t.prototype.getFocusedCell=function(){return this.focusedCellPosition},t.prototype.setFocusedCell=function(e,t,o,r){void 0===r&&(r=!1);var a=s.f.makeNull(this.columnController.getGridColumn(t));this.focusedCellPosition={rowIndex:e,rowPinned:s.f.makeNull(o),column:a},this.onCellFocused(r)},t.prototype.isCellFocused=function(e){return!s.f.missing(this.focusedCellPosition)&&(this.focusedCellPosition.column===e.column&&this.isRowFocused(e.rowIndex,e.rowPinned))},t.prototype.isRowNodeFocused=function(e){return this.isRowFocused(e.rowIndex,e.rowPinned)},t.prototype.isHeaderWrapperFocused=function(e){if(s.f.missing(this.focusedHeaderPosition))return!1;var t=e.getColumn(),o=e.getParentComponent().getRowIndex(),r=e.getPinned(),a=this.focusedHeaderPosition,n=a.column,i=a.headerRowIndex;return t===n&&o===i&&r==n.getPinned()},t.prototype.clearFocusedHeader=function(){this.focusedHeaderPosition=null},t.prototype.getFocusedHeader=function(){return this.focusedHeaderPosition},t.prototype.setFocusedHeader=function(e,t){this.focusedHeaderPosition={headerRowIndex:e,column:t}},t.prototype.focusHeaderPosition=function(e,t){this.headerNavigationService.scrollToColumn(e.column,t);var o=this.headerNavigationService.getHeaderContainer(e.column.getPinned()).getRowComps()[e.headerRowIndex].getHeaderComps()[e.column.getUniqueId()];return!!o&&(o.getFocusableElement().focus(),!0)},t.prototype.isAnyCellFocused=function(){return!!this.focusedCellPosition},t.prototype.isRowFocused=function(e,t){if(s.f.missing(this.focusedCellPosition))return!1;var o=s.f.makeNull(t);return this.focusedCellPosition.rowIndex===e&&this.focusedCellPosition.rowPinned===o},t.prototype.findFocusableElements=function(e,t,r){var a=o.FOCUSABLE_SELECTOR,n=o.FOCUSABLE_EXCLUDE;t&&(n+=", "+t),r&&(n+=', [tabindex="-1"]');var i=Array.prototype.slice.apply(e.querySelectorAll(a)),l=Array.prototype.slice.apply(e.querySelectorAll(n));if(!l.length)return i;var g;return g=l,i.filter((function(e){return-1===g.indexOf(e)}))},t.prototype.focusFirstFocusableElement=function(e,t){var o=this.findFocusableElements(e,null,t)[0];return!!o&&(o.focus(),!0)},t.prototype.focusLastFocusableElement=function(e,t){var o=s.f.last(this.findFocusableElements(e,null,t));return!!o&&(o.focus(),!0)},t.prototype.findNextFocusableElement=function(e,t,o){var r=this.findFocusableElements(e,t?':not([tabindex="-1"])':null),a=(t?s.f.findIndex(r,(function(e){return e.contains(document.activeElement)})):r.indexOf(document.activeElement))+(o?-1:1);if(!(a<0||a>r.length))return r[a]},t.prototype.isFocusUnderManagedComponent=function(e){var t=e.querySelectorAll("."+g.a.FOCUS_MANAGED_CLASS);if(!t.length)return!1;for(var o=0;o=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.gridInstanceId=o.gridInstanceSequence.next(),t}var o;return g(t,e),o=t,t.prototype.init=function(){this.stampDomElementWithGridInstance()},t.prototype.registerGridComp=function(e){this.gridPanel=e},t.prototype.stampDomElementWithGridInstance=function(){this.eGridDiv[o.GRID_DOM_KEY]=this.gridInstanceId},t.prototype.getRenderedCellForEvent=function(e){return n.f.getCellCompForEvent(this.gridOptionsWrapper,e)},t.prototype.isEventFromThisGrid=function(e){for(var t=n.f.getEventPath(e),r=0;r=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return g(t,e),t.prototype.getNextCellToFocus=function(e,t){for(var o=t,r=!1;!r;){switch(e){case i.a.KEY_UP:o=this.getCellAbove(o);break;case i.a.KEY_DOWN:o=this.getCellBelow(o);break;case i.a.KEY_RIGHT:o=this.gridOptionsWrapper.isEnableRtl()?this.getCellToLeft(o):this.getCellToRight(o);break;case i.a.KEY_LEFT:o=this.gridOptionsWrapper.isEnableRtl()?this.getCellToRight(o):this.getCellToLeft(o);break;default:o=null,console.warn("ag-Grid: unknown key for navigation "+e)}r=!o||this.isCellGoodToFocusOn(o)}return o},t.prototype.isCellGoodToFocusOn=function(e){var t,o=e.column;switch(e.rowPinned){case i.a.PINNED_TOP:t=this.pinnedRowModel.getPinnedTopRow(e.rowIndex);break;case i.a.PINNED_BOTTOM:t=this.pinnedRowModel.getPinnedBottomRow(e.rowIndex);break;default:t=this.rowModel.getRow(e.rowIndex)}return!o.isSuppressNavigable(t)},t.prototype.getCellToLeft=function(e){if(!e)return null;var t=this.columnController.getDisplayedColBefore(e.column);return t?{rowIndex:e.rowIndex,column:t,rowPinned:e.rowPinned}:null},t.prototype.getCellToRight=function(e){if(!e)return null;var t=this.columnController.getDisplayedColAfter(e.column);return t?{rowIndex:e.rowIndex,column:t,rowPinned:e.rowPinned}:null},t.prototype.getRowBelow=function(e){var t=e.rowIndex,o=e.rowPinned;if(this.isLastRowInContainer(e))switch(o){case i.a.PINNED_BOTTOM:return null;case i.a.PINNED_TOP:return this.rowModel.isRowsToRender()?{rowIndex:0,rowPinned:null}:this.pinnedRowModel.isRowsToRender(i.a.PINNED_BOTTOM)?{rowIndex:0,rowPinned:i.a.PINNED_BOTTOM}:null;default:return this.pinnedRowModel.isRowsToRender(i.a.PINNED_BOTTOM)?{rowIndex:0,rowPinned:i.a.PINNED_BOTTOM}:null}return{rowIndex:t+1,rowPinned:o}},t.prototype.getCellBelow=function(e){if(!e)return null;var t=this.getRowBelow(e);return t?{rowIndex:t.rowIndex,column:e.column,rowPinned:t.rowPinned}:null},t.prototype.isLastRowInContainer=function(e){var t=e.rowPinned,o=e.rowIndex;return t===i.a.PINNED_TOP?this.pinnedRowModel.getPinnedTopRowData().length-1<=o:t===i.a.PINNED_BOTTOM?this.pinnedRowModel.getPinnedBottomRowData().length-1<=o:this.rowModel.getRowCount()-1<=o},t.prototype.getRowAbove=function(e){var t=e.rowIndex,o=e.rowPinned;return 0===t?o===i.a.PINNED_TOP?null:o&&this.rowModel.isRowsToRender()?this.getLastBodyCell():this.pinnedRowModel.isRowsToRender(i.a.PINNED_TOP)?this.getLastFloatingTopRow():null:{rowIndex:t-1,rowPinned:o}},t.prototype.getCellAbove=function(e){if(!e)return null;var t=this.getRowAbove({rowIndex:e.rowIndex,rowPinned:e.rowPinned});return t?{rowIndex:t.rowIndex,column:e.column,rowPinned:t.rowPinned}:null},t.prototype.getLastBodyCell=function(){return{rowIndex:this.rowModel.getRowCount()-1,rowPinned:null}},t.prototype.getLastFloatingTopRow=function(){return{rowIndex:this.pinnedRowModel.getPinnedTopRowData().length-1,rowPinned:i.a.PINNED_TOP}},t.prototype.getNextTabbedCell=function(e,t){return t?this.getNextTabbedCellBackwards(e):this.getNextTabbedCellForwards(e)},t.prototype.getNextTabbedCellForwards=function(e){var t=this.columnController.getAllDisplayedColumns(),o=e.rowIndex,r=e.rowPinned,a=this.columnController.getDisplayedColAfter(e.column);if(!a){a=t[0];var n=this.getRowBelow(e);if(l.f.missing(n))return null;o=n?n.rowIndex:null,r=n?n.rowPinned:null}return{rowIndex:o,column:a,rowPinned:r}},t.prototype.getNextTabbedCellBackwards=function(e){var t=this.columnController.getAllDisplayedColumns(),o=e.rowIndex,r=e.rowPinned,a=this.columnController.getDisplayedColBefore(e.column);if(!a){a=l.f.last(t);var n=this.getRowAbove({rowIndex:e.rowIndex,rowPinned:e.rowPinned});if(l.f.missing(n))return null;o=n?n.rowIndex:null,r=n?n.rowPinned:null}return{rowIndex:o,column:a,rowPinned:r}},s([Object(a.a)("columnController")],t.prototype,"columnController",void 0),s([Object(a.a)("rowModel")],t.prototype,"rowModel",void 0),s([Object(a.a)("pinnedRowModel")],t.prototype,"pinnedRowModel",void 0),s([Object(a.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),t=s([Object(a.b)("cellNavigationService")],t)}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return s}));var r=o(1),a=o(55),n=o(54),i=o(46),l=o(0),g=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},s=function(){function e(){this.cellRendererMap={}}var t;return t=e,e.prototype.init=function(){this.cellRendererMap[t.ANIMATE_SLIDE]=a.a,this.cellRendererMap[t.ANIMATE_SHOW_CHANGE]=n.a,this.cellRendererMap[t.GROUP]=i.a},e.prototype.addCellRenderer=function(e,t){this.cellRendererMap[e]=t},e.prototype.getCellRenderer=function(e){var t=this.cellRendererMap[e];return l.f.missing(t)?(console.warn("ag-Grid: unable to find cellRenderer for key "+e),null):t},e.ANIMATE_SLIDE="animateSlide",e.ANIMATE_SHOW_CHANGE="animateShowChange",e.GROUP="group",g([Object(r.a)("gridOptionsWrapper")],e.prototype,"gridOptionsWrapper",void 0),g([Object(r.a)("expressionService")],e.prototype,"expressionService",void 0),g([Object(r.a)("eventService")],e.prototype,"eventService",void 0),g([r.e],e.prototype,"init",null),e=t=g([Object(r.b)("cellRendererFactory")],e)}()},function(e,t,o){"use strict";o.d(t,"a",(function(){return g}));var r,a=o(1),n=o(6),i=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),l=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},g=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return i(t,e),t.prototype.formatValue=function(e,t,o,r,a,n){void 0===n&&(n=!0);var i,l=null,g=e.getColDef();if(a?i=a:n&&(i=t&&t.rowPinned&&g.pinnedRowValueFormatter?g.pinnedRowValueFormatter:g.valueFormatter),i){var s={value:r,node:t,data:t?t.data:null,colDef:g,column:e,api:this.gridOptionsWrapper.getApi(),columnApi:this.gridOptionsWrapper.getColumnApi(),context:this.gridOptionsWrapper.getContext()};s.$scope=o,l=this.expressionService.evaluate(i,s)}else if(g.refData)return g.refData[r]||"";return null==l&&Array.isArray(r)&&(l=r.join(", ")),l},l([Object(a.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),l([Object(a.a)("expressionService")],t.prototype,"expressionService",void 0),t=l([Object(a.b)("valueFormatterService")],t)}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return r}));var r=function(){function e(){}return e.prototype.setTimeout=function(e,t){window.setTimeout(e,t)},e.prototype.addEventListenerOutsideAngular=function(e,t,o,r){e.addEventListener(t,o,r)},e}()},function(e,t,o){"use strict";o.d(t,"a",(function(){return s}));var r,a=o(1),n=o(6),i=o(4),l=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),g=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},s=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return l(t,e),t.prototype.setScrollsVisible=function(e){if(this.horizontalScrollShowing!==e.horizontalScrollShowing||this.verticalScrollShowing!==e.verticalScrollShowing){this.horizontalScrollShowing=e.horizontalScrollShowing,this.verticalScrollShowing=e.verticalScrollShowing;var t={type:i.a.EVENT_SCROLL_VISIBILITY_CHANGED,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(t)}},t.prototype.isHorizontalScrollShowing=function(){return this.horizontalScrollShowing},t.prototype.isVerticalScrollShowing=function(){return this.verticalScrollShowing},g([Object(a.a)("columnController")],t.prototype,"columnController",void 0),g([Object(a.a)("columnApi")],t.prototype,"columnApi",void 0),g([Object(a.a)("gridApi")],t.prototype,"gridApi",void 0),g([Object(a.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),t=g([Object(a.b)("scrollVisibleService")],t)}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return g}));var r,a=o(1),n=o(6),i=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),l=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},g=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return i(t,e),t.prototype.processAllCellClasses=function(e,t,o,r){this.processClassRules(e.cellClassRules,t,o,r),this.processStaticCellClasses(e,t,o)},t.prototype.processClassRules=function(e,t,o,r){if("object"==typeof e&&null!==e)for(var a=Object.keys(e),n=0;n=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.currentPage=0,t.topDisplayedRowIndex=0,t.bottomDisplayedRowIndex=0,t.pixelOffset=0,t.masterRowCount=0,t}return g(t,e),t.prototype.postConstruct=function(){this.active=this.gridOptionsWrapper.isPagination(),this.paginateChildRows=this.gridOptionsWrapper.isPaginateChildRows(),this.addManagedListener(this.eventService,n.a.EVENT_MODEL_UPDATED,this.onModelUpdated.bind(this)),this.addManagedListener(this.gridOptionsWrapper,"paginationPageSize",this.onModelUpdated.bind(this)),this.onModelUpdated()},t.prototype.ensureRowHeightsValid=function(e,t,o,r){var a=this.rowModel.ensureRowHeightsValid(e,t,this.getPageFirstRow(),this.getPageLastRow());return a&&this.calculatePages(),a},t.prototype.onModelUpdated=function(e){this.calculatePages();var t={type:n.a.EVENT_PAGINATION_CHANGED,animate:!!e&&e.animate,newData:!!e&&e.newData,newPage:!!e&&e.newPage,keepRenderedRows:!!e&&e.keepRenderedRows,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(t)},t.prototype.goToPage=function(e){if(this.active&&this.currentPage!==e){this.currentPage=e;var t={type:n.a.EVENT_MODEL_UPDATED,animate:!1,keepRenderedRows:!1,newData:!1,newPage:!0,api:this.gridApi,columnApi:this.columnApi};this.onModelUpdated(t)}},t.prototype.getPixelOffset=function(){return this.pixelOffset},t.prototype.getRow=function(e){return this.rowModel.getRow(e)},t.prototype.getRowNode=function(e){return this.rowModel.getRowNode(e)},t.prototype.getRowIndexAtPixel=function(e){return this.rowModel.getRowIndexAtPixel(e)},t.prototype.getCurrentPageHeight=function(){return l.f.missing(this.topRowBounds)||l.f.missing(this.bottomRowBounds)?0:Math.max(this.bottomRowBounds.rowTop+this.bottomRowBounds.rowHeight-this.topRowBounds.rowTop,0)},t.prototype.isRowPresent=function(e){return!!this.rowModel.isRowPresent(e)&&(e.rowIndex>=this.topDisplayedRowIndex&&e.rowIndex<=this.bottomDisplayedRowIndex)},t.prototype.isEmpty=function(){return this.rowModel.isEmpty()},t.prototype.isRowsToRender=function(){return this.rowModel.isRowsToRender()},t.prototype.getNodesInRangeForSelection=function(e,t){return this.rowModel.getNodesInRangeForSelection(e,t)},t.prototype.forEachNode=function(e){return this.rowModel.forEachNode(e)},t.prototype.getType=function(){return this.rowModel.getType()},t.prototype.getRowBounds=function(e){var t=this.rowModel.getRowBounds(e);return t.rowIndex=e,t},t.prototype.getPageFirstRow=function(){return this.topRowBounds?this.topRowBounds.rowIndex:-1},t.prototype.getPageLastRow=function(){return this.bottomRowBounds?this.bottomRowBounds.rowIndex:-1},t.prototype.getRowCount=function(){return this.rowModel.getRowCount()},t.prototype.goToPageWithIndex=function(e){if(this.active){var t=Math.floor(e/this.pageSize);this.goToPage(t)}},t.prototype.isLastPageFound=function(){return this.rowModel.isLastRowFound()},t.prototype.getCurrentPage=function(){return this.currentPage},t.prototype.goToNextPage=function(){this.goToPage(this.currentPage+1)},t.prototype.goToPreviousPage=function(){this.goToPage(this.currentPage-1)},t.prototype.goToFirstPage=function(){this.goToPage(0)},t.prototype.goToLastPage=function(){var e=this.rowModel.getRowCount(),t=Math.floor(e/this.pageSize);this.goToPage(t)},t.prototype.getPageSize=function(){return this.pageSize},t.prototype.getTotalPages=function(){return this.totalPages},t.prototype.setPageSize=function(){this.pageSize=this.gridOptionsWrapper.getPaginationPageSize(),this.pageSize>=1||(this.pageSize=100)},t.prototype.calculatePages=function(){this.active?(this.setPageSize(),this.paginateChildRows?this.calculatePagesAllRows():this.calculatePagesMasterRowsOnly()):this.calculatedPagesNotActive(),this.topRowBounds=this.rowModel.getRowBounds(this.topDisplayedRowIndex),this.topRowBounds&&(this.topRowBounds.rowIndex=this.topDisplayedRowIndex),this.bottomRowBounds=this.rowModel.getRowBounds(this.bottomDisplayedRowIndex),this.bottomRowBounds&&(this.bottomRowBounds.rowIndex=this.bottomDisplayedRowIndex),this.pixelOffset=l.f.exists(this.topRowBounds)?this.topRowBounds.rowTop:0},t.prototype.setZeroRows=function(){this.topDisplayedRowIndex=0,this.bottomDisplayedRowIndex=-1,this.currentPage=0,this.totalPages=0},t.prototype.calculatePagesMasterRowsOnly=function(){if(this.masterRowCount=this.rowModel.getTopLevelRowCount(),0!==this.masterRowCount){var e=this.masterRowCount-1;this.totalPages=Math.floor(e/this.pageSize)+1,this.currentPage>=this.totalPages&&(this.currentPage=this.totalPages-1),(!l.f.isNumeric(this.currentPage)||this.currentPage<0)&&(this.currentPage=0);var t=this.pageSize*this.currentPage,o=this.pageSize*(this.currentPage+1)-1;if(o>e&&(o=e),this.topDisplayedRowIndex=this.rowModel.getTopLevelRowDisplayedIndex(t),o===e)this.bottomDisplayedRowIndex=this.rowModel.getRowCount()-1;else{var r=this.rowModel.getTopLevelRowDisplayedIndex(o+1);this.bottomDisplayedRowIndex=r-1}}else this.setZeroRows()},t.prototype.getMasterRowCount=function(){return this.masterRowCount},t.prototype.calculatePagesAllRows=function(){if(this.masterRowCount=this.rowModel.getRowCount(),0!==this.masterRowCount){var e=this.masterRowCount-1;this.totalPages=Math.floor(e/this.pageSize)+1,this.currentPage>=this.totalPages&&(this.currentPage=this.totalPages-1),(!l.f.isNumeric(this.currentPage)||this.currentPage<0)&&(this.currentPage=0),this.topDisplayedRowIndex=this.pageSize*this.currentPage,this.bottomDisplayedRowIndex=this.pageSize*(this.currentPage+1)-1,this.bottomDisplayedRowIndex>e&&(this.bottomDisplayedRowIndex=e)}else this.setZeroRows()},t.prototype.calculatedPagesNotActive=function(){this.pageSize=this.rowModel.getRowCount(),this.totalPages=1,this.currentPage=0,this.topDisplayedRowIndex=0,this.bottomDisplayedRowIndex=this.rowModel.getRowCount()-1},s([Object(i.a)("rowModel")],t.prototype,"rowModel",void 0),s([Object(i.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),s([Object(i.a)("selectionController")],t.prototype,"selectionController",void 0),s([Object(i.a)("columnApi")],t.prototype,"columnApi",void 0),s([Object(i.a)("gridApi")],t.prototype,"gridApi",void 0),s([i.e],t.prototype,"postConstruct",null),t=s([Object(i.b)("paginationProxy")],t)}(a.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return g}));var r,a=o(1),n=o(6),i=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),l=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},g=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.cacheVersion=0,t}return i(t,e),t.prototype.init=function(){this.active=this.gridOptionsWrapper.isValueCache(),this.neverExpires=this.gridOptionsWrapper.isValueCacheNeverExpires()},t.prototype.onDataChanged=function(){this.neverExpires||this.expire()},t.prototype.expire=function(){this.cacheVersion++},t.prototype.setValue=function(e,t,o){this.active&&(e.__cacheVersion!==this.cacheVersion&&(e.__cacheVersion=this.cacheVersion,e.__cacheData={}),e.__cacheData[t]=o)},t.prototype.getValue=function(e,t){if(this.active&&e.__cacheVersion===this.cacheVersion)return e.__cacheData[t]},l([Object(a.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),l([a.e],t.prototype,"init",null),t=l([Object(a.b)("valueCache")],t)}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return p}));var r,a=o(4),n=o(1),i=o(6),l=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),g=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},s=function(e,t){return function(o,r){t(o,r,e)}},p=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.consuming=!1,t}return l(t,e),t.prototype.setBeans=function(e){this.logger=e.create("AlignedGridsService")},t.prototype.registerGridComp=function(e){this.gridPanel=e},t.prototype.init=function(){this.addManagedListener(this.eventService,a.a.EVENT_COLUMN_MOVED,this.fireColumnEvent.bind(this)),this.addManagedListener(this.eventService,a.a.EVENT_COLUMN_VISIBLE,this.fireColumnEvent.bind(this)),this.addManagedListener(this.eventService,a.a.EVENT_COLUMN_PINNED,this.fireColumnEvent.bind(this)),this.addManagedListener(this.eventService,a.a.EVENT_COLUMN_GROUP_OPENED,this.fireColumnEvent.bind(this)),this.addManagedListener(this.eventService,a.a.EVENT_COLUMN_RESIZED,this.fireColumnEvent.bind(this)),this.addManagedListener(this.eventService,a.a.EVENT_BODY_SCROLL,this.fireScrollEvent.bind(this))},t.prototype.fireEvent=function(e){if(!this.consuming){var t=this.gridOptionsWrapper.getAlignedGrids();t&&t.forEach((function(t){if(t.api){var o=t.api.__getAlignedGridService();e(o)}}))}},t.prototype.onEvent=function(e){this.consuming=!0,e(),this.consuming=!1},t.prototype.fireColumnEvent=function(e){this.fireEvent((function(t){t.onColumnEvent(e)}))},t.prototype.fireScrollEvent=function(e){"horizontal"===e.direction&&this.fireEvent((function(t){t.onScrollEvent(e)}))},t.prototype.onScrollEvent=function(e){var t=this;this.onEvent((function(){t.gridPanel.setHorizontalScrollPosition(e.left)}))},t.prototype.getMasterColumns=function(e){var t=[];return e.columns?e.columns.forEach((function(e){t.push(e)})):e.column&&t.push(e.column),t},t.prototype.getColumnIds=function(e){var t=[];return e.columns?e.columns.forEach((function(e){t.push(e.getColId())})):e.column&&t.push(e.column.getColId()),t},t.prototype.onColumnEvent=function(e){var t=this;this.onEvent((function(){switch(e.type){case a.a.EVENT_COLUMN_MOVED:case a.a.EVENT_COLUMN_VISIBLE:case a.a.EVENT_COLUMN_PINNED:case a.a.EVENT_COLUMN_RESIZED:var o=e;t.processColumnEvent(o);break;case a.a.EVENT_COLUMN_GROUP_OPENED:var r=e;t.processGroupOpenedEvent(r);break;case a.a.EVENT_COLUMN_PIVOT_CHANGED:console.warn("ag-Grid: pivoting is not supported with aligned grids. You can only use one of these features at a time in a grid.")}}))},t.prototype.processGroupOpenedEvent=function(e){var t,o=e.columnGroup;if(o){var r=o.getGroupId();t=this.columnController.getOriginalColumnGroup(r)}o&&!t||(this.logger.log("onColumnEvent-> processing "+e+" expanded = "+o.isExpanded()),this.columnController.setColumnGroupOpened(t,o.isExpanded(),"alignedGridChanged"))},t.prototype.processColumnEvent=function(e){var t,o=this,r=e.column;if(r&&(t=this.columnController.getPrimaryColumn(r.getColId())),!r||t){var n=this.getColumnIds(e),i=this.getMasterColumns(e);switch(e.type){case a.a.EVENT_COLUMN_MOVED:var l=e;this.logger.log("onColumnEvent-> processing "+e.type+" toIndex = "+l.toIndex),this.columnController.moveColumns(n,l.toIndex,"alignedGridChanged");break;case a.a.EVENT_COLUMN_VISIBLE:var g=e;this.logger.log("onColumnEvent-> processing "+e.type+" visible = "+g.visible),this.columnController.setColumnsVisible(n,g.visible,"alignedGridChanged");break;case a.a.EVENT_COLUMN_PINNED:var s=e;this.logger.log("onColumnEvent-> processing "+e.type+" pinned = "+s.pinned),this.columnController.setColumnsPinned(n,s.pinned,"alignedGridChanged");break;case a.a.EVENT_COLUMN_RESIZED:var p=e;i.forEach((function(t){o.logger.log("onColumnEvent-> processing "+e.type+" actualWidth = "+t.getActualWidth());var r=[{key:t.getColId(),newWidth:t.getActualWidth()}];o.columnController.setColumnWidths(r,!1,p.finished,"alignedGridChanged")}))}var c=this.gridPanel.isVerticalScrollShowing();this.gridOptionsWrapper.getAlignedGrids().forEach((function(e){e.api.setAlwaysShowVerticalScroll(c)}))}},g([Object(n.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),g([Object(n.a)("columnController")],t.prototype,"columnController",void 0),g([s(0,Object(n.h)("loggerFactory"))],t.prototype,"setBeans",null),g([n.e],t.prototype,"init",null),t=g([Object(n.b)("alignedGridsService")],t)}(i.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return d}));var r,a=o(1),n=o(6),i=o(0),l=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),g=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},s={"ag-theme-custom":{headerHeight:25,headerCellMinWidth:24,listItemHeight:20,rowHeight:25,chartMenuPanelWidth:220},"ag-theme-material":{headerHeight:56,headerCellMinWidth:48,listItemHeight:40,rowHeight:48,chartMenuPanelWidth:240},"ag-theme-balham":{headerHeight:32,headerCellMinWidth:24,listItemHeight:28,rowHeight:28,chartMenuPanelWidth:220},"ag-theme-alpine":{headerHeight:48,headerCellMinWidth:36,listItemHeight:30,rowHeight:42,chartMenuPanelWidth:240}},p={headerHeight:["ag-header-row"],headerCellMinWidth:["ag-header-cell"],listItemHeight:["ag-virtual-list-item"],rowHeight:["ag-row"],chartMenuPanelWidth:["ag-chart-docked-container"]},c={},d=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return l(t,e),t.prototype.getSassVariable=function(e,t){var o="ag-theme-"+(e.match("material")?"material":e.match("balham")?"balham":e.match("alpine")?"alpine":"custom"),r=s[o][t],a=0;if(c[e]||(c[e]={}),c[e][t])return c[e][t];if(p[t]){var n=p[t],l=document.createElement("div");l.style.position="absolute";var g=n.reduce((function(t,o,r){0===r&&i.f.addCssClass(t,e);var a=document.createElement("div");return a.style.position="static",i.f.addCssClass(a,o),t.appendChild(a),a}),l);if(document.body){document.body.appendChild(l);var d=-1!==t.toLowerCase().indexOf("height")?"height":"width";a=parseInt(window.getComputedStyle(g)[d],10),document.body.removeChild(l)}}return c[e][t]=a||r,c[e][t]},t.prototype.isThemeDark=function(){var e=this.getTheme().theme;return!!e&&e.indexOf("dark")>=0},t.prototype.chartMenuPanelWidth=function(){var e=this.getTheme().themeFamily;return this.getSassVariable(e,"chartMenuPanelWidth")},t.prototype.getTheme=function(){for(var e,t=/\bag-(material|(?:theme-([\w\-]*)))\b/,o=this.eGridDiv;o&&!(e=t.exec(o.className));)o=o.parentElement;if(!e)return{};var r=e[0];if(void 0===e[2]){var a=r.replace("ag-","ag-theme-");i.f.doOnce((function(){return console.warn("ag-Grid: As of v19 old theme are no longer provided. Please replace "+r+" with "+a+".")}),"using-old-theme")}return{theme:r,el:o,themeFamily:r.replace(/-dark$/,"")}},g([Object(a.a)("eGridDiv")],t.prototype,"eGridDiv",void 0),t=g([Object(a.b)("environment")],t)}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return s}));var r,a=o(1),n=o(0),i=o(6),l=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),g=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},s=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return l(t,e),t.prototype.init=function(){this.groupSelectsChildren=this.gridOptionsWrapper.isGroupSelectsChildren(),this.isRowSelectableFunc=this.gridOptionsWrapper.getIsRowSelectableFunc()},t.prototype.updateSelectableAfterGrouping=function(e){if(this.isRowSelectableFunc){this.recurseDown(e.childrenAfterGroup,(function(e){return e.childrenAfterGroup}))}},t.prototype.updateSelectableAfterFiltering=function(e){if(this.isRowSelectableFunc){this.recurseDown(e.childrenAfterGroup,(function(e){return e.childrenAfterFilter}))}},t.prototype.recurseDown=function(e,t){var o=this;e.forEach((function(e){if(e.group){var r;if(e.hasChildren()&&o.recurseDown(t(e),t),o.groupSelectsChildren){var a=n.f.find(t(e),"selectable",!0);r=n.f.exists(a)}else r=!!o.isRowSelectableFunc&&o.isRowSelectableFunc(e);e.setRowSelectable(r)}}))},g([Object(a.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),g([a.e],t.prototype,"init",null),t=g([Object(a.b)("selectableService")],t)}(i.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return s}));var r,a=o(1),n=o(6),i=o(0),l=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),g=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},s=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return l(t,e),t.prototype.observeResize=function(e,t,o){void 0===o&&(o=50);var r,a,n,l,g,s=this.getFrameworkOverrides(),p=i.f.debounce(t,o),c=this.gridOptionsWrapper.isSuppressBrowserResizeObserver();return!!window.ResizeObserver&&!c?((g=new window.ResizeObserver(p)).observe(e),function(){return g.disconnect()}):(r=i.f.offsetWidth(e),a=i.f.offsetHeight(e),n=!0,(l=function(){if(n){var g=i.f.offsetWidth(e),p=i.f.offsetHeight(e);(g!==r||p!==a)&&(r=g,a=p,t()),s.setTimeout(l,o)}})(),function(){return n=!1})},g([Object(a.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),t=g([Object(a.b)("resizeObserverService")],t)}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return c}));var r,a=o(7),n=o(5),i=o(1),l=o(2),g=o(0),s=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),p=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},c=function(e){function t(o){void 0===o&&(o={});var r=e.call(this,t.getTemplate(o))||this;r.suppressEnabledCheckbox=!0,r.suppressOpenCloseIcons=!1;var a=o.title,n=o.enabled,i=o.items,l=o.suppressEnabledCheckbox,g=o.suppressOpenCloseIcons;return r.title=a,r.cssIdentifier=o.cssIdentifier||"default",r.enabled=null==n||n,r.items=i||[],r.alignItems=o.alignItems||"center",null!=l&&(r.suppressEnabledCheckbox=l),null!=g&&(r.suppressOpenCloseIcons=g),r}return s(t,e),t.getTemplate=function(e){var t=e.cssIdentifier||"default";return'
\n
\n \n \n \n
\n
\n \n
\n
\n
'},t.prototype.postConstruct=function(){if(this.items.length){var e=this.items;this.items=[],this.addItems(e)}var t=this.gridOptionsWrapper.getLocaleTextFunc();this.cbGroupEnabled.setLabel(t("enabled","Enabled")),this.title&&this.setTitle(this.title),this.enabled&&this.setEnabled(this.enabled),this.setAlignItems(this.alignItems),this.hideEnabledCheckbox(this.suppressEnabledCheckbox),this.hideOpenCloseIcons(this.suppressOpenCloseIcons),this.setupExpandContract(),this.refreshChildDisplay()},t.prototype.setupExpandContract=function(){var e=this;this.eGroupClosedIcon.appendChild(g.f.createIcon("columnSelectClosed",this.gridOptionsWrapper,null)),this.eGroupOpenedIcon.appendChild(g.f.createIcon("columnSelectOpen",this.gridOptionsWrapper,null)),this.addManagedListener(this.eTitleBar,"click",(function(){return e.toggleGroupExpand()})),this.addManagedListener(this.eTitleBar,"keydown",(function(t){t.keyCode===l.a.KEY_ENTER&&e.toggleGroupExpand()}))},t.prototype.refreshChildDisplay=function(){var e=!this.suppressOpenCloseIcons;g.f.setDisplayed(this.eGroupClosedIcon,e&&!this.expanded),g.f.setDisplayed(this.eGroupOpenedIcon,e&&this.expanded),g.f.setDisplayed(this.eToolbar,this.expanded&&!this.suppressEnabledCheckbox)},t.prototype.isExpanded=function(){return this.expanded},t.prototype.setAlignItems=function(e){var t=this.getGui();this.alignItems!==e&&g.f.removeCssClass(t,"ag-group-item-alignment-"+this.alignItems),this.alignItems=e;var o="ag-group-item-alignment-"+this.alignItems;return g.f.addCssClass(t,o),this},t.prototype.toggleGroupExpand=function(e){return this.suppressOpenCloseIcons?(this.expanded=!0,this.refreshChildDisplay(),g.f.setDisplayed(this.eContainer,!0),this):(e=null!=e?e:!this.expanded,this.expanded===e||(this.expanded=e,this.refreshChildDisplay(),g.f.setDisplayed(this.eContainer,e),this.expanded?this.dispatchEvent({type:t.EVENT_EXPANDED}):this.dispatchEvent({type:t.EVENT_COLLAPSED})),this)},t.prototype.addItems=function(e){var t=this;e.forEach((function(e){return t.addItem(e)}))},t.prototype.addItem=function(e){var t=this.eContainer,o=e instanceof a.a?e.getGui():e;g.f.addCssClass(o,"ag-group-item"),g.f.addCssClass(o,"ag-"+this.cssIdentifier+"-group-item"),t.appendChild(o),this.items.push(o)},t.prototype.hideItem=function(e,t){var o=this.items[t];g.f.addOrRemoveCssClass(o,"ag-hidden",e)},t.prototype.setTitle=function(e){return this.eTitle.innerText=e,this},t.prototype.addCssClassToTitleBar=function(e){g.f.addCssClass(this.eTitleBar,e)},t.prototype.setEnabled=function(e,t){return this.enabled=e,this.refreshDisabledStyles(),this.toggleGroupExpand(e),t||this.cbGroupEnabled.setValue(e),this},t.prototype.isEnabled=function(){return this.enabled},t.prototype.onEnableChange=function(e){var t=this;return this.cbGroupEnabled.onValueChange((function(o){t.setEnabled(o,!0),e(o)})),this},t.prototype.hideEnabledCheckbox=function(e){return this.suppressEnabledCheckbox=e,this.refreshChildDisplay(),this.refreshDisabledStyles(),this},t.prototype.hideOpenCloseIcons=function(e){return this.suppressOpenCloseIcons=e,e&&this.toggleGroupExpand(!0),this},t.prototype.refreshDisabledStyles=function(){g.f.addOrRemoveCssClass(this.getGui(),"ag-disabled",!this.enabled),this.suppressEnabledCheckbox&&!this.enabled?(g.f.addCssClass(this.eTitleBar,"ag-disabled-group-title-bar"),this.eTitleBar.removeAttribute("tabindex")):(g.f.removeCssClass(this.eTitleBar,"ag-disabled-group-title-bar"),this.eTitleBar.setAttribute("tabindex","0")),g.f.addOrRemoveCssClass(this.eContainer,"ag-disabled-group-container",!this.enabled)},t.EVENT_EXPANDED="expanded",t.EVENT_COLLAPSED="collapsed",p([Object(i.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),p([Object(n.d)("eTitleBar")],t.prototype,"eTitleBar",void 0),p([Object(n.d)("eGroupOpenedIcon")],t.prototype,"eGroupOpenedIcon",void 0),p([Object(n.d)("eGroupClosedIcon")],t.prototype,"eGroupClosedIcon",void 0),p([Object(n.d)("eToolbar")],t.prototype,"eToolbar",void 0),p([Object(n.d)("cbGroupEnabled")],t.prototype,"cbGroupEnabled",void 0),p([Object(n.d)("eTitle")],t.prototype,"eTitle",void 0),p([Object(n.d)("eContainer")],t.prototype,"eContainer",void 0),p([i.e],t.prototype,"postConstruct",null),t}(a.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return i}));var r,a=o(43),n=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),i=function(e){function t(t){var o=e.call(this)||this;return o.className="ag-text-area",o.displayTag="textarea",o.inputType="",o.setTemplate(o.TEMPLATE.replace(/%displayField%/g,o.displayTag)),t&&(o.config=t),o}return n(t,e),t.prototype.setValue=function(t,o){var r=e.prototype.setValue.call(this,t,o);return this.eInput.value=t,r},t.prototype.setCols=function(e){return this.eInput.cols=e,this},t.prototype.setRows=function(e){return this.eInput.rows=e,this},t}(a.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return c}));var r,a=o(5),n=o(67),i=o(22),l=o(1),g=o(0),s=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),p=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},c=function(e){function t(){var o=e.call(this,t.TEMPLATE)||this;return o.labelAlignment="top",o}return s(t,e),t.prototype.init=function(){g.f.addCssClass(this.eSlider.getGui(),"ag-slider-field")},t.prototype.onValueChange=function(e){var t=this,o=i.a.EVENT_CHANGED;return this.addManagedListener(this.eText,o,(function(){var o=parseFloat(t.eText.getValue());t.eSlider.setValue(o.toString(),!0),e(o||0)})),this.addManagedListener(this.eSlider,o,(function(){var o=t.eSlider.getValue();t.eText.setValue(o,!0),e(parseFloat(o))})),this},t.prototype.setSliderWidth=function(e){return this.eSlider.setWidth(e),this},t.prototype.setTextFieldWidth=function(e){return this.eText.setWidth(e),this},t.prototype.setMinValue=function(e){return this.eSlider.setMinValue(e),this.eText.setMin(e),this},t.prototype.setMaxValue=function(e){return this.eSlider.setMaxValue(e),this.eText.setMax(e),this},t.prototype.getValue=function(){return this.eText.getValue()},t.prototype.setValue=function(e){return this.getValue()===e||(this.eText.setValue(e,!0),this.eSlider.setValue(e,!0),this.dispatchEvent({type:i.a.EVENT_CHANGED})),this},t.prototype.setStep=function(e){return this.eSlider.setStep(e),this.eText.setStep(e),this},t.TEMPLATE='
\n \n
\n \n \n
\n
',p([Object(a.d)("eLabel")],t.prototype,"eLabel",void 0),p([Object(a.d)("eSlider")],t.prototype,"eSlider",void 0),p([Object(a.d)("eText")],t.prototype,"eText",void 0),p([l.e],t.prototype,"init",null),t}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return i}));var r,a=o(64),n=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),i=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.className="ag-number-field",t.inputType="number",t}return n(t,e),t.prototype.postConstruct=function(){var t=this;e.prototype.postConstruct.call(this),this.addManagedListener(this.eInput,"blur",(function(){var e=parseFloat(t.eInput.value),o=isNaN(e)?"":t.normalizeValue(e.toString());t.value!==o&&t.setValue(o)}))},t.prototype.normalizeValue=function(e){if(""===e)return"";this.precision&&(e=this.adjustPrecision(e));var t=parseFloat(e);return null!=this.min&&tthis.max&&(e=this.max.toString()),e},t.prototype.adjustPrecision=function(e){if(this.precision){var t=parseFloat(e).toFixed(this.precision);e=parseFloat(t).toString()}return e},t.prototype.setMin=function(e){return this.min===e||(this.min=e,null!=this.min?this.eInput.setAttribute("min",e.toString()):this.eInput.removeAttribute("min")),this},t.prototype.setMax=function(e){return this.max===e||(this.max=e,null!=this.max?this.eInput.setAttribute("max",e.toString()):this.eInput.removeAttribute("max")),this},t.prototype.setPrecision=function(e){return this.precision=e,this},t.prototype.setStep=function(e){return this.step===e||(this.step=e,null!=e?this.eInput.setAttribute("step",e.toString()):this.eInput.removeAttribute("step")),this},t.prototype.setValue=function(t,o){return(t=this.adjustPrecision(t))!=this.normalizeValue(t)?this:e.prototype.setValue.call(this,t,o)},t}(a.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return l}));var r,a=o(43),n=o(0),i=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),l=function(e){function t(t){var o=e.call(this)||this;return o.className="ag-range-field",o.displayTag="input",o.inputType="range",o.setTemplate(o.TEMPLATE.replace(/%displayField%/g,o.displayTag)),t&&(o.config=t),o}return i(t,e),t.prototype.postConstruct=function(){e.prototype.postConstruct.call(this);var t=this.config,o=t.min,r=t.max,a=t.step;null!=o&&this.setMinValue(o),null!=r&&this.setMaxValue(r),this.setStep(a||1)},t.prototype.addInputListeners=function(){var e=this,t=n.f.isBrowserIE()?"change":"input";this.addManagedListener(this.eInput,t,(function(t){var o=t.target.value;e.setValue(o)}))},t.prototype.setMinValue=function(e){return this.min=e,this.eInput.setAttribute("min",e.toString()),this},t.prototype.setMaxValue=function(e){return this.max=e,this.eInput.setAttribute("max",e.toString()),this},t.prototype.setStep=function(e){return this.step=e,this.eInput.setAttribute("step",e.toString()),this},t.prototype.setValue=function(t,o){null!=this.min&&(t=Math.max(parseFloat(t),this.min).toString()),null!=this.max&&(t=Math.min(parseFloat(t),this.max).toString());var r=e.prototype.setValue.call(this,t,o);return this.eInput.value=t,r},t}(a.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return c}));var r,a=o(67),n=o(5),i=o(1),l=o(22),g=o(0),s=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),p=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},c=function(e){function t(){var o=e.call(this,t.TEMPLATE)||this;return o.radius=0,o.offsetX=0,o.offsetY=0,o}return s(t,e),t.prototype.postConstruct=function(){var t=this;e.prototype.postConstruct.call(this),this.dragListener={eElement:this.eParentCircle,dragStartPixels:0,onDragStart:function(e){t.parentCircleRect=t.eParentCircle.getBoundingClientRect()},onDragging:function(e){return t.calculateAngleDrag(e)},onDragStop:function(){}},this.dragService.addDragSource(this.dragListener),this.eAngleValue.setLabel("").setLabelWidth(5).setInputWidth(45).setMin(0).setMax(360).setValue(""+this.degrees).onValueChange((function(e){null!=e&&""!==e||(e="0"),e=t.eAngleValue.normalizeValue(e);var o=parseFloat(e);o>180&&(o-=360),t.setValue(o)})),this.updateNumberInput(),g.f.exists(this.getValue())&&this.eAngleValue.setValue(this.normalizeNegativeValue(this.getValue()).toString()),this.addManagedListener(this,l.a.EVENT_CHANGED,(function(){t.eAngleValue.getInputElement().contains(document.activeElement)||t.updateNumberInput()}))},t.prototype.updateNumberInput=function(){var e=this.normalizeNegativeValue(this.getValue());this.eAngleValue.setValue(e.toString())},t.prototype.positionChildCircle=function(e){var t=this.parentCircleRect||{width:24,height:24},o=this.eChildCircle,r=t.width/2,a=t.height/2;o.style.left=r+8*Math.cos(e)+"px",o.style.top=a+8*Math.sin(e)+"px"},t.prototype.calculatePolar=function(){var e=this.offsetX,t=this.offsetY,o=Math.atan2(t,e);this.degrees=this.toDegrees(o),this.radius=Math.sqrt(e*e+t*t),this.positionChildCircle(o)},t.prototype.calculateCartesian=function(){var e=this.toRadians(this.getValue()),t=this.getRadius();this.setOffsetX(Math.cos(e)*t).setOffsetY(Math.sin(e)*t)},t.prototype.setOffsetX=function(e){return this.offsetX!==e&&(this.offsetX=e,this.calculatePolar()),this},t.prototype.setOffsetY=function(e){return this.offsetY!==e&&(this.offsetY=e,this.calculatePolar()),this},t.prototype.calculateAngleDrag=function(e){var t=this.parentCircleRect,o=t.width/2,r=t.height/2,a=e.clientX-t.left-o,n=e.clientY-t.top-r,i=Math.atan2(n,a);this.setValue(i,!0)},t.prototype.toDegrees=function(e){return e/Math.PI*180},t.prototype.toRadians=function(e){return e/180*Math.PI},t.prototype.normalizeNegativeValue=function(e){return e<0?360+e:e},t.prototype.normalizeAngle180=function(e){return(e%=2*Math.PI)<-Math.PI?e+=2*Math.PI:e>=Math.PI&&(e-=2*Math.PI),e},t.prototype.getRadius=function(){return this.radius},t.prototype.setRadius=function(e){return this.radius===e||(this.radius=e,this.calculateCartesian()),this},t.prototype.onValueChange=function(e){var t=this;return this.addManagedListener(this,l.a.EVENT_CHANGED,(function(){e(t.degrees)})),this},t.prototype.getValue=function(e){return e?this.toRadians(this.degrees):this.degrees},t.prototype.setValue=function(e,t){var o;return o=t?e:this.normalizeAngle180(this.toRadians(e)),e=this.toDegrees(o),this.degrees!==e&&(this.degrees=Math.floor(e),this.calculateCartesian(),this.positionChildCircle(o),this.dispatchEvent({type:l.a.EVENT_CHANGED})),this},t.prototype.setWidth=function(e){return g.f.setFixedWidth(this.getGui(),e),this},t.prototype.destroy=function(){this.dragService.removeDragSource(this.dragListener),e.prototype.destroy.call(this)},t.TEMPLATE='
\n \n
\n
\n
\n
\n
\n
\n \n
\n
',p([Object(n.d)("eLabel")],t.prototype,"eLabel",void 0),p([Object(n.d)("eParentCircle")],t.prototype,"eParentCircle",void 0),p([Object(n.d)("eChildCircle")],t.prototype,"eChildCircle",void 0),p([Object(n.d)("eAngleValue")],t.prototype,"eAngleValue",void 0),p([Object(i.a)("dragService")],t.prototype,"dragService",void 0),t}(a.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return l}));var r,a=o(61),n=o(0),i=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),l=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.className="ag-toggle-button",t.inputType="checkbox",t}return i(t,e),t.prototype.setValue=function(t,o){return e.prototype.setValue.call(this,t,o),n.f.addOrRemoveCssClass(this.getGui(),"ag-selected",this.getValue()),this},t}(a.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return p}));var r,a=o(1),n=o(6),i=o(2),l=o(0),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return g(t,e),t.prototype.getFirstRow=function(){var e;return this.pinnedRowModel.getPinnedTopRowCount()?e=i.a.PINNED_TOP:this.rowModel.getRowCount()?e=null:this.pinnedRowModel.getPinnedBottomRowCount()&&(e=i.a.PINNED_BOTTOM),void 0===e?null:{rowIndex:0,rowPinned:e}},t.prototype.getRowNode=function(e){switch(e.rowPinned){case i.a.PINNED_TOP:return this.pinnedRowModel.getPinnedTopRowData()[e.rowIndex];case i.a.PINNED_BOTTOM:return this.pinnedRowModel.getPinnedBottomRowData()[e.rowIndex];default:return this.rowModel.getRow(e.rowIndex)}},t.prototype.sameRow=function(e,t){return!e&&!t||!(e&&!t||!e&&t)&&(e.rowIndex===t.rowIndex&&e.rowPinned==t.rowPinned)},t.prototype.before=function(e,t){switch(e.rowPinned){case i.a.PINNED_TOP:if(t.rowPinned!==i.a.PINNED_TOP)return!0;break;case i.a.PINNED_BOTTOM:if(t.rowPinned!==i.a.PINNED_BOTTOM)return!1;break;default:if(l.f.exists(t.rowPinned))return t.rowPinned!==i.a.PINNED_TOP}return e.rowIndex=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},g=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return i(t,e),t.prototype.createId=function(e){var t=e.rowIndex,o=e.rowPinned,r=e.column;return this.createIdFromValues(t,r,o)},t.prototype.createIdFromValues=function(e,t,o){return e+"."+(null==o?"null":o)+"."+t.getId()},t.prototype.equals=function(e,t){var o=e.column===t.column,r=e.rowPinned===t.rowPinned,a=e.rowIndex===t.rowIndex;return o&&r&&a},t=l([Object(a.b)("cellPositionUtils")],t)}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return d}));var r,a=o(16),n=o(1),i=o(4),l=o(2),g=o(0),s=o(6),p=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),c=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},d=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return p(t,e),t.prototype.init=function(){this.setPinnedTopRowData(this.gridOptionsWrapper.getPinnedTopRowData()),this.setPinnedBottomRowData(this.gridOptionsWrapper.getPinnedBottomRowData())},t.prototype.isEmpty=function(e){var t=e===l.a.PINNED_TOP?this.pinnedTopRows:this.pinnedBottomRows;return g.f.missingOrEmpty(t)},t.prototype.isRowsToRender=function(e){return!this.isEmpty(e)},t.prototype.getRowAtPixel=function(e,t){var o=t===l.a.PINNED_TOP?this.pinnedTopRows:this.pinnedBottomRows;if(g.f.missingOrEmpty(o))return 0;for(var r=0;r=e)return r}return o.length-1},t.prototype.setPinnedTopRowData=function(e){this.pinnedTopRows=this.createNodesFromData(e,!0);var t={type:i.a.EVENT_PINNED_ROW_DATA_CHANGED,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(t)},t.prototype.setPinnedBottomRowData=function(e){this.pinnedBottomRows=this.createNodesFromData(e,!1);var t={type:i.a.EVENT_PINNED_ROW_DATA_CHANGED,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(t)},t.prototype.createNodesFromData=function(e,t){var o=this,r=[];if(e){var n=0;e.forEach((function(e,i){var g=new a.a;o.context.createBean(g),g.data=e;var s=t?a.a.ID_PREFIX_TOP_PINNED:a.a.ID_PREFIX_BOTTOM_PINNED;g.id=s+i,g.rowPinned=t?l.a.PINNED_TOP:l.a.PINNED_BOTTOM,g.setRowTop(n),g.setRowHeight(o.gridOptionsWrapper.getRowHeightForNode(g).height),g.setRowIndex(i),n+=g.rowHeight,r.push(g)}))}return r},t.prototype.getPinnedTopRowData=function(){return this.pinnedTopRows},t.prototype.getPinnedBottomRowData=function(){return this.pinnedBottomRows},t.prototype.getPinnedTopTotalHeight=function(){return this.getTotalHeight(this.pinnedTopRows)},t.prototype.getPinnedTopRowCount=function(){return this.pinnedTopRows?this.pinnedTopRows.length:0},t.prototype.getPinnedBottomRowCount=function(){return this.pinnedBottomRows?this.pinnedBottomRows.length:0},t.prototype.getPinnedTopRow=function(e){return this.pinnedTopRows[e]},t.prototype.getPinnedBottomRow=function(e){return this.pinnedBottomRows[e]},t.prototype.forEachPinnedTopRow=function(e){g.f.missingOrEmpty(this.pinnedTopRows)||this.pinnedTopRows.forEach(e)},t.prototype.forEachPinnedBottomRow=function(e){g.f.missingOrEmpty(this.pinnedBottomRows)||this.pinnedBottomRows.forEach(e)},t.prototype.getPinnedBottomTotalHeight=function(){return this.getTotalHeight(this.pinnedBottomRows)},t.prototype.getTotalHeight=function(e){if(e&&0!==e.length){var t=g.f.last(e);return t.rowTop+t.rowHeight}return 0},c([Object(n.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),c([Object(n.a)("columnApi")],t.prototype,"columnApi",void 0),c([Object(n.a)("gridApi")],t.prototype,"gridApi",void 0),c([n.e],t.prototype,"init",null),t=c([Object(n.b)("pinnedRowModel")],t)}(s.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return p}));var r,a=o(20),n=o(1),i=o(6),l=o(31),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return g(t,e),t.prototype.findHeader=function(e,t){var o,r,n;if(e.column instanceof a.a?(r="getDisplayedGroup"+t,o=this.columnController[r](e.column)):(n="getDisplayedCol"+t,o=this.columnController[n](e.column)),o)return{column:o,headerRowIndex:e.headerRowIndex}},t.prototype.findColAtEdgeForHeaderRow=function(e,t){var o=this.columnController.getAllDisplayedColumns(),r=o["start"===t?0:o.length-1];if(r){var a=this.headerNavigationService.getHeaderContainer(r.getPinned()).getRowComps()[e];return(a&&a.getType())==l.b.COLUMN_GROUP?{headerRowIndex:e,column:this.columnController.getColumnGroupAtLevel(r,e)}:{headerRowIndex:a?e:-1,column:r}}},s([Object(n.a)("columnController")],t.prototype,"columnController",void 0),s([Object(n.a)("headerNavigationService")],t.prototype,"headerNavigationService",void 0),t=s([Object(n.b)("headerPositionUtils")],t)}(i.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return S}));var r,a=o(15),n=o(1),i=o(4),l=o(2),g=o(0),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(){function e(e){this.childCount=0,this.rowTemplatesToAdd=[],this.afterGuiAttachedCallbacks=[],this.lastMadeVisibleTime=0,this.eContainer=e.eContainer,this.eViewport=e.eViewport,e.eWrapper&&(this.eWrapper=e.eWrapper),this.hideWhenNoChildren=e.hideWhenNoChildren}return e.prototype.setVerticalScrollPosition=function(e){this.scrollTop=e},e.prototype.postConstruct=function(){this.checkDomOrder(),this.checkVisibility(),this.gridOptionsWrapper.addEventListener(a.a.PROP_DOM_LAYOUT,this.checkDomOrder.bind(this))},e.prototype.checkDomOrder=function(){this.domOrder=this.gridOptionsWrapper.isEnsureDomOrder()},e.prototype.getRowElement=function(e){return this.eContainer.querySelector('[comp-id="'+e+'"]')},e.prototype.setHeight=function(e){null!=e?(this.eContainer.style.height=e+"px",this.eWrapper&&(this.eWrapper.style.height=e+"px")):this.eContainer.style.height=""},e.prototype.flushRowTemplates=function(){if(0!==this.rowTemplatesToAdd.length){var e=this.rowTemplatesToAdd.join("");g.f.appendHtml(this.eContainer,e),this.rowTemplatesToAdd.length=0}this.afterGuiAttachedCallbacks.forEach((function(e){return e()})),this.afterGuiAttachedCallbacks.length=0,this.lastPlacedElement=null},e.prototype.appendRowTemplate=function(e,t){this.domOrder?this.lastPlacedElement=g.f.insertTemplateWithDomOrder(this.eContainer,e,this.lastPlacedElement):this.rowTemplatesToAdd.push(e),this.afterGuiAttachedCallbacks.push(t),this.childCount++,this.checkVisibility()},e.prototype.ensureDomOrder=function(e){this.domOrder&&(g.f.ensureDomOrder(this.eContainer,e,this.lastPlacedElement),this.lastPlacedElement=e)},e.prototype.removeRowElement=function(e){this.eContainer.removeChild(e),this.childCount--,this.checkVisibility()},e.prototype.checkVisibility=function(){if(this.hideWhenNoChildren){var e=this.eViewport?this.eViewport:this.eContainer,t=this.childCount>0;this.visible!==t&&(this.visible=t,this.lastMadeVisibleTime=(new Date).getTime(),g.f.setDisplayed(e,t),t&&this.eViewport&&(this.eViewport.scrollTop=this.scrollTop))}},e.prototype.isMadeVisibleRecently=function(){return(new Date).getTime()-this.lastMadeVisibleTime<500},s([Object(n.a)("gridOptionsWrapper")],e.prototype,"gridOptionsWrapper",void 0),s([n.e],e.prototype,"postConstruct",null),e}(),c=o(47),d=o(24),u=o(13),h=o(9),f=o(17),m=o(6),b=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),v=function(){return(v=Object.assign||function(e){for(var t,o=1,r=arguments.length;o=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},w=function(){for(var e=0,t=0,o=arguments.length;tt.bottom-50,this.needToMoveUp||this.needToMoveDown?this.ensureIntervalStarted():this.ensureIntervalCleared()},t.prototype.ensureIntervalStarted=function(){this.movingIntervalId||(this.intervalCount=0,this.movingIntervalId=window.setInterval(this.moveInterval.bind(this),100))},t.prototype.ensureIntervalCleared=function(){this.moveInterval&&(window.clearInterval(this.movingIntervalId),this.movingIntervalId=null)},t.prototype.moveInterval=function(){var e,t;this.intervalCount++,(e=10+5*this.intervalCount)>100&&(e=100),this.needToMoveDown?t=this.gridPanel.scrollVertically(e):this.needToMoveUp&&(t=this.gridPanel.scrollVertically(-e)),0!==t&&this.onDragging(this.lastDraggingEvent)},t.prototype.addRowDropZone=function(e){var t=this;if(e.getContainer())if(this.dragAndDropService.findExternalZone(e))console.warn("ag-Grid: addRowDropZone - target already exists in the list of DropZones. Use `removeRowDropZone` before adding it again.");else{var o={getContainer:e.getContainer};e.fromGrid?(e.fromGrid=void 0,o=e):(e.onDragEnter&&(o.onDragEnter=function(o){e.onDragEnter(t.draggingToRowDragEvent(h.a.EVENT_ROW_DRAG_ENTER,o))}),e.onDragLeave&&(o.onDragLeave=function(o){e.onDragLeave(t.draggingToRowDragEvent(h.a.EVENT_ROW_DRAG_LEAVE,o))}),e.onDragging&&(o.onDragging=function(o){e.onDragging(t.draggingToRowDragEvent(h.a.EVENT_ROW_DRAG_MOVE,o))}),e.onDragStop&&(o.onDragStop=function(o){e.onDragStop(t.draggingToRowDragEvent(h.a.EVENT_ROW_DRAG_END,o))})),this.dragAndDropService.addDropTarget(v({isInterestedIn:function(e){return e===u.b.RowDrag},getIconName:function(){return u.a.ICON_MOVE},external:!0},o))}else g.f.doOnce((function(){return console.warn("ag-Grid: addRowDropZone - A container target needs to be provided")}),"add-drop-zone-empty-target")},t.prototype.getRowDropZone=function(e){var t=this,o=this.getContainer.bind(this),r=this.onDragEnter.bind(this),a=this.onDragLeave.bind(this),n=this.onDragging.bind(this),i=this.onDragStop.bind(this);return e?{getContainer:o,onDragEnter:e.onDragEnter?function(o){r(o),e.onDragEnter(t.draggingToRowDragEvent(h.a.EVENT_ROW_DRAG_ENTER,o))}:r,onDragLeave:e.onDragLeave?function(o){a(o),e.onDragLeave(t.draggingToRowDragEvent(h.a.EVENT_ROW_DRAG_LEAVE,o))}:a,onDragging:e.onDragging?function(o){n(o),e.onDragging(t.draggingToRowDragEvent(h.a.EVENT_ROW_DRAG_MOVE,o))}:n,onDragStop:e.onDragStop?function(o){i(o),e.onDragStop(t.draggingToRowDragEvent(h.a.EVENT_ROW_DRAG_END,o))}:i,fromGrid:!0}:{getContainer:o,onDragEnter:r,onDragLeave:a,onDragging:n,onDragStop:i,fromGrid:!0}},t.prototype.draggingToRowDragEvent=function(e,t){var o,r=this.mouseEventService.getNormalisedPosition(t).y,a=-1,n=null;switch(r>this.rowModel.getCurrentPageHeight()||(a=this.rowModel.getRowIndexAtPixel(r),n=this.rowModel.getRow(a)),t.vDirection){case u.d.Down:o="down";break;case u.d.Up:o="up";break;default:o=null}return{type:e,api:this.gridOptionsWrapper.getApi(),columnApi:this.gridOptionsWrapper.getColumnApi(),event:t.event,node:t.dragItem.rowNode,nodes:t.dragItem.rowNodes,overIndex:a,overNode:n,y:r,vDirection:o}},t.prototype.dispatchGridEvent=function(e,t){var o=this.draggingToRowDragEvent(e,t);this.eventService.dispatchEvent(o)},t.prototype.onDragLeave=function(e){this.dispatchGridEvent(h.a.EVENT_ROW_DRAG_LEAVE,e),this.stopDragging(e),this.clearRowHighlight(),this.isFromThisGrid(e)&&(this.isMultiRowDrag=!1)},t.prototype.onDragStop=function(e){this.dispatchGridEvent(h.a.EVENT_ROW_DRAG_END,e),this.stopDragging(e),!this.gridOptionsWrapper.isRowDragManaged()||!this.gridOptionsWrapper.isSuppressMoveWhenRowDragging()&&this.isFromThisGrid(e)||this.isDropZoneWithinThisGrid(e)||this.moveRowAndClearHighlight(e)},t.prototype.stopDragging=function(e){this.ensureIntervalCleared(),this.getRowNodes(e).forEach((function(e){e.setDragging(!1)}))},y([Object(n.a)("dragAndDropService")],t.prototype,"dragAndDropService",void 0),y([Object(n.a)("rowModel")],t.prototype,"rowModel",void 0),y([Object(n.a)("columnController")],t.prototype,"columnController",void 0),y([Object(n.a)("focusController")],t.prototype,"focusController",void 0),y([Object(n.a)("sortController")],t.prototype,"sortController",void 0),y([Object(n.a)("filterManager")],t.prototype,"filterManager",void 0),y([Object(n.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),y([Object(n.a)("selectionController")],t.prototype,"selectionController",void 0),y([Object(n.d)("rangeController")],t.prototype,"rangeController",void 0),y([Object(n.a)("mouseEventService")],t.prototype,"mouseEventService",void 0),y([n.e],t.prototype,"postConstruct",null),t}(m.a),C=o(7),k=o(5),A=o(11),E=o(10),O=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),R=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},S=function(e){function t(){var t=e.call(this,'
\n \n \n \n \n \n \n
')||this;return t.scrollLeft=-1,t.scrollTop=-1,t.resetLastHorizontalScrollElementDebounced=g.f.debounce(t.resetLastHorizontalScrollElement.bind(t),500),t}return O(t,e),t.prototype.getVScrollPosition=function(){return{top:this.eBodyViewport.scrollTop,bottom:this.eBodyViewport.scrollTop+this.eBodyViewport.offsetHeight}},t.prototype.getHScrollPosition=function(){return{left:this.eCenterViewport.scrollLeft,right:this.eCenterViewport.scrollLeft+this.eCenterViewport.offsetWidth}},t.prototype.onRowDataChanged=function(){this.showOrHideOverlay()},t.prototype.showOrHideOverlay=function(){var e=this.paginationProxy.isEmpty(),t=this.gridOptionsWrapper.isSuppressNoRowsOverlay();this[e&&!t?"showNoRowsOverlay":"hideOverlay"]()},t.prototype.onNewColumnsLoaded=function(){this.beans.columnController.isReady()&&!this.paginationProxy.isEmpty()&&this.hideOverlay()},t.prototype.init=function(){var e=this;this.scrollWidth=this.gridOptionsWrapper.getScrollbarWidth(),this.enableRtl=this.gridOptionsWrapper.isEnableRtl(),this.printLayout=this.gridOptionsWrapper.getDomLayout()===l.a.DOM_LAYOUT_PRINT,this.gridOptionsWrapper.addLayoutElement(this.getGui()),this.gridOptionsWrapper.addLayoutElement(this.eBodyViewport),this.suppressScrollOnFloatingRow(),this.setupRowAnimationCssClass(),this.buildRowContainerComponents(),this.addEventListeners(),this.addDragListeners(),this.addScrollListener(),this.gridOptionsWrapper.isRowModelDefault()&&!this.gridOptionsWrapper.getRowData()&&this.showLoadingOverlay(),this.setCellTextSelection(this.gridOptionsWrapper.isEnableCellTextSelect()),this.setPinnedContainerSize(),this.setHeaderAndFloatingHeights(),this.disableBrowserDragging(),this.addMouseListeners(),this.addKeyboardEvents(),this.addBodyViewportListener(),this.addStopEditingWhenGridLosesFocus(),this.mockContextMenuForIPad(),this.addRowDragListener(),this.$scope&&this.addAngularApplyCheck(),this.onDisplayedColumnsWidthChanged(),this.gridApi.registerGridComp(this),this.alignedGridsService.registerGridComp(this),this.headerRootComp.registerGridComp(this),this.navigationService.registerGridComp(this),this.headerNavigationService.registerGridComp(this),this.heightScaler.registerGridComp(this),this.autoHeightCalculator.registerGridComp(this),this.columnAnimationService.registerGridComp(this),this.autoWidthCalculator.registerGridComp(this),this.paginationAutoPageSizeService.registerGridComp(this),this.mouseEventService.registerGridComp(this),this.beans.registerGridComp(this),this.rowRenderer.registerGridComp(this),this.rangeController&&this.rangeController.registerGridComp(this),[this.eCenterViewport,this.eBodyViewport].forEach((function(t){var o=e.resizeObserverService.observeResize(t,e.onCenterViewportResized.bind(e));e.addDestroyFunc((function(){return o()}))})),[this.eTop,this.eBodyViewport,this.eBottom].forEach((function(t){e.addManagedListener(t,"focusin",(function(){g.f.addCssClass(t,"ag-has-focus")})),e.addManagedListener(t,"focusout",(function(e){t.contains(e.relatedTarget)||g.f.removeCssClass(t,"ag-has-focus")}))}))},t.prototype.onDomLayoutChanged=function(){var e=this.gridOptionsWrapper.getDomLayout()===l.a.DOM_LAYOUT_PRINT;this.printLayout!==e&&(this.printLayout=e,this.setWidthsOfContainers(),this.setPinnedContainerSize())},t.prototype.onCenterViewportResized=function(){g.f.isVisible(this.eCenterViewport)?(this.checkViewportAndScrolls(),this.beans.columnController.refreshFlexedColumns(this.getCenterWidth())):this.bodyHeight=0},t.prototype.setColumnMovingCss=function(e){this.addOrRemoveCssClass("ag-column-moving",e)},t.prototype.setCellTextSelection=function(e){void 0===e&&(e=!1),[this.eTop,this.eBodyViewport,this.eBottom].forEach((function(t){return g.f.addOrRemoveCssClass(t,"ag-selectable",e)}))},t.prototype.addRowDragListener=function(){this.rowDragFeature=this.createManagedBean(new x(this.eBodyViewport,this)),this.dragAndDropService.addDropTarget(this.rowDragFeature)},t.prototype.getRowDragFeature=function(){return this.rowDragFeature},t.prototype.addStopEditingWhenGridLosesFocus=function(){var e=this;if(this.gridOptionsWrapper.isStopEditingWhenGridLosesFocus()){var t=[this.eBodyViewport,this.eBottom,this.eTop],o=function(o){var r=o.relatedTarget;if(null!==g.f.getTabIndex(r)){var a=t.some((function(e){return e.contains(r)}));if(!a){var n=e.beans.popupService;a=n.getActivePopups().some((function(e){return e.contains(r)}))||n.isElementWithinCustomPopup(r)}a||e.rowRenderer.stopEditing()}else e.rowRenderer.stopEditing()};t.forEach((function(t){return e.addManagedListener(t,"focusout",o)}))}},t.prototype.addAngularApplyCheck=function(){var e=this,t=!1,o=function(){t||(t=!0,window.setTimeout((function(){t=!1,e.$scope.$apply()}),0))};this.addManagedListener(this.eventService,i.a.EVENT_DISPLAYED_COLUMNS_CHANGED,o),this.addManagedListener(this.eventService,i.a.EVENT_VIRTUAL_COLUMNS_CHANGED,o)},t.prototype.disableBrowserDragging=function(){this.addGuiEventListener("dragstart",(function(e){if(e.target instanceof HTMLImageElement)return e.preventDefault(),!1}))},t.prototype.addEventListeners=function(){this.addManagedListener(this.eventService,i.a.EVENT_DISPLAYED_COLUMNS_CHANGED,this.onDisplayedColumnsChanged.bind(this)),this.addManagedListener(this.eventService,i.a.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED,this.onDisplayedColumnsWidthChanged.bind(this)),this.addManagedListener(this.eventService,i.a.EVENT_PINNED_ROW_DATA_CHANGED,this.setHeaderAndFloatingHeights.bind(this)),this.addManagedListener(this.eventService,i.a.EVENT_ROW_DATA_CHANGED,this.onRowDataChanged.bind(this)),this.addManagedListener(this.eventService,i.a.EVENT_ROW_DATA_UPDATED,this.onRowDataChanged.bind(this)),this.addManagedListener(this.eventService,i.a.EVENT_NEW_COLUMNS_LOADED,this.onNewColumnsLoaded.bind(this)),this.addManagedListener(this.gridOptionsWrapper,a.a.PROP_HEADER_HEIGHT,this.setHeaderAndFloatingHeights.bind(this)),this.addManagedListener(this.gridOptionsWrapper,a.a.PROP_PIVOT_HEADER_HEIGHT,this.setHeaderAndFloatingHeights.bind(this)),this.addManagedListener(this.gridOptionsWrapper,a.a.PROP_GROUP_HEADER_HEIGHT,this.setHeaderAndFloatingHeights.bind(this)),this.addManagedListener(this.gridOptionsWrapper,a.a.PROP_PIVOT_GROUP_HEADER_HEIGHT,this.setHeaderAndFloatingHeights.bind(this)),this.addManagedListener(this.gridOptionsWrapper,a.a.PROP_FLOATING_FILTERS_HEIGHT,this.setHeaderAndFloatingHeights.bind(this)),this.addManagedListener(this.gridOptionsWrapper,a.a.PROP_DOM_LAYOUT,this.onDomLayoutChanged.bind(this))},t.prototype.addDragListeners=function(){var e=this;this.gridOptionsWrapper.isEnableRangeSelection()&&!g.f.missing(this.rangeController)&&[this.eLeftContainer,this.eRightContainer,this.eCenterContainer,this.eTop,this.eBottom].forEach((function(t){var o={eElement:t,onDragStart:e.rangeController.onDragStart.bind(e.rangeController),onDragStop:e.rangeController.onDragStop.bind(e.rangeController),onDragging:e.rangeController.onDragging.bind(e.rangeController)};e.dragService.addDragSource(o),e.addDestroyFunc((function(){return e.dragService.removeDragSource(o)}))}))},t.prototype.addMouseListeners=function(){var e=this;["click","mousedown","dblclick","contextmenu","mouseover","mouseout"].forEach((function(t){var o=e.processMouseEvent.bind(e,t);e.eAllCellContainers.forEach((function(r){return e.addManagedListener(r,t,o)}))}))},t.prototype.addKeyboardEvents=function(){var e=this;["keydown","keypress"].forEach((function(t){var o=e.processKeyboardEvent.bind(e,t);e.eAllCellContainers.forEach((function(r){e.addManagedListener(r,t,o)}))}))},t.prototype.addBodyViewportListener=function(){var e=this;this.addManagedListener(this.eBodyViewport,"contextmenu",(function(t){var o=g.f.getTarget(t);o!==e.eBodyViewport&&o!==e.eCenterViewport||(e.onContextMenu(t,null,null,null,null),e.preventDefaultOnContextMenu(t))}))},t.prototype.getBodyClientRect=function(){if(this.eBodyViewport)return this.eBodyViewport.getBoundingClientRect()},t.prototype.getRowForEvent=function(e){for(var t=g.f.getTarget(e);t;){var o=this.gridOptionsWrapper.getDomData(t,c.a.DOM_DATA_KEY_RENDERED_ROW);if(o)return o;t=t.parentElement}return null},t.prototype.processKeyboardEvent=function(e,t){var o=g.f.getCellCompForEvent(this.gridOptionsWrapper,t);if(o&&!t.defaultPrevented){var r=o.getRenderedRow().getRowNode(),a=o.getColumn(),n=o.isEditing();if(!g.f.isUserSuppressingKeyboardEvent(this.gridOptionsWrapper,t,r,a,n))switch(e){case"keydown":!n&&this.navigationService.handlePageScrollingKey(t)||o.onKeyDown(t),this.doGridOperations(t,o);break;case"keypress":o.onKeyPress(t)}if("keydown"===e){var l=o.createEvent(t,i.a.EVENT_CELL_KEY_DOWN);this.beans.eventService.dispatchEvent(l)}if("keypress"===e){var s=o.createEvent(t,i.a.EVENT_CELL_KEY_PRESS);this.beans.eventService.dispatchEvent(s)}}},t.prototype.doGridOperations=function(e,t){if((e.ctrlKey||e.metaKey)&&!t.isEditing()&&this.mouseEventService.isEventFromThisGrid(e))switch(e.which){case l.a.KEY_A:return this.onCtrlAndA(e);case l.a.KEY_C:return this.onCtrlAndC(e);case l.a.KEY_V:return this.onCtrlAndV();case l.a.KEY_D:return this.onCtrlAndD(e);case l.a.KEY_Z:return e.shiftKey?this.undoRedoService.redo():this.undoRedoService.undo();case l.a.KEY_Y:return this.undoRedoService.redo()}},t.prototype.scrollToTop=function(){this.eBodyViewport.scrollTop=0},t.prototype.processMouseEvent=function(e,t){if(this.mouseEventService.isEventFromThisGrid(t)&&!g.f.isStopPropagationForAgGrid(t)){var o=this.getRowForEvent(t),r=this.mouseEventService.getRenderedCellForEvent(t);"contextmenu"===e?(this.preventDefaultOnContextMenu(t),this.handleContextMenuMouseEvent(t,null,o,r)):(r&&r.onMouseEvent(e,t),o&&o.onMouseEvent(e,t))}},t.prototype.mockContextMenuForIPad=function(){var e=this;g.f.isIOSUserAgent()&&this.eAllCellContainers.forEach((function(t){var o=new d.a(t);e.addManagedListener(o,d.a.EVENT_LONG_TAP,(function(t){var o=e.getRowForEvent(t.touchEvent),r=e.mouseEventService.getRenderedCellForEvent(t.touchEvent);e.handleContextMenuMouseEvent(null,t.touchEvent,o,r)})),e.addDestroyFunc((function(){return o.destroy()}))}))},t.prototype.handleContextMenuMouseEvent=function(e,t,o,r){var a=o?o.getRowNode():null,n=r?r.getColumn():null,i=null;if(n){var l=e||t;r.dispatchCellContextMenuEvent(l),i=this.valueService.getValue(n,a)}this.onContextMenu(e,t,a,n,i)},t.prototype.onContextMenu=function(e,t,o,r,a){if((this.gridOptionsWrapper.isAllowContextMenuWithControlKey()||!e||!e.ctrlKey&&!e.metaKey)&&this.contextMenuFactory&&!this.gridOptionsWrapper.isSuppressContextMenu()){var n=e||t.touches[0];if(this.contextMenuFactory.showMenu(o,r,a,n))(e||t).preventDefault()}},t.prototype.preventDefaultOnContextMenu=function(e){var t=this.gridOptionsWrapper,o=e.which;(t.isPreventDefaultOnContextMenu()||t.isSuppressMiddleClickScrolls()&&2===o)&&e.preventDefault()},t.prototype.onCtrlAndA=function(e){var t=this.beans,o=this.pinnedRowModel,r=this.paginationProxy,a=this.rangeController,n=l.a.PINNED_BOTTOM,i=l.a.PINNED_TOP;if(a&&r.isRowsToRender()){var s=[o.isEmpty(i),o.isEmpty(n)],p=s[0]?null:i,c=void 0,d=void 0;s[1]?(c=null,d=this.paginationProxy.getRowCount()-1):(c=n,d=o.getPinnedBottomRowData().length-1);var u=t.columnController.getAllDisplayedColumns();if(g.f.missingOrEmpty(u))return;a.setCellRange({rowStartIndex:0,rowStartPinned:p,rowEndIndex:d,rowEndPinned:c,columnStart:u[0],columnEnd:g.f.last(u)})}e.preventDefault()},t.prototype.onCtrlAndC=function(e){this.clipboardService&&!this.gridOptionsWrapper.isEnableCellTextSelection()&&(this.clipboardService.copyToClipboard(),e.preventDefault())},t.prototype.onCtrlAndV=function(){A.a.isRegistered(E.a.ClipboardModule)&&!this.gridOptionsWrapper.isSuppressClipboardPaste()&&this.clipboardService.pasteFromClipboard()},t.prototype.onCtrlAndD=function(e){A.a.isRegistered(E.a.ClipboardModule)&&!this.gridOptionsWrapper.isSuppressClipboardPaste()&&this.clipboardService.copyRangeDown(),e.preventDefault()},t.prototype.ensureIndexVisible=function(e,t){if(!this.printLayout){var o=this.paginationProxy.getRowCount();if("number"!=typeof e||e<0||e>=o)console.warn("invalid row index for ensureIndexVisible: "+e);else{this.paginationProxy.goToPageWithIndex(e);var r,a=this.paginationProxy.getRow(e);do{var n=a.rowTop,i=a.rowHeight,l=this.paginationProxy.getPixelOffset(),g=a.rowTop-l,s=g+a.rowHeight,p=this.getVScrollPosition(),c=this.heightScaler.getOffset(),d=p.top+c,u=p.bottom+c,h=u-d,f=this.heightScaler.getScrollPositionForPixel(g),m=this.heightScaler.getScrollPositionForPixel(s-h),b=Math.min((f+m)/2,g),v=null;"top"===t?v=f:"bottom"===t?v=m:"middle"===t?v=b:d>g?v=f:ua,p=r0?this.columnController.sizeColumnsToFit(o,"sizeColumnsToFit"):void 0===e?window.setTimeout((function(){t.sizeColumnsToFit(100)}),0):100===e?window.setTimeout((function(){t.sizeColumnsToFit(500)}),100):500===e?window.setTimeout((function(){t.sizeColumnsToFit(-1)}),500):console.warn("ag-Grid: tried to call sizeColumnsToFit() but the grid is coming back with zero width, maybe the grid is not visible yet on the screen?")},t.prototype.getCenterContainer=function(){return this.eCenterContainer},t.prototype.getDropTargetBodyContainers=function(){return[this.eCenterViewport,this.eTopViewport,this.eBottomViewport]},t.prototype.getDropTargetLeftContainers=function(){return[this.eLeftContainer,this.eLeftBottom,this.eLeftTop]},t.prototype.getDropTargetRightContainers=function(){return[this.eRightContainer,this.eRightBottom,this.eRightTop]},t.prototype.buildRowContainerComponents=function(){var e=this;this.eAllCellContainers=[this.eLeftContainer,this.eRightContainer,this.eCenterContainer,this.eTop,this.eBottom,this.eFullWidthContainer],this.rowContainerComponents={body:new p({eContainer:this.eCenterContainer,eWrapper:this.eCenterColsClipper,eViewport:this.eBodyViewport}),fullWidth:new p({eContainer:this.eFullWidthContainer}),pinnedLeft:new p({eContainer:this.eLeftContainer}),pinnedRight:new p({eContainer:this.eRightContainer}),floatingTop:new p({eContainer:this.eTopContainer}),floatingTopPinnedLeft:new p({eContainer:this.eLeftTop}),floatingTopPinnedRight:new p({eContainer:this.eRightTop}),floatingTopFullWidth:new p({eContainer:this.eTopFullWidthContainer,hideWhenNoChildren:!0}),floatingBottom:new p({eContainer:this.eBottomContainer}),floatingBottomPinnedLeft:new p({eContainer:this.eLeftBottom}),floatingBottomPinnedRight:new p({eContainer:this.eRightBottom}),floatingBottomFullWidth:new p({eContainer:this.eBottomFullWidthContainer,hideWhenNoChildren:!0})},g.f.iterateObject(this.rowContainerComponents,(function(t,o){o&&e.getContext().createBean(o)}))},t.prototype.setupRowAnimationCssClass=function(){var e=this,t=function(){var t=e.gridOptionsWrapper.isAnimateRows()&&!e.heightScaler.isScaling();g.f.addOrRemoveCssClass(e.eBodyViewport,"ag-row-animation",t),g.f.addOrRemoveCssClass(e.eBodyViewport,"ag-row-no-animation",!t)};t(),this.addManagedListener(this.eventService,i.a.EVENT_HEIGHT_SCALE_CHANGED,t)},t.prototype.suppressScrollOnFloatingRow=function(){var e=this;this.addManagedListener(this.eTopViewport,"scroll",(function(){return e.eTopViewport.scrollLeft=0})),this.addManagedListener(this.eBottomViewport,"scroll",(function(){return e.eTopViewport.scrollLeft=0}))},t.prototype.getRowContainers=function(){return this.rowContainerComponents},t.prototype.getFloatingTopBottom=function(){return[this.eTop,this.eBottom]},t.prototype.onDisplayedColumnsChanged=function(){this.setPinnedContainerSize(),this.setHeaderAndFloatingHeights(),this.onHorizontalViewportChanged(),this.updateScrollVisibleService(),this.updateColumnCount()},t.prototype.onDisplayedColumnsWidthChanged=function(){this.setWidthsOfContainers(),this.onHorizontalViewportChanged(),this.updateScrollVisibleService(),this.enableRtl&&this.horizontallyScrollHeaderCenterAndFloatingCenter()},t.prototype.setWidthsOfContainers=function(){this.setCenterWidth(),this.setPinnedContainerSize()},t.prototype.setCenterWidth=function(){var e=this.headerRootComp,t=this.columnController,o=t.getBodyContainerWidth();this.printLayout&&(o+=t.getPinnedLeftContainerWidth()+t.getPinnedRightContainerWidth());e.setHeaderContainerWidth(o);var r=o+"px";this.eCenterContainer.style.width=r,this.eBottomContainer.style.width=r,this.eTopContainer.style.width=r,this.printLayout||(this.eBodyHorizontalScrollContainer.style.width=r)},t.prototype.setPinnedLeftWidth=function(){var e=this,t=this.pinningLeft,o=this.columnController.getPinnedLeftContainerWidth(),r=this.pinningLeft=!this.printLayout&&o>0,a=[this.eLeftContainer,this.eLeftTop,this.eLeftBottom];t!==r&&this.headerRootComp.setLeftVisible(r),a.forEach((function(t){return g.f.setDisplayed(t,e.pinningLeft)})),r&&a.forEach((function(e){return g.f.setFixedWidth(e,o)}))},t.prototype.setPinnedRightWidth=function(){var e=this.pinningRight,t=this.columnController.getPinnedRightContainerWidth(),o=this.pinningRight=!this.printLayout&&t>0,r=[this.eRightContainer,this.eRightTop,this.eRightBottom];e!==o&&this.headerRootComp.setRightVisible(o),r.forEach((function(e){return g.f.setDisplayed(e,o)})),o&&r.forEach((function(e){return g.f.setFixedWidth(e,t)}))},t.prototype.setPinnedContainerSize=function(){this.setPinnedLeftWidth(),this.setPinnedRightWidth(),this.setFakeHScrollSpacerWidths()},t.prototype.setFakeHScrollSpacerWidths=function(){var e=this.columnController.getPinnedRightContainerWidth();!this.enableRtl&&this.isVerticalScrollShowing()&&(e+=this.scrollWidth),g.f.setFixedWidth(this.eHorizontalRightSpacer,e),g.f.addOrRemoveCssClass(this.eHorizontalRightSpacer,"ag-scroller-corner",e<=this.scrollWidth);var t=this.columnController.getPinnedLeftContainerWidth();this.enableRtl&&this.isVerticalScrollShowing()&&(t+=this.scrollWidth),g.f.setFixedWidth(this.eHorizontalLeftSpacer,t),g.f.addOrRemoveCssClass(this.eHorizontalLeftSpacer,"ag-scroller-corner",t<=this.scrollWidth)},t.prototype.checkBodyHeight=function(){var e=this.eBodyViewport.clientHeight;if(this.bodyHeight!==e){this.bodyHeight=e;var t={type:i.a.EVENT_BODY_HEIGHT_CHANGED,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(t)}},t.prototype.setHeaderAndFloatingHeights=function(){var e,t,o,r=this,a=r.columnController,n=r.gridOptionsWrapper,i=r.pinnedRowModel,l=r.eTop,g=r.eBottom,s=0,p=a.getHeaderRowCount();a.isPivotMode()?(t=n.getPivotGroupHeaderHeight(),o=n.getPivotHeaderHeight()):(a.hasFloatingFilters()&&(p++,s=1),t=n.getGroupHeaderHeight(),o=n.getHeaderHeight());var c=p-(1+s);e=s*n.getFloatingFiltersHeight(),e+=c*t,e+=o,this.headerRootComp.setHeight(e);var d=i.getPinnedTopTotalHeight();d&&(d+=1);var u=i.getPinnedBottomTotalHeight();u&&(u+=1);var h=d+"px",f=u+"px";l.style.minHeight=h,l.style.height=h,l.style.display=d?"inherit":"none",g.style.minHeight=f,g.style.height=f,g.style.display=u?"inherit":"none",this.checkBodyHeight()},t.prototype.getBodyHeight=function(){return this.bodyHeight},t.prototype.setHorizontalScrollPosition=function(e){this.eCenterViewport.scrollLeft=e,this.doHorizontalScroll(e)},t.prototype.setVerticalScrollPosition=function(e){this.eBodyViewport.scrollTop=e},t.prototype.scrollHorizontally=function(e){var t=this.eCenterViewport.scrollLeft;return this.setHorizontalScrollPosition(t+e),this.eCenterViewport.scrollLeft-t},t.prototype.scrollVertically=function(e){var t=this.eBodyViewport.scrollTop;return this.setVerticalScrollPosition(t+e),this.eBodyViewport.scrollTop-t},t.prototype.addScrollListener=function(){this.addManagedListener(this.eCenterViewport,"scroll",this.onCenterViewportScroll.bind(this)),this.addManagedListener(this.eBodyHorizontalScrollViewport,"scroll",this.onFakeHorizontalScroll.bind(this)),this.addManagedListener(this.eBodyViewport,"scroll",this.onVerticalScroll.bind(this))},t.prototype.onVerticalScroll=function(){var e=this.eBodyViewport.scrollTop;this.animationFrameService.setScrollTop(e),this.scrollTop=e,this.redrawRowsAfterScroll()},t.prototype.isControllingScroll=function(e){return this.lastHorizontalScrollElement?e===this.lastHorizontalScrollElement:(this.lastHorizontalScrollElement=e,!0)},t.prototype.onFakeHorizontalScroll=function(){this.isControllingScroll(this.eBodyHorizontalScrollViewport)&&this.onBodyHorizontalScroll(this.eBodyHorizontalScrollViewport)},t.prototype.onCenterViewportScroll=function(){this.isControllingScroll(this.eCenterViewport)&&this.onBodyHorizontalScroll(this.eCenterViewport)},t.prototype.onBodyHorizontalScroll=function(e){var t=this.eCenterViewport,o=t.scrollWidth,r=t.clientWidth,a=Math.floor(g.f.getScrollLeft(e,this.enableRtl)),n=o-r;a<0?a=0:a>n&&(a=n),this.doHorizontalScroll(a),this.resetLastHorizontalScrollElementDebounced()},t.prototype.resetLastHorizontalScrollElement=function(){this.lastHorizontalScrollElement=null},t.prototype.doHorizontalScroll=function(e){this.scrollLeft=e;var t={type:i.a.EVENT_BODY_SCROLL,api:this.gridApi,columnApi:this.columnApi,direction:"horizontal",left:this.scrollLeft,top:this.scrollTop};this.eventService.dispatchEvent(t),this.horizontallyScrollHeaderCenterAndFloatingCenter(e),this.onHorizontalViewportChanged()},t.prototype.redrawRowsAfterScroll=function(){var e={type:i.a.EVENT_BODY_SCROLL,direction:"vertical",api:this.gridApi,columnApi:this.columnApi,left:this.scrollLeft,top:this.scrollTop};this.eventService.dispatchEvent(e)},t.prototype.onHorizontalViewportChanged=function(){var e=this.eCenterViewport.clientWidth,t=this.getCenterViewportScrollLeft();this.columnController.setVirtualViewportPosition(e,t)},t.prototype.getCenterViewportScrollLeft=function(){return g.f.getScrollLeft(this.eCenterViewport,this.enableRtl)},t.prototype.setCenterViewportScrollLeft=function(e){g.f.setScrollLeft(this.eCenterViewport,e,this.enableRtl)},t.prototype.horizontallyScrollHeaderCenterAndFloatingCenter=function(e){void 0===e&&(e=this.getCenterViewportScrollLeft());var t=this.enableRtl?e:-e,o=this.eCenterViewport,r=o.clientWidth,a=o.scrollWidth;if(!(Math.abs(t)+r>a||this.enableRtl&&t<0||!this.enableRtl&&t>0)){this.headerRootComp.setHorizontalScroll(t),this.eBottomContainer.style.transform="translateX("+t+"px)",this.eTopContainer.style.transform="translateX("+t+"px)";var n=this.lastHorizontalScrollElement===this.eCenterViewport?this.eBodyHorizontalScrollViewport:this.eCenterViewport;g.f.setScrollLeft(n,e,this.enableRtl)}},t.prototype.addScrollEventListener=function(e){this.eBodyViewport.addEventListener("scroll",e)},t.prototype.removeScrollEventListener=function(e){this.eBodyViewport.removeEventListener("scroll",e)},R([Object(n.a)("alignedGridsService")],t.prototype,"alignedGridsService",void 0),R([Object(n.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),R([Object(n.a)("rowRenderer")],t.prototype,"rowRenderer",void 0),R([Object(n.a)("pinnedRowModel")],t.prototype,"pinnedRowModel",void 0),R([Object(n.a)("animationFrameService")],t.prototype,"animationFrameService",void 0),R([Object(n.a)("navigationService")],t.prototype,"navigationService",void 0),R([Object(n.a)("autoHeightCalculator")],t.prototype,"autoHeightCalculator",void 0),R([Object(n.a)("columnAnimationService")],t.prototype,"columnAnimationService",void 0),R([Object(n.a)("autoWidthCalculator")],t.prototype,"autoWidthCalculator",void 0),R([Object(n.a)("paginationAutoPageSizeService")],t.prototype,"paginationAutoPageSizeService",void 0),R([Object(n.a)("beans")],t.prototype,"beans",void 0),R([Object(n.a)("paginationProxy")],t.prototype,"paginationProxy",void 0),R([Object(n.a)("columnApi")],t.prototype,"columnApi",void 0),R([Object(n.a)("gridApi")],t.prototype,"gridApi",void 0),R([Object(n.a)("dragService")],t.prototype,"dragService",void 0),R([Object(n.a)("mouseEventService")],t.prototype,"mouseEventService",void 0),R([Object(n.a)("$scope")],t.prototype,"$scope",void 0),R([Object(n.a)("scrollVisibleService")],t.prototype,"scrollVisibleService",void 0),R([Object(n.a)("valueService")],t.prototype,"valueService",void 0),R([Object(n.a)("dragAndDropService")],t.prototype,"dragAndDropService",void 0),R([Object(n.a)("maxDivHeightScaler")],t.prototype,"heightScaler",void 0),R([Object(n.a)("resizeObserverService")],t.prototype,"resizeObserverService",void 0),R([Object(n.a)("undoRedoService")],t.prototype,"undoRedoService",void 0),R([Object(n.a)("columnController")],t.prototype,"columnController",void 0),R([Object(n.a)("headerNavigationService")],t.prototype,"headerNavigationService",void 0),R([Object(n.d)("rangeController")],t.prototype,"rangeController",void 0),R([Object(n.d)("contextMenuFactory")],t.prototype,"contextMenuFactory",void 0),R([Object(n.d)("clipboardService")],t.prototype,"clipboardService",void 0),R([Object(k.d)("eBodyViewport")],t.prototype,"eBodyViewport",void 0),R([Object(k.d)("eCenterContainer")],t.prototype,"eCenterContainer",void 0),R([Object(k.d)("eCenterViewport")],t.prototype,"eCenterViewport",void 0),R([Object(k.d)("eLeftContainer")],t.prototype,"eLeftContainer",void 0),R([Object(k.d)("eRightContainer")],t.prototype,"eRightContainer",void 0),R([Object(k.d)("eCenterColsClipper")],t.prototype,"eCenterColsClipper",void 0),R([Object(k.d)("eHorizontalScrollBody")],t.prototype,"eHorizontalScrollBody",void 0),R([Object(k.d)("eHorizontalLeftSpacer")],t.prototype,"eHorizontalLeftSpacer",void 0),R([Object(k.d)("eHorizontalRightSpacer")],t.prototype,"eHorizontalRightSpacer",void 0),R([Object(k.d)("eBodyHorizontalScrollViewport")],t.prototype,"eBodyHorizontalScrollViewport",void 0),R([Object(k.d)("eBodyHorizontalScrollContainer")],t.prototype,"eBodyHorizontalScrollContainer",void 0),R([Object(k.d)("eFullWidthContainer")],t.prototype,"eFullWidthContainer",void 0),R([Object(k.d)("eTop")],t.prototype,"eTop",void 0),R([Object(k.d)("eLeftTop")],t.prototype,"eLeftTop",void 0),R([Object(k.d)("eRightTop")],t.prototype,"eRightTop",void 0),R([Object(k.d)("eTopContainer")],t.prototype,"eTopContainer",void 0),R([Object(k.d)("eTopViewport")],t.prototype,"eTopViewport",void 0),R([Object(k.d)("eTopFullWidthContainer")],t.prototype,"eTopFullWidthContainer",void 0),R([Object(k.d)("eBottom")],t.prototype,"eBottom",void 0),R([Object(k.d)("eLeftBottom")],t.prototype,"eLeftBottom",void 0),R([Object(k.d)("eRightBottom")],t.prototype,"eRightBottom",void 0),R([Object(k.d)("eBottomContainer")],t.prototype,"eBottomContainer",void 0),R([Object(k.d)("eBottomViewport")],t.prototype,"eBottomViewport",void 0),R([Object(k.d)("eBottomFullWidthContainer")],t.prototype,"eBottomFullWidthContainer",void 0),R([Object(k.d)("headerRoot")],t.prototype,"headerRootComp",void 0),R([Object(k.d)("overlayWrapper")],t.prototype,"overlayWrapper",void 0),R([n.e],t.prototype,"init",null),t}(C.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return f}));var r,a=o(7),n=o(0),i=o(5),l=o(1),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(o){var r=e.call(this,t.TEMPLATE)||this;return r.H=1,r.S=1,r.B=1,r.A=1,r.isSpectrumDragging=!1,r.isSpectrumHueDragging=!1,r.isSpectrumAlphaDragging=!1,r.colorChanged=!1,r.picker=o.picker,r}return g(t,e),t.prototype.postConstruct=function(){var e=this.getGui();this.initRecentColors(),this.addManagedListener(this.spectrumVal,"mousedown",this.onSpectrumDraggerDown.bind(this)),this.addManagedListener(e,"mousemove",this.onSpectrumDraggerMove.bind(this)),this.addManagedListener(this.spectrumHue,"mousedown",this.onSpectrumHueDown.bind(this)),this.addManagedListener(e,"mousemove",this.onSpectrumHueMove.bind(this)),this.addManagedListener(this.spectrumAlpha,"mousedown",this.onSpectrumAlphaDown.bind(this)),this.addManagedListener(e,"mousemove",this.onSpectrumAlphaMove.bind(this)),this.addManagedListener(document,"mouseup",this.onMouseUp.bind(this)),this.addManagedListener(this.recentColors,"click",this.onRecentColorClick.bind(this))},t.prototype.refreshSpectrumRect=function(){return this.spectrumValRect=this.spectrumVal.getBoundingClientRect()},t.prototype.refreshHueRect=function(){return this.spectrumHueRect=this.spectrumHue.getBoundingClientRect()},t.prototype.refreshAlphaRect=function(){return this.spectrumAlphaRect=this.spectrumAlpha.getBoundingClientRect()},t.prototype.onSpectrumDraggerDown=function(e){this.refreshSpectrumRect(),this.isSpectrumDragging=!0,this.moveDragger(e)},t.prototype.onSpectrumDraggerMove=function(e){this.isSpectrumDragging&&this.moveDragger(e)},t.prototype.onSpectrumHueDown=function(e){this.refreshHueRect(),this.isSpectrumHueDragging=!0,this.moveHueSlider(e)},t.prototype.onSpectrumHueMove=function(e){this.isSpectrumHueDragging&&this.moveHueSlider(e)},t.prototype.onSpectrumAlphaDown=function(e){this.refreshAlphaRect(),this.isSpectrumAlphaDragging=!0,this.moveAlphaSlider(e)},t.prototype.onSpectrumAlphaMove=function(e){this.isSpectrumAlphaDragging&&this.moveAlphaSlider(e)},t.prototype.onMouseUp=function(){this.isSpectrumDragging=!1,this.isSpectrumHueDragging=!1,this.isSpectrumAlphaDragging=!1},t.prototype.moveDragger=function(e){var t=this.spectrumValRect;if(t){var o=e.clientX-t.left,r=e.clientY-t.top;o=Math.max(o,0),o=Math.min(o,t.width),r=Math.max(r,0),r=Math.min(r,t.height),this.setSpectrumValue(o/t.width,1-r/t.height)}},t.prototype.moveHueSlider=function(e){var t=this.spectrumHueRect;if(t){var o=this.spectrumHueSlider,r=o.getBoundingClientRect(),a=e.clientX-t.left;a=Math.max(a,0),a=Math.min(a,t.width),this.H=1-a/t.width,o.style.left=a+r.width/2+"px",this.update()}},t.prototype.moveAlphaSlider=function(e){var t=this.spectrumAlphaRect;if(t){var o=this.spectrumAlphaSlider,r=o.getBoundingClientRect(),a=e.clientX-t.left;a=Math.max(a,0),a=Math.min(a,t.width),this.A=a/t.width,o.style.left=a+r.width/2+"px",this.update()}},t.prototype.update=function(){var e=n.a.fromHSB(360*this.H,this.S,this.B,this.A),t=n.a.fromHSB(360*this.H,1,1),o=e.toRgbaString(),r=this.picker;n.a.fromString(r.getValue()).toRgbaString()!==o&&(this.colorChanged=!0),r.setValue(o),this.spectrumColor.style.backgroundColor=t.toRgbaString(),this.spectrumDragger.style.backgroundColor=o},t.prototype.setSpectrumValue=function(e,t){var o=this.spectrumValRect||this.refreshSpectrumRect();if(o){var r=this.spectrumDragger,a=r.getBoundingClientRect();e=Math.max(0,e),e=Math.min(1,e),t=Math.max(0,t),t=Math.min(1,t),this.S=e,this.B=t,r.style.left=e*o.width-a.width/2+"px",r.style.top=(1-t)*o.height-a.height/2+"px",this.update()}},t.prototype.initRecentColors=function(){var e=t.recentColors.map((function(e,t){return'
'}));this.recentColors.innerHTML=e.join("")},t.prototype.setValue=function(e){var t=n.a.fromString(e),o=t.toHSB(),r=o[0],a=o[1],i=o[2];this.H=(isNaN(r)?0:r)/360,this.A=t.a;var l=this.spectrumHueRect||this.refreshHueRect(),g=this.spectrumAlphaRect||this.refreshAlphaRect();this.spectrumHueSlider.style.left=(this.H-1)*-l.width+"px",this.spectrumAlphaSlider.style.left=this.A*g.width+"px",this.setSpectrumValue(a,i)},t.prototype.onRecentColorClick=function(e){var o=e.target;if(n.f.exists(o.id)){var r=parseInt(o.id,10);this.setValue(t.recentColors[r]),this.destroy()}},t.prototype.addRecentColor=function(){var e=n.a.fromHSB(360*this.H,this.S,this.B,this.A).toRgbaString(),o=t.recentColors;this.colorChanged&&o[0]!==e&&(o=o.filter((function(t){return t!=e})),(o=[e].concat(o)).length>t.maxRecentColors&&(o=o.slice(0,t.maxRecentColors)),t.recentColors=o)},t.prototype.destroy=function(){this.addRecentColor(),e.prototype.destroy.call(this)},t.maxRecentColors=8,t.recentColors=[],t.TEMPLATE='
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
',s([Object(i.d)("spectrumColor")],t.prototype,"spectrumColor",void 0),s([Object(i.d)("spectrumVal")],t.prototype,"spectrumVal",void 0),s([Object(i.d)("spectrumDragger")],t.prototype,"spectrumDragger",void 0),s([Object(i.d)("spectrumHue")],t.prototype,"spectrumHue",void 0),s([Object(i.d)("spectrumHueSlider")],t.prototype,"spectrumHueSlider",void 0),s([Object(i.d)("spectrumAlpha")],t.prototype,"spectrumAlpha",void 0),s([Object(i.d)("spectrumAlphaSlider")],t.prototype,"spectrumAlphaSlider",void 0),s([Object(i.d)("recentColors")],t.prototype,"recentColors",void 0),s([l.e],t.prototype,"postConstruct",null),t}(a.a),c=o(62),d=o(138),u=o(22),h=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),f=function(e){function t(t){var o=e.call(this)||this;return o.displayTag="div",o.className="ag-color-picker",o.pickerIcon="colorPicker",o.setTemplate(o.TEMPLATE.replace(/%displayField%/g,o.displayTag)),t&&t.color&&(o.value=t.color),o}return h(t,e),t.prototype.postConstruct=function(){e.prototype.postConstruct.call(this),this.value&&this.setValue(this.value)},t.prototype.showPicker=function(){var e=this,t=this.getGui().getBoundingClientRect(),o=new c.a({closable:!1,modal:!0,hideTitleBar:!0,minWidth:190,width:190,height:250,x:t.right-190,y:t.top-250});this.createBean(o),n.f.addCssClass(o.getGui(),"ag-color-dialog");var r=new p({picker:this});return this.createBean(r),r.addDestroyFunc((function(){o.isAlive()&&e.destroyBean(o)})),o.setParentComponent(this),o.setBodyComponent(r),r.setValue(this.getValue()),o.addDestroyFunc((function(){e.isDestroyingPicker?e.isDestroyingPicker=!1:(e.isDestroyingPicker=!0,r.isAlive()&&e.destroyBean(r)),e.isAlive()&&e.getFocusableElement().focus()})),o},t.prototype.setValue=function(e){return this.value===e||(this.value=e,this.eDisplayField.style.backgroundColor=e,this.dispatchEvent({type:u.a.EVENT_CHANGED})),this},t.prototype.getValue=function(){return this.value},t}(d.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return f}));var r,a=o(22),n=o(138),i=o(7),l=o(1),g=o(2),s=o(0),p=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),c=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},d=function(e){function t(o){void 0===o&&(o="default");var r=e.call(this,t.getTemplate(o))||this;return r.cssIdentifier=o,r.options=[],r.itemEls=[],r}return p(t,e),t.prototype.init=function(){this.addManagedListener(this.getGui(),"keydown",this.handleKeyDown.bind(this))},t.getTemplate=function(e){return'
'},t.prototype.handleKeyDown=function(e){var t=e.keyCode;switch(t){case g.a.KEY_ENTER:if(this.highlightedEl){var o=this.itemEls.indexOf(this.highlightedEl);this.setValueByIndex(o)}else this.setValue(this.getValue());break;case g.a.KEY_DOWN:case g.a.KEY_UP:var r=t===g.a.KEY_DOWN,a=void 0;if(e.preventDefault(),this.highlightedEl){var n=this.itemEls.indexOf(this.highlightedEl)+(r?1:-1);n=Math.min(Math.max(n,0),this.itemEls.length-1),a=this.itemEls[n]}else a=this.itemEls[r?0:this.itemEls.length-1];this.highlightItem(a)}},t.prototype.addOptions=function(e){var t=this;return e.forEach((function(e){return t.addOption(e)})),this},t.prototype.addOption=function(e){var t=e.value,o=e.text,r=s.f.escape(void 0===o?t:o);return this.options.push({value:t,text:r}),this.renderOption(r),this},t.prototype.renderOption=function(e){var t=this,o=document.createElement("div"),r=document.createElement("span");s.f.addCssClass(o,"ag-list-item"),s.f.addCssClass(o,"ag-"+this.cssIdentifier+"-list-item"),o.tabIndex=-1,r.innerHTML=e,this.itemEls.push(o),this.addManagedListener(o,"mouseover",(function(e){return t.highlightItem(o)})),this.addManagedListener(o,"mouseleave",(function(){return t.clearHighlighted()})),this.addManagedListener(o,"click",(function(){var e=t.itemEls.indexOf(o);t.setValueByIndex(e)})),o.appendChild(r),this.getGui().appendChild(o)},t.prototype.setValue=function(e,t){if(this.value===e)return this.fireItemSelected(),this;if(null==e)return this.reset(),this;var o=s.f.findIndex(this.options,(function(t){return t.value===e}));if(-1!==o){var r=this.options[o];this.value=r.value,this.displayValue=null!=r.text?r.text:r.value,this.highlightItem(this.itemEls[o]),t||this.fireChangeEvent()}return this},t.prototype.setValueByIndex=function(e){return this.setValue(this.options[e].value)},t.prototype.getValue=function(){return this.value},t.prototype.getDisplayValue=function(){return this.displayValue},t.prototype.refreshHighlighted=function(){var e=this;this.clearHighlighted();var t=s.f.findIndex(this.options,(function(t){return t.value===e.value}));-1!==t&&this.highlightItem(this.itemEls[t])},t.prototype.reset=function(){this.value=null,this.displayValue=null,this.clearHighlighted(),this.fireChangeEvent()},t.prototype.highlightItem=function(e){e.offsetParent&&(s.f.radioCssClass(e,"ag-active-item"),this.highlightedEl=e,this.highlightedEl.focus())},t.prototype.clearHighlighted=function(){this.highlightedEl&&this.highlightedEl.offsetParent&&(s.f.removeCssClass(this.highlightedEl,"ag-active-item"),this.highlightedEl=null)},t.prototype.fireChangeEvent=function(){this.dispatchEvent({type:a.a.EVENT_CHANGED}),this.fireItemSelected()},t.prototype.fireItemSelected=function(){this.dispatchEvent({type:t.EVENT_ITEM_SELECTED})},t.EVENT_ITEM_SELECTED="selectedItem",c([l.e],t.prototype,"init",null),t}(i.a),u=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),h=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},f=function(e){function t(t){var o=e.call(this)||this;return o.displayTag="div",o.className="ag-select",o.pickerIcon="smallDown",o.setTemplate(o.TEMPLATE.replace(/%displayField%/g,o.displayTag)),o}return u(t,e),t.prototype.init=function(){var e=this;this.listComponent=new d("select"),this.getContext().createBean(this.listComponent),this.listComponent.setParentComponent(this),this.eWrapper.tabIndex=0,this.listComponent.addManagedListener(this.listComponent,d.EVENT_ITEM_SELECTED,(function(){e.hideList&&e.hideList()})),this.listComponent.addManagedListener(this.listComponent,a.a.EVENT_CHANGED,(function(){e.setValue(e.listComponent.getValue(),!1,!0),e.hideList&&e.hideList()}))},t.prototype.showPicker=function(){var e=this,t=this.listComponent.getGui(),o=this.addManagedListener(document.body,"wheel",(function(o){!t.contains(o.target)&&e.hideList&&e.hideList()})),r=this.addManagedListener(t,"focusout",(function(o){!t.contains(o.relatedTarget)&&e.hideList&&e.hideList()}));return this.hideList=this.popupService.addPopup(!0,t,!0,(function(){e.hideList=null,r(),o(),e.isAlive()&&e.getFocusableElement().focus()})),s.f.setElementWidth(t,s.f.getAbsoluteWidth(this.eWrapper)),t.style.maxHeight=s.f.getInnerHeight(this.popupService.getPopupParent())+"px",t.style.position="absolute",this.popupService.positionPopupUnderComponent({type:"ag-list",eventSource:this.eWrapper,ePopup:t,keepWithinBounds:!0}),this.listComponent.refreshHighlighted(),this.listComponent},t.prototype.addOptions=function(e){var t=this;return e.forEach((function(e){return t.addOption(e)})),this},t.prototype.addOption=function(e){return this.listComponent.addOption(e),this},t.prototype.setValue=function(t,o,r){if(this.value!==t&&(r||this.listComponent.setValue(t,!0),this.listComponent.getValue()!==this.getValue()))return this.eDisplayField.innerHTML=this.listComponent.getDisplayValue(),e.prototype.setValue.call(this,t,o)},t.prototype.destroy=function(){this.hideList&&this.hideList(),this.getContext().destroyBean(this.listComponent),e.prototype.destroy.call(this)},h([Object(l.a)("popupService")],t.prototype,"popupService",void 0),h([l.e],t.prototype,"init",null),t}(n.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return h}));var r,a=o(76),n=o(19),i=o(12),l=o(1),g={numericColumn:{headerClass:"ag-right-aligned-header",cellClass:"ag-right-aligned-cell"},rightAligned:{headerClass:"ag-right-aligned-header",cellClass:"ag-right-aligned-cell"}},s=o(0),p=o(6),c=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),d=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},u=function(e,t){return function(o,r){t(o,r,e)}},h=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return c(t,e),t.prototype.setBeans=function(e){this.logger=e.create("ColumnFactory")},t.prototype.createColumnTree=function(e,t,o){var r=new a.a;if(o){var i=o.map((function(e){return e.getId()}));r.addExistingKeys(i)}var l=o?o.slice():null,g=this.recursivelyCreateColumns(e,0,t,l,r,null),s=this.findMaxDept(g,0);this.logger.log("Number of levels for grouped columns is "+s);var p=this.balanceColumnTree(g,0,s,r);return this.columnUtils.depthFirstOriginalTreeSearch(null,p,(function(e,t){e instanceof n.a&&e.setupExpandable(),e.setOriginalParent(t)})),{columnTree:p,treeDept:s}},t.prototype.createForAutoGroups=function(e,t){var o=this,r=[];return e.forEach((function(e){var a=o.createAutoGroupTreeItem(t,e);r.push(a)})),r},t.prototype.createAutoGroupTreeItem=function(e,t){for(var o=t,r=this.findDepth(e)-1;r>=0;r--){var a=new n.a(null,"FAKE_PATH_"+t.getId()+"}_"+r,!0,r);this.context.createBean(a),a.setChildren([o]),o.setOriginalParent(a),o=a}return o},t.prototype.findDepth=function(e){for(var t=0,o=e;o&&o[0]&&o[0]instanceof n.a;)t++,o=o[0].getChildren();return t},t.prototype.balanceColumnTree=function(e,t,o,r){for(var a=[],i=0;i=t;d--){var u=r.getUniqueKey(null,null),h=this.createMergedColGroupDef(null),f=new n.a(h,u,!0,t);this.context.createBean(f),c&&c.setChildren([f]),c=f,p||(p=c)}if(p){if(a.push(p),e.some((function(e){return e instanceof n.a}))){c.setChildren([l]);continue}c.setChildren(e);break}a.push(l)}}return a},t.prototype.findMaxDept=function(e,t){for(var o=t,r=0;r-1)return r;var a=document.createElement("span");return a.appendChild(r),a}function i(e,t,o,n){var i=null,l=o&&o.getColDef().icons;if(l&&(i=l[e]),t&&!i){var g=t.getIcons();g&&(i=g[e])}if(!i){var s=document.createElement("span"),p=a[e];return p||(n?p=e:(console.warn("ag-Grid: Did not find icon "+e),p="")),s.setAttribute("class","ag-icon ag-icon-"+p),s.setAttribute("unselectable","on"),s}var c=void 0;if("function"==typeof i)c=i();else{if("string"!=typeof i)throw new Error("icon from grid options needs to be a string or a function");c=i}return"string"==typeof c?Object(r.loadTemplate)(c):Object(r.isNodeOrElement)(c)?c:void console.warn("ag-Grid: iconRenderer should return back a string or a dom object")}},function(e,t,o){"use strict";o.r(t),o.d(t,"isKeyPressed",(function(){return i})),o.d(t,"isCharacterKey",(function(){return l})),o.d(t,"isEventFromPrintableCharacter",(function(){return g})),o.d(t,"isUserSuppressingKeyboardEvent",(function(){return s}));var r=o(2),a=o(18),n=o(25);function i(e,t){return(e.which||e.keyCode)===t}function l(e){var t=e.which;return"number"==typeof t&&t?!e.ctrlKey&&!e.metaKey&&!e.altKey&&8!==e.which&&16!==e.which:void 0===t}function g(e){var t=String.fromCharCode(e.charCode);if(i(e,r.a.KEY_NEW_LINE))return!1;if(e.altKey||e.ctrlKey)return!1;if(Object(a.exists)(e.key)){var o=1===e.key.length,l=function(e){return(Object(n.isBrowserEdge)()||Object(n.isBrowserIE)())&&"Del"===e.key&&46===e.charCode}(e);return o||l}return"qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM1234567890!\"£$%^&*()_+-=[];'#,./\\|<>?:@~{}".indexOf(t)>=0}function s(e,t,o,r,a){var n=e.getSuppressKeyboardEventFunc(),i=r.getColDef().suppressKeyboardEvent;if(!n&&!i)return!1;var l={event:t,editing:a,column:r,api:e.getApi(),node:o,data:o.data,colDef:r.getColDef(),context:e.getContext(),columnApi:e.getColumnApi()};if(i&&i(l))return!0;return!!n&&n(l)}},function(e,t,o){"use strict";function r(e){var t=new Set;return e.forEach((function(e){return t.add(e)})),t}o.r(t),o.d(t,"convertToSet",(function(){return r}))},function(e,t,o){"use strict";o.d(t,"a",(function(){return r}));var r=function(){function e(){}return e.parse=function(t){if(!t)return null;if(!0===t)return{toolPanels:[e.DEFAULT_COLUMN_COMP,e.DEFAULT_FILTER_COMP],defaultToolPanel:"columns"};if("string"==typeof t)return e.parse([t]);if(Array.isArray(t)){var o=[];return t.forEach((function(t){var r=e.DEFAULT_BY_KEY[t];r?o.push(r):console.warn("ag-grid: the key "+t+" is not a valid key for specifying a tool panel, valid keys are: "+Object.keys(e.DEFAULT_BY_KEY).join(","))})),0===o.length?null:{toolPanels:o,defaultToolPanel:o[0].id}}return{toolPanels:e.parseComponents(t.toolPanels),defaultToolPanel:t.defaultToolPanel,hiddenByDefault:t.hiddenByDefault,position:t.position}},e.parseComponents=function(t){var o=[];return t.forEach((function(t){var r=null;if("string"==typeof t){var a=e.DEFAULT_BY_KEY[t];if(!a)return void console.warn("ag-grid: the key "+t+" is not a valid key for specifying a tool panel, valid keys are: "+Object.keys(e.DEFAULT_BY_KEY).join(","));r=a}else r=t;o.push(r)})),o},e.DEFAULT_COLUMN_COMP={id:"columns",labelDefault:"Columns",labelKey:"columns",iconKey:"columns",toolPanel:"agColumnsToolPanel"},e.DEFAULT_FILTER_COMP={id:"filters",labelDefault:"Filters",labelKey:"filters",iconKey:"filter",toolPanel:"agFiltersToolPanel"},e.DEFAULT_BY_KEY={columns:e.DEFAULT_COLUMN_COMP,filters:e.DEFAULT_FILTER_COMP},e}()},function(e,t,o){"use strict";o.d(t,"a",(function(){return a}));var r=o(17),a=function(){function e(){this.customFilterOptions={}}return e.prototype.init=function(e,t){this.filterOptions=e.filterOptions||t,this.mapCustomOptions(),this.selectDefaultItem(e)},e.prototype.getFilterOptions=function(){return this.filterOptions},e.prototype.mapCustomOptions=function(){var e=this;this.filterOptions&&this.filterOptions.forEach((function(t){if("string"!=typeof t){Object(r.every)(["displayKey","displayName","test"],(function(e){return!!t[e]||(console.warn("ag-Grid: ignoring FilterOptionDef as it doesn't contain a '"+e+"'"),!1)}))&&(e.customFilterOptions[t.displayKey]=t)}}))},e.prototype.selectDefaultItem=function(e){if(e.defaultOption)this.defaultOption=e.defaultOption;else if(this.filterOptions.length>=1){var t=this.filterOptions[0];"string"==typeof t?this.defaultOption=t:t.displayKey?this.defaultOption=t.displayKey:console.warn("ag-Grid: invalid FilterOptionDef supplied as it doesn't contain a 'displayKey'")}else console.warn("ag-Grid: no filter options for filter")},e.prototype.getDefaultOption=function(){return this.defaultOption},e.prototype.getCustomOption=function(e){return this.customFilterOptions[e]},e}()},function(e,t,o){"use strict";o.d(t,"a",(function(){return c}));var r,a=o(22),n=o(1),i=o(2),l=o(5),g=o(0),s=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),p=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},c=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.TEMPLATE='',t.isDestroyingPicker=!1,t.skipClick=!1,t}return s(t,e),t.prototype.postConstruct=function(){var t=this;e.prototype.postConstruct.call(this);var o=function(){t.skipClick?t.skipClick=!1:t.isDisabled()||(t.pickerComponent=t.showPicker())},r=this.getGui();this.addManagedListener(r,"mousedown",(function(e){!t.skipClick&&t.pickerComponent&&t.pickerComponent.isAlive()&&g.f.isVisible(t.pickerComponent.getGui())&&r.contains(e.target)&&(t.skipClick=!0)})),this.addManagedListener(r,"keydown",(function(e){switch(e.keyCode){case i.a.KEY_UP:case i.a.KEY_DOWN:case i.a.KEY_ENTER:case i.a.KEY_SPACE:o();case i.a.KEY_ESCAPE:e.preventDefault()}})),this.addManagedListener(this.eWrapper,"click",o),this.addManagedListener(this.eLabel,"click",o),this.pickerIcon&&this.eIcon.appendChild(g.f.createIconNoSpan(this.pickerIcon,this.gridOptionsWrapper,null))},t.prototype.setInputWidth=function(e){return g.f.setElementWidth(this.eWrapper,e),this},t.prototype.getFocusableElement=function(){return this.eWrapper},p([Object(n.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),p([Object(l.d)("eLabel")],t.prototype,"eLabel",void 0),p([Object(l.d)("eWrapper")],t.prototype,"eWrapper",void 0),p([Object(l.d)("eDisplayField")],t.prototype,"eDisplayField",void 0),p([Object(l.d)("eIcon")],t.prototype,"eIcon",void 0),t}(a.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return A}));var r,a=o(1),n=o(12),i=o(13),l=o(2),g=o(60),s=o(4),p=o(69),c=o(41),d=o(36),u=o(6),h=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),f=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},m=function(e){function t(t,o){var r=e.call(this)||this;r.cbSelectAllVisible=!1,r.processingEventFromCheckbox=!1,r.cbSelectAll=t,r.column=o;var a=o.getColDef();return r.filteredOnly=!!a&&!!a.headerCheckboxSelectionFilteredOnly,r}return h(t,e),t.prototype.postConstruct=function(){this.showOrHideSelectAll(),this.addManagedListener(this.eventService,s.a.EVENT_DISPLAYED_COLUMNS_CHANGED,this.showOrHideSelectAll.bind(this)),this.addManagedListener(this.eventService,s.a.EVENT_SELECTION_CHANGED,this.onSelectionChanged.bind(this)),this.addManagedListener(this.eventService,s.a.EVENT_MODEL_UPDATED,this.onModelChanged.bind(this)),this.addManagedListener(this.cbSelectAll,d.a.EVENT_CHANGED,this.onCbSelectAll.bind(this))},t.prototype.showOrHideSelectAll=function(){this.cbSelectAllVisible=this.isCheckboxSelection(),this.cbSelectAll.setDisplayed(this.cbSelectAllVisible),this.cbSelectAllVisible&&(this.checkRightRowModelType(),this.updateStateOfCheckbox())},t.prototype.onModelChanged=function(){this.cbSelectAllVisible&&this.updateStateOfCheckbox()},t.prototype.onSelectionChanged=function(){this.cbSelectAllVisible&&this.updateStateOfCheckbox()},t.prototype.getNextCheckboxState=function(e){return(0!==e.selected||0!==e.notSelected)&&(e.selected>0&&e.notSelected>0?null:e.selected>0)},t.prototype.updateStateOfCheckbox=function(){if(!this.processingEventFromCheckbox){this.processingEventFromCheckbox=!0;var e=this.getSelectionCount(),t=this.getNextCheckboxState(e);this.cbSelectAll.setValue(t),this.processingEventFromCheckbox=!1}},t.prototype.getSelectionCount=function(){var e=this,t=0,o=0,r=function(r){e.gridOptionsWrapper.isGroupSelectsChildren()&&r.group||(r.isSelected()?t++:r.selectable&&o++)};return this.filteredOnly?this.gridApi.forEachNodeAfterFilter(r):this.gridApi.forEachNode(r),{notSelected:o,selected:t}},t.prototype.checkRightRowModelType=function(){var e=this.rowModel.getType();e===l.a.ROW_MODEL_TYPE_CLIENT_SIDE||console.warn("ag-Grid: selectAllCheckbox is only available if using normal row model, you are using "+e)},t.prototype.onCbSelectAll=function(){this.processingEventFromCheckbox||this.cbSelectAllVisible&&(this.cbSelectAll.getValue()?this.selectionController.selectAllRowNodes(this.filteredOnly):this.selectionController.deselectAllRowNodes(this.filteredOnly))},t.prototype.isCheckboxSelection=function(){var e=this.column.getColDef().headerCheckboxSelection;"function"==typeof e&&(e=e({column:this.column,colDef:this.column.getColDef(),columnApi:this.columnApi,api:this.gridApi}));return!!e&&(this.gridOptionsWrapper.isRowModelServerSide()?(console.warn("headerCheckboxSelection is not supported for Server Side Row Model"),!1):this.gridOptionsWrapper.isRowModelInfinite()?(console.warn("headerCheckboxSelection is not supported for Infinite Row Model"),!1):!this.gridOptionsWrapper.isRowModelViewport()||(console.warn("headerCheckboxSelection is not supported for Viewport Row Model"),!1))},f([Object(a.a)("gridApi")],t.prototype,"gridApi",void 0),f([Object(a.a)("columnApi")],t.prototype,"columnApi",void 0),f([Object(a.a)("rowModel")],t.prototype,"rowModel",void 0),f([Object(a.a)("selectionController")],t.prototype,"selectionController",void 0),f([Object(a.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),f([a.e],t.prototype,"postConstruct",null),t}(u.a),b=o(5),v=o(24),y=o(40),w=o(70),x=o(0),C=function(){var e=function(t,o){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(t,o)};return function(t,o){function r(){this.constructor=t}e(t,o),t.prototype=null===o?Object.create(o):(r.prototype=o.prototype,new r)}}(),k=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},A=function(e){function t(o,r,a){var n=e.call(this,t.TEMPLATE)||this;return n.column=o,n.dragSourceDropTarget=r,n.pinned=a,n}return C(t,e),t.prototype.postConstruct=function(){e.prototype.postConstruct.call(this);var t=this.getComponentHolder(),o=this.columnController.getDisplayNameForColumn(this.column,"header",!0),r=t.sortable,a=this.menuEnabled=this.menuFactory.isMenuEnabled(this.column)&&!t.suppressMenu;this.appendHeaderComp(o,r,a),this.setupWidth(),this.setupMovingCss(),this.setupTooltip(),this.setupResize(),this.setupMenuClass(),this.setupSortableClass(r),this.addColumnHoverListener(),this.addDisplayMenuListeners(),this.cbSelectAll.setInputAriaLabel("Toggle Selection of All Rows"),this.createManagedBean(new p.a([this.column],this.getGui())),this.addManagedListener(this.column,n.a.EVENT_FILTER_ACTIVE_CHANGED,this.onFilterChanged.bind(this)),this.onFilterChanged(),this.createManagedBean(new m(this.cbSelectAll,this.column));var i=new c.a(this.column,this.getGui(),this.beans);this.createManagedBean(i),this.addAttributes(),g.a.addHeaderClassesFromColDef(t,this.getGui(),this.gridOptionsWrapper,this.column,null)},t.prototype.addDisplayMenuListeners=function(){var e=this.onMouseOverOut.bind(this);this.addGuiEventListener("mouseenter",e),this.addGuiEventListener("mouseleave",e)},t.prototype.onMouseOverOut=function(e){this.headerComp&&this.headerComp.setActiveParent&&this.headerComp.setActiveParent("mouseenter"===e.type)},t.prototype.onFocusIn=function(e){if(!this.getGui().contains(e.relatedTarget)){var t=this.getParentComponent();this.focusController.setFocusedHeader(t.getRowIndex(),this.getColumn())}this.headerComp&&this.headerComp.setActiveParent&&this.headerComp.setActiveParent(!0)},t.prototype.onFocusOut=function(e){this.headerComp&&this.headerComp.setActiveParent&&!this.getGui().contains(e.relatedTarget)&&this.headerComp.setActiveParent(!1)},t.prototype.handleKeyDown=function(e){var t=this.headerComp;if(t){if(e.keyCode===l.a.KEY_SPACE){var o=this.cbSelectAll;o.isDisplayed()&&!o.getGui().contains(document.activeElement)&&o.setValue(!o.getValue())}if(e.keyCode===l.a.KEY_ENTER)if(e.ctrlKey||e.metaKey)this.menuEnabled&&t.showMenu&&(e.preventDefault(),t.showMenu());else if(this.sortable){var r=e.shiftKey;this.sortController.progressSort(this.column,r,"uiColumnSorted")}}},t.prototype.getComponentHolder=function(){return this.column.getColDef()},t.prototype.addColumnHoverListener=function(){this.addManagedListener(this.eventService,s.a.EVENT_COLUMN_HOVER_CHANGED,this.onColumnHover.bind(this)),this.onColumnHover()},t.prototype.onColumnHover=function(){var e=this.columnHoverService.isHovered(this.column);x.f.addOrRemoveCssClass(this.getGui(),"ag-column-hover",e)},t.prototype.setupSortableClass=function(e){if(e){var t=this.getGui();x.f.addCssClass(t,"ag-header-cell-sortable"),this.sortable=!0}},t.prototype.onFilterChanged=function(){var e=this.column.isFilterActive();x.f.addOrRemoveCssClass(this.getGui(),"ag-header-cell-filtered",e)},t.prototype.appendHeaderComp=function(e,t,o){var r=this,a={column:this.column,displayName:e,enableSorting:t,enableMenu:o,showColumnMenu:function(e){r.gridApi.showColumnMenuAfterButtonClick(r.column,e)},progressSort:function(e){r.sortController.progressSort(r.column,!!e,"uiColumnSorted")},setSort:function(e,t){r.sortController.setSortForColumn(r.column,e,!!t,"uiColumnSorted")},api:this.gridApi,columnApi:this.columnApi,context:this.gridOptionsWrapper.getContext()},n=this.afterHeaderCompCreated.bind(this,e);this.userComponentFactory.newHeaderComponent(a).then(n)},t.prototype.afterHeaderCompCreated=function(e,t){var o=this;this.getGui().appendChild(t.getGui()),this.addDestroyFunc((function(){o.getContext().destroyBean(t)})),this.setupMove(t.getGui(),e),this.headerComp=t},t.prototype.onColumnMovingChanged=function(){this.column.isMoving()?x.f.addCssClass(this.getGui(),"ag-header-cell-moving"):x.f.removeCssClass(this.getGui(),"ag-header-cell-moving")},t.prototype.setupMove=function(e,t){var o=this,r=this.column.getColDef(),a=this.gridOptionsWrapper.isSuppressMovableColumns()||this.getComponentHolder().suppressMovable||r.lockPosition;if((!a||r.enableRowGroup||r.enablePivot)&&e){var n={type:i.b.HeaderCell,eElement:e,defaultIconName:i.a.ICON_HIDE,getDragItem:function(){return o.createDragItem()},dragItemName:t,dragSourceDropTarget:this.dragSourceDropTarget,onDragStarted:function(){return!a&&o.column.setMoving(!0,"uiColumnMoved")},onDragStopped:function(){return!a&&o.column.setMoving(!1,"uiColumnMoved")}};this.dragAndDropService.addDragSource(n,!0),this.addDestroyFunc((function(){return o.dragAndDropService.removeDragSource(n)}))}},t.prototype.createDragItem=function(){var e={};return e[this.column.getId()]=this.column.isVisible(),{columns:[this.column],visibleState:e}},t.prototype.setupResize=function(){var e=this,t=this.getComponentHolder();if(this.eResize)if(this.column.isResizable()){var o=this.horizontalResizeService.addResizeBar({eResizeBar:this.eResize,onResizeStart:this.onResizeStart.bind(this),onResizing:this.onResizing.bind(this,!1),onResizeEnd:this.onResizing.bind(this,!0)});this.addDestroyFunc(o);var r=!this.gridOptionsWrapper.isSuppressAutoSize()&&!t.suppressAutoSize,a=this.gridOptionsWrapper.isSkipHeaderOnAutoSize();if(r){this.addManagedListener(this.eResize,"dblclick",(function(){e.columnController.autoSizeColumn(e.column,a,"uiColumnResized")}));var n=new v.a(this.eResize);this.addManagedListener(n,v.a.EVENT_DOUBLE_TAP,(function(){e.columnController.autoSizeColumn(e.column,a,"uiColumnResized")})),this.addDestroyFunc(n.destroy.bind(n))}}else x.f.removeFromParent(this.eResize)},t.prototype.onResizing=function(e,t){var o=this.normaliseResizeAmount(t),r=[{key:this.column,newWidth:this.resizeStartWidth+o}];this.columnController.setColumnWidths(r,this.resizeWithShiftKey,e,"uiColumnDragged"),e&&x.f.removeCssClass(this.getGui(),"ag-column-resizing")},t.prototype.onResizeStart=function(e){this.resizeStartWidth=this.column.getActualWidth(),this.resizeWithShiftKey=e,x.f.addCssClass(this.getGui(),"ag-column-resizing")},t.prototype.getTooltipText=function(){return this.getComponentHolder().headerTooltip},t.prototype.setupTooltip=function(){var e=this.getTooltipText();null!=e&&(this.gridOptionsWrapper.isEnableBrowserTooltips()?this.getGui().setAttribute("title",e):this.createManagedBean(new y.a(this,"header")))},t.prototype.setupMovingCss=function(){this.addManagedListener(this.column,n.a.EVENT_MOVING_CHANGED,this.onColumnMovingChanged.bind(this)),this.onColumnMovingChanged()},t.prototype.addAttributes=function(){this.getGui().setAttribute("col-id",this.column.getColId())},t.prototype.setupWidth=function(){this.addManagedListener(this.column,n.a.EVENT_WIDTH_CHANGED,this.onColumnWidthChanged.bind(this)),this.onColumnWidthChanged()},t.prototype.setupMenuClass=function(){this.addManagedListener(this.column,n.a.EVENT_MENU_VISIBLE_CHANGED,this.onMenuVisible.bind(this)),this.onColumnWidthChanged()},t.prototype.onMenuVisible=function(){this.addOrRemoveCssClass("ag-column-menu-visible",this.column.isMenuVisible())},t.prototype.onColumnWidthChanged=function(){this.getGui().style.width=this.column.getActualWidth()+"px"},t.prototype.normaliseResizeAmount=function(e){var t=e;return this.gridOptionsWrapper.isEnableRtl()?this.pinned!==l.a.PINNED_LEFT&&(t*=-1):this.pinned===l.a.PINNED_RIGHT&&(t*=-1),t},t.TEMPLATE='',k([Object(a.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),k([Object(a.a)("dragAndDropService")],t.prototype,"dragAndDropService",void 0),k([Object(a.a)("columnController")],t.prototype,"columnController",void 0),k([Object(a.a)("horizontalResizeService")],t.prototype,"horizontalResizeService",void 0),k([Object(a.a)("menuFactory")],t.prototype,"menuFactory",void 0),k([Object(a.a)("gridApi")],t.prototype,"gridApi",void 0),k([Object(a.a)("columnApi")],t.prototype,"columnApi",void 0),k([Object(a.a)("sortController")],t.prototype,"sortController",void 0),k([Object(a.a)("userComponentFactory")],t.prototype,"userComponentFactory",void 0),k([Object(a.a)("columnHoverService")],t.prototype,"columnHoverService",void 0),k([Object(a.a)("beans")],t.prototype,"beans",void 0),k([Object(b.d)("eResize")],t.prototype,"eResize",void 0),k([Object(b.d)("cbSelectAll")],t.prototype,"cbSelectAll",void 0),t}(w.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return a}));var r=o(65);function a(e){e.module("agGrid",[]).directive("agGrid",(function(){return{restrict:"A",controller:["$element","$scope","$compile","$attrs",n],scope:!0}}))}function n(e,t,o,a){var n,i,l=a.agGrid;if(i=l+".quickFilterText",n=t.$eval(l)){var g=e[0],s={$scope:t,$compile:o,quickFilterOnScope:i},p=new r.a(g,n,s);t.$on("$destroy",(function(){p.destroy(),p=null}))}else console.warn("WARNING - grid options for ag-Grid not found. Please ensure the attribute ag-grid points to a valid object on the scope")}},function(e,t,o){"use strict";o.d(t,"a",(function(){return i}));var r=o(37),a=o(65),n=!1;function i(){if(console.warn("ag-grid: initialiseAgGridWithWebComponents is deprecated. Please use the ag-grid-webcomponent dependency instead. "),!n){n=!0,"undefined"!=typeof document&&document.registerElement||console.error("ag-Grid: unable to find document.registerElement() function, unable to initialise ag-Grid as a Web Component");var e=Object.create(HTMLElement.prototype);r.a.ALL_PROPERTIES.forEach((function(t){Object.defineProperty(e,t,{set:function(e){this.__agGridSetProperty(t,e)},get:function(){return this.__agGridGetProperty(t)},enumerable:!0,configurable:!0})}));var t=e;t.__agGridSetProperty=function(e,t){this.__attributes||(this.__attributes={}),this.__attributes[e]=t;var o={};o[e]={currentValue:t},this.onChange(o)},t.onChange=function(e){this._initialised&&r.a.processOnChange(e,this._gridOptions,this.api,this.columnApi)},t.__agGridGetProperty=function(e){return this.__attributes||(this.__attributes={}),this.__attributes[e]},t.setGridOptions=function(e){var t=this.globalEventListener.bind(this);this._gridOptions=r.a.copyAttributesToGridOptions(e,this);var o={globalEventListener:t};this._agGrid=new a.a(this,this._gridOptions,o),this.api=e.api,this.columnApi=e.columnApi,this._initialised=!0},t.createdCallback=function(){for(var e=0;e=0&&(this[o]=a)},t.attachedCallback=function(e){},t.detachedCallback=function(e){},t.attributeChangedCallback=function(e){var t=this.attributes[e];this.setPropertyFromAttribute(t)},t.globalEventListener=function(e,t){var o=e.toLowerCase(),r=new Event(o);r.agGridDetails=t,this.dispatchEvent(r);var a="on"+o;"function"==typeof this[a]&&this[a](r)},document.registerElement("ag-grid",{prototype:e})}}},function(e,t,o){"use strict";o.d(t,"a",(function(){return p}));var r,a=o(0),n=o(5),i=o(2),l=o(29),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(o){var r=e.call(this,t.getTemplate(o.cssClass))||this;return r.items=[],r.params=o,o.items&&o.items.forEach((function(e){return r.addItem(e)})),r}return g(t,e),t.getTemplate=function(e){return'
\n
\n
\n
'},t.prototype.handleKeyDown=function(e){switch(e.keyCode){case i.a.KEY_RIGHT:case i.a.KEY_LEFT:if(!this.eHeader.contains(document.activeElement))return;var t=this.items.indexOf(this.activeItem),o=e.keyCode===i.a.KEY_RIGHT?Math.min(t+1,this.items.length-1):Math.max(t-1,0);if(t===o)return;e.preventDefault();var r=this.items[o];this.showItemWrapper(r),r.eHeaderButton.focus();break;case i.a.KEY_UP:case i.a.KEY_DOWN:e.stopPropagation()}},t.prototype.onTabKeyDown=function(e){var t=this.focusController,o=this.eHeader,r=this.eBody,a=this.activeItem,n=document.activeElement,i=o.contains(n);if(e.preventDefault(),i)e.shiftKey?t.focusLastFocusableElement(r):t.focusFirstFocusableElement(r);else if(t.isFocusUnderManagedComponent(r))a.eHeaderButton.focus();else{var l=t.findNextFocusableElement(r,!1,e.shiftKey);l?l.focus():a.eHeaderButton.focus()}},t.prototype.setAfterAttachedParams=function(e){this.afterAttachedParams=e},t.prototype.getMinDimensions=function(){var e=this.getGui().cloneNode(!0),t=e.querySelector('[ref="eBody"]');e.style.position="fixed",this.getGui().appendChild(e);var o=0,r=0;return this.items.forEach((function(n){a.f.clearElement(t);var i=n.tabbedItem.bodyPromise.resolveNow(null,(function(e){return e.cloneNode(!0)}));null!=i&&(t.appendChild(i),o0&&this.showItemWrapper(this.items[0])},t.prototype.addItem=function(e){var t=document.createElement("span");t.tabIndex=-1,t.appendChild(e.title),a.f.addCssClass(t,"ag-tab"),this.eHeader.appendChild(t),t.setAttribute("aria-label",e.titleLabel);var o={tabbedItem:e,eHeaderButton:t};this.items.push(o),t.addEventListener("click",this.showItemWrapper.bind(this,o))},t.prototype.showItem=function(e){var t=a.f.find(this.items,(function(t){return t.tabbedItem===e}));t&&this.showItemWrapper(t)},t.prototype.showItemWrapper=function(e){var t=this;this.params.onItemClicked&&this.params.onItemClicked({item:e.tabbedItem}),this.activeItem!==e?(a.f.clearElement(this.eBody),e.tabbedItem.bodyPromise.then((function(e){t.eBody.appendChild(e);var o=!t.focusController.isKeyboardFocus();t.focusController.focusFirstFocusableElement(t.eBody,o)})),this.activeItem&&a.f.removeCssClass(this.activeItem.eHeaderButton,"ag-tab-selected"),a.f.addCssClass(e.eHeaderButton,"ag-tab-selected"),this.activeItem=e,e.tabbedItem.afterAttachedCallback&&e.tabbedItem.afterAttachedCallback(this.afterAttachedParams)):a.f.callIfPresent(this.params.onActiveItemClicked)},s([Object(n.d)("eHeader")],t.prototype,"eHeader",void 0),s([Object(n.d)("eBody")],t.prototype,"eBody",void 0),t}(l.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return a}));var r=o(0);function a(e){return new r.c((function(t){var o=new XMLHttpRequest;o.open("GET",e.url),o.send(),o.onreadystatechange=function(){4===o.readyState&&200===o.status&&t(JSON.parse(o.responseText))}}))}},function(e,t,o){"use strict";o.d(t,"a",(function(){return c}));var r,a=o(49),n=o(1),i=o(6),l=o(0),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e,t){return function(o,r){t(o,r,e)}},c=function(e){function t(t,o){var r=e.call(this)||this;return r.activeBlockLoadsCount=0,r.blocks=[],r.active=!0,r.maxConcurrentRequests=t,o&&o>0&&(r.checkBlockToLoadDebounce=l.f.debounce(r.performCheckBlocksToLoad.bind(r),o)),r}return g(t,e),t.prototype.setBeans=function(e){this.logger=e.create("RowNodeBlockLoader")},t.prototype.addBlock=function(e){this.blocks.push(e)},t.prototype.removeBlock=function(e){l.f.removeFromArray(this.blocks,e)},t.prototype.destroy=function(){e.prototype.destroy.call(this),this.active=!1},t.prototype.loadComplete=function(){this.activeBlockLoadsCount--},t.prototype.checkBlockToLoad=function(){this.checkBlockToLoadDebounce?this.checkBlockToLoadDebounce():this.performCheckBlocksToLoad()},t.prototype.performCheckBlocksToLoad=function(){if(this.active)if(this.printCacheStatus(),this.activeBlockLoadsCount>=this.maxConcurrentRequests)this.logger.log("checkBlockToLoad: max loads exceeded");else{var e=null;this.blocks.forEach((function(t){t.getState()===a.a.STATE_DIRTY&&(e=t)})),e?(e.load(),this.activeBlockLoadsCount++,this.logger.log("checkBlockToLoad: loading page "+e.getBlockNumber()),this.printCacheStatus()):this.logger.log("checkBlockToLoad: no pages to load")}},t.prototype.getBlockState=function(){var e={};return this.blocks.forEach((function(t){var o=t.getNodeIdPrefix(),r={blockNumber:t.getBlockNumber(),startRow:t.getStartRow(),endRow:t.getEndRow(),pageStatus:t.getState()};l.f.exists(o)?e[o+t.getBlockNumber()]=r:e[t.getBlockNumber()]=r})),e},t.prototype.printCacheStatus=function(){this.logger.isLogging()&&this.logger.log("printCacheStatus: activePageLoadsCount = "+this.activeBlockLoadsCount+", blocks = "+JSON.stringify(this.getBlockState()))},t.prototype.isLoading=function(){return this.activeBlockLoadsCount>0},s([p(0,Object(n.h)("loggerFactory"))],t.prototype,"setBeans",null),t}(i.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return p}));var r,a=o(6),n=o(49),i=o(0),l=o(1),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),s=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},p=function(e){function t(t){var o=e.call(this)||this;return o.maxRowFound=!1,o.blocks={},o.blockCount=0,o.virtualRowCount=t.initialRowCount,o.cacheParams=t,o}return g(t,e),t.prototype.destroyAllBlocks=function(){var e=this;this.forEachBlockInOrder((function(t){return e.destroyBlock(t)}))},t.prototype.init=function(){var e=this;this.active=!0,this.addDestroyFunc((function(){return e.active=!1}))},t.prototype.isActive=function(){return this.active},t.prototype.getVirtualRowCount=function(){return this.virtualRowCount},t.prototype.hack_setVirtualRowCount=function(e){this.virtualRowCount=e},t.prototype.isMaxRowFound=function(){return this.maxRowFound},t.prototype.onPageLoaded=function(e){this.cacheParams.rowNodeBlockLoader.loadComplete(),this.checkBlockToLoad(),this.isActive()&&(this.logger.log("onPageLoaded: page = "+e.page.getBlockNumber()+", lastRow = "+e.lastRow),e.success&&this.checkVirtualRowCount(e.page,e.lastRow))},t.prototype.purgeBlocksIfNeeded=function(e){var o=this,r=[];this.forEachBlockInOrder((function(t){t!==e&&r.push(t)})),r.sort((function(e,t){return t.getLastAccessed()-e.getLastAccessed()}));var a=this.cacheParams.maxBlocksInCache>0,i=a?this.cacheParams.maxBlocksInCache-1:null,l=t.MAX_EMPTY_BLOCKS_TO_KEEP-1;r.forEach((function(e,t){if(e.getState()===n.a.STATE_DIRTY&&t>=l||!!a&&t>=i){if(e.isAnyNodeOpen(o.virtualRowCount))return;if(o.isBlockCurrentlyDisplayed(e))return;o.removeBlockFromCache(e)}}))},t.prototype.isBlockCurrentlyDisplayed=function(e){var t=this.rowRenderer.getFirstVirtualRenderedRow(),o=this.rowRenderer.getLastVirtualRenderedRow(),r=e.getDisplayIndexStart(),a=e.getDisplayIndexEnd()-1;return null!=r&&null!=a&&(!(r>o)&&!(a=0)this.virtualRowCount=t,this.maxRowFound=!0,this.onCacheUpdated();else if(!this.maxRowFound){var o=(e.getBlockNumber()+1)*this.cacheParams.blockSize+this.cacheParams.overflowSize;this.virtualRowCount=e.virtualRowCount&&t.push(o)})),t.length>0&&t.forEach((function(t){return e.destroyBlock(t)}))},t.prototype.purgeCache=function(){var e=this;this.forEachBlockInOrder((function(t){return e.removeBlockFromCache(t)})),this.maxRowFound=!1,0===this.virtualRowCount&&(this.virtualRowCount=this.cacheParams.initialRowCount),this.onCacheUpdated()},t.prototype.getRowNodesInRange=function(e,t){var o=this,r=[],a=-1,n=!1,l=new i.b;i.f.missing(e)&&(n=!0);var g=!1;return this.forEachBlockInOrder((function(i,s){g||(n&&a+1!==s?g=!0:(a=s,i.forEachNodeShallow((function(o){var a=o===e||o===t;(n||a)&&r.push(o),a&&(n=!n)}),l,o.virtualRowCount)))})),g||n?[]:r},t.EVENT_CACHE_UPDATED="cacheUpdated",t.MAX_EMPTY_BLOCKS_TO_KEEP=2,s([Object(l.a)("rowRenderer")],t.prototype,"rowRenderer",void 0),s([l.g],t.prototype,"destroyAllBlocks",null),s([l.e],t.prototype,"init",null),t}(a.a)},function(e,t,o){"use strict";o.d(t,"a",(function(){return c}));var r,a=o(1),n=o(5),i=o(29),l=o(2),g=o(0),s=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var o in t)t.hasOwnProperty(o)&&(e[o]=t[o])})(e,t)},function(e,t){function o(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(o.prototype=t.prototype,new o)}),p=function(e,t,o,r){var a,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,r);else for(var l=e.length-1;l>=0;l--)(a=e[l])&&(i=(n<3?a(i):n>3?a(t,o,i):a(t,o))||i);return n>3&&i&&Object.defineProperty(t,o,i),i},c=function(e){function t(o){void 0===o&&(o="default");var r=e.call(this,t.getTemplate(o))||this;return r.cssIdentifier=o,r.renderedRows=new Map,r.rowHeight=20,r}return s(t,e),t.prototype.postConstruct=function(){this.addScrollListener(),this.rowHeight=this.getItemHeight(),e.prototype.postConstruct.call(this)},t.prototype.isFocusableContainer=function(){return!0},t.prototype.focusInnerElement=function(e){var t=this.model.getRowCount();this.focusRow(e?t-1:0)},t.prototype.onFocusIn=function(t){e.prototype.onFocusIn.call(this,t);var o=t.target;g.f.containsClass(o,"ag-virtual-list-item")&&(this.lastFocusedRow=parseInt(o.getAttribute("aria-rowindex"),10)-1)},t.prototype.onFocusOut=function(t){e.prototype.onFocusOut.call(this,t),this.getFocusableElement().contains(t.relatedTarget)||(this.lastFocusedRow=null)},t.prototype.handleKeyDown=function(e){switch(e.keyCode){case l.a.KEY_UP:case l.a.KEY_DOWN:case l.a.KEY_TAB:this.navigate(e.keyCode===l.a.KEY_UP||e.keyCode===l.a.KEY_TAB&&e.shiftKey)&&e.preventDefault()}},t.prototype.navigate=function(e){if(!g.f.exists(this.lastFocusedRow))return!1;var t=this.lastFocusedRow+(e?-1:1);return!(t<0||t>=this.model.getRowCount())&&(this.focusRow(t),!0)},t.prototype.getLastFocusedRow=function(){return this.lastFocusedRow},t.prototype.focusRow=function(e){var t=this;this.ensureIndexVisible(e),window.setTimeout((function(){var o=t.renderedRows.get(e);o&&o.eDiv.focus()}),10)},t.prototype.getComponentAt=function(e){var t=this.renderedRows.get(e);return t&&t.rowComponent},t.getTemplate=function(e){return'\n
\n
\n
'},t.prototype.getItemHeight=function(){return this.gridOptionsWrapper.getListItemHeight()},t.prototype.ensureIndexVisible=function(e){var t=this.model.getRowCount();if("number"!=typeof e||e<0||e>=t)console.warn("invalid row index for ensureIndexVisible: "+e);else{var o=e*this.rowHeight,r=o+this.rowHeight,a=this.getGui(),n=a.scrollTop,i=a.offsetHeight,l=n+io)a.scrollTop=o;else if(l){var g=r-i;a.scrollTop=g}}},t.prototype.setComponentCreator=function(e){this.componentCreator=e},t.prototype.getRowHeight=function(){return this.rowHeight},t.prototype.getScrollTop=function(){return this.getGui().scrollTop},t.prototype.setRowHeight=function(e){this.rowHeight=e,this.refresh()},t.prototype.refresh=function(){var e=this;if(null!=this.model){var t=this.model.getRowCount();this.eContainer.style.height=t*this.rowHeight+"px",this.eContainer.setAttribute("aria-rowcount",t.toString()),setTimeout((function(){e.clearVirtualRows(),e.drawVirtualRows()}),0)}},t.prototype.clearVirtualRows=function(){var e=this;this.renderedRows.forEach((function(t,o){return e.removeRow(o)}))},t.prototype.drawVirtualRows=function(){var e=this.getGui(),t=e.scrollTop,o=t+e.offsetHeight,r=Math.floor(t/this.rowHeight),a=Math.floor(o/this.rowHeight);this.ensureRowsRendered(r,a)},t.prototype.ensureRowsRendered=function(e,t){var o=this;this.renderedRows.forEach((function(r,a){(at)&&a!==o.lastFocusedRow&&o.removeRow(a)}));for(var r=e;r<=t;r++)if(!this.renderedRows.has(r)&&r*{flex:none}.ag-column-drop-empty .ag-column-drop-vertical-list{overflow:hidden}.ag-column-drop-vertical-empty-message{display:block}.ag-column-drop.ag-column-drop-horizontal{white-space:nowrap;overflow:hidden}.ag-column-drop-cell-button{cursor:pointer}.ag-filter-toolpanel{flex:1 1 0px;min-width:0}.ag-filter-toolpanel-header{position:relative}.ag-filter-toolpanel-header,.ag-filter-toolpanel-header>*,.ag-filter-toolpanel-search,.ag-filter-toolpanel-search>*{display:flex;align-items:center}.ag-filter-apply-panel{display:flex;justify-content:flex-end;overflow:hidden}.ag-row-animation .ag-row{transition:top .4s,height .4s,background-color .1s,opacity .2s,-webkit-transform .4s;transition:transform .4s,top .4s,height .4s,background-color .1s,opacity .2s;transition:transform .4s,top .4s,height .4s,background-color .1s,opacity .2s,-webkit-transform .4s}.ag-row-no-animation .ag-row{transition:background-color .1s}.ag-row{white-space:nowrap;width:100%}.ag-row-loading{display:flex;align-items:center}.ag-row-position-absolute{position:absolute}.ag-row-position-relative{position:relative}.ag-full-width-row{overflow:hidden;pointer-events:all}.ag-row-inline-editing{z-index:1}.ag-row-dragging{z-index:2}.ag-stub-cell{display:flex;align-items:center}.ag-cell{display:inline-block;position:absolute;white-space:nowrap}.ag-cell-value,.ag-group-value{overflow:hidden;text-overflow:ellipsis}.ag-cell-wrapper{display:flex;align-items:center;height:100%}.ag-cell-wrapper.ag-row-group{align-items:flex-start}.ag-full-width-row .ag-cell-wrapper.ag-row-group{align-items:center}.ag-cell-auto-height{height:100%}.ag-cell-inline-editing{z-index:1}.ag-cell-inline-editing .ag-cell-edit-wrapper,.ag-cell-inline-editing .ag-cell-editor,.ag-cell-inline-editing .ag-cell-editor .ag-wrapper,.ag-cell-inline-editing .ag-cell-editor input{height:100%;width:100%;line-height:normal}.ag-cell .ag-icon{display:inline-block;vertical-align:middle}.ag-set-filter-item{display:flex;align-items:center;height:100%}.ag-set-filter-item-value{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ag-set-filter-item-checkbox{display:flex;pointer-events:none}.ag-filter-body-wrapper{display:flex;flex-direction:column}.ag-filter-filter{flex:1 1 auto;overflow:hidden}.ag-filter-condition{display:flex}.ag-floating-filter-body{position:relative;display:flex;flex:1 1 auto;height:100%}.ag-floating-filter-full-body{display:flex;flex:1 1 auto;height:100%;width:100%;align-items:center;overflow:hidden}.ag-floating-filter-full-body>div{flex:1 1 auto}.ag-floating-filter{display:inline-block;position:absolute}.ag-floating-filter-input{align-items:center;display:flex;width:100%}.ag-floating-filter-input>*{flex:1 1 auto}.ag-floating-filter-button{display:flex;flex:none}.ag-dnd-ghost{position:absolute;display:inline-flex;align-items:center;cursor:move;white-space:nowrap}.ag-overlay{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.ag-overlay-panel,.ag-overlay-wrapper{display:flex;height:100%;width:100%}.ag-overlay-wrapper{flex:none;align-items:center;justify-content:center;text-align:center}.ag-overlay-loading-wrapper{pointer-events:all}.ag-popup-child{z-index:5}.ag-popup-editor{position:absolute;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:1}.ag-large-text-input{display:block}.ag-virtual-list-item{position:absolute;width:100%}.ag-floating-top{overflow:hidden;white-space:nowrap;width:100%;position:relative;display:flex}.ag-pinned-left-floating-top,.ag-pinned-right-floating-top{display:inline-block;overflow:hidden;position:relative;min-width:0}.ag-floating-bottom{overflow:hidden;white-space:nowrap;width:100%;position:relative;display:flex}.ag-pinned-left-floating-bottom,.ag-pinned-right-floating-bottom{display:inline-block;overflow:hidden;position:relative;min-width:0}.ag-dialog,.ag-panel{display:flex;flex-direction:column;position:relative;overflow:hidden}.ag-panel-title-bar{display:flex;flex:none;align-items:center;cursor:default}.ag-panel-title-bar-title{flex:1 1 auto}.ag-panel-title-bar-buttons{display:flex}.ag-panel-title-bar-button{cursor:pointer}.ag-panel-content-wrapper{display:flex;flex:1 1 auto;position:relative;overflow:hidden}.ag-dialog,.ag-resizer{position:absolute}.ag-resizer{pointer-events:none;z-index:1}.ag-resizer.ag-resizer-topLeft{top:0;left:0;height:5px;width:5px;cursor:nwse-resize}.ag-resizer.ag-resizer-top{top:0;left:5px;right:5px;height:5px;cursor:ns-resize}.ag-resizer.ag-resizer-topRight{top:0;right:0;height:5px;width:5px;cursor:nesw-resize}.ag-resizer.ag-resizer-right{top:5px;right:0;bottom:5px;width:5px;cursor:ew-resize}.ag-resizer.ag-resizer-bottomRight{bottom:0;right:0;height:5px;width:5px;cursor:nwse-resize}.ag-resizer.ag-resizer-bottom{bottom:0;left:5px;right:5px;height:5px;cursor:ns-resize}.ag-resizer.ag-resizer-bottomLeft{bottom:0;left:0;height:5px;width:5px;cursor:nesw-resize}.ag-resizer.ag-resizer-left{left:0;top:5px;bottom:5px;width:5px;cursor:ew-resize}.ag-tooltip{position:absolute;pointer-events:none;z-index:99999}.ag-value-slide-out{margin-right:5px;opacity:1;transition:opacity 3s,margin-right 3s;transition-timing-function:linear}.ag-value-slide-out-end{margin-right:10px;opacity:0}.ag-opacity-zero{opacity:0!important}.ag-menu{max-height:100%;overflow-y:auto;position:absolute;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ag-menu-column-select-wrapper{height:265px;overflow:auto}.ag-menu-list{display:table}.ag-menu-option,.ag-menu-separator{display:table-row}.ag-menu-option-part,.ag-menu-separator-cell{display:table-cell;vertical-align:middle}.ag-menu-option-text{white-space:nowrap}.ag-menu-column-select-wrapper .ag-column-select{height:100%}.ag-rich-select{cursor:default;outline:none}.ag-rich-select-value{display:flex;align-items:center}.ag-rich-select-value-icon{flex:1 1 auto;order:1}.ag-ltr .ag-rich-select-value-icon{text-align:right}.ag-rtl .ag-rich-select-value-icon{text-align:left}.ag-rich-select-list{position:relative}.ag-rich-select-virtual-list-item{display:flex}.ag-rich-select-row{display:flex;flex:1 1 auto;align-items:center;white-space:nowrap}.ag-paging-panel{justify-content:flex-end}.ag-paging-page-summary-panel,.ag-paging-panel{align-items:center;display:flex}.ag-paging-button-wrapper{position:relative;overflow:hidden}.ag-paging-button{position:absolute}.ag-disabled .ag-paging-page-summary-panel{pointer-events:none}.ag-tool-panel-wrapper{display:flex;overflow-y:auto;overflow-x:hidden;cursor:default;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;width:200px}.ag-column-select-column,.ag-column-select-column-group{position:relative;align-items:center;display:flex;flex-direction:row;flex-wrap:nowrap;text-overflow:ellipsis;white-space:nowrap}.ag-column-select-column-group>*,.ag-column-select-column>*{flex:none}.ag-column-select-checkbox{display:flex}.ag-tool-panel-horizontal-resize{cursor:ew-resize;height:100%;position:absolute;top:0;width:5px;z-index:1}.ag-ltr .ag-side-bar-left .ag-tool-panel-horizontal-resize{right:-3px}.ag-ltr .ag-side-bar-right .ag-tool-panel-horizontal-resize,.ag-rtl .ag-side-bar-left .ag-tool-panel-horizontal-resize{left:-3px}.ag-rtl .ag-side-bar-right .ag-tool-panel-horizontal-resize{right:-3px}.ag-details-row{width:100%}.ag-details-row-fixed-height{height:100%}.ag-details-grid{width:100%}.ag-details-grid-fixed-height{height:100%}.ag-header-group-cell{display:flex;align-items:center;height:100%;position:absolute}.ag-cell-label-container{display:flex;justify-content:space-between;flex-direction:row-reverse;align-items:center;width:100%;height:100%}.ag-right-aligned-header .ag-cell-label-container{flex-direction:row}.ag-side-bar{display:flex;flex-direction:row-reverse}.ag-side-bar-left{order:-1;flex-direction:row}.ag-side-button-button{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-wrap:nowrap;white-space:nowrap;outline:none;cursor:pointer}.ag-side-button-label{-webkit-writing-mode:vertical-lr;-ms-writing-mode:tb-lr;writing-mode:vertical-lr}.ag-status-bar{display:flex;justify-content:space-between;overflow:hidden}.ag-status-panel{display:inline-flex}.ag-status-name-value{white-space:nowrap}.ag-status-bar-center,.ag-status-bar-left,.ag-status-bar-right{display:inline-flex}.ag-icon{display:block;speak:none}.ag-group{position:relative;width:100%}.ag-group-title-bar{display:flex;align-items:center}.ag-group-title{display:block;flex:1 1 auto;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.ag-group-title-bar .ag-group-title{cursor:default}.ag-group-toolbar{display:flex;align-items:center}.ag-group-container{display:flex}.ag-disabled .ag-group-container{pointer-events:none}.ag-group-container-horizontal{flex-direction:row;flex-wrap:wrap}.ag-group-container-vertical{flex-direction:column}.ag-charts-font-size-color{display:flex;align-self:stretch;justify-content:space-between}.ag-column-group-icons{display:block}.ag-column-group-icons>*{cursor:pointer}.ag-group-item-alignment-stretch .ag-group-item{align-items:stretch}.ag-group-item-alignment-start .ag-group-item{align-items:flex-start}.ag-group-item-alignment-end .ag-group-item{align-items:flex-end}.ag-toggle-button-icon{transition:right .3s;position:absolute;top:-1px}.ag-input-field,.ag-select{display:flex;flex-direction:row;align-items:center}.ag-input-field-input{flex:1 1 auto;width:100%;min-width:0}.ag-floating-filter-input .ag-input-field-input[type=date]{width:1px}.ag-angle-select,.ag-range-field{display:flex;align-items:center}.ag-angle-select-wrapper{display:flex}.ag-angle-select-parent-circle{display:block;position:relative}.ag-angle-select-child-circle{position:absolute}.ag-slider-wrapper{display:flex}.ag-picker-field-display,.ag-slider-wrapper .ag-input-field{flex:1 1 auto}.ag-picker-field{display:flex;align-items:center}.ag-picker-field-icon{display:flex;border:0;padding:0;margin:0;cursor:pointer}.ag-picker-field-wrapper{overflow:hidden}.ag-label-align-right .ag-label{order:1}.ag-label-align-right>*{flex:none}.ag-label-align-top{flex-direction:column;align-items:flex-start}.ag-label-align-top>*{align-self:stretch}.ag-color-panel{width:100%;display:flex;flex-direction:column;text-align:center}.ag-spectrum-color{flex:1 1 auto;position:relative;overflow:hidden;cursor:default}.ag-spectrum-fill{position:absolute;top:0;left:0;right:0;bottom:0}.ag-spectrum-val{cursor:pointer}.ag-spectrum-dragger{position:absolute;pointer-events:none;cursor:pointer}.ag-spectrum-hue{cursor:default;background:linear-gradient(270deg,red 3%,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red)}.ag-spectrum-alpha{cursor:default}.ag-spectrum-hue-background{width:100%;height:100%}.ag-spectrum-alpha-background{background-image:linear-gradient(90deg,transparent,#000);width:100%;height:100%}.ag-spectrum-tool{cursor:pointer}.ag-spectrum-slider{position:absolute;pointer-events:none}.ag-recent-colors{display:flex}.ag-recent-color{cursor:pointer}.ag-ltr .ag-column-select-indent-1{padding-left:20px}.ag-rtl .ag-column-select-indent-1{padding-right:20px}.ag-ltr .ag-row-group-indent-1{padding-left:20px}.ag-rtl .ag-row-group-indent-1{padding-right:20px}.ag-ltr .ag-column-select-indent-2{padding-left:40px}.ag-rtl .ag-column-select-indent-2{padding-right:40px}.ag-ltr .ag-row-group-indent-2{padding-left:40px}.ag-rtl .ag-row-group-indent-2{padding-right:40px}.ag-ltr .ag-column-select-indent-3{padding-left:60px}.ag-rtl .ag-column-select-indent-3{padding-right:60px}.ag-ltr .ag-row-group-indent-3{padding-left:60px}.ag-rtl .ag-row-group-indent-3{padding-right:60px}.ag-ltr .ag-column-select-indent-4{padding-left:80px}.ag-rtl .ag-column-select-indent-4{padding-right:80px}.ag-ltr .ag-row-group-indent-4{padding-left:80px}.ag-rtl .ag-row-group-indent-4{padding-right:80px}.ag-ltr .ag-column-select-indent-5{padding-left:100px}.ag-rtl .ag-column-select-indent-5{padding-right:100px}.ag-ltr .ag-row-group-indent-5{padding-left:100px}.ag-rtl .ag-row-group-indent-5{padding-right:100px}.ag-ltr .ag-column-select-indent-6{padding-left:120px}.ag-rtl .ag-column-select-indent-6{padding-right:120px}.ag-ltr .ag-row-group-indent-6{padding-left:120px}.ag-rtl .ag-row-group-indent-6{padding-right:120px}.ag-ltr .ag-column-select-indent-7{padding-left:140px}.ag-rtl .ag-column-select-indent-7{padding-right:140px}.ag-ltr .ag-row-group-indent-7{padding-left:140px}.ag-rtl .ag-row-group-indent-7{padding-right:140px}.ag-ltr .ag-column-select-indent-8{padding-left:160px}.ag-rtl .ag-column-select-indent-8{padding-right:160px}.ag-ltr .ag-row-group-indent-8{padding-left:160px}.ag-rtl .ag-row-group-indent-8{padding-right:160px}.ag-ltr .ag-column-select-indent-9{padding-left:180px}.ag-rtl .ag-column-select-indent-9{padding-right:180px}.ag-ltr .ag-row-group-indent-9{padding-left:180px}.ag-rtl .ag-row-group-indent-9{padding-right:180px}.ag-ltr{direction:ltr}.ag-ltr .ag-body,.ag-ltr .ag-body-horizontal-scroll,.ag-ltr .ag-body-viewport,.ag-ltr .ag-floating-bottom,.ag-ltr .ag-floating-top,.ag-ltr .ag-header{flex-direction:row}.ag-rtl{direction:rtl}.ag-rtl .ag-body,.ag-rtl .ag-body-horizontal-scroll,.ag-rtl .ag-body-viewport,.ag-rtl .ag-floating-bottom,.ag-rtl .ag-floating-top,.ag-rtl .ag-header{flex-direction:row-reverse}.ag-rtl .ag-icon-contracted,.ag-rtl .ag-icon-tree-closed{display:block;-webkit-transform:rotate(180deg);transform:rotate(180deg)}.ag-body .ag-body-viewport{-webkit-overflow-scrolling:touch}.ag-chart{width:100%;height:100%}.ag-chart,.ag-chart-components-wrapper{position:relative;display:flex;overflow:hidden}.ag-chart-components-wrapper{flex:1 1 auto}.ag-chart-title-edit{position:absolute;display:none;top:0;left:0;text-align:center}.ag-chart-title-edit.currently-editing{display:inline-block}.ag-chart-canvas-wrapper{position:relative;flex:1 1 auto;overflow:hidden}.ag-charts-canvas{display:block}.ag-chart-menu{position:absolute;top:10px;width:24px;overflow:hidden;display:flex;flex-direction:column}.ag-ltr .ag-chart-menu{right:20px}.ag-rtl .ag-chart-menu{left:20px}.ag-chart-docked-container{position:relative;width:0;min-width:0;transition:min-width .4s}.ag-chart-menu-hidden~.ag-chart-docked-container{max-width:0;overflow:hidden}.ag-chart-tabbed-menu{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}.ag-chart-tabbed-menu-header{flex:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;cursor:default}.ag-chart-tabbed-menu-body{display:flex;flex:1 1 auto;align-items:stretch;overflow:hidden}.ag-chart-tab{width:100%;overflow:hidden;overflow-y:auto}.ag-chart-settings{overflow-x:hidden}.ag-chart-settings-wrapper{position:relative;flex-direction:column;width:100%;height:100%;display:flex;overflow:hidden}.ag-chart-settings-nav-bar{width:100%;display:flex;height:30px;align-items:center}.ag-chart-settings-card-selector{display:flex;align-items:center;justify-content:space-around;flex:1 1 auto;height:100%;padding:0 10px}.ag-chart-settings-card-item{cursor:pointer;width:10px;height:10px;background-color:#000;position:relative}.ag-chart-settings-card-item.ag-not-selected{opacity:.2}.ag-chart-settings-card-item:before{content:" ";display:block;position:absolute;background-color:transparent;left:50%;top:50%;margin-left:-10px;margin-top:-10px;width:20px;height:20px}.ag-chart-settings-next,.ag-chart-settings-prev{position:relative;flex:none}.ag-chart-settings-next-button,.ag-chart-settings-prev-button{position:absolute;top:0;left:0;width:100%;height:100%;cursor:pointer;opacity:0}.ag-chart-settings-mini-charts-container{position:relative;flex:1 1 auto;overflow-x:hidden;overflow-y:auto}.ag-chart-settings-mini-wrapper{position:absolute;top:0;left:0;display:flex;flex-direction:column;width:100%;min-height:100%;overflow:hidden}.ag-chart-settings-mini-wrapper.ag-animating{transition:left .3s;transition-timing-function:ease-in-out}.ag-chart-mini-thumbnail{cursor:pointer}.ag-chart-mini-thumbnail-canvas{display:block}.ag-chart-data-wrapper,.ag-chart-format-wrapper{display:flex;flex-direction:column;position:relative;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ag-chart-data-section,.ag-chart-format-section{display:flex;margin:0}.ag-charts-font-panel-controls{justify-content:space-between}.ag-chart-empty-text{display:flex;top:0;width:100%;height:100%;align-items:center;justify-content:center}.ag-chart .ag-chart-menu{opacity:0;pointer-events:none}.ag-chart-menu-hidden:hover .ag-chart-menu{opacity:1;pointer-events:all}.ag-chart-settings-nav-bar{padding:0 10px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ag-date-time-list-page-column-labels-row,.ag-date-time-list-page-entries-row,.ag-date-time-list-page-title-bar{display:flex}.ag-date-time-list-page-column-label,.ag-date-time-list-page-entry{flex-basis:0;flex-grow:1}.ag-date-time-list-page-entry{cursor:pointer}',""]),e.exports=t},function(e,t,o){var r=o(27),a=o(156);"string"==typeof(a=a.__esModule?a.default:a)&&(a=[[e.i,a,""]]);var n={insert:"head",singleton:!1};r(a,n);e.exports=a.locals||{}},function(e,t,o){(t=o(28)(!1)).push([e.i,'.ag-theme-alpine-dark{-webkit-font-smoothing:antialiased;color:#fff;color:var(--ag-foreground-color,#fff);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:13px;line-height:normal}@font-face{font-family:agGridAlpine;src:url("data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABNkAAsAAAAAIqAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlMAAAReYc5joU9TLzIAAANcAAAAQAAAAFZWUVJ5Y21hcAAAA5wAAAHqAAAFgHCsDfxnbHlmAAAFiAAACesAABCUC9Ir6mhlYWQAAA90AAAANAAAADZ2zsSBaGhlYQAAD6gAAAAeAAAAJAfSBC5obXR4AAAPyAAAABcAAAEou4D/+2xvY2EAAA/gAAAAbwAAAJbPsst2bWF4cAAAEFAAAAAfAAAAIAFgAHNuYW1lAAAQcAAAATUAAAJG5xgJvXBvc3QAABGoAAABuQAAApPSPvKNeJx9k81SE1EQhc9kQgwJBkREjREU//GPYX4yJiGQMAFisXDhwoUbXGhpUa54Atc+gOUD+BQ+geXSlQ/gA1g+gN/tTAyyIFOZubf79Onuc/vKk1TRmroqZDv7z1U7PDh6r7qKGv2c//jaO3z75kDl8Q5f0b5lef4f1bSiFzrSN0/ea+9zoeQX/K6/73/wP/k/5IO6pkegq1rnCRXxDhQrUVOpCiphC1k/UQu0z7tt1nktaso8mQa6QM6QmIExruqpbmkOnr7x9LQJKuZxnD3euzy3NXsKItUd+BOq2cDqWBvUeU7T2qHGHnV0iG7hncO3ReaAmD6+PrX5hiqajnt6SeS89eYikxwX8w+1bfvAdkuoMEa14W/C7/gek3Vsb5IpIuIh7Amobq7hKv8q3hhMQGzHNHPRSyAjKoy1zMp1FtHZjG7C/kyvdJ+47TymZyqOer5H9RN73/hS8hy3duDaBfuAGiZWdyJ3yRVoiL/CSWV6p4/6oq/6rp/6pd/gF8kSWQebcG+dqsw0+p1EZ3jb/6yu0zOcxUnU/4gKfTdNmxDfIFfQZZvB57SJWQdYY8NX4XT4jGpS9Jpi8gLLG2Etsd9gH4Ku5dPY4jlrOg+YATcBdbRY5+2YRvOWsr9MtFuN6rpoarXguWSn5TR1N2nWdm7m3SnX0fkK34DOEtNnD+9VLI5pYmlYVErVjmMNf0q1k2yuqgZVRcxA2SZraLcgI9N1+hhVEumG3YChTdUKFST5jVzQeau+k5/UguFCi/JQIshvcmyauUnuU5ubit2/LKNqzAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMb0GmMDCC5ADUogpqeJy11IdSWkEYxfE/RdNM79X0jgJiQIogIMhjmO6Y4pju5CnzJt8LxJzlnjyAmcnO/Fh2udy9O3fPB8wABXkqRcgXyZHab83mpvMFjk7ni/zSeI7D5PW9xBY77EV5f1+zJTbZZjdy09HfltPVc1zjPs80WqNClxZ9aoyp0tHsKm0GNKizzhJNlhkyYYUeIzb0/7xWLzLLIa16RM9xTPc7zglOcorTnOEs5zjPBS5yictc4apWu84N5rnJLW5zh7vc0/oPeMgjHvNE+ynp9wUWKesBZzlYWzvg9alVuq1+bVztaLftQaOujTaXh5OV3mjjH272H9pc+ij89GhCepuZtNtNq8hz68oLa8lL68srq8lrG8sbq8pb68iWpROybavyztry3gbywRry0eqyY+uya0vyyZry2Zbliw3lq6W9f7MV+W49+WEj2TO9wMhlUlYinyH1hUzKVhQzKV8xk9GZJkynmzCdc8J04glLGQxTCghLby9MySBMGSFMaSFMuSFMCSJMWSJMqSJM+SJMSSNMmSNM6SNMOSRMiSRM2SRMKSVMeSVMySVMGSVMaSZMuSZMCSdMWSdMqSdM+SdMlYAw1QTCVB0IU50gTBWDMNUOwlRFCEt1MyxlJmz6/AsZUr+YIfXlDOU/rrOgigAAeJzFF21sU9f1nntjvzgJSRx/vJgQg/3ivNSxwxL7+dkx2JAEEmhIqWpYCqMhMCbWdFppM7EBbsd+dEVV1apS6A/yY9O2oFVaQEOb+sFKtZaRqh/qVLQf/fixdkxkXbNRodIZ3mXnXttpApnW/Zr93rnn3nt8zrnnni8TIPihcyxKqgmBgEdVPAEjYOoBOsdrCgW4yu9HeJxFs4VCJlMoCHLbzes3r7NP2afEhr+qIx7SRIhLURXdtJkChhAwVaAuXcBPnn028uqrNIMg8iwfHR4eXidXInKBPrFgMnzv8DD/YiE9qiWEsh7WQypRjmo6Y07VhJPds7nLaX4GrqZnuQ2uz6ZhCx5F0k6wCeImq/CnQcWu2N2qV/V2mQkzEddb9VaXoqOSqBnqBlcPjI6YqZQ5MvpRGRnpPn68e2JCQjaxaEsi1uvlXYTk/yOTle6tFjFF3l3MqekxjyZG+G0+fzafh4P5PFtmvY0XeJAfK+t5mV0mLuITtx2sBY/T7YdYoCsDhjPeAQ4wVVDZD2587o/58WFVcrTm+N+GZmBqiF3G+aLNG5+Dd+gCTN21mL+6NH+GznUb9yetizRyO2fr4oMLeTLJ0xlwhpbiizxZ1S18i4vfvZVv0Xbs++yb6L+VpJEQByiqA5i5Euzi6jxub1fCENdGP+Ej3Xu5BZmZmQunq6t9dd7ODZ3eOh/8Hn6axg3+KqydmcksW+ZvavUFOzuDvtAKv2BfIWVEMa6K91NHSCjgDNg0Z8ylOdPg1Jwsaj1FD/DN8q5eyhdoLM+PiZsq3lbJ7+lp5GFDHSm6DxyEFL+AYcii/AKfKcVj8Tw/ZOfwND7SLC1v92CUBFSJuL1oqATaqVVzoQ70NK/ROnNwNc8NoTK8gVADbsAb7OXOoPUC7b+nU7NeEHu0X+u09tH+Ugw+zZ4WvuYANJfiAB3dBa7Cvb18Cnb08pN8qhd2IKCJRVPYgSTkljgGXUEb6Aqw9TKQYYsIZLjObbMY1IvPHkKBioq2moEk5qGzkIRUduHZn8A4aCIdZK3ga6qJWJcfVoJSCyIp2ZUOuhrMDKg499NYl6nbtWAHGHFTVxNI6VbUhNlBg9C4NjKwfWT75HgzY+6+aDRi7hr7+uT4iooKz9BotM+9fPTowN2b0mGjfVM4UJlsuWdT2D0w1OLbc/RJ+nP87R19h7dWVZu7tI5IIgbQd2hrddWafY7me7rW7zVbuleG+9uN9t1Jd3gg1zKQ3omLC/SvxdwRRf3RpYUyUtdQhpZOQlHh1WDDTfR23ETvpxX9R/f4UPhTR0eXo2r8/IrxyV9J5ZslsqICfhzeFA5v2iYA+My961FkEV7aerhPaFtVGidRp4GwBKWYG0PbK2QZaqR4FKduBGyqxzRMNlZ4qUBPWdPvZ9+jc4XJszBcyGbffy8z+T4p50J6jc7hvTnkbeiKKnISvfbKK+lCgRu5HBjnzqVlbakhNcU4QfpynIjc0URWEo3opJ2sJsTUjJi64A39lznWqbPZ7EsSWm/9p0khX/xkS2OmNKI6lfPnv1UnAlgdQ/i6UI6Br46vWFNwDODIxoSPWm9LViiCnuIziMFv+Aw9IOXyzVmUleXHUIVMJrOEzVzo61iA0WZXpMngYC5Hz0iT8RpyWxxhscYw1ANsfTF0YIsII+qf7eZn+Jnu2XKMTNDzWJ8aSQQlxDOQBkMr+pHEOkDF1BzSPBg6tBbaARHpaz8LrtGmplK7k8ndqakpbU3wORjiv4aDEgdtfhOuamntruTIQyPJu7S0kptCuFGs7D4wkpQ2vXmTzco8fotNA5gTRXG0ic4BlbCJBqQ0F/mSLh8cPHbNvEbbzWsmJpQ3IW4NCrgL5/QT3OFvDg5CvBUxfMy1g4OD4zjic+2PEC/XkOfYc6iFU+bhmAfQKTEZagbogPWSHxsG2sP5h1g07+W8B+gHWTj4oVxjLn7sA7k2n2++9Fe0vzH/LWb08gspvOd8piz/HfZOUf682HlFsvNC0X/KmgilimL/VNZkviZMF/OiSG8qwPfSnKchxaI4dkOy5E+XWL3sz0SmVbG0KaL5oJeuXImcPx+RkPrl8JiE82cr9jEBzKZLdzIQF2isy6tCB0CwVQc/eNyCcKm+hvdEI4Nbdqb2t/NosAW2IALvBlvE4lJtDh/ZuWUwEm0J8mj7fv73liC8274/JdfK+j2Adc6LfqOjfhrmQrui3VLkAl1etz3YGk+AMHDAiLHGU8vWbV237JQsaQMC8g+cPl/Q5wPDej4HP8mxsVBHRwir3z5JcyLY2ag14mM10BMiKRTv8Ag7TIKlKpMoflWzVQxZAMWOhkZTKfY6NLkuegm0eitaBgQFliDVG/MiqsPdz2D2tjmau1ebeyvranwNqhv8nnUb9gNQ5vZE1eN/icAll6Omsn4y0dblhOWVKoVKOlFZVV1X21B/ER55xlFdXVfTVu2oHl3ub2xyNdTyj1Zsq9lnt/mM9q+p1ciBPlVf76r1TtYy1sT/anfrjfGG4xUVoFQ2XBTHqZJnmmbTGImrSBtZTzaSO0mO7CSj5Ft4Rj9VG1gtVSpCHVSnrgw1W2wBpxcrqZmwuVVRmAzpVorucWO90lQ58UrDhNxqzMDaGzPMMKBFYpioPTG9A/SQXVM8MbMVcw1ztm0IA6oU3tDGP+YffzmDZjhkXfjHnBanDqsSaFxbBS9WRbblIo7wxrZxR2TbtkjVupau5X6wXocjhwHy2fidSYBDWfjdIUGP5kiFHz2X7H+U/XJJ/s1ydsN63e5A8rm3nPUoDA5DnWTueLCtv506IjmUAzbF5Q37NyYfeXmz8ei/EqGR7JEjQaRmAEfy8MhtcSkzMp1O8wuQSnP6WVp0a92cLOxn3eSOcoTVC7dZJcxWLyKMBQWUYdYldkrB9fj4gd6+vt4D41Bfxh7/zq4dhmkaO3a9V0bYZbHB/7mY+MaRRUQSKcWT0KUG4z0htJEFoZj49f9Btb6He3sfflyAvq+mJZ0r0SMofGWFb6t9iopFV6TABf8BZT85241/BovnG2Rjsq7KTkbkQPyXG5AdSTEXWh/T09ZWTNYZmJUL/GSWzllvl2UxekLcmssBl6AO6ugJrH5Dpfs+wZjYc9DiKmP8Cr+yeA97V2xtsWTKXy/Ns0hQ2vsFc8l+X/TYJtwPX/Ra5/mfe6BJYH+AlT0luijtFSd04WnOyoLTc9+8faJ0ulgfdOzS6WeyLECKTmOdEC65INePYUXykC6RS0XpB4/Xrqj4pwodAOM5Jnpmz5c9ghFPmCoSqviYQF8rNgFmeG08m9y95xu5Suv5H3UPlDuFns7tKx8aGTgZt/rpa9gOaJEN1Wub9qxJjSSncvDA0cZvr0vJbkHr3GzbnrsPKemLhPwbDwYCEQB4nGNgZGBgAOLsD0FR8fw2Xxm4mV8ABaI4H+9rgNH/f///zfyW+S1QJQcDE5BkAACRug+HeJxjYGRgYH7BwAAi///+/5v5LQMjAyrwAgCe2QcHAAB4nGNgYGBgfgHC/39D6KGH6QEAIHUuCwB4nGNgAAIphiCGDIZFDHcYvjGqMQYwVjGuYTzH+IhJhMmMyYcpgekAMxezBrMDcxfzIeZbzJ9YTFiKWGawbGK5wfKKlY01jHUK6z+2JWw72P6xR7Dnsfexz2Ffxb6D/Rj7LfYX7H84vEiHANyaI6IAeJxjYGRgYPBiSGfgYQABJiDmAkIGhv9gPgMAGzsB1AB4nHWRPU7DQBCFnxMniBghJCREx1Y0SM5PQZEuFHGfIgWdE68dR7bXWm8ipeMYnIBjUHIETsEheDFTREjZ1a6/+fbNNAZwgy94OC4PV+19XB1csPrjLulW2Cc/CPcQ4Em4T/8sPKB9EQ7YWXKC51/S3ONNuINrvAt36T+EffKncA93+Bbu0/8ID7D0fOEAj95rnEU2T2ZFnVd6obNdEdtTdcpLbZvcVGocjk51pCttY6cTtTqoZp9NnEtVak2p5qZyuiiMqq3Z6rULN87V0+EwFR+uTYkYGSJY5EgwQ4GaVEFjwZNhRxPz9VzqnF/yWDSsDGuFMUKMzqYjnqrtiOH4TdixwoF3gz17JrQOKeuUGcO/ojBvJx/TBbehqdu3Lc2aPsSm7aoxxZA7/ZcPmeKkXwK+aWkAAAB4nG2S6W7bMBCE/cWSI9tpk7ptet/3obbpfaf3kT4FQ9EyEYkUSMp28vRl4yBAgO4fzgwWs7MLdpY6ixp0/l9bLNElIaXHMhl9BgxZ4RjHWWWNE4w4ySlOs84ZznKO81zgIpe4zBWuco3r3OAmt7jNHe5yj/s84CE5j3jMEzZ4yjOe84KXvOI1b3jLO97zgY9s8onPfOEr3/jOD37yi99s8aczFGXpVCmCtqYnnLMz3xVe9qQwUlXZ4sk3UjkRLqzJiZI723ae7wNVrB8K2hQqKFdrI4IaHcqtOehckbayLm90JG45krY2fiCtCU7IoIpE2mY3lc56nxTKy0zNGxE9i77aVbmvhJ90I+qNdRXHpGPtfEhKp5u0dLZtktgQkkqNQ6/SJs5brqwotCmzWsx1rfdUUivTZjHfghk1D4mxRg2NDbmoKjtTRdpEF9VttEkbPbUha5yaatv6NRfNbL7dhmBNbsfj1aOCSZ0uJyHxYqoGvo52eWFn5gD+izVcwP22bIFj6hDPMQpOqaP36+9LtlEma81iHwQlDkVAYzHM8EgqJuywzTx+g4KaloZdxuwx7XT+AvL3sQsAAAA=") format("woff");font-weight:400;font-style:normal}.ag-theme-alpine-dark .ag-icon{font-family:agGridAlpine;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ag-theme-alpine-dark .ag-icon-aggregation:before{content:"\\f101"}.ag-theme-alpine-dark .ag-icon-arrows:before{content:"\\f102"}.ag-theme-alpine-dark .ag-icon-asc:before{content:"\\f103"}.ag-theme-alpine-dark .ag-icon-cancel:before{content:"\\f104"}.ag-theme-alpine-dark .ag-icon-chart:before{content:"\\f105"}.ag-theme-alpine-dark .ag-icon-color-picker:before{content:"\\f109"}.ag-theme-alpine-dark .ag-icon-columns:before{content:"\\f10a"}.ag-theme-alpine-dark .ag-icon-contracted:before{content:"\\f10b"}.ag-theme-alpine-dark .ag-icon-copy:before{content:"\\f10c"}.ag-theme-alpine-dark .ag-icon-cross:before{content:"\\f10d"}.ag-theme-alpine-dark .ag-icon-desc:before{content:"\\f10e"}.ag-theme-alpine-dark .ag-icon-expanded:before{content:"\\f10f"}.ag-theme-alpine-dark .ag-icon-eye-slash:before{content:"\\f110"}.ag-theme-alpine-dark .ag-icon-eye:before{content:"\\f111"}.ag-theme-alpine-dark .ag-icon-filter:before{content:"\\f112"}.ag-theme-alpine-dark .ag-icon-first:before{content:"\\f113"}.ag-theme-alpine-dark .ag-icon-grip:before{content:"\\f114"}.ag-theme-alpine-dark .ag-icon-group:before{content:"\\f115"}.ag-theme-alpine-dark .ag-icon-last:before{content:"\\f116"}.ag-theme-alpine-dark .ag-icon-left:before{content:"\\f117"}.ag-theme-alpine-dark .ag-icon-linked:before{content:"\\f118"}.ag-theme-alpine-dark .ag-icon-loading:before{content:"\\f119"}.ag-theme-alpine-dark .ag-icon-maximize:before{content:"\\f11a"}.ag-theme-alpine-dark .ag-icon-menu:before{content:"\\f11b"}.ag-theme-alpine-dark .ag-icon-minimize:before{content:"\\f11c"}.ag-theme-alpine-dark .ag-icon-next:before{content:"\\f11d"}.ag-theme-alpine-dark .ag-icon-none:before{content:"\\f11e"}.ag-theme-alpine-dark .ag-icon-not-allowed:before{content:"\\f11f"}.ag-theme-alpine-dark .ag-icon-paste:before{content:"\\f120"}.ag-theme-alpine-dark .ag-icon-pin:before{content:"\\f121"}.ag-theme-alpine-dark .ag-icon-pivot:before{content:"\\f122"}.ag-theme-alpine-dark .ag-icon-previous:before{content:"\\f123"}.ag-theme-alpine-dark .ag-icon-right:before{content:"\\f126"}.ag-theme-alpine-dark .ag-icon-save:before{content:"\\f127"}.ag-theme-alpine-dark .ag-icon-small-down:before{content:"\\f128"}.ag-theme-alpine-dark .ag-icon-small-left:before{content:"\\f129"}.ag-theme-alpine-dark .ag-icon-small-right:before{content:"\\f12a"}.ag-theme-alpine-dark .ag-icon-small-up:before{content:"\\f12b"}.ag-theme-alpine-dark .ag-icon-tick:before{content:"\\f12c"}.ag-theme-alpine-dark .ag-icon-tree-closed:before{content:"\\f12d"}.ag-theme-alpine-dark .ag-icon-tree-indeterminate:before{content:"\\f12e"}.ag-theme-alpine-dark .ag-icon-tree-open:before{content:"\\f12f"}.ag-theme-alpine-dark .ag-icon-unlinked:before{content:"\\f130"}.ag-theme-alpine-dark .ag-icon-row-drag:before{content:"\\f114"}.ag-theme-alpine-dark .ag-right-arrow:before{content:"\\f117";content:"\\f126"}.ag-theme-alpine-dark .ag-root-wrapper{background-color:#181d1f;background-color:var(--ag-background-color,#181d1f)}.ag-theme-alpine-dark [class^=ag-],.ag-theme-alpine-dark [class^=ag-]:after,.ag-theme-alpine-dark [class^=ag-]:before,.ag-theme-alpine-dark [class^=ag-]:focus{box-sizing:border-box;outline:none}.ag-theme-alpine-dark [class^=ag-]::-ms-clear{display:none}.ag-theme-alpine-dark .ag-checkbox .ag-input-wrapper,.ag-theme-alpine-dark .ag-radio-button .ag-input-wrapper{overflow:visible}.ag-theme-alpine-dark .ag-range-field .ag-input-wrapper{height:100%}.ag-theme-alpine-dark .ag-toggle-button{flex:none;width:unset;min-width:unset}.ag-theme-alpine-dark .ag-ltr .ag-label-align-right .ag-label{margin-left:6px}.ag-theme-alpine-dark .ag-rtl .ag-label-align-right .ag-label{margin-right:6px}.ag-theme-alpine-dark input[class^=ag-]{margin:0}.ag-theme-alpine-dark input[class^=ag-],.ag-theme-alpine-dark select[class^=ag-],.ag-theme-alpine-dark textarea[class^=ag-]{background-color:#181d1f;background-color:var(--ag-background-color,#181d1f)}.ag-theme-alpine-dark input[class^=ag-]:not([type]),.ag-theme-alpine-dark input[class^=ag-][type=date],.ag-theme-alpine-dark input[class^=ag-][type=datetime-local],.ag-theme-alpine-dark input[class^=ag-][type=number],.ag-theme-alpine-dark input[class^=ag-][type=tel],.ag-theme-alpine-dark input[class^=ag-][type=text],.ag-theme-alpine-dark textarea[class^=ag-]{font-size:inherit;line-height:inherit;color:inherit;border:1px solid #68686e;border-color:var(--ag-input-border-color,var(--ag-border-color,#68686e))}.ag-theme-alpine-dark input[class^=ag-]:not([type]):disabled,.ag-theme-alpine-dark input[class^=ag-][type=date]:disabled,.ag-theme-alpine-dark input[class^=ag-][type=datetime-local]:disabled,.ag-theme-alpine-dark input[class^=ag-][type=number]:disabled,.ag-theme-alpine-dark input[class^=ag-][type=tel]:disabled,.ag-theme-alpine-dark input[class^=ag-][type=text]:disabled,.ag-theme-alpine-dark textarea[class^=ag-]:disabled{color:hsla(0,0%,100%,.5);color:var(--ag-disabled-foreground-color,hsla(0,0%,100%,.5));background-color:#282c2f;background-color:var(--ag-input-disabled-background-color,#282c2f);border-color:rgba(104,104,110,.3);border-color:var(--ag-input-disabled-border-color,rgba(104,104,110,.3))}.ag-theme-alpine-dark input[class^=ag-]:not([type]):focus,.ag-theme-alpine-dark input[class^=ag-][type=date]:focus,.ag-theme-alpine-dark input[class^=ag-][type=datetime-local]:focus,.ag-theme-alpine-dark input[class^=ag-][type=number]:focus,.ag-theme-alpine-dark input[class^=ag-][type=tel]:focus,.ag-theme-alpine-dark input[class^=ag-][type=text]:focus,.ag-theme-alpine-dark textarea[class^=ag-]:focus{outline:none;box-shadow:0 0 2px .5px hsla(0,0%,100%,.5),0 0 4px 3px rgba(33,150,243,.6);border-color:rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine-dark input[class^=ag-][type=number]{-moz-appearance:textfield}.ag-theme-alpine-dark input[class^=ag-][type=number]::-webkit-inner-spin-button,.ag-theme-alpine-dark input[class^=ag-][type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.ag-theme-alpine-dark input[class^=ag-][type=range]{padding:0}.ag-theme-alpine-dark button[class^=ag-]:focus,.ag-theme-alpine-dark input[class^=ag-][type=button]:focus{box-shadow:0 0 2px .5px hsla(0,0%,100%,.5),0 0 4px 3px rgba(33,150,243,.6)}.ag-theme-alpine-dark .ag-drag-handle{color:#fff;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#fff))}.ag-theme-alpine-dark .ag-list-item,.ag-theme-alpine-dark .ag-virtual-list-item{height:30px}.ag-theme-alpine-dark .ag-keyboard-focus .ag-virtual-list-item:focus{outline:none}.ag-theme-alpine-dark .ag-keyboard-focus .ag-virtual-list-item:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine-dark .ag-select-list{background-color:#181d1f;background-color:var(--ag-background-color,#181d1f);overflow-y:auto;overflow-x:hidden}.ag-theme-alpine-dark .ag-list-item{display:flex;align-items:center}.ag-theme-alpine-dark .ag-list-item.ag-active-item{background-color:rgba(33,150,243,.1);background-color:var(--ag-row-hover-color,rgba(33,150,243,.1))}.ag-theme-alpine-dark .ag-select-list-item{padding-left:4px;padding-right:4px;cursor:default;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.ag-theme-alpine-dark .ag-select-list-item span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.ag-theme-alpine-dark .ag-select .ag-picker-field-wrapper{background-color:#181d1f;background-color:var(--ag-background-color,#181d1f);min-height:30px;cursor:default}.ag-theme-alpine-dark .ag-select:not(.ag-cell-editor){height:30px}.ag-theme-alpine-dark .ag-select .ag-picker-field-display{margin:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ag-theme-alpine-dark .ag-select .ag-picker-field-icon{display:flex;align-items:center}.ag-theme-alpine-dark .ag-select.ag-disabled{opacity:.5}.ag-theme-alpine-dark .ag-rich-select{background-color:#222628;background-color:var(--ag-control-panel-background-color,#222628)}.ag-theme-alpine-dark .ag-rich-select-list{width:100%;min-width:200px;height:273px}.ag-theme-alpine-dark .ag-rich-select-value{padding:0 6px 0 18px;height:42px;border-bottom:1px solid rgba(88,86,82,.5);border-bottom-color:var(--ag-secondary-border-color,rgba(88,86,82,.5))}.ag-theme-alpine-dark .ag-rich-select-virtual-list-item{cursor:default;height:30px}.ag-theme-alpine-dark .ag-rich-select-virtual-list-item:hover{background-color:rgba(33,150,243,.1);background-color:var(--ag-row-hover-color,rgba(33,150,243,.1))}.ag-theme-alpine-dark .ag-rich-select-row{padding-left:18px}.ag-theme-alpine-dark .ag-rich-select-row-selected{background-color:rgba(33,150,243,.3);background-color:var(--ag-selected-row-background-color,rgba(33,150,243,.3))}.ag-theme-alpine-dark .ag-group-contracted,.ag-theme-alpine-dark .ag-group-expanded,.ag-theme-alpine-dark .ag-row-drag,.ag-theme-alpine-dark .ag-selection-checkbox{color:#fff;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#fff))}.ag-theme-alpine-dark .ag-ltr .ag-group-contracted,.ag-theme-alpine-dark .ag-ltr .ag-group-expanded,.ag-theme-alpine-dark .ag-ltr .ag-row-drag,.ag-theme-alpine-dark .ag-ltr .ag-selection-checkbox{margin-right:12px}.ag-theme-alpine-dark .ag-rtl .ag-group-contracted,.ag-theme-alpine-dark .ag-rtl .ag-group-expanded,.ag-theme-alpine-dark .ag-rtl .ag-row-drag,.ag-theme-alpine-dark .ag-rtl .ag-selection-checkbox{margin-left:12px}.ag-theme-alpine-dark .ag-cell-wrapper>:not(.ag-cell-value):not(.ag-group-value){height:40px;display:flex;align-items:center;flex:none}.ag-theme-alpine-dark .ag-group-contracted,.ag-theme-alpine-dark .ag-group-expanded{cursor:pointer}.ag-theme-alpine-dark .ag-group-title-bar-icon{cursor:pointer;flex:none;color:#fff;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#fff))}.ag-theme-alpine-dark .ag-ltr .ag-group-child-count{margin-left:2px}.ag-theme-alpine-dark .ag-rtl .ag-group-child-count{margin-right:2px}.ag-theme-alpine-dark .ag-group-title-bar{background-color:#000;background-color:var(--ag-subheader-background-color,#000);padding:6px}.ag-theme-alpine-dark .ag-group-toolbar{padding:6px}.ag-theme-alpine-dark .ag-disabled-group-container,.ag-theme-alpine-dark .ag-disabled-group-title-bar{opacity:.5}.ag-theme-alpine-dark .group-item{margin:3px 0}.ag-theme-alpine-dark .ag-label{white-space:nowrap}.ag-theme-alpine-dark .ag-ltr .ag-label{margin-right:6px}.ag-theme-alpine-dark .ag-rtl .ag-label{margin-left:6px}.ag-theme-alpine-dark .ag-label-align-top .ag-label{margin-bottom:3px}.ag-theme-alpine-dark .ag-ltr .ag-angle-select-field,.ag-theme-alpine-dark .ag-ltr .ag-slider-field{margin-right:12px}.ag-theme-alpine-dark .ag-rtl .ag-angle-select-field,.ag-theme-alpine-dark .ag-rtl .ag-slider-field{margin-left:12px}.ag-theme-alpine-dark .ag-angle-select-parent-circle{width:24px;height:24px;border-radius:12px;border:1px solid #68686e;border-color:var(--ag-border-color,#68686e);background-color:#181d1f;background-color:var(--ag-background-color,#181d1f)}.ag-theme-alpine-dark .ag-angle-select-child-circle{top:4px;left:12px;width:6px;height:6px;margin-left:-3px;margin-top:-4px;border-radius:3px;background-color:#fff;background-color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#fff))}.ag-theme-alpine-dark .ag-picker-field-wrapper{border:1px solid #68686e;border-color:var(--ag-border-color,#68686e);border-radius:5px}.ag-theme-alpine-dark .ag-picker-field-wrapper:focus{box-shadow:0 0 2px .5px hsla(0,0%,100%,.5),0 0 4px 3px rgba(33,150,243,.6)}.ag-theme-alpine-dark .ag-picker-field-button{background-color:#181d1f;background-color:var(--ag-background-color,#181d1f);color:#fff;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#fff))}.ag-theme-alpine-dark .ag-dialog.ag-color-dialog{border-radius:5px}.ag-theme-alpine-dark .ag-color-picker .ag-picker-field-display{height:16px}.ag-theme-alpine-dark .ag-color-panel{padding:6px}.ag-theme-alpine-dark .ag-spectrum-color{background-color:red;border-radius:2px}.ag-theme-alpine-dark .ag-spectrum-tools{padding:10px}.ag-theme-alpine-dark .ag-spectrum-sat{background-image:linear-gradient(90deg,#fff,rgba(204,154,129,0))}.ag-theme-alpine-dark .ag-spectrum-val{background-image:linear-gradient(0deg,#000,rgba(204,154,129,0))}.ag-theme-alpine-dark .ag-spectrum-dragger{border-radius:12px;height:12px;width:12px;border:1px solid #fff;background:#000;box-shadow:0 0 2px 0 rgba(0,0,0,.24)}.ag-theme-alpine-dark .ag-spectrum-alpha-background,.ag-theme-alpine-dark .ag-spectrum-hue-background{border-radius:2px}.ag-theme-alpine-dark .ag-spectrum-tool{margin-bottom:10px;height:11px;border-radius:2px}.ag-theme-alpine-dark .ag-spectrum-slider{margin-top:-12px;width:13px;height:13px;border-radius:13px;background-color:#f8f8f8;box-shadow:0 1px 4px 0 rgba(0,0,0,.37)}.ag-theme-alpine-dark .ag-recent-color{margin:0 3px}.ag-theme-alpine-dark .ag-recent-color:first-child{margin-left:0}.ag-theme-alpine-dark .ag-recent-color:last-child{margin-right:0}.ag-theme-alpine-dark.ag-dnd-ghost{background:#181d1f;background:var(--ag-background-color,#181d1f);border-radius:3px;box-shadow:0 1px 20px 1px #000;overflow:hidden;text-overflow:ellipsis;z-index:10;border:1px solid rgba(88,86,82,.5);border:1px solid var(--ag-secondary-border-color,rgba(88,86,82,.5));color:#fff;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#fff));height:48px!important;line-height:48px;margin:0;padding:0 12px;-webkit-transform:translateY(12px);transform:translateY(12px)}.ag-theme-alpine-dark .ag-dnd-ghost-icon{margin-right:6px;color:#fff;color:var(--ag-foreground-color,#fff)}.ag-theme-alpine-dark .ag-popup-child:not(.ag-tooltip-custom){box-shadow:0 1px 20px 1px #000}.ag-dragging-fill-handle .ag-theme-alpine-dark .ag-dialog,.ag-dragging-range-handle .ag-theme-alpine-dark .ag-dialog{opacity:.7;pointer-events:none}.ag-theme-alpine-dark .ag-dialog{border-radius:3px;border:1px solid #68686e;border-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-panel{background-color:#181d1f;background-color:var(--ag-background-color,#181d1f)}.ag-theme-alpine-dark .ag-panel-title-bar{background-color:#222628;background-color:var(--ag-header-background-color,#222628);color:#fff;color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,var(--ag-foreground-color,#fff)));height:48px;padding:6px 18px;border-bottom:1px solid #68686e;border-bottom-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-ltr .ag-panel-title-bar-button{margin-left:6px}.ag-theme-alpine-dark .ag-rtl .ag-panel-title-bar-button{margin-right:6px}.ag-theme-alpine-dark .ag-tooltip{background-color:#222628;background-color:var(--ag-header-background-color,#222628);color:#fff;color:var(--ag-foreground-color,#fff);padding:6px;border:1px solid #68686e;border-color:var(--ag-border-color,#68686e);border-radius:3px;transition:opacity 1s}.ag-theme-alpine-dark .ag-tooltip.ag-tooltip-hiding{opacity:0}.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-1{padding-left:16px}.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-1{padding-right:16px}.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-2{padding-left:32px}.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-2{padding-right:32px}.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-3{padding-left:48px}.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-3{padding-right:48px}.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-4{padding-left:64px}.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-4{padding-right:64px}.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-5{padding-left:80px}.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-5{padding-right:80px}.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-6{padding-left:96px}.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-6{padding-right:96px}.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-7{padding-left:112px}.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-7{padding-right:112px}.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-8{padding-left:128px}.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-8{padding-right:128px}.ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-9{padding-left:144px}.ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-9{padding-right:144px}.ag-theme-alpine-dark .ag-column-select-header-icon{cursor:pointer}.ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-header-icon:focus{outline:none}.ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-header-icon:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:0;left:0;display:block;width:100%;height:100%;border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine-dark .ag-ltr .ag-column-group-icons:not(:last-child),.ag-theme-alpine-dark .ag-ltr .ag-column-select-checkbox:not(:last-child),.ag-theme-alpine-dark .ag-ltr .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-alpine-dark .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-alpine-dark .ag-ltr .ag-column-select-column-label:not(:last-child),.ag-theme-alpine-dark .ag-ltr .ag-column-select-header-checkbox:not(:last-child),.ag-theme-alpine-dark .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-alpine-dark .ag-ltr .ag-column-select-header-icon:not(:last-child){margin-right:12px}.ag-theme-alpine-dark .ag-rtl .ag-column-group-icons:not(:last-child),.ag-theme-alpine-dark .ag-rtl .ag-column-select-checkbox:not(:last-child),.ag-theme-alpine-dark .ag-rtl .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-alpine-dark .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-alpine-dark .ag-rtl .ag-column-select-column-label:not(:last-child),.ag-theme-alpine-dark .ag-rtl .ag-column-select-header-checkbox:not(:last-child),.ag-theme-alpine-dark .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-alpine-dark .ag-rtl .ag-column-select-header-icon:not(:last-child){margin-left:12px}.ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-column-group:focus{outline:none}.ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-column-group:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-3px;left:-3px;display:block;width:calc(100% - -6px);height:calc(100% - -6px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-column:focus{outline:none}.ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-column:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-3px;left:-3px;display:block;width:calc(100% - -6px);height:calc(100% - -6px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine-dark .ag-column-select-column-group:not(:last-child),.ag-theme-alpine-dark .ag-column-select-column:not(:last-child){margin-bottom:9px}.ag-theme-alpine-dark .ag-column-select-column-group-readonly,.ag-theme-alpine-dark .ag-column-select-column-readonly{color:hsla(0,0%,100%,.5);color:var(--ag-disabled-foreground-color,hsla(0,0%,100%,.5));pointer-events:none}.ag-theme-alpine-dark .ag-ltr .ag-column-select-add-group-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-column-select-add-group-indent{margin-right:28px}.ag-theme-alpine-dark .ag-column-select-list{padding:12px}.ag-theme-alpine-dark .ag-rtl{text-align:right}.ag-theme-alpine-dark .ag-root-wrapper{border:1px solid #68686e;border-color:var(--ag-border-color,#68686e);border-radius:3px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-left:46px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-right:46px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-1{padding-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-1{padding-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-left:74px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-right:74px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-2{padding-left:56px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-2{padding-right:56px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-left:102px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-right:102px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-3{padding-left:84px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-3{padding-right:84px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-left:130px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-right:130px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-4{padding-left:112px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-4{padding-right:112px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-left:158px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-right:158px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-5{padding-left:140px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-5{padding-right:140px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-left:186px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-right:186px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-6{padding-left:168px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-6{padding-right:168px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-left:214px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-right:214px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-7{padding-left:196px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-7{padding-right:196px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-left:242px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-right:242px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-8{padding-left:224px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-8{padding-right:224px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-left:270px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-right:270px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-9{padding-left:252px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-9{padding-right:252px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-left:298px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-right:298px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-10{padding-left:280px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-10{padding-right:280px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-left:326px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-right:326px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-11{padding-left:308px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-11{padding-right:308px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-left:354px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-right:354px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-12{padding-left:336px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-12{padding-right:336px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-left:382px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-right:382px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-13{padding-left:364px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-13{padding-right:364px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-left:410px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-right:410px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-14{padding-left:392px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-14{padding-right:392px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-left:438px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-right:438px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-15{padding-left:420px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-15{padding-right:420px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-left:466px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-right:466px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-16{padding-left:448px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-16{padding-right:448px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-left:494px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-right:494px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-17{padding-left:476px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-17{padding-right:476px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-left:522px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-right:522px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-18{padding-left:504px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-18{padding-right:504px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-left:550px}.ag-theme-alpine-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-right:550px}.ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-19{padding-left:532px}.ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-19{padding-right:532px}.ag-theme-alpine-dark .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine-dark .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine-dark .ag-cell{-webkit-font-smoothing:subpixel-antialiased}.ag-theme-alpine-dark .ag-value-change-delta{padding-right:2px}.ag-theme-alpine-dark .ag-value-change-delta-up{color:#43a047;color:var(--ag-value-change-delta-up-color,#43a047)}.ag-theme-alpine-dark .ag-value-change-delta-down{color:#e53935;color:var(--ag-value-change-delta-down-color,#e53935)}.ag-theme-alpine-dark .ag-value-change-value{background-color:transparent;border-radius:1px;padding-left:1px;padding-right:1px;transition:background-color 1s}.ag-theme-alpine-dark .ag-value-change-value-highlight{background-color:rgba(22,160,133,.5);background-color:var(--ag-value-change-value-highlight-background-color,rgba(22,160,133,.5));transition:background-color .1s}.ag-theme-alpine-dark .ag-cell-data-changed{background-color:rgba(22,160,133,.5)!important;background-color:var(--ag-value-change-value-highlight-background-color,rgba(22,160,133,.5))!important}.ag-theme-alpine-dark .ag-cell-data-changed-animation{background-color:transparent}.ag-theme-alpine-dark .ag-cell-highlight{background-color:#2196f3!important;background-color:var(--ag-range-selection-highlight-color,var(--ag-range-selection-border-color,#2196f3))!important}.ag-theme-alpine-dark .ag-row{height:42px;background-color:#181d1f;background-color:var(--ag-background-color,#181d1f);color:#fff;color:var(--ag-data-color,var(--ag-foreground-color,#fff));border-width:1px;border-color:rgba(88,86,82,.5);border-color:var(--ag-row-border-color,var(--ag-secondary-border-color,rgba(88,86,82,.5)))}.ag-theme-alpine-dark .ag-row:not(.ag-row-first){border-top-style:solid}.ag-theme-alpine-dark .ag-row.ag-row-last{border-bottom-style:solid}.ag-theme-alpine-dark .ag-row-highlight-above:after,.ag-theme-alpine-dark .ag-row-highlight-below:after{content:"";position:absolute;width:calc(100% - 1px);height:1px;background-color:#2196f3;background-color:var(--ag-range-selection-border-color,#2196f3);left:1px}.ag-theme-alpine-dark .ag-row-highlight-above:after{top:-1px}.ag-theme-alpine-dark .ag-row-highlight-above.ag-row-first:after{top:0}.ag-theme-alpine-dark .ag-row-highlight-below:after{bottom:0}.ag-theme-alpine-dark .ag-row-odd{background-color:#222628;background-color:var(--ag-odd-row-background-color,#222628)}.ag-theme-alpine-dark .ag-horizontal-left-spacer:not(.ag-scroller-corner){border-right:1px solid #68686e;border-right-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-horizontal-right-spacer:not(.ag-scroller-corner){border-left:1px solid #68686e;border-left-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-row-hover{background-color:rgba(33,150,243,.1);background-color:var(--ag-row-hover-color,rgba(33,150,243,.1))}.ag-theme-alpine-dark .ag-ltr .ag-right-aligned-cell{text-align:right}.ag-theme-alpine-dark .ag-rtl .ag-right-aligned-cell{text-align:left}.ag-theme-alpine-dark .ag-ltr .ag-right-aligned-cell .ag-cell-value{margin-left:auto}.ag-theme-alpine-dark .ag-rtl .ag-right-aligned-cell .ag-cell-value{margin-right:auto}.ag-theme-alpine-dark .ag-cell{border:1px solid transparent;line-height:40px}.ag-theme-alpine-dark .ag-cell,.ag-theme-alpine-dark .ag-row>.ag-cell-wrapper{padding-left:17px;padding-right:17px}.ag-theme-alpine-dark .ag-row-dragging{cursor:move;opacity:.5}.ag-theme-alpine-dark .ag-cell-inline-editing{height:42px}.ag-theme-alpine-dark .ag-cell-inline-editing,.ag-theme-alpine-dark .ag-popup-editor{border:1px solid #68686e;border-color:var(--ag-border-color,#68686e);background:#181d1f;background:var(--ag-background-color,#181d1f);border-radius:3px;box-shadow:0 1px 20px 1px #000;padding:0;background-color:#222628;background-color:var(--ag-control-panel-background-color,#222628)}.ag-theme-alpine-dark .ag-large-text-input{height:auto;padding:18px}.ag-theme-alpine-dark .ag-details-row{padding:30px;background-color:#181d1f;background-color:var(--ag-background-color,#181d1f)}.ag-theme-alpine-dark .ag-overlay-loading-wrapper{background-color:rgba(24,29,31,.66);background-color:var(--ag-modal-overlay-background-color,rgba(24,29,31,.66))}.ag-theme-alpine-dark .ag-overlay-loading-center{border:1px solid #68686e;border-color:var(--ag-border-color,#68686e);background:#181d1f;background:var(--ag-background-color,#181d1f);border-radius:3px;box-shadow:0 1px 20px 1px #000;padding:6px}.ag-theme-alpine-dark .ag-overlay-no-rows-wrapper.ag-layout-auto-height{padding-top:30px}.ag-theme-alpine-dark .ag-loading{padding-left:18px;display:flex;height:100%;align-items:center}.ag-theme-alpine-dark .ag-loading-icon{padding-right:12px}.ag-theme-alpine-dark .ag-icon-loading{-webkit-animation-name:spin;animation-name:spin;-webkit-animation-duration:1s;animation-duration:1s;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite;-webkit-animation-timing-function:linear;animation-timing-function:linear}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}.ag-theme-alpine-dark .ag-floating-top{border-bottom:1px solid #68686e;border-bottom-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-floating-bottom{border-top:1px solid #68686e;border-top-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-ltr .ag-cell{border-right:solid transparent}.ag-theme-alpine-dark .ag-rtl .ag-cell{border-left:solid transparent}.ag-theme-alpine-dark .ag-ltr .ag-cell{border-right-width:1px}.ag-theme-alpine-dark .ag-rtl .ag-cell{border-left-width:1px}.ag-theme-alpine-dark .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell){border-left:1px solid #68686e;border-left-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell){border-right:1px solid #68686e;border-right-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-row-selected{background-color:rgba(33,150,243,.3);background-color:var(--ag-selected-row-background-color,rgba(33,150,243,.3))}.ag-theme-alpine-dark .ag-cell-range-selected:not(.ag-cell-focus){background-color:rgba(33,150,243,.2);background-color:var(--ag-range-selection-background-color,rgba(33,150,243,.2))}.ag-theme-alpine-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart{background-color:rgba(0,88,255,.1);background-color:var(--ag-range-selection-chart-background-color,rgba(0,88,255,.1))}.ag-theme-alpine-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category{background-color:rgba(0,255,132,.1);background-color:var(--ag-range-selection-chart-category-background-color,rgba(0,255,132,.1))}.ag-theme-alpine-dark .ag-cell-range-selected-1:not(.ag-cell-focus){background-color:rgba(33,150,243,.2);background-color:var(--ag-range-selection-background-color-1,var(--ag-range-selection-background-color,rgba(33,150,243,.2)))}.ag-theme-alpine-dark .ag-cell-range-selected-2:not(.ag-cell-focus){background-color:rgba(33,150,243,.36);background-color:var(--ag-range-selection-background-color-2,rgba(33,150,243,.36))}.ag-theme-alpine-dark .ag-cell-range-selected-3:not(.ag-cell-focus){background-color:rgba(33,150,243,.488);background-color:var(--ag-range-selection-background-color-3,rgba(33,150,243,.488))}.ag-theme-alpine-dark .ag-cell-range-selected-4:not(.ag-cell-focus){background-color:rgba(33,150,243,.5904);background-color:var(--ag-range-selection-background-color-4,rgba(33,150,243,.5904))}.ag-theme-alpine-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top{border-top-color:#2196f3;border-top-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right{border-right-color:#2196f3;border-right-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom{border-bottom-color:#2196f3;border-bottom-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left{border-left-color:#2196f3;border-left-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine-dark .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-alpine-dark .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-alpine-dark .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),.ag-theme-alpine-dark .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-alpine-dark .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-alpine-dark .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected){border:1px solid #2196f3;border-color:var(--ag-range-selection-border-color,#2196f3);outline:initial}.ag-theme-alpine-dark .ag-cell.ag-selection-fill-top,.ag-theme-alpine-dark .ag-cell.ag-selection-fill-top.ag-cell-range-selected{border-top:1px dashed #2196f3;border-top-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine-dark .ag-ltr .ag-cell.ag-selection-fill-right,.ag-theme-alpine-dark .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-right:1px dashed #2196f3;border-right-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine-dark .ag-rtl .ag-cell.ag-selection-fill-right,.ag-theme-alpine-dark .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-left:1px dashed #2196f3;border-left-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine-dark .ag-cell.ag-selection-fill-bottom,.ag-theme-alpine-dark .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected{border-bottom:1px dashed #2196f3;border-bottom-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine-dark .ag-ltr .ag-cell.ag-selection-fill-left,.ag-theme-alpine-dark .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-left:1px dashed #2196f3;border-left-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine-dark .ag-rtl .ag-cell.ag-selection-fill-left,.ag-theme-alpine-dark .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-right:1px dashed #2196f3;border-right-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine-dark .ag-fill-handle,.ag-theme-alpine-dark .ag-range-handle{position:absolute;width:6px;height:6px;bottom:-1px;background-color:#2196f3;background-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine-dark .ag-ltr .ag-fill-handle,.ag-theme-alpine-dark .ag-ltr .ag-range-handle{right:-1px}.ag-theme-alpine-dark .ag-rtl .ag-fill-handle,.ag-theme-alpine-dark .ag-rtl .ag-range-handle{left:-1px}.ag-theme-alpine-dark .ag-fill-handle{cursor:cell}.ag-theme-alpine-dark .ag-range-handle{cursor:nwse-resize}.ag-theme-alpine-dark .ag-cell-inline-editing{border-color:rgba(33,150,243,.4)!important;border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))!important}.ag-theme-alpine-dark .ag-menu{border:1px solid #68686e;border-color:var(--ag-border-color,#68686e);background:#181d1f;background:var(--ag-background-color,#181d1f);border-radius:3px;box-shadow:0 1px 20px 1px #000;padding:0}.ag-theme-alpine-dark .ag-menu-list{cursor:default;width:100%;padding-top:6px;padding-bottom:6px}.ag-theme-alpine-dark .ag-menu-option-part{padding-top:8px;padding-bottom:8px;line-height:16px}.ag-theme-alpine-dark .ag-menu-option-active{background-color:rgba(33,150,243,.1);background-color:var(--ag-row-hover-color,rgba(33,150,243,.1))}.ag-theme-alpine-dark .ag-menu-option-disabled{opacity:.5}.ag-theme-alpine-dark .ag-menu-option-text{margin-left:6px}.ag-theme-alpine-dark .ag-menu-option-icon{padding-left:12px;padding-right:6px;min-width:28px}.ag-theme-alpine-dark .ag-menu-option-shortcut{padding-left:12px}.ag-theme-alpine-dark .ag-menu-separator{height:12px}.ag-theme-alpine-dark .ag-menu-separator-cell:after{content:"";display:block;border-top:1px solid #68686e;border-top-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-menu-option-popup-pointer{width:28px;text-align:center}.ag-theme-alpine-dark .ag-tabs-header{min-width:220px;width:100%;display:flex}.ag-theme-alpine-dark .ag-tab{border-bottom:2px solid transparent;display:flex;flex:none;align-items:center;justify-content:center;cursor:pointer;flex:1 1 auto;transition:border-bottom .3s}.ag-theme-alpine-dark .ag-keyboard-focus .ag-tab:focus{outline:none}.ag-theme-alpine-dark .ag-keyboard-focus .ag-tab:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine-dark .ag-tab-selected{border-bottom-color:#2196f3;border-bottom-color:var(--ag-selected-tab-underline-color,var(--ag-alpine-active-color,#2196f3))}.ag-theme-alpine-dark .ag-menu-header{color:#fff;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#fff))}.ag-theme-alpine-dark .ag-filter-condition-operator{height:17px}.ag-theme-alpine-dark .ag-ltr .ag-filter-condition-operator-or{margin-left:12px}.ag-theme-alpine-dark .ag-rtl .ag-filter-condition-operator-or{margin-right:12px}.ag-theme-alpine-dark .ag-set-filter-select-all{padding-top:12px}.ag-theme-alpine-dark .ag-set-filter-list{height:180px}.ag-theme-alpine-dark .ag-set-filter-filter{margin-top:12px;margin-left:12px;margin-right:12px}.ag-theme-alpine-dark .ag-filter-to{margin-top:9px}.ag-theme-alpine-dark .ag-mini-filter{margin:12px 12px 0}.ag-theme-alpine-dark .ag-set-filter-item{margin:0 12px}.ag-theme-alpine-dark .ag-ltr .ag-set-filter-item-value{margin-left:12px}.ag-theme-alpine-dark .ag-rtl .ag-set-filter-item-value{margin-right:12px}.ag-theme-alpine-dark .ag-filter-header-container{padding-bottom:12px;border-bottom:1px solid rgba(88,86,82,.5);border-bottom-color:var(--ag-secondary-border-color,rgba(88,86,82,.5))}.ag-theme-alpine-dark .ag-filter-apply-panel{padding:12px;border-top:1px solid rgba(88,86,82,.5);border-top-color:var(--ag-secondary-border-color,rgba(88,86,82,.5))}.ag-theme-alpine-dark .ag-filter-apply-panel-button{line-height:1.5}.ag-theme-alpine-dark .ag-ltr .ag-filter-apply-panel-button{margin-left:12px}.ag-theme-alpine-dark .ag-rtl .ag-filter-apply-panel-button{margin-right:12px}.ag-theme-alpine-dark .ag-simple-filter-body-wrapper{padding:12px 12px 3px}.ag-theme-alpine-dark .ag-simple-filter-body-wrapper>*{margin-bottom:9px}.ag-theme-alpine-dark .ag-filter-no-matches{margin:12px}.ag-theme-alpine-dark .ag-side-bar{position:relative}.ag-theme-alpine-dark .ag-tool-panel-wrapper{background-color:#222628;background-color:var(--ag-control-panel-background-color,#222628)}.ag-theme-alpine-dark .ag-side-buttons{padding-top:24px;width:20px;position:relative;color:#fff;color:var(--ag-foreground-color,#fff);overflow:hidden}.ag-theme-alpine-dark button.ag-side-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;background:transparent;padding:12px 0;width:100%;margin:0;min-height:108px;background-position-y:center;background-position-x:center;background-repeat:no-repeat;border:none}.ag-theme-alpine-dark button.ag-side-button-button:focus{box-shadow:none}.ag-theme-alpine-dark .ag-keyboard-focus .ag-side-button-button:focus{outline:none}.ag-theme-alpine-dark .ag-keyboard-focus .ag-side-button-button:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine-dark .ag-side-button-icon-wrapper{margin-bottom:3px}.ag-theme-alpine-dark .ag-ltr .ag-side-bar-left,.ag-theme-alpine-dark .ag-rtl .ag-side-bar-right{border-right:1px solid #68686e;border-right-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,.ag-theme-alpine-dark .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper{border-left:1px solid #68686e;border-left-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-ltr .ag-side-bar-left .ag-side-button-button,.ag-theme-alpine-dark .ag-rtl .ag-side-bar-right .ag-side-button-button{border-right:2px solid transparent;transition:border-right .3s}.ag-theme-alpine-dark .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,.ag-theme-alpine-dark .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button{border-right-color:#2196f3;border-right-color:var(--ag-selected-tab-underline-color,var(--ag-alpine-active-color,#2196f3))}.ag-theme-alpine-dark .ag-ltr .ag-side-bar-right,.ag-theme-alpine-dark .ag-rtl .ag-side-bar-left{border-left:1px solid #68686e;border-left-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper,.ag-theme-alpine-dark .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper{border-right:1px solid #68686e;border-right-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-ltr .ag-side-bar-right .ag-side-button-button,.ag-theme-alpine-dark .ag-rtl .ag-side-bar-left .ag-side-button-button{border-left:2px solid transparent;transition:border-left .3s}.ag-theme-alpine-dark .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button,.ag-theme-alpine-dark .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button{border-left-color:#2196f3;border-left-color:var(--ag-selected-tab-underline-color,var(--ag-alpine-active-color,#2196f3))}.ag-theme-alpine-dark .ag-filter-toolpanel-header{height:36px}.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-header,.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-search{padding-left:6px}.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-header,.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-search{padding-right:6px}.ag-theme-alpine-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus{outline:none}.ag-theme-alpine-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine-dark .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{font-family:agGridAlpine;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;content:"\\f112";position:absolute}.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-left:6px}.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-right:6px}.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-0-header{height:48px}.ag-theme-alpine-dark .ag-filter-toolpanel-group-item{margin-top:3px;margin-bottom:3px}.ag-theme-alpine-dark .ag-filter-toolpanel-search{height:48px}.ag-theme-alpine-dark .ag-filter-toolpanel-search-input{flex-grow:1;height:24px}.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-search-input{margin-right:6px}.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-search-input{margin-left:6px}.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-0{border-top:1px solid rgba(88,86,82,.5);border-top-color:var(--ag-secondary-border-color,rgba(88,86,82,.5))}.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-expand,.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-title-bar-icon{margin-right:6px}.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-expand,.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-title-bar-icon{margin-left:6px}.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-left:22px}.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-right:22px}.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-left:38px}.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-right:38px}.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-left:54px}.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-right:54px}.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-left:70px}.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-right:70px}.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-left:86px}.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-right:86px}.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-left:102px}.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-right:102px}.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-left:118px}.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-right:118px}.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-left:134px}.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-right:134px}.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-left:150px}.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-right:150px}.ag-theme-alpine-dark .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-left:166px}.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-right:166px}.ag-theme-alpine-dark .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header{padding-left:6px}.ag-theme-alpine-dark .ag-filter-toolpanel-instance-filter{border-top:1px solid #68686e;border-top-color:var(--ag-border-color,#68686e);border-bottom:1px solid #68686e;border-bottom-color:var(--ag-border-color,#68686e);padding-top:6px}.ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-instance-header-icon{margin-left:6px}.ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-instance-header-icon{margin-right:6px}.ag-theme-alpine-dark .ag-pivot-mode-panel{height:48px;display:flex}.ag-theme-alpine-dark .ag-pivot-mode-select{display:flex;align-items:center}.ag-theme-alpine-dark .ag-ltr .ag-pivot-mode-select{margin-left:12px}.ag-theme-alpine-dark .ag-rtl .ag-pivot-mode-select{margin-right:12px}.ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-header:focus{outline:none}.ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine-dark .ag-column-select-header{height:48px;align-items:center;padding:0 12px}.ag-theme-alpine-dark .ag-column-panel-column-select,.ag-theme-alpine-dark .ag-column-select-header{border-bottom:1px solid rgba(88,86,82,.5);border-bottom-color:var(--ag-secondary-border-color,rgba(88,86,82,.5))}.ag-theme-alpine-dark .ag-column-panel-column-select{border-top:1px solid rgba(88,86,82,.5);border-top-color:var(--ag-secondary-border-color,rgba(88,86,82,.5))}.ag-theme-alpine-dark .ag-column-group-icons,.ag-theme-alpine-dark .ag-column-select-header-icon{color:#fff;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#fff))}.ag-theme-alpine-dark .ag-header{background-color:#222628;background-color:var(--ag-header-background-color,#222628);border-bottom:1px solid #68686e;border-bottom-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-header-row{color:#fff;color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,var(--ag-foreground-color,#fff)))}.ag-theme-alpine-dark .ag-pinned-right-header{border-left:1px solid #68686e;border-left-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-pinned-left-header{border-right:1px solid #68686e;border-right-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-header-row{height:48px}.ag-theme-alpine-dark .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-left:6px}.ag-theme-alpine-dark .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon,.ag-theme-alpine-dark .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-right:6px}.ag-theme-alpine-dark .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon{margin-left:6px}.ag-theme-alpine-dark .ag-header-cell,.ag-theme-alpine-dark .ag-header-group-cell{padding-left:18px;padding-right:18px}.ag-theme-alpine-dark .ag-header-cell.ag-header-cell-moving,.ag-theme-alpine-dark .ag-header-group-cell.ag-header-cell-moving{background-color:#181d1f;background-color:var(--ag-header-cell-moving-background-color,var(--ag-background-color,#181d1f))}.ag-theme-alpine-dark .ag-keyboard-focus .ag-header-cell:focus{outline:none}.ag-theme-alpine-dark .ag-keyboard-focus .ag-header-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine-dark .ag-keyboard-focus .ag-header-group-cell:focus{outline:none}.ag-theme-alpine-dark .ag-keyboard-focus .ag-header-group-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine-dark .ag-header-icon{color:#fff;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#fff))}.ag-theme-alpine-dark .ag-header-expand-icon{cursor:pointer}.ag-theme-alpine-dark .ag-ltr .ag-header-expand-icon{padding-left:4px}.ag-theme-alpine-dark .ag-rtl .ag-header-expand-icon{padding-right:4px}.ag-theme-alpine-dark .ag-header-row:not(:first-child) .ag-header-cell,.ag-theme-alpine-dark .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group{border-top:1px solid #68686e;border-top-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-header-cell-resize{display:flex;align-items:center}.ag-theme-alpine-dark .ag-header-cell-resize:after{content:"";position:absolute;z-index:1;display:block;left:calc(50% - 1px);width:2px;height:30%;top:35%;background-color:rgba(104,104,110,.5);background-color:var(--ag-header-column-resize-handle-color,rgba(104,104,110,.5))}.ag-theme-alpine-dark .ag-pinned-right-header .ag-header-cell-resize:after{left:calc(50% - 2px)}.ag-theme-alpine-dark .ag-ltr .ag-header-select-all{margin-right:18px}.ag-theme-alpine-dark .ag-ltr .ag-floating-filter-button,.ag-theme-alpine-dark .ag-rtl .ag-header-select-all{margin-left:18px}.ag-theme-alpine-dark .ag-rtl .ag-floating-filter-button{margin-right:18px}.ag-theme-alpine-dark .ag-floating-filter-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;height:16px;padding:0;width:16px}.ag-theme-alpine-dark .ag-filter-loading{background-color:#222628;background-color:var(--ag-control-panel-background-color,#222628);height:100%;padding:12px;position:absolute;width:100%;z-index:1}.ag-theme-alpine-dark .ag-paging-panel{border-top:1px solid #68686e;border-top-color:var(--ag-border-color,#68686e);color:#fff;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#fff));height:48px}.ag-theme-alpine-dark .ag-paging-panel>*{margin:0 18px}.ag-theme-alpine-dark .ag-paging-button{cursor:pointer;opacity:0;top:0;right:0;bottom:0;left:0;padding:0;width:16px}.ag-theme-alpine-dark .ag-disabled .ag-paging-button{cursor:default}.ag-theme-alpine-dark .ag-paging-button-wrapper.ag-disabled{color:hsla(0,0%,100%,.5);color:var(--ag-disabled-foreground-color,hsla(0,0%,100%,.5));cursor:default}.ag-theme-alpine-dark .ag-paging-button-wrapper,.ag-theme-alpine-dark .ag-paging-description{margin:0 6px}.ag-theme-alpine-dark .ag-status-bar{border-top:1px solid #68686e;border-top-color:var(--ag-border-color,#68686e);color:hsla(0,0%,100%,.5);color:var(--ag-disabled-foreground-color,hsla(0,0%,100%,.5));padding-right:24px;padding-left:24px;line-height:1.5}.ag-theme-alpine-dark .ag-status-name-value-value{color:#fff;color:var(--ag-foreground-color,#fff)}.ag-theme-alpine-dark .ag-status-bar-center{text-align:center}.ag-theme-alpine-dark .ag-status-name-value{margin-left:6px;margin-right:6px;padding-top:12px;padding-bottom:12px}.ag-theme-alpine-dark .ag-column-drop-cell{background:hsla(0,0%,100%,.07);background:var(--ag-chip-background-color,hsla(0,0%,100%,.07));border-radius:24px;height:24px;padding:0 3px}.ag-theme-alpine-dark .ag-column-drop-cell-text{margin:0 6px}.ag-theme-alpine-dark .ag-column-drop-cell-button{min-width:24px;margin:0 3px;color:#fff;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#fff))}.ag-theme-alpine-dark .ag-column-drop-cell-drag-handle{margin-left:12px}.ag-theme-alpine-dark .ag-column-drop-cell-ghost{opacity:.5}.ag-theme-alpine-dark .ag-column-drop-horizontal{background-color:#222628;background-color:var(--ag-control-panel-background-color,#222628);color:#fff;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#fff));height:42px;border-bottom:1px solid #68686e;border-bottom-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-ltr .ag-column-drop-horizontal{padding-left:18px}.ag-theme-alpine-dark .ag-rtl .ag-column-drop-horizontal{padding-right:18px}.ag-theme-alpine-dark .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child){border-right:1px solid #68686e;border-right-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child){border-left:1px solid #68686e;border-left-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-column-drop-horizontal-cell-separator{margin:0 6px;color:#fff;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#fff))}.ag-theme-alpine-dark .ag-column-drop-horizontal-empty-message{color:hsla(0,0%,100%,.5);color:var(--ag-disabled-foreground-color,hsla(0,0%,100%,.5))}.ag-theme-alpine-dark .ag-ltr .ag-column-drop-horizontal-icon{margin-right:18px}.ag-theme-alpine-dark .ag-rtl .ag-column-drop-horizontal-icon{margin-left:18px}.ag-theme-alpine-dark .ag-column-drop-vertical-list{padding-bottom:6px;padding-right:6px;padding-left:6px}.ag-theme-alpine-dark .ag-column-drop-vertical-cell{margin-top:6px}.ag-theme-alpine-dark .ag-column-drop-vertical{min-height:50px;max-height:150px;border-bottom:1px solid rgba(88,86,82,.5);border-bottom-color:var(--ag-secondary-border-color,rgba(88,86,82,.5))}.ag-theme-alpine-dark .ag-column-drop-vertical.ag-last-column-drop{border-bottom:none}.ag-theme-alpine-dark .ag-column-drop-vertical-icon{margin-left:6px;margin-right:6px}.ag-theme-alpine-dark .ag-column-drop-vertical-list{position:relative}.ag-theme-alpine-dark .ag-column-drop-vertical-empty-message{position:absolute;top:0;bottom:0;left:0;right:0;overflow:hidden;color:hsla(0,0%,100%,.5);color:var(--ag-disabled-foreground-color,hsla(0,0%,100%,.5));margin-top:6px}.ag-theme-alpine-dark .ag-select-agg-func-popup{border:1px solid #68686e;border-color:var(--ag-border-color,#68686e);border-radius:3px;box-shadow:0 1px 20px 1px #000;background:#181d1f;background:var(--ag-background-color,#181d1f);height:105px;padding:0}.ag-theme-alpine-dark .ag-select-agg-func-virtual-list-item{cursor:default;line-height:30px;padding-left:12px}.ag-theme-alpine-dark .ag-select-agg-func-virtual-list-item:hover{background-color:rgba(33,150,243,.3);background-color:var(--ag-selected-row-background-color,rgba(33,150,243,.3))}.ag-theme-alpine-dark .ag-chart-menu{border-radius:3px;background:#181d1f;background:var(--ag-background-color,#181d1f)}.ag-theme-alpine-dark .ag-chart-menu-icon{opacity:.5;line-height:24px;font-size:24px;width:24px;height:24px;margin:2px 0;cursor:pointer;border-radius:3px;color:#fff;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#fff))}.ag-theme-alpine-dark .ag-chart-menu-icon:hover{opacity:1}.ag-theme-alpine-dark .ag-chart-mini-thumbnail{border:1px solid rgba(88,86,82,.5);border-color:var(--ag-secondary-border-color,rgba(88,86,82,.5));border-radius:5px;margin:5px}.ag-theme-alpine-dark .ag-chart-mini-thumbnail:nth-last-child(3),.ag-theme-alpine-dark .ag-chart-mini-thumbnail:nth-last-child(3)~.ag-chart-mini-thumbnail{margin-left:auto;margin-right:auto}.ag-theme-alpine-dark .ag-ltr .ag-chart-mini-thumbnail:first-child{margin-left:0}.ag-theme-alpine-dark .ag-ltr .ag-chart-mini-thumbnail:last-child,.ag-theme-alpine-dark .ag-rtl .ag-chart-mini-thumbnail:first-child{margin-right:0}.ag-theme-alpine-dark .ag-rtl .ag-chart-mini-thumbnail:last-child{margin-left:0}.ag-theme-alpine-dark .ag-chart-mini-thumbnail.ag-selected{border-color:#2196f3;border-color:var(--ag-minichart-selected-chart-color,var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3)))}.ag-theme-alpine-dark .ag-chart-settings-card-item{background:#fff;background:var(--ag-foreground-color,#fff);width:8px;height:8px;border-radius:4px}.ag-theme-alpine-dark .ag-chart-settings-card-item.ag-selected{background-color:#2196f3;background-color:var(--ag-minichart-selected-page-color,var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3)))}.ag-theme-alpine-dark .ag-chart-data-column-drag-handle{margin-left:6px}.ag-theme-alpine-dark .ag-charts-data-group-title-bar,.ag-theme-alpine-dark .ag-charts-format-top-level-group-title-bar,.ag-theme-alpine-dark .ag-charts-settings-group-title-bar{border-top:1px solid rgba(88,86,82,.5);border-top-color:var(--ag-secondary-border-color,rgba(88,86,82,.5))}.ag-theme-alpine-dark .ag-charts-settings-group-container{padding:6px}.ag-theme-alpine-dark .ag-charts-data-group-container{padding:12px 12px 3px}.ag-theme-alpine-dark .ag-charts-data-group-container>*{margin-bottom:9px}.ag-theme-alpine-dark .ag-charts-format-top-level-group-container{margin-left:12px;padding:6px}.ag-theme-alpine-dark .ag-charts-format-top-level-group-item{margin:6px 0}.ag-theme-alpine-dark .ag-charts-format-sub-level-group-container{padding:12px 12px 3px}.ag-theme-alpine-dark .ag-charts-format-sub-level-group-container>*{margin-bottom:9px}.ag-theme-alpine-dark .ag-charts-group-container.ag-group-container-horizontal{padding:6px}.ag-theme-alpine-dark .ag-chart-data-section,.ag-theme-alpine-dark .ag-chart-format-section{display:flex;margin:0}.ag-theme-alpine-dark .ag-chart-menu-panel{background-color:#222628;background-color:var(--ag-control-panel-background-color,#222628)}.ag-theme-alpine-dark .ag-ltr .ag-chart-menu-panel{border-left:1px solid #68686e;border-left-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-rtl .ag-chart-menu-panel{border-right:1px solid #68686e;border-right-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-date-time-list-page-title{flex-grow:1;text-align:center}.ag-theme-alpine-dark .ag-date-time-list-page-column-label,.ag-theme-alpine-dark .ag-date-time-list-page-entry{text-align:center}.ag-theme-alpine-dark .ag-checkbox-input-wrapper{font-family:agGridAlpine;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:16px;height:16px;background-color:#181d1f;background-color:var(--ag-checkbox-background-color,var(--ag-background-color,#181d1f));border-radius:3px;display:inline-block;vertical-align:middle;flex:none}.ag-theme-alpine-dark .ag-checkbox-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-alpine-dark .ag-checkbox-input-wrapper:active,.ag-theme-alpine-dark .ag-checkbox-input-wrapper:focus-within{outline:none;box-shadow:0 0 2px .5px hsla(0,0%,100%,.5),0 0 4px 3px rgba(33,150,243,.6)}.ag-theme-alpine-dark .ag-checkbox-input-wrapper.ag-disabled{opacity:.5}.ag-theme-alpine-dark .ag-checkbox-input-wrapper:after{content:"\\f108";color:#999;color:var(--ag-checkbox-unchecked-color,#999);position:absolute;top:0;left:0;pointer-events:none}.ag-theme-alpine-dark .ag-checkbox-input-wrapper.ag-checked:after{content:"\\f106";color:#2196f3;color:var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-alpine-dark .ag-checkbox-input-wrapper.ag-indeterminate:after{content:"\\f107";color:#999;color:var(--ag-checkbox-indeterminate-color,var(--ag-checkbox-unchecked-color,#999));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-alpine-dark .ag-toggle-button-input-wrapper{box-sizing:border-box;width:28px;height:18px;background-color:#999;background-color:var(--ag-toggle-button-off-background-color,var(--ag-checkbox-unchecked-color,#999));border-radius:9px;position:relative;flex:none;border:1px solid #999;border-color:var(--ag-toggle-button-off-border-color,var(--ag-checkbox-unchecked-color,#999))}.ag-theme-alpine-dark .ag-toggle-button-input-wrapper input{opacity:0;height:100%;width:100%}.ag-theme-alpine-dark .ag-toggle-button-input-wrapper:focus-within{outline:none;box-shadow:0 0 2px .5px hsla(0,0%,100%,.5),0 0 4px 3px rgba(33,150,243,.6)}.ag-theme-alpine-dark .ag-toggle-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-alpine-dark .ag-toggle-button-input-wrapper.ag-checked{background-color:#2196f3;background-color:var(--ag-toggle-button-on-background-color,var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3)));border-color:#2196f3;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3)))}.ag-theme-alpine-dark .ag-toggle-button-input-wrapper:before{content:" ";position:absolute;top:-1px;left:-1px;display:block;box-sizing:border-box;height:18px;width:18px;background-color:#181d1f;background-color:var(--ag-toggle-button-switch-background-color,var(--ag-background-color,#181d1f));border-radius:9px;transition:left .1s;border:1px solid #999;border-color:var(--ag-toggle-button-switch-border-color,var(--ag-toggle-button-off-border-color,var(--ag-checkbox-unchecked-color,#999)))}.ag-theme-alpine-dark .ag-toggle-button-input-wrapper.ag-checked:before{left:calc(100% - 18px);border-color:#2196f3;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3)))}.ag-theme-alpine-dark .ag-radio-button-input-wrapper{font-family:agGridAlpine;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:16px;height:16px;background-color:#181d1f;background-color:var(--ag-checkbox-background-color,var(--ag-background-color,#181d1f));border-radius:3px;display:inline-block;vertical-align:middle;flex:none;border-radius:16px}.ag-theme-alpine-dark .ag-radio-button-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-alpine-dark .ag-radio-button-input-wrapper:active,.ag-theme-alpine-dark .ag-radio-button-input-wrapper:focus-within{outline:none;box-shadow:0 0 2px .5px hsla(0,0%,100%,.5),0 0 4px 3px rgba(33,150,243,.6)}.ag-theme-alpine-dark .ag-radio-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-alpine-dark .ag-radio-button-input-wrapper:after{content:"\\f124";color:#999;color:var(--ag-checkbox-unchecked-color,#999);position:absolute;top:0;left:0;pointer-events:none}.ag-theme-alpine-dark .ag-radio-button-input-wrapper.ag-checked:after{content:"\\f125";color:#2196f3;color:var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-alpine-dark input[class^=ag-][type=range]{-webkit-appearance:none;width:100%;height:100%;background:none;overflow:visible}.ag-theme-alpine-dark input[class^=ag-][type=range]::-webkit-slider-runnable-track{margin:0;padding:0;width:100%;height:3px;background-color:#68686e;background-color:var(--ag-border-color,#68686e);border-radius:3px}.ag-theme-alpine-dark input[class^=ag-][type=range]::-moz-range-track{margin:0;padding:0;width:100%;height:3px;background-color:#68686e;background-color:var(--ag-border-color,#68686e);border-radius:3px}.ag-theme-alpine-dark input[class^=ag-][type=range]::-ms-track{margin:0;padding:0;width:100%;height:3px;background-color:#68686e;background-color:var(--ag-border-color,#68686e);border-radius:3px;color:transparent;width:calc(100% - 2px)}.ag-theme-alpine-dark input[class^=ag-][type=range]::-webkit-slider-thumb{margin:0;padding:0;-webkit-appearance:none;width:16px;height:16px;background-color:#181d1f;background-color:var(--ag-background-color,#181d1f);border:1px solid #999;border-color:var(--ag-checkbox-unchecked-color,#999);border-radius:16px;-webkit-transform:translateY(-6.5px);transform:translateY(-6.5px)}.ag-theme-alpine-dark input[class^=ag-][type=range]::-ms-thumb{margin:0;padding:0;-webkit-appearance:none;width:16px;height:16px;background-color:#181d1f;background-color:var(--ag-background-color,#181d1f);border:1px solid #999;border-color:var(--ag-checkbox-unchecked-color,#999);border-radius:16px}.ag-theme-alpine-dark input[class^=ag-][type=range]::-moz-ag-range-thumb{margin:0;padding:0;-webkit-appearance:none;width:16px;height:16px;background-color:#181d1f;background-color:var(--ag-background-color,#181d1f);border:1px solid #999;border-color:var(--ag-checkbox-unchecked-color,#999);border-radius:16px}.ag-theme-alpine-dark input[class^=ag-][type=range]:focus{outline:none}.ag-theme-alpine-dark input[class^=ag-][type=range]:focus::-webkit-slider-thumb{box-shadow:0 0 2px .5px hsla(0,0%,100%,.5),0 0 4px 3px rgba(33,150,243,.6);border-color:#2196f3;border-color:var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3))}.ag-theme-alpine-dark input[class^=ag-][type=range]:focus::-ms-thumb{box-shadow:0 0 2px .5px hsla(0,0%,100%,.5),0 0 4px 3px rgba(33,150,243,.6);border-color:#2196f3;border-color:var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3))}.ag-theme-alpine-dark input[class^=ag-][type=range]:focus::-moz-ag-range-thumb{box-shadow:0 0 2px .5px hsla(0,0%,100%,.5),0 0 4px 3px rgba(33,150,243,.6);border-color:#2196f3;border-color:var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3))}.ag-theme-alpine-dark input[class^=ag-][type=range]:active::-webkit-slider-runnable-track{background-color:rgba(33,150,243,.4);background-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine-dark input[class^=ag-][type=range]:active::-moz-ag-range-track{background-color:rgba(33,150,243,.4);background-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine-dark input[class^=ag-][type=range]:active::-ms-track{background-color:rgba(33,150,243,.4);background-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine-dark input[class^=ag-][type=range]:disabled{opacity:.5}.ag-theme-alpine-dark .ag-filter-toolpanel-header,.ag-theme-alpine-dark .ag-filter-toolpanel-search,.ag-theme-alpine-dark .ag-header-row,.ag-theme-alpine-dark .ag-panel-title-bar-title,.ag-theme-alpine-dark .ag-status-bar{font-weight:700;color:#fff;color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,var(--ag-foreground-color,#fff)))}.ag-theme-alpine-dark .ag-ltr .ag-pinned-right-header .ag-header-row:after,.ag-theme-alpine-dark .ag-rtl .ag-pinned-left-header .ag-header-row:before{content:"";position:absolute;height:calc(100% - 20px);top:10px;width:1px;background-color:#68686e;background-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-ltr .ag-pinned-right-header .ag-header-row:after{right:0}.ag-theme-alpine-dark .ag-rtl .ag-pinned-left-header .ag-header-row:before{left:0}.ag-theme-alpine-dark .ag-row{font-size:14px}.ag-theme-alpine-dark input[class^=ag-]:not([type]),.ag-theme-alpine-dark input[class^=ag-][type=date],.ag-theme-alpine-dark input[class^=ag-][type=datetime-local],.ag-theme-alpine-dark input[class^=ag-][type=number],.ag-theme-alpine-dark input[class^=ag-][type=tel],.ag-theme-alpine-dark input[class^=ag-][type=text],.ag-theme-alpine-dark textarea[class^=ag-]{min-height:24px;border-radius:3px}.ag-theme-alpine-dark .ag-ltr input[class^=ag-]:not([type]),.ag-theme-alpine-dark .ag-ltr input[class^=ag-][type=date],.ag-theme-alpine-dark .ag-ltr input[class^=ag-][type=datetime-local],.ag-theme-alpine-dark .ag-ltr input[class^=ag-][type=number],.ag-theme-alpine-dark .ag-ltr input[class^=ag-][type=tel],.ag-theme-alpine-dark .ag-ltr input[class^=ag-][type=text],.ag-theme-alpine-dark .ag-ltr textarea[class^=ag-]{padding-left:6px}.ag-theme-alpine-dark .ag-rtl input[class^=ag-]:not([type]),.ag-theme-alpine-dark .ag-rtl input[class^=ag-][type=date],.ag-theme-alpine-dark .ag-rtl input[class^=ag-][type=datetime-local],.ag-theme-alpine-dark .ag-rtl input[class^=ag-][type=number],.ag-theme-alpine-dark .ag-rtl input[class^=ag-][type=tel],.ag-theme-alpine-dark .ag-rtl input[class^=ag-][type=text],.ag-theme-alpine-dark .ag-rtl textarea[class^=ag-]{padding-right:6px}.ag-theme-alpine-dark .ag-tab{padding:9px;transition:color .4s}.ag-theme-alpine-dark .ag-tab-selected{color:#2196f3;color:var(--ag-alpine-active-color,#2196f3)}.ag-theme-alpine-dark .ag-menu,.ag-theme-alpine-dark .ag-menu-header{background-color:#222628;background-color:var(--ag-control-panel-background-color,#222628)}.ag-theme-alpine-dark .ag-menu-header{padding-top:1px}.ag-theme-alpine-dark .ag-tabs-header{border-bottom:1px solid #68686e;border-bottom-color:var(--ag-border-color,#68686e)}.ag-theme-alpine-dark .ag-charts-data-group-title-bar,.ag-theme-alpine-dark .ag-charts-format-top-level-group-title-bar,.ag-theme-alpine-dark .ag-charts-settings-group-title-bar{padding:6px 12px;line-height:20px}.ag-theme-alpine-dark .ag-chart-mini-thumbnail{background-color:#181d1f;background-color:var(--ag-background-color,#181d1f)}.ag-theme-alpine-dark .ag-chart-settings-nav-bar{border-top:1px solid rgba(88,86,82,.5);border-top-color:var(--ag-secondary-border-color,rgba(88,86,82,.5))}.ag-theme-alpine-dark .ag-ltr .ag-group-title-bar-icon{margin-right:6px}.ag-theme-alpine-dark .ag-rtl .ag-group-title-bar-icon{margin-left:6px}.ag-theme-alpine-dark .ag-charts-format-top-level-group-toolbar{margin-top:6px}.ag-theme-alpine-dark .ag-ltr .ag-charts-format-top-level-group-toolbar{padding-left:20px}.ag-theme-alpine-dark .ag-rtl .ag-charts-format-top-level-group-toolbar{padding-right:20px}.ag-theme-alpine-dark .ag-charts-format-sub-level-group{border-left:1px dashed #68686e;border-left-color:var(--ag-border-color,#68686e);padding-left:6px;margin-bottom:12px}.ag-theme-alpine-dark .ag-charts-format-sub-level-group-title-bar{padding-top:0;padding-bottom:0;background:none;font-weight:700}.ag-theme-alpine-dark .ag-charts-format-sub-level-group-container{padding-bottom:0}.ag-theme-alpine-dark .ag-charts-format-sub-level-group-item:last-child{margin-bottom:0}.ag-theme-alpine-dark .ag-dnd-ghost{font-size:12px;font-weight:700}.ag-theme-alpine-dark .ag-side-buttons{width:30px}.ag-theme-alpine-dark .ag-standard-button{-moz-appearance:none;appearance:none;-webkit-appearance:none;border-radius:3px;border:1px solid #2196f3;border-color:var(--ag-alpine-active-color,#2196f3);color:#2196f3;color:var(--ag-alpine-active-color,#2196f3);background-color:#181d1f;background-color:var(--ag-background-color,#181d1f);font-weight:600;padding:6px 12px}.ag-theme-alpine-dark .ag-standard-button:hover{border-color:#2196f3;border-color:var(--ag-alpine-active-color,#2196f3);background-color:rgba(33,150,243,.1);background-color:var(--ag-row-hover-color,rgba(33,150,243,.1))}.ag-theme-alpine-dark .ag-standard-button:active{border-color:#2196f3;border-color:var(--ag-alpine-active-color,#2196f3);background-color:#2196f3;background-color:var(--ag-alpine-active-color,#2196f3);color:#181d1f;color:var(--ag-background-color,#181d1f)}.ag-theme-alpine-dark .ag-standard-button:disabled{color:hsla(0,0%,100%,.5);color:var(--ag-disabled-foreground-color,hsla(0,0%,100%,.5));background-color:#282c2f;background-color:var(--ag-input-disabled-background-color,#282c2f);border-color:rgba(104,104,110,.3);border-color:var(--ag-input-disabled-border-color,rgba(104,104,110,.3))}.ag-theme-alpine-dark .ag-menu-header{min-width:240px}.ag-theme-alpine-dark .ag-column-drop-vertical{min-height:75px;max-height:175px}.ag-theme-alpine-dark .ag-tool-panel-wrapper{width:250px}.ag-theme-alpine-dark .ag-column-drop-vertical-title-bar{padding:12px 12px 0}.ag-theme-alpine-dark .ag-column-drop-vertical-empty-message{display:flex;align-items:center;border:1px dashed #68686e;border-color:var(--ag-border-color,#68686e);margin:12px;padding:12px}.ag-theme-alpine-dark .ag-column-drop-empty-message{color:#fff;color:var(--ag-foreground-color,#fff);opacity:.75}.ag-theme-alpine-dark .ag-status-bar{font-weight:400}.ag-theme-alpine-dark .ag-paging-number,.ag-theme-alpine-dark .ag-paging-row-summary-panel-number,.ag-theme-alpine-dark .ag-status-name-value-value{font-weight:700}.ag-theme-alpine-dark .ag-column-drop-cell-button{opacity:.5}.ag-theme-alpine-dark .ag-column-drop-cell-button:hover{opacity:.75}.ag-theme-alpine-dark .ag-chart-menu-icon:hover,.ag-theme-alpine-dark .ag-chart-settings-next:hover,.ag-theme-alpine-dark .ag-chart-settings-prev:hover,.ag-theme-alpine-dark .ag-column-group-icons:hover,.ag-theme-alpine-dark .ag-column-select-header-icon:hover,.ag-theme-alpine-dark .ag-filter-toolpanel-expand:hover,.ag-theme-alpine-dark .ag-floating-filter-button-button:hover,.ag-theme-alpine-dark .ag-group-contracted .ag-icon:hover,.ag-theme-alpine-dark .ag-group-expanded .ag-icon:hover,.ag-theme-alpine-dark .ag-group-title-bar-icon:hover,.ag-theme-alpine-dark .ag-header-cell-menu-button:hover,.ag-theme-alpine-dark .ag-header-expand-icon:hover,.ag-theme-alpine-dark .ag-panel-title-bar-button:hover,.ag-theme-alpine-dark .ag-side-button-button:hover,.ag-theme-alpine-dark .ag-tab:hover{color:#2196f3;color:var(--ag-alpine-active-color,#2196f3)}.ag-theme-alpine-dark .ag-chart-settings-card-item.ag-not-selected:hover{opacity:.35}.ag-theme-alpine-dark .ag-ltr .ag-panel-title-bar-button{margin-left:12px;margin-right:6px}.ag-theme-alpine-dark .ag-rtl .ag-panel-title-bar-button{margin-right:12px;margin-left:6px}.ag-theme-alpine-dark .ag-filter-toolpanel-group-container{padding-left:6px}.ag-theme-alpine-dark .ag-filter-toolpanel-instance-filter{background-color:#222628;background-color:var(--ag-control-panel-background-color,#222628);border:none;border-left:#68686e;border-left:1px dashed var(--ag-border-color,#68686e);margin-left:13px;padding-left:8px;margin-right:12px}.ag-theme-alpine-dark .ag-set-filter-list{padding-top:3px;padding-bottom:3px}.ag-theme-alpine-dark .ag-overlay-no-rows-wrapper.ag-layout-auto-height{padding-top:60px}.ag-theme-alpine-dark .ag-date-time-list-page-entry-is-current{background-color:#2196f3;background-color:var(--ag-alpine-active-color,#2196f3)}',""]),e.exports=t},function(e,t,o){var r=o(27),a=o(158);"string"==typeof(a=a.__esModule?a.default:a)&&(a=[[e.i,a,""]]);var n={insert:"head",singleton:!1};r(a,n);e.exports=a.locals||{}},function(e,t,o){(t=o(28)(!1)).push([e.i,'.ag-theme-alpine{-webkit-font-smoothing:antialiased;color:#181d1f;color:var(--ag-foreground-color,#181d1f);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:13px;line-height:normal}@font-face{font-family:agGridAlpine;src:url("data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABNkAAsAAAAAIqAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlMAAAReYc5joU9TLzIAAANcAAAAQAAAAFZWUVJ5Y21hcAAAA5wAAAHqAAAFgHCsDfxnbHlmAAAFiAAACesAABCUC9Ir6mhlYWQAAA90AAAANAAAADZ2zsSBaGhlYQAAD6gAAAAeAAAAJAfSBC5obXR4AAAPyAAAABcAAAEou4D/+2xvY2EAAA/gAAAAbwAAAJbPsst2bWF4cAAAEFAAAAAfAAAAIAFgAHNuYW1lAAAQcAAAATUAAAJG5xgJvXBvc3QAABGoAAABuQAAApPSPvKNeJx9k81SE1EQhc9kQgwJBkREjREU//GPYX4yJiGQMAFisXDhwoUbXGhpUa54Atc+gOUD+BQ+geXSlQ/gA1g+gN/tTAyyIFOZubf79Onuc/vKk1TRmroqZDv7z1U7PDh6r7qKGv2c//jaO3z75kDl8Q5f0b5lef4f1bSiFzrSN0/ea+9zoeQX/K6/73/wP/k/5IO6pkegq1rnCRXxDhQrUVOpCiphC1k/UQu0z7tt1nktaso8mQa6QM6QmIExruqpbmkOnr7x9LQJKuZxnD3euzy3NXsKItUd+BOq2cDqWBvUeU7T2qHGHnV0iG7hncO3ReaAmD6+PrX5hiqajnt6SeS89eYikxwX8w+1bfvAdkuoMEa14W/C7/gek3Vsb5IpIuIh7Amobq7hKv8q3hhMQGzHNHPRSyAjKoy1zMp1FtHZjG7C/kyvdJ+47TymZyqOer5H9RN73/hS8hy3duDaBfuAGiZWdyJ3yRVoiL/CSWV6p4/6oq/6rp/6pd/gF8kSWQebcG+dqsw0+p1EZ3jb/6yu0zOcxUnU/4gKfTdNmxDfIFfQZZvB57SJWQdYY8NX4XT4jGpS9Jpi8gLLG2Etsd9gH4Ku5dPY4jlrOg+YATcBdbRY5+2YRvOWsr9MtFuN6rpoarXguWSn5TR1N2nWdm7m3SnX0fkK34DOEtNnD+9VLI5pYmlYVErVjmMNf0q1k2yuqgZVRcxA2SZraLcgI9N1+hhVEumG3YChTdUKFST5jVzQeau+k5/UguFCi/JQIshvcmyauUnuU5ubit2/LKNqzAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMb0GmMDCC5ADUogpqeJy11IdSWkEYxfE/RdNM79X0jgJiQIogIMhjmO6Y4pju5CnzJt8LxJzlnjyAmcnO/Fh2udy9O3fPB8wABXkqRcgXyZHab83mpvMFjk7ni/zSeI7D5PW9xBY77EV5f1+zJTbZZjdy09HfltPVc1zjPs80WqNClxZ9aoyp0tHsKm0GNKizzhJNlhkyYYUeIzb0/7xWLzLLIa16RM9xTPc7zglOcorTnOEs5zjPBS5yictc4apWu84N5rnJLW5zh7vc0/oPeMgjHvNE+ynp9wUWKesBZzlYWzvg9alVuq1+bVztaLftQaOujTaXh5OV3mjjH272H9pc+ij89GhCepuZtNtNq8hz68oLa8lL68srq8lrG8sbq8pb68iWpROybavyztry3gbywRry0eqyY+uya0vyyZry2Zbliw3lq6W9f7MV+W49+WEj2TO9wMhlUlYinyH1hUzKVhQzKV8xk9GZJkynmzCdc8J04glLGQxTCghLby9MySBMGSFMaSFMuSFMCSJMWSJMqSJM+SJMSSNMmSNM6SNMOSRMiSRM2SRMKSVMeSVMySVMGSVMaSZMuSZMCSdMWSdMqSdM+SdMlYAw1QTCVB0IU50gTBWDMNUOwlRFCEt1MyxlJmz6/AsZUr+YIfXlDOU/rrOgigAAeJzFF21sU9f1nntjvzgJSRx/vJgQg/3ivNSxwxL7+dkx2JAEEmhIqWpYCqMhMCbWdFppM7EBbsd+dEVV1apS6A/yY9O2oFVaQEOb+sFKtZaRqh/qVLQf/fixdkxkXbNRodIZ3mXnXttpApnW/Zr93rnn3nt8zrnnni8TIPihcyxKqgmBgEdVPAEjYOoBOsdrCgW4yu9HeJxFs4VCJlMoCHLbzes3r7NP2afEhr+qIx7SRIhLURXdtJkChhAwVaAuXcBPnn028uqrNIMg8iwfHR4eXidXInKBPrFgMnzv8DD/YiE9qiWEsh7WQypRjmo6Y07VhJPds7nLaX4GrqZnuQ2uz6ZhCx5F0k6wCeImq/CnQcWu2N2qV/V2mQkzEddb9VaXoqOSqBnqBlcPjI6YqZQ5MvpRGRnpPn68e2JCQjaxaEsi1uvlXYTk/yOTle6tFjFF3l3MqekxjyZG+G0+fzafh4P5PFtmvY0XeJAfK+t5mV0mLuITtx2sBY/T7YdYoCsDhjPeAQ4wVVDZD2587o/58WFVcrTm+N+GZmBqiF3G+aLNG5+Dd+gCTN21mL+6NH+GznUb9yetizRyO2fr4oMLeTLJ0xlwhpbiizxZ1S18i4vfvZVv0Xbs++yb6L+VpJEQByiqA5i5Euzi6jxub1fCENdGP+Ej3Xu5BZmZmQunq6t9dd7ODZ3eOh/8Hn6axg3+KqydmcksW+ZvavUFOzuDvtAKv2BfIWVEMa6K91NHSCjgDNg0Z8ylOdPg1Jwsaj1FD/DN8q5eyhdoLM+PiZsq3lbJ7+lp5GFDHSm6DxyEFL+AYcii/AKfKcVj8Tw/ZOfwND7SLC1v92CUBFSJuL1oqATaqVVzoQ70NK/ROnNwNc8NoTK8gVADbsAb7OXOoPUC7b+nU7NeEHu0X+u09tH+Ugw+zZ4WvuYANJfiAB3dBa7Cvb18Cnb08pN8qhd2IKCJRVPYgSTkljgGXUEb6Aqw9TKQYYsIZLjObbMY1IvPHkKBioq2moEk5qGzkIRUduHZn8A4aCIdZK3ga6qJWJcfVoJSCyIp2ZUOuhrMDKg499NYl6nbtWAHGHFTVxNI6VbUhNlBg9C4NjKwfWT75HgzY+6+aDRi7hr7+uT4iooKz9BotM+9fPTowN2b0mGjfVM4UJlsuWdT2D0w1OLbc/RJ+nP87R19h7dWVZu7tI5IIgbQd2hrddWafY7me7rW7zVbuleG+9uN9t1Jd3gg1zKQ3omLC/SvxdwRRf3RpYUyUtdQhpZOQlHh1WDDTfR23ETvpxX9R/f4UPhTR0eXo2r8/IrxyV9J5ZslsqICfhzeFA5v2iYA+My961FkEV7aerhPaFtVGidRp4GwBKWYG0PbK2QZaqR4FKduBGyqxzRMNlZ4qUBPWdPvZ9+jc4XJszBcyGbffy8z+T4p50J6jc7hvTnkbeiKKnISvfbKK+lCgRu5HBjnzqVlbakhNcU4QfpynIjc0URWEo3opJ2sJsTUjJi64A39lznWqbPZ7EsSWm/9p0khX/xkS2OmNKI6lfPnv1UnAlgdQ/i6UI6Br46vWFNwDODIxoSPWm9LViiCnuIziMFv+Aw9IOXyzVmUleXHUIVMJrOEzVzo61iA0WZXpMngYC5Hz0iT8RpyWxxhscYw1ANsfTF0YIsII+qf7eZn+Jnu2XKMTNDzWJ8aSQQlxDOQBkMr+pHEOkDF1BzSPBg6tBbaARHpaz8LrtGmplK7k8ndqakpbU3wORjiv4aDEgdtfhOuamntruTIQyPJu7S0kptCuFGs7D4wkpQ2vXmTzco8fotNA5gTRXG0ic4BlbCJBqQ0F/mSLh8cPHbNvEbbzWsmJpQ3IW4NCrgL5/QT3OFvDg5CvBUxfMy1g4OD4zjic+2PEC/XkOfYc6iFU+bhmAfQKTEZagbogPWSHxsG2sP5h1g07+W8B+gHWTj4oVxjLn7sA7k2n2++9Fe0vzH/LWb08gspvOd8piz/HfZOUf682HlFsvNC0X/KmgilimL/VNZkviZMF/OiSG8qwPfSnKchxaI4dkOy5E+XWL3sz0SmVbG0KaL5oJeuXImcPx+RkPrl8JiE82cr9jEBzKZLdzIQF2isy6tCB0CwVQc/eNyCcKm+hvdEI4Nbdqb2t/NosAW2IALvBlvE4lJtDh/ZuWUwEm0J8mj7fv73liC8274/JdfK+j2Adc6LfqOjfhrmQrui3VLkAl1etz3YGk+AMHDAiLHGU8vWbV237JQsaQMC8g+cPl/Q5wPDej4HP8mxsVBHRwir3z5JcyLY2ag14mM10BMiKRTv8Ag7TIKlKpMoflWzVQxZAMWOhkZTKfY6NLkuegm0eitaBgQFliDVG/MiqsPdz2D2tjmau1ebeyvranwNqhv8nnUb9gNQ5vZE1eN/icAll6Omsn4y0dblhOWVKoVKOlFZVV1X21B/ER55xlFdXVfTVu2oHl3ub2xyNdTyj1Zsq9lnt/mM9q+p1ciBPlVf76r1TtYy1sT/anfrjfGG4xUVoFQ2XBTHqZJnmmbTGImrSBtZTzaSO0mO7CSj5Ft4Rj9VG1gtVSpCHVSnrgw1W2wBpxcrqZmwuVVRmAzpVorucWO90lQ58UrDhNxqzMDaGzPMMKBFYpioPTG9A/SQXVM8MbMVcw1ztm0IA6oU3tDGP+YffzmDZjhkXfjHnBanDqsSaFxbBS9WRbblIo7wxrZxR2TbtkjVupau5X6wXocjhwHy2fidSYBDWfjdIUGP5kiFHz2X7H+U/XJJ/s1ydsN63e5A8rm3nPUoDA5DnWTueLCtv506IjmUAzbF5Q37NyYfeXmz8ei/EqGR7JEjQaRmAEfy8MhtcSkzMp1O8wuQSnP6WVp0a92cLOxn3eSOcoTVC7dZJcxWLyKMBQWUYdYldkrB9fj4gd6+vt4D41Bfxh7/zq4dhmkaO3a9V0bYZbHB/7mY+MaRRUQSKcWT0KUG4z0htJEFoZj49f9Btb6He3sfflyAvq+mJZ0r0SMofGWFb6t9iopFV6TABf8BZT85241/BovnG2Rjsq7KTkbkQPyXG5AdSTEXWh/T09ZWTNYZmJUL/GSWzllvl2UxekLcmssBl6AO6ugJrH5Dpfs+wZjYc9DiKmP8Cr+yeA97V2xtsWTKXy/Ns0hQ2vsFc8l+X/TYJtwPX/Ra5/mfe6BJYH+AlT0luijtFSd04WnOyoLTc9+8faJ0ulgfdOzS6WeyLECKTmOdEC65INePYUXykC6RS0XpB4/Xrqj4pwodAOM5Jnpmz5c9ghFPmCoSqviYQF8rNgFmeG08m9y95xu5Suv5H3UPlDuFns7tKx8aGTgZt/rpa9gOaJEN1Wub9qxJjSSncvDA0cZvr0vJbkHr3GzbnrsPKemLhPwbDwYCEQB4nGNgZGBgAOLsD0FR8fw2Xxm4mV8ABaI4H+9rgNH/f///zfyW+S1QJQcDE5BkAACRug+HeJxjYGRgYH7BwAAi///+/5v5LQMjAyrwAgCe2QcHAAB4nGNgYGBgfgHC/39D6KGH6QEAIHUuCwB4nGNgAAIphiCGDIZFDHcYvjGqMQYwVjGuYTzH+IhJhMmMyYcpgekAMxezBrMDcxfzIeZbzJ9YTFiKWGawbGK5wfKKlY01jHUK6z+2JWw72P6xR7Dnsfexz2Ffxb6D/Rj7LfYX7H84vEiHANyaI6IAeJxjYGRgYPBiSGfgYQABJiDmAkIGhv9gPgMAGzsB1AB4nHWRPU7DQBCFnxMniBghJCREx1Y0SM5PQZEuFHGfIgWdE68dR7bXWm8ipeMYnIBjUHIETsEheDFTREjZ1a6/+fbNNAZwgy94OC4PV+19XB1csPrjLulW2Cc/CPcQ4Em4T/8sPKB9EQ7YWXKC51/S3ONNuINrvAt36T+EffKncA93+Bbu0/8ID7D0fOEAj95rnEU2T2ZFnVd6obNdEdtTdcpLbZvcVGocjk51pCttY6cTtTqoZp9NnEtVak2p5qZyuiiMqq3Z6rULN87V0+EwFR+uTYkYGSJY5EgwQ4GaVEFjwZNhRxPz9VzqnF/yWDSsDGuFMUKMzqYjnqrtiOH4TdixwoF3gz17JrQOKeuUGcO/ojBvJx/TBbehqdu3Lc2aPsSm7aoxxZA7/ZcPmeKkXwK+aWkAAAB4nG2S6W7bMBCE/cWSI9tpk7ptet/3obbpfaf3kT4FQ9EyEYkUSMp28vRl4yBAgO4fzgwWs7MLdpY6ixp0/l9bLNElIaXHMhl9BgxZ4RjHWWWNE4w4ySlOs84ZznKO81zgIpe4zBWuco3r3OAmt7jNHe5yj/s84CE5j3jMEzZ4yjOe84KXvOI1b3jLO97zgY9s8onPfOEr3/jOD37yi99s8aczFGXpVCmCtqYnnLMz3xVe9qQwUlXZ4sk3UjkRLqzJiZI723ae7wNVrB8K2hQqKFdrI4IaHcqtOehckbayLm90JG45krY2fiCtCU7IoIpE2mY3lc56nxTKy0zNGxE9i77aVbmvhJ90I+qNdRXHpGPtfEhKp5u0dLZtktgQkkqNQ6/SJs5brqwotCmzWsx1rfdUUivTZjHfghk1D4mxRg2NDbmoKjtTRdpEF9VttEkbPbUha5yaatv6NRfNbL7dhmBNbsfj1aOCSZ0uJyHxYqoGvo52eWFn5gD+izVcwP22bIFj6hDPMQpOqaP36+9LtlEma81iHwQlDkVAYzHM8EgqJuywzTx+g4KaloZdxuwx7XT+AvL3sQsAAAA=") format("woff");font-weight:400;font-style:normal}.ag-theme-alpine .ag-icon{font-family:agGridAlpine;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ag-theme-alpine .ag-icon-aggregation:before{content:"\\f101"}.ag-theme-alpine .ag-icon-arrows:before{content:"\\f102"}.ag-theme-alpine .ag-icon-asc:before{content:"\\f103"}.ag-theme-alpine .ag-icon-cancel:before{content:"\\f104"}.ag-theme-alpine .ag-icon-chart:before{content:"\\f105"}.ag-theme-alpine .ag-icon-color-picker:before{content:"\\f109"}.ag-theme-alpine .ag-icon-columns:before{content:"\\f10a"}.ag-theme-alpine .ag-icon-contracted:before{content:"\\f10b"}.ag-theme-alpine .ag-icon-copy:before{content:"\\f10c"}.ag-theme-alpine .ag-icon-cross:before{content:"\\f10d"}.ag-theme-alpine .ag-icon-desc:before{content:"\\f10e"}.ag-theme-alpine .ag-icon-expanded:before{content:"\\f10f"}.ag-theme-alpine .ag-icon-eye-slash:before{content:"\\f110"}.ag-theme-alpine .ag-icon-eye:before{content:"\\f111"}.ag-theme-alpine .ag-icon-filter:before{content:"\\f112"}.ag-theme-alpine .ag-icon-first:before{content:"\\f113"}.ag-theme-alpine .ag-icon-grip:before{content:"\\f114"}.ag-theme-alpine .ag-icon-group:before{content:"\\f115"}.ag-theme-alpine .ag-icon-last:before{content:"\\f116"}.ag-theme-alpine .ag-icon-left:before{content:"\\f117"}.ag-theme-alpine .ag-icon-linked:before{content:"\\f118"}.ag-theme-alpine .ag-icon-loading:before{content:"\\f119"}.ag-theme-alpine .ag-icon-maximize:before{content:"\\f11a"}.ag-theme-alpine .ag-icon-menu:before{content:"\\f11b"}.ag-theme-alpine .ag-icon-minimize:before{content:"\\f11c"}.ag-theme-alpine .ag-icon-next:before{content:"\\f11d"}.ag-theme-alpine .ag-icon-none:before{content:"\\f11e"}.ag-theme-alpine .ag-icon-not-allowed:before{content:"\\f11f"}.ag-theme-alpine .ag-icon-paste:before{content:"\\f120"}.ag-theme-alpine .ag-icon-pin:before{content:"\\f121"}.ag-theme-alpine .ag-icon-pivot:before{content:"\\f122"}.ag-theme-alpine .ag-icon-previous:before{content:"\\f123"}.ag-theme-alpine .ag-icon-right:before{content:"\\f126"}.ag-theme-alpine .ag-icon-save:before{content:"\\f127"}.ag-theme-alpine .ag-icon-small-down:before{content:"\\f128"}.ag-theme-alpine .ag-icon-small-left:before{content:"\\f129"}.ag-theme-alpine .ag-icon-small-right:before{content:"\\f12a"}.ag-theme-alpine .ag-icon-small-up:before{content:"\\f12b"}.ag-theme-alpine .ag-icon-tick:before{content:"\\f12c"}.ag-theme-alpine .ag-icon-tree-closed:before{content:"\\f12d"}.ag-theme-alpine .ag-icon-tree-indeterminate:before{content:"\\f12e"}.ag-theme-alpine .ag-icon-tree-open:before{content:"\\f12f"}.ag-theme-alpine .ag-icon-unlinked:before{content:"\\f130"}.ag-theme-alpine .ag-icon-row-drag:before{content:"\\f114"}.ag-theme-alpine .ag-right-arrow:before{content:"\\f117";content:"\\f126"}.ag-theme-alpine .ag-root-wrapper{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-alpine [class^=ag-],.ag-theme-alpine [class^=ag-]:after,.ag-theme-alpine [class^=ag-]:before,.ag-theme-alpine [class^=ag-]:focus{box-sizing:border-box;outline:none}.ag-theme-alpine [class^=ag-]::-ms-clear{display:none}.ag-theme-alpine .ag-checkbox .ag-input-wrapper,.ag-theme-alpine .ag-radio-button .ag-input-wrapper{overflow:visible}.ag-theme-alpine .ag-range-field .ag-input-wrapper{height:100%}.ag-theme-alpine .ag-toggle-button{flex:none;width:unset;min-width:unset}.ag-theme-alpine .ag-ltr .ag-label-align-right .ag-label{margin-left:6px}.ag-theme-alpine .ag-rtl .ag-label-align-right .ag-label{margin-right:6px}.ag-theme-alpine input[class^=ag-]{margin:0}.ag-theme-alpine input[class^=ag-],.ag-theme-alpine select[class^=ag-],.ag-theme-alpine textarea[class^=ag-]{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-alpine input[class^=ag-]:not([type]),.ag-theme-alpine input[class^=ag-][type=date],.ag-theme-alpine input[class^=ag-][type=datetime-local],.ag-theme-alpine input[class^=ag-][type=number],.ag-theme-alpine input[class^=ag-][type=tel],.ag-theme-alpine input[class^=ag-][type=text],.ag-theme-alpine textarea[class^=ag-]{font-size:inherit;line-height:inherit;color:inherit;border:1px solid #babfc7;border-color:var(--ag-input-border-color,var(--ag-border-color,#babfc7))}.ag-theme-alpine input[class^=ag-]:not([type]):disabled,.ag-theme-alpine input[class^=ag-][type=date]:disabled,.ag-theme-alpine input[class^=ag-][type=datetime-local]:disabled,.ag-theme-alpine input[class^=ag-][type=number]:disabled,.ag-theme-alpine input[class^=ag-][type=tel]:disabled,.ag-theme-alpine input[class^=ag-][type=text]:disabled,.ag-theme-alpine textarea[class^=ag-]:disabled{color:rgba(24,29,31,.5);color:var(--ag-disabled-foreground-color,rgba(24,29,31,.5));background-color:#f1f2f4;background-color:var(--ag-input-disabled-background-color,#f1f2f4);border-color:rgba(186,191,199,.3);border-color:var(--ag-input-disabled-border-color,rgba(186,191,199,.3))}.ag-theme-alpine input[class^=ag-]:not([type]):focus,.ag-theme-alpine input[class^=ag-][type=date]:focus,.ag-theme-alpine input[class^=ag-][type=datetime-local]:focus,.ag-theme-alpine input[class^=ag-][type=number]:focus,.ag-theme-alpine input[class^=ag-][type=tel]:focus,.ag-theme-alpine input[class^=ag-][type=text]:focus,.ag-theme-alpine textarea[class^=ag-]:focus{outline:none;box-shadow:0 0 2px .1rem rgba(33,150,243,.4);border-color:rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine input[class^=ag-][type=number]{-moz-appearance:textfield}.ag-theme-alpine input[class^=ag-][type=number]::-webkit-inner-spin-button,.ag-theme-alpine input[class^=ag-][type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.ag-theme-alpine input[class^=ag-][type=range]{padding:0}.ag-theme-alpine button[class^=ag-]:focus,.ag-theme-alpine input[class^=ag-][type=button]:focus{box-shadow:0 0 2px .1rem rgba(33,150,243,.4)}.ag-theme-alpine .ag-drag-handle{color:#181d1f;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#181d1f))}.ag-theme-alpine .ag-list-item,.ag-theme-alpine .ag-virtual-list-item{height:30px}.ag-theme-alpine .ag-keyboard-focus .ag-virtual-list-item:focus{outline:none}.ag-theme-alpine .ag-keyboard-focus .ag-virtual-list-item:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine .ag-select-list{background-color:#fff;background-color:var(--ag-background-color,#fff);overflow-y:auto;overflow-x:hidden}.ag-theme-alpine .ag-list-item{display:flex;align-items:center}.ag-theme-alpine .ag-list-item.ag-active-item{background-color:rgba(33,150,243,.1);background-color:var(--ag-row-hover-color,rgba(33,150,243,.1))}.ag-theme-alpine .ag-select-list-item{padding-left:4px;padding-right:4px;cursor:default;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.ag-theme-alpine .ag-select-list-item span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.ag-theme-alpine .ag-select .ag-picker-field-wrapper{background-color:#fff;background-color:var(--ag-background-color,#fff);min-height:30px;cursor:default}.ag-theme-alpine .ag-select:not(.ag-cell-editor){height:30px}.ag-theme-alpine .ag-select .ag-picker-field-display{margin:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ag-theme-alpine .ag-select .ag-picker-field-icon{display:flex;align-items:center}.ag-theme-alpine .ag-select.ag-disabled{opacity:.5}.ag-theme-alpine .ag-rich-select{background-color:#f8f8f8;background-color:var(--ag-control-panel-background-color,#f8f8f8)}.ag-theme-alpine .ag-rich-select-list{width:100%;min-width:200px;height:273px}.ag-theme-alpine .ag-rich-select-value{padding:0 6px 0 18px;height:42px;border-bottom:1px solid #dde2eb;border-bottom-color:var(--ag-secondary-border-color,#dde2eb)}.ag-theme-alpine .ag-rich-select-virtual-list-item{cursor:default;height:30px}.ag-theme-alpine .ag-rich-select-virtual-list-item:hover{background-color:rgba(33,150,243,.1);background-color:var(--ag-row-hover-color,rgba(33,150,243,.1))}.ag-theme-alpine .ag-rich-select-row{padding-left:18px}.ag-theme-alpine .ag-rich-select-row-selected{background-color:rgba(33,150,243,.3);background-color:var(--ag-selected-row-background-color,rgba(33,150,243,.3))}.ag-theme-alpine .ag-group-contracted,.ag-theme-alpine .ag-group-expanded,.ag-theme-alpine .ag-row-drag,.ag-theme-alpine .ag-selection-checkbox{color:#181d1f;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#181d1f))}.ag-theme-alpine .ag-ltr .ag-group-contracted,.ag-theme-alpine .ag-ltr .ag-group-expanded,.ag-theme-alpine .ag-ltr .ag-row-drag,.ag-theme-alpine .ag-ltr .ag-selection-checkbox{margin-right:12px}.ag-theme-alpine .ag-rtl .ag-group-contracted,.ag-theme-alpine .ag-rtl .ag-group-expanded,.ag-theme-alpine .ag-rtl .ag-row-drag,.ag-theme-alpine .ag-rtl .ag-selection-checkbox{margin-left:12px}.ag-theme-alpine .ag-cell-wrapper>:not(.ag-cell-value):not(.ag-group-value){height:40px;display:flex;align-items:center;flex:none}.ag-theme-alpine .ag-group-contracted,.ag-theme-alpine .ag-group-expanded{cursor:pointer}.ag-theme-alpine .ag-group-title-bar-icon{cursor:pointer;flex:none;color:#181d1f;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#181d1f))}.ag-theme-alpine .ag-ltr .ag-group-child-count{margin-left:2px}.ag-theme-alpine .ag-rtl .ag-group-child-count{margin-right:2px}.ag-theme-alpine .ag-group-title-bar{background-color:#fff;background-color:var(--ag-subheader-background-color,#fff);padding:6px}.ag-theme-alpine .ag-group-toolbar{padding:6px}.ag-theme-alpine .ag-disabled-group-container,.ag-theme-alpine .ag-disabled-group-title-bar{opacity:.5}.ag-theme-alpine .group-item{margin:3px 0}.ag-theme-alpine .ag-label{white-space:nowrap}.ag-theme-alpine .ag-ltr .ag-label{margin-right:6px}.ag-theme-alpine .ag-rtl .ag-label{margin-left:6px}.ag-theme-alpine .ag-label-align-top .ag-label{margin-bottom:3px}.ag-theme-alpine .ag-ltr .ag-angle-select-field,.ag-theme-alpine .ag-ltr .ag-slider-field{margin-right:12px}.ag-theme-alpine .ag-rtl .ag-angle-select-field,.ag-theme-alpine .ag-rtl .ag-slider-field{margin-left:12px}.ag-theme-alpine .ag-angle-select-parent-circle{width:24px;height:24px;border-radius:12px;border:1px solid #babfc7;border-color:var(--ag-border-color,#babfc7);background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-alpine .ag-angle-select-child-circle{top:4px;left:12px;width:6px;height:6px;margin-left:-3px;margin-top:-4px;border-radius:3px;background-color:#181d1f;background-color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#181d1f))}.ag-theme-alpine .ag-picker-field-wrapper{border:1px solid #babfc7;border-color:var(--ag-border-color,#babfc7);border-radius:5px}.ag-theme-alpine .ag-picker-field-wrapper:focus{box-shadow:0 0 2px .1rem rgba(33,150,243,.4)}.ag-theme-alpine .ag-picker-field-button{background-color:#fff;background-color:var(--ag-background-color,#fff);color:#181d1f;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#181d1f))}.ag-theme-alpine .ag-dialog.ag-color-dialog{border-radius:5px}.ag-theme-alpine .ag-color-picker .ag-picker-field-display{height:16px}.ag-theme-alpine .ag-color-panel{padding:6px}.ag-theme-alpine .ag-spectrum-color{background-color:red;border-radius:2px}.ag-theme-alpine .ag-spectrum-tools{padding:10px}.ag-theme-alpine .ag-spectrum-sat{background-image:linear-gradient(90deg,#fff,rgba(204,154,129,0))}.ag-theme-alpine .ag-spectrum-val{background-image:linear-gradient(0deg,#000,rgba(204,154,129,0))}.ag-theme-alpine .ag-spectrum-dragger{border-radius:12px;height:12px;width:12px;border:1px solid #fff;background:#000;box-shadow:0 0 2px 0 rgba(0,0,0,.24)}.ag-theme-alpine .ag-spectrum-alpha-background,.ag-theme-alpine .ag-spectrum-hue-background{border-radius:2px}.ag-theme-alpine .ag-spectrum-tool{margin-bottom:10px;height:11px;border-radius:2px}.ag-theme-alpine .ag-spectrum-slider{margin-top:-12px;width:13px;height:13px;border-radius:13px;background-color:#f8f8f8;box-shadow:0 1px 4px 0 rgba(0,0,0,.37)}.ag-theme-alpine .ag-recent-color{margin:0 3px}.ag-theme-alpine .ag-recent-color:first-child{margin-left:0}.ag-theme-alpine .ag-recent-color:last-child{margin-right:0}.ag-theme-alpine.ag-dnd-ghost{background:#fff;background:var(--ag-background-color,#fff);border-radius:3px;box-shadow:0 1px 4px 1px rgba(186,191,199,.4);overflow:hidden;text-overflow:ellipsis;z-index:10;border:1px solid #dde2eb;border:1px solid var(--ag-secondary-border-color,#dde2eb);color:#181d1f;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#181d1f));height:48px!important;line-height:48px;margin:0;padding:0 12px;-webkit-transform:translateY(12px);transform:translateY(12px)}.ag-theme-alpine .ag-dnd-ghost-icon{margin-right:6px;color:#181d1f;color:var(--ag-foreground-color,#181d1f)}.ag-theme-alpine .ag-popup-child:not(.ag-tooltip-custom){box-shadow:0 1px 4px 1px rgba(186,191,199,.4)}.ag-dragging-fill-handle .ag-theme-alpine .ag-dialog,.ag-dragging-range-handle .ag-theme-alpine .ag-dialog{opacity:.7;pointer-events:none}.ag-theme-alpine .ag-dialog{border-radius:3px;border:1px solid #babfc7;border-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-panel{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-alpine .ag-panel-title-bar{background-color:#f8f8f8;background-color:var(--ag-header-background-color,#f8f8f8);color:#181d1f;color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,var(--ag-foreground-color,#181d1f)));height:48px;padding:6px 18px;border-bottom:1px solid #babfc7;border-bottom-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-ltr .ag-panel-title-bar-button{margin-left:6px}.ag-theme-alpine .ag-rtl .ag-panel-title-bar-button{margin-right:6px}.ag-theme-alpine .ag-tooltip{background-color:#f8f8f8;background-color:var(--ag-header-background-color,#f8f8f8);color:#181d1f;color:var(--ag-foreground-color,#181d1f);padding:6px;border:1px solid #babfc7;border-color:var(--ag-border-color,#babfc7);border-radius:3px;transition:opacity 1s}.ag-theme-alpine .ag-tooltip.ag-tooltip-hiding{opacity:0}.ag-theme-alpine .ag-ltr .ag-column-select-indent-1{padding-left:16px}.ag-theme-alpine .ag-rtl .ag-column-select-indent-1{padding-right:16px}.ag-theme-alpine .ag-ltr .ag-column-select-indent-2{padding-left:32px}.ag-theme-alpine .ag-rtl .ag-column-select-indent-2{padding-right:32px}.ag-theme-alpine .ag-ltr .ag-column-select-indent-3{padding-left:48px}.ag-theme-alpine .ag-rtl .ag-column-select-indent-3{padding-right:48px}.ag-theme-alpine .ag-ltr .ag-column-select-indent-4{padding-left:64px}.ag-theme-alpine .ag-rtl .ag-column-select-indent-4{padding-right:64px}.ag-theme-alpine .ag-ltr .ag-column-select-indent-5{padding-left:80px}.ag-theme-alpine .ag-rtl .ag-column-select-indent-5{padding-right:80px}.ag-theme-alpine .ag-ltr .ag-column-select-indent-6{padding-left:96px}.ag-theme-alpine .ag-rtl .ag-column-select-indent-6{padding-right:96px}.ag-theme-alpine .ag-ltr .ag-column-select-indent-7{padding-left:112px}.ag-theme-alpine .ag-rtl .ag-column-select-indent-7{padding-right:112px}.ag-theme-alpine .ag-ltr .ag-column-select-indent-8{padding-left:128px}.ag-theme-alpine .ag-rtl .ag-column-select-indent-8{padding-right:128px}.ag-theme-alpine .ag-ltr .ag-column-select-indent-9{padding-left:144px}.ag-theme-alpine .ag-rtl .ag-column-select-indent-9{padding-right:144px}.ag-theme-alpine .ag-column-select-header-icon{cursor:pointer}.ag-theme-alpine .ag-keyboard-focus .ag-column-select-header-icon:focus{outline:none}.ag-theme-alpine .ag-keyboard-focus .ag-column-select-header-icon:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:0;left:0;display:block;width:100%;height:100%;border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine .ag-ltr .ag-column-group-icons:not(:last-child),.ag-theme-alpine .ag-ltr .ag-column-select-checkbox:not(:last-child),.ag-theme-alpine .ag-ltr .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-alpine .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-alpine .ag-ltr .ag-column-select-column-label:not(:last-child),.ag-theme-alpine .ag-ltr .ag-column-select-header-checkbox:not(:last-child),.ag-theme-alpine .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-alpine .ag-ltr .ag-column-select-header-icon:not(:last-child){margin-right:12px}.ag-theme-alpine .ag-rtl .ag-column-group-icons:not(:last-child),.ag-theme-alpine .ag-rtl .ag-column-select-checkbox:not(:last-child),.ag-theme-alpine .ag-rtl .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-alpine .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-alpine .ag-rtl .ag-column-select-column-label:not(:last-child),.ag-theme-alpine .ag-rtl .ag-column-select-header-checkbox:not(:last-child),.ag-theme-alpine .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-alpine .ag-rtl .ag-column-select-header-icon:not(:last-child){margin-left:12px}.ag-theme-alpine .ag-keyboard-focus .ag-column-select-column-group:focus{outline:none}.ag-theme-alpine .ag-keyboard-focus .ag-column-select-column-group:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-3px;left:-3px;display:block;width:calc(100% - -6px);height:calc(100% - -6px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine .ag-keyboard-focus .ag-column-select-column:focus{outline:none}.ag-theme-alpine .ag-keyboard-focus .ag-column-select-column:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-3px;left:-3px;display:block;width:calc(100% - -6px);height:calc(100% - -6px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine .ag-column-select-column-group:not(:last-child),.ag-theme-alpine .ag-column-select-column:not(:last-child){margin-bottom:9px}.ag-theme-alpine .ag-column-select-column-group-readonly,.ag-theme-alpine .ag-column-select-column-readonly{color:rgba(24,29,31,.5);color:var(--ag-disabled-foreground-color,rgba(24,29,31,.5));pointer-events:none}.ag-theme-alpine .ag-ltr .ag-column-select-add-group-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-column-select-add-group-indent{margin-right:28px}.ag-theme-alpine .ag-column-select-list{padding:12px}.ag-theme-alpine .ag-rtl{text-align:right}.ag-theme-alpine .ag-root-wrapper{border:1px solid #babfc7;border-color:var(--ag-border-color,#babfc7);border-radius:3px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-left:46px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-right:46px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-1{padding-left:28px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-1{padding-right:28px}.ag-theme-alpine .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-left:74px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-right:74px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-2{padding-left:56px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-2{padding-right:56px}.ag-theme-alpine .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-left:102px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-right:102px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-3{padding-left:84px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-3{padding-right:84px}.ag-theme-alpine .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-left:130px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-right:130px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-4{padding-left:112px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-4{padding-right:112px}.ag-theme-alpine .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-left:158px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-right:158px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-5{padding-left:140px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-5{padding-right:140px}.ag-theme-alpine .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-left:186px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-right:186px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-6{padding-left:168px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-6{padding-right:168px}.ag-theme-alpine .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-left:214px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-right:214px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-7{padding-left:196px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-7{padding-right:196px}.ag-theme-alpine .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-left:242px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-right:242px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-8{padding-left:224px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-8{padding-right:224px}.ag-theme-alpine .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-left:270px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-right:270px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-9{padding-left:252px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-9{padding-right:252px}.ag-theme-alpine .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-left:298px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-right:298px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-10{padding-left:280px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-10{padding-right:280px}.ag-theme-alpine .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-left:326px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-right:326px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-11{padding-left:308px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-11{padding-right:308px}.ag-theme-alpine .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-left:354px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-right:354px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-12{padding-left:336px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-12{padding-right:336px}.ag-theme-alpine .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-left:382px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-right:382px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-13{padding-left:364px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-13{padding-right:364px}.ag-theme-alpine .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-left:410px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-right:410px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-14{padding-left:392px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-14{padding-right:392px}.ag-theme-alpine .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-left:438px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-right:438px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-15{padding-left:420px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-15{padding-right:420px}.ag-theme-alpine .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-left:466px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-right:466px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-16{padding-left:448px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-16{padding-right:448px}.ag-theme-alpine .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-left:494px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-right:494px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-17{padding-left:476px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-17{padding-right:476px}.ag-theme-alpine .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-left:522px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-right:522px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-18{padding-left:504px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-18{padding-right:504px}.ag-theme-alpine .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-left:550px}.ag-theme-alpine .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-right:550px}.ag-theme-alpine .ag-ltr .ag-row-group-indent-19{padding-left:532px}.ag-theme-alpine .ag-rtl .ag-row-group-indent-19{padding-right:532px}.ag-theme-alpine .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-alpine .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-alpine .ag-cell{-webkit-font-smoothing:subpixel-antialiased}.ag-theme-alpine .ag-value-change-delta{padding-right:2px}.ag-theme-alpine .ag-value-change-delta-up{color:#43a047;color:var(--ag-value-change-delta-up-color,#43a047)}.ag-theme-alpine .ag-value-change-delta-down{color:#e53935;color:var(--ag-value-change-delta-down-color,#e53935)}.ag-theme-alpine .ag-value-change-value{background-color:transparent;border-radius:1px;padding-left:1px;padding-right:1px;transition:background-color 1s}.ag-theme-alpine .ag-value-change-value-highlight{background-color:rgba(22,160,133,.5);background-color:var(--ag-value-change-value-highlight-background-color,rgba(22,160,133,.5));transition:background-color .1s}.ag-theme-alpine .ag-cell-data-changed{background-color:rgba(22,160,133,.5)!important;background-color:var(--ag-value-change-value-highlight-background-color,rgba(22,160,133,.5))!important}.ag-theme-alpine .ag-cell-data-changed-animation{background-color:transparent}.ag-theme-alpine .ag-cell-highlight{background-color:#2196f3!important;background-color:var(--ag-range-selection-highlight-color,var(--ag-range-selection-border-color,#2196f3))!important}.ag-theme-alpine .ag-row{height:42px;background-color:#fff;background-color:var(--ag-background-color,#fff);color:#181d1f;color:var(--ag-data-color,var(--ag-foreground-color,#181d1f));border-width:1px;border-color:#dde2eb;border-color:var(--ag-row-border-color,var(--ag-secondary-border-color,#dde2eb))}.ag-theme-alpine .ag-row:not(.ag-row-first){border-top-style:solid}.ag-theme-alpine .ag-row.ag-row-last{border-bottom-style:solid}.ag-theme-alpine .ag-row-highlight-above:after,.ag-theme-alpine .ag-row-highlight-below:after{content:"";position:absolute;width:calc(100% - 1px);height:1px;background-color:#2196f3;background-color:var(--ag-range-selection-border-color,#2196f3);left:1px}.ag-theme-alpine .ag-row-highlight-above:after{top:-1px}.ag-theme-alpine .ag-row-highlight-above.ag-row-first:after{top:0}.ag-theme-alpine .ag-row-highlight-below:after{bottom:0}.ag-theme-alpine .ag-row-odd{background-color:#fcfcfc;background-color:var(--ag-odd-row-background-color,#fcfcfc)}.ag-theme-alpine .ag-horizontal-left-spacer:not(.ag-scroller-corner){border-right:1px solid #babfc7;border-right-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-horizontal-right-spacer:not(.ag-scroller-corner){border-left:1px solid #babfc7;border-left-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-row-hover{background-color:rgba(33,150,243,.1);background-color:var(--ag-row-hover-color,rgba(33,150,243,.1))}.ag-theme-alpine .ag-ltr .ag-right-aligned-cell{text-align:right}.ag-theme-alpine .ag-rtl .ag-right-aligned-cell{text-align:left}.ag-theme-alpine .ag-ltr .ag-right-aligned-cell .ag-cell-value{margin-left:auto}.ag-theme-alpine .ag-rtl .ag-right-aligned-cell .ag-cell-value{margin-right:auto}.ag-theme-alpine .ag-cell{border:1px solid transparent;line-height:40px}.ag-theme-alpine .ag-cell,.ag-theme-alpine .ag-row>.ag-cell-wrapper{padding-left:17px;padding-right:17px}.ag-theme-alpine .ag-row-dragging{cursor:move;opacity:.5}.ag-theme-alpine .ag-cell-inline-editing{height:42px}.ag-theme-alpine .ag-cell-inline-editing,.ag-theme-alpine .ag-popup-editor{border:1px solid #babfc7;border-color:var(--ag-border-color,#babfc7);background:#fff;background:var(--ag-background-color,#fff);border-radius:3px;box-shadow:0 1px 4px 1px rgba(186,191,199,.4);padding:0;background-color:#f8f8f8;background-color:var(--ag-control-panel-background-color,#f8f8f8)}.ag-theme-alpine .ag-large-text-input{height:auto;padding:18px}.ag-theme-alpine .ag-details-row{padding:30px;background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-alpine .ag-overlay-loading-wrapper{background-color:hsla(0,0%,100%,.66);background-color:var(--ag-modal-overlay-background-color,hsla(0,0%,100%,.66))}.ag-theme-alpine .ag-overlay-loading-center{border:1px solid #babfc7;border-color:var(--ag-border-color,#babfc7);background:#fff;background:var(--ag-background-color,#fff);border-radius:3px;box-shadow:0 1px 4px 1px rgba(186,191,199,.4);padding:6px}.ag-theme-alpine .ag-overlay-no-rows-wrapper.ag-layout-auto-height{padding-top:30px}.ag-theme-alpine .ag-loading{padding-left:18px;display:flex;height:100%;align-items:center}.ag-theme-alpine .ag-loading-icon{padding-right:12px}.ag-theme-alpine .ag-icon-loading{-webkit-animation-name:spin;animation-name:spin;-webkit-animation-duration:1s;animation-duration:1s;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite;-webkit-animation-timing-function:linear;animation-timing-function:linear}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}.ag-theme-alpine .ag-floating-top{border-bottom:1px solid #babfc7;border-bottom-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-floating-bottom{border-top:1px solid #babfc7;border-top-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-ltr .ag-cell{border-right:solid transparent}.ag-theme-alpine .ag-rtl .ag-cell{border-left:solid transparent}.ag-theme-alpine .ag-ltr .ag-cell{border-right-width:1px}.ag-theme-alpine .ag-rtl .ag-cell{border-left-width:1px}.ag-theme-alpine .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell){border-left:1px solid #babfc7;border-left-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell){border-right:1px solid #babfc7;border-right-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-row-selected{background-color:rgba(33,150,243,.3);background-color:var(--ag-selected-row-background-color,rgba(33,150,243,.3))}.ag-theme-alpine .ag-cell-range-selected:not(.ag-cell-focus){background-color:rgba(33,150,243,.2);background-color:var(--ag-range-selection-background-color,rgba(33,150,243,.2))}.ag-theme-alpine .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart{background-color:rgba(0,88,255,.1);background-color:var(--ag-range-selection-chart-background-color,rgba(0,88,255,.1))}.ag-theme-alpine .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category{background-color:rgba(0,255,132,.1);background-color:var(--ag-range-selection-chart-category-background-color,rgba(0,255,132,.1))}.ag-theme-alpine .ag-cell-range-selected-1:not(.ag-cell-focus){background-color:rgba(33,150,243,.2);background-color:var(--ag-range-selection-background-color-1,var(--ag-range-selection-background-color,rgba(33,150,243,.2)))}.ag-theme-alpine .ag-cell-range-selected-2:not(.ag-cell-focus){background-color:rgba(33,150,243,.36);background-color:var(--ag-range-selection-background-color-2,rgba(33,150,243,.36))}.ag-theme-alpine .ag-cell-range-selected-3:not(.ag-cell-focus){background-color:rgba(33,150,243,.488);background-color:var(--ag-range-selection-background-color-3,rgba(33,150,243,.488))}.ag-theme-alpine .ag-cell-range-selected-4:not(.ag-cell-focus){background-color:rgba(33,150,243,.5904);background-color:var(--ag-range-selection-background-color-4,rgba(33,150,243,.5904))}.ag-theme-alpine .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top{border-top-color:#2196f3;border-top-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right{border-right-color:#2196f3;border-right-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom{border-bottom-color:#2196f3;border-bottom-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left{border-left-color:#2196f3;border-left-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-alpine .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-alpine .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),.ag-theme-alpine .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-alpine .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-alpine .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected){border:1px solid #2196f3;border-color:var(--ag-range-selection-border-color,#2196f3);outline:initial}.ag-theme-alpine .ag-cell.ag-selection-fill-top,.ag-theme-alpine .ag-cell.ag-selection-fill-top.ag-cell-range-selected{border-top:1px dashed #2196f3;border-top-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine .ag-ltr .ag-cell.ag-selection-fill-right,.ag-theme-alpine .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-right:1px dashed #2196f3;border-right-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine .ag-rtl .ag-cell.ag-selection-fill-right,.ag-theme-alpine .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-left:1px dashed #2196f3;border-left-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine .ag-cell.ag-selection-fill-bottom,.ag-theme-alpine .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected{border-bottom:1px dashed #2196f3;border-bottom-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine .ag-ltr .ag-cell.ag-selection-fill-left,.ag-theme-alpine .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-left:1px dashed #2196f3;border-left-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine .ag-rtl .ag-cell.ag-selection-fill-left,.ag-theme-alpine .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-right:1px dashed #2196f3;border-right-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine .ag-fill-handle,.ag-theme-alpine .ag-range-handle{position:absolute;width:6px;height:6px;bottom:-1px;background-color:#2196f3;background-color:var(--ag-range-selection-border-color,#2196f3)}.ag-theme-alpine .ag-ltr .ag-fill-handle,.ag-theme-alpine .ag-ltr .ag-range-handle{right:-1px}.ag-theme-alpine .ag-rtl .ag-fill-handle,.ag-theme-alpine .ag-rtl .ag-range-handle{left:-1px}.ag-theme-alpine .ag-fill-handle{cursor:cell}.ag-theme-alpine .ag-range-handle{cursor:nwse-resize}.ag-theme-alpine .ag-cell-inline-editing{border-color:rgba(33,150,243,.4)!important;border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))!important}.ag-theme-alpine .ag-menu{border:1px solid #babfc7;border-color:var(--ag-border-color,#babfc7);background:#fff;background:var(--ag-background-color,#fff);border-radius:3px;box-shadow:0 1px 4px 1px rgba(186,191,199,.4);padding:0}.ag-theme-alpine .ag-menu-list{cursor:default;width:100%;padding-top:6px;padding-bottom:6px}.ag-theme-alpine .ag-menu-option-part{padding-top:8px;padding-bottom:8px;line-height:16px}.ag-theme-alpine .ag-menu-option-active{background-color:rgba(33,150,243,.1);background-color:var(--ag-row-hover-color,rgba(33,150,243,.1))}.ag-theme-alpine .ag-menu-option-disabled{opacity:.5}.ag-theme-alpine .ag-menu-option-text{margin-left:6px}.ag-theme-alpine .ag-menu-option-icon{padding-left:12px;padding-right:6px;min-width:28px}.ag-theme-alpine .ag-menu-option-shortcut{padding-left:12px}.ag-theme-alpine .ag-menu-separator{height:12px}.ag-theme-alpine .ag-menu-separator-cell:after{content:"";display:block;border-top:1px solid #babfc7;border-top-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-menu-option-popup-pointer{width:28px;text-align:center}.ag-theme-alpine .ag-tabs-header{min-width:220px;width:100%;display:flex}.ag-theme-alpine .ag-tab{border-bottom:2px solid transparent;display:flex;flex:none;align-items:center;justify-content:center;cursor:pointer;flex:1 1 auto;transition:border-bottom .3s}.ag-theme-alpine .ag-keyboard-focus .ag-tab:focus{outline:none}.ag-theme-alpine .ag-keyboard-focus .ag-tab:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine .ag-tab-selected{border-bottom-color:#2196f3;border-bottom-color:var(--ag-selected-tab-underline-color,var(--ag-alpine-active-color,#2196f3))}.ag-theme-alpine .ag-menu-header{color:#181d1f;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#181d1f))}.ag-theme-alpine .ag-filter-condition-operator{height:17px}.ag-theme-alpine .ag-ltr .ag-filter-condition-operator-or{margin-left:12px}.ag-theme-alpine .ag-rtl .ag-filter-condition-operator-or{margin-right:12px}.ag-theme-alpine .ag-set-filter-select-all{padding-top:12px}.ag-theme-alpine .ag-set-filter-list{height:180px}.ag-theme-alpine .ag-set-filter-filter{margin-top:12px;margin-left:12px;margin-right:12px}.ag-theme-alpine .ag-filter-to{margin-top:9px}.ag-theme-alpine .ag-mini-filter{margin:12px 12px 0}.ag-theme-alpine .ag-set-filter-item{margin:0 12px}.ag-theme-alpine .ag-ltr .ag-set-filter-item-value{margin-left:12px}.ag-theme-alpine .ag-rtl .ag-set-filter-item-value{margin-right:12px}.ag-theme-alpine .ag-filter-header-container{padding-bottom:12px;border-bottom:1px solid #dde2eb;border-bottom-color:var(--ag-secondary-border-color,#dde2eb)}.ag-theme-alpine .ag-filter-apply-panel{padding:12px;border-top:1px solid #dde2eb;border-top-color:var(--ag-secondary-border-color,#dde2eb)}.ag-theme-alpine .ag-filter-apply-panel-button{line-height:1.5}.ag-theme-alpine .ag-ltr .ag-filter-apply-panel-button{margin-left:12px}.ag-theme-alpine .ag-rtl .ag-filter-apply-panel-button{margin-right:12px}.ag-theme-alpine .ag-simple-filter-body-wrapper{padding:12px 12px 3px}.ag-theme-alpine .ag-simple-filter-body-wrapper>*{margin-bottom:9px}.ag-theme-alpine .ag-filter-no-matches{margin:12px}.ag-theme-alpine .ag-side-bar{position:relative}.ag-theme-alpine .ag-tool-panel-wrapper{background-color:#f8f8f8;background-color:var(--ag-control-panel-background-color,#f8f8f8)}.ag-theme-alpine .ag-side-buttons{padding-top:24px;width:20px;position:relative;color:#181d1f;color:var(--ag-foreground-color,#181d1f);overflow:hidden}.ag-theme-alpine button.ag-side-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;background:transparent;padding:12px 0;width:100%;margin:0;min-height:108px;background-position-y:center;background-position-x:center;background-repeat:no-repeat;border:none}.ag-theme-alpine button.ag-side-button-button:focus{box-shadow:none}.ag-theme-alpine .ag-keyboard-focus .ag-side-button-button:focus{outline:none}.ag-theme-alpine .ag-keyboard-focus .ag-side-button-button:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine .ag-side-button-icon-wrapper{margin-bottom:3px}.ag-theme-alpine .ag-ltr .ag-side-bar-left,.ag-theme-alpine .ag-rtl .ag-side-bar-right{border-right:1px solid #babfc7;border-right-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,.ag-theme-alpine .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper{border-left:1px solid #babfc7;border-left-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-ltr .ag-side-bar-left .ag-side-button-button,.ag-theme-alpine .ag-rtl .ag-side-bar-right .ag-side-button-button{border-right:2px solid transparent;transition:border-right .3s}.ag-theme-alpine .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,.ag-theme-alpine .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button{border-right-color:#2196f3;border-right-color:var(--ag-selected-tab-underline-color,var(--ag-alpine-active-color,#2196f3))}.ag-theme-alpine .ag-ltr .ag-side-bar-right,.ag-theme-alpine .ag-rtl .ag-side-bar-left{border-left:1px solid #babfc7;border-left-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper,.ag-theme-alpine .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper{border-right:1px solid #babfc7;border-right-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-ltr .ag-side-bar-right .ag-side-button-button,.ag-theme-alpine .ag-rtl .ag-side-bar-left .ag-side-button-button{border-left:2px solid transparent;transition:border-left .3s}.ag-theme-alpine .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button,.ag-theme-alpine .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button{border-left-color:#2196f3;border-left-color:var(--ag-selected-tab-underline-color,var(--ag-alpine-active-color,#2196f3))}.ag-theme-alpine .ag-filter-toolpanel-header{height:36px}.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-header,.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-search{padding-left:6px}.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-header,.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-search{padding-right:6px}.ag-theme-alpine .ag-keyboard-focus .ag-filter-toolpanel-header:focus{outline:none}.ag-theme-alpine .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{font-family:agGridAlpine;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;content:"\\f112";position:absolute}.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-left:6px}.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-right:6px}.ag-theme-alpine .ag-filter-toolpanel-group-level-0-header{height:48px}.ag-theme-alpine .ag-filter-toolpanel-group-item{margin-top:3px;margin-bottom:3px}.ag-theme-alpine .ag-filter-toolpanel-search{height:48px}.ag-theme-alpine .ag-filter-toolpanel-search-input{flex-grow:1;height:24px}.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-search-input{margin-right:6px}.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-search-input{margin-left:6px}.ag-theme-alpine .ag-filter-toolpanel-group-level-0{border-top:1px solid #dde2eb;border-top-color:var(--ag-secondary-border-color,#dde2eb)}.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-expand,.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-title-bar-icon{margin-right:6px}.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-expand,.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-title-bar-icon{margin-left:6px}.ag-theme-alpine .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-left:22px}.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-right:22px}.ag-theme-alpine .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-left:38px}.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-right:38px}.ag-theme-alpine .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-left:54px}.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-right:54px}.ag-theme-alpine .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-left:70px}.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-right:70px}.ag-theme-alpine .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-left:86px}.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-right:86px}.ag-theme-alpine .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-left:102px}.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-right:102px}.ag-theme-alpine .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-left:118px}.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-right:118px}.ag-theme-alpine .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-left:134px}.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-right:134px}.ag-theme-alpine .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-left:150px}.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-right:150px}.ag-theme-alpine .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-left:166px}.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-right:166px}.ag-theme-alpine .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header{padding-left:6px}.ag-theme-alpine .ag-filter-toolpanel-instance-filter{border-top:1px solid #babfc7;border-top-color:var(--ag-border-color,#babfc7);border-bottom:1px solid #babfc7;border-bottom-color:var(--ag-border-color,#babfc7);padding-top:6px}.ag-theme-alpine .ag-ltr .ag-filter-toolpanel-instance-header-icon{margin-left:6px}.ag-theme-alpine .ag-rtl .ag-filter-toolpanel-instance-header-icon{margin-right:6px}.ag-theme-alpine .ag-pivot-mode-panel{height:48px;display:flex}.ag-theme-alpine .ag-pivot-mode-select{display:flex;align-items:center}.ag-theme-alpine .ag-ltr .ag-pivot-mode-select{margin-left:12px}.ag-theme-alpine .ag-rtl .ag-pivot-mode-select{margin-right:12px}.ag-theme-alpine .ag-keyboard-focus .ag-column-select-header:focus{outline:none}.ag-theme-alpine .ag-keyboard-focus .ag-column-select-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine .ag-column-select-header{height:48px;align-items:center;padding:0 12px}.ag-theme-alpine .ag-column-panel-column-select,.ag-theme-alpine .ag-column-select-header{border-bottom:1px solid #dde2eb;border-bottom-color:var(--ag-secondary-border-color,#dde2eb)}.ag-theme-alpine .ag-column-panel-column-select{border-top:1px solid #dde2eb;border-top-color:var(--ag-secondary-border-color,#dde2eb)}.ag-theme-alpine .ag-column-group-icons,.ag-theme-alpine .ag-column-select-header-icon{color:#181d1f;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#181d1f))}.ag-theme-alpine .ag-header{background-color:#f8f8f8;background-color:var(--ag-header-background-color,#f8f8f8);border-bottom:1px solid #babfc7;border-bottom-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-header-row{color:#181d1f;color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,var(--ag-foreground-color,#181d1f)))}.ag-theme-alpine .ag-pinned-right-header{border-left:1px solid #babfc7;border-left-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-pinned-left-header{border-right:1px solid #babfc7;border-right-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-header-row{height:48px}.ag-theme-alpine .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-left:6px}.ag-theme-alpine .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon,.ag-theme-alpine .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-right:6px}.ag-theme-alpine .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon{margin-left:6px}.ag-theme-alpine .ag-header-cell,.ag-theme-alpine .ag-header-group-cell{padding-left:18px;padding-right:18px}.ag-theme-alpine .ag-header-cell.ag-header-cell-moving,.ag-theme-alpine .ag-header-group-cell.ag-header-cell-moving{background-color:#fff;background-color:var(--ag-header-cell-moving-background-color,var(--ag-background-color,#fff))}.ag-theme-alpine .ag-keyboard-focus .ag-header-cell:focus{outline:none}.ag-theme-alpine .ag-keyboard-focus .ag-header-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine .ag-keyboard-focus .ag-header-group-cell:focus{outline:none}.ag-theme-alpine .ag-keyboard-focus .ag-header-group-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid rgba(33,150,243,.4);border-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine .ag-header-icon{color:#181d1f;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#181d1f))}.ag-theme-alpine .ag-header-expand-icon{cursor:pointer}.ag-theme-alpine .ag-ltr .ag-header-expand-icon{padding-left:4px}.ag-theme-alpine .ag-rtl .ag-header-expand-icon{padding-right:4px}.ag-theme-alpine .ag-header-row:not(:first-child) .ag-header-cell,.ag-theme-alpine .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group{border-top:1px solid #babfc7;border-top-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-header-cell-resize{display:flex;align-items:center}.ag-theme-alpine .ag-header-cell-resize:after{content:"";position:absolute;z-index:1;display:block;left:calc(50% - 1px);width:2px;height:30%;top:35%;background-color:rgba(186,191,199,.5);background-color:var(--ag-header-column-resize-handle-color,rgba(186,191,199,.5))}.ag-theme-alpine .ag-pinned-right-header .ag-header-cell-resize:after{left:calc(50% - 2px)}.ag-theme-alpine .ag-ltr .ag-header-select-all{margin-right:18px}.ag-theme-alpine .ag-ltr .ag-floating-filter-button,.ag-theme-alpine .ag-rtl .ag-header-select-all{margin-left:18px}.ag-theme-alpine .ag-rtl .ag-floating-filter-button{margin-right:18px}.ag-theme-alpine .ag-floating-filter-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;height:16px;padding:0;width:16px}.ag-theme-alpine .ag-filter-loading{background-color:#f8f8f8;background-color:var(--ag-control-panel-background-color,#f8f8f8);height:100%;padding:12px;position:absolute;width:100%;z-index:1}.ag-theme-alpine .ag-paging-panel{border-top:1px solid #babfc7;border-top-color:var(--ag-border-color,#babfc7);color:#181d1f;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#181d1f));height:48px}.ag-theme-alpine .ag-paging-panel>*{margin:0 18px}.ag-theme-alpine .ag-paging-button{cursor:pointer;opacity:0;top:0;right:0;bottom:0;left:0;padding:0;width:16px}.ag-theme-alpine .ag-disabled .ag-paging-button{cursor:default}.ag-theme-alpine .ag-paging-button-wrapper.ag-disabled{color:rgba(24,29,31,.5);color:var(--ag-disabled-foreground-color,rgba(24,29,31,.5));cursor:default}.ag-theme-alpine .ag-paging-button-wrapper,.ag-theme-alpine .ag-paging-description{margin:0 6px}.ag-theme-alpine .ag-status-bar{border-top:1px solid #babfc7;border-top-color:var(--ag-border-color,#babfc7);color:rgba(24,29,31,.5);color:var(--ag-disabled-foreground-color,rgba(24,29,31,.5));padding-right:24px;padding-left:24px;line-height:1.5}.ag-theme-alpine .ag-status-name-value-value{color:#181d1f;color:var(--ag-foreground-color,#181d1f)}.ag-theme-alpine .ag-status-bar-center{text-align:center}.ag-theme-alpine .ag-status-name-value{margin-left:6px;margin-right:6px;padding-top:12px;padding-bottom:12px}.ag-theme-alpine .ag-column-drop-cell{background:rgba(24,29,31,.07);background:var(--ag-chip-background-color,rgba(24,29,31,.07));border-radius:24px;height:24px;padding:0 3px}.ag-theme-alpine .ag-column-drop-cell-text{margin:0 6px}.ag-theme-alpine .ag-column-drop-cell-button{min-width:24px;margin:0 3px;color:#181d1f;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#181d1f))}.ag-theme-alpine .ag-column-drop-cell-drag-handle{margin-left:12px}.ag-theme-alpine .ag-column-drop-cell-ghost{opacity:.5}.ag-theme-alpine .ag-column-drop-horizontal{background-color:#f8f8f8;background-color:var(--ag-control-panel-background-color,#f8f8f8);color:#181d1f;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#181d1f));height:42px;border-bottom:1px solid #babfc7;border-bottom-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-ltr .ag-column-drop-horizontal{padding-left:18px}.ag-theme-alpine .ag-rtl .ag-column-drop-horizontal{padding-right:18px}.ag-theme-alpine .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child){border-right:1px solid #babfc7;border-right-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child){border-left:1px solid #babfc7;border-left-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-column-drop-horizontal-cell-separator{margin:0 6px;color:#181d1f;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#181d1f))}.ag-theme-alpine .ag-column-drop-horizontal-empty-message{color:rgba(24,29,31,.5);color:var(--ag-disabled-foreground-color,rgba(24,29,31,.5))}.ag-theme-alpine .ag-ltr .ag-column-drop-horizontal-icon{margin-right:18px}.ag-theme-alpine .ag-rtl .ag-column-drop-horizontal-icon{margin-left:18px}.ag-theme-alpine .ag-column-drop-vertical-list{padding-bottom:6px;padding-right:6px;padding-left:6px}.ag-theme-alpine .ag-column-drop-vertical-cell{margin-top:6px}.ag-theme-alpine .ag-column-drop-vertical{min-height:50px;max-height:150px;border-bottom:1px solid #dde2eb;border-bottom-color:var(--ag-secondary-border-color,#dde2eb)}.ag-theme-alpine .ag-column-drop-vertical.ag-last-column-drop{border-bottom:none}.ag-theme-alpine .ag-column-drop-vertical-icon{margin-left:6px;margin-right:6px}.ag-theme-alpine .ag-column-drop-vertical-list{position:relative}.ag-theme-alpine .ag-column-drop-vertical-empty-message{position:absolute;top:0;bottom:0;left:0;right:0;overflow:hidden;color:rgba(24,29,31,.5);color:var(--ag-disabled-foreground-color,rgba(24,29,31,.5));margin-top:6px}.ag-theme-alpine .ag-select-agg-func-popup{border:1px solid #babfc7;border-color:var(--ag-border-color,#babfc7);border-radius:3px;box-shadow:0 1px 4px 1px rgba(186,191,199,.4);background:#fff;background:var(--ag-background-color,#fff);height:105px;padding:0}.ag-theme-alpine .ag-select-agg-func-virtual-list-item{cursor:default;line-height:30px;padding-left:12px}.ag-theme-alpine .ag-select-agg-func-virtual-list-item:hover{background-color:rgba(33,150,243,.3);background-color:var(--ag-selected-row-background-color,rgba(33,150,243,.3))}.ag-theme-alpine .ag-chart-menu{border-radius:3px;background:#fff;background:var(--ag-background-color,#fff)}.ag-theme-alpine .ag-chart-menu-icon{opacity:.5;line-height:24px;font-size:24px;width:24px;height:24px;margin:2px 0;cursor:pointer;border-radius:3px;color:#181d1f;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#181d1f))}.ag-theme-alpine .ag-chart-menu-icon:hover{opacity:1}.ag-theme-alpine .ag-chart-mini-thumbnail{border:1px solid #dde2eb;border-color:var(--ag-secondary-border-color,#dde2eb);border-radius:5px;margin:5px}.ag-theme-alpine .ag-chart-mini-thumbnail:nth-last-child(3),.ag-theme-alpine .ag-chart-mini-thumbnail:nth-last-child(3)~.ag-chart-mini-thumbnail{margin-left:auto;margin-right:auto}.ag-theme-alpine .ag-ltr .ag-chart-mini-thumbnail:first-child{margin-left:0}.ag-theme-alpine .ag-ltr .ag-chart-mini-thumbnail:last-child,.ag-theme-alpine .ag-rtl .ag-chart-mini-thumbnail:first-child{margin-right:0}.ag-theme-alpine .ag-rtl .ag-chart-mini-thumbnail:last-child{margin-left:0}.ag-theme-alpine .ag-chart-mini-thumbnail.ag-selected{border-color:#2196f3;border-color:var(--ag-minichart-selected-chart-color,var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3)))}.ag-theme-alpine .ag-chart-settings-card-item{background:#181d1f;background:var(--ag-foreground-color,#181d1f);width:8px;height:8px;border-radius:4px}.ag-theme-alpine .ag-chart-settings-card-item.ag-selected{background-color:#2196f3;background-color:var(--ag-minichart-selected-page-color,var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3)))}.ag-theme-alpine .ag-chart-data-column-drag-handle{margin-left:6px}.ag-theme-alpine .ag-charts-data-group-title-bar,.ag-theme-alpine .ag-charts-format-top-level-group-title-bar,.ag-theme-alpine .ag-charts-settings-group-title-bar{border-top:1px solid #dde2eb;border-top-color:var(--ag-secondary-border-color,#dde2eb)}.ag-theme-alpine .ag-charts-settings-group-container{padding:6px}.ag-theme-alpine .ag-charts-data-group-container{padding:12px 12px 3px}.ag-theme-alpine .ag-charts-data-group-container>*{margin-bottom:9px}.ag-theme-alpine .ag-charts-format-top-level-group-container{margin-left:12px;padding:6px}.ag-theme-alpine .ag-charts-format-top-level-group-item{margin:6px 0}.ag-theme-alpine .ag-charts-format-sub-level-group-container{padding:12px 12px 3px}.ag-theme-alpine .ag-charts-format-sub-level-group-container>*{margin-bottom:9px}.ag-theme-alpine .ag-charts-group-container.ag-group-container-horizontal{padding:6px}.ag-theme-alpine .ag-chart-data-section,.ag-theme-alpine .ag-chart-format-section{display:flex;margin:0}.ag-theme-alpine .ag-chart-menu-panel{background-color:#f8f8f8;background-color:var(--ag-control-panel-background-color,#f8f8f8)}.ag-theme-alpine .ag-ltr .ag-chart-menu-panel{border-left:1px solid #babfc7;border-left-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-rtl .ag-chart-menu-panel{border-right:1px solid #babfc7;border-right-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-date-time-list-page-title{flex-grow:1;text-align:center}.ag-theme-alpine .ag-date-time-list-page-column-label,.ag-theme-alpine .ag-date-time-list-page-entry{text-align:center}.ag-theme-alpine .ag-checkbox-input-wrapper{font-family:agGridAlpine;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:16px;height:16px;background-color:#fff;background-color:var(--ag-checkbox-background-color,var(--ag-background-color,#fff));border-radius:3px;display:inline-block;vertical-align:middle;flex:none}.ag-theme-alpine .ag-checkbox-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-alpine .ag-checkbox-input-wrapper:active,.ag-theme-alpine .ag-checkbox-input-wrapper:focus-within{outline:none;box-shadow:0 0 2px .1rem rgba(33,150,243,.4)}.ag-theme-alpine .ag-checkbox-input-wrapper.ag-disabled{opacity:.5}.ag-theme-alpine .ag-checkbox-input-wrapper:after{content:"\\f108";color:#999;color:var(--ag-checkbox-unchecked-color,#999);position:absolute;top:0;left:0;pointer-events:none}.ag-theme-alpine .ag-checkbox-input-wrapper.ag-checked:after{content:"\\f106";color:#2196f3;color:var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-alpine .ag-checkbox-input-wrapper.ag-indeterminate:after{content:"\\f107";color:#999;color:var(--ag-checkbox-indeterminate-color,var(--ag-checkbox-unchecked-color,#999));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-alpine .ag-toggle-button-input-wrapper{box-sizing:border-box;width:28px;height:18px;background-color:#999;background-color:var(--ag-toggle-button-off-background-color,var(--ag-checkbox-unchecked-color,#999));border-radius:9px;position:relative;flex:none;border:1px solid #999;border-color:var(--ag-toggle-button-off-border-color,var(--ag-checkbox-unchecked-color,#999))}.ag-theme-alpine .ag-toggle-button-input-wrapper input{opacity:0;height:100%;width:100%}.ag-theme-alpine .ag-toggle-button-input-wrapper:focus-within{outline:none;box-shadow:0 0 2px .1rem rgba(33,150,243,.4)}.ag-theme-alpine .ag-toggle-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-alpine .ag-toggle-button-input-wrapper.ag-checked{background-color:#2196f3;background-color:var(--ag-toggle-button-on-background-color,var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3)));border-color:#2196f3;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3)))}.ag-theme-alpine .ag-toggle-button-input-wrapper:before{content:" ";position:absolute;top:-1px;left:-1px;display:block;box-sizing:border-box;height:18px;width:18px;background-color:#fff;background-color:var(--ag-toggle-button-switch-background-color,var(--ag-background-color,#fff));border-radius:9px;transition:left .1s;border:1px solid #999;border-color:var(--ag-toggle-button-switch-border-color,var(--ag-toggle-button-off-border-color,var(--ag-checkbox-unchecked-color,#999)))}.ag-theme-alpine .ag-toggle-button-input-wrapper.ag-checked:before{left:calc(100% - 18px);border-color:#2196f3;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3)))}.ag-theme-alpine .ag-radio-button-input-wrapper{font-family:agGridAlpine;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:16px;height:16px;background-color:#fff;background-color:var(--ag-checkbox-background-color,var(--ag-background-color,#fff));border-radius:3px;display:inline-block;vertical-align:middle;flex:none;border-radius:16px}.ag-theme-alpine .ag-radio-button-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-alpine .ag-radio-button-input-wrapper:active,.ag-theme-alpine .ag-radio-button-input-wrapper:focus-within{outline:none;box-shadow:0 0 2px .1rem rgba(33,150,243,.4)}.ag-theme-alpine .ag-radio-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-alpine .ag-radio-button-input-wrapper:after{content:"\\f124";color:#999;color:var(--ag-checkbox-unchecked-color,#999);position:absolute;top:0;left:0;pointer-events:none}.ag-theme-alpine .ag-radio-button-input-wrapper.ag-checked:after{content:"\\f125";color:#2196f3;color:var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-alpine input[class^=ag-][type=range]{-webkit-appearance:none;width:100%;height:100%;background:none;overflow:visible}.ag-theme-alpine input[class^=ag-][type=range]::-webkit-slider-runnable-track{margin:0;padding:0;width:100%;height:3px;background-color:#babfc7;background-color:var(--ag-border-color,#babfc7);border-radius:3px}.ag-theme-alpine input[class^=ag-][type=range]::-moz-range-track{margin:0;padding:0;width:100%;height:3px;background-color:#babfc7;background-color:var(--ag-border-color,#babfc7);border-radius:3px}.ag-theme-alpine input[class^=ag-][type=range]::-ms-track{margin:0;padding:0;width:100%;height:3px;background-color:#babfc7;background-color:var(--ag-border-color,#babfc7);border-radius:3px;color:transparent;width:calc(100% - 2px)}.ag-theme-alpine input[class^=ag-][type=range]::-webkit-slider-thumb{margin:0;padding:0;-webkit-appearance:none;width:16px;height:16px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #999;border-color:var(--ag-checkbox-unchecked-color,#999);border-radius:16px;-webkit-transform:translateY(-6.5px);transform:translateY(-6.5px)}.ag-theme-alpine input[class^=ag-][type=range]::-ms-thumb{margin:0;padding:0;-webkit-appearance:none;width:16px;height:16px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #999;border-color:var(--ag-checkbox-unchecked-color,#999);border-radius:16px}.ag-theme-alpine input[class^=ag-][type=range]::-moz-ag-range-thumb{margin:0;padding:0;-webkit-appearance:none;width:16px;height:16px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #999;border-color:var(--ag-checkbox-unchecked-color,#999);border-radius:16px}.ag-theme-alpine input[class^=ag-][type=range]:focus{outline:none}.ag-theme-alpine input[class^=ag-][type=range]:focus::-webkit-slider-thumb{box-shadow:0 0 2px .1rem rgba(33,150,243,.4);border-color:#2196f3;border-color:var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3))}.ag-theme-alpine input[class^=ag-][type=range]:focus::-ms-thumb{box-shadow:0 0 2px .1rem rgba(33,150,243,.4);border-color:#2196f3;border-color:var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3))}.ag-theme-alpine input[class^=ag-][type=range]:focus::-moz-ag-range-thumb{box-shadow:0 0 2px .1rem rgba(33,150,243,.4);border-color:#2196f3;border-color:var(--ag-checkbox-checked-color,var(--ag-alpine-active-color,#2196f3))}.ag-theme-alpine input[class^=ag-][type=range]:active::-webkit-slider-runnable-track{background-color:rgba(33,150,243,.4);background-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine input[class^=ag-][type=range]:active::-moz-ag-range-track{background-color:rgba(33,150,243,.4);background-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine input[class^=ag-][type=range]:active::-ms-track{background-color:rgba(33,150,243,.4);background-color:var(--ag-input-focus-border-color,rgba(33,150,243,.4))}.ag-theme-alpine input[class^=ag-][type=range]:disabled{opacity:.5}.ag-theme-alpine .ag-filter-toolpanel-header,.ag-theme-alpine .ag-filter-toolpanel-search,.ag-theme-alpine .ag-header-row,.ag-theme-alpine .ag-panel-title-bar-title,.ag-theme-alpine .ag-status-bar{font-weight:700;color:#181d1f;color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,var(--ag-foreground-color,#181d1f)))}.ag-theme-alpine .ag-ltr .ag-pinned-right-header .ag-header-row:after,.ag-theme-alpine .ag-rtl .ag-pinned-left-header .ag-header-row:before{content:"";position:absolute;height:calc(100% - 20px);top:10px;width:1px;background-color:#babfc7;background-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-ltr .ag-pinned-right-header .ag-header-row:after{right:0}.ag-theme-alpine .ag-rtl .ag-pinned-left-header .ag-header-row:before{left:0}.ag-theme-alpine .ag-row{font-size:14px}.ag-theme-alpine input[class^=ag-]:not([type]),.ag-theme-alpine input[class^=ag-][type=date],.ag-theme-alpine input[class^=ag-][type=datetime-local],.ag-theme-alpine input[class^=ag-][type=number],.ag-theme-alpine input[class^=ag-][type=tel],.ag-theme-alpine input[class^=ag-][type=text],.ag-theme-alpine textarea[class^=ag-]{min-height:24px;border-radius:3px}.ag-theme-alpine .ag-ltr input[class^=ag-]:not([type]),.ag-theme-alpine .ag-ltr input[class^=ag-][type=date],.ag-theme-alpine .ag-ltr input[class^=ag-][type=datetime-local],.ag-theme-alpine .ag-ltr input[class^=ag-][type=number],.ag-theme-alpine .ag-ltr input[class^=ag-][type=tel],.ag-theme-alpine .ag-ltr input[class^=ag-][type=text],.ag-theme-alpine .ag-ltr textarea[class^=ag-]{padding-left:6px}.ag-theme-alpine .ag-rtl input[class^=ag-]:not([type]),.ag-theme-alpine .ag-rtl input[class^=ag-][type=date],.ag-theme-alpine .ag-rtl input[class^=ag-][type=datetime-local],.ag-theme-alpine .ag-rtl input[class^=ag-][type=number],.ag-theme-alpine .ag-rtl input[class^=ag-][type=tel],.ag-theme-alpine .ag-rtl input[class^=ag-][type=text],.ag-theme-alpine .ag-rtl textarea[class^=ag-]{padding-right:6px}.ag-theme-alpine .ag-tab{padding:9px;transition:color .4s}.ag-theme-alpine .ag-tab-selected{color:#2196f3;color:var(--ag-alpine-active-color,#2196f3)}.ag-theme-alpine .ag-menu,.ag-theme-alpine .ag-menu-header{background-color:#f8f8f8;background-color:var(--ag-control-panel-background-color,#f8f8f8)}.ag-theme-alpine .ag-menu-header{padding-top:1px}.ag-theme-alpine .ag-tabs-header{border-bottom:1px solid #babfc7;border-bottom-color:var(--ag-border-color,#babfc7)}.ag-theme-alpine .ag-charts-data-group-title-bar,.ag-theme-alpine .ag-charts-format-top-level-group-title-bar,.ag-theme-alpine .ag-charts-settings-group-title-bar{padding:6px 12px;line-height:20px}.ag-theme-alpine .ag-chart-mini-thumbnail{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-alpine .ag-chart-settings-nav-bar{border-top:1px solid #dde2eb;border-top-color:var(--ag-secondary-border-color,#dde2eb)}.ag-theme-alpine .ag-ltr .ag-group-title-bar-icon{margin-right:6px}.ag-theme-alpine .ag-rtl .ag-group-title-bar-icon{margin-left:6px}.ag-theme-alpine .ag-charts-format-top-level-group-toolbar{margin-top:6px}.ag-theme-alpine .ag-ltr .ag-charts-format-top-level-group-toolbar{padding-left:20px}.ag-theme-alpine .ag-rtl .ag-charts-format-top-level-group-toolbar{padding-right:20px}.ag-theme-alpine .ag-charts-format-sub-level-group{border-left:1px dashed #babfc7;border-left-color:var(--ag-border-color,#babfc7);padding-left:6px;margin-bottom:12px}.ag-theme-alpine .ag-charts-format-sub-level-group-title-bar{padding-top:0;padding-bottom:0;background:none;font-weight:700}.ag-theme-alpine .ag-charts-format-sub-level-group-container{padding-bottom:0}.ag-theme-alpine .ag-charts-format-sub-level-group-item:last-child{margin-bottom:0}.ag-theme-alpine .ag-dnd-ghost{font-size:12px;font-weight:700}.ag-theme-alpine .ag-side-buttons{width:30px}.ag-theme-alpine .ag-standard-button{-moz-appearance:none;appearance:none;-webkit-appearance:none;border-radius:3px;border:1px solid #2196f3;border-color:var(--ag-alpine-active-color,#2196f3);color:#2196f3;color:var(--ag-alpine-active-color,#2196f3);background-color:#fff;background-color:var(--ag-background-color,#fff);font-weight:600;padding:6px 12px}.ag-theme-alpine .ag-standard-button:hover{border-color:#2196f3;border-color:var(--ag-alpine-active-color,#2196f3);background-color:rgba(33,150,243,.1);background-color:var(--ag-row-hover-color,rgba(33,150,243,.1))}.ag-theme-alpine .ag-standard-button:active{border-color:#2196f3;border-color:var(--ag-alpine-active-color,#2196f3);background-color:#2196f3;background-color:var(--ag-alpine-active-color,#2196f3);color:#fff;color:var(--ag-background-color,#fff)}.ag-theme-alpine .ag-standard-button:disabled{color:rgba(24,29,31,.5);color:var(--ag-disabled-foreground-color,rgba(24,29,31,.5));background-color:#f1f2f4;background-color:var(--ag-input-disabled-background-color,#f1f2f4);border-color:rgba(186,191,199,.3);border-color:var(--ag-input-disabled-border-color,rgba(186,191,199,.3))}.ag-theme-alpine .ag-menu-header{min-width:240px}.ag-theme-alpine .ag-column-drop-vertical{min-height:75px;max-height:175px}.ag-theme-alpine .ag-tool-panel-wrapper{width:250px}.ag-theme-alpine .ag-column-drop-vertical-title-bar{padding:12px 12px 0}.ag-theme-alpine .ag-column-drop-vertical-empty-message{display:flex;align-items:center;border:1px dashed #babfc7;border-color:var(--ag-border-color,#babfc7);margin:12px;padding:12px}.ag-theme-alpine .ag-column-drop-empty-message{color:#181d1f;color:var(--ag-foreground-color,#181d1f);opacity:.75}.ag-theme-alpine .ag-status-bar{font-weight:400}.ag-theme-alpine .ag-paging-number,.ag-theme-alpine .ag-paging-row-summary-panel-number,.ag-theme-alpine .ag-status-name-value-value{font-weight:700}.ag-theme-alpine .ag-column-drop-cell-button{opacity:.5}.ag-theme-alpine .ag-column-drop-cell-button:hover{opacity:.75}.ag-theme-alpine .ag-chart-menu-icon:hover,.ag-theme-alpine .ag-chart-settings-next:hover,.ag-theme-alpine .ag-chart-settings-prev:hover,.ag-theme-alpine .ag-column-group-icons:hover,.ag-theme-alpine .ag-column-select-header-icon:hover,.ag-theme-alpine .ag-filter-toolpanel-expand:hover,.ag-theme-alpine .ag-floating-filter-button-button:hover,.ag-theme-alpine .ag-group-contracted .ag-icon:hover,.ag-theme-alpine .ag-group-expanded .ag-icon:hover,.ag-theme-alpine .ag-group-title-bar-icon:hover,.ag-theme-alpine .ag-header-cell-menu-button:hover,.ag-theme-alpine .ag-header-expand-icon:hover,.ag-theme-alpine .ag-panel-title-bar-button:hover,.ag-theme-alpine .ag-side-button-button:hover,.ag-theme-alpine .ag-tab:hover{color:#2196f3;color:var(--ag-alpine-active-color,#2196f3)}.ag-theme-alpine .ag-chart-settings-card-item.ag-not-selected:hover{opacity:.35}.ag-theme-alpine .ag-ltr .ag-panel-title-bar-button{margin-left:12px;margin-right:6px}.ag-theme-alpine .ag-rtl .ag-panel-title-bar-button{margin-right:12px;margin-left:6px}.ag-theme-alpine .ag-filter-toolpanel-group-container{padding-left:6px}.ag-theme-alpine .ag-filter-toolpanel-instance-filter{background-color:#f8f8f8;background-color:var(--ag-control-panel-background-color,#f8f8f8);border:none;border-left:#babfc7;border-left:1px dashed var(--ag-border-color,#babfc7);margin-left:13px;padding-left:8px;margin-right:12px}.ag-theme-alpine .ag-set-filter-list{padding-top:3px;padding-bottom:3px}.ag-theme-alpine .ag-overlay-no-rows-wrapper.ag-layout-auto-height{padding-top:60px}.ag-theme-alpine .ag-date-time-list-page-entry-is-current{background-color:#2196f3;background-color:var(--ag-alpine-active-color,#2196f3)}',""]),e.exports=t},function(e,t,o){var r=o(27),a=o(160);"string"==typeof(a=a.__esModule?a.default:a)&&(a=[[e.i,a,""]]);var n={insert:"head",singleton:!1};r(a,n);e.exports=a.locals||{}},function(e,t,o){(t=o(28)(!1)).push([e.i,'.ag-theme-balham-dark{-webkit-font-smoothing:antialiased;color:#f5f5f5;color:var(--ag-foreground-color,#f5f5f5);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:12px;line-height:normal}@font-face{font-family:agGridBalham;src:url("data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABX4AAsAAAAAJ8wAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlEAAAReXgFf/09TLzIAAANcAAAAPgAAAFZWTFJaY21hcAAAA5wAAAHtAAAFgFIH7gFnbHlmAAAFjAAADLgAABYYNphscGhlYWQAABJEAAAALwAAADZ2zsSBaGhlYQAAEnQAAAAbAAAAJAfTBC1obXR4AAASkAAAABIAAAEUp/gAAGxvY2EAABKkAAAAZAAAAIwBFQakbWF4cAAAEwgAAAAfAAAAIAFbAHNuYW1lAAATKAAAATUAAAJG0OP3eXBvc3QAABRgAAABlwAAAlqez14KeJx9k09yElEQxr9hCBKISYwxloga/0bjOAwM/yQQCFKWZWXhwoULN3GhpZVylRO49gCWB/AUnsBy6coDeADLA/jrZpCYRXjFzJvur7/+ul8/BZJKSrSr3OTx/nMtHx4cvVdFeU1/5j++Dw7fvjlQcfaFL+/vooLwj5Z1Qy90pG+BgtfB51whzIW74X74IfwU/lAIalMx6LIesGLVeEZkr6uhVDkVsMXsm2qBDnm23bqmC1pwz1AjrZMzJmbkjNt6qptahWfgPH31QCUs4+zzHLNuaeUURKrb8NdR08VqrFUyrGpRe2jso6NDdAvvCr4dMkfEDPANdA68ofLexyd6iaI1r80i6xku4R/TZfuO/KvMmqHa8DfgN74tss7sDTLViLgHex3Uw6yH27pGdAOePmwdj256dBlkDYWJrrKzympUtkT9PT3TK8+6m8X0vYvTmrdQP7cPnC+l2uPWDlxjsHfRMLfaidwhV6QJ/pI2eL/TR33RV33XT/3Sb53B2sVrFfTg3jm1M0X6dxI9xNv+Z7VKC5zPSdT/iEXqbnhvYnyjrIOWrYxO603CPsKaOL6ETsMPUZNyGnlyRJ63hnWB1eU7Bn02m8YWa8n7PGIGbAIqdKfB05im85bS4Usw2W6qa8O71YLnop+W9dRu0rJ/2czbKVfAXOYdUVnd+/MI7xUsxjS3VD0qRbVx3MefonaezVRVUdX02bXJmvgtGJJpkzqmSmrcXLsBE5+q6yioZzdyndMw9Z3spM47LvaoAM1RdpMT75lN8gBtNhXjv2nbY10AAAB4nGNgZMpnnMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVFgEqgRRAAAy9AKRgAAeJy102dSWzEUhuHXhW56TaN3Y2wwvRkb/rAM0hlSGNKZrDI70QZCvnPPyQLITDTz+Ls6o6srjSygDSjImhQhXySHtd+q5rJ6ge6sXuSX+iU6yeu5whU33KXa/b2qFS655jblst7fltPoEk9ZZEe9I811oKdjqrT0xh4b7LPLCXU2OWWdbWo0OGeLQ5qc6f28vl7UGtvp0He7tJIezdhLH/0MMMgQw4wwyhjjTPCYJ/raM42ZZIppZpjVuDnmWdAalvTcwzIr+l1Vr6wFtvOwdvTA8dbWDnaOq63Knna7e1Lf1Ea3a43zrcPm2T9M9h9ayX4KP6N3gZ2ms91eBvt/PA8H8iLYyb4Mx/IqVOV1aMmbYPO+DXtyFTbkOuzLu7Ar78OJfAh1+Rg25Sacym1Yl09hWz6HmnwJDfkazuVb2JLv4VB+hKbcBR1gyjm7KynvsCw4u1up6Ox+pTZn9y61Oyw7HJadDssuh2W3s/uYehyWJWcnmXodln0Oy36H5YDDctBhOeSwHHZYjjgsRx2WYw7LcYflhMPykdPdJAXdUlLQfSUF3VxSyPY16bCcclhOOyxnHJazDss5l+133mG1BYfVFh1WW3JYbdlhtRWXzbPqsrWVHTZ2zWFjKy4bs+6w96oum7PmKP8BU32drwAAAHic7RhpcBvVeb+3lmRZsm5pJdk6V4ety9YdS/Zu7MTGdu7DCRlC0jQHDTFH0tAwIYJCaCAhDDSZcEwzFDoDGZgpw7TTDNMmpUMZMFNi0hQ6JTD9AbQNaRtCyXQGFy393molxybl+l1pd9/33vve9773ve96j2EZ/LHPss8yHJNm1jMMeAlnYQ1E0xROkSixCqQYUgXVRlDbbZwXuKawAEULm4JohA+qVXyetzs45a/WyH97Np+1B6K5YqGIuIViIRKl/3yANXcMxqCpCWKDHdJ70nvTNfBIfwvPAWCbSI4HL3j5HNHpEF65de5/4CFxCqw6v9fg0JlanEZ/xMBNidJ+aNLYDf0Gu1rt9XVbPAC72KevRBo8cm2gEF77+JIfXF8nrUzDslMia7ToHQ691dI+4Gh1egycSazouuwhm75bbzWa250hm5+fR0UFsrweYR9hfAxj5TTRIqcJmOUiag7IRTFglgvOPDGcOHw4MQytM0vpY6X+5pXbG/2tynzkZdbGNGNFmYeHN/clz5xJ7hPI0X2JM2cS+6Q5lC2Zt23sNsbGdDJ5xA/S7bDRrcnQfcjRfdBkaN1Ge+R9KdAeK9JFykg/WoRLW1aPZbLZzNjq1+rAlrGRoVg8HhsaeYYCEENo7MnkU08ln5S/7LYZ6DIgzESXIenj+gj8Mg2enawTIQ2jQ5lmzTx9i1k7f7pSOb9z5we33EK2SteR4erzU1PTYz5gzzFWJsogmU4IpiBvzgmQDWS8YDfbDMAGggYKeWmbQHtToAGUH7C56vfTK7q7V6RJreyqVjwZDz5kr1x2SOteyz4KN01jpOUR7E88aU91D37wIXfj5yPEzDwKN8/mKf7VeWIDaBdfxlF/9SXS++XsSKlhWV1m8MJAfXo+0GBJdSVOcpcRp5PdNYsL9tzlvbQcms2BIodb2U2MCjXWyTBa0HBaYIs+qPkGmyNTyFNFJH+X1pc2SlUQJiZeeU6ncxkd6cG0w+iCF+GJMnZIv4W+iQmhtdXbFnEF0+mgK9zupeSb5DmSrEHRGSPDhHlz1qq8QN/jovgrQTghitVTgvA2yVQnp9+GHZPDrAr5RB6p3pND0sXE++8n4FKtVNayCO3JyvBMN52lLsByQ6gsekEEHNhSwK4Izi7vuT2A7eSnl+Ij8dhIghbxkcinkUJB/khNc2MjcTgiXRfOV7APsjJCXDqFH5IpRKSXKCr0RgqSnljiw3ExH57m+2XyMrUVmGG1l5kj8V9uZjN9iOKbssSq+BBYWPMhMDFbLrh1Gi2QQygM6SKYyJ+odExgQhSVLJtjbAkl08MsZMaYdYhfKGYxfNSiAOXMANGa7y/KXgbZ5AxgBDlY0KpaFmiuCAKIkCI4ppClgrVpwqgpqJwZEVBbUsAHNcCv32pZ+/SdoVazpc3tj/QlRhY8s2zl/GVpk1Wr05lMCbE3IXQv5CCybMmGzWsdtvbSSO+mcgLu6V7AgXfnkR8v4Esj5c2luDTpjl8V74om3LHhWFeUfJRm2cX3Xt0e9MbaAy4kHLbY7N3lVW0pm9PutffF+xIP+67OkzVCn83uVbe0x8ubyiMl6ff+NXkyfGMfGwxiS+9I6WxHF1J0J6JdcSymdfUYyzNtTIopo6TkCKuISH25eDBWcgZSl05NIhqUBioZSgmViqOSQLv1AIqGWi1UG/JYcMP1N+1YszSjyEL8zTgsvP9GnyKLZXfyVADDpQ2l0oadG3p6NvwxNrxyOCZ/WL6x+MUh3mCcW1qtLHxsU5NI+sYHawv3uG9ZQlfr60ESNTp/gBglEiO1ouF7kmwS8wn0gqCs0wOaYkFZbKQPAiqbkjPYi/maahTybBI6nQNFZ/MJAAIaZ2HA1Um2V081yxCqSK2XnIt2e8rdbq3+uwfHdpR0za50n7c7NCiate50n6c7tLdrRUe3p5R2a80KP2RK1mdtXaNVZt5MPlG0WvqW0FBsh6SHS4y+tgZyoeFfrLiaNoz4vOzbuximyOez3GVv+EvqU7IvmvZIV65MVWo/USkFpUR2mmfkaXm0uT6mnxlkRr5uxmZFblQYc8Kzym+Ymx2tVGCX9Ar0SPsbkB6hS9IoHP9m6Vj1n4IgiMrbiGfTe1jz1tTLk7jisf8sCHWvXf037mBdD3ewbSg5M913dMh061muGMXVFqMkKsJ+aZd4QDoLkcnJdAXelbyVNHlQOCEcgAhEpLOTGdyBTJ3WdowDMWa1rNMoVg0KGN0blWpBhHwkmkY9NwCqtBdzXhHVFVXdGpSxsJF6u5TSQUfbsAOb07Ldy1R44sRYGWhraWkf96zoCOU0aofLomctYVO70WDi43t6Yr7xpNPDxTbFFnm2dXHtXNzbDJqwy66z0CHxInA2C+hYC29ot7Xo5qUinWRQq1e1Le+MeLZ5rK2tfRF+yG1h+bAlZI9u7E6H4m2c0b8tdU855QOtH6neXe72e7U6lW9TkkOqVoNxScqTt8ljAtbQtcn0Eqvp/zK5kkxqNnofe9/n/AZDrYzGaRW+ssXhW1TqGoTRaoWbJxIT8GJiIgGuqanq5NTUAoTJOmxF77FuyocAPokMWsU6LPGZeHpq2j6qpMqoGTwyWH3UQDThLsDsoPgP9q2hHct2wO+UcuIsS8vHaoWS4yTJ6/X8G9A66n82WX0APbDygktEexDrex/EmCbPp0ykTAuvN8kT/bA237/easJiO7zwFju0ffkOZewzmLvV7LKejaA51w43UDqYevts6mA//KIfobe7DsLSvfFTp+J74WR1Ek7WYJyZ0rmL3cU4mAQzh5kr5yAMUFXjHLLaoa5R7SoKhKNVjVrRQwxEsm4hGm2NRrpACw45BnWBwwcgjyoUOTlyccUITF27atkNLfpYZNHI81dfO69vLiFh/4339S8dnn+NVhuOLF98cvFYjG9uXjM0uvqCX61e0jcwmktHYbf0YXa8M2Y0W08O9HRI+0I6p7tQWq4Vchm7w/KZj/0eyaWPrdt8zdI5+bDdIfQ8tnL1aP/GgkgSsfuXji1akoqrYslVI2PLHownX+0bGaoEQxqV2wG3SQ+b2sKRXKn8GvE6pH3iof55nUmVwHZ29Arlz1qUfR1nb0Pt62B6UTLy4U8+ENr5zyf/vCbjsKmDkVwBAsEINhXKYA/ksxkHIqrJdr3B5Vvlcxn0lWBPEB+4VCunzC5X0OUCnaR3h0JuEXYJ7nCY9VhsToPFYnDaLIgkjSqDjuPH7PQ78ak+HnbBcXeoUgm5pVFXuOGz9yDPQYxuDNSzxgLuAS1EoNuloXkD9TRoTzS98IEmgquC2v4VOUdWTi1h2SEgTSqtp9RV3Nhs1LssnA289rmD38HsgrXZk9xDGDj+YtXqm01HCx0ZM7ibOQLN5Ehzi85osJjegNsPYS5l1HfotLoNbq+zzWoxSO+2j+k3q1WufLyb0yEF8oDJZDU4jhpYtk36q9oWdeYsD2Gk0zRb3qDLabksbvtxJ/qZIWYBs5K5htnAbPkfsTtgdsgXJyoavn2Y5tUsw46JoIavXTk4ZMGEbVw2H1VrsvliDFAiWUw87Fmq3WE1r7FnixHenv2iwA67q698eAGjrrbaDBiD/fDLlsTYyoQ2NtSxU5sYG0u0zA1l3F6ovgp7bgOoiLkFmAnsFuHkboqP4uiJ3fHCnKvu+MJQ/2n1VbUW0S+cMptwMrgNjDJx7c0dV8WJNrES5wGVxuqIeYfm3P7r0fwdnxTC68U9e4I0IQDYU4HbG/pxDs+19H5Dud0wUXXwU3GYZt1uBGmdXkIV4NK9O7fPmz9/3vadYKpD9+7asrHU21vauOUCAuUyAuw52iFdnIkszMChQG/9vF/nRfha3My6e5FxviqL8NwVblW+Mt/S6NjMkZTY7FyJ5lfo/DEwcZg0oWePstulswdEaRfsFw+kK5IX3q2kJycx4zp7gGZLB2iaNDmp0BnHnKAVvTID5gDm2TYHOhk8Gavqnp51Vp9fkQ6S4WBa+vl46fTp0vhKJPUOhKR36CkfQu3j5dOny+NwuHHfpiKH5XM6KXJFtkm6KKd6ZAtN3xFgZuMBPRNjvpqopfV31coGzov1Mz+HONKhn+HRd4AcQSB5Dww0aCWJje6yFWVwQg6AVqFx93QDO477Hsf8m7EGMdHG0wxGHXpYRS+LscWK+Y2XoMOKaqbzoSjQzIeTTZteltZgGqT4Y4SECPkRzDlPVDIkTZwnphTncSz/9saQkBT4rTFnQNNsdwtJeKJzsQebzElX1yqL2exD2OdXO9o2zmG34WAVOSpNfIAEQU2OQvE8kW7FVAbxfTIhfZsp1R4abUNCo36ZjoNVZRIda5CO6Fu1tiNdxhX+FyXYf3Z4nGNgZGBgAOJNb47Mjue3+crAzfwCKBDF+XhfA4JmYGB+CRJn4GBgAvEAeqIMgAB4nGNgZGBgfsHAACH//2d+ycDIgApcAXBnBQgAeJxjYGBgYH4xdDA9AADYnCd6AAB4nGNgAIIZDBcYnjE6MEYxLmF8xaTBFMVUw9THdIPpEzMHswzzBhYNlgKWLpYrrEGsOayT2GTYlrE9Ymdgl2K3YI9hf8PhxrGBM4xzDhcTlxpXAFcKVxlXF9cMbh7SIQDoHxaseJxjYGRgYHBlSGfgYQABJiDmAkIGhv9gPgMAGrQBzwB4nHWPP07DMBjFX2haRIsQEhJiwxMLUvpnYOjYodk7dGBzGydtlcSR41bqxjE4Acdg5AicgkPwEr6hQqotOT///N4nBcAtvhCgWQGu27NZF7jk7Y87pDvhkPwo3MUAz8I9+hfhPu1MeMBmwQlBeEXzgDfhC9zgXbhD/yEckj+Fu7jHt3CP/ke4j2UQCg/wFLzqLHbbZKbzjS4WJtvn2p2qU14aV29tqcbR6FTHpjROe5Oo1VHVh2zifapSZws1t6U3eW5V5ezOrH208b6aDoep+GhtC2hkiOGwRcI/18ix4VlgAcOXPe+ar+dS5/ySbYea3qKEwhgRRmfTMdNl29Dw/CZsrHDkWePAzoTWI+U9ZcayoTBvJzfpnNvSVO3bjmZNH3F206owxZA7/ZePmOKkX1qXaMkAAAB4nG2R6W7bMBCE/cWSrThp47ptet/3obbpfadX+h40RclEJFIgKR95+hJ1ESBA9w9nBsvZWbK30VvXqPf/OmCDPgkpA4ZkbDJii21OcZodxpxhwlnOcZ5dLnCRS1zmCle5xnVucJNb3OYOd7nHfR7wkEc85glPyXnGc16wx0te8Zo3vOUd7/nARz7xmS98ZZ9vfOcHP/nFAb97W6KqnKpE0NYMhHN24fvCy4EURqo6lTPhwljOlDyc2mX+F6hi91jQplBBuUYbEdTkWO7Mv85taWvr8lZH4oaRdI3xI2lNcEIGVSTStqtUOut9UigvM7VsRfQsNtVK5b4WftaPaFDqOo5JS+18SCqn27RytmuT2BCSWpVhUGsT52XrI98b1lYU2lRZI5a60UcqaZTpshh0zYw1asvYkIu6tgtVpG10Uv1Wm7TVcxvGLl63+bQLwZrcluXOScGkTlezkHgxVyPfRJe8sAuTrWFMFuLKk+CUOvlGWWfWERFUOBQBjcWwwCOpmXHIlGX8zYKGjpYVJUfMe70/6zKeWwA=") format("woff");font-weight:400;font-style:normal}.ag-theme-balham-dark .ag-icon{font-family:agGridBalham;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ag-theme-balham-dark .ag-icon-aggregation:before{content:"\\f101"}.ag-theme-balham-dark .ag-icon-arrows:before{content:"\\f102"}.ag-theme-balham-dark .ag-icon-asc:before{content:"\\f103"}.ag-theme-balham-dark .ag-icon-cancel:before{content:"\\f104"}.ag-theme-balham-dark .ag-icon-chart:before{content:"\\f105"}.ag-theme-balham-dark .ag-icon-color-picker:before{content:"\\f109"}.ag-theme-balham-dark .ag-icon-columns:before{content:"\\f10a"}.ag-theme-balham-dark .ag-icon-contracted:before{content:"\\f10b"}.ag-theme-balham-dark .ag-icon-copy:before{content:"\\f10c"}.ag-theme-balham-dark .ag-icon-cross:before{content:"\\f10d"}.ag-theme-balham-dark .ag-icon-desc:before{content:"\\f10e"}.ag-theme-balham-dark .ag-icon-expanded:before{content:"\\f10f"}.ag-theme-balham-dark .ag-icon-eye-slash:before{content:"\\f110"}.ag-theme-balham-dark .ag-icon-eye:before{content:"\\f111"}.ag-theme-balham-dark .ag-icon-filter:before{content:"\\f112"}.ag-theme-balham-dark .ag-icon-first:before{content:"\\f113"}.ag-theme-balham-dark .ag-icon-grip:before{content:"\\f114"}.ag-theme-balham-dark .ag-icon-group:before{content:"\\f115"}.ag-theme-balham-dark .ag-icon-last:before{content:"\\f116"}.ag-theme-balham-dark .ag-icon-left:before{content:"\\f117"}.ag-theme-balham-dark .ag-icon-linked:before{content:"\\f118"}.ag-theme-balham-dark .ag-icon-loading:before{content:"\\f119"}.ag-theme-balham-dark .ag-icon-maximize:before{content:"\\f11a"}.ag-theme-balham-dark .ag-icon-menu:before{content:"\\f11b"}.ag-theme-balham-dark .ag-icon-minimize:before{content:"\\f11c"}.ag-theme-balham-dark .ag-icon-next:before{content:"\\f11d"}.ag-theme-balham-dark .ag-icon-none:before{content:"\\f11e"}.ag-theme-balham-dark .ag-icon-not-allowed:before{content:"\\f11f"}.ag-theme-balham-dark .ag-icon-paste:before{content:"\\f120"}.ag-theme-balham-dark .ag-icon-pin:before{content:"\\f121"}.ag-theme-balham-dark .ag-icon-pivot:before{content:"\\f122"}.ag-theme-balham-dark .ag-icon-previous:before{content:"\\f123"}.ag-theme-balham-dark .ag-icon-right:before{content:"\\f126"}.ag-theme-balham-dark .ag-icon-save:before{content:"\\f127"}.ag-theme-balham-dark .ag-icon-small-down:before{content:"\\f128"}.ag-theme-balham-dark .ag-icon-small-left:before{content:"\\f129"}.ag-theme-balham-dark .ag-icon-small-right:before{content:"\\f12a"}.ag-theme-balham-dark .ag-icon-small-up:before{content:"\\f12b"}.ag-theme-balham-dark .ag-icon-tick:before{content:"\\f12c"}.ag-theme-balham-dark .ag-icon-tree-closed:before{content:"\\f12d"}.ag-theme-balham-dark .ag-icon-tree-indeterminate:before{content:"\\f12e"}.ag-theme-balham-dark .ag-icon-tree-open:before{content:"\\f12f"}.ag-theme-balham-dark .ag-icon-unlinked:before{content:"\\f130"}.ag-theme-balham-dark .ag-icon-row-drag:before{content:"\\f114"}.ag-theme-balham-dark .ag-right-arrow:before{content:"\\f117";content:"\\f126"}.ag-theme-balham-dark .ag-root-wrapper{background-color:#2d3436;background-color:var(--ag-background-color,#2d3436)}.ag-theme-balham-dark [class^=ag-],.ag-theme-balham-dark [class^=ag-]:after,.ag-theme-balham-dark [class^=ag-]:before,.ag-theme-balham-dark [class^=ag-]:focus{box-sizing:border-box;outline:none}.ag-theme-balham-dark [class^=ag-]::-ms-clear{display:none}.ag-theme-balham-dark .ag-checkbox .ag-input-wrapper,.ag-theme-balham-dark .ag-radio-button .ag-input-wrapper{overflow:visible}.ag-theme-balham-dark .ag-range-field .ag-input-wrapper{height:100%}.ag-theme-balham-dark .ag-toggle-button{flex:none;width:unset;min-width:unset}.ag-theme-balham-dark .ag-ltr .ag-label-align-right .ag-label{margin-left:4px}.ag-theme-balham-dark .ag-rtl .ag-label-align-right .ag-label{margin-right:4px}.ag-theme-balham-dark input[class^=ag-]{margin:0}.ag-theme-balham-dark input[class^=ag-],.ag-theme-balham-dark select[class^=ag-],.ag-theme-balham-dark textarea[class^=ag-]{background-color:#2d3436;background-color:var(--ag-background-color,#2d3436)}.ag-theme-balham-dark input[class^=ag-]:not([type]),.ag-theme-balham-dark input[class^=ag-][type=date],.ag-theme-balham-dark input[class^=ag-][type=datetime-local],.ag-theme-balham-dark input[class^=ag-][type=number],.ag-theme-balham-dark input[class^=ag-][type=tel],.ag-theme-balham-dark input[class^=ag-][type=text],.ag-theme-balham-dark textarea[class^=ag-]{font-size:inherit;line-height:inherit;color:inherit;border:1px solid #f0f0f0;border-color:var(--ag-input-border-color,#f0f0f0)}.ag-theme-balham-dark input[class^=ag-]:not([type]):disabled,.ag-theme-balham-dark input[class^=ag-][type=date]:disabled,.ag-theme-balham-dark input[class^=ag-][type=datetime-local]:disabled,.ag-theme-balham-dark input[class^=ag-][type=number]:disabled,.ag-theme-balham-dark input[class^=ag-][type=tel]:disabled,.ag-theme-balham-dark input[class^=ag-][type=text]:disabled,.ag-theme-balham-dark textarea[class^=ag-]:disabled{color:hsla(0,0%,96.1%,.38);color:var(--ag-disabled-foreground-color,hsla(0,0%,96.1%,.38));background-color:rgba(48,46,46,.3);background-color:var(--ag-input-disabled-background-color,rgba(48,46,46,.3));border-color:hsla(0,0%,94.1%,.3);border-color:var(--ag-input-disabled-border-color,hsla(0,0%,94.1%,.3))}.ag-theme-balham-dark input[class^=ag-]:not([type]):focus,.ag-theme-balham-dark input[class^=ag-][type=date]:focus,.ag-theme-balham-dark input[class^=ag-][type=datetime-local]:focus,.ag-theme-balham-dark input[class^=ag-][type=number]:focus,.ag-theme-balham-dark input[class^=ag-][type=tel]:focus,.ag-theme-balham-dark input[class^=ag-][type=text]:focus,.ag-theme-balham-dark textarea[class^=ag-]:focus{outline:none;box-shadow:0 0 4px 1.5px #719ece;border-color:#719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham-dark input[class^=ag-][type=number]{-moz-appearance:textfield}.ag-theme-balham-dark input[class^=ag-][type=number]::-webkit-inner-spin-button,.ag-theme-balham-dark input[class^=ag-][type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.ag-theme-balham-dark input[class^=ag-][type=range]{padding:0}.ag-theme-balham-dark button[class^=ag-]:focus,.ag-theme-balham-dark input[class^=ag-][type=button]:focus{box-shadow:0 0 4px 1.5px #719ece}.ag-theme-balham-dark .ag-drag-handle{color:#f5f5f5;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#f5f5f5))}.ag-theme-balham-dark .ag-list-item,.ag-theme-balham-dark .ag-virtual-list-item{height:28px}.ag-theme-balham-dark .ag-keyboard-focus .ag-virtual-list-item:focus{outline:none}.ag-theme-balham-dark .ag-keyboard-focus .ag-virtual-list-item:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham-dark .ag-select-list{background-color:#2d3436;background-color:var(--ag-background-color,#2d3436);overflow-y:auto;overflow-x:hidden}.ag-theme-balham-dark .ag-list-item{display:flex;align-items:center}.ag-theme-balham-dark .ag-list-item.ag-active-item{background-color:#3d4749;background-color:var(--ag-row-hover-color,#3d4749)}.ag-theme-balham-dark .ag-select-list-item{padding-left:4px;padding-right:4px;cursor:default;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.ag-theme-balham-dark .ag-select-list-item span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.ag-theme-balham-dark .ag-select .ag-picker-field-wrapper{background-color:#2d3436;background-color:var(--ag-background-color,#2d3436);min-height:28px;cursor:default}.ag-theme-balham-dark .ag-select:not(.ag-cell-editor){height:28px}.ag-theme-balham-dark .ag-select .ag-picker-field-display{margin:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ag-theme-balham-dark .ag-select .ag-picker-field-icon{display:flex;align-items:center}.ag-theme-balham-dark .ag-select.ag-disabled{opacity:.5}.ag-theme-balham-dark .ag-rich-select{background-color:#202020;background-color:var(--ag-control-panel-background-color,#202020)}.ag-theme-balham-dark .ag-rich-select-list{width:100%;min-width:200px;height:182px}.ag-theme-balham-dark .ag-rich-select-value{padding:0 4px 0 12px;height:28px;border-bottom:1px solid #424242;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#424242))}.ag-theme-balham-dark .ag-rich-select-virtual-list-item{cursor:default;height:28px}.ag-theme-balham-dark .ag-rich-select-virtual-list-item:hover{background-color:#3d4749;background-color:var(--ag-row-hover-color,#3d4749)}.ag-theme-balham-dark .ag-rich-select-row{padding-left:12px}.ag-theme-balham-dark .ag-rich-select-row-selected{background-color:#005880;background-color:var(--ag-selected-row-background-color,#005880)}.ag-theme-balham-dark .ag-group-contracted,.ag-theme-balham-dark .ag-group-expanded,.ag-theme-balham-dark .ag-row-drag,.ag-theme-balham-dark .ag-selection-checkbox{color:#f5f5f5;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#f5f5f5))}.ag-theme-balham-dark .ag-ltr .ag-group-contracted,.ag-theme-balham-dark .ag-ltr .ag-group-expanded,.ag-theme-balham-dark .ag-ltr .ag-row-drag,.ag-theme-balham-dark .ag-ltr .ag-selection-checkbox{margin-right:12px}.ag-theme-balham-dark .ag-rtl .ag-group-contracted,.ag-theme-balham-dark .ag-rtl .ag-group-expanded,.ag-theme-balham-dark .ag-rtl .ag-row-drag,.ag-theme-balham-dark .ag-rtl .ag-selection-checkbox{margin-left:12px}.ag-theme-balham-dark .ag-cell-wrapper>:not(.ag-cell-value):not(.ag-group-value){height:26px;display:flex;align-items:center;flex:none}.ag-theme-balham-dark .ag-group-contracted,.ag-theme-balham-dark .ag-group-expanded{cursor:pointer}.ag-theme-balham-dark .ag-group-title-bar-icon{cursor:pointer;flex:none;color:#f5f5f5;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#f5f5f5))}.ag-theme-balham-dark .ag-ltr .ag-group-child-count{margin-left:2px}.ag-theme-balham-dark .ag-rtl .ag-group-child-count{margin-right:2px}.ag-theme-balham-dark .ag-group-title-bar{background-color:#111;background-color:var(--ag-subheader-background-color,#111);padding:4px}.ag-theme-balham-dark .ag-group-toolbar{padding:4px}.ag-theme-balham-dark .ag-disabled-group-container,.ag-theme-balham-dark .ag-disabled-group-title-bar{opacity:.5}.ag-theme-balham-dark .group-item{margin:2px 0}.ag-theme-balham-dark .ag-label{white-space:nowrap}.ag-theme-balham-dark .ag-ltr .ag-label{margin-right:4px}.ag-theme-balham-dark .ag-rtl .ag-label{margin-left:4px}.ag-theme-balham-dark .ag-label-align-top .ag-label{margin-bottom:2px}.ag-theme-balham-dark .ag-ltr .ag-angle-select-field,.ag-theme-balham-dark .ag-ltr .ag-slider-field{margin-right:8px}.ag-theme-balham-dark .ag-rtl .ag-angle-select-field,.ag-theme-balham-dark .ag-rtl .ag-slider-field{margin-left:8px}.ag-theme-balham-dark .ag-angle-select-parent-circle{width:24px;height:24px;border-radius:12px;border:1px solid #424242;border-color:var(--ag-border-color,#424242);background-color:#2d3436;background-color:var(--ag-background-color,#2d3436)}.ag-theme-balham-dark .ag-angle-select-child-circle{top:4px;left:12px;width:6px;height:6px;margin-left:-3px;margin-top:-4px;border-radius:3px;background-color:#f5f5f5;background-color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#f5f5f5))}.ag-theme-balham-dark .ag-picker-field-wrapper{border:1px solid #424242;border-color:var(--ag-border-color,#424242);border-radius:5px}.ag-theme-balham-dark .ag-picker-field-wrapper:focus{box-shadow:0 0 4px 1.5px #719ece}.ag-theme-balham-dark .ag-picker-field-button{background-color:#2d3436;background-color:var(--ag-background-color,#2d3436);color:#f5f5f5;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#f5f5f5))}.ag-theme-balham-dark .ag-dialog.ag-color-dialog{border-radius:5px}.ag-theme-balham-dark .ag-color-picker .ag-picker-field-display{height:16px}.ag-theme-balham-dark .ag-color-panel{padding:4px}.ag-theme-balham-dark .ag-spectrum-color{background-color:red;border-radius:2px}.ag-theme-balham-dark .ag-spectrum-tools{padding:10px}.ag-theme-balham-dark .ag-spectrum-sat{background-image:linear-gradient(90deg,#fff,rgba(204,154,129,0))}.ag-theme-balham-dark .ag-spectrum-val{background-image:linear-gradient(0deg,#000,rgba(204,154,129,0))}.ag-theme-balham-dark .ag-spectrum-dragger{border-radius:12px;height:12px;width:12px;border:1px solid #fff;background:#000;box-shadow:0 0 2px 0 rgba(0,0,0,.24)}.ag-theme-balham-dark .ag-spectrum-alpha-background,.ag-theme-balham-dark .ag-spectrum-hue-background{border-radius:2px}.ag-theme-balham-dark .ag-spectrum-tool{margin-bottom:10px;height:11px;border-radius:2px}.ag-theme-balham-dark .ag-spectrum-slider{margin-top:-12px;width:13px;height:13px;border-radius:13px;background-color:#f8f8f8;box-shadow:0 1px 4px 0 rgba(0,0,0,.37)}.ag-theme-balham-dark .ag-recent-color{margin:0 3px}.ag-theme-balham-dark .ag-recent-color:first-child{margin-left:0}.ag-theme-balham-dark .ag-recent-color:last-child{margin-right:0}.ag-theme-balham-dark.ag-dnd-ghost{background:#2d3436;background:var(--ag-background-color,#2d3436);border-radius:2px;box-shadow:none;overflow:hidden;text-overflow:ellipsis;z-index:10;border:1px solid #424242;border:1px solid var(--ag-secondary-border-color,var(--ag-border-color,#424242));color:#f5f5f5;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#f5f5f5));height:32px!important;line-height:32px;margin:0;padding:0 8px;-webkit-transform:translateY(8px);transform:translateY(8px)}.ag-theme-balham-dark .ag-dnd-ghost-icon{margin-right:4px;color:#f5f5f5;color:var(--ag-foreground-color,#f5f5f5)}.ag-theme-balham-dark .ag-popup-child:not(.ag-tooltip-custom){box-shadow:5px 5px 10px rgba(0,0,0,.3)}.ag-dragging-fill-handle .ag-theme-balham-dark .ag-dialog,.ag-dragging-range-handle .ag-theme-balham-dark .ag-dialog{opacity:.7;pointer-events:none}.ag-theme-balham-dark .ag-dialog{border-radius:2px;border:1px solid #424242;border-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-panel{background-color:#2d3436;background-color:var(--ag-background-color,#2d3436)}.ag-theme-balham-dark .ag-panel-title-bar{background-color:#1c1c1c;background-color:var(--ag-header-background-color,#1c1c1c);color:hsla(0,0%,96.1%,.64);color:var(--ag-header-foreground-color,hsla(0,0%,96.1%,.64));height:32px;padding:4px 12px;border-bottom:1px solid #424242;border-bottom-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-ltr .ag-panel-title-bar-button{margin-left:4px}.ag-theme-balham-dark .ag-rtl .ag-panel-title-bar-button{margin-right:4px}.ag-theme-balham-dark .ag-tooltip{background-color:#1c1c1c;background-color:var(--ag-header-background-color,#1c1c1c);color:#f5f5f5;color:var(--ag-foreground-color,#f5f5f5);padding:4px;border:1px solid #424242;border-color:var(--ag-border-color,#424242);border-radius:2px;transition:opacity 1s}.ag-theme-balham-dark .ag-tooltip.ag-tooltip-hiding{opacity:0}.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-1{padding-left:20px}.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-1{padding-right:20px}.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-2{padding-left:40px}.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-2{padding-right:40px}.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-3{padding-left:60px}.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-3{padding-right:60px}.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-4{padding-left:80px}.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-4{padding-right:80px}.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-5{padding-left:100px}.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-5{padding-right:100px}.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-6{padding-left:120px}.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-6{padding-right:120px}.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-7{padding-left:140px}.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-7{padding-right:140px}.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-8{padding-left:160px}.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-8{padding-right:160px}.ag-theme-balham-dark .ag-ltr .ag-column-select-indent-9{padding-left:180px}.ag-theme-balham-dark .ag-rtl .ag-column-select-indent-9{padding-right:180px}.ag-theme-balham-dark .ag-column-select-header-icon{cursor:pointer}.ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-header-icon:focus{outline:none}.ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-header-icon:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:0;left:0;display:block;width:100%;height:100%;border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham-dark .ag-ltr .ag-column-group-icons:not(:last-child),.ag-theme-balham-dark .ag-ltr .ag-column-select-checkbox:not(:last-child),.ag-theme-balham-dark .ag-ltr .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-balham-dark .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-balham-dark .ag-ltr .ag-column-select-column-label:not(:last-child),.ag-theme-balham-dark .ag-ltr .ag-column-select-header-checkbox:not(:last-child),.ag-theme-balham-dark .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-balham-dark .ag-ltr .ag-column-select-header-icon:not(:last-child){margin-right:6px}.ag-theme-balham-dark .ag-rtl .ag-column-group-icons:not(:last-child),.ag-theme-balham-dark .ag-rtl .ag-column-select-checkbox:not(:last-child),.ag-theme-balham-dark .ag-rtl .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-balham-dark .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-balham-dark .ag-rtl .ag-column-select-column-label:not(:last-child),.ag-theme-balham-dark .ag-rtl .ag-column-select-header-checkbox:not(:last-child),.ag-theme-balham-dark .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-balham-dark .ag-rtl .ag-column-select-header-icon:not(:last-child){margin-left:6px}.ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-column-group:focus{outline:none}.ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-column-group:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-2px;left:-2px;display:block;width:calc(100% - -4px);height:calc(100% - -4px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-column:focus{outline:none}.ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-column:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-2px;left:-2px;display:block;width:calc(100% - -4px);height:calc(100% - -4px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham-dark .ag-column-select-column-group:not(:last-child),.ag-theme-balham-dark .ag-column-select-column:not(:last-child){margin-bottom:4px}.ag-theme-balham-dark .ag-column-select-column-group-readonly,.ag-theme-balham-dark .ag-column-select-column-readonly{color:hsla(0,0%,96.1%,.38);color:var(--ag-disabled-foreground-color,hsla(0,0%,96.1%,.38));pointer-events:none}.ag-theme-balham-dark .ag-ltr .ag-column-select-add-group-indent{margin-left:24px}.ag-theme-balham-dark .ag-rtl .ag-column-select-add-group-indent{margin-right:24px}.ag-theme-balham-dark .ag-column-select-list{padding:6px}.ag-theme-balham-dark .ag-rtl{text-align:right}.ag-theme-balham-dark .ag-root-wrapper{border:1px solid #424242;border-color:var(--ag-border-color,#424242);border-radius:2px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-left:40px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-right:40px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-1{padding-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-1{padding-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-left:68px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-right:68px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-2{padding-left:56px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-2{padding-right:56px}.ag-theme-balham-dark .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-left:96px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-right:96px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-3{padding-left:84px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-3{padding-right:84px}.ag-theme-balham-dark .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-left:124px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-right:124px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-4{padding-left:112px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-4{padding-right:112px}.ag-theme-balham-dark .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-left:152px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-right:152px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-5{padding-left:140px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-5{padding-right:140px}.ag-theme-balham-dark .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-left:180px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-right:180px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-6{padding-left:168px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-6{padding-right:168px}.ag-theme-balham-dark .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-left:208px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-right:208px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-7{padding-left:196px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-7{padding-right:196px}.ag-theme-balham-dark .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-left:236px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-right:236px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-8{padding-left:224px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-8{padding-right:224px}.ag-theme-balham-dark .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-left:264px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-right:264px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-9{padding-left:252px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-9{padding-right:252px}.ag-theme-balham-dark .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-left:292px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-right:292px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-10{padding-left:280px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-10{padding-right:280px}.ag-theme-balham-dark .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-left:320px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-right:320px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-11{padding-left:308px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-11{padding-right:308px}.ag-theme-balham-dark .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-left:348px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-right:348px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-12{padding-left:336px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-12{padding-right:336px}.ag-theme-balham-dark .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-left:376px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-right:376px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-13{padding-left:364px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-13{padding-right:364px}.ag-theme-balham-dark .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-left:404px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-right:404px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-14{padding-left:392px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-14{padding-right:392px}.ag-theme-balham-dark .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-left:432px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-right:432px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-15{padding-left:420px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-15{padding-right:420px}.ag-theme-balham-dark .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-left:460px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-right:460px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-16{padding-left:448px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-16{padding-right:448px}.ag-theme-balham-dark .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-left:488px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-right:488px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-17{padding-left:476px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-17{padding-right:476px}.ag-theme-balham-dark .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-left:516px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-right:516px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-18{padding-left:504px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-18{padding-right:504px}.ag-theme-balham-dark .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-left:544px}.ag-theme-balham-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-right:544px}.ag-theme-balham-dark .ag-ltr .ag-row-group-indent-19{padding-left:532px}.ag-theme-balham-dark .ag-rtl .ag-row-group-indent-19{padding-right:532px}.ag-theme-balham-dark .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham-dark .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham-dark .ag-cell{-webkit-font-smoothing:subpixel-antialiased}.ag-theme-balham-dark .ag-value-change-delta{padding-right:2px}.ag-theme-balham-dark .ag-value-change-delta-up{color:#43a047;color:var(--ag-value-change-delta-up-color,#43a047)}.ag-theme-balham-dark .ag-value-change-delta-down{color:#e53935;color:var(--ag-value-change-delta-down-color,#e53935)}.ag-theme-balham-dark .ag-value-change-value{background-color:transparent;border-radius:1px;padding-left:1px;padding-right:1px;transition:background-color 1s}.ag-theme-balham-dark .ag-value-change-value-highlight{background-color:rgba(22,160,133,.5);background-color:var(--ag-value-change-value-highlight-background-color,rgba(22,160,133,.5));transition:background-color .1s}.ag-theme-balham-dark .ag-cell-data-changed{background-color:rgba(22,160,133,.5)!important;background-color:var(--ag-value-change-value-highlight-background-color,rgba(22,160,133,.5))!important}.ag-theme-balham-dark .ag-cell-data-changed-animation{background-color:transparent}.ag-theme-balham-dark .ag-cell-highlight{background-color:#00b0ff!important;background-color:var(--ag-range-selection-highlight-color,var(--ag-balham-active-color,#00b0ff))!important}.ag-theme-balham-dark .ag-row{height:28px;background-color:#2d3436;background-color:var(--ag-background-color,#2d3436);color:#f5f5f5;color:var(--ag-data-color,var(--ag-foreground-color,#f5f5f5));border-width:1px;border-color:#5c5c5c;border-color:var(--ag-row-border-color,#5c5c5c)}.ag-theme-balham-dark .ag-row:not(.ag-row-first){border-top-style:solid}.ag-theme-balham-dark .ag-row.ag-row-last{border-bottom-style:solid}.ag-theme-balham-dark .ag-row-highlight-above:after,.ag-theme-balham-dark .ag-row-highlight-below:after{content:"";position:absolute;width:calc(100% - 1px);height:1px;background-color:#00b0ff;background-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#00b0ff));left:1px}.ag-theme-balham-dark .ag-row-highlight-above:after{top:-1px}.ag-theme-balham-dark .ag-row-highlight-above.ag-row-first:after{top:0}.ag-theme-balham-dark .ag-row-highlight-below:after{bottom:0}.ag-theme-balham-dark .ag-row-odd{background-color:#262c2e;background-color:var(--ag-odd-row-background-color,#262c2e)}.ag-theme-balham-dark .ag-horizontal-left-spacer:not(.ag-scroller-corner){border-right:1px solid #424242;border-right-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-horizontal-right-spacer:not(.ag-scroller-corner){border-left:1px solid #424242;border-left-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-row-hover{background-color:#3d4749;background-color:var(--ag-row-hover-color,#3d4749)}.ag-theme-balham-dark .ag-ltr .ag-right-aligned-cell{text-align:right}.ag-theme-balham-dark .ag-rtl .ag-right-aligned-cell{text-align:left}.ag-theme-balham-dark .ag-ltr .ag-right-aligned-cell .ag-cell-value{margin-left:auto}.ag-theme-balham-dark .ag-rtl .ag-right-aligned-cell .ag-cell-value{margin-right:auto}.ag-theme-balham-dark .ag-cell{border:1px solid transparent;line-height:26px}.ag-theme-balham-dark .ag-cell,.ag-theme-balham-dark .ag-row>.ag-cell-wrapper{padding-left:11px;padding-right:11px}.ag-theme-balham-dark .ag-row-dragging{cursor:move;opacity:.5}.ag-theme-balham-dark .ag-cell-inline-editing{height:28px}.ag-theme-balham-dark .ag-cell-inline-editing,.ag-theme-balham-dark .ag-popup-editor{border:1px solid #424242;border-color:var(--ag-border-color,#424242);background:#2d3436;background:var(--ag-background-color,#2d3436);border-radius:2px;box-shadow:none;padding:0;background-color:#202020;background-color:var(--ag-control-panel-background-color,#202020)}.ag-theme-balham-dark .ag-large-text-input{height:auto;padding:12px}.ag-theme-balham-dark .ag-details-row{padding:20px;background-color:#2d3436;background-color:var(--ag-background-color,#2d3436)}.ag-theme-balham-dark .ag-overlay-loading-wrapper{background-color:rgba(45,52,54,.66);background-color:var(--ag-modal-overlay-background-color,rgba(45,52,54,.66))}.ag-theme-balham-dark .ag-overlay-loading-center{background:#2d3436;background:var(--ag-background-color,#2d3436);border-radius:2px;box-shadow:none;padding:4px}.ag-theme-balham-dark .ag-overlay-no-rows-wrapper.ag-layout-auto-height{padding-top:30px}.ag-theme-balham-dark .ag-loading{padding-left:12px;display:flex;height:100%;align-items:center}.ag-theme-balham-dark .ag-loading-icon{padding-right:12px}.ag-theme-balham-dark .ag-icon-loading{-webkit-animation-name:spin;animation-name:spin;-webkit-animation-duration:1s;animation-duration:1s;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite;-webkit-animation-timing-function:linear;animation-timing-function:linear}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}.ag-theme-balham-dark .ag-floating-top{border-bottom:1px solid #424242;border-bottom-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-floating-bottom{border-top:1px solid #424242;border-top-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-ltr .ag-cell{border-right:solid transparent}.ag-theme-balham-dark .ag-rtl .ag-cell{border-left:solid transparent}.ag-theme-balham-dark .ag-ltr .ag-cell{border-right-width:1px}.ag-theme-balham-dark .ag-rtl .ag-cell{border-left-width:1px}.ag-theme-balham-dark .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell){border-left:1px solid #424242;border-left-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell){border-right:1px solid #424242;border-right-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-row-selected{background-color:#005880;background-color:var(--ag-selected-row-background-color,#005880)}.ag-theme-balham-dark .ag-cell-range-selected:not(.ag-cell-focus){background-color:rgba(0,176,255,.2);background-color:var(--ag-range-selection-background-color,rgba(0,176,255,.2))}.ag-theme-balham-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart{background-color:rgba(45,166,255,.5);background-color:var(--ag-range-selection-chart-background-color,rgba(45,166,255,.5))}.ag-theme-balham-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category{background-color:rgba(26,177,74,.5);background-color:var(--ag-range-selection-chart-category-background-color,rgba(26,177,74,.5))}.ag-theme-balham-dark .ag-cell-range-selected-1:not(.ag-cell-focus){background-color:rgba(0,176,255,.2);background-color:var(--ag-range-selection-background-color-1,var(--ag-range-selection-background-color,rgba(0,176,255,.2)))}.ag-theme-balham-dark .ag-cell-range-selected-2:not(.ag-cell-focus){background-color:rgba(0,176,255,.36);background-color:var(--ag-range-selection-background-color-2,rgba(0,176,255,.36))}.ag-theme-balham-dark .ag-cell-range-selected-3:not(.ag-cell-focus){background-color:rgba(0,176,255,.488);background-color:var(--ag-range-selection-background-color-3,rgba(0,176,255,.488))}.ag-theme-balham-dark .ag-cell-range-selected-4:not(.ag-cell-focus){background-color:rgba(0,176,255,.5904);background-color:var(--ag-range-selection-background-color-4,rgba(0,176,255,.5904))}.ag-theme-balham-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top{border-top-color:#00b0ff;border-top-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#00b0ff))}.ag-theme-balham-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right{border-right-color:#00b0ff;border-right-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#00b0ff))}.ag-theme-balham-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom{border-bottom-color:#00b0ff;border-bottom-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#00b0ff))}.ag-theme-balham-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left{border-left-color:#00b0ff;border-left-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#00b0ff))}.ag-theme-balham-dark .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-balham-dark .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-balham-dark .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),.ag-theme-balham-dark .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-balham-dark .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-balham-dark .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected){border:1px solid #00b0ff;border-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#00b0ff));outline:initial}.ag-theme-balham-dark .ag-cell.ag-selection-fill-top,.ag-theme-balham-dark .ag-cell.ag-selection-fill-top.ag-cell-range-selected{border-top:1px dashed #00b0ff;border-top-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#00b0ff))}.ag-theme-balham-dark .ag-ltr .ag-cell.ag-selection-fill-right,.ag-theme-balham-dark .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-right:1px dashed #00b0ff;border-right-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#00b0ff))}.ag-theme-balham-dark .ag-rtl .ag-cell.ag-selection-fill-right,.ag-theme-balham-dark .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-left:1px dashed #00b0ff;border-left-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#00b0ff))}.ag-theme-balham-dark .ag-cell.ag-selection-fill-bottom,.ag-theme-balham-dark .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected{border-bottom:1px dashed #00b0ff;border-bottom-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#00b0ff))}.ag-theme-balham-dark .ag-ltr .ag-cell.ag-selection-fill-left,.ag-theme-balham-dark .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-left:1px dashed #00b0ff;border-left-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#00b0ff))}.ag-theme-balham-dark .ag-rtl .ag-cell.ag-selection-fill-left,.ag-theme-balham-dark .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-right:1px dashed #00b0ff;border-right-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#00b0ff))}.ag-theme-balham-dark .ag-fill-handle,.ag-theme-balham-dark .ag-range-handle{position:absolute;width:6px;height:6px;bottom:-1px;background-color:#00b0ff;background-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#00b0ff))}.ag-theme-balham-dark .ag-ltr .ag-fill-handle,.ag-theme-balham-dark .ag-ltr .ag-range-handle{right:-1px}.ag-theme-balham-dark .ag-rtl .ag-fill-handle,.ag-theme-balham-dark .ag-rtl .ag-range-handle{left:-1px}.ag-theme-balham-dark .ag-fill-handle{cursor:cell}.ag-theme-balham-dark .ag-range-handle{cursor:nwse-resize}.ag-theme-balham-dark .ag-cell-inline-editing{border-color:#719ece!important;border-color:var(--ag-input-focus-border-color,#719ece)!important}.ag-theme-balham-dark .ag-menu{border:1px solid #424242;border-color:var(--ag-border-color,#424242);background:#2d3436;background:var(--ag-background-color,#2d3436);border-radius:2px;box-shadow:none;padding:0}.ag-theme-balham-dark .ag-menu-list{cursor:default;width:100%;padding-top:4px;padding-bottom:4px}.ag-theme-balham-dark .ag-menu-option-part{padding-top:6px;padding-bottom:6px;line-height:16px}.ag-theme-balham-dark .ag-menu-option-active{background-color:#3d4749;background-color:var(--ag-row-hover-color,#3d4749)}.ag-theme-balham-dark .ag-menu-option-disabled{opacity:.5}.ag-theme-balham-dark .ag-menu-option-text{margin-left:4px}.ag-theme-balham-dark .ag-menu-option-icon{padding-left:8px;padding-right:4px;min-width:24px}.ag-theme-balham-dark .ag-menu-option-shortcut{padding-left:8px}.ag-theme-balham-dark .ag-menu-separator{height:8px}.ag-theme-balham-dark .ag-menu-separator-cell:after{content:"";display:block;border-top:1px solid #424242;border-top-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-menu-option-popup-pointer{width:24px;text-align:center}.ag-theme-balham-dark .ag-tabs-header{min-width:220px;width:100%;display:flex}.ag-theme-balham-dark .ag-tab{border-bottom:0 solid transparent;display:flex;flex:none;align-items:center;justify-content:center;cursor:pointer}.ag-theme-balham-dark .ag-keyboard-focus .ag-tab:focus{outline:none}.ag-theme-balham-dark .ag-keyboard-focus .ag-tab:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham-dark .ag-tab-selected{border-bottom-color:#00b0ff;border-bottom-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-balham-active-color,#00b0ff)))}.ag-theme-balham-dark .ag-menu-header{color:#f5f5f5;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#f5f5f5))}.ag-theme-balham-dark .ag-filter-condition-operator{height:17px}.ag-theme-balham-dark .ag-ltr .ag-filter-condition-operator-or{margin-left:8px}.ag-theme-balham-dark .ag-rtl .ag-filter-condition-operator-or{margin-right:8px}.ag-theme-balham-dark .ag-set-filter-select-all{padding-top:6px}.ag-theme-balham-dark .ag-set-filter-list{height:168px}.ag-theme-balham-dark .ag-set-filter-filter{margin-top:6px;margin-left:6px;margin-right:6px}.ag-theme-balham-dark .ag-filter-to{margin-top:4px}.ag-theme-balham-dark .ag-mini-filter{margin:6px 6px 0}.ag-theme-balham-dark .ag-set-filter-item{margin:0 6px}.ag-theme-balham-dark .ag-ltr .ag-set-filter-item-value{margin-left:6px}.ag-theme-balham-dark .ag-rtl .ag-set-filter-item-value{margin-right:6px}.ag-theme-balham-dark .ag-filter-header-container{padding-bottom:6px;border-bottom:1px solid #424242;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#424242))}.ag-theme-balham-dark .ag-filter-apply-panel{padding:6px;border-top:1px solid #424242;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#424242))}.ag-theme-balham-dark .ag-filter-apply-panel-button{line-height:1.5}.ag-theme-balham-dark .ag-ltr .ag-filter-apply-panel-button{margin-left:8px}.ag-theme-balham-dark .ag-rtl .ag-filter-apply-panel-button{margin-right:8px}.ag-theme-balham-dark .ag-simple-filter-body-wrapper{padding:6px 6px 2px}.ag-theme-balham-dark .ag-simple-filter-body-wrapper>*{margin-bottom:4px}.ag-theme-balham-dark .ag-filter-no-matches{margin:6px}.ag-theme-balham-dark .ag-side-bar{position:relative}.ag-theme-balham-dark .ag-tool-panel-wrapper{background-color:#202020;background-color:var(--ag-control-panel-background-color,#202020)}.ag-theme-balham-dark .ag-side-buttons{padding-top:16px;width:20px;position:relative;color:#f5f5f5;color:var(--ag-foreground-color,#f5f5f5);overflow:hidden}.ag-theme-balham-dark button.ag-side-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;background:transparent;padding:8px 0;width:calc(100% + 1px);margin:0;min-height:72px;background-position-y:center;background-position-x:center;background-repeat:no-repeat;border-left:none;border-right:none;border-top:#424242;border-top:1px solid var(--ag-border-color,#424242);border-bottom:#424242;border-bottom:1px solid var(--ag-border-color,#424242)}.ag-theme-balham-dark button.ag-side-button-button:focus{box-shadow:none}.ag-theme-balham-dark .ag-keyboard-focus .ag-side-button-button:focus{outline:none}.ag-theme-balham-dark .ag-keyboard-focus .ag-side-button-button:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham-dark .ag-selected .ag-side-button-button{background-color:#202020;background-color:var(--ag-control-panel-background-color,#202020);border-top-color:#424242;border-top-color:var(--ag-border-color,#424242);border-bottom-color:#424242;border-bottom-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-side-button-icon-wrapper{margin-bottom:3px}.ag-theme-balham-dark .ag-ltr .ag-side-bar-left,.ag-theme-balham-dark .ag-rtl .ag-side-bar-right{border-right:1px solid #424242;border-right-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,.ag-theme-balham-dark .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper{border-left:1px solid #424242;border-left-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-ltr .ag-side-bar-left .ag-side-button-button,.ag-theme-balham-dark .ag-rtl .ag-side-bar-right .ag-side-button-button{border-right:0 solid transparent;margin-right:-1px;padding-right:1px}.ag-theme-balham-dark .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,.ag-theme-balham-dark .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button{border-right-color:#00b0ff;border-right-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-balham-active-color,#00b0ff)))}.ag-theme-balham-dark .ag-ltr .ag-side-bar-right,.ag-theme-balham-dark .ag-rtl .ag-side-bar-left{border-left:1px solid #424242;border-left-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper,.ag-theme-balham-dark .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper{border-right:1px solid #424242;border-right-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-ltr .ag-side-bar-right .ag-side-button-button,.ag-theme-balham-dark .ag-rtl .ag-side-bar-left .ag-side-button-button{border-left:0 solid transparent;margin-left:-1px;padding-left:1px}.ag-theme-balham-dark .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button,.ag-theme-balham-dark .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button{border-left-color:#00b0ff;border-left-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-balham-active-color,#00b0ff)))}.ag-theme-balham-dark .ag-filter-toolpanel-header{height:24px}.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-header,.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-search{padding-left:4px}.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-header,.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-search{padding-right:4px}.ag-theme-balham-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus{outline:none}.ag-theme-balham-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham-dark .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{font-family:agGridBalham;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;content:"\\f112";position:absolute}.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-left:4px}.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-right:4px}.ag-theme-balham-dark .ag-filter-toolpanel-group-level-0-header{height:32px}.ag-theme-balham-dark .ag-filter-toolpanel-group-item{margin-top:2px;margin-bottom:2px}.ag-theme-balham-dark .ag-filter-toolpanel-search{height:32px}.ag-theme-balham-dark .ag-filter-toolpanel-search-input{flex-grow:1;height:16px}.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-search-input{margin-right:4px}.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-search-input{margin-left:4px}.ag-theme-balham-dark .ag-filter-toolpanel-group-level-0{border-top:1px solid #424242;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#424242))}.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-expand,.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-title-bar-icon{margin-right:4px}.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-expand,.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-title-bar-icon{margin-left:4px}.ag-theme-balham-dark .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-left:20px}.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-right:20px}.ag-theme-balham-dark .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-left:36px}.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-right:36px}.ag-theme-balham-dark .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-left:52px}.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-right:52px}.ag-theme-balham-dark .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-left:68px}.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-right:68px}.ag-theme-balham-dark .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-left:84px}.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-right:84px}.ag-theme-balham-dark .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-left:100px}.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-right:100px}.ag-theme-balham-dark .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-left:116px}.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-right:116px}.ag-theme-balham-dark .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-left:132px}.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-right:132px}.ag-theme-balham-dark .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-left:148px}.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-right:148px}.ag-theme-balham-dark .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-left:164px}.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-right:164px}.ag-theme-balham-dark .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header{padding-left:4px}.ag-theme-balham-dark .ag-filter-toolpanel-instance-filter{border-top:1px solid #424242;border-top-color:var(--ag-border-color,#424242);border-bottom:1px solid #424242;border-bottom-color:var(--ag-border-color,#424242);padding-top:4px}.ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-instance-header-icon{margin-left:4px}.ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-instance-header-icon{margin-right:4px}.ag-theme-balham-dark .ag-pivot-mode-panel{height:32px;display:flex}.ag-theme-balham-dark .ag-pivot-mode-select{display:flex;align-items:center}.ag-theme-balham-dark .ag-ltr .ag-pivot-mode-select{margin-left:6px}.ag-theme-balham-dark .ag-rtl .ag-pivot-mode-select{margin-right:6px}.ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-header:focus{outline:none}.ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham-dark .ag-column-select-header{height:32px;align-items:center;padding:0 6px}.ag-theme-balham-dark .ag-column-panel-column-select,.ag-theme-balham-dark .ag-column-select-header{border-bottom:1px solid #424242;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#424242))}.ag-theme-balham-dark .ag-column-panel-column-select{border-top:1px solid #424242;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#424242))}.ag-theme-balham-dark .ag-column-group-icons,.ag-theme-balham-dark .ag-column-select-header-icon{color:#f5f5f5;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#f5f5f5))}.ag-theme-balham-dark .ag-header{background-color:#1c1c1c;background-color:var(--ag-header-background-color,#1c1c1c);border-bottom:1px solid #424242;border-bottom-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-header-row{color:hsla(0,0%,96.1%,.64);color:var(--ag-header-foreground-color,hsla(0,0%,96.1%,.64))}.ag-theme-balham-dark .ag-pinned-right-header{border-left:1px solid #424242;border-left-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-pinned-left-header{border-right:1px solid #424242;border-right-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-header-row{height:32px}.ag-theme-balham-dark .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-left:4px}.ag-theme-balham-dark .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon,.ag-theme-balham-dark .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-right:4px}.ag-theme-balham-dark .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon{margin-left:4px}.ag-theme-balham-dark .ag-header-cell,.ag-theme-balham-dark .ag-header-group-cell{padding-left:12px;padding-right:12px}.ag-theme-balham-dark .ag-header-cell.ag-header-cell-moving,.ag-theme-balham-dark .ag-header-group-cell.ag-header-cell-moving{background-color:#2d3436;background-color:var(--ag-header-cell-moving-background-color,var(--ag-background-color,#2d3436))}.ag-theme-balham-dark .ag-keyboard-focus .ag-header-cell:focus{outline:none}.ag-theme-balham-dark .ag-keyboard-focus .ag-header-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham-dark .ag-keyboard-focus .ag-header-group-cell:focus{outline:none}.ag-theme-balham-dark .ag-keyboard-focus .ag-header-group-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham-dark .ag-header-icon{color:#f5f5f5;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#f5f5f5))}.ag-theme-balham-dark .ag-header-expand-icon{cursor:pointer}.ag-theme-balham-dark .ag-ltr .ag-header-expand-icon{padding-left:4px}.ag-theme-balham-dark .ag-rtl .ag-header-expand-icon{padding-right:4px}.ag-theme-balham-dark .ag-header-row:not(:first-child) .ag-header-cell,.ag-theme-balham-dark .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group{border-top:1px solid #424242;border-top-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-header-cell:after,.ag-theme-balham-dark .ag-header-group-cell:after{content:"";position:absolute;z-index:1;display:block;width:1px;height:50%;top:25%;background-color:rgba(66,66,66,.5);background-color:var(--ag-header-column-separator-color,rgba(66,66,66,.5))}.ag-theme-balham-dark .ag-ltr .ag-header-cell:after,.ag-theme-balham-dark .ag-ltr .ag-header-group-cell:after{right:0}.ag-theme-balham-dark .ag-rtl .ag-header-cell:after,.ag-theme-balham-dark .ag-rtl .ag-header-group-cell:after{left:0}.ag-theme-balham-dark .ag-ltr .ag-header-select-all{margin-right:12px}.ag-theme-balham-dark .ag-ltr .ag-floating-filter-button,.ag-theme-balham-dark .ag-rtl .ag-header-select-all{margin-left:12px}.ag-theme-balham-dark .ag-rtl .ag-floating-filter-button{margin-right:12px}.ag-theme-balham-dark .ag-floating-filter-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;height:16px;padding:0;width:16px}.ag-theme-balham-dark .ag-filter-loading{background-color:#202020;background-color:var(--ag-control-panel-background-color,#202020);height:100%;padding:6px;position:absolute;width:100%;z-index:1}.ag-theme-balham-dark .ag-paging-panel{border-top:1px solid #424242;border-top-color:var(--ag-border-color,#424242);color:#f5f5f5;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#f5f5f5));height:32px}.ag-theme-balham-dark .ag-paging-panel>*{margin:0 12px}.ag-theme-balham-dark .ag-paging-button{cursor:pointer;opacity:0;top:0;right:0;bottom:0;left:0;padding:0;width:16px}.ag-theme-balham-dark .ag-disabled .ag-paging-button{cursor:default}.ag-theme-balham-dark .ag-paging-button-wrapper.ag-disabled{color:hsla(0,0%,96.1%,.38);color:var(--ag-disabled-foreground-color,hsla(0,0%,96.1%,.38));cursor:default}.ag-theme-balham-dark .ag-paging-button-wrapper,.ag-theme-balham-dark .ag-paging-description{margin:0 4px}.ag-theme-balham-dark .ag-status-bar{border-top:1px solid #424242;border-top-color:var(--ag-border-color,#424242);color:hsla(0,0%,96.1%,.38);color:var(--ag-disabled-foreground-color,hsla(0,0%,96.1%,.38));padding-right:16px;padding-left:16px;line-height:1.5}.ag-theme-balham-dark .ag-status-name-value-value{color:#f5f5f5;color:var(--ag-foreground-color,#f5f5f5)}.ag-theme-balham-dark .ag-status-bar-center{text-align:center}.ag-theme-balham-dark .ag-status-name-value{margin-left:4px;margin-right:4px;padding-top:8px;padding-bottom:8px}.ag-theme-balham-dark .ag-column-drop-cell{background:#353535;background:var(--ag-chip-background-color,#353535);border-radius:16px;height:16px;padding:0 2px}.ag-theme-balham-dark .ag-column-drop-cell-text{margin:0 4px}.ag-theme-balham-dark .ag-column-drop-cell-button{min-width:16px;margin:0 2px;color:#f5f5f5;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#f5f5f5))}.ag-theme-balham-dark .ag-column-drop-cell-drag-handle{margin-left:8px}.ag-theme-balham-dark .ag-column-drop-cell-ghost{opacity:.5}.ag-theme-balham-dark .ag-column-drop-horizontal{background-color:#202020;background-color:var(--ag-control-panel-background-color,#202020);color:#f5f5f5;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#f5f5f5));height:28px;border-bottom:1px solid #424242;border-bottom-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-ltr .ag-column-drop-horizontal{padding-left:12px}.ag-theme-balham-dark .ag-rtl .ag-column-drop-horizontal{padding-right:12px}.ag-theme-balham-dark .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child){border-right:1px solid #424242;border-right-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child){border-left:1px solid #424242;border-left-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-column-drop-horizontal-cell-separator{margin:0 4px;color:#f5f5f5;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#f5f5f5))}.ag-theme-balham-dark .ag-column-drop-horizontal-empty-message{color:hsla(0,0%,96.1%,.38);color:var(--ag-disabled-foreground-color,hsla(0,0%,96.1%,.38))}.ag-theme-balham-dark .ag-ltr .ag-column-drop-horizontal-icon{margin-right:12px}.ag-theme-balham-dark .ag-rtl .ag-column-drop-horizontal-icon{margin-left:12px}.ag-theme-balham-dark .ag-column-drop-vertical-list{padding-bottom:4px;padding-right:4px;padding-left:4px}.ag-theme-balham-dark .ag-column-drop-vertical-cell{margin-top:4px}.ag-theme-balham-dark .ag-column-drop-vertical{min-height:50px;max-height:150px;border-bottom:1px solid #424242;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#424242))}.ag-theme-balham-dark .ag-column-drop-vertical.ag-last-column-drop{border-bottom:none}.ag-theme-balham-dark .ag-column-drop-vertical-icon{margin-left:4px;margin-right:4px}.ag-theme-balham-dark .ag-column-drop-vertical-list{position:relative}.ag-theme-balham-dark .ag-column-drop-vertical-empty-message{position:absolute;top:0;bottom:0;left:0;right:0;overflow:hidden;color:hsla(0,0%,96.1%,.38);color:var(--ag-disabled-foreground-color,hsla(0,0%,96.1%,.38));margin-top:4px}.ag-theme-balham-dark .ag-select-agg-func-popup{border:1px solid #424242;border-color:var(--ag-border-color,#424242);border-radius:2px;box-shadow:none;background:#2d3436;background:var(--ag-background-color,#2d3436);height:70px;padding:0}.ag-theme-balham-dark .ag-select-agg-func-virtual-list-item{cursor:default;line-height:20px;padding-left:8px}.ag-theme-balham-dark .ag-select-agg-func-virtual-list-item:hover{background-color:#005880;background-color:var(--ag-selected-row-background-color,#005880)}.ag-theme-balham-dark .ag-chart-menu{border-radius:2px;background:#2d3436;background:var(--ag-background-color,#2d3436)}.ag-theme-balham-dark .ag-chart-menu-icon{opacity:.5;line-height:24px;font-size:24px;width:24px;height:24px;margin:2px 0;cursor:pointer;border-radius:2px;color:#f5f5f5;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#f5f5f5))}.ag-theme-balham-dark .ag-chart-menu-icon:hover{opacity:1}.ag-theme-balham-dark .ag-chart-mini-thumbnail{border:1px solid #424242;border-color:var(--ag-secondary-border-color,var(--ag-border-color,#424242));border-radius:5px;margin:5px}.ag-theme-balham-dark .ag-chart-mini-thumbnail:nth-last-child(3),.ag-theme-balham-dark .ag-chart-mini-thumbnail:nth-last-child(3)~.ag-chart-mini-thumbnail{margin-left:auto;margin-right:auto}.ag-theme-balham-dark .ag-ltr .ag-chart-mini-thumbnail:first-child{margin-left:0}.ag-theme-balham-dark .ag-ltr .ag-chart-mini-thumbnail:last-child,.ag-theme-balham-dark .ag-rtl .ag-chart-mini-thumbnail:first-child{margin-right:0}.ag-theme-balham-dark .ag-rtl .ag-chart-mini-thumbnail:last-child{margin-left:0}.ag-theme-balham-dark .ag-chart-mini-thumbnail.ag-selected{border-color:#00b0ff;border-color:var(--ag-minichart-selected-chart-color,var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#00b0ff)))}.ag-theme-balham-dark .ag-chart-settings-card-item{background:#f5f5f5;background:var(--ag-foreground-color,#f5f5f5);width:8px;height:8px;border-radius:4px}.ag-theme-balham-dark .ag-chart-settings-card-item.ag-selected{background-color:#00b0ff;background-color:var(--ag-minichart-selected-page-color,var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#00b0ff)))}.ag-theme-balham-dark .ag-chart-data-column-drag-handle{margin-left:4px}.ag-theme-balham-dark .ag-charts-data-group-title-bar,.ag-theme-balham-dark .ag-charts-format-top-level-group-title-bar,.ag-theme-balham-dark .ag-charts-settings-group-title-bar{border-top:1px solid #424242;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#424242))}.ag-theme-balham-dark .ag-charts-settings-group-container{padding:4px}.ag-theme-balham-dark .ag-charts-data-group-container{padding:6px 6px 2px}.ag-theme-balham-dark .ag-charts-data-group-container>*{margin-bottom:4px}.ag-theme-balham-dark .ag-charts-format-top-level-group-container{margin-left:8px;padding:4px}.ag-theme-balham-dark .ag-charts-format-top-level-group-item{margin:4px 0}.ag-theme-balham-dark .ag-charts-format-sub-level-group-container{padding:6px 6px 2px}.ag-theme-balham-dark .ag-charts-format-sub-level-group-container>*{margin-bottom:4px}.ag-theme-balham-dark .ag-charts-group-container.ag-group-container-horizontal{padding:4px}.ag-theme-balham-dark .ag-chart-data-section,.ag-theme-balham-dark .ag-chart-format-section{display:flex;margin:0}.ag-theme-balham-dark .ag-chart-menu-panel{background-color:#202020;background-color:var(--ag-control-panel-background-color,#202020)}.ag-theme-balham-dark .ag-ltr .ag-chart-menu-panel{border-left:1px solid #424242;border-left-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-rtl .ag-chart-menu-panel{border-right:1px solid #424242;border-right-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-date-time-list-page-title{flex-grow:1;text-align:center}.ag-theme-balham-dark .ag-date-time-list-page-column-label,.ag-theme-balham-dark .ag-date-time-list-page-entry{text-align:center}.ag-theme-balham-dark .ag-checkbox-input-wrapper{font-family:agGridBalham;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:16px;height:16px;background-color:#2d3436;background-color:var(--ag-checkbox-background-color,var(--ag-background-color,#2d3436));border-radius:3px;display:inline-block;vertical-align:middle;flex:none}.ag-theme-balham-dark .ag-checkbox-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-balham-dark .ag-checkbox-input-wrapper:active,.ag-theme-balham-dark .ag-checkbox-input-wrapper:focus-within{outline:none;box-shadow:0 0 4px 1.5px #719ece}.ag-theme-balham-dark .ag-checkbox-input-wrapper.ag-disabled{opacity:.5}.ag-theme-balham-dark .ag-checkbox-input-wrapper:after{content:"\\f108";color:#ecf0f1;color:var(--ag-checkbox-unchecked-color,#ecf0f1);position:absolute;top:0;left:0;pointer-events:none}.ag-theme-balham-dark .ag-checkbox-input-wrapper.ag-checked:after{content:"\\f106";color:#00b0ff;color:var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#00b0ff));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-balham-dark .ag-checkbox-input-wrapper.ag-indeterminate:after{content:"\\f107";color:#ecf0f1;color:var(--ag-checkbox-indeterminate-color,var(--ag-checkbox-unchecked-color,#ecf0f1));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-balham-dark .ag-toggle-button-input-wrapper{box-sizing:border-box;width:32px;height:16px;background-color:transparent;background-color:var(--ag-toggle-button-off-background-color,transparent);border-radius:8px;position:relative;flex:none;border:1px solid #f5f5f5;border-color:var(--ag-toggle-button-off-border-color,var(--ag-foreground-color,#f5f5f5))}.ag-theme-balham-dark .ag-toggle-button-input-wrapper input{opacity:0;height:100%;width:100%}.ag-theme-balham-dark .ag-toggle-button-input-wrapper:focus-within{outline:none;box-shadow:0 0 4px 1.5px #719ece}.ag-theme-balham-dark .ag-toggle-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-balham-dark .ag-toggle-button-input-wrapper.ag-checked{background-color:#00b0ff;background-color:var(--ag-toggle-button-on-background-color,var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#00b0ff)));border-color:#00b0ff;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#00b0ff)))}.ag-theme-balham-dark .ag-toggle-button-input-wrapper:before{content:" ";position:absolute;top:-1px;left:-1px;display:block;box-sizing:border-box;height:16px;width:16px;background-color:#2d3436;background-color:var(--ag-toggle-button-switch-background-color,var(--ag-background-color,#2d3436));border-radius:8px;transition:left .1s;border:1px solid #f5f5f5;border-color:var(--ag-toggle-button-switch-border-color,var(--ag-toggle-button-off-border-color,var(--ag-foreground-color,#f5f5f5)))}.ag-theme-balham-dark .ag-toggle-button-input-wrapper.ag-checked:before{left:calc(100% - 16px);border-color:#00b0ff;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#00b0ff)))}.ag-theme-balham-dark .ag-radio-button-input-wrapper{font-family:agGridBalham;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:16px;height:16px;background-color:#2d3436;background-color:var(--ag-checkbox-background-color,var(--ag-background-color,#2d3436));border-radius:3px;display:inline-block;vertical-align:middle;flex:none;border-radius:16px}.ag-theme-balham-dark .ag-radio-button-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-balham-dark .ag-radio-button-input-wrapper:active,.ag-theme-balham-dark .ag-radio-button-input-wrapper:focus-within{outline:none;box-shadow:0 0 4px 1.5px #719ece}.ag-theme-balham-dark .ag-radio-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-balham-dark .ag-radio-button-input-wrapper:after{content:"\\f124";color:#ecf0f1;color:var(--ag-checkbox-unchecked-color,#ecf0f1);position:absolute;top:0;left:0;pointer-events:none}.ag-theme-balham-dark .ag-radio-button-input-wrapper.ag-checked:after{content:"\\f125";color:#00b0ff;color:var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#00b0ff));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-balham-dark input[class^=ag-][type=range]{-webkit-appearance:none;width:100%;height:100%;background:none;overflow:visible}.ag-theme-balham-dark input[class^=ag-][type=range]::-webkit-slider-runnable-track{margin:0;padding:0;width:100%;height:3px;background-color:#424242;background-color:var(--ag-border-color,#424242);border-radius:2px;border-radius:3px}.ag-theme-balham-dark input[class^=ag-][type=range]::-moz-range-track{margin:0;padding:0;width:100%;height:3px;background-color:#424242;background-color:var(--ag-border-color,#424242);border-radius:2px;border-radius:3px}.ag-theme-balham-dark input[class^=ag-][type=range]::-ms-track{margin:0;padding:0;width:100%;height:3px;background-color:#424242;background-color:var(--ag-border-color,#424242);border-radius:2px;border-radius:3px;color:transparent;width:calc(100% - 2px)}.ag-theme-balham-dark input[class^=ag-][type=range]::-webkit-slider-thumb{margin:0;padding:0;-webkit-appearance:none;width:16px;height:16px;background-color:#2d3436;background-color:var(--ag-background-color,#2d3436);border:1px solid #ecf0f1;border-color:var(--ag-checkbox-unchecked-color,#ecf0f1);border-radius:16px;-webkit-transform:translateY(-6.5px);transform:translateY(-6.5px)}.ag-theme-balham-dark input[class^=ag-][type=range]::-ms-thumb{margin:0;padding:0;-webkit-appearance:none;width:16px;height:16px;background-color:#2d3436;background-color:var(--ag-background-color,#2d3436);border:1px solid #ecf0f1;border-color:var(--ag-checkbox-unchecked-color,#ecf0f1);border-radius:16px}.ag-theme-balham-dark input[class^=ag-][type=range]::-moz-ag-range-thumb{margin:0;padding:0;-webkit-appearance:none;width:16px;height:16px;background-color:#2d3436;background-color:var(--ag-background-color,#2d3436);border:1px solid #ecf0f1;border-color:var(--ag-checkbox-unchecked-color,#ecf0f1);border-radius:16px}.ag-theme-balham-dark input[class^=ag-][type=range]:focus{outline:none}.ag-theme-balham-dark input[class^=ag-][type=range]:focus::-webkit-slider-thumb{box-shadow:0 0 4px 1.5px #719ece;border-color:#00b0ff;border-color:var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#00b0ff))}.ag-theme-balham-dark input[class^=ag-][type=range]:focus::-ms-thumb{box-shadow:0 0 4px 1.5px #719ece;border-color:#00b0ff;border-color:var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#00b0ff))}.ag-theme-balham-dark input[class^=ag-][type=range]:focus::-moz-ag-range-thumb{box-shadow:0 0 4px 1.5px #719ece;border-color:#00b0ff;border-color:var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#00b0ff))}.ag-theme-balham-dark input[class^=ag-][type=range]:active::-webkit-slider-runnable-track{background-color:#719ece;background-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham-dark input[class^=ag-][type=range]:active::-moz-ag-range-track{background-color:#719ece;background-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham-dark input[class^=ag-][type=range]:active::-ms-track{background-color:#719ece;background-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham-dark input[class^=ag-][type=range]:disabled{opacity:.5}.ag-theme-balham-dark .ag-filter-toolpanel-header,.ag-theme-balham-dark .ag-filter-toolpanel-search,.ag-theme-balham-dark .ag-header-row,.ag-theme-balham-dark .ag-status-bar{font-weight:600;color:hsla(0,0%,96.1%,.64);color:var(--ag-header-foreground-color,hsla(0,0%,96.1%,.64))}.ag-theme-balham-dark .ag-ltr input[class^=ag-]:not([type]),.ag-theme-balham-dark .ag-ltr input[class^=ag-][type=date],.ag-theme-balham-dark .ag-ltr input[class^=ag-][type=datetime-local],.ag-theme-balham-dark .ag-ltr input[class^=ag-][type=number],.ag-theme-balham-dark .ag-ltr input[class^=ag-][type=tel],.ag-theme-balham-dark .ag-ltr input[class^=ag-][type=text],.ag-theme-balham-dark .ag-ltr textarea[class^=ag-]{padding-left:4px}.ag-theme-balham-dark .ag-rtl input[class^=ag-]:not([type]),.ag-theme-balham-dark .ag-rtl input[class^=ag-][type=date],.ag-theme-balham-dark .ag-rtl input[class^=ag-][type=datetime-local],.ag-theme-balham-dark .ag-rtl input[class^=ag-][type=number],.ag-theme-balham-dark .ag-rtl input[class^=ag-][type=tel],.ag-theme-balham-dark .ag-rtl input[class^=ag-][type=text],.ag-theme-balham-dark .ag-rtl textarea[class^=ag-]{padding-right:4px}.ag-theme-balham-dark .ag-column-drop-vertical-empty-message,.ag-theme-balham-dark .ag-status-bar{font-weight:600;color:hsla(0,0%,96.1%,.38);color:var(--ag-disabled-foreground-color,hsla(0,0%,96.1%,.38))}.ag-theme-balham-dark .ag-dnd-ghost{font-weight:600}.ag-theme-balham-dark .ag-tab{border:1px solid transparent;padding:4px 8px;margin:4px 4px -1px}.ag-theme-balham-dark .ag-tab-selected{background-color:#2d3436;background-color:var(--ag-background-color,#2d3436);border-color:#424242;border-color:var(--ag-border-color,#424242);border-bottom-color:transparent}.ag-theme-balham-dark .ag-tabs-header{border-bottom:1px solid #424242;border-bottom-color:var(--ag-border-color,#424242)}.ag-theme-balham-dark .ag-column-drop-cell{height:24px}.ag-theme-balham-dark .ag-column-drop-vertical-title{color:#f5f5f5;color:var(--ag-foreground-color,#f5f5f5)}.ag-theme-balham-dark .ag-column-drop-vertical-cell{margin-left:8px;margin-right:8px}.ag-theme-balham-dark .ag-column-drop-vertical-cell-text{margin-left:8px}.ag-theme-balham-dark .ag-column-drop-vertical-icon{color:#f5f5f5;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#f5f5f5))}.ag-theme-balham-dark .ag-ltr .ag-column-drop-vertical-empty-message{padding-left:24px;padding-right:4px}.ag-theme-balham-dark .ag-rtl .ag-column-drop-vertical-empty-message{padding-right:24px;padding-left:4px}.ag-theme-balham-dark .ag-column-drop-horizontal{height:32px}.ag-theme-balham-dark .ag-column-drop-empty{color:hsla(0,0%,96.1%,.38);color:var(--ag-disabled-foreground-color,hsla(0,0%,96.1%,.38))}.ag-theme-balham-dark .ag-column-drop-horizontal-cell-text{margin-left:8px}.ag-theme-balham-dark .ag-column-drop-vertical{padding-top:8px}.ag-theme-balham-dark .ag-menu-header{background-color:#1c1c1c;background-color:var(--ag-header-background-color,#1c1c1c)}.ag-theme-balham-dark .ag-overlay-loading-center{background-color:#2d3436;background-color:var(--ag-background-color,#2d3436);border:1px solid #424242;border-color:var(--ag-border-color,#424242);color:#f5f5f5;color:var(--ag-foreground-color,#f5f5f5);padding:16px}.ag-theme-balham-dark .ag-tooltip{border:none;background-color:#cbd0d3}.ag-theme-balham-dark .ag-panel-title-bar-button-icon{font-size:20px}.ag-theme-balham-dark .ag-chart-data-section,.ag-theme-balham-dark .ag-chart-format-section{padding-bottom:2px}.ag-theme-balham-dark .ag-group-toolbar{background-color:rgba(17,17,17,.5);background-color:var(--ag-subheader-toolbar-background-color,rgba(17,17,17,.5))}.ag-theme-balham-dark .ag-chart-tab{padding-top:2px}.ag-theme-balham-dark .ag-charts-format-sub-level-group-item{margin-bottom:6px}.ag-theme-balham-dark .ag-tooltip{background-color:#1c1f20}',""]),e.exports=t},function(e,t,o){var r=o(27),a=o(162);"string"==typeof(a=a.__esModule?a.default:a)&&(a=[[e.i,a,""]]);var n={insert:"head",singleton:!1};r(a,n);e.exports=a.locals||{}},function(e,t,o){(t=o(28)(!1)).push([e.i,'.ag-theme-balham{-webkit-font-smoothing:antialiased;color:#000;color:var(--ag-foreground-color,#000);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:12px;line-height:normal}@font-face{font-family:agGridBalham;src:url("data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABX4AAsAAAAAJ8wAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlEAAAReXgFf/09TLzIAAANcAAAAPgAAAFZWTFJaY21hcAAAA5wAAAHtAAAFgFIH7gFnbHlmAAAFjAAADLgAABYYNphscGhlYWQAABJEAAAALwAAADZ2zsSBaGhlYQAAEnQAAAAbAAAAJAfTBC1obXR4AAASkAAAABIAAAEUp/gAAGxvY2EAABKkAAAAZAAAAIwBFQakbWF4cAAAEwgAAAAfAAAAIAFbAHNuYW1lAAATKAAAATUAAAJG0OP3eXBvc3QAABRgAAABlwAAAlqez14KeJx9k09yElEQxr9hCBKISYwxloga/0bjOAwM/yQQCFKWZWXhwoULN3GhpZVylRO49gCWB/AUnsBy6coDeADLA/jrZpCYRXjFzJvur7/+ul8/BZJKSrSr3OTx/nMtHx4cvVdFeU1/5j++Dw7fvjlQcfaFL+/vooLwj5Z1Qy90pG+BgtfB51whzIW74X74IfwU/lAIalMx6LIesGLVeEZkr6uhVDkVsMXsm2qBDnm23bqmC1pwz1AjrZMzJmbkjNt6qptahWfgPH31QCUs4+zzHLNuaeUURKrb8NdR08VqrFUyrGpRe2jso6NDdAvvCr4dMkfEDPANdA68ofLexyd6iaI1r80i6xku4R/TZfuO/KvMmqHa8DfgN74tss7sDTLViLgHex3Uw6yH27pGdAOePmwdj256dBlkDYWJrrKzympUtkT9PT3TK8+6m8X0vYvTmrdQP7cPnC+l2uPWDlxjsHfRMLfaidwhV6QJ/pI2eL/TR33RV33XT/3Sb53B2sVrFfTg3jm1M0X6dxI9xNv+Z7VKC5zPSdT/iEXqbnhvYnyjrIOWrYxO603CPsKaOL6ETsMPUZNyGnlyRJ63hnWB1eU7Bn02m8YWa8n7PGIGbAIqdKfB05im85bS4Usw2W6qa8O71YLnop+W9dRu0rJ/2czbKVfAXOYdUVnd+/MI7xUsxjS3VD0qRbVx3MefonaezVRVUdX02bXJmvgtGJJpkzqmSmrcXLsBE5+q6yioZzdyndMw9Z3spM47LvaoAM1RdpMT75lN8gBtNhXjv2nbY10AAAB4nGNgZMpnnMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVFgEqgRRAAAy9AKRgAAeJy102dSWzEUhuHXhW56TaN3Y2wwvRkb/rAM0hlSGNKZrDI70QZCvnPPyQLITDTz+Ls6o6srjSygDSjImhQhXySHtd+q5rJ6ge6sXuSX+iU6yeu5whU33KXa/b2qFS655jblst7fltPoEk9ZZEe9I811oKdjqrT0xh4b7LPLCXU2OWWdbWo0OGeLQ5qc6f28vl7UGtvp0He7tJIezdhLH/0MMMgQw4wwyhjjTPCYJ/raM42ZZIppZpjVuDnmWdAalvTcwzIr+l1Vr6wFtvOwdvTA8dbWDnaOq63Knna7e1Lf1Ea3a43zrcPm2T9M9h9ayX4KP6N3gZ2ms91eBvt/PA8H8iLYyb4Mx/IqVOV1aMmbYPO+DXtyFTbkOuzLu7Ar78OJfAh1+Rg25Sacym1Yl09hWz6HmnwJDfkazuVb2JLv4VB+hKbcBR1gyjm7KynvsCw4u1up6Ox+pTZn9y61Oyw7HJadDssuh2W3s/uYehyWJWcnmXodln0Oy36H5YDDctBhOeSwHHZYjjgsRx2WYw7LcYflhMPykdPdJAXdUlLQfSUF3VxSyPY16bCcclhOOyxnHJazDss5l+133mG1BYfVFh1WW3JYbdlhtRWXzbPqsrWVHTZ2zWFjKy4bs+6w96oum7PmKP8BU32drwAAAHic7RhpcBvVeb+3lmRZsm5pJdk6V4ety9YdS/Zu7MTGdu7DCRlC0jQHDTFH0tAwIYJCaCAhDDSZcEwzFDoDGZgpw7TTDNMmpUMZMFNi0hQ6JTD9AbQNaRtCyXQGFy393molxybl+l1pd9/33vve9773ve96j2EZ/LHPss8yHJNm1jMMeAlnYQ1E0xROkSixCqQYUgXVRlDbbZwXuKawAEULm4JohA+qVXyetzs45a/WyH97Np+1B6K5YqGIuIViIRKl/3yANXcMxqCpCWKDHdJ70nvTNfBIfwvPAWCbSI4HL3j5HNHpEF65de5/4CFxCqw6v9fg0JlanEZ/xMBNidJ+aNLYDf0Gu1rt9XVbPAC72KevRBo8cm2gEF77+JIfXF8nrUzDslMia7ToHQ691dI+4Gh1egycSazouuwhm75bbzWa250hm5+fR0UFsrweYR9hfAxj5TTRIqcJmOUiag7IRTFglgvOPDGcOHw4MQytM0vpY6X+5pXbG/2tynzkZdbGNGNFmYeHN/clz5xJ7hPI0X2JM2cS+6Q5lC2Zt23sNsbGdDJ5xA/S7bDRrcnQfcjRfdBkaN1Ge+R9KdAeK9JFykg/WoRLW1aPZbLZzNjq1+rAlrGRoVg8HhsaeYYCEENo7MnkU08ln5S/7LYZ6DIgzESXIenj+gj8Mg2enawTIQ2jQ5lmzTx9i1k7f7pSOb9z5we33EK2SteR4erzU1PTYz5gzzFWJsogmU4IpiBvzgmQDWS8YDfbDMAGggYKeWmbQHtToAGUH7C56vfTK7q7V6RJreyqVjwZDz5kr1x2SOteyz4KN01jpOUR7E88aU91D37wIXfj5yPEzDwKN8/mKf7VeWIDaBdfxlF/9SXS++XsSKlhWV1m8MJAfXo+0GBJdSVOcpcRp5PdNYsL9tzlvbQcms2BIodb2U2MCjXWyTBa0HBaYIs+qPkGmyNTyFNFJH+X1pc2SlUQJiZeeU6ncxkd6cG0w+iCF+GJMnZIv4W+iQmhtdXbFnEF0+mgK9zupeSb5DmSrEHRGSPDhHlz1qq8QN/jovgrQTghitVTgvA2yVQnp9+GHZPDrAr5RB6p3pND0sXE++8n4FKtVNayCO3JyvBMN52lLsByQ6gsekEEHNhSwK4Izi7vuT2A7eSnl+Ij8dhIghbxkcinkUJB/khNc2MjcTgiXRfOV7APsjJCXDqFH5IpRKSXKCr0RgqSnljiw3ExH57m+2XyMrUVmGG1l5kj8V9uZjN9iOKbssSq+BBYWPMhMDFbLrh1Gi2QQygM6SKYyJ+odExgQhSVLJtjbAkl08MsZMaYdYhfKGYxfNSiAOXMANGa7y/KXgbZ5AxgBDlY0KpaFmiuCAKIkCI4ppClgrVpwqgpqJwZEVBbUsAHNcCv32pZ+/SdoVazpc3tj/QlRhY8s2zl/GVpk1Wr05lMCbE3IXQv5CCybMmGzWsdtvbSSO+mcgLu6V7AgXfnkR8v4Esj5c2luDTpjl8V74om3LHhWFeUfJRm2cX3Xt0e9MbaAy4kHLbY7N3lVW0pm9PutffF+xIP+67OkzVCn83uVbe0x8ubyiMl6ff+NXkyfGMfGwxiS+9I6WxHF1J0J6JdcSymdfUYyzNtTIopo6TkCKuISH25eDBWcgZSl05NIhqUBioZSgmViqOSQLv1AIqGWi1UG/JYcMP1N+1YszSjyEL8zTgsvP9GnyKLZXfyVADDpQ2l0oadG3p6NvwxNrxyOCZ/WL6x+MUh3mCcW1qtLHxsU5NI+sYHawv3uG9ZQlfr60ESNTp/gBglEiO1ouF7kmwS8wn0gqCs0wOaYkFZbKQPAiqbkjPYi/maahTybBI6nQNFZ/MJAAIaZ2HA1Um2V081yxCqSK2XnIt2e8rdbq3+uwfHdpR0za50n7c7NCiate50n6c7tLdrRUe3p5R2a80KP2RK1mdtXaNVZt5MPlG0WvqW0FBsh6SHS4y+tgZyoeFfrLiaNoz4vOzbuximyOez3GVv+EvqU7IvmvZIV65MVWo/USkFpUR2mmfkaXm0uT6mnxlkRr5uxmZFblQYc8Kzym+Ymx2tVGCX9Ar0SPsbkB6hS9IoHP9m6Vj1n4IgiMrbiGfTe1jz1tTLk7jisf8sCHWvXf037mBdD3ewbSg5M913dMh061muGMXVFqMkKsJ+aZd4QDoLkcnJdAXelbyVNHlQOCEcgAhEpLOTGdyBTJ3WdowDMWa1rNMoVg0KGN0blWpBhHwkmkY9NwCqtBdzXhHVFVXdGpSxsJF6u5TSQUfbsAOb07Ldy1R44sRYGWhraWkf96zoCOU0aofLomctYVO70WDi43t6Yr7xpNPDxTbFFnm2dXHtXNzbDJqwy66z0CHxInA2C+hYC29ot7Xo5qUinWRQq1e1Le+MeLZ5rK2tfRF+yG1h+bAlZI9u7E6H4m2c0b8tdU855QOtH6neXe72e7U6lW9TkkOqVoNxScqTt8ljAtbQtcn0Eqvp/zK5kkxqNnofe9/n/AZDrYzGaRW+ssXhW1TqGoTRaoWbJxIT8GJiIgGuqanq5NTUAoTJOmxF77FuyocAPokMWsU6LPGZeHpq2j6qpMqoGTwyWH3UQDThLsDsoPgP9q2hHct2wO+UcuIsS8vHaoWS4yTJ6/X8G9A66n82WX0APbDygktEexDrex/EmCbPp0ykTAuvN8kT/bA237/easJiO7zwFju0ffkOZewzmLvV7LKejaA51w43UDqYevts6mA//KIfobe7DsLSvfFTp+J74WR1Ek7WYJyZ0rmL3cU4mAQzh5kr5yAMUFXjHLLaoa5R7SoKhKNVjVrRQwxEsm4hGm2NRrpACw45BnWBwwcgjyoUOTlyccUITF27atkNLfpYZNHI81dfO69vLiFh/4339S8dnn+NVhuOLF98cvFYjG9uXjM0uvqCX61e0jcwmktHYbf0YXa8M2Y0W08O9HRI+0I6p7tQWq4Vchm7w/KZj/0eyaWPrdt8zdI5+bDdIfQ8tnL1aP/GgkgSsfuXji1akoqrYslVI2PLHownX+0bGaoEQxqV2wG3SQ+b2sKRXKn8GvE6pH3iof55nUmVwHZ29Arlz1qUfR1nb0Pt62B6UTLy4U8+ENr5zyf/vCbjsKmDkVwBAsEINhXKYA/ksxkHIqrJdr3B5Vvlcxn0lWBPEB+4VCunzC5X0OUCnaR3h0JuEXYJ7nCY9VhsToPFYnDaLIgkjSqDjuPH7PQ78ak+HnbBcXeoUgm5pVFXuOGz9yDPQYxuDNSzxgLuAS1EoNuloXkD9TRoTzS98IEmgquC2v4VOUdWTi1h2SEgTSqtp9RV3Nhs1LssnA289rmD38HsgrXZk9xDGDj+YtXqm01HCx0ZM7ibOQLN5Ehzi85osJjegNsPYS5l1HfotLoNbq+zzWoxSO+2j+k3q1WufLyb0yEF8oDJZDU4jhpYtk36q9oWdeYsD2Gk0zRb3qDLabksbvtxJ/qZIWYBs5K5htnAbPkfsTtgdsgXJyoavn2Y5tUsw46JoIavXTk4ZMGEbVw2H1VrsvliDFAiWUw87Fmq3WE1r7FnixHenv2iwA67q698eAGjrrbaDBiD/fDLlsTYyoQ2NtSxU5sYG0u0zA1l3F6ovgp7bgOoiLkFmAnsFuHkboqP4uiJ3fHCnKvu+MJQ/2n1VbUW0S+cMptwMrgNjDJx7c0dV8WJNrES5wGVxuqIeYfm3P7r0fwdnxTC68U9e4I0IQDYU4HbG/pxDs+19H5Dud0wUXXwU3GYZt1uBGmdXkIV4NK9O7fPmz9/3vadYKpD9+7asrHU21vauOUCAuUyAuw52iFdnIkszMChQG/9vF/nRfha3My6e5FxviqL8NwVblW+Mt/S6NjMkZTY7FyJ5lfo/DEwcZg0oWePstulswdEaRfsFw+kK5IX3q2kJycx4zp7gGZLB2iaNDmp0BnHnKAVvTID5gDm2TYHOhk8Gavqnp51Vp9fkQ6S4WBa+vl46fTp0vhKJPUOhKR36CkfQu3j5dOny+NwuHHfpiKH5XM6KXJFtkm6KKd6ZAtN3xFgZuMBPRNjvpqopfV31coGzov1Mz+HONKhn+HRd4AcQSB5Dww0aCWJje6yFWVwQg6AVqFx93QDO477Hsf8m7EGMdHG0wxGHXpYRS+LscWK+Y2XoMOKaqbzoSjQzIeTTZteltZgGqT4Y4SECPkRzDlPVDIkTZwnphTncSz/9saQkBT4rTFnQNNsdwtJeKJzsQebzElX1yqL2exD2OdXO9o2zmG34WAVOSpNfIAEQU2OQvE8kW7FVAbxfTIhfZsp1R4abUNCo36ZjoNVZRIda5CO6Fu1tiNdxhX+FyXYf3Z4nGNgZGBgAOJNb47Mjue3+crAzfwCKBDF+XhfA4JmYGB+CRJn4GBgAvEAeqIMgAB4nGNgZGBgfsHAACH//2d+ycDIgApcAXBnBQgAeJxjYGBgYH4xdDA9AADYnCd6AAB4nGNgAIIZDBcYnjE6MEYxLmF8xaTBFMVUw9THdIPpEzMHswzzBhYNlgKWLpYrrEGsOayT2GTYlrE9Ymdgl2K3YI9hf8PhxrGBM4xzDhcTlxpXAFcKVxlXF9cMbh7SIQDoHxaseJxjYGRgYHBlSGfgYQABJiDmAkIGhv9gPgMAGrQBzwB4nHWPP07DMBjFX2haRIsQEhJiwxMLUvpnYOjYodk7dGBzGydtlcSR41bqxjE4Acdg5AicgkPwEr6hQqotOT///N4nBcAtvhCgWQGu27NZF7jk7Y87pDvhkPwo3MUAz8I9+hfhPu1MeMBmwQlBeEXzgDfhC9zgXbhD/yEckj+Fu7jHt3CP/ke4j2UQCg/wFLzqLHbbZKbzjS4WJtvn2p2qU14aV29tqcbR6FTHpjROe5Oo1VHVh2zifapSZws1t6U3eW5V5ezOrH208b6aDoep+GhtC2hkiOGwRcI/18ix4VlgAcOXPe+ar+dS5/ySbYea3qKEwhgRRmfTMdNl29Dw/CZsrHDkWePAzoTWI+U9ZcayoTBvJzfpnNvSVO3bjmZNH3F206owxZA7/ZePmOKkX1qXaMkAAAB4nG2R6W7bMBCE/cWSrThp47ptet/3obbpfadX+h40RclEJFIgKR95+hJ1ESBA9w9nBsvZWbK30VvXqPf/OmCDPgkpA4ZkbDJii21OcZodxpxhwlnOcZ5dLnCRS1zmCle5xnVucJNb3OYOd7nHfR7wkEc85glPyXnGc16wx0te8Zo3vOUd7/nARz7xmS98ZZ9vfOcHP/nFAb97W6KqnKpE0NYMhHN24fvCy4EURqo6lTPhwljOlDyc2mX+F6hi91jQplBBuUYbEdTkWO7Mv85taWvr8lZH4oaRdI3xI2lNcEIGVSTStqtUOut9UigvM7VsRfQsNtVK5b4WftaPaFDqOo5JS+18SCqn27RytmuT2BCSWpVhUGsT52XrI98b1lYU2lRZI5a60UcqaZTpshh0zYw1asvYkIu6tgtVpG10Uv1Wm7TVcxvGLl63+bQLwZrcluXOScGkTlezkHgxVyPfRJe8sAuTrWFMFuLKk+CUOvlGWWfWERFUOBQBjcWwwCOpmXHIlGX8zYKGjpYVJUfMe70/6zKeWwA=") format("woff");font-weight:400;font-style:normal}.ag-theme-balham .ag-icon{font-family:agGridBalham;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ag-theme-balham .ag-icon-aggregation:before{content:"\\f101"}.ag-theme-balham .ag-icon-arrows:before{content:"\\f102"}.ag-theme-balham .ag-icon-asc:before{content:"\\f103"}.ag-theme-balham .ag-icon-cancel:before{content:"\\f104"}.ag-theme-balham .ag-icon-chart:before{content:"\\f105"}.ag-theme-balham .ag-icon-color-picker:before{content:"\\f109"}.ag-theme-balham .ag-icon-columns:before{content:"\\f10a"}.ag-theme-balham .ag-icon-contracted:before{content:"\\f10b"}.ag-theme-balham .ag-icon-copy:before{content:"\\f10c"}.ag-theme-balham .ag-icon-cross:before{content:"\\f10d"}.ag-theme-balham .ag-icon-desc:before{content:"\\f10e"}.ag-theme-balham .ag-icon-expanded:before{content:"\\f10f"}.ag-theme-balham .ag-icon-eye-slash:before{content:"\\f110"}.ag-theme-balham .ag-icon-eye:before{content:"\\f111"}.ag-theme-balham .ag-icon-filter:before{content:"\\f112"}.ag-theme-balham .ag-icon-first:before{content:"\\f113"}.ag-theme-balham .ag-icon-grip:before{content:"\\f114"}.ag-theme-balham .ag-icon-group:before{content:"\\f115"}.ag-theme-balham .ag-icon-last:before{content:"\\f116"}.ag-theme-balham .ag-icon-left:before{content:"\\f117"}.ag-theme-balham .ag-icon-linked:before{content:"\\f118"}.ag-theme-balham .ag-icon-loading:before{content:"\\f119"}.ag-theme-balham .ag-icon-maximize:before{content:"\\f11a"}.ag-theme-balham .ag-icon-menu:before{content:"\\f11b"}.ag-theme-balham .ag-icon-minimize:before{content:"\\f11c"}.ag-theme-balham .ag-icon-next:before{content:"\\f11d"}.ag-theme-balham .ag-icon-none:before{content:"\\f11e"}.ag-theme-balham .ag-icon-not-allowed:before{content:"\\f11f"}.ag-theme-balham .ag-icon-paste:before{content:"\\f120"}.ag-theme-balham .ag-icon-pin:before{content:"\\f121"}.ag-theme-balham .ag-icon-pivot:before{content:"\\f122"}.ag-theme-balham .ag-icon-previous:before{content:"\\f123"}.ag-theme-balham .ag-icon-right:before{content:"\\f126"}.ag-theme-balham .ag-icon-save:before{content:"\\f127"}.ag-theme-balham .ag-icon-small-down:before{content:"\\f128"}.ag-theme-balham .ag-icon-small-left:before{content:"\\f129"}.ag-theme-balham .ag-icon-small-right:before{content:"\\f12a"}.ag-theme-balham .ag-icon-small-up:before{content:"\\f12b"}.ag-theme-balham .ag-icon-tick:before{content:"\\f12c"}.ag-theme-balham .ag-icon-tree-closed:before{content:"\\f12d"}.ag-theme-balham .ag-icon-tree-indeterminate:before{content:"\\f12e"}.ag-theme-balham .ag-icon-tree-open:before{content:"\\f12f"}.ag-theme-balham .ag-icon-unlinked:before{content:"\\f130"}.ag-theme-balham .ag-icon-row-drag:before{content:"\\f114"}.ag-theme-balham .ag-right-arrow:before{content:"\\f117";content:"\\f126"}.ag-theme-balham .ag-root-wrapper{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-balham [class^=ag-],.ag-theme-balham [class^=ag-]:after,.ag-theme-balham [class^=ag-]:before,.ag-theme-balham [class^=ag-]:focus{box-sizing:border-box;outline:none}.ag-theme-balham [class^=ag-]::-ms-clear{display:none}.ag-theme-balham .ag-checkbox .ag-input-wrapper,.ag-theme-balham .ag-radio-button .ag-input-wrapper{overflow:visible}.ag-theme-balham .ag-range-field .ag-input-wrapper{height:100%}.ag-theme-balham .ag-toggle-button{flex:none;width:unset;min-width:unset}.ag-theme-balham .ag-ltr .ag-label-align-right .ag-label{margin-left:4px}.ag-theme-balham .ag-rtl .ag-label-align-right .ag-label{margin-right:4px}.ag-theme-balham input[class^=ag-]{margin:0}.ag-theme-balham input[class^=ag-],.ag-theme-balham select[class^=ag-],.ag-theme-balham textarea[class^=ag-]{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-balham input[class^=ag-]:not([type]),.ag-theme-balham input[class^=ag-][type=date],.ag-theme-balham input[class^=ag-][type=datetime-local],.ag-theme-balham input[class^=ag-][type=number],.ag-theme-balham input[class^=ag-][type=tel],.ag-theme-balham input[class^=ag-][type=text],.ag-theme-balham textarea[class^=ag-]{font-size:inherit;line-height:inherit;color:inherit;border:1px solid #95a5a6;border-color:var(--ag-input-border-color,#95a5a6)}.ag-theme-balham input[class^=ag-]:not([type]):disabled,.ag-theme-balham input[class^=ag-][type=date]:disabled,.ag-theme-balham input[class^=ag-][type=datetime-local]:disabled,.ag-theme-balham input[class^=ag-][type=number]:disabled,.ag-theme-balham input[class^=ag-][type=tel]:disabled,.ag-theme-balham input[class^=ag-][type=text]:disabled,.ag-theme-balham textarea[class^=ag-]:disabled{color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38));background-color:#ebebeb;background-color:var(--ag-input-disabled-background-color,#ebebeb);border-color:rgba(149,165,166,.3);border-color:var(--ag-input-disabled-border-color,rgba(149,165,166,.3))}.ag-theme-balham input[class^=ag-]:not([type]):focus,.ag-theme-balham input[class^=ag-][type=date]:focus,.ag-theme-balham input[class^=ag-][type=datetime-local]:focus,.ag-theme-balham input[class^=ag-][type=number]:focus,.ag-theme-balham input[class^=ag-][type=tel]:focus,.ag-theme-balham input[class^=ag-][type=text]:focus,.ag-theme-balham textarea[class^=ag-]:focus{outline:none;box-shadow:0 0 2px 1px #719ece;border-color:#719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham input[class^=ag-][type=number]{-moz-appearance:textfield}.ag-theme-balham input[class^=ag-][type=number]::-webkit-inner-spin-button,.ag-theme-balham input[class^=ag-][type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.ag-theme-balham input[class^=ag-][type=range]{padding:0}.ag-theme-balham button[class^=ag-]:focus,.ag-theme-balham input[class^=ag-][type=button]:focus{box-shadow:0 0 2px 1px #719ece}.ag-theme-balham .ag-drag-handle{color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-balham .ag-list-item,.ag-theme-balham .ag-virtual-list-item{height:28px}.ag-theme-balham .ag-keyboard-focus .ag-virtual-list-item:focus{outline:none}.ag-theme-balham .ag-keyboard-focus .ag-virtual-list-item:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham .ag-select-list{background-color:#fff;background-color:var(--ag-background-color,#fff);overflow-y:auto;overflow-x:hidden}.ag-theme-balham .ag-list-item{display:flex;align-items:center}.ag-theme-balham .ag-list-item.ag-active-item{background-color:#ecf0f1;background-color:var(--ag-row-hover-color,#ecf0f1)}.ag-theme-balham .ag-select-list-item{padding-left:4px;padding-right:4px;cursor:default;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.ag-theme-balham .ag-select-list-item span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.ag-theme-balham .ag-select .ag-picker-field-wrapper{background-color:#fff;background-color:var(--ag-background-color,#fff);min-height:28px;cursor:default}.ag-theme-balham .ag-select:not(.ag-cell-editor){height:28px}.ag-theme-balham .ag-select .ag-picker-field-display{margin:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ag-theme-balham .ag-select .ag-picker-field-icon{display:flex;align-items:center}.ag-theme-balham .ag-select.ag-disabled{opacity:.5}.ag-theme-balham .ag-rich-select{background-color:#f5f7f7;background-color:var(--ag-control-panel-background-color,#f5f7f7)}.ag-theme-balham .ag-rich-select-list{width:100%;min-width:200px;height:182px}.ag-theme-balham .ag-rich-select-value{padding:0 4px 0 12px;height:28px;border-bottom:1px solid #bdc3c7;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#bdc3c7))}.ag-theme-balham .ag-rich-select-virtual-list-item{cursor:default;height:28px}.ag-theme-balham .ag-rich-select-virtual-list-item:hover{background-color:#ecf0f1;background-color:var(--ag-row-hover-color,#ecf0f1)}.ag-theme-balham .ag-rich-select-row{padding-left:12px}.ag-theme-balham .ag-rich-select-row-selected{background-color:#b7e4ff;background-color:var(--ag-selected-row-background-color,#b7e4ff)}.ag-theme-balham .ag-group-contracted,.ag-theme-balham .ag-group-expanded,.ag-theme-balham .ag-row-drag,.ag-theme-balham .ag-selection-checkbox{color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-balham .ag-ltr .ag-group-contracted,.ag-theme-balham .ag-ltr .ag-group-expanded,.ag-theme-balham .ag-ltr .ag-row-drag,.ag-theme-balham .ag-ltr .ag-selection-checkbox{margin-right:12px}.ag-theme-balham .ag-rtl .ag-group-contracted,.ag-theme-balham .ag-rtl .ag-group-expanded,.ag-theme-balham .ag-rtl .ag-row-drag,.ag-theme-balham .ag-rtl .ag-selection-checkbox{margin-left:12px}.ag-theme-balham .ag-cell-wrapper>:not(.ag-cell-value):not(.ag-group-value){height:26px;display:flex;align-items:center;flex:none}.ag-theme-balham .ag-group-contracted,.ag-theme-balham .ag-group-expanded{cursor:pointer}.ag-theme-balham .ag-group-title-bar-icon{cursor:pointer;flex:none;color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-balham .ag-ltr .ag-group-child-count{margin-left:2px}.ag-theme-balham .ag-rtl .ag-group-child-count{margin-right:2px}.ag-theme-balham .ag-group-title-bar{background-color:#e2e9eb;background-color:var(--ag-subheader-background-color,#e2e9eb);padding:4px}.ag-theme-balham .ag-group-toolbar{padding:4px}.ag-theme-balham .ag-disabled-group-container,.ag-theme-balham .ag-disabled-group-title-bar{opacity:.5}.ag-theme-balham .group-item{margin:2px 0}.ag-theme-balham .ag-label{white-space:nowrap}.ag-theme-balham .ag-ltr .ag-label{margin-right:4px}.ag-theme-balham .ag-rtl .ag-label{margin-left:4px}.ag-theme-balham .ag-label-align-top .ag-label{margin-bottom:2px}.ag-theme-balham .ag-ltr .ag-angle-select-field,.ag-theme-balham .ag-ltr .ag-slider-field{margin-right:8px}.ag-theme-balham .ag-rtl .ag-angle-select-field,.ag-theme-balham .ag-rtl .ag-slider-field{margin-left:8px}.ag-theme-balham .ag-angle-select-parent-circle{width:24px;height:24px;border-radius:12px;border:1px solid #bdc3c7;border-color:var(--ag-border-color,#bdc3c7);background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-balham .ag-angle-select-child-circle{top:4px;left:12px;width:6px;height:6px;margin-left:-3px;margin-top:-4px;border-radius:3px;background-color:rgba(0,0,0,.54);background-color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-balham .ag-picker-field-wrapper{border:1px solid #bdc3c7;border-color:var(--ag-border-color,#bdc3c7);border-radius:5px}.ag-theme-balham .ag-picker-field-wrapper:focus{box-shadow:0 0 2px 1px #719ece}.ag-theme-balham .ag-picker-field-button{background-color:#fff;background-color:var(--ag-background-color,#fff);color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-balham .ag-dialog.ag-color-dialog{border-radius:5px}.ag-theme-balham .ag-color-picker .ag-picker-field-display{height:16px}.ag-theme-balham .ag-color-panel{padding:4px}.ag-theme-balham .ag-spectrum-color{background-color:red;border-radius:2px}.ag-theme-balham .ag-spectrum-tools{padding:10px}.ag-theme-balham .ag-spectrum-sat{background-image:linear-gradient(90deg,#fff,rgba(204,154,129,0))}.ag-theme-balham .ag-spectrum-val{background-image:linear-gradient(0deg,#000,rgba(204,154,129,0))}.ag-theme-balham .ag-spectrum-dragger{border-radius:12px;height:12px;width:12px;border:1px solid #fff;background:#000;box-shadow:0 0 2px 0 rgba(0,0,0,.24)}.ag-theme-balham .ag-spectrum-alpha-background,.ag-theme-balham .ag-spectrum-hue-background{border-radius:2px}.ag-theme-balham .ag-spectrum-tool{margin-bottom:10px;height:11px;border-radius:2px}.ag-theme-balham .ag-spectrum-slider{margin-top:-12px;width:13px;height:13px;border-radius:13px;background-color:#f8f8f8;box-shadow:0 1px 4px 0 rgba(0,0,0,.37)}.ag-theme-balham .ag-recent-color{margin:0 3px}.ag-theme-balham .ag-recent-color:first-child{margin-left:0}.ag-theme-balham .ag-recent-color:last-child{margin-right:0}.ag-theme-balham.ag-dnd-ghost{background:#fff;background:var(--ag-background-color,#fff);border-radius:2px;box-shadow:none;overflow:hidden;text-overflow:ellipsis;z-index:10;border:1px solid #bdc3c7;border:1px solid var(--ag-secondary-border-color,var(--ag-border-color,#bdc3c7));color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54));height:32px!important;line-height:32px;margin:0;padding:0 8px;-webkit-transform:translateY(8px);transform:translateY(8px)}.ag-theme-balham .ag-dnd-ghost-icon{margin-right:4px;color:#000;color:var(--ag-foreground-color,#000)}.ag-theme-balham .ag-popup-child:not(.ag-tooltip-custom){box-shadow:5px 5px 10px rgba(0,0,0,.3)}.ag-dragging-fill-handle .ag-theme-balham .ag-dialog,.ag-dragging-range-handle .ag-theme-balham .ag-dialog{opacity:.7;pointer-events:none}.ag-theme-balham .ag-dialog{border-radius:2px;border:1px solid #bdc3c7;border-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-panel{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-balham .ag-panel-title-bar{background-color:#f5f7f7;background-color:var(--ag-header-background-color,#f5f7f7);color:rgba(0,0,0,.54);color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,rgba(0,0,0,.54)));height:32px;padding:4px 12px;border-bottom:1px solid #bdc3c7;border-bottom-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-ltr .ag-panel-title-bar-button{margin-left:4px}.ag-theme-balham .ag-rtl .ag-panel-title-bar-button{margin-right:4px}.ag-theme-balham .ag-tooltip{background-color:#f5f7f7;background-color:var(--ag-header-background-color,#f5f7f7);color:#000;color:var(--ag-foreground-color,#000);padding:4px;border:1px solid #bdc3c7;border-color:var(--ag-border-color,#bdc3c7);border-radius:2px;transition:opacity 1s}.ag-theme-balham .ag-tooltip.ag-tooltip-hiding{opacity:0}.ag-theme-balham .ag-ltr .ag-column-select-indent-1{padding-left:20px}.ag-theme-balham .ag-rtl .ag-column-select-indent-1{padding-right:20px}.ag-theme-balham .ag-ltr .ag-column-select-indent-2{padding-left:40px}.ag-theme-balham .ag-rtl .ag-column-select-indent-2{padding-right:40px}.ag-theme-balham .ag-ltr .ag-column-select-indent-3{padding-left:60px}.ag-theme-balham .ag-rtl .ag-column-select-indent-3{padding-right:60px}.ag-theme-balham .ag-ltr .ag-column-select-indent-4{padding-left:80px}.ag-theme-balham .ag-rtl .ag-column-select-indent-4{padding-right:80px}.ag-theme-balham .ag-ltr .ag-column-select-indent-5{padding-left:100px}.ag-theme-balham .ag-rtl .ag-column-select-indent-5{padding-right:100px}.ag-theme-balham .ag-ltr .ag-column-select-indent-6{padding-left:120px}.ag-theme-balham .ag-rtl .ag-column-select-indent-6{padding-right:120px}.ag-theme-balham .ag-ltr .ag-column-select-indent-7{padding-left:140px}.ag-theme-balham .ag-rtl .ag-column-select-indent-7{padding-right:140px}.ag-theme-balham .ag-ltr .ag-column-select-indent-8{padding-left:160px}.ag-theme-balham .ag-rtl .ag-column-select-indent-8{padding-right:160px}.ag-theme-balham .ag-ltr .ag-column-select-indent-9{padding-left:180px}.ag-theme-balham .ag-rtl .ag-column-select-indent-9{padding-right:180px}.ag-theme-balham .ag-column-select-header-icon{cursor:pointer}.ag-theme-balham .ag-keyboard-focus .ag-column-select-header-icon:focus{outline:none}.ag-theme-balham .ag-keyboard-focus .ag-column-select-header-icon:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:0;left:0;display:block;width:100%;height:100%;border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham .ag-ltr .ag-column-group-icons:not(:last-child),.ag-theme-balham .ag-ltr .ag-column-select-checkbox:not(:last-child),.ag-theme-balham .ag-ltr .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-balham .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-balham .ag-ltr .ag-column-select-column-label:not(:last-child),.ag-theme-balham .ag-ltr .ag-column-select-header-checkbox:not(:last-child),.ag-theme-balham .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-balham .ag-ltr .ag-column-select-header-icon:not(:last-child){margin-right:6px}.ag-theme-balham .ag-rtl .ag-column-group-icons:not(:last-child),.ag-theme-balham .ag-rtl .ag-column-select-checkbox:not(:last-child),.ag-theme-balham .ag-rtl .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-balham .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-balham .ag-rtl .ag-column-select-column-label:not(:last-child),.ag-theme-balham .ag-rtl .ag-column-select-header-checkbox:not(:last-child),.ag-theme-balham .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-balham .ag-rtl .ag-column-select-header-icon:not(:last-child){margin-left:6px}.ag-theme-balham .ag-keyboard-focus .ag-column-select-column-group:focus{outline:none}.ag-theme-balham .ag-keyboard-focus .ag-column-select-column-group:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-2px;left:-2px;display:block;width:calc(100% - -4px);height:calc(100% - -4px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham .ag-keyboard-focus .ag-column-select-column:focus{outline:none}.ag-theme-balham .ag-keyboard-focus .ag-column-select-column:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-2px;left:-2px;display:block;width:calc(100% - -4px);height:calc(100% - -4px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham .ag-column-select-column-group:not(:last-child),.ag-theme-balham .ag-column-select-column:not(:last-child){margin-bottom:4px}.ag-theme-balham .ag-column-select-column-group-readonly,.ag-theme-balham .ag-column-select-column-readonly{color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38));pointer-events:none}.ag-theme-balham .ag-ltr .ag-column-select-add-group-indent{margin-left:24px}.ag-theme-balham .ag-rtl .ag-column-select-add-group-indent{margin-right:24px}.ag-theme-balham .ag-column-select-list{padding:6px}.ag-theme-balham .ag-rtl{text-align:right}.ag-theme-balham .ag-root-wrapper{border:1px solid #bdc3c7;border-color:var(--ag-border-color,#bdc3c7);border-radius:2px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-left:40px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-right:40px}.ag-theme-balham .ag-ltr .ag-row-group-indent-1{padding-left:28px}.ag-theme-balham .ag-rtl .ag-row-group-indent-1{padding-right:28px}.ag-theme-balham .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-left:68px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-right:68px}.ag-theme-balham .ag-ltr .ag-row-group-indent-2{padding-left:56px}.ag-theme-balham .ag-rtl .ag-row-group-indent-2{padding-right:56px}.ag-theme-balham .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-left:96px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-right:96px}.ag-theme-balham .ag-ltr .ag-row-group-indent-3{padding-left:84px}.ag-theme-balham .ag-rtl .ag-row-group-indent-3{padding-right:84px}.ag-theme-balham .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-left:124px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-right:124px}.ag-theme-balham .ag-ltr .ag-row-group-indent-4{padding-left:112px}.ag-theme-balham .ag-rtl .ag-row-group-indent-4{padding-right:112px}.ag-theme-balham .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-left:152px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-right:152px}.ag-theme-balham .ag-ltr .ag-row-group-indent-5{padding-left:140px}.ag-theme-balham .ag-rtl .ag-row-group-indent-5{padding-right:140px}.ag-theme-balham .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-left:180px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-right:180px}.ag-theme-balham .ag-ltr .ag-row-group-indent-6{padding-left:168px}.ag-theme-balham .ag-rtl .ag-row-group-indent-6{padding-right:168px}.ag-theme-balham .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-left:208px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-right:208px}.ag-theme-balham .ag-ltr .ag-row-group-indent-7{padding-left:196px}.ag-theme-balham .ag-rtl .ag-row-group-indent-7{padding-right:196px}.ag-theme-balham .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-left:236px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-right:236px}.ag-theme-balham .ag-ltr .ag-row-group-indent-8{padding-left:224px}.ag-theme-balham .ag-rtl .ag-row-group-indent-8{padding-right:224px}.ag-theme-balham .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-left:264px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-right:264px}.ag-theme-balham .ag-ltr .ag-row-group-indent-9{padding-left:252px}.ag-theme-balham .ag-rtl .ag-row-group-indent-9{padding-right:252px}.ag-theme-balham .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-left:292px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-right:292px}.ag-theme-balham .ag-ltr .ag-row-group-indent-10{padding-left:280px}.ag-theme-balham .ag-rtl .ag-row-group-indent-10{padding-right:280px}.ag-theme-balham .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-left:320px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-right:320px}.ag-theme-balham .ag-ltr .ag-row-group-indent-11{padding-left:308px}.ag-theme-balham .ag-rtl .ag-row-group-indent-11{padding-right:308px}.ag-theme-balham .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-left:348px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-right:348px}.ag-theme-balham .ag-ltr .ag-row-group-indent-12{padding-left:336px}.ag-theme-balham .ag-rtl .ag-row-group-indent-12{padding-right:336px}.ag-theme-balham .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-left:376px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-right:376px}.ag-theme-balham .ag-ltr .ag-row-group-indent-13{padding-left:364px}.ag-theme-balham .ag-rtl .ag-row-group-indent-13{padding-right:364px}.ag-theme-balham .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-left:404px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-right:404px}.ag-theme-balham .ag-ltr .ag-row-group-indent-14{padding-left:392px}.ag-theme-balham .ag-rtl .ag-row-group-indent-14{padding-right:392px}.ag-theme-balham .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-left:432px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-right:432px}.ag-theme-balham .ag-ltr .ag-row-group-indent-15{padding-left:420px}.ag-theme-balham .ag-rtl .ag-row-group-indent-15{padding-right:420px}.ag-theme-balham .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-left:460px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-right:460px}.ag-theme-balham .ag-ltr .ag-row-group-indent-16{padding-left:448px}.ag-theme-balham .ag-rtl .ag-row-group-indent-16{padding-right:448px}.ag-theme-balham .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-left:488px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-right:488px}.ag-theme-balham .ag-ltr .ag-row-group-indent-17{padding-left:476px}.ag-theme-balham .ag-rtl .ag-row-group-indent-17{padding-right:476px}.ag-theme-balham .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-left:516px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-right:516px}.ag-theme-balham .ag-ltr .ag-row-group-indent-18{padding-left:504px}.ag-theme-balham .ag-rtl .ag-row-group-indent-18{padding-right:504px}.ag-theme-balham .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-left:544px}.ag-theme-balham .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-right:544px}.ag-theme-balham .ag-ltr .ag-row-group-indent-19{padding-left:532px}.ag-theme-balham .ag-rtl .ag-row-group-indent-19{padding-right:532px}.ag-theme-balham .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent{margin-left:28px}.ag-theme-balham .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent{margin-right:28px}.ag-theme-balham .ag-cell{-webkit-font-smoothing:subpixel-antialiased}.ag-theme-balham .ag-value-change-delta{padding-right:2px}.ag-theme-balham .ag-value-change-delta-up{color:#43a047;color:var(--ag-value-change-delta-up-color,#43a047)}.ag-theme-balham .ag-value-change-delta-down{color:#e53935;color:var(--ag-value-change-delta-down-color,#e53935)}.ag-theme-balham .ag-value-change-value{background-color:transparent;border-radius:1px;padding-left:1px;padding-right:1px;transition:background-color 1s}.ag-theme-balham .ag-value-change-value-highlight{background-color:rgba(22,160,133,.5);background-color:var(--ag-value-change-value-highlight-background-color,rgba(22,160,133,.5));transition:background-color .1s}.ag-theme-balham .ag-cell-data-changed{background-color:rgba(22,160,133,.5)!important;background-color:var(--ag-value-change-value-highlight-background-color,rgba(22,160,133,.5))!important}.ag-theme-balham .ag-cell-data-changed-animation{background-color:transparent}.ag-theme-balham .ag-cell-highlight{background-color:#0091ea!important;background-color:var(--ag-range-selection-highlight-color,var(--ag-balham-active-color,#0091ea))!important}.ag-theme-balham .ag-row{height:28px;background-color:#fff;background-color:var(--ag-background-color,#fff);color:#000;color:var(--ag-data-color,var(--ag-foreground-color,#000));border-width:1px;border-color:#d9dcde;border-color:var(--ag-row-border-color,#d9dcde)}.ag-theme-balham .ag-row:not(.ag-row-first){border-top-style:solid}.ag-theme-balham .ag-row.ag-row-last{border-bottom-style:solid}.ag-theme-balham .ag-row-highlight-above:after,.ag-theme-balham .ag-row-highlight-below:after{content:"";position:absolute;width:calc(100% - 1px);height:1px;background-color:#0091ea;background-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#0091ea));left:1px}.ag-theme-balham .ag-row-highlight-above:after{top:-1px}.ag-theme-balham .ag-row-highlight-above.ag-row-first:after{top:0}.ag-theme-balham .ag-row-highlight-below:after{bottom:0}.ag-theme-balham .ag-row-odd{background-color:#fcfdfe;background-color:var(--ag-odd-row-background-color,#fcfdfe)}.ag-theme-balham .ag-horizontal-left-spacer:not(.ag-scroller-corner){border-right:1px solid #bdc3c7;border-right-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-horizontal-right-spacer:not(.ag-scroller-corner){border-left:1px solid #bdc3c7;border-left-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-row-hover{background-color:#ecf0f1;background-color:var(--ag-row-hover-color,#ecf0f1)}.ag-theme-balham .ag-ltr .ag-right-aligned-cell{text-align:right}.ag-theme-balham .ag-rtl .ag-right-aligned-cell{text-align:left}.ag-theme-balham .ag-ltr .ag-right-aligned-cell .ag-cell-value{margin-left:auto}.ag-theme-balham .ag-rtl .ag-right-aligned-cell .ag-cell-value{margin-right:auto}.ag-theme-balham .ag-cell{border:1px solid transparent;line-height:26px}.ag-theme-balham .ag-cell,.ag-theme-balham .ag-row>.ag-cell-wrapper{padding-left:11px;padding-right:11px}.ag-theme-balham .ag-row-dragging{cursor:move;opacity:.5}.ag-theme-balham .ag-cell-inline-editing{height:28px}.ag-theme-balham .ag-cell-inline-editing,.ag-theme-balham .ag-popup-editor{border:1px solid #bdc3c7;border-color:var(--ag-border-color,#bdc3c7);background:#fff;background:var(--ag-background-color,#fff);border-radius:2px;box-shadow:none;padding:0;background-color:#f5f7f7;background-color:var(--ag-control-panel-background-color,#f5f7f7)}.ag-theme-balham .ag-large-text-input{height:auto;padding:12px}.ag-theme-balham .ag-details-row{padding:20px;background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-balham .ag-overlay-loading-wrapper{background-color:hsla(0,0%,100%,.66);background-color:var(--ag-modal-overlay-background-color,hsla(0,0%,100%,.66))}.ag-theme-balham .ag-overlay-loading-center{background:#fff;background:var(--ag-background-color,#fff);border-radius:2px;box-shadow:none;padding:4px}.ag-theme-balham .ag-overlay-no-rows-wrapper.ag-layout-auto-height{padding-top:30px}.ag-theme-balham .ag-loading{padding-left:12px;display:flex;height:100%;align-items:center}.ag-theme-balham .ag-loading-icon{padding-right:12px}.ag-theme-balham .ag-icon-loading{-webkit-animation-name:spin;animation-name:spin;-webkit-animation-duration:1s;animation-duration:1s;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite;-webkit-animation-timing-function:linear;animation-timing-function:linear}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}.ag-theme-balham .ag-floating-top{border-bottom:1px solid #bdc3c7;border-bottom-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-floating-bottom{border-top:1px solid #bdc3c7;border-top-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-ltr .ag-cell{border-right:solid transparent}.ag-theme-balham .ag-rtl .ag-cell{border-left:solid transparent}.ag-theme-balham .ag-ltr .ag-cell{border-right-width:1px}.ag-theme-balham .ag-rtl .ag-cell{border-left-width:1px}.ag-theme-balham .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell){border-left:1px solid #bdc3c7;border-left-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell){border-right:1px solid #bdc3c7;border-right-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-row-selected{background-color:#b7e4ff;background-color:var(--ag-selected-row-background-color,#b7e4ff)}.ag-theme-balham .ag-cell-range-selected:not(.ag-cell-focus){background-color:rgba(0,145,234,.2);background-color:var(--ag-range-selection-background-color,rgba(0,145,234,.2))}.ag-theme-balham .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart{background-color:rgba(0,88,255,.1);background-color:var(--ag-range-selection-chart-background-color,rgba(0,88,255,.1))}.ag-theme-balham .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category{background-color:rgba(0,255,132,.1);background-color:var(--ag-range-selection-chart-category-background-color,rgba(0,255,132,.1))}.ag-theme-balham .ag-cell-range-selected-1:not(.ag-cell-focus){background-color:rgba(0,145,234,.2);background-color:var(--ag-range-selection-background-color-1,var(--ag-range-selection-background-color,rgba(0,145,234,.2)))}.ag-theme-balham .ag-cell-range-selected-2:not(.ag-cell-focus){background-color:rgba(0,145,234,.36);background-color:var(--ag-range-selection-background-color-2,rgba(0,145,234,.36))}.ag-theme-balham .ag-cell-range-selected-3:not(.ag-cell-focus){background-color:rgba(0,145,234,.488);background-color:var(--ag-range-selection-background-color-3,rgba(0,145,234,.488))}.ag-theme-balham .ag-cell-range-selected-4:not(.ag-cell-focus){background-color:rgba(0,145,234,.5904);background-color:var(--ag-range-selection-background-color-4,rgba(0,145,234,.5904))}.ag-theme-balham .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top{border-top-color:#0091ea;border-top-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#0091ea))}.ag-theme-balham .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right{border-right-color:#0091ea;border-right-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#0091ea))}.ag-theme-balham .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom{border-bottom-color:#0091ea;border-bottom-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#0091ea))}.ag-theme-balham .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left{border-left-color:#0091ea;border-left-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#0091ea))}.ag-theme-balham .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-balham .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-balham .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),.ag-theme-balham .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-balham .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-balham .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected){border:1px solid #0091ea;border-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#0091ea));outline:initial}.ag-theme-balham .ag-cell.ag-selection-fill-top,.ag-theme-balham .ag-cell.ag-selection-fill-top.ag-cell-range-selected{border-top:1px dashed #0091ea;border-top-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#0091ea))}.ag-theme-balham .ag-ltr .ag-cell.ag-selection-fill-right,.ag-theme-balham .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-right:1px dashed #0091ea;border-right-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#0091ea))}.ag-theme-balham .ag-rtl .ag-cell.ag-selection-fill-right,.ag-theme-balham .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-left:1px dashed #0091ea;border-left-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#0091ea))}.ag-theme-balham .ag-cell.ag-selection-fill-bottom,.ag-theme-balham .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected{border-bottom:1px dashed #0091ea;border-bottom-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#0091ea))}.ag-theme-balham .ag-ltr .ag-cell.ag-selection-fill-left,.ag-theme-balham .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-left:1px dashed #0091ea;border-left-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#0091ea))}.ag-theme-balham .ag-rtl .ag-cell.ag-selection-fill-left,.ag-theme-balham .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-right:1px dashed #0091ea;border-right-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#0091ea))}.ag-theme-balham .ag-fill-handle,.ag-theme-balham .ag-range-handle{position:absolute;width:6px;height:6px;bottom:-1px;background-color:#0091ea;background-color:var(--ag-range-selection-border-color,var(--ag-balham-active-color,#0091ea))}.ag-theme-balham .ag-ltr .ag-fill-handle,.ag-theme-balham .ag-ltr .ag-range-handle{right:-1px}.ag-theme-balham .ag-rtl .ag-fill-handle,.ag-theme-balham .ag-rtl .ag-range-handle{left:-1px}.ag-theme-balham .ag-fill-handle{cursor:cell}.ag-theme-balham .ag-range-handle{cursor:nwse-resize}.ag-theme-balham .ag-cell-inline-editing{border-color:#719ece!important;border-color:var(--ag-input-focus-border-color,#719ece)!important}.ag-theme-balham .ag-menu{border:1px solid #bdc3c7;border-color:var(--ag-border-color,#bdc3c7);background:#fff;background:var(--ag-background-color,#fff);border-radius:2px;box-shadow:none;padding:0}.ag-theme-balham .ag-menu-list{cursor:default;width:100%;padding-top:4px;padding-bottom:4px}.ag-theme-balham .ag-menu-option-part{padding-top:6px;padding-bottom:6px;line-height:16px}.ag-theme-balham .ag-menu-option-active{background-color:#ecf0f1;background-color:var(--ag-row-hover-color,#ecf0f1)}.ag-theme-balham .ag-menu-option-disabled{opacity:.5}.ag-theme-balham .ag-menu-option-text{margin-left:4px}.ag-theme-balham .ag-menu-option-icon{padding-left:8px;padding-right:4px;min-width:24px}.ag-theme-balham .ag-menu-option-shortcut{padding-left:8px}.ag-theme-balham .ag-menu-separator{height:8px}.ag-theme-balham .ag-menu-separator-cell:after{content:"";display:block;border-top:1px solid #bdc3c7;border-top-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-menu-option-popup-pointer{width:24px;text-align:center}.ag-theme-balham .ag-tabs-header{min-width:220px;width:100%;display:flex}.ag-theme-balham .ag-tab{border-bottom:0 solid transparent;display:flex;flex:none;align-items:center;justify-content:center;cursor:pointer}.ag-theme-balham .ag-keyboard-focus .ag-tab:focus{outline:none}.ag-theme-balham .ag-keyboard-focus .ag-tab:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham .ag-tab-selected{border-bottom-color:#0091ea;border-bottom-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-balham-active-color,#0091ea)))}.ag-theme-balham .ag-menu-header{color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-balham .ag-filter-condition-operator{height:17px}.ag-theme-balham .ag-ltr .ag-filter-condition-operator-or{margin-left:8px}.ag-theme-balham .ag-rtl .ag-filter-condition-operator-or{margin-right:8px}.ag-theme-balham .ag-set-filter-select-all{padding-top:6px}.ag-theme-balham .ag-set-filter-list{height:168px}.ag-theme-balham .ag-set-filter-filter{margin-top:6px;margin-left:6px;margin-right:6px}.ag-theme-balham .ag-filter-to{margin-top:4px}.ag-theme-balham .ag-mini-filter{margin:6px 6px 0}.ag-theme-balham .ag-set-filter-item{margin:0 6px}.ag-theme-balham .ag-ltr .ag-set-filter-item-value{margin-left:6px}.ag-theme-balham .ag-rtl .ag-set-filter-item-value{margin-right:6px}.ag-theme-balham .ag-filter-header-container{padding-bottom:6px;border-bottom:1px solid #bdc3c7;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#bdc3c7))}.ag-theme-balham .ag-filter-apply-panel{padding:6px;border-top:1px solid #bdc3c7;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#bdc3c7))}.ag-theme-balham .ag-filter-apply-panel-button{line-height:1.5}.ag-theme-balham .ag-ltr .ag-filter-apply-panel-button{margin-left:8px}.ag-theme-balham .ag-rtl .ag-filter-apply-panel-button{margin-right:8px}.ag-theme-balham .ag-simple-filter-body-wrapper{padding:6px 6px 2px}.ag-theme-balham .ag-simple-filter-body-wrapper>*{margin-bottom:4px}.ag-theme-balham .ag-filter-no-matches{margin:6px}.ag-theme-balham .ag-side-bar{position:relative}.ag-theme-balham .ag-tool-panel-wrapper{background-color:#f5f7f7;background-color:var(--ag-control-panel-background-color,#f5f7f7)}.ag-theme-balham .ag-side-buttons{padding-top:16px;width:20px;position:relative;color:#000;color:var(--ag-foreground-color,#000);overflow:hidden}.ag-theme-balham button.ag-side-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;background:transparent;padding:8px 0;width:calc(100% + 1px);margin:0;min-height:72px;background-position-y:center;background-position-x:center;background-repeat:no-repeat;border-left:none;border-right:none;border-top:#bdc3c7;border-top:1px solid var(--ag-border-color,#bdc3c7);border-bottom:#bdc3c7;border-bottom:1px solid var(--ag-border-color,#bdc3c7)}.ag-theme-balham button.ag-side-button-button:focus{box-shadow:none}.ag-theme-balham .ag-keyboard-focus .ag-side-button-button:focus{outline:none}.ag-theme-balham .ag-keyboard-focus .ag-side-button-button:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham .ag-selected .ag-side-button-button{background-color:#f5f7f7;background-color:var(--ag-control-panel-background-color,#f5f7f7);border-top-color:#bdc3c7;border-top-color:var(--ag-border-color,#bdc3c7);border-bottom-color:#bdc3c7;border-bottom-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-side-button-icon-wrapper{margin-bottom:3px}.ag-theme-balham .ag-ltr .ag-side-bar-left,.ag-theme-balham .ag-rtl .ag-side-bar-right{border-right:1px solid #bdc3c7;border-right-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,.ag-theme-balham .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper{border-left:1px solid #bdc3c7;border-left-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-ltr .ag-side-bar-left .ag-side-button-button,.ag-theme-balham .ag-rtl .ag-side-bar-right .ag-side-button-button{border-right:0 solid transparent;margin-right:-1px;padding-right:1px}.ag-theme-balham .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,.ag-theme-balham .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button{border-right-color:#0091ea;border-right-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-balham-active-color,#0091ea)))}.ag-theme-balham .ag-ltr .ag-side-bar-right,.ag-theme-balham .ag-rtl .ag-side-bar-left{border-left:1px solid #bdc3c7;border-left-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper,.ag-theme-balham .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper{border-right:1px solid #bdc3c7;border-right-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-ltr .ag-side-bar-right .ag-side-button-button,.ag-theme-balham .ag-rtl .ag-side-bar-left .ag-side-button-button{border-left:0 solid transparent;margin-left:-1px;padding-left:1px}.ag-theme-balham .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button,.ag-theme-balham .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button{border-left-color:#0091ea;border-left-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-balham-active-color,#0091ea)))}.ag-theme-balham .ag-filter-toolpanel-header{height:24px}.ag-theme-balham .ag-ltr .ag-filter-toolpanel-header,.ag-theme-balham .ag-ltr .ag-filter-toolpanel-search{padding-left:4px}.ag-theme-balham .ag-rtl .ag-filter-toolpanel-header,.ag-theme-balham .ag-rtl .ag-filter-toolpanel-search{padding-right:4px}.ag-theme-balham .ag-keyboard-focus .ag-filter-toolpanel-header:focus{outline:none}.ag-theme-balham .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{font-family:agGridBalham;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;content:"\\f112";position:absolute}.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-left:4px}.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-right:4px}.ag-theme-balham .ag-filter-toolpanel-group-level-0-header{height:32px}.ag-theme-balham .ag-filter-toolpanel-group-item{margin-top:2px;margin-bottom:2px}.ag-theme-balham .ag-filter-toolpanel-search{height:32px}.ag-theme-balham .ag-filter-toolpanel-search-input{flex-grow:1;height:16px}.ag-theme-balham .ag-ltr .ag-filter-toolpanel-search-input{margin-right:4px}.ag-theme-balham .ag-rtl .ag-filter-toolpanel-search-input{margin-left:4px}.ag-theme-balham .ag-filter-toolpanel-group-level-0{border-top:1px solid #bdc3c7;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#bdc3c7))}.ag-theme-balham .ag-ltr .ag-filter-toolpanel-expand,.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-title-bar-icon{margin-right:4px}.ag-theme-balham .ag-rtl .ag-filter-toolpanel-expand,.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-title-bar-icon{margin-left:4px}.ag-theme-balham .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-left:20px}.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-right:20px}.ag-theme-balham .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-left:36px}.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-right:36px}.ag-theme-balham .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-left:52px}.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-right:52px}.ag-theme-balham .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-left:68px}.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-right:68px}.ag-theme-balham .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-left:84px}.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-right:84px}.ag-theme-balham .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-left:100px}.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-right:100px}.ag-theme-balham .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-left:116px}.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-right:116px}.ag-theme-balham .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-left:132px}.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-right:132px}.ag-theme-balham .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-left:148px}.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-right:148px}.ag-theme-balham .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-left:164px}.ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-right:164px}.ag-theme-balham .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header{padding-left:4px}.ag-theme-balham .ag-filter-toolpanel-instance-filter{border-top:1px solid #bdc3c7;border-top-color:var(--ag-border-color,#bdc3c7);border-bottom:1px solid #bdc3c7;border-bottom-color:var(--ag-border-color,#bdc3c7);padding-top:4px}.ag-theme-balham .ag-ltr .ag-filter-toolpanel-instance-header-icon{margin-left:4px}.ag-theme-balham .ag-rtl .ag-filter-toolpanel-instance-header-icon{margin-right:4px}.ag-theme-balham .ag-pivot-mode-panel{height:32px;display:flex}.ag-theme-balham .ag-pivot-mode-select{display:flex;align-items:center}.ag-theme-balham .ag-ltr .ag-pivot-mode-select{margin-left:6px}.ag-theme-balham .ag-rtl .ag-pivot-mode-select{margin-right:6px}.ag-theme-balham .ag-keyboard-focus .ag-column-select-header:focus{outline:none}.ag-theme-balham .ag-keyboard-focus .ag-column-select-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham .ag-column-select-header{height:32px;align-items:center;padding:0 6px}.ag-theme-balham .ag-column-panel-column-select,.ag-theme-balham .ag-column-select-header{border-bottom:1px solid #bdc3c7;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#bdc3c7))}.ag-theme-balham .ag-column-panel-column-select{border-top:1px solid #bdc3c7;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#bdc3c7))}.ag-theme-balham .ag-column-group-icons,.ag-theme-balham .ag-column-select-header-icon{color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-balham .ag-header{background-color:#f5f7f7;background-color:var(--ag-header-background-color,#f5f7f7);border-bottom:1px solid #bdc3c7;border-bottom-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-header-row{color:rgba(0,0,0,.54);color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,rgba(0,0,0,.54)))}.ag-theme-balham .ag-pinned-right-header{border-left:1px solid #bdc3c7;border-left-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-pinned-left-header{border-right:1px solid #bdc3c7;border-right-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-header-row{height:32px}.ag-theme-balham .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-left:4px}.ag-theme-balham .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon,.ag-theme-balham .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-right:4px}.ag-theme-balham .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon{margin-left:4px}.ag-theme-balham .ag-header-cell,.ag-theme-balham .ag-header-group-cell{padding-left:12px;padding-right:12px}.ag-theme-balham .ag-header-cell.ag-header-cell-moving,.ag-theme-balham .ag-header-group-cell.ag-header-cell-moving{background-color:#fff;background-color:var(--ag-header-cell-moving-background-color,var(--ag-background-color,#fff))}.ag-theme-balham .ag-keyboard-focus .ag-header-cell:focus{outline:none}.ag-theme-balham .ag-keyboard-focus .ag-header-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham .ag-keyboard-focus .ag-header-group-cell:focus{outline:none}.ag-theme-balham .ag-keyboard-focus .ag-header-group-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #719ece;border-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham .ag-header-icon{color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-balham .ag-header-expand-icon{cursor:pointer}.ag-theme-balham .ag-ltr .ag-header-expand-icon{padding-left:4px}.ag-theme-balham .ag-rtl .ag-header-expand-icon{padding-right:4px}.ag-theme-balham .ag-header-row:not(:first-child) .ag-header-cell,.ag-theme-balham .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group{border-top:1px solid #bdc3c7;border-top-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-header-cell:after,.ag-theme-balham .ag-header-group-cell:after{content:"";position:absolute;z-index:1;display:block;width:1px;height:50%;top:25%;background-color:rgba(189,195,199,.5);background-color:var(--ag-header-column-separator-color,rgba(189,195,199,.5))}.ag-theme-balham .ag-ltr .ag-header-cell:after,.ag-theme-balham .ag-ltr .ag-header-group-cell:after{right:0}.ag-theme-balham .ag-rtl .ag-header-cell:after,.ag-theme-balham .ag-rtl .ag-header-group-cell:after{left:0}.ag-theme-balham .ag-ltr .ag-header-select-all{margin-right:12px}.ag-theme-balham .ag-ltr .ag-floating-filter-button,.ag-theme-balham .ag-rtl .ag-header-select-all{margin-left:12px}.ag-theme-balham .ag-rtl .ag-floating-filter-button{margin-right:12px}.ag-theme-balham .ag-floating-filter-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;height:16px;padding:0;width:16px}.ag-theme-balham .ag-filter-loading{background-color:#f5f7f7;background-color:var(--ag-control-panel-background-color,#f5f7f7);height:100%;padding:6px;position:absolute;width:100%;z-index:1}.ag-theme-balham .ag-paging-panel{border-top:1px solid #bdc3c7;border-top-color:var(--ag-border-color,#bdc3c7);color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54));height:32px}.ag-theme-balham .ag-paging-panel>*{margin:0 12px}.ag-theme-balham .ag-paging-button{cursor:pointer;opacity:0;top:0;right:0;bottom:0;left:0;padding:0;width:16px}.ag-theme-balham .ag-disabled .ag-paging-button{cursor:default}.ag-theme-balham .ag-paging-button-wrapper.ag-disabled{color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38));cursor:default}.ag-theme-balham .ag-paging-button-wrapper,.ag-theme-balham .ag-paging-description{margin:0 4px}.ag-theme-balham .ag-status-bar{border-top:1px solid #bdc3c7;border-top-color:var(--ag-border-color,#bdc3c7);color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38));padding-right:16px;padding-left:16px;line-height:1.5}.ag-theme-balham .ag-status-name-value-value{color:#000;color:var(--ag-foreground-color,#000)}.ag-theme-balham .ag-status-bar-center{text-align:center}.ag-theme-balham .ag-status-name-value{margin-left:4px;margin-right:4px;padding-top:8px;padding-bottom:8px}.ag-theme-balham .ag-column-drop-cell{background:#dddede;background:var(--ag-chip-background-color,#dddede);border-radius:16px;height:16px;padding:0 2px}.ag-theme-balham .ag-column-drop-cell-text{margin:0 4px}.ag-theme-balham .ag-column-drop-cell-button{min-width:16px;margin:0 2px;color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-balham .ag-column-drop-cell-drag-handle{margin-left:8px}.ag-theme-balham .ag-column-drop-cell-ghost{opacity:.5}.ag-theme-balham .ag-column-drop-horizontal{background-color:#f5f7f7;background-color:var(--ag-control-panel-background-color,#f5f7f7);color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54));height:28px;border-bottom:1px solid #bdc3c7;border-bottom-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-ltr .ag-column-drop-horizontal{padding-left:12px}.ag-theme-balham .ag-rtl .ag-column-drop-horizontal{padding-right:12px}.ag-theme-balham .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child){border-right:1px solid #bdc3c7;border-right-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child){border-left:1px solid #bdc3c7;border-left-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-column-drop-horizontal-cell-separator{margin:0 4px;color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-balham .ag-column-drop-horizontal-empty-message{color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38))}.ag-theme-balham .ag-ltr .ag-column-drop-horizontal-icon{margin-right:12px}.ag-theme-balham .ag-rtl .ag-column-drop-horizontal-icon{margin-left:12px}.ag-theme-balham .ag-column-drop-vertical-list{padding-bottom:4px;padding-right:4px;padding-left:4px}.ag-theme-balham .ag-column-drop-vertical-cell{margin-top:4px}.ag-theme-balham .ag-column-drop-vertical{min-height:50px;max-height:150px;border-bottom:1px solid #bdc3c7;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#bdc3c7))}.ag-theme-balham .ag-column-drop-vertical.ag-last-column-drop{border-bottom:none}.ag-theme-balham .ag-column-drop-vertical-icon{margin-left:4px;margin-right:4px}.ag-theme-balham .ag-column-drop-vertical-list{position:relative}.ag-theme-balham .ag-column-drop-vertical-empty-message{position:absolute;top:0;bottom:0;left:0;right:0;overflow:hidden;color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38));margin-top:4px}.ag-theme-balham .ag-select-agg-func-popup{border:1px solid #bdc3c7;border-color:var(--ag-border-color,#bdc3c7);border-radius:2px;box-shadow:none;background:#fff;background:var(--ag-background-color,#fff);height:70px;padding:0}.ag-theme-balham .ag-select-agg-func-virtual-list-item{cursor:default;line-height:20px;padding-left:8px}.ag-theme-balham .ag-select-agg-func-virtual-list-item:hover{background-color:#b7e4ff;background-color:var(--ag-selected-row-background-color,#b7e4ff)}.ag-theme-balham .ag-chart-menu{border-radius:2px;background:#fff;background:var(--ag-background-color,#fff)}.ag-theme-balham .ag-chart-menu-icon{opacity:.5;line-height:24px;font-size:24px;width:24px;height:24px;margin:2px 0;cursor:pointer;border-radius:2px;color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-balham .ag-chart-menu-icon:hover{opacity:1}.ag-theme-balham .ag-chart-mini-thumbnail{border:1px solid #bdc3c7;border-color:var(--ag-secondary-border-color,var(--ag-border-color,#bdc3c7));border-radius:5px;margin:5px}.ag-theme-balham .ag-chart-mini-thumbnail:nth-last-child(3),.ag-theme-balham .ag-chart-mini-thumbnail:nth-last-child(3)~.ag-chart-mini-thumbnail{margin-left:auto;margin-right:auto}.ag-theme-balham .ag-ltr .ag-chart-mini-thumbnail:first-child{margin-left:0}.ag-theme-balham .ag-ltr .ag-chart-mini-thumbnail:last-child,.ag-theme-balham .ag-rtl .ag-chart-mini-thumbnail:first-child{margin-right:0}.ag-theme-balham .ag-rtl .ag-chart-mini-thumbnail:last-child{margin-left:0}.ag-theme-balham .ag-chart-mini-thumbnail.ag-selected{border-color:#0091ea;border-color:var(--ag-minichart-selected-chart-color,var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#0091ea)))}.ag-theme-balham .ag-chart-settings-card-item{background:#000;background:var(--ag-foreground-color,#000);width:8px;height:8px;border-radius:4px}.ag-theme-balham .ag-chart-settings-card-item.ag-selected{background-color:#0091ea;background-color:var(--ag-minichart-selected-page-color,var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#0091ea)))}.ag-theme-balham .ag-chart-data-column-drag-handle{margin-left:4px}.ag-theme-balham .ag-charts-data-group-title-bar,.ag-theme-balham .ag-charts-format-top-level-group-title-bar,.ag-theme-balham .ag-charts-settings-group-title-bar{border-top:1px solid #bdc3c7;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#bdc3c7))}.ag-theme-balham .ag-charts-settings-group-container{padding:4px}.ag-theme-balham .ag-charts-data-group-container{padding:6px 6px 2px}.ag-theme-balham .ag-charts-data-group-container>*{margin-bottom:4px}.ag-theme-balham .ag-charts-format-top-level-group-container{margin-left:8px;padding:4px}.ag-theme-balham .ag-charts-format-top-level-group-item{margin:4px 0}.ag-theme-balham .ag-charts-format-sub-level-group-container{padding:6px 6px 2px}.ag-theme-balham .ag-charts-format-sub-level-group-container>*{margin-bottom:4px}.ag-theme-balham .ag-charts-group-container.ag-group-container-horizontal{padding:4px}.ag-theme-balham .ag-chart-data-section,.ag-theme-balham .ag-chart-format-section{display:flex;margin:0}.ag-theme-balham .ag-chart-menu-panel{background-color:#f5f7f7;background-color:var(--ag-control-panel-background-color,#f5f7f7)}.ag-theme-balham .ag-ltr .ag-chart-menu-panel{border-left:1px solid #bdc3c7;border-left-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-rtl .ag-chart-menu-panel{border-right:1px solid #bdc3c7;border-right-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-date-time-list-page-title{flex-grow:1;text-align:center}.ag-theme-balham .ag-date-time-list-page-column-label,.ag-theme-balham .ag-date-time-list-page-entry{text-align:center}.ag-theme-balham .ag-checkbox-input-wrapper{font-family:agGridBalham;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:16px;height:16px;background-color:#fff;background-color:var(--ag-checkbox-background-color,var(--ag-background-color,#fff));border-radius:3px;display:inline-block;vertical-align:middle;flex:none}.ag-theme-balham .ag-checkbox-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-balham .ag-checkbox-input-wrapper:active,.ag-theme-balham .ag-checkbox-input-wrapper:focus-within{outline:none;box-shadow:0 0 2px 1px #719ece}.ag-theme-balham .ag-checkbox-input-wrapper.ag-disabled{opacity:.5}.ag-theme-balham .ag-checkbox-input-wrapper:after{content:"\\f108";color:#7f8c8d;color:var(--ag-checkbox-unchecked-color,#7f8c8d);position:absolute;top:0;left:0;pointer-events:none}.ag-theme-balham .ag-checkbox-input-wrapper.ag-checked:after{content:"\\f106";color:#0091ea;color:var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#0091ea));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-balham .ag-checkbox-input-wrapper.ag-indeterminate:after{content:"\\f107";color:#7f8c8d;color:var(--ag-checkbox-indeterminate-color,var(--ag-checkbox-unchecked-color,#7f8c8d));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-balham .ag-toggle-button-input-wrapper{box-sizing:border-box;width:32px;height:16px;background-color:#7f8c8d;background-color:var(--ag-toggle-button-off-background-color,var(--ag-checkbox-unchecked-color,#7f8c8d));border-radius:8px;position:relative;flex:none;border:1px solid #7f8c8d;border-color:var(--ag-toggle-button-off-border-color,var(--ag-checkbox-unchecked-color,#7f8c8d))}.ag-theme-balham .ag-toggle-button-input-wrapper input{opacity:0;height:100%;width:100%}.ag-theme-balham .ag-toggle-button-input-wrapper:focus-within{outline:none;box-shadow:0 0 2px 1px #719ece}.ag-theme-balham .ag-toggle-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-balham .ag-toggle-button-input-wrapper.ag-checked{background-color:#0091ea;background-color:var(--ag-toggle-button-on-background-color,var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#0091ea)));border-color:#0091ea;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#0091ea)))}.ag-theme-balham .ag-toggle-button-input-wrapper:before{content:" ";position:absolute;top:-1px;left:-1px;display:block;box-sizing:border-box;height:16px;width:16px;background-color:#fff;background-color:var(--ag-toggle-button-switch-background-color,var(--ag-background-color,#fff));border-radius:8px;transition:left .1s;border:1px solid #7f8c8d;border-color:var(--ag-toggle-button-switch-border-color,var(--ag-toggle-button-off-border-color,var(--ag-checkbox-unchecked-color,#7f8c8d)))}.ag-theme-balham .ag-toggle-button-input-wrapper.ag-checked:before{left:calc(100% - 16px);border-color:#0091ea;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#0091ea)))}.ag-theme-balham .ag-radio-button-input-wrapper{font-family:agGridBalham;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:16px;height:16px;background-color:#fff;background-color:var(--ag-checkbox-background-color,var(--ag-background-color,#fff));border-radius:3px;display:inline-block;vertical-align:middle;flex:none;border-radius:16px}.ag-theme-balham .ag-radio-button-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-balham .ag-radio-button-input-wrapper:active,.ag-theme-balham .ag-radio-button-input-wrapper:focus-within{outline:none;box-shadow:0 0 2px 1px #719ece}.ag-theme-balham .ag-radio-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-balham .ag-radio-button-input-wrapper:after{content:"\\f124";color:#7f8c8d;color:var(--ag-checkbox-unchecked-color,#7f8c8d);position:absolute;top:0;left:0;pointer-events:none}.ag-theme-balham .ag-radio-button-input-wrapper.ag-checked:after{content:"\\f125";color:#0091ea;color:var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#0091ea));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-balham input[class^=ag-][type=range]{-webkit-appearance:none;width:100%;height:100%;background:none;overflow:visible}.ag-theme-balham input[class^=ag-][type=range]::-webkit-slider-runnable-track{margin:0;padding:0;width:100%;height:3px;background-color:#bdc3c7;background-color:var(--ag-border-color,#bdc3c7);border-radius:2px;border-radius:3px}.ag-theme-balham input[class^=ag-][type=range]::-moz-range-track{margin:0;padding:0;width:100%;height:3px;background-color:#bdc3c7;background-color:var(--ag-border-color,#bdc3c7);border-radius:2px;border-radius:3px}.ag-theme-balham input[class^=ag-][type=range]::-ms-track{margin:0;padding:0;width:100%;height:3px;background-color:#bdc3c7;background-color:var(--ag-border-color,#bdc3c7);border-radius:2px;border-radius:3px;color:transparent;width:calc(100% - 2px)}.ag-theme-balham input[class^=ag-][type=range]::-webkit-slider-thumb{margin:0;padding:0;-webkit-appearance:none;width:16px;height:16px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #7f8c8d;border-color:var(--ag-checkbox-unchecked-color,#7f8c8d);border-radius:16px;-webkit-transform:translateY(-6.5px);transform:translateY(-6.5px)}.ag-theme-balham input[class^=ag-][type=range]::-ms-thumb{margin:0;padding:0;-webkit-appearance:none;width:16px;height:16px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #7f8c8d;border-color:var(--ag-checkbox-unchecked-color,#7f8c8d);border-radius:16px}.ag-theme-balham input[class^=ag-][type=range]::-moz-ag-range-thumb{margin:0;padding:0;-webkit-appearance:none;width:16px;height:16px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #7f8c8d;border-color:var(--ag-checkbox-unchecked-color,#7f8c8d);border-radius:16px}.ag-theme-balham input[class^=ag-][type=range]:focus{outline:none}.ag-theme-balham input[class^=ag-][type=range]:focus::-webkit-slider-thumb{box-shadow:0 0 2px 1px #719ece;border-color:#0091ea;border-color:var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#0091ea))}.ag-theme-balham input[class^=ag-][type=range]:focus::-ms-thumb{box-shadow:0 0 2px 1px #719ece;border-color:#0091ea;border-color:var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#0091ea))}.ag-theme-balham input[class^=ag-][type=range]:focus::-moz-ag-range-thumb{box-shadow:0 0 2px 1px #719ece;border-color:#0091ea;border-color:var(--ag-checkbox-checked-color,var(--ag-balham-active-color,#0091ea))}.ag-theme-balham input[class^=ag-][type=range]:active::-webkit-slider-runnable-track{background-color:#719ece;background-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham input[class^=ag-][type=range]:active::-moz-ag-range-track{background-color:#719ece;background-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham input[class^=ag-][type=range]:active::-ms-track{background-color:#719ece;background-color:var(--ag-input-focus-border-color,#719ece)}.ag-theme-balham input[class^=ag-][type=range]:disabled{opacity:.5}.ag-theme-balham .ag-filter-toolpanel-header,.ag-theme-balham .ag-filter-toolpanel-search,.ag-theme-balham .ag-header-row,.ag-theme-balham .ag-status-bar{font-weight:600;color:rgba(0,0,0,.54);color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,rgba(0,0,0,.54)))}.ag-theme-balham .ag-ltr input[class^=ag-]:not([type]),.ag-theme-balham .ag-ltr input[class^=ag-][type=date],.ag-theme-balham .ag-ltr input[class^=ag-][type=datetime-local],.ag-theme-balham .ag-ltr input[class^=ag-][type=number],.ag-theme-balham .ag-ltr input[class^=ag-][type=tel],.ag-theme-balham .ag-ltr input[class^=ag-][type=text],.ag-theme-balham .ag-ltr textarea[class^=ag-]{padding-left:4px}.ag-theme-balham .ag-rtl input[class^=ag-]:not([type]),.ag-theme-balham .ag-rtl input[class^=ag-][type=date],.ag-theme-balham .ag-rtl input[class^=ag-][type=datetime-local],.ag-theme-balham .ag-rtl input[class^=ag-][type=number],.ag-theme-balham .ag-rtl input[class^=ag-][type=tel],.ag-theme-balham .ag-rtl input[class^=ag-][type=text],.ag-theme-balham .ag-rtl textarea[class^=ag-]{padding-right:4px}.ag-theme-balham .ag-column-drop-vertical-empty-message,.ag-theme-balham .ag-status-bar{font-weight:600;color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38))}.ag-theme-balham .ag-dnd-ghost{font-weight:600}.ag-theme-balham .ag-tab{border:1px solid transparent;padding:4px 8px;margin:4px 4px -1px}.ag-theme-balham .ag-tab-selected{background-color:#fff;background-color:var(--ag-background-color,#fff);border-color:#bdc3c7;border-color:var(--ag-border-color,#bdc3c7);border-bottom-color:transparent}.ag-theme-balham .ag-tabs-header{border-bottom:1px solid #bdc3c7;border-bottom-color:var(--ag-border-color,#bdc3c7)}.ag-theme-balham .ag-column-drop-cell{height:24px}.ag-theme-balham .ag-column-drop-vertical-title{color:#000;color:var(--ag-foreground-color,#000)}.ag-theme-balham .ag-column-drop-vertical-cell{margin-left:8px;margin-right:8px}.ag-theme-balham .ag-column-drop-vertical-cell-text{margin-left:8px}.ag-theme-balham .ag-column-drop-vertical-icon{color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-balham .ag-ltr .ag-column-drop-vertical-empty-message{padding-left:24px;padding-right:4px}.ag-theme-balham .ag-rtl .ag-column-drop-vertical-empty-message{padding-right:24px;padding-left:4px}.ag-theme-balham .ag-column-drop-horizontal{height:32px}.ag-theme-balham .ag-column-drop-empty{color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38))}.ag-theme-balham .ag-column-drop-horizontal-cell-text{margin-left:8px}.ag-theme-balham .ag-column-drop-vertical{padding-top:8px}.ag-theme-balham .ag-menu-header{background-color:#f5f7f7;background-color:var(--ag-header-background-color,#f5f7f7)}.ag-theme-balham .ag-overlay-loading-center{background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #bdc3c7;border-color:var(--ag-border-color,#bdc3c7);color:#000;color:var(--ag-foreground-color,#000);padding:16px}.ag-theme-balham .ag-tooltip{border:none;background-color:#cbd0d3}.ag-theme-balham .ag-panel-title-bar-button-icon{font-size:20px}.ag-theme-balham .ag-chart-data-section,.ag-theme-balham .ag-chart-format-section{padding-bottom:2px}.ag-theme-balham .ag-group-toolbar{background-color:rgba(226,233,235,.5);background-color:var(--ag-subheader-toolbar-background-color,rgba(226,233,235,.5))}.ag-theme-balham .ag-chart-tab{padding-top:2px}.ag-theme-balham .ag-charts-format-sub-level-group-item{margin-bottom:6px}',""]),e.exports=t},function(e,t,o){var r=o(27),a=o(164);"string"==typeof(a=a.__esModule?a.default:a)&&(a=[[e.i,a,""]]);var n={insert:"head",singleton:!1};r(a,n);e.exports=a.locals||{}},function(e,t,o){(t=o(28)(!1)).push([e.i,'.ag-theme-blue{-webkit-font-smoothing:antialiased;color:#222;color:var(--ag-foreground-color,#222);font-family:Helvetica Neue,sans-serif;font-size:14px;line-height:normal}@font-face{font-family:agGridClassic;src:url("data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABOsAAsAAAAAJiwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlIAAAReYchjok9TLzIAAANcAAAAQQAAAFZWVlJ+Y21hcAAAA6AAAAHtAAAFgHClDfdnbHlmAAAFkAAACi0AABQQq+8lqmhlYWQAAA/AAAAANAAAADZ2z8SBaGhlYQAAD/QAAAAeAAAAJAfTBChobXR4AAAQFAAAABoAAAEou4L/4mxvY2EAABAwAAAAbwAAAJb7HvWgbWF4cAAAEKAAAAAfAAAAIAFgAHhuYW1lAAAQwAAAATMAAAJS8kTiWnBvc3QAABH0AAABtgAAApcplp2DeJx9k0lyE0EQRX+rZSMPyGDMZMRkRpsh3O5BjSTLltzyQHjBggULNmYBAeFg5ROw5gAEB+AUnIBgyYoDcACCA/Ay1UbGC6tC1VWZP3/+yspSIGlSy+qqUmzuPld9f+/gveZV1fBn/qPrYP/tmz3VDnf4qv6tKQj/qK4FvdCBvgUKXgefK+NhJeyGu+GH8FP4QyGoG3oMekorjFgJc6RUmZrKVdE4tpj1E7VAh8xtt87qgsbcU2ig8+SMiRk445Ke6o7OwNN3np7WQKUM4+wxbzHuauYERK578GeoWcVqrA10ntWENtHYQ0eH6BbeGXzrZI6I6eProy10VNXruK2XRM762SwyK3Ep/1gbvo9894AqHKLa8DfhN75Fsh7am2RKiHgEewaqW9Zwif8U3hRMRGzHa2bR10AmKEx1nZWdLOFk07oN+zO98qwbZUzPqzg88yLqR/a+8+XkOWrtwLUF9iEaRla7kfvkirSDf5KbKvROH/VFX/VdP/VLv3UK6ypeO8Ea3OsnVqZG/Y6jC7ztf1Y76Th3fhz1P2KCcze9NjG+QVlByzaFTqtNyjrCmjp+Ep2GL1CTU68qOSLPm2AdY6yyj0GfLruxxZj2Og/oAeuAeWqxwmxMw37L2V+GyVZDXRe9Wi14LvltWU3tJdV9Zz1vtzxPna/wjThZ5vXZxnsVizGNLA2PylFtHMv4c9SOspmqBqoSeqDmnbXjr6Ag003OMVSS6Ja/gB3vqgUUZOWLnNM5V98pb2rOcbFHBWiOypeces2sk/tos67Y+gsvGGrHAAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMnxi4gDQjSA4A1QYKdAAAAHictdQHTltBFIXh3wXTTEnvvRc6hGp6XQbpiBREOsoqs5O7gZBzPScLIFJG+nw9o+c3b/R8LtAB1OSp1KFap0KO31qttNdr9LTX6/zSvEkXVX0fYo8DjmL0+FirQ+yyz2FU2rO/o6Krm1zlPs80W2GMJeZZZZItxmlpdZEF1phhmg0mmGOKdXaYZZlNtvX7qnav6xkbdGrfbj1Jr+7YRz8DDHKaM5zlHOe5wEUucZkr2u0a17nBTW5xmzvc5Z72f8BDHvGYJzrPkD6HNRvRAzY42Vg54fU5xpbmVye3xls67cLazLQOOje1vjO7vLn9Dzf7D6OZH7Wfnu2Qb7PI0+7amDy3JXlh8/LSVuWVTcpr25I3Ni5vrSV7lv+QfVuUd7Yg721NPtiMfLRpObANObQJ+WRz8tmm5Iuty1fLs3+zWfluy/LDNuXI9AKjUmRWolqQtVZktqJeZL6io8jcRaMga2dB1q6CrN0FWXuKzGP0FmRtFvkmo68ga39B1oGCrIMFWU8VyhJhShVhyhdhShphyhxhSh9hyiFhSiRhyiZhSilhyithSi5hyjBhSjNhyjVhSjhhyjphSj1hyj9h6gSEqScQpu5AmPoEYeoRhKl3EKb+QVj2zbDMTFj7muGCrCNF+56jBSN/AHzNoH4AAAB4nO1Ye2xT1xm/37nEN87D8bUdXwezwLWJDZQCtmNfO4FATIgdQhLWGwhrt0DSGJHHpgaawFRatBIVVrXbHxXTWCiPabMHo9MgSH1IGxJMa6b+sbBJFZVK2/HHVNjI6JZ2k8W97DvHjzyggPrntBufe17fPec73/md3/edcMDhw4f4fs7IcSBLglwuW3mZD+mj+/ZBQtv//vtkhPxuYiIFe2EvijD5T/lPuUVYCQpeRRK8oswyRRZZJokyywQZLrXFxscbNwPf1oh5m65txjzWpuu0PdYGhF9k/LIuWm/czOXm3Mq/whViRfAaMYlu+NkbCeiG7sTZU2TPGz3QrR/vOavdzMmTSTLJFTN51AW1QX3IZOOFsdiFC7GxC41jUJ8rjTVe4Ao47q6O67rBWTk35+Ue41ZyXIHsWgFBsboOArK/EspFmwl42WXAgh1bQtjlgYDorgqUu3nM+T7N5qpx4Y/83VUjyzWyZjY7HGZyW5Qk7ReqCi2qmmpvJ66Ii3yGL/xpZfjifySJmig6HCL5hyjpY/q1ZBJO6jtw2Vm9bjK9luJ6coq4p5UrmKOTALheK9/HdHDldbo1Q5teffLf1aev8zdyKuRU2jJTk3f0ot/XH4YTc/XwPpoevByUH6jFX/Tz0PoQHfTSJN3OWfM/2uwPmvkhk9L14qL38T2IjELOwXEIOskIvLIQDAL+ldvsOEu11+Mlf9O31zyta1A3Pv7ur4uLK8rsvg0+e1kFXIJTtdihX4Y14+N1paWVTk+Fy+dzVVQtqKTDG9gcR/gjOJuAWC3DtUkcV1WOZsPEz8nhlH6ej+rnk7OydAofaEniA620zGV1v5HF8spHsxYghsvdQXcwEAzw/RmLadaMBcmkZmaWoZbT30uxJ2NBS9aCk1kLWlFCJLdw2y5QlVJMFfaK8lG2ShH1CYhy0I0sIYsyH5TFQJCMJvWSJEyp+hi0pPQxlYyyehrrp7AxzeV54Hn+eXqujYDbIRgB2UCBKbAM65PspU8OgwVfpG9WFSxYncElhxmXiAFkLDrAz0+eTejH9eMJ+C4xaVNYOQFdCe6r4p7u2oPQ9wO95GGoH0smp233Lq9wFZyPW43zK1IoYJfskgkBicwGobUQdLsQk17rCuI1CJUg2RXJgMikfyEUUFgJ5UGu9qyNHnpucNvSb9cF6xeZ9D+taPYW1T0WfvzAX0PfXF3UUO17pVX9uv9bT3ZtrYus9D85BFc3N5os9kq5uHY5b1qyyjLvieaDa3Z5GgJLiuFAEQG1wGBy6tcM4W1Bf7zhabujeN2CImN1VZ1/40ub9KO+TqskLZwfaHf+b65FQjwv4UK4FroORg1ZXUNYpm12Jac0QcB4qzxrwE3lJBRR4A5dQdvw/hd/uJ8q+Y0933umoXpdZ/euZ3Zs3ciULWnctbc3VgQboagtFAtVLQl5VvPlvNr84nBLW0nJRs8af/NI85Yz/vg2JWwwKP4eq2RfVBF+qjrUWcOXLlgGhcXzm22FAuEyPMo4px95DT2+VQbRG/SVB4Iq45Qk34/eZ3sq3d6elSV30I/yLDoQ3SI6Fq8gwVqVmC9fDqfTZFIvgSm94dIlrFDxkuxZvziL05zcwmmvqiDT5BI8pCwjH6WSyTT7ISN8WQlOJpMTSUaCJ+/NUKWC7Lovcl/jZK4KPenjlIcYsSLvZSk2n0R3UAZ3Ofr0TKrCBKeQYdFGyLY0p0zF8h3t0JqdjqnD96tovqSaxiytklhas6hwqh15TFXn2rTKLQaARicCuaOq2m1m1PQMi2b46iS/lfGVhIRHQzTYebpHPw7dPWdIDZw8nYmDzlCyJXe/uPsF/y/+n1w1159BpaGMuiwvYs+j4AEL+RkqsdUElQQb6sCDnUGfhxaxC6segXVTOSlgpx95q70+KsbkK0muuxL82KmEvB7yQsRmWxIeibQ2b2rZbcMnEi+qsAARyTxDhdNmCTY1OQ8usFidRgepWFpoL7JbwBpp2dTcGhkJL0FxSzkU2QuXOUhpsdFptToPOpuaghabs8IwjzcTsFQUxSN0XJyptfkozkQru9kAcaPZFPQXWgzznfGmkM3qHHHG406jaHY5lhYSg5nOxFQaCR9FcUuZQAqXOlxmo1BEBUecVluoKe6cb7AU+oMmszHOVjHzvBxBFC9kjCUgLJGs0FciYyE8cfPQYwaUoNctlJPY0eGjV6/iK5kv/Pjl7u6Xu8lvZjXSgvZWN+3i5s2KPZchNz5a5CmwoBYU5E5JeXDseevjmG80fAyuxT7xvR5+/SEBqFYX+2jVMRR//pOYD/O8H5qOVViUAtnEH7nzWz6aSelMNEJjEfrJV12bwsJ2XCIlnAev7bmPYquOKaNQHfuYKv2wtaWza3sNTXJMOZa/L7yKZ7KA7jA9jfAUO4ngzxFb5hw6+T9zpdN3EBY7SDDamwAveBO9vQn9A/2DRC8514ctWOrTX+rDNuzry8YSd1ksYeMWcwEaS9ATZqZOYxF1EWb0CKECemYDflqk8eVKehyZTzSU0+MIU4efHYxu2BAdfFb/bGgw2tAQHRyCCe3NUH00Nti1XYlI0rJ4qH49VjrDEcAafxOlh/TbQ7up9O4hMON3Gz7X3lwmSRGls3swFl0XaspUugbj0fpQDvdR9BMCcjiL2DBMC0iUKTFyo6y2M51Mqfp5FaZ4h5Ygo2qK8l/eVjTewxq4RckteN0KpVQy2Xkurarpc50wha5jvDed7oWwmuHnPE5k9Khhbu39kUIDBAaVWvRHwQKMIBExfOYeyg4mPaFWSuL0BjAHN9p3DlDcHEjx67R3SKUo/adk9eBgbcnFklqaDUxo10mjdA+CyO1kBkIkhiT9tkOE1ZkPMt+VkljyBbwzzMYR85Tk1Tk4IjMwQG9zbGPNFAaL6I6bKQwEBgsb7XHRejXtgalD+d0uyyHgMNvwiLK96zpuNj6dXfff7C10a693d1Lhzm4UViKz8biUxTD3w6PEVGQ+g4GS3nk8VtwJ3BvcGdyX+0LyUAZ+VKXrOSW/v37P4T3r2euR1dR3NGQ/Wb8nj60TWX/oVfACoMhBcvCXCejSTyROa38gsTOZUP50Ks/fA4jjUs5OYxh07XmeKcj+uyKAAH5L9blI3OXTxwZqJiZqBtrRCX8Ii/UP6Y0NFi8YqJ2YqB2A16bxTUbp6BhBpchP9DG8sJzPc8koYp/QO4pIYwS8nrRoO+f2kUz4wNdjwDU2Z0wj0CCjJSOR7UvyMYorI0HG4ZPaFf294YvwNrmiXYHgEJam9YrTnaVHABXTdiI4aXM+LnBzMa4D+dtumxsXLATalo0KQn6Jt/vz3t5gw96sr6dfCKxNAooH8LgyFbufPCEIHTNCgA7BKrQaDNvQn1MH2yHYBBemDuqm0cVvMxhaUaJjhivvEATiWG4y3fmpyWPCnO80ef54r0zL7FHgV7MnablXjTufL8cRcTgc1VuKw//fJvfa5L+BscYKAAAAeJxjYGRgYABi/jvPp8Xz23xl4GZ+ARSI4ny8rwFG///2/xvzZ+ZPQJUcDExAkgEAoUMP6XicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AIAnloHAgAAeJxjYGBgYH5Ba/z/G+3M/f+NgQ4AAPv8MfAAAHicY2AAAgmGIIYshhaGC4wijCGMPYz7GF8xGTGFMVUwTWC6wGzGPIf5BwsfiwZLCcsOlgssL1gnsB5iE2EzYGtim8K2jZ2HXYvdhX0Z+w72fxwRHAUcszhWcGzjOMJxieMZxxfOOi4O0iEAtgsblgB4nGNgZGBg8GLIYeBhAAEmIOYCQgaG/2A+AwAbuAHZAHicfZC9TsMwFIVP+odoBaoEYmAyCwtS+rPRtVKzd+ieJnaaKo2D41bqznPwBDxHn4OnYObEeCkStSXnu9899w4BMMQJAZoT4Ma9zWnhitUvt0n3njvkJ89dDBB67tG/eu7jBQvPA9zhjRuCzjXNI949t3CLD89t+k/PHfLJcxcP+PLco//23McqGHoe4DlQcRaZPJ0XcV3nyVJm+yI2Z+6sWElT57oUk3B85iNZShNbmYr1UdSHbGqtEsronVjo0sqi0KIyeisTG26srWajkfI+TPQOMTJEMMiRYo6Cdc2bI8ESkr29c+ZC7v/OihuMY40SAhP+9/GFfMR86WZiWH5Tzqxx5FvjwKkprYVirZjR2JEWbneTLng1TeV6W5qEPsTGTVWYYcSr/uRDprjpB8WrbRMAeJxtkmdv2zAURX1iyVbstEnTNt17D7VN994z/RUMRctEJFIgKY/8+rJxGiBA36dzHx7uu3xgZ6mzqEHn/7XFEl0SUnr0yVhmwJAVjnCUVdY4xjrHOcFJNjjFac5wlnOc5wIXucRlrnCVa1znBje5xW3ucJd73CfnAQ95xCaPecJTnvGcF7zkFa95w1ve8Z4PfOQTn/nCV77xnR/85Bdb/O4MRVk6VYqgrekJ5+zUd4WXPSmMVFUqx8KFNTlWcmfbzvI9UMXGQUObQgXlam1EUOsH7dbsT65IW1mXNzoK14+irY0fSGuCEzKoIpG2mafSWe+TQnmZqVkjomexrOYq95Xw4+EB5ZvdyL2RruLKdKSdD0npdJOWzrZNEkdCUqlR6FXaxN39yopCmzKrxUzXelcltTJtFrMulFGzkBhr1NDYkIuqslNVpE10Ud1Gm7TRExuyxqmJtq1fc9HM5tttCNbkdjRaPdwwqdPlOCReTNTA19EuL+zU7OPfWMMF7o1lC46pQzzNenBKHb5l1prFKwb/IN9EUOJQBDQWwxSPpGLMDtvM4lcoqGlpmDNil0mn8wcxorJdAAA=") format("woff");font-weight:400;font-style:normal}.ag-theme-blue .ag-icon{font-family:agGridClassic;font-size:12px;line-height:12px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ag-theme-blue .ag-icon-aggregation:before{content:"\\f101"}.ag-theme-blue .ag-icon-arrows:before{content:"\\f102"}.ag-theme-blue .ag-icon-asc:before{content:"\\f103"}.ag-theme-blue .ag-icon-cancel:before{content:"\\f104"}.ag-theme-blue .ag-icon-chart:before{content:"\\f105"}.ag-theme-blue .ag-icon-color-picker:before{content:"\\f109"}.ag-theme-blue .ag-icon-columns:before{content:"\\f10a"}.ag-theme-blue .ag-icon-contracted:before{content:"\\f10b"}.ag-theme-blue .ag-icon-copy:before{content:"\\f10c"}.ag-theme-blue .ag-icon-cross:before{content:"\\f10d"}.ag-theme-blue .ag-icon-desc:before{content:"\\f10e"}.ag-theme-blue .ag-icon-expanded:before{content:"\\f10f"}.ag-theme-blue .ag-icon-eye-slash:before{content:"\\f110"}.ag-theme-blue .ag-icon-eye:before{content:"\\f111"}.ag-theme-blue .ag-icon-filter:before{content:"\\f112"}.ag-theme-blue .ag-icon-first:before{content:"\\f113"}.ag-theme-blue .ag-icon-grip:before{content:"\\f114"}.ag-theme-blue .ag-icon-group:before{content:"\\f115"}.ag-theme-blue .ag-icon-last:before{content:"\\f116"}.ag-theme-blue .ag-icon-left:before{content:"\\f117"}.ag-theme-blue .ag-icon-linked:before{content:"\\f118"}.ag-theme-blue .ag-icon-loading:before{content:"\\f119"}.ag-theme-blue .ag-icon-maximize:before{content:"\\f11a"}.ag-theme-blue .ag-icon-menu:before{content:"\\f11b"}.ag-theme-blue .ag-icon-minimize:before{content:"\\f11c"}.ag-theme-blue .ag-icon-next:before{content:"\\f11d"}.ag-theme-blue .ag-icon-none:before{content:"\\f11e"}.ag-theme-blue .ag-icon-not-allowed:before{content:"\\f11f"}.ag-theme-blue .ag-icon-paste:before{content:"\\f120"}.ag-theme-blue .ag-icon-pin:before{content:"\\f121"}.ag-theme-blue .ag-icon-pivot:before{content:"\\f122"}.ag-theme-blue .ag-icon-previous:before{content:"\\f123"}.ag-theme-blue .ag-icon-right:before{content:"\\f126"}.ag-theme-blue .ag-icon-save:before{content:"\\f127"}.ag-theme-blue .ag-icon-small-down:before{content:"\\f128"}.ag-theme-blue .ag-icon-small-left:before{content:"\\f129"}.ag-theme-blue .ag-icon-small-right:before{content:"\\f12a"}.ag-theme-blue .ag-icon-small-up:before{content:"\\f12b"}.ag-theme-blue .ag-icon-tick:before{content:"\\f12c"}.ag-theme-blue .ag-icon-tree-closed:before{content:"\\f12d"}.ag-theme-blue .ag-icon-tree-indeterminate:before{content:"\\f12e"}.ag-theme-blue .ag-icon-tree-open:before{content:"\\f12f"}.ag-theme-blue .ag-icon-unlinked:before{content:"\\f130"}.ag-theme-blue .ag-icon-row-drag:before{content:"\\f114"}.ag-theme-blue .ag-right-arrow:before{content:"\\f117";content:"\\f126"}.ag-theme-blue .ag-root-wrapper{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-blue [class^=ag-],.ag-theme-blue [class^=ag-]:after,.ag-theme-blue [class^=ag-]:before,.ag-theme-blue [class^=ag-]:focus{box-sizing:border-box;outline:none}.ag-theme-blue [class^=ag-]::-ms-clear{display:none}.ag-theme-blue .ag-checkbox .ag-input-wrapper,.ag-theme-blue .ag-radio-button .ag-input-wrapper{overflow:visible}.ag-theme-blue .ag-range-field .ag-input-wrapper{height:100%}.ag-theme-blue .ag-toggle-button{flex:none;width:unset;min-width:unset}.ag-theme-blue .ag-ltr .ag-label-align-right .ag-label{margin-left:4px}.ag-theme-blue .ag-rtl .ag-label-align-right .ag-label{margin-right:4px}.ag-theme-blue input[class^=ag-]{margin:0}.ag-theme-blue input[class^=ag-],.ag-theme-blue select[class^=ag-],.ag-theme-blue textarea[class^=ag-]{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-blue input[class^=ag-]:not([type]),.ag-theme-blue input[class^=ag-][type=date],.ag-theme-blue input[class^=ag-][type=datetime-local],.ag-theme-blue input[class^=ag-][type=number],.ag-theme-blue input[class^=ag-][type=tel],.ag-theme-blue input[class^=ag-][type=text],.ag-theme-blue textarea[class^=ag-]{font-size:inherit;line-height:inherit;color:inherit;border:1px solid #000;border-color:var(--ag-input-border-color,#000)}.ag-theme-blue input[class^=ag-]:not([type]):disabled,.ag-theme-blue input[class^=ag-][type=date]:disabled,.ag-theme-blue input[class^=ag-][type=datetime-local]:disabled,.ag-theme-blue input[class^=ag-][type=number]:disabled,.ag-theme-blue input[class^=ag-][type=tel]:disabled,.ag-theme-blue input[class^=ag-][type=text]:disabled,.ag-theme-blue textarea[class^=ag-]:disabled{color:rgba(34,34,34,.5);color:var(--ag-disabled-foreground-color,rgba(34,34,34,.5));background-color:#dedede;background-color:var(--ag-input-disabled-background-color,#dedede);border-color:rgba(0,0,0,.3);border-color:var(--ag-input-disabled-border-color,rgba(0,0,0,.3))}.ag-theme-blue input[class^=ag-]:not([type]):focus,.ag-theme-blue input[class^=ag-][type=date]:focus,.ag-theme-blue input[class^=ag-][type=datetime-local]:focus,.ag-theme-blue input[class^=ag-][type=number]:focus,.ag-theme-blue input[class^=ag-][type=tel]:focus,.ag-theme-blue input[class^=ag-][type=text]:focus,.ag-theme-blue textarea[class^=ag-]:focus{outline:none;border-color:var(--ag-input-focus-border-color)}.ag-theme-blue input[class^=ag-][type=number]{-moz-appearance:textfield}.ag-theme-blue input[class^=ag-][type=number]::-webkit-inner-spin-button,.ag-theme-blue input[class^=ag-][type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.ag-theme-blue input[class^=ag-][type=range]{padding:0}.ag-theme-blue .ag-drag-handle{color:#222;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-list-item,.ag-theme-blue .ag-virtual-list-item{height:20px}.ag-theme-blue .ag-keyboard-focus .ag-virtual-list-item:focus{outline:none}.ag-theme-blue .ag-keyboard-focus .ag-virtual-list-item:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-blue .ag-select-list{background-color:#fff;background-color:var(--ag-background-color,#fff);overflow-y:auto;overflow-x:hidden}.ag-theme-blue .ag-list-item{display:flex;align-items:center}.ag-theme-blue .ag-list-item.ag-active-item{background-color:#f0f0f0;background-color:var(--ag-row-hover-color,#f0f0f0)}.ag-theme-blue .ag-select-list-item{padding-left:4px;padding-right:4px;cursor:default;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.ag-theme-blue .ag-select-list-item span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.ag-theme-blue .ag-select .ag-picker-field-wrapper{background-color:#fff;background-color:var(--ag-background-color,#fff);min-height:20px;cursor:default}.ag-theme-blue .ag-select:not(.ag-cell-editor){height:20px}.ag-theme-blue .ag-select .ag-picker-field-display{margin:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ag-theme-blue .ag-select .ag-picker-field-icon{display:flex;align-items:center}.ag-theme-blue .ag-select.ag-disabled{opacity:.5}.ag-theme-blue .ag-rich-select{background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6)}.ag-theme-blue .ag-rich-select-list{width:100%;min-width:200px;height:162.5px}.ag-theme-blue .ag-rich-select-value{padding:0 4px 0 12px;height:25px;border-bottom:1px solid #9bc2e6;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#9bc2e6))}.ag-theme-blue .ag-rich-select-virtual-list-item{cursor:default;height:20px}.ag-theme-blue .ag-rich-select-virtual-list-item:hover{background-color:#f0f0f0;background-color:var(--ag-row-hover-color,#f0f0f0)}.ag-theme-blue .ag-rich-select-row{padding-left:12px}.ag-theme-blue .ag-rich-select-row-selected{background-color:#c8c8c8;background-color:var(--ag-selected-row-background-color,#c8c8c8)}.ag-theme-blue .ag-group-contracted,.ag-theme-blue .ag-group-expanded,.ag-theme-blue .ag-row-drag,.ag-theme-blue .ag-selection-checkbox{color:#222;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-ltr .ag-group-contracted,.ag-theme-blue .ag-ltr .ag-group-expanded,.ag-theme-blue .ag-ltr .ag-row-drag,.ag-theme-blue .ag-ltr .ag-selection-checkbox{margin-right:12px}.ag-theme-blue .ag-rtl .ag-group-contracted,.ag-theme-blue .ag-rtl .ag-group-expanded,.ag-theme-blue .ag-rtl .ag-row-drag,.ag-theme-blue .ag-rtl .ag-selection-checkbox{margin-left:12px}.ag-theme-blue .ag-cell-wrapper>:not(.ag-cell-value):not(.ag-group-value){height:23px;display:flex;align-items:center;flex:none}.ag-theme-blue .ag-group-contracted,.ag-theme-blue .ag-group-expanded{cursor:pointer}.ag-theme-blue .ag-group-title-bar-icon{cursor:pointer;flex:none;color:#222;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-ltr .ag-group-child-count{margin-left:2px}.ag-theme-blue .ag-rtl .ag-group-child-count{margin-right:2px}.ag-theme-blue .ag-group-title-bar{background-color:#ececec;background-color:var(--ag-subheader-background-color,#ececec);padding:4px}.ag-theme-blue .ag-group-toolbar{padding:4px}.ag-theme-blue .ag-disabled-group-container,.ag-theme-blue .ag-disabled-group-title-bar{opacity:.5}.ag-theme-blue .group-item{margin:2px 0}.ag-theme-blue .ag-label{white-space:nowrap}.ag-theme-blue .ag-ltr .ag-label{margin-right:4px}.ag-theme-blue .ag-rtl .ag-label{margin-left:4px}.ag-theme-blue .ag-label-align-top .ag-label{margin-bottom:2px}.ag-theme-blue .ag-ltr .ag-angle-select-field,.ag-theme-blue .ag-ltr .ag-slider-field{margin-right:8px}.ag-theme-blue .ag-rtl .ag-angle-select-field,.ag-theme-blue .ag-rtl .ag-slider-field{margin-left:8px}.ag-theme-blue .ag-angle-select-parent-circle{width:24px;height:24px;border-radius:12px;border:1px solid #9bc2e6;border-color:var(--ag-border-color,#9bc2e6);background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-blue .ag-angle-select-child-circle{top:4px;left:12px;width:6px;height:6px;margin-left:-3px;margin-top:-4px;border-radius:3px;background-color:#222;background-color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-picker-field-wrapper{border:1px solid #9bc2e6;border-color:var(--ag-border-color,#9bc2e6);border-radius:5px}.ag-theme-blue .ag-picker-field-button{background-color:#fff;background-color:var(--ag-background-color,#fff);color:#222;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-dialog.ag-color-dialog{border-radius:5px}.ag-theme-blue .ag-color-picker .ag-picker-field-display{height:12px}.ag-theme-blue .ag-color-panel{padding:4px}.ag-theme-blue .ag-spectrum-color{background-color:red;border-radius:2px}.ag-theme-blue .ag-spectrum-tools{padding:10px}.ag-theme-blue .ag-spectrum-sat{background-image:linear-gradient(90deg,#fff,rgba(204,154,129,0))}.ag-theme-blue .ag-spectrum-val{background-image:linear-gradient(0deg,#000,rgba(204,154,129,0))}.ag-theme-blue .ag-spectrum-dragger{border-radius:12px;height:12px;width:12px;border:1px solid #fff;background:#000;box-shadow:0 0 2px 0 rgba(0,0,0,.24)}.ag-theme-blue .ag-spectrum-alpha-background,.ag-theme-blue .ag-spectrum-hue-background{border-radius:2px}.ag-theme-blue .ag-spectrum-tool{margin-bottom:10px;height:11px;border-radius:2px}.ag-theme-blue .ag-spectrum-slider{margin-top:-12px;width:13px;height:13px;border-radius:13px;background-color:#f8f8f8;box-shadow:0 1px 4px 0 rgba(0,0,0,.37)}.ag-theme-blue .ag-recent-color{margin:0 3px}.ag-theme-blue .ag-recent-color:first-child{margin-left:0}.ag-theme-blue .ag-recent-color:last-child{margin-right:0}.ag-theme-blue.ag-dnd-ghost{background:#fff;background:var(--ag-background-color,#fff);border-radius:0;box-shadow:none;overflow:hidden;text-overflow:ellipsis;z-index:10;border:1px solid #9bc2e6;border:1px solid var(--ag-secondary-border-color,var(--ag-border-color,#9bc2e6));color:#222;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#222));height:25px!important;line-height:25px;margin:0;padding:0 8px;-webkit-transform:translateY(8px);transform:translateY(8px)}.ag-theme-blue .ag-dnd-ghost-icon{margin-right:4px;color:#222;color:var(--ag-foreground-color,#222)}.ag-theme-blue .ag-popup-child:not(.ag-tooltip-custom){box-shadow:5px 5px 10px rgba(0,0,0,.3)}.ag-dragging-fill-handle .ag-theme-blue .ag-dialog,.ag-dragging-range-handle .ag-theme-blue .ag-dialog{opacity:.7;pointer-events:none}.ag-theme-blue .ag-dialog{border-radius:0;border:1px solid #9bc2e6;border-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-panel{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-blue .ag-panel-title-bar{background-color:#5e9cd3;background-color:var(--ag-header-background-color,#5e9cd3);color:#fff;color:var(--ag-header-foreground-color,#fff);height:25px;padding:4px 12px;border-bottom:1px solid #9bc2e6;border-bottom-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-ltr .ag-panel-title-bar-button{margin-left:4px}.ag-theme-blue .ag-rtl .ag-panel-title-bar-button{margin-right:4px}.ag-theme-blue .ag-tooltip{background-color:#5e9cd3;background-color:var(--ag-header-background-color,#5e9cd3);color:#222;color:var(--ag-foreground-color,#222);padding:4px;border:1px solid #9bc2e6;border-color:var(--ag-border-color,#9bc2e6);border-radius:0;transition:opacity 1s}.ag-theme-blue .ag-tooltip.ag-tooltip-hiding{opacity:0}.ag-theme-blue .ag-ltr .ag-column-select-indent-1{padding-left:16px}.ag-theme-blue .ag-rtl .ag-column-select-indent-1{padding-right:16px}.ag-theme-blue .ag-ltr .ag-column-select-indent-2{padding-left:32px}.ag-theme-blue .ag-rtl .ag-column-select-indent-2{padding-right:32px}.ag-theme-blue .ag-ltr .ag-column-select-indent-3{padding-left:48px}.ag-theme-blue .ag-rtl .ag-column-select-indent-3{padding-right:48px}.ag-theme-blue .ag-ltr .ag-column-select-indent-4{padding-left:64px}.ag-theme-blue .ag-rtl .ag-column-select-indent-4{padding-right:64px}.ag-theme-blue .ag-ltr .ag-column-select-indent-5{padding-left:80px}.ag-theme-blue .ag-rtl .ag-column-select-indent-5{padding-right:80px}.ag-theme-blue .ag-ltr .ag-column-select-indent-6{padding-left:96px}.ag-theme-blue .ag-rtl .ag-column-select-indent-6{padding-right:96px}.ag-theme-blue .ag-ltr .ag-column-select-indent-7{padding-left:112px}.ag-theme-blue .ag-rtl .ag-column-select-indent-7{padding-right:112px}.ag-theme-blue .ag-ltr .ag-column-select-indent-8{padding-left:128px}.ag-theme-blue .ag-rtl .ag-column-select-indent-8{padding-right:128px}.ag-theme-blue .ag-ltr .ag-column-select-indent-9{padding-left:144px}.ag-theme-blue .ag-rtl .ag-column-select-indent-9{padding-right:144px}.ag-theme-blue .ag-column-select-header-icon{cursor:pointer}.ag-theme-blue .ag-keyboard-focus .ag-column-select-header-icon:focus{outline:none}.ag-theme-blue .ag-keyboard-focus .ag-column-select-header-icon:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:0;left:0;display:block;width:100%;height:100%;border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-blue .ag-ltr .ag-column-group-icons:not(:last-child),.ag-theme-blue .ag-ltr .ag-column-select-checkbox:not(:last-child),.ag-theme-blue .ag-ltr .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-blue .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-blue .ag-ltr .ag-column-select-column-label:not(:last-child),.ag-theme-blue .ag-ltr .ag-column-select-header-checkbox:not(:last-child),.ag-theme-blue .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-blue .ag-ltr .ag-column-select-header-icon:not(:last-child){margin-right:6px}.ag-theme-blue .ag-rtl .ag-column-group-icons:not(:last-child),.ag-theme-blue .ag-rtl .ag-column-select-checkbox:not(:last-child),.ag-theme-blue .ag-rtl .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-blue .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-blue .ag-rtl .ag-column-select-column-label:not(:last-child),.ag-theme-blue .ag-rtl .ag-column-select-header-checkbox:not(:last-child),.ag-theme-blue .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-blue .ag-rtl .ag-column-select-header-icon:not(:last-child){margin-left:6px}.ag-theme-blue .ag-keyboard-focus .ag-column-select-column-group:focus{outline:none}.ag-theme-blue .ag-keyboard-focus .ag-column-select-column-group:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-2px;left:-2px;display:block;width:calc(100% - -4px);height:calc(100% - -4px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-blue .ag-keyboard-focus .ag-column-select-column:focus{outline:none}.ag-theme-blue .ag-keyboard-focus .ag-column-select-column:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-2px;left:-2px;display:block;width:calc(100% - -4px);height:calc(100% - -4px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-blue .ag-column-select-column-group:not(:last-child),.ag-theme-blue .ag-column-select-column:not(:last-child){margin-bottom:4px}.ag-theme-blue .ag-column-select-column-group-readonly,.ag-theme-blue .ag-column-select-column-readonly{color:rgba(34,34,34,.5);color:var(--ag-disabled-foreground-color,rgba(34,34,34,.5));pointer-events:none}.ag-theme-blue .ag-ltr .ag-column-select-add-group-indent{margin-left:20px}.ag-theme-blue .ag-rtl .ag-column-select-add-group-indent{margin-right:20px}.ag-theme-blue .ag-column-select-list{padding:6px}.ag-theme-blue .ag-rtl{text-align:right}.ag-theme-blue .ag-root-wrapper{border:1px solid #9bc2e6;border-color:var(--ag-border-color,#9bc2e6);border-radius:0}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-left:36px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-right:36px}.ag-theme-blue .ag-ltr .ag-row-group-indent-1{padding-left:24px}.ag-theme-blue .ag-rtl .ag-row-group-indent-1{padding-right:24px}.ag-theme-blue .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-left:60px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-right:60px}.ag-theme-blue .ag-ltr .ag-row-group-indent-2{padding-left:48px}.ag-theme-blue .ag-rtl .ag-row-group-indent-2{padding-right:48px}.ag-theme-blue .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-left:84px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-right:84px}.ag-theme-blue .ag-ltr .ag-row-group-indent-3{padding-left:72px}.ag-theme-blue .ag-rtl .ag-row-group-indent-3{padding-right:72px}.ag-theme-blue .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-left:108px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-right:108px}.ag-theme-blue .ag-ltr .ag-row-group-indent-4{padding-left:96px}.ag-theme-blue .ag-rtl .ag-row-group-indent-4{padding-right:96px}.ag-theme-blue .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-left:132px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-right:132px}.ag-theme-blue .ag-ltr .ag-row-group-indent-5{padding-left:120px}.ag-theme-blue .ag-rtl .ag-row-group-indent-5{padding-right:120px}.ag-theme-blue .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-left:156px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-right:156px}.ag-theme-blue .ag-ltr .ag-row-group-indent-6{padding-left:144px}.ag-theme-blue .ag-rtl .ag-row-group-indent-6{padding-right:144px}.ag-theme-blue .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-left:180px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-right:180px}.ag-theme-blue .ag-ltr .ag-row-group-indent-7{padding-left:168px}.ag-theme-blue .ag-rtl .ag-row-group-indent-7{padding-right:168px}.ag-theme-blue .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-left:204px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-right:204px}.ag-theme-blue .ag-ltr .ag-row-group-indent-8{padding-left:192px}.ag-theme-blue .ag-rtl .ag-row-group-indent-8{padding-right:192px}.ag-theme-blue .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-left:228px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-right:228px}.ag-theme-blue .ag-ltr .ag-row-group-indent-9{padding-left:216px}.ag-theme-blue .ag-rtl .ag-row-group-indent-9{padding-right:216px}.ag-theme-blue .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-left:252px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-right:252px}.ag-theme-blue .ag-ltr .ag-row-group-indent-10{padding-left:240px}.ag-theme-blue .ag-rtl .ag-row-group-indent-10{padding-right:240px}.ag-theme-blue .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-left:276px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-right:276px}.ag-theme-blue .ag-ltr .ag-row-group-indent-11{padding-left:264px}.ag-theme-blue .ag-rtl .ag-row-group-indent-11{padding-right:264px}.ag-theme-blue .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-left:300px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-right:300px}.ag-theme-blue .ag-ltr .ag-row-group-indent-12{padding-left:288px}.ag-theme-blue .ag-rtl .ag-row-group-indent-12{padding-right:288px}.ag-theme-blue .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-left:324px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-right:324px}.ag-theme-blue .ag-ltr .ag-row-group-indent-13{padding-left:312px}.ag-theme-blue .ag-rtl .ag-row-group-indent-13{padding-right:312px}.ag-theme-blue .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-left:348px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-right:348px}.ag-theme-blue .ag-ltr .ag-row-group-indent-14{padding-left:336px}.ag-theme-blue .ag-rtl .ag-row-group-indent-14{padding-right:336px}.ag-theme-blue .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-left:372px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-right:372px}.ag-theme-blue .ag-ltr .ag-row-group-indent-15{padding-left:360px}.ag-theme-blue .ag-rtl .ag-row-group-indent-15{padding-right:360px}.ag-theme-blue .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-left:396px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-right:396px}.ag-theme-blue .ag-ltr .ag-row-group-indent-16{padding-left:384px}.ag-theme-blue .ag-rtl .ag-row-group-indent-16{padding-right:384px}.ag-theme-blue .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-left:420px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-right:420px}.ag-theme-blue .ag-ltr .ag-row-group-indent-17{padding-left:408px}.ag-theme-blue .ag-rtl .ag-row-group-indent-17{padding-right:408px}.ag-theme-blue .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-left:444px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-right:444px}.ag-theme-blue .ag-ltr .ag-row-group-indent-18{padding-left:432px}.ag-theme-blue .ag-rtl .ag-row-group-indent-18{padding-right:432px}.ag-theme-blue .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-left:468px}.ag-theme-blue .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-right:468px}.ag-theme-blue .ag-ltr .ag-row-group-indent-19{padding-left:456px}.ag-theme-blue .ag-rtl .ag-row-group-indent-19{padding-right:456px}.ag-theme-blue .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-blue .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-blue .ag-cell{-webkit-font-smoothing:subpixel-antialiased}.ag-theme-blue .ag-value-change-delta{padding-right:2px}.ag-theme-blue .ag-value-change-delta-up{color:#006400;color:var(--ag-value-change-delta-up-color,#006400)}.ag-theme-blue .ag-value-change-delta-down{color:#8b0000;color:var(--ag-value-change-delta-down-color,#8b0000)}.ag-theme-blue .ag-value-change-value{background-color:transparent;border-radius:1px;padding-left:1px;padding-right:1px;transition:background-color 1s}.ag-theme-blue .ag-value-change-value-highlight{background-color:#cec;background-color:var(--ag-value-change-value-highlight-background-color,#cec);transition:background-color .1s}.ag-theme-blue .ag-cell-data-changed{background-color:#cec!important;background-color:var(--ag-value-change-value-highlight-background-color,#cec)!important}.ag-theme-blue .ag-cell-data-changed-animation{background-color:transparent}.ag-theme-blue .ag-cell-highlight{background-color:rgba(136,255,136,.4)!important;background-color:var(--ag-range-selection-highlight-color,rgba(136,255,136,.4))!important}.ag-theme-blue .ag-row{height:25px;background-color:#fff;background-color:var(--ag-background-color,#fff);color:#222;color:var(--ag-data-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-row-highlight-above:after,.ag-theme-blue .ag-row-highlight-below:after{content:"";position:absolute;width:calc(100% - 1px);height:1px;background-color:#222;background-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#222));left:1px}.ag-theme-blue .ag-row-highlight-above:after{top:-1px}.ag-theme-blue .ag-row-highlight-above.ag-row-first:after{top:0}.ag-theme-blue .ag-row-highlight-below:after{bottom:0}.ag-theme-blue .ag-row-odd{background-color:#deebf7;background-color:var(--ag-odd-row-background-color,#deebf7)}.ag-theme-blue .ag-horizontal-left-spacer:not(.ag-scroller-corner){border-right:1px solid #9bc2e6;border-right-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-horizontal-right-spacer:not(.ag-scroller-corner){border-left:1px solid #9bc2e6;border-left-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-row-hover{background-color:#f0f0f0;background-color:var(--ag-row-hover-color,#f0f0f0)}.ag-theme-blue .ag-ltr .ag-right-aligned-cell{text-align:right}.ag-theme-blue .ag-rtl .ag-right-aligned-cell{text-align:left}.ag-theme-blue .ag-ltr .ag-right-aligned-cell .ag-cell-value{margin-left:auto}.ag-theme-blue .ag-rtl .ag-right-aligned-cell .ag-cell-value{margin-right:auto}.ag-theme-blue .ag-cell{border:1px solid transparent;line-height:23px}.ag-theme-blue .ag-cell,.ag-theme-blue .ag-row>.ag-cell-wrapper{padding-left:11px;padding-right:11px}.ag-theme-blue .ag-row-dragging{cursor:move;opacity:.5}.ag-theme-blue .ag-cell-inline-editing{height:25px}.ag-theme-blue .ag-cell-inline-editing,.ag-theme-blue .ag-popup-editor{border:1px solid #9bc2e6;border-color:var(--ag-border-color,#9bc2e6);background:#fff;background:var(--ag-background-color,#fff);border-radius:0;box-shadow:none;padding:0;background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6)}.ag-theme-blue .ag-large-text-input{height:auto;padding:12px}.ag-theme-blue .ag-details-row{padding:20px;background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-blue .ag-overlay-loading-wrapper{background-color:hsla(0,0%,100%,.66);background-color:var(--ag-modal-overlay-background-color,hsla(0,0%,100%,.66))}.ag-theme-blue .ag-overlay-loading-center{border:1px solid #9bc2e6;border-color:var(--ag-border-color,#9bc2e6);background:#fff;background:var(--ag-background-color,#fff);border-radius:0;box-shadow:none;padding:4px}.ag-theme-blue .ag-overlay-no-rows-wrapper.ag-layout-auto-height{padding-top:30px}.ag-theme-blue .ag-loading{padding-left:12px;display:flex;height:100%;align-items:center}.ag-theme-blue .ag-loading-icon{padding-right:12px}.ag-theme-blue .ag-icon-loading{-webkit-animation-name:spin;animation-name:spin;-webkit-animation-duration:1s;animation-duration:1s;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite;-webkit-animation-timing-function:linear;animation-timing-function:linear}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}.ag-theme-blue .ag-floating-top{border-bottom:1px solid #9bc2e6;border-bottom-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-floating-bottom{border-top:1px solid #9bc2e6;border-top-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-ltr .ag-cell{border-right:dotted #9bc2e6}.ag-theme-blue .ag-rtl .ag-cell{border-left:dotted #9bc2e6}.ag-theme-blue .ag-ltr .ag-cell{border-right-width:1px}.ag-theme-blue .ag-rtl .ag-cell{border-left-width:1px}.ag-theme-blue .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell){border-left:1px solid #9bc2e6;border-left-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell){border-right:1px solid #9bc2e6;border-right-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-row-selected{background-color:#c8c8c8;background-color:var(--ag-selected-row-background-color,#c8c8c8)}.ag-theme-blue .ag-cell-range-selected:not(.ag-cell-focus){background-color:rgba(34,34,34,.2);background-color:var(--ag-range-selection-background-color,rgba(34,34,34,.2))}.ag-theme-blue .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart{background-color:rgba(0,88,255,.1);background-color:var(--ag-range-selection-chart-background-color,rgba(0,88,255,.1))}.ag-theme-blue .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category{background-color:rgba(0,255,132,.1);background-color:var(--ag-range-selection-chart-category-background-color,rgba(0,255,132,.1))}.ag-theme-blue .ag-cell-range-selected-1:not(.ag-cell-focus){background-color:rgba(34,34,34,.2);background-color:var(--ag-range-selection-background-color-1,var(--ag-range-selection-background-color,rgba(34,34,34,.2)))}.ag-theme-blue .ag-cell-range-selected-2:not(.ag-cell-focus){background-color:rgba(34,34,34,.36);background-color:var(--ag-range-selection-background-color-2,rgba(34,34,34,.36))}.ag-theme-blue .ag-cell-range-selected-3:not(.ag-cell-focus){background-color:rgba(34,34,34,.488);background-color:var(--ag-range-selection-background-color-3,rgba(34,34,34,.488))}.ag-theme-blue .ag-cell-range-selected-4:not(.ag-cell-focus){background-color:rgba(34,34,34,.5904);background-color:var(--ag-range-selection-background-color-4,rgba(34,34,34,.5904))}.ag-theme-blue .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top{border-top-color:#222;border-top-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right{border-right-color:#222;border-right-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom{border-bottom-color:#222;border-bottom-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left{border-left-color:#222;border-left-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-blue .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-blue .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),.ag-theme-blue .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-blue .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-blue .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected){border:1px solid #222;border-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#222));outline:initial}.ag-theme-blue .ag-cell.ag-selection-fill-top,.ag-theme-blue .ag-cell.ag-selection-fill-top.ag-cell-range-selected{border-top:1px dashed #222;border-top-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-ltr .ag-cell.ag-selection-fill-right,.ag-theme-blue .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-right:1px dashed #222;border-right-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-rtl .ag-cell.ag-selection-fill-right,.ag-theme-blue .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-left:1px dashed #222;border-left-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-cell.ag-selection-fill-bottom,.ag-theme-blue .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected{border-bottom:1px dashed #222;border-bottom-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-ltr .ag-cell.ag-selection-fill-left,.ag-theme-blue .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-left:1px dashed #222;border-left-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-rtl .ag-cell.ag-selection-fill-left,.ag-theme-blue .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-right:1px dashed #222;border-right-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-fill-handle,.ag-theme-blue .ag-range-handle{position:absolute;width:6px;height:6px;bottom:-1px;background-color:#222;background-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-ltr .ag-fill-handle,.ag-theme-blue .ag-ltr .ag-range-handle{right:-1px}.ag-theme-blue .ag-rtl .ag-fill-handle,.ag-theme-blue .ag-rtl .ag-range-handle{left:-1px}.ag-theme-blue .ag-fill-handle{cursor:cell}.ag-theme-blue .ag-range-handle{cursor:nwse-resize}.ag-theme-blue .ag-cell-inline-editing{border-color:var(--ag-input-focus-border-color)!important}.ag-theme-blue .ag-menu{border:1px solid #9bc2e6;border-color:var(--ag-border-color,#9bc2e6);background:#fff;background:var(--ag-background-color,#fff);border-radius:0;box-shadow:none;padding:0}.ag-theme-blue .ag-menu-list{cursor:default;width:100%;padding-top:4px;padding-bottom:4px}.ag-theme-blue .ag-menu-option-part{padding-top:6px;padding-bottom:6px;line-height:12px}.ag-theme-blue .ag-menu-option-active{background-color:#f0f0f0;background-color:var(--ag-row-hover-color,#f0f0f0)}.ag-theme-blue .ag-menu-option-disabled{opacity:.5}.ag-theme-blue .ag-menu-option-text{margin-left:4px}.ag-theme-blue .ag-menu-option-icon{padding-left:8px;padding-right:4px;min-width:20px}.ag-theme-blue .ag-menu-option-shortcut{padding-left:8px}.ag-theme-blue .ag-menu-separator{height:8px}.ag-theme-blue .ag-menu-separator-cell:after{content:"";display:block;border-top:1px solid #9bc2e6;border-top-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-menu-option-popup-pointer{width:20px;text-align:center}.ag-theme-blue .ag-tabs-header{min-width:220px;width:100%;display:flex}.ag-theme-blue .ag-tab{border-bottom:0 solid transparent;display:flex;flex:none;align-items:center;justify-content:center;cursor:pointer}.ag-theme-blue .ag-keyboard-focus .ag-tab:focus{outline:none}.ag-theme-blue .ag-keyboard-focus .ag-tab:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-blue .ag-tab-selected{border-bottom-color:#222;border-bottom-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-foreground-color,#222)))}.ag-theme-blue .ag-menu-header{color:#222;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-filter-condition-operator{height:17px}.ag-theme-blue .ag-ltr .ag-filter-condition-operator-or{margin-left:8px}.ag-theme-blue .ag-rtl .ag-filter-condition-operator-or{margin-right:8px}.ag-theme-blue .ag-set-filter-select-all{padding-top:6px}.ag-theme-blue .ag-set-filter-list{height:120px}.ag-theme-blue .ag-set-filter-filter{margin-top:6px;margin-left:6px;margin-right:6px}.ag-theme-blue .ag-filter-to{margin-top:4px}.ag-theme-blue .ag-mini-filter{margin:6px 6px 0}.ag-theme-blue .ag-set-filter-item{margin:0 6px}.ag-theme-blue .ag-ltr .ag-set-filter-item-value{margin-left:6px}.ag-theme-blue .ag-rtl .ag-set-filter-item-value{margin-right:6px}.ag-theme-blue .ag-filter-header-container{padding-bottom:6px;border-bottom:1px solid #9bc2e6;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#9bc2e6))}.ag-theme-blue .ag-filter-apply-panel{padding:6px;border-top:1px solid #9bc2e6;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#9bc2e6))}.ag-theme-blue .ag-filter-apply-panel-button{line-height:1.5}.ag-theme-blue .ag-ltr .ag-filter-apply-panel-button{margin-left:8px}.ag-theme-blue .ag-rtl .ag-filter-apply-panel-button{margin-right:8px}.ag-theme-blue .ag-simple-filter-body-wrapper{padding:6px 6px 2px}.ag-theme-blue .ag-simple-filter-body-wrapper>*{margin-bottom:4px}.ag-theme-blue .ag-filter-no-matches{margin:6px}.ag-theme-blue .ag-side-bar{position:relative}.ag-theme-blue .ag-tool-panel-wrapper{background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6)}.ag-theme-blue .ag-side-buttons{padding-top:16px;width:16px;position:relative;color:#222;color:var(--ag-foreground-color,#222);overflow:hidden}.ag-theme-blue button.ag-side-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;background:transparent;padding:8px 0;width:calc(100% + 1px);margin:0;min-height:72px;background-position-y:center;background-position-x:center;background-repeat:no-repeat;border-left:none;border-right:none;border-top:#9bc2e6;border-top:1px solid var(--ag-border-color,#9bc2e6);border-bottom:#9bc2e6;border-bottom:1px solid var(--ag-border-color,#9bc2e6)}.ag-theme-blue button.ag-side-button-button:focus{box-shadow:none}.ag-theme-blue .ag-keyboard-focus .ag-side-button-button:focus{outline:none}.ag-theme-blue .ag-keyboard-focus .ag-side-button-button:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-blue .ag-selected .ag-side-button-button{background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6);border-top-color:#9bc2e6;border-top-color:var(--ag-border-color,#9bc2e6);border-bottom-color:#9bc2e6;border-bottom-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-side-button-icon-wrapper{margin-bottom:3px}.ag-theme-blue .ag-ltr .ag-side-bar-left,.ag-theme-blue .ag-rtl .ag-side-bar-right{border-right:1px solid #9bc2e6;border-right-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,.ag-theme-blue .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper{border-left:1px solid #9bc2e6;border-left-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-ltr .ag-side-bar-left .ag-side-button-button,.ag-theme-blue .ag-rtl .ag-side-bar-right .ag-side-button-button{border-right:0 solid transparent;margin-right:-1px;padding-right:1px}.ag-theme-blue .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,.ag-theme-blue .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button{border-right-color:#222;border-right-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-foreground-color,#222)))}.ag-theme-blue .ag-ltr .ag-side-bar-right,.ag-theme-blue .ag-rtl .ag-side-bar-left{border-left:1px solid #9bc2e6;border-left-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper,.ag-theme-blue .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper{border-right:1px solid #9bc2e6;border-right-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-ltr .ag-side-bar-right .ag-side-button-button,.ag-theme-blue .ag-rtl .ag-side-bar-left .ag-side-button-button{border-left:0 solid transparent;margin-left:-1px;padding-left:1px}.ag-theme-blue .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button,.ag-theme-blue .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button{border-left-color:#222;border-left-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-foreground-color,#222)))}.ag-theme-blue .ag-filter-toolpanel-header{height:24px}.ag-theme-blue .ag-ltr .ag-filter-toolpanel-header,.ag-theme-blue .ag-ltr .ag-filter-toolpanel-search{padding-left:4px}.ag-theme-blue .ag-rtl .ag-filter-toolpanel-header,.ag-theme-blue .ag-rtl .ag-filter-toolpanel-search{padding-right:4px}.ag-theme-blue .ag-keyboard-focus .ag-filter-toolpanel-header:focus{outline:none}.ag-theme-blue .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-blue .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{font-family:agGridClassic;font-size:12px;line-height:12px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;content:"\\f112";position:absolute}.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-left:4px}.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-right:4px}.ag-theme-blue .ag-filter-toolpanel-group-level-0-header{height:32px}.ag-theme-blue .ag-filter-toolpanel-group-item{margin-top:2px;margin-bottom:2px}.ag-theme-blue .ag-filter-toolpanel-search{height:25px}.ag-theme-blue .ag-filter-toolpanel-search-input{flex-grow:1;height:16px}.ag-theme-blue .ag-ltr .ag-filter-toolpanel-search-input{margin-right:4px}.ag-theme-blue .ag-rtl .ag-filter-toolpanel-search-input{margin-left:4px}.ag-theme-blue .ag-filter-toolpanel-group-level-0{border-top:1px solid #9bc2e6;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#9bc2e6))}.ag-theme-blue .ag-ltr .ag-filter-toolpanel-expand,.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-title-bar-icon{margin-right:4px}.ag-theme-blue .ag-rtl .ag-filter-toolpanel-expand,.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-title-bar-icon{margin-left:4px}.ag-theme-blue .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-left:20px}.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-right:20px}.ag-theme-blue .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-left:36px}.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-right:36px}.ag-theme-blue .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-left:52px}.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-right:52px}.ag-theme-blue .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-left:68px}.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-right:68px}.ag-theme-blue .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-left:84px}.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-right:84px}.ag-theme-blue .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-left:100px}.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-right:100px}.ag-theme-blue .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-left:116px}.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-right:116px}.ag-theme-blue .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-left:132px}.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-right:132px}.ag-theme-blue .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-left:148px}.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-right:148px}.ag-theme-blue .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-left:164px}.ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-right:164px}.ag-theme-blue .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header{padding-left:4px}.ag-theme-blue .ag-filter-toolpanel-instance-filter{border-top:1px solid #9bc2e6;border-top-color:var(--ag-border-color,#9bc2e6);border-bottom:1px solid #9bc2e6;border-bottom-color:var(--ag-border-color,#9bc2e6);padding-top:4px}.ag-theme-blue .ag-ltr .ag-filter-toolpanel-instance-header-icon{margin-left:4px}.ag-theme-blue .ag-rtl .ag-filter-toolpanel-instance-header-icon{margin-right:4px}.ag-theme-blue .ag-pivot-mode-panel{height:25px;display:flex}.ag-theme-blue .ag-pivot-mode-select{display:flex;align-items:center}.ag-theme-blue .ag-ltr .ag-pivot-mode-select{margin-left:6px}.ag-theme-blue .ag-rtl .ag-pivot-mode-select{margin-right:6px}.ag-theme-blue .ag-keyboard-focus .ag-column-select-header:focus{outline:none}.ag-theme-blue .ag-keyboard-focus .ag-column-select-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-blue .ag-column-select-header{height:25px;align-items:center;padding:0 6px}.ag-theme-blue .ag-column-panel-column-select,.ag-theme-blue .ag-column-select-header{border-bottom:1px solid #9bc2e6;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#9bc2e6))}.ag-theme-blue .ag-column-panel-column-select{border-top:1px solid #9bc2e6;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#9bc2e6))}.ag-theme-blue .ag-column-group-icons,.ag-theme-blue .ag-column-select-header-icon{color:#222;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-header{background-color:#5e9cd3;background-color:var(--ag-header-background-color,#5e9cd3);border-bottom:1px solid #9bc2e6;border-bottom-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-header-row{color:#fff;color:var(--ag-header-foreground-color,#fff)}.ag-theme-blue .ag-pinned-right-header{border-left:1px solid #9bc2e6;border-left-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-pinned-left-header{border-right:1px solid #9bc2e6;border-right-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-header-row{height:25px}.ag-theme-blue .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-left:4px}.ag-theme-blue .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon,.ag-theme-blue .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-right:4px}.ag-theme-blue .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon{margin-left:4px}.ag-theme-blue .ag-header-cell,.ag-theme-blue .ag-header-group-cell{padding-left:12px;padding-right:12px}.ag-theme-blue .ag-header-cell.ag-header-cell-moving,.ag-theme-blue .ag-header-group-cell.ag-header-cell-moving{background-color:#9bc2e6;background-color:var(--ag-header-cell-moving-background-color,#9bc2e6)}.ag-theme-blue .ag-keyboard-focus .ag-header-cell:focus{outline:none}.ag-theme-blue .ag-keyboard-focus .ag-header-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-blue .ag-keyboard-focus .ag-header-group-cell:focus{outline:none}.ag-theme-blue .ag-keyboard-focus .ag-header-group-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-blue .ag-header-icon{color:#222;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-header-expand-icon{cursor:pointer}.ag-theme-blue .ag-ltr .ag-header-expand-icon{padding-left:4px}.ag-theme-blue .ag-rtl .ag-header-expand-icon{padding-right:4px}.ag-theme-blue .ag-header-row:not(:first-child) .ag-header-cell,.ag-theme-blue .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group{border-top:1px solid #9bc2e6;border-top-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-header-cell:after,.ag-theme-blue .ag-header-group-cell:after{content:"";position:absolute;z-index:1;display:block;width:1px;height:100%;top:0;background-color:rgba(155,194,230,.5);background-color:var(--ag-header-column-separator-color,rgba(155,194,230,.5))}.ag-theme-blue .ag-ltr .ag-header-cell:after,.ag-theme-blue .ag-ltr .ag-header-group-cell:after{right:0}.ag-theme-blue .ag-rtl .ag-header-cell:after,.ag-theme-blue .ag-rtl .ag-header-group-cell:after{left:0}.ag-theme-blue .ag-ltr .ag-header-select-all{margin-right:12px}.ag-theme-blue .ag-ltr .ag-floating-filter-button,.ag-theme-blue .ag-rtl .ag-header-select-all{margin-left:12px}.ag-theme-blue .ag-rtl .ag-floating-filter-button{margin-right:12px}.ag-theme-blue .ag-floating-filter-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;height:12px;padding:0;width:12px}.ag-theme-blue .ag-filter-loading{background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6);height:100%;padding:6px;position:absolute;width:100%;z-index:1}.ag-theme-blue .ag-paging-panel{border-top:1px solid #9bc2e6;border-top-color:var(--ag-border-color,#9bc2e6);color:#222;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#222));height:25px}.ag-theme-blue .ag-paging-panel>*{margin:0 12px}.ag-theme-blue .ag-paging-button{cursor:pointer;opacity:0;top:0;right:0;bottom:0;left:0;padding:0;width:12px}.ag-theme-blue .ag-disabled .ag-paging-button{cursor:default}.ag-theme-blue .ag-paging-button-wrapper.ag-disabled{color:rgba(34,34,34,.5);color:var(--ag-disabled-foreground-color,rgba(34,34,34,.5));cursor:default}.ag-theme-blue .ag-paging-button-wrapper,.ag-theme-blue .ag-paging-description{margin:0 4px}.ag-theme-blue .ag-status-bar{border-top:1px solid #9bc2e6;border-top-color:var(--ag-border-color,#9bc2e6);color:rgba(34,34,34,.5);color:var(--ag-disabled-foreground-color,rgba(34,34,34,.5));padding-right:16px;padding-left:16px;line-height:1.5}.ag-theme-blue .ag-status-name-value-value{color:#222;color:var(--ag-foreground-color,#222)}.ag-theme-blue .ag-status-bar-center{text-align:center}.ag-theme-blue .ag-status-name-value{margin-left:4px;margin-right:4px;padding-top:8px;padding-bottom:8px}.ag-theme-blue .ag-column-drop-cell{background:#ddebf7;background:var(--ag-chip-background-color,#ddebf7);border-radius:16px;height:16px;padding:0 2px}.ag-theme-blue .ag-column-drop-cell-text{margin:0 4px}.ag-theme-blue .ag-column-drop-cell-button{min-width:16px;margin:0 2px;color:#222;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-column-drop-cell-drag-handle{margin-left:8px}.ag-theme-blue .ag-column-drop-cell-ghost{opacity:.5}.ag-theme-blue .ag-column-drop-horizontal{background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6);color:#222;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#222));height:25px;border-bottom:1px solid #9bc2e6;border-bottom-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-ltr .ag-column-drop-horizontal{padding-left:12px}.ag-theme-blue .ag-rtl .ag-column-drop-horizontal{padding-right:12px}.ag-theme-blue .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child){border-right:1px solid #9bc2e6;border-right-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child){border-left:1px solid #9bc2e6;border-left-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-column-drop-horizontal-cell-separator{margin:0 4px;color:#222;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-column-drop-horizontal-empty-message{color:rgba(34,34,34,.5);color:var(--ag-disabled-foreground-color,rgba(34,34,34,.5))}.ag-theme-blue .ag-ltr .ag-column-drop-horizontal-icon{margin-right:12px}.ag-theme-blue .ag-rtl .ag-column-drop-horizontal-icon{margin-left:12px}.ag-theme-blue .ag-column-drop-vertical-list{padding-bottom:4px;padding-right:4px;padding-left:4px}.ag-theme-blue .ag-column-drop-vertical-cell{margin-top:4px}.ag-theme-blue .ag-column-drop-vertical{min-height:50px;max-height:150px;border-bottom:1px solid #9bc2e6;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#9bc2e6))}.ag-theme-blue .ag-column-drop-vertical.ag-last-column-drop{border-bottom:none}.ag-theme-blue .ag-column-drop-vertical-icon{margin-left:4px;margin-right:4px}.ag-theme-blue .ag-column-drop-vertical-list{position:relative}.ag-theme-blue .ag-column-drop-vertical-empty-message{position:absolute;top:0;bottom:0;left:0;right:0;overflow:hidden;color:rgba(34,34,34,.5);color:var(--ag-disabled-foreground-color,rgba(34,34,34,.5));margin-top:4px}.ag-theme-blue .ag-select-agg-func-popup{border:1px solid #9bc2e6;border-color:var(--ag-border-color,#9bc2e6);border-radius:0;box-shadow:none;background:#fff;background:var(--ag-background-color,#fff);height:70px;padding:0}.ag-theme-blue .ag-select-agg-func-virtual-list-item{cursor:default;line-height:20px;padding-left:8px}.ag-theme-blue .ag-select-agg-func-virtual-list-item:hover{background-color:#c8c8c8;background-color:var(--ag-selected-row-background-color,#c8c8c8)}.ag-theme-blue .ag-chart-menu{border-radius:0;background:#fff;background:var(--ag-background-color,#fff)}.ag-theme-blue .ag-chart-menu-icon{opacity:.5;line-height:24px;font-size:24px;width:24px;height:24px;margin:2px 0;cursor:pointer;border-radius:0;color:#222;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#222))}.ag-theme-blue .ag-chart-menu-icon:hover{opacity:1}.ag-theme-blue .ag-chart-mini-thumbnail{border:1px solid #9bc2e6;border-color:var(--ag-secondary-border-color,var(--ag-border-color,#9bc2e6));border-radius:5px;margin:5px}.ag-theme-blue .ag-chart-mini-thumbnail:nth-last-child(3),.ag-theme-blue .ag-chart-mini-thumbnail:nth-last-child(3)~.ag-chart-mini-thumbnail{margin-left:auto;margin-right:auto}.ag-theme-blue .ag-ltr .ag-chart-mini-thumbnail:first-child{margin-left:0}.ag-theme-blue .ag-ltr .ag-chart-mini-thumbnail:last-child,.ag-theme-blue .ag-rtl .ag-chart-mini-thumbnail:first-child{margin-right:0}.ag-theme-blue .ag-rtl .ag-chart-mini-thumbnail:last-child{margin-left:0}.ag-theme-blue .ag-chart-mini-thumbnail.ag-selected{border-color:#222;border-color:var(--ag-minichart-selected-chart-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#222)))}.ag-theme-blue .ag-chart-settings-card-item{background:#222;background:var(--ag-foreground-color,#222);width:8px;height:8px;border-radius:4px}.ag-theme-blue .ag-chart-settings-card-item.ag-selected{background-color:#222;background-color:var(--ag-minichart-selected-page-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#222)))}.ag-theme-blue .ag-chart-data-column-drag-handle{margin-left:4px}.ag-theme-blue .ag-charts-data-group-title-bar,.ag-theme-blue .ag-charts-format-top-level-group-title-bar,.ag-theme-blue .ag-charts-settings-group-title-bar{border-top:1px solid #9bc2e6;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#9bc2e6))}.ag-theme-blue .ag-charts-settings-group-container{padding:4px}.ag-theme-blue .ag-charts-data-group-container{padding:6px 6px 2px}.ag-theme-blue .ag-charts-data-group-container>*{margin-bottom:4px}.ag-theme-blue .ag-charts-format-top-level-group-container{margin-left:8px;padding:4px}.ag-theme-blue .ag-charts-format-top-level-group-item{margin:4px 0}.ag-theme-blue .ag-charts-format-sub-level-group-container{padding:6px 6px 2px}.ag-theme-blue .ag-charts-format-sub-level-group-container>*{margin-bottom:4px}.ag-theme-blue .ag-charts-group-container.ag-group-container-horizontal{padding:4px}.ag-theme-blue .ag-chart-data-section,.ag-theme-blue .ag-chart-format-section{display:flex;margin:0}.ag-theme-blue .ag-chart-menu-panel{background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6)}.ag-theme-blue .ag-ltr .ag-chart-menu-panel{border-left:1px solid #9bc2e6;border-left-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-rtl .ag-chart-menu-panel{border-right:1px solid #9bc2e6;border-right-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-date-time-list-page-title{flex-grow:1;text-align:center}.ag-theme-blue .ag-date-time-list-page-column-label,.ag-theme-blue .ag-date-time-list-page-entry{text-align:center}.ag-theme-blue .ag-checkbox-input-wrapper{font-family:agGridClassic;font-size:12px;line-height:12px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:12px;height:12px;background-color:var(--ag-checkbox-background-color);border-radius:0;display:inline-block;vertical-align:middle;flex:none}.ag-theme-blue .ag-checkbox-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-blue .ag-checkbox-input-wrapper:active,.ag-theme-blue .ag-checkbox-input-wrapper:focus-within{outline:none}.ag-theme-blue .ag-checkbox-input-wrapper.ag-disabled{opacity:.5}.ag-theme-blue .ag-checkbox-input-wrapper:after{content:"\\f108";color:#222;color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#222));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-blue .ag-checkbox-input-wrapper.ag-checked:after{content:"\\f106";color:#222;color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#222));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-blue .ag-checkbox-input-wrapper.ag-indeterminate:after{content:"\\f107";color:#222;color:var(--ag-checkbox-indeterminate-color,var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#222)));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-blue .ag-toggle-button-input-wrapper{box-sizing:border-box;width:24px;height:12px;background-color:#222;background-color:var(--ag-toggle-button-off-background-color,var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#222)));border-radius:6px;position:relative;flex:none;border:1px solid #222;border-color:var(--ag-toggle-button-off-border-color,var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#222)))}.ag-theme-blue .ag-toggle-button-input-wrapper input{opacity:0;height:100%;width:100%}.ag-theme-blue .ag-toggle-button-input-wrapper:focus-within{outline:none}.ag-theme-blue .ag-toggle-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-blue .ag-toggle-button-input-wrapper.ag-checked{background-color:#222;background-color:var(--ag-toggle-button-on-background-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#222)));border-color:#222;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#222)))}.ag-theme-blue .ag-toggle-button-input-wrapper:before{content:" ";position:absolute;top:-1px;left:-1px;display:block;box-sizing:border-box;height:12px;width:12px;background-color:#fff;background-color:var(--ag-toggle-button-switch-background-color,var(--ag-background-color,#fff));border-radius:6px;transition:left .1s;border:1px solid #222;border-color:var(--ag-toggle-button-switch-border-color,var(--ag-toggle-button-off-border-color,var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#222))))}.ag-theme-blue .ag-toggle-button-input-wrapper.ag-checked:before{left:calc(100% - 12px);border-color:#222;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#222)))}.ag-theme-blue .ag-radio-button-input-wrapper{font-family:agGridClassic;font-size:12px;line-height:12px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:12px;height:12px;background-color:var(--ag-checkbox-background-color);border-radius:0;display:inline-block;vertical-align:middle;flex:none;border-radius:12px}.ag-theme-blue .ag-radio-button-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-blue .ag-radio-button-input-wrapper:active,.ag-theme-blue .ag-radio-button-input-wrapper:focus-within{outline:none}.ag-theme-blue .ag-radio-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-blue .ag-radio-button-input-wrapper:after{content:"\\f124";color:#222;color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#222));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-blue .ag-radio-button-input-wrapper.ag-checked:after{content:"\\f125";color:#222;color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#222));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-blue input[class^=ag-][type=range]{-webkit-appearance:none;width:100%;height:100%;background:none;overflow:visible}.ag-theme-blue input[class^=ag-][type=range]::-webkit-slider-runnable-track{margin:0;padding:0;width:100%;height:3px;background-color:#9bc2e6;background-color:var(--ag-border-color,#9bc2e6);border-radius:0}.ag-theme-blue input[class^=ag-][type=range]::-moz-range-track{margin:0;padding:0;width:100%;height:3px;background-color:#9bc2e6;background-color:var(--ag-border-color,#9bc2e6);border-radius:0}.ag-theme-blue input[class^=ag-][type=range]::-ms-track{margin:0;padding:0;width:100%;height:3px;background-color:#9bc2e6;background-color:var(--ag-border-color,#9bc2e6);border-radius:0;color:transparent;width:calc(100% - 2px)}.ag-theme-blue input[class^=ag-][type=range]::-webkit-slider-thumb{margin:0;padding:0;-webkit-appearance:none;width:12px;height:12px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #222;border-color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#222));border-radius:12px;-webkit-transform:translateY(-4.5px);transform:translateY(-4.5px)}.ag-theme-blue input[class^=ag-][type=range]::-ms-thumb{margin:0;padding:0;-webkit-appearance:none;width:12px;height:12px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #222;border-color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#222));border-radius:12px}.ag-theme-blue input[class^=ag-][type=range]::-moz-ag-range-thumb{margin:0;padding:0;-webkit-appearance:none;width:12px;height:12px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #222;border-color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#222));border-radius:12px}.ag-theme-blue input[class^=ag-][type=range]:focus{outline:none}.ag-theme-blue input[class^=ag-][type=range]:focus::-webkit-slider-thumb{border-color:#222;border-color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#222))}.ag-theme-blue input[class^=ag-][type=range]:focus::-ms-thumb{border-color:#222;border-color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#222))}.ag-theme-blue input[class^=ag-][type=range]:focus::-moz-ag-range-thumb{border-color:#222;border-color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#222))}.ag-theme-blue input[class^=ag-][type=range]:active::-webkit-slider-runnable-track{background-color:var(--ag-input-focus-border-color)}.ag-theme-blue input[class^=ag-][type=range]:active::-moz-ag-range-track{background-color:var(--ag-input-focus-border-color)}.ag-theme-blue input[class^=ag-][type=range]:active::-ms-track{background-color:var(--ag-input-focus-border-color)}.ag-theme-blue input[class^=ag-][type=range]:disabled{opacity:.5}.ag-theme-blue .ag-icon{color:#333}.ag-theme-blue .ag-icon-tree-closed:before{content:"\\f10b"}.ag-theme-blue .ag-icon-tree-open:before{content:"\\f10f"}.ag-theme-blue .ag-column-drop-cell,.ag-theme-blue .ag-header{background-image:none}.ag-theme-blue .ag-tab{border:1px solid transparent;padding:4px 8px;margin:4px 4px -1px}.ag-theme-blue .ag-tabs-body{margin:2px 0}.ag-theme-blue .ag-icon{margin:1px 1px 2px}.ag-theme-blue .ag-tab-selected{background-color:#fff;background-color:var(--ag-background-color,#fff);border-color:#9bc2e6;border-color:var(--ag-border-color,#9bc2e6);border-bottom-color:transparent}.ag-theme-blue .ag-tabs-header{background-color:#5e9cd3;background-color:var(--ag-header-background-color,#5e9cd3);border-bottom:1px solid #9bc2e6;border-bottom-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-filter .ag-filter-apply-panel{justify-content:flex-start}.ag-theme-blue .ag-menu-option-active{background-color:#c8c8c8;background-color:var(--ag-selected-row-background-color,#c8c8c8)}.ag-theme-blue .ag-column-drop-cell{border:1px solid #9bc2e6;border-color:var(--ag-border-color,#9bc2e6);border-radius:0}.ag-theme-blue .ag-column-drop-cell-button .ag-icon{border:1px solid transparent}.ag-theme-blue .ag-column-drop-cell-button:hover .ag-icon{border-color:#9bc2e6;border-color:var(--ag-border-color,#9bc2e6)}.ag-theme-blue .ag-panel-title-bar-button-icon{font-size:20px;line-height:20px}.ag-theme-blue .ag-menu-option-part{padding-top:4px;padding-bottom:4px}.ag-theme-blue .ag-column-drop-vertical-title-bar{margin-top:4px;margin-left:4px}.ag-theme-blue .ag-column-drop-vertical-title{margin-left:4px}.ag-theme-blue .ag-column-drop-vertical-empty-message{margin-left:24px}',""]),e.exports=t},function(e,t,o){var r=o(27),a=o(166);"string"==typeof(a=a.__esModule?a.default:a)&&(a=[[e.i,a,""]]);var n={insert:"head",singleton:!1};r(a,n);e.exports=a.locals||{}},function(e,t,o){(t=o(28)(!1)).push([e.i,'.ag-theme-bootstrap{-webkit-font-smoothing:antialiased;color:#000;color:var(--ag-foreground-color,#000);font-family:Helvetica Neue,sans-serif;font-size:14px;line-height:normal}@font-face{font-family:agGridClassic;src:url("data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABOsAAsAAAAAJiwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlIAAAReYchjok9TLzIAAANcAAAAQQAAAFZWVlJ+Y21hcAAAA6AAAAHtAAAFgHClDfdnbHlmAAAFkAAACi0AABQQq+8lqmhlYWQAAA/AAAAANAAAADZ2z8SBaGhlYQAAD/QAAAAeAAAAJAfTBChobXR4AAAQFAAAABoAAAEou4L/4mxvY2EAABAwAAAAbwAAAJb7HvWgbWF4cAAAEKAAAAAfAAAAIAFgAHhuYW1lAAAQwAAAATMAAAJS8kTiWnBvc3QAABH0AAABtgAAApcplp2DeJx9k0lyE0EQRX+rZSMPyGDMZMRkRpsh3O5BjSTLltzyQHjBggULNmYBAeFg5ROw5gAEB+AUnIBgyYoDcACCA/Ay1UbGC6tC1VWZP3/+yspSIGlSy+qqUmzuPld9f+/gveZV1fBn/qPrYP/tmz3VDnf4qv6tKQj/qK4FvdCBvgUKXgefK+NhJeyGu+GH8FP4QyGoG3oMekorjFgJc6RUmZrKVdE4tpj1E7VAh8xtt87qgsbcU2ig8+SMiRk445Ke6o7OwNN3np7WQKUM4+wxbzHuauYERK578GeoWcVqrA10ntWENtHYQ0eH6BbeGXzrZI6I6eProy10VNXruK2XRM762SwyK3Ep/1gbvo9894AqHKLa8DfhN75Fsh7am2RKiHgEewaqW9Zwif8U3hRMRGzHa2bR10AmKEx1nZWdLOFk07oN+zO98qwbZUzPqzg88yLqR/a+8+XkOWrtwLUF9iEaRla7kfvkirSDf5KbKvROH/VFX/VdP/VLv3UK6ypeO8Ea3OsnVqZG/Y6jC7ztf1Y76Th3fhz1P2KCcze9NjG+QVlByzaFTqtNyjrCmjp+Ep2GL1CTU68qOSLPm2AdY6yyj0GfLruxxZj2Og/oAeuAeWqxwmxMw37L2V+GyVZDXRe9Wi14LvltWU3tJdV9Zz1vtzxPna/wjThZ5vXZxnsVizGNLA2PylFtHMv4c9SOspmqBqoSeqDmnbXjr6Ag003OMVSS6Ja/gB3vqgUUZOWLnNM5V98pb2rOcbFHBWiOypeces2sk/tos67Y+gsvGGrHAAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMnxi4gDQjSA4A1QYKdAAAAHictdQHTltBFIXh3wXTTEnvvRc6hGp6XQbpiBREOsoqs5O7gZBzPScLIFJG+nw9o+c3b/R8LtAB1OSp1KFap0KO31qttNdr9LTX6/zSvEkXVX0fYo8DjmL0+FirQ+yyz2FU2rO/o6Krm1zlPs80W2GMJeZZZZItxmlpdZEF1phhmg0mmGOKdXaYZZlNtvX7qnav6xkbdGrfbj1Jr+7YRz8DDHKaM5zlHOe5wEUucZkr2u0a17nBTW5xmzvc5Z72f8BDHvGYJzrPkD6HNRvRAzY42Vg54fU5xpbmVye3xls67cLazLQOOje1vjO7vLn9Dzf7D6OZH7Wfnu2Qb7PI0+7amDy3JXlh8/LSVuWVTcpr25I3Ni5vrSV7lv+QfVuUd7Yg721NPtiMfLRpObANObQJ+WRz8tmm5Iuty1fLs3+zWfluy/LDNuXI9AKjUmRWolqQtVZktqJeZL6io8jcRaMga2dB1q6CrN0FWXuKzGP0FmRtFvkmo68ga39B1oGCrIMFWU8VyhJhShVhyhdhShphyhxhSh9hyiFhSiRhyiZhSilhyithSi5hyjBhSjNhyjVhSjhhyjphSj1hyj9h6gSEqScQpu5AmPoEYeoRhKl3EKb+QVj2zbDMTFj7muGCrCNF+56jBSN/AHzNoH4AAAB4nO1Ye2xT1xm/37nEN87D8bUdXwezwLWJDZQCtmNfO4FATIgdQhLWGwhrt0DSGJHHpgaawFRatBIVVrXbHxXTWCiPabMHo9MgSH1IGxJMa6b+sbBJFZVK2/HHVNjI6JZ2k8W97DvHjzyggPrntBufe17fPec73/md3/edcMDhw4f4fs7IcSBLglwuW3mZD+mj+/ZBQtv//vtkhPxuYiIFe2EvijD5T/lPuUVYCQpeRRK8oswyRRZZJokyywQZLrXFxscbNwPf1oh5m65txjzWpuu0PdYGhF9k/LIuWm/czOXm3Mq/whViRfAaMYlu+NkbCeiG7sTZU2TPGz3QrR/vOavdzMmTSTLJFTN51AW1QX3IZOOFsdiFC7GxC41jUJ8rjTVe4Ao47q6O67rBWTk35+Ue41ZyXIHsWgFBsboOArK/EspFmwl42WXAgh1bQtjlgYDorgqUu3nM+T7N5qpx4Y/83VUjyzWyZjY7HGZyW5Qk7ReqCi2qmmpvJ66Ii3yGL/xpZfjifySJmig6HCL5hyjpY/q1ZBJO6jtw2Vm9bjK9luJ6coq4p5UrmKOTALheK9/HdHDldbo1Q5teffLf1aev8zdyKuRU2jJTk3f0ot/XH4YTc/XwPpoevByUH6jFX/Tz0PoQHfTSJN3OWfM/2uwPmvkhk9L14qL38T2IjELOwXEIOskIvLIQDAL+ldvsOEu11+Mlf9O31zyta1A3Pv7ur4uLK8rsvg0+e1kFXIJTtdihX4Y14+N1paWVTk+Fy+dzVVQtqKTDG9gcR/gjOJuAWC3DtUkcV1WOZsPEz8nhlH6ej+rnk7OydAofaEniA620zGV1v5HF8spHsxYghsvdQXcwEAzw/RmLadaMBcmkZmaWoZbT30uxJ2NBS9aCk1kLWlFCJLdw2y5QlVJMFfaK8lG2ShH1CYhy0I0sIYsyH5TFQJCMJvWSJEyp+hi0pPQxlYyyehrrp7AxzeV54Hn+eXqujYDbIRgB2UCBKbAM65PspU8OgwVfpG9WFSxYncElhxmXiAFkLDrAz0+eTejH9eMJ+C4xaVNYOQFdCe6r4p7u2oPQ9wO95GGoH0smp233Lq9wFZyPW43zK1IoYJfskgkBicwGobUQdLsQk17rCuI1CJUg2RXJgMikfyEUUFgJ5UGu9qyNHnpucNvSb9cF6xeZ9D+taPYW1T0WfvzAX0PfXF3UUO17pVX9uv9bT3ZtrYus9D85BFc3N5os9kq5uHY5b1qyyjLvieaDa3Z5GgJLiuFAEQG1wGBy6tcM4W1Bf7zhabujeN2CImN1VZ1/40ub9KO+TqskLZwfaHf+b65FQjwv4UK4FroORg1ZXUNYpm12Jac0QcB4qzxrwE3lJBRR4A5dQdvw/hd/uJ8q+Y0933umoXpdZ/euZ3Zs3ciULWnctbc3VgQboagtFAtVLQl5VvPlvNr84nBLW0nJRs8af/NI85Yz/vg2JWwwKP4eq2RfVBF+qjrUWcOXLlgGhcXzm22FAuEyPMo4px95DT2+VQbRG/SVB4Iq45Qk34/eZ3sq3d6elSV30I/yLDoQ3SI6Fq8gwVqVmC9fDqfTZFIvgSm94dIlrFDxkuxZvziL05zcwmmvqiDT5BI8pCwjH6WSyTT7ISN8WQlOJpMTSUaCJ+/NUKWC7Lovcl/jZK4KPenjlIcYsSLvZSk2n0R3UAZ3Ofr0TKrCBKeQYdFGyLY0p0zF8h3t0JqdjqnD96tovqSaxiytklhas6hwqh15TFXn2rTKLQaARicCuaOq2m1m1PQMi2b46iS/lfGVhIRHQzTYebpHPw7dPWdIDZw8nYmDzlCyJXe/uPsF/y/+n1w1159BpaGMuiwvYs+j4AEL+RkqsdUElQQb6sCDnUGfhxaxC6segXVTOSlgpx95q70+KsbkK0muuxL82KmEvB7yQsRmWxIeibQ2b2rZbcMnEi+qsAARyTxDhdNmCTY1OQ8usFidRgepWFpoL7JbwBpp2dTcGhkJL0FxSzkU2QuXOUhpsdFptToPOpuaghabs8IwjzcTsFQUxSN0XJyptfkozkQru9kAcaPZFPQXWgzznfGmkM3qHHHG406jaHY5lhYSg5nOxFQaCR9FcUuZQAqXOlxmo1BEBUecVluoKe6cb7AU+oMmszHOVjHzvBxBFC9kjCUgLJGs0FciYyE8cfPQYwaUoNctlJPY0eGjV6/iK5kv/Pjl7u6Xu8lvZjXSgvZWN+3i5s2KPZchNz5a5CmwoBYU5E5JeXDseevjmG80fAyuxT7xvR5+/SEBqFYX+2jVMRR//pOYD/O8H5qOVViUAtnEH7nzWz6aSelMNEJjEfrJV12bwsJ2XCIlnAev7bmPYquOKaNQHfuYKv2wtaWza3sNTXJMOZa/L7yKZ7KA7jA9jfAUO4ngzxFb5hw6+T9zpdN3EBY7SDDamwAveBO9vQn9A/2DRC8514ctWOrTX+rDNuzry8YSd1ksYeMWcwEaS9ATZqZOYxF1EWb0CKECemYDflqk8eVKehyZTzSU0+MIU4efHYxu2BAdfFb/bGgw2tAQHRyCCe3NUH00Nti1XYlI0rJ4qH49VjrDEcAafxOlh/TbQ7up9O4hMON3Gz7X3lwmSRGls3swFl0XaspUugbj0fpQDvdR9BMCcjiL2DBMC0iUKTFyo6y2M51Mqfp5FaZ4h5Ygo2qK8l/eVjTewxq4RckteN0KpVQy2Xkurarpc50wha5jvDed7oWwmuHnPE5k9Khhbu39kUIDBAaVWvRHwQKMIBExfOYeyg4mPaFWSuL0BjAHN9p3DlDcHEjx67R3SKUo/adk9eBgbcnFklqaDUxo10mjdA+CyO1kBkIkhiT9tkOE1ZkPMt+VkljyBbwzzMYR85Tk1Tk4IjMwQG9zbGPNFAaL6I6bKQwEBgsb7XHRejXtgalD+d0uyyHgMNvwiLK96zpuNj6dXfff7C10a693d1Lhzm4UViKz8biUxTD3w6PEVGQ+g4GS3nk8VtwJ3BvcGdyX+0LyUAZ+VKXrOSW/v37P4T3r2euR1dR3NGQ/Wb8nj60TWX/oVfACoMhBcvCXCejSTyROa38gsTOZUP50Ks/fA4jjUs5OYxh07XmeKcj+uyKAAH5L9blI3OXTxwZqJiZqBtrRCX8Ii/UP6Y0NFi8YqJ2YqB2A16bxTUbp6BhBpchP9DG8sJzPc8koYp/QO4pIYwS8nrRoO+f2kUz4wNdjwDU2Z0wj0CCjJSOR7UvyMYorI0HG4ZPaFf294YvwNrmiXYHgEJam9YrTnaVHABXTdiI4aXM+LnBzMa4D+dtumxsXLATalo0KQn6Jt/vz3t5gw96sr6dfCKxNAooH8LgyFbufPCEIHTNCgA7BKrQaDNvQn1MH2yHYBBemDuqm0cVvMxhaUaJjhivvEATiWG4y3fmpyWPCnO80ef54r0zL7FHgV7MnablXjTufL8cRcTgc1VuKw//fJvfa5L+BscYKAAAAeJxjYGRgYABi/jvPp8Xz23xl4GZ+ARSI4ny8rwFG///2/xvzZ+ZPQJUcDExAkgEAoUMP6XicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AIAnloHAgAAeJxjYGBgYH5Ba/z/G+3M/f+NgQ4AAPv8MfAAAHicY2AAAgmGIIYshhaGC4wijCGMPYz7GF8xGTGFMVUwTWC6wGzGPIf5BwsfiwZLCcsOlgssL1gnsB5iE2EzYGtim8K2jZ2HXYvdhX0Z+w72fxwRHAUcszhWcGzjOMJxieMZxxfOOi4O0iEAtgsblgB4nGNgZGBg8GLIYeBhAAEmIOYCQgaG/2A+AwAbuAHZAHicfZC9TsMwFIVP+odoBaoEYmAyCwtS+rPRtVKzd+ieJnaaKo2D41bqznPwBDxHn4OnYObEeCkStSXnu9899w4BMMQJAZoT4Ma9zWnhitUvt0n3njvkJ89dDBB67tG/eu7jBQvPA9zhjRuCzjXNI949t3CLD89t+k/PHfLJcxcP+PLco//23McqGHoe4DlQcRaZPJ0XcV3nyVJm+yI2Z+6sWElT57oUk3B85iNZShNbmYr1UdSHbGqtEsronVjo0sqi0KIyeisTG26srWajkfI+TPQOMTJEMMiRYo6Cdc2bI8ESkr29c+ZC7v/OihuMY40SAhP+9/GFfMR86WZiWH5Tzqxx5FvjwKkprYVirZjR2JEWbneTLng1TeV6W5qEPsTGTVWYYcSr/uRDprjpB8WrbRMAeJxtkmdv2zAURX1iyVbstEnTNt17D7VN994z/RUMRctEJFIgKY/8+rJxGiBA36dzHx7uu3xgZ6mzqEHn/7XFEl0SUnr0yVhmwJAVjnCUVdY4xjrHOcFJNjjFac5wlnOc5wIXucRlrnCVa1znBje5xW3ucJd73CfnAQ95xCaPecJTnvGcF7zkFa95w1ve8Z4PfOQTn/nCV77xnR/85Bdb/O4MRVk6VYqgrekJ5+zUd4WXPSmMVFUqx8KFNTlWcmfbzvI9UMXGQUObQgXlam1EUOsH7dbsT65IW1mXNzoK14+irY0fSGuCEzKoIpG2mafSWe+TQnmZqVkjomexrOYq95Xw4+EB5ZvdyL2RruLKdKSdD0npdJOWzrZNEkdCUqlR6FXaxN39yopCmzKrxUzXelcltTJtFrMulFGzkBhr1NDYkIuqslNVpE10Ud1Gm7TRExuyxqmJtq1fc9HM5tttCNbkdjRaPdwwqdPlOCReTNTA19EuL+zU7OPfWMMF7o1lC46pQzzNenBKHb5l1prFKwb/IN9EUOJQBDQWwxSPpGLMDtvM4lcoqGlpmDNil0mn8wcxorJdAAA=") format("woff");font-weight:400;font-style:normal}.ag-theme-bootstrap .ag-icon{font-family:agGridClassic;font-size:12px;line-height:12px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ag-theme-bootstrap .ag-icon-aggregation:before{content:"\\f101"}.ag-theme-bootstrap .ag-icon-arrows:before{content:"\\f102"}.ag-theme-bootstrap .ag-icon-asc:before{content:"\\f103"}.ag-theme-bootstrap .ag-icon-cancel:before{content:"\\f104"}.ag-theme-bootstrap .ag-icon-chart:before{content:"\\f105"}.ag-theme-bootstrap .ag-icon-color-picker:before{content:"\\f109"}.ag-theme-bootstrap .ag-icon-columns:before{content:"\\f10a"}.ag-theme-bootstrap .ag-icon-contracted:before{content:"\\f10b"}.ag-theme-bootstrap .ag-icon-copy:before{content:"\\f10c"}.ag-theme-bootstrap .ag-icon-cross:before{content:"\\f10d"}.ag-theme-bootstrap .ag-icon-desc:before{content:"\\f10e"}.ag-theme-bootstrap .ag-icon-expanded:before{content:"\\f10f"}.ag-theme-bootstrap .ag-icon-eye-slash:before{content:"\\f110"}.ag-theme-bootstrap .ag-icon-eye:before{content:"\\f111"}.ag-theme-bootstrap .ag-icon-filter:before{content:"\\f112"}.ag-theme-bootstrap .ag-icon-first:before{content:"\\f113"}.ag-theme-bootstrap .ag-icon-grip:before{content:"\\f114"}.ag-theme-bootstrap .ag-icon-group:before{content:"\\f115"}.ag-theme-bootstrap .ag-icon-last:before{content:"\\f116"}.ag-theme-bootstrap .ag-icon-left:before{content:"\\f117"}.ag-theme-bootstrap .ag-icon-linked:before{content:"\\f118"}.ag-theme-bootstrap .ag-icon-loading:before{content:"\\f119"}.ag-theme-bootstrap .ag-icon-maximize:before{content:"\\f11a"}.ag-theme-bootstrap .ag-icon-menu:before{content:"\\f11b"}.ag-theme-bootstrap .ag-icon-minimize:before{content:"\\f11c"}.ag-theme-bootstrap .ag-icon-next:before{content:"\\f11d"}.ag-theme-bootstrap .ag-icon-none:before{content:"\\f11e"}.ag-theme-bootstrap .ag-icon-not-allowed:before{content:"\\f11f"}.ag-theme-bootstrap .ag-icon-paste:before{content:"\\f120"}.ag-theme-bootstrap .ag-icon-pin:before{content:"\\f121"}.ag-theme-bootstrap .ag-icon-pivot:before{content:"\\f122"}.ag-theme-bootstrap .ag-icon-previous:before{content:"\\f123"}.ag-theme-bootstrap .ag-icon-right:before{content:"\\f126"}.ag-theme-bootstrap .ag-icon-save:before{content:"\\f127"}.ag-theme-bootstrap .ag-icon-small-down:before{content:"\\f128"}.ag-theme-bootstrap .ag-icon-small-left:before{content:"\\f129"}.ag-theme-bootstrap .ag-icon-small-right:before{content:"\\f12a"}.ag-theme-bootstrap .ag-icon-small-up:before{content:"\\f12b"}.ag-theme-bootstrap .ag-icon-tick:before{content:"\\f12c"}.ag-theme-bootstrap .ag-icon-tree-closed:before{content:"\\f12d"}.ag-theme-bootstrap .ag-icon-tree-indeterminate:before{content:"\\f12e"}.ag-theme-bootstrap .ag-icon-tree-open:before{content:"\\f12f"}.ag-theme-bootstrap .ag-icon-unlinked:before{content:"\\f130"}.ag-theme-bootstrap .ag-icon-row-drag:before{content:"\\f114"}.ag-theme-bootstrap .ag-right-arrow:before{content:"\\f117";content:"\\f126"}.ag-theme-bootstrap .ag-root-wrapper{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-bootstrap [class^=ag-],.ag-theme-bootstrap [class^=ag-]:after,.ag-theme-bootstrap [class^=ag-]:before,.ag-theme-bootstrap [class^=ag-]:focus{box-sizing:border-box;outline:none}.ag-theme-bootstrap [class^=ag-]::-ms-clear{display:none}.ag-theme-bootstrap .ag-checkbox .ag-input-wrapper,.ag-theme-bootstrap .ag-radio-button .ag-input-wrapper{overflow:visible}.ag-theme-bootstrap .ag-range-field .ag-input-wrapper{height:100%}.ag-theme-bootstrap .ag-toggle-button{flex:none;width:unset;min-width:unset}.ag-theme-bootstrap .ag-ltr .ag-label-align-right .ag-label{margin-left:4px}.ag-theme-bootstrap .ag-rtl .ag-label-align-right .ag-label{margin-right:4px}.ag-theme-bootstrap input[class^=ag-]{margin:0}.ag-theme-bootstrap input[class^=ag-],.ag-theme-bootstrap select[class^=ag-],.ag-theme-bootstrap textarea[class^=ag-]{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-bootstrap input[class^=ag-]:not([type]),.ag-theme-bootstrap input[class^=ag-][type=date],.ag-theme-bootstrap input[class^=ag-][type=datetime-local],.ag-theme-bootstrap input[class^=ag-][type=number],.ag-theme-bootstrap input[class^=ag-][type=tel],.ag-theme-bootstrap input[class^=ag-][type=text],.ag-theme-bootstrap textarea[class^=ag-]{font-size:inherit;line-height:inherit;color:inherit;border:1px solid #000;border-color:var(--ag-input-border-color,#000)}.ag-theme-bootstrap input[class^=ag-]:not([type]):disabled,.ag-theme-bootstrap input[class^=ag-][type=date]:disabled,.ag-theme-bootstrap input[class^=ag-][type=datetime-local]:disabled,.ag-theme-bootstrap input[class^=ag-][type=number]:disabled,.ag-theme-bootstrap input[class^=ag-][type=tel]:disabled,.ag-theme-bootstrap input[class^=ag-][type=text]:disabled,.ag-theme-bootstrap textarea[class^=ag-]:disabled{color:rgba(0,0,0,.5);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.5));background-color:#ebebeb;background-color:var(--ag-input-disabled-background-color,#ebebeb);border-color:rgba(0,0,0,.3);border-color:var(--ag-input-disabled-border-color,rgba(0,0,0,.3))}.ag-theme-bootstrap input[class^=ag-]:not([type]):focus,.ag-theme-bootstrap input[class^=ag-][type=date]:focus,.ag-theme-bootstrap input[class^=ag-][type=datetime-local]:focus,.ag-theme-bootstrap input[class^=ag-][type=number]:focus,.ag-theme-bootstrap input[class^=ag-][type=tel]:focus,.ag-theme-bootstrap input[class^=ag-][type=text]:focus,.ag-theme-bootstrap textarea[class^=ag-]:focus{outline:none;border-color:var(--ag-input-focus-border-color)}.ag-theme-bootstrap input[class^=ag-][type=number]{-moz-appearance:textfield}.ag-theme-bootstrap input[class^=ag-][type=number]::-webkit-inner-spin-button,.ag-theme-bootstrap input[class^=ag-][type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.ag-theme-bootstrap input[class^=ag-][type=range]{padding:0}.ag-theme-bootstrap .ag-drag-handle{color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-list-item,.ag-theme-bootstrap .ag-virtual-list-item{height:20px}.ag-theme-bootstrap .ag-keyboard-focus .ag-virtual-list-item:focus{outline:none}.ag-theme-bootstrap .ag-keyboard-focus .ag-virtual-list-item:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-bootstrap .ag-select-list{background-color:#fff;background-color:var(--ag-background-color,#fff);overflow-y:auto;overflow-x:hidden}.ag-theme-bootstrap .ag-list-item{display:flex;align-items:center}.ag-theme-bootstrap .ag-list-item.ag-active-item{background-color:var(--ag-row-hover-color)}.ag-theme-bootstrap .ag-select-list-item{padding-left:4px;padding-right:4px;cursor:default;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.ag-theme-bootstrap .ag-select-list-item span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.ag-theme-bootstrap .ag-select .ag-picker-field-wrapper{background-color:#fff;background-color:var(--ag-background-color,#fff);min-height:20px;cursor:default}.ag-theme-bootstrap .ag-select:not(.ag-cell-editor){height:20px}.ag-theme-bootstrap .ag-select .ag-picker-field-display{margin:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ag-theme-bootstrap .ag-select .ag-picker-field-icon{display:flex;align-items:center}.ag-theme-bootstrap .ag-select.ag-disabled{opacity:.5}.ag-theme-bootstrap .ag-rich-select{background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6)}.ag-theme-bootstrap .ag-rich-select-list{width:100%;min-width:200px;height:162.5px}.ag-theme-bootstrap .ag-rich-select-value{padding:0 4px 0 12px;height:25px}.ag-theme-bootstrap .ag-rich-select-virtual-list-item{cursor:default;height:20px}.ag-theme-bootstrap .ag-rich-select-virtual-list-item:hover{background-color:var(--ag-row-hover-color)}.ag-theme-bootstrap .ag-rich-select-row{padding-left:12px}.ag-theme-bootstrap .ag-rich-select-row-selected{background-color:#bde2e5;background-color:var(--ag-selected-row-background-color,#bde2e5)}.ag-theme-bootstrap .ag-group-contracted,.ag-theme-bootstrap .ag-group-expanded,.ag-theme-bootstrap .ag-row-drag,.ag-theme-bootstrap .ag-selection-checkbox{color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-ltr .ag-group-contracted,.ag-theme-bootstrap .ag-ltr .ag-group-expanded,.ag-theme-bootstrap .ag-ltr .ag-row-drag,.ag-theme-bootstrap .ag-ltr .ag-selection-checkbox{margin-right:12px}.ag-theme-bootstrap .ag-rtl .ag-group-contracted,.ag-theme-bootstrap .ag-rtl .ag-group-expanded,.ag-theme-bootstrap .ag-rtl .ag-row-drag,.ag-theme-bootstrap .ag-rtl .ag-selection-checkbox{margin-left:12px}.ag-theme-bootstrap .ag-cell-wrapper>:not(.ag-cell-value):not(.ag-group-value){height:23px;display:flex;align-items:center;flex:none}.ag-theme-bootstrap .ag-group-contracted,.ag-theme-bootstrap .ag-group-expanded{cursor:pointer}.ag-theme-bootstrap .ag-group-title-bar-icon{cursor:pointer;flex:none;color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-ltr .ag-group-child-count{margin-left:2px}.ag-theme-bootstrap .ag-rtl .ag-group-child-count{margin-right:2px}.ag-theme-bootstrap .ag-group-title-bar{background-color:#ececec;background-color:var(--ag-subheader-background-color,#ececec);padding:4px}.ag-theme-bootstrap .ag-group-toolbar{padding:4px}.ag-theme-bootstrap .ag-disabled-group-container,.ag-theme-bootstrap .ag-disabled-group-title-bar{opacity:.5}.ag-theme-bootstrap .group-item{margin:2px 0}.ag-theme-bootstrap .ag-label{white-space:nowrap}.ag-theme-bootstrap .ag-ltr .ag-label{margin-right:4px}.ag-theme-bootstrap .ag-rtl .ag-label{margin-left:4px}.ag-theme-bootstrap .ag-label-align-top .ag-label{margin-bottom:2px}.ag-theme-bootstrap .ag-ltr .ag-angle-select-field,.ag-theme-bootstrap .ag-ltr .ag-slider-field{margin-right:8px}.ag-theme-bootstrap .ag-rtl .ag-angle-select-field,.ag-theme-bootstrap .ag-rtl .ag-slider-field{margin-left:8px}.ag-theme-bootstrap .ag-angle-select-parent-circle{width:24px;height:24px;border-radius:12px;border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-bootstrap .ag-angle-select-child-circle{top:4px;left:12px;width:6px;height:6px;margin-left:-3px;margin-top:-4px;border-radius:3px;background-color:#000;background-color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-picker-field-wrapper{border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);border-radius:5px}.ag-theme-bootstrap .ag-picker-field-button{background-color:#fff;background-color:var(--ag-background-color,#fff);color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-dialog.ag-color-dialog{border-radius:5px}.ag-theme-bootstrap .ag-color-picker .ag-picker-field-display{height:12px}.ag-theme-bootstrap .ag-color-panel{padding:4px}.ag-theme-bootstrap .ag-spectrum-color{background-color:red;border-radius:2px}.ag-theme-bootstrap .ag-spectrum-tools{padding:10px}.ag-theme-bootstrap .ag-spectrum-sat{background-image:linear-gradient(90deg,#fff,rgba(204,154,129,0))}.ag-theme-bootstrap .ag-spectrum-val{background-image:linear-gradient(0deg,#000,rgba(204,154,129,0))}.ag-theme-bootstrap .ag-spectrum-dragger{border-radius:12px;height:12px;width:12px;border:1px solid #fff;background:#000;box-shadow:0 0 2px 0 rgba(0,0,0,.24)}.ag-theme-bootstrap .ag-spectrum-alpha-background,.ag-theme-bootstrap .ag-spectrum-hue-background{border-radius:2px}.ag-theme-bootstrap .ag-spectrum-tool{margin-bottom:10px;height:11px;border-radius:2px}.ag-theme-bootstrap .ag-spectrum-slider{margin-top:-12px;width:13px;height:13px;border-radius:13px;background-color:#f8f8f8;box-shadow:0 1px 4px 0 rgba(0,0,0,.37)}.ag-theme-bootstrap .ag-recent-color{margin:0 3px}.ag-theme-bootstrap .ag-recent-color:first-child{margin-left:0}.ag-theme-bootstrap .ag-recent-color:last-child{margin-right:0}.ag-theme-bootstrap.ag-dnd-ghost{background:#fff;background:var(--ag-background-color,#fff);border-radius:0;box-shadow:none;overflow:hidden;text-overflow:ellipsis;z-index:10;color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000));height:25px!important;line-height:25px;margin:0;padding:0 8px;-webkit-transform:translateY(8px);transform:translateY(8px)}.ag-theme-bootstrap .ag-dnd-ghost-icon{margin-right:4px;color:#000;color:var(--ag-foreground-color,#000)}.ag-theme-bootstrap .ag-popup-child:not(.ag-tooltip-custom){box-shadow:5px 5px 10px rgba(0,0,0,.3)}.ag-dragging-fill-handle .ag-theme-bootstrap .ag-dialog,.ag-dragging-range-handle .ag-theme-bootstrap .ag-dialog{opacity:.7;pointer-events:none}.ag-theme-bootstrap .ag-dialog{border-radius:0}.ag-theme-bootstrap .ag-panel{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-bootstrap .ag-panel-title-bar{background-color:var(--ag-header-background-color);color:#000;color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000)));height:25px;padding:4px 12px}.ag-theme-bootstrap .ag-ltr .ag-panel-title-bar-button{margin-left:4px}.ag-theme-bootstrap .ag-rtl .ag-panel-title-bar-button{margin-right:4px}.ag-theme-bootstrap .ag-tooltip{background-color:var(--ag-header-background-color);color:#000;color:var(--ag-foreground-color,#000);padding:4px;border-radius:0;transition:opacity 1s}.ag-theme-bootstrap .ag-tooltip.ag-tooltip-hiding{opacity:0}.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-1{padding-left:16px}.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-1{padding-right:16px}.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-2{padding-left:32px}.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-2{padding-right:32px}.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-3{padding-left:48px}.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-3{padding-right:48px}.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-4{padding-left:64px}.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-4{padding-right:64px}.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-5{padding-left:80px}.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-5{padding-right:80px}.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-6{padding-left:96px}.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-6{padding-right:96px}.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-7{padding-left:112px}.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-7{padding-right:112px}.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-8{padding-left:128px}.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-8{padding-right:128px}.ag-theme-bootstrap .ag-ltr .ag-column-select-indent-9{padding-left:144px}.ag-theme-bootstrap .ag-rtl .ag-column-select-indent-9{padding-right:144px}.ag-theme-bootstrap .ag-column-select-header-icon{cursor:pointer}.ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-header-icon:focus{outline:none}.ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-header-icon:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:0;left:0;display:block;width:100%;height:100%;border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-bootstrap .ag-ltr .ag-column-group-icons:not(:last-child),.ag-theme-bootstrap .ag-ltr .ag-column-select-checkbox:not(:last-child),.ag-theme-bootstrap .ag-ltr .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-bootstrap .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-bootstrap .ag-ltr .ag-column-select-column-label:not(:last-child),.ag-theme-bootstrap .ag-ltr .ag-column-select-header-checkbox:not(:last-child),.ag-theme-bootstrap .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-bootstrap .ag-ltr .ag-column-select-header-icon:not(:last-child){margin-right:6px}.ag-theme-bootstrap .ag-rtl .ag-column-group-icons:not(:last-child),.ag-theme-bootstrap .ag-rtl .ag-column-select-checkbox:not(:last-child),.ag-theme-bootstrap .ag-rtl .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-bootstrap .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-bootstrap .ag-rtl .ag-column-select-column-label:not(:last-child),.ag-theme-bootstrap .ag-rtl .ag-column-select-header-checkbox:not(:last-child),.ag-theme-bootstrap .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-bootstrap .ag-rtl .ag-column-select-header-icon:not(:last-child){margin-left:6px}.ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-column-group:focus{outline:none}.ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-column-group:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-2px;left:-2px;display:block;width:calc(100% - -4px);height:calc(100% - -4px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-column:focus{outline:none}.ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-column:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-2px;left:-2px;display:block;width:calc(100% - -4px);height:calc(100% - -4px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-bootstrap .ag-column-select-column-group:not(:last-child),.ag-theme-bootstrap .ag-column-select-column:not(:last-child){margin-bottom:4px}.ag-theme-bootstrap .ag-column-select-column-group-readonly,.ag-theme-bootstrap .ag-column-select-column-readonly{color:rgba(0,0,0,.5);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.5));pointer-events:none}.ag-theme-bootstrap .ag-ltr .ag-column-select-add-group-indent{margin-left:20px}.ag-theme-bootstrap .ag-rtl .ag-column-select-add-group-indent{margin-right:20px}.ag-theme-bootstrap .ag-column-select-list{padding:6px}.ag-theme-bootstrap .ag-rtl{text-align:right}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-left:36px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-right:36px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-1{padding-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-1{padding-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-left:60px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-right:60px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-2{padding-left:48px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-2{padding-right:48px}.ag-theme-bootstrap .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-left:84px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-right:84px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-3{padding-left:72px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-3{padding-right:72px}.ag-theme-bootstrap .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-left:108px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-right:108px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-4{padding-left:96px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-4{padding-right:96px}.ag-theme-bootstrap .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-left:132px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-right:132px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-5{padding-left:120px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-5{padding-right:120px}.ag-theme-bootstrap .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-left:156px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-right:156px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-6{padding-left:144px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-6{padding-right:144px}.ag-theme-bootstrap .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-left:180px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-right:180px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-7{padding-left:168px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-7{padding-right:168px}.ag-theme-bootstrap .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-left:204px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-right:204px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-8{padding-left:192px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-8{padding-right:192px}.ag-theme-bootstrap .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-left:228px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-right:228px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-9{padding-left:216px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-9{padding-right:216px}.ag-theme-bootstrap .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-left:252px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-right:252px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-10{padding-left:240px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-10{padding-right:240px}.ag-theme-bootstrap .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-left:276px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-right:276px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-11{padding-left:264px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-11{padding-right:264px}.ag-theme-bootstrap .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-left:300px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-right:300px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-12{padding-left:288px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-12{padding-right:288px}.ag-theme-bootstrap .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-left:324px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-right:324px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-13{padding-left:312px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-13{padding-right:312px}.ag-theme-bootstrap .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-left:348px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-right:348px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-14{padding-left:336px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-14{padding-right:336px}.ag-theme-bootstrap .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-left:372px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-right:372px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-15{padding-left:360px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-15{padding-right:360px}.ag-theme-bootstrap .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-left:396px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-right:396px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-16{padding-left:384px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-16{padding-right:384px}.ag-theme-bootstrap .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-left:420px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-right:420px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-17{padding-left:408px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-17{padding-right:408px}.ag-theme-bootstrap .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-left:444px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-right:444px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-18{padding-left:432px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-18{padding-right:432px}.ag-theme-bootstrap .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-left:468px}.ag-theme-bootstrap .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-right:468px}.ag-theme-bootstrap .ag-ltr .ag-row-group-indent-19{padding-left:456px}.ag-theme-bootstrap .ag-rtl .ag-row-group-indent-19{padding-right:456px}.ag-theme-bootstrap .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-bootstrap .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-bootstrap .ag-cell{-webkit-font-smoothing:subpixel-antialiased}.ag-theme-bootstrap .ag-value-change-delta{padding-right:2px}.ag-theme-bootstrap .ag-value-change-delta-up{color:#006400;color:var(--ag-value-change-delta-up-color,#006400)}.ag-theme-bootstrap .ag-value-change-delta-down{color:#8b0000;color:var(--ag-value-change-delta-down-color,#8b0000)}.ag-theme-bootstrap .ag-value-change-value{background-color:transparent;border-radius:1px;padding-left:1px;padding-right:1px;transition:background-color 1s}.ag-theme-bootstrap .ag-value-change-value-highlight{background-color:#cec;background-color:var(--ag-value-change-value-highlight-background-color,#cec);transition:background-color .1s}.ag-theme-bootstrap .ag-cell-data-changed{background-color:#cec!important;background-color:var(--ag-value-change-value-highlight-background-color,#cec)!important}.ag-theme-bootstrap .ag-cell-data-changed-animation{background-color:transparent}.ag-theme-bootstrap .ag-cell-highlight{background-color:rgba(136,255,136,.4)!important;background-color:var(--ag-range-selection-highlight-color,rgba(136,255,136,.4))!important}.ag-theme-bootstrap .ag-row{height:25px;background-color:#fff;background-color:var(--ag-background-color,#fff);color:#000;color:var(--ag-data-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-row-highlight-above:after,.ag-theme-bootstrap .ag-row-highlight-below:after{content:"";position:absolute;width:calc(100% - 1px);height:1px;background-color:#000;background-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000));left:1px}.ag-theme-bootstrap .ag-row-highlight-above:after{top:-1px}.ag-theme-bootstrap .ag-row-highlight-above.ag-row-first:after{top:0}.ag-theme-bootstrap .ag-row-highlight-below:after{bottom:0}.ag-theme-bootstrap .ag-row-odd{background-color:#f6f6f6;background-color:var(--ag-odd-row-background-color,#f6f6f6)}.ag-theme-bootstrap .ag-ltr .ag-right-aligned-cell{text-align:right}.ag-theme-bootstrap .ag-rtl .ag-right-aligned-cell{text-align:left}.ag-theme-bootstrap .ag-ltr .ag-right-aligned-cell .ag-cell-value{margin-left:auto}.ag-theme-bootstrap .ag-rtl .ag-right-aligned-cell .ag-cell-value{margin-right:auto}.ag-theme-bootstrap .ag-cell{border:1px solid transparent;line-height:23px}.ag-theme-bootstrap .ag-cell,.ag-theme-bootstrap .ag-row>.ag-cell-wrapper{padding-left:11px;padding-right:11px}.ag-theme-bootstrap .ag-row-dragging{cursor:move;opacity:.5}.ag-theme-bootstrap .ag-cell-inline-editing{height:25px}.ag-theme-bootstrap .ag-cell-inline-editing,.ag-theme-bootstrap .ag-popup-editor{background:#fff;background:var(--ag-background-color,#fff);border-radius:0;box-shadow:none;padding:0;background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6)}.ag-theme-bootstrap .ag-large-text-input{height:auto;padding:12px}.ag-theme-bootstrap .ag-details-row{padding:20px;background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-bootstrap .ag-overlay-loading-wrapper{background-color:hsla(0,0%,100%,.66);background-color:var(--ag-modal-overlay-background-color,hsla(0,0%,100%,.66))}.ag-theme-bootstrap .ag-overlay-loading-center{background:#fff;background:var(--ag-background-color,#fff);border-radius:0;box-shadow:none;padding:4px}.ag-theme-bootstrap .ag-overlay-no-rows-wrapper.ag-layout-auto-height{padding-top:30px}.ag-theme-bootstrap .ag-loading{padding-left:12px;display:flex;height:100%;align-items:center}.ag-theme-bootstrap .ag-loading-icon{padding-right:12px}.ag-theme-bootstrap .ag-icon-loading{-webkit-animation-name:spin;animation-name:spin;-webkit-animation-duration:1s;animation-duration:1s;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite;-webkit-animation-timing-function:linear;animation-timing-function:linear}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}.ag-theme-bootstrap .ag-ltr .ag-cell{border-right:solid transparent}.ag-theme-bootstrap .ag-rtl .ag-cell{border-left:solid transparent}.ag-theme-bootstrap .ag-ltr .ag-cell{border-right-width:1px}.ag-theme-bootstrap .ag-rtl .ag-cell{border-left-width:1px}.ag-theme-bootstrap .ag-row-selected{background-color:#bde2e5;background-color:var(--ag-selected-row-background-color,#bde2e5)}.ag-theme-bootstrap .ag-cell-range-selected:not(.ag-cell-focus){background-color:rgba(0,0,0,.2);background-color:var(--ag-range-selection-background-color,rgba(0,0,0,.2))}.ag-theme-bootstrap .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart{background-color:rgba(0,88,255,.1);background-color:var(--ag-range-selection-chart-background-color,rgba(0,88,255,.1))}.ag-theme-bootstrap .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category{background-color:rgba(0,255,132,.1);background-color:var(--ag-range-selection-chart-category-background-color,rgba(0,255,132,.1))}.ag-theme-bootstrap .ag-cell-range-selected-1:not(.ag-cell-focus){background-color:rgba(0,0,0,.2);background-color:var(--ag-range-selection-background-color-1,var(--ag-range-selection-background-color,rgba(0,0,0,.2)))}.ag-theme-bootstrap .ag-cell-range-selected-2:not(.ag-cell-focus){background-color:rgba(0,0,0,.36);background-color:var(--ag-range-selection-background-color-2,rgba(0,0,0,.36))}.ag-theme-bootstrap .ag-cell-range-selected-3:not(.ag-cell-focus){background-color:rgba(0,0,0,.488);background-color:var(--ag-range-selection-background-color-3,rgba(0,0,0,.488))}.ag-theme-bootstrap .ag-cell-range-selected-4:not(.ag-cell-focus){background-color:rgba(0,0,0,.5904);background-color:var(--ag-range-selection-background-color-4,rgba(0,0,0,.5904))}.ag-theme-bootstrap .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top{border-top-color:#000;border-top-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right{border-right-color:#000;border-right-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom{border-bottom-color:#000;border-bottom-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left{border-left-color:#000;border-left-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-bootstrap .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-bootstrap .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),.ag-theme-bootstrap .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-bootstrap .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-bootstrap .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected){border:1px solid #000;border-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000));outline:initial}.ag-theme-bootstrap .ag-cell.ag-selection-fill-top,.ag-theme-bootstrap .ag-cell.ag-selection-fill-top.ag-cell-range-selected{border-top:1px dashed #000;border-top-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-ltr .ag-cell.ag-selection-fill-right,.ag-theme-bootstrap .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-right:1px dashed #000;border-right-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-rtl .ag-cell.ag-selection-fill-right,.ag-theme-bootstrap .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-left:1px dashed #000;border-left-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-cell.ag-selection-fill-bottom,.ag-theme-bootstrap .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected{border-bottom:1px dashed #000;border-bottom-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-ltr .ag-cell.ag-selection-fill-left,.ag-theme-bootstrap .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-left:1px dashed #000;border-left-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-rtl .ag-cell.ag-selection-fill-left,.ag-theme-bootstrap .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-right:1px dashed #000;border-right-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-fill-handle,.ag-theme-bootstrap .ag-range-handle{position:absolute;width:6px;height:6px;bottom:-1px;background-color:#000;background-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-ltr .ag-fill-handle,.ag-theme-bootstrap .ag-ltr .ag-range-handle{right:-1px}.ag-theme-bootstrap .ag-rtl .ag-fill-handle,.ag-theme-bootstrap .ag-rtl .ag-range-handle{left:-1px}.ag-theme-bootstrap .ag-fill-handle{cursor:cell}.ag-theme-bootstrap .ag-range-handle{cursor:nwse-resize}.ag-theme-bootstrap .ag-cell-inline-editing{border-color:var(--ag-input-focus-border-color)!important}.ag-theme-bootstrap .ag-menu{background:#fff;background:var(--ag-background-color,#fff);border-radius:0;box-shadow:none;padding:0}.ag-theme-bootstrap .ag-menu-list{cursor:default;width:100%;padding-top:4px;padding-bottom:4px}.ag-theme-bootstrap .ag-menu-option-part{padding-top:6px;padding-bottom:6px;line-height:12px}.ag-theme-bootstrap .ag-menu-option-active{background-color:var(--ag-row-hover-color)}.ag-theme-bootstrap .ag-menu-option-disabled{opacity:.5}.ag-theme-bootstrap .ag-menu-option-text{margin-left:4px}.ag-theme-bootstrap .ag-menu-option-icon{padding-left:8px;padding-right:4px;min-width:20px}.ag-theme-bootstrap .ag-menu-option-shortcut{padding-left:8px}.ag-theme-bootstrap .ag-menu-separator{height:8px}.ag-theme-bootstrap .ag-menu-separator-cell:after{content:"";display:block}.ag-theme-bootstrap .ag-menu-option-popup-pointer{width:20px;text-align:center}.ag-theme-bootstrap .ag-tabs-header{min-width:220px;width:100%;display:flex}.ag-theme-bootstrap .ag-tab{border-bottom:0 solid transparent;display:flex;flex:none;align-items:center;justify-content:center;cursor:pointer}.ag-theme-bootstrap .ag-keyboard-focus .ag-tab:focus{outline:none}.ag-theme-bootstrap .ag-keyboard-focus .ag-tab:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-bootstrap .ag-tab-selected{border-bottom-color:#000;border-bottom-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-foreground-color,#000)))}.ag-theme-bootstrap .ag-menu-header{color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-filter-condition-operator{height:17px}.ag-theme-bootstrap .ag-ltr .ag-filter-condition-operator-or{margin-left:8px}.ag-theme-bootstrap .ag-rtl .ag-filter-condition-operator-or{margin-right:8px}.ag-theme-bootstrap .ag-set-filter-select-all{padding-top:6px}.ag-theme-bootstrap .ag-set-filter-list{height:120px}.ag-theme-bootstrap .ag-set-filter-filter{margin-top:6px;margin-left:6px;margin-right:6px}.ag-theme-bootstrap .ag-filter-to{margin-top:4px}.ag-theme-bootstrap .ag-mini-filter{margin:6px 6px 0}.ag-theme-bootstrap .ag-set-filter-item{margin:0 6px}.ag-theme-bootstrap .ag-ltr .ag-set-filter-item-value{margin-left:6px}.ag-theme-bootstrap .ag-rtl .ag-set-filter-item-value{margin-right:6px}.ag-theme-bootstrap .ag-filter-header-container{padding-bottom:6px}.ag-theme-bootstrap .ag-filter-apply-panel{padding:6px}.ag-theme-bootstrap .ag-filter-apply-panel-button{line-height:1.5}.ag-theme-bootstrap .ag-ltr .ag-filter-apply-panel-button{margin-left:8px}.ag-theme-bootstrap .ag-rtl .ag-filter-apply-panel-button{margin-right:8px}.ag-theme-bootstrap .ag-simple-filter-body-wrapper{padding:6px 6px 2px}.ag-theme-bootstrap .ag-simple-filter-body-wrapper>*{margin-bottom:4px}.ag-theme-bootstrap .ag-filter-no-matches{margin:6px}.ag-theme-bootstrap .ag-side-bar{position:relative}.ag-theme-bootstrap .ag-tool-panel-wrapper{background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6)}.ag-theme-bootstrap .ag-side-buttons{padding-top:16px;width:16px;position:relative;color:#000;color:var(--ag-foreground-color,#000);overflow:hidden}.ag-theme-bootstrap button.ag-side-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;background:transparent;padding:8px 0;width:100%;margin:0;min-height:72px;background-position-y:center;background-position-x:center;background-repeat:no-repeat;border:none}.ag-theme-bootstrap button.ag-side-button-button:focus{box-shadow:none}.ag-theme-bootstrap .ag-keyboard-focus .ag-side-button-button:focus{outline:none}.ag-theme-bootstrap .ag-keyboard-focus .ag-side-button-button:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-bootstrap .ag-side-button-icon-wrapper{margin-bottom:3px}.ag-theme-bootstrap .ag-ltr .ag-side-bar-left .ag-side-button-button,.ag-theme-bootstrap .ag-rtl .ag-side-bar-right .ag-side-button-button{border-right:0 solid transparent}.ag-theme-bootstrap .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,.ag-theme-bootstrap .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button{border-right-color:#000;border-right-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-foreground-color,#000)))}.ag-theme-bootstrap .ag-ltr .ag-side-bar-right .ag-side-button-button,.ag-theme-bootstrap .ag-rtl .ag-side-bar-left .ag-side-button-button{border-left:0 solid transparent}.ag-theme-bootstrap .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button,.ag-theme-bootstrap .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button{border-left-color:#000;border-left-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-foreground-color,#000)))}.ag-theme-bootstrap .ag-filter-toolpanel-header{height:24px}.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-header,.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-search{padding-left:4px}.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-header,.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-search{padding-right:4px}.ag-theme-bootstrap .ag-keyboard-focus .ag-filter-toolpanel-header:focus{outline:none}.ag-theme-bootstrap .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-bootstrap .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{font-family:agGridClassic;font-size:12px;line-height:12px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;content:"\\f112";position:absolute}.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-left:4px}.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-right:4px}.ag-theme-bootstrap .ag-filter-toolpanel-group-level-0-header{height:32px}.ag-theme-bootstrap .ag-filter-toolpanel-group-item{margin-top:2px;margin-bottom:2px}.ag-theme-bootstrap .ag-filter-toolpanel-search{height:25px}.ag-theme-bootstrap .ag-filter-toolpanel-search-input{flex-grow:1;height:16px}.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-search-input{margin-right:4px}.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-search-input{margin-left:4px}.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-expand,.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-title-bar-icon{margin-right:4px}.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-expand,.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-title-bar-icon{margin-left:4px}.ag-theme-bootstrap .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-left:20px}.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-right:20px}.ag-theme-bootstrap .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-left:36px}.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-right:36px}.ag-theme-bootstrap .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-left:52px}.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-right:52px}.ag-theme-bootstrap .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-left:68px}.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-right:68px}.ag-theme-bootstrap .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-left:84px}.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-right:84px}.ag-theme-bootstrap .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-left:100px}.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-right:100px}.ag-theme-bootstrap .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-left:116px}.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-right:116px}.ag-theme-bootstrap .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-left:132px}.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-right:132px}.ag-theme-bootstrap .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-left:148px}.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-right:148px}.ag-theme-bootstrap .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-left:164px}.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-right:164px}.ag-theme-bootstrap .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header{padding-left:4px}.ag-theme-bootstrap .ag-filter-toolpanel-instance-filter{padding-top:4px}.ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-instance-header-icon{margin-left:4px}.ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-instance-header-icon{margin-right:4px}.ag-theme-bootstrap .ag-pivot-mode-panel{height:25px;display:flex}.ag-theme-bootstrap .ag-pivot-mode-select{display:flex;align-items:center}.ag-theme-bootstrap .ag-ltr .ag-pivot-mode-select{margin-left:6px}.ag-theme-bootstrap .ag-rtl .ag-pivot-mode-select{margin-right:6px}.ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-header:focus{outline:none}.ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-bootstrap .ag-column-select-header{height:25px;align-items:center;padding:0 6px}.ag-theme-bootstrap .ag-column-group-icons,.ag-theme-bootstrap .ag-column-select-header-icon{color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-header{background-color:var(--ag-header-background-color)}.ag-theme-bootstrap .ag-header-row{color:#000;color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000)));height:25px}.ag-theme-bootstrap .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-left:4px}.ag-theme-bootstrap .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon,.ag-theme-bootstrap .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-right:4px}.ag-theme-bootstrap .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon{margin-left:4px}.ag-theme-bootstrap .ag-header-cell,.ag-theme-bootstrap .ag-header-group-cell{padding-left:12px;padding-right:12px}.ag-theme-bootstrap .ag-header-cell.ag-header-cell-moving,.ag-theme-bootstrap .ag-header-group-cell.ag-header-cell-moving{background-color:#bebebe;background-color:var(--ag-header-cell-moving-background-color,#bebebe)}.ag-theme-bootstrap .ag-keyboard-focus .ag-header-cell:focus{outline:none}.ag-theme-bootstrap .ag-keyboard-focus .ag-header-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-bootstrap .ag-keyboard-focus .ag-header-group-cell:focus{outline:none}.ag-theme-bootstrap .ag-keyboard-focus .ag-header-group-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-bootstrap .ag-header-icon{color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-header-expand-icon{cursor:pointer}.ag-theme-bootstrap .ag-ltr .ag-header-expand-icon{padding-left:4px}.ag-theme-bootstrap .ag-rtl .ag-header-expand-icon{padding-right:4px}.ag-theme-bootstrap .ag-ltr .ag-header-select-all{margin-right:12px}.ag-theme-bootstrap .ag-ltr .ag-floating-filter-button,.ag-theme-bootstrap .ag-rtl .ag-header-select-all{margin-left:12px}.ag-theme-bootstrap .ag-rtl .ag-floating-filter-button{margin-right:12px}.ag-theme-bootstrap .ag-floating-filter-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;height:12px;padding:0;width:12px}.ag-theme-bootstrap .ag-filter-loading{background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6);height:100%;padding:6px;position:absolute;width:100%;z-index:1}.ag-theme-bootstrap .ag-paging-panel{border-top:1px solid #a9a9a9;border-top-color:var(--ag-border-color,#a9a9a9);color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000));height:25px}.ag-theme-bootstrap .ag-paging-panel>*{margin:0 12px}.ag-theme-bootstrap .ag-paging-button{cursor:pointer;opacity:0;top:0;right:0;bottom:0;left:0;padding:0;width:12px}.ag-theme-bootstrap .ag-disabled .ag-paging-button{cursor:default}.ag-theme-bootstrap .ag-paging-button-wrapper.ag-disabled{color:rgba(0,0,0,.5);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.5));cursor:default}.ag-theme-bootstrap .ag-paging-button-wrapper,.ag-theme-bootstrap .ag-paging-description{margin:0 4px}.ag-theme-bootstrap .ag-status-bar{color:rgba(0,0,0,.5);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.5));padding-right:16px;padding-left:16px;line-height:1.5}.ag-theme-bootstrap .ag-status-name-value-value{color:#000;color:var(--ag-foreground-color,#000)}.ag-theme-bootstrap .ag-status-bar-center{text-align:center}.ag-theme-bootstrap .ag-status-name-value{margin-left:4px;margin-right:4px;padding-top:8px;padding-bottom:8px}.ag-theme-bootstrap .ag-column-drop-cell{background:#ecf0f1;background:var(--ag-chip-background-color,#ecf0f1);border-radius:16px;height:16px;padding:0 2px}.ag-theme-bootstrap .ag-column-drop-cell-text{margin:0 4px}.ag-theme-bootstrap .ag-column-drop-cell-button{min-width:16px;margin:0 2px;color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-column-drop-cell-drag-handle{margin-left:8px}.ag-theme-bootstrap .ag-column-drop-cell-ghost{opacity:.5}.ag-theme-bootstrap .ag-column-drop-horizontal{background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6);color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000));height:25px}.ag-theme-bootstrap .ag-ltr .ag-column-drop-horizontal{padding-left:12px}.ag-theme-bootstrap .ag-rtl .ag-column-drop-horizontal{padding-right:12px}.ag-theme-bootstrap .ag-column-drop-horizontal-cell-separator{margin:0 4px;color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-column-drop-horizontal-empty-message{color:rgba(0,0,0,.5);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.5))}.ag-theme-bootstrap .ag-ltr .ag-column-drop-horizontal-icon{margin-right:12px}.ag-theme-bootstrap .ag-rtl .ag-column-drop-horizontal-icon{margin-left:12px}.ag-theme-bootstrap .ag-column-drop-vertical-list{padding-bottom:4px;padding-right:4px;padding-left:4px}.ag-theme-bootstrap .ag-column-drop-vertical-cell{margin-top:4px}.ag-theme-bootstrap .ag-column-drop-vertical{min-height:50px;max-height:150px}.ag-theme-bootstrap .ag-column-drop-vertical-icon{margin-left:4px;margin-right:4px}.ag-theme-bootstrap .ag-column-drop-vertical-list{position:relative}.ag-theme-bootstrap .ag-column-drop-vertical-empty-message{position:absolute;top:0;bottom:0;left:0;right:0;overflow:hidden;color:rgba(0,0,0,.5);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.5));margin-top:4px}.ag-theme-bootstrap .ag-select-agg-func-popup{border-radius:0;box-shadow:none;background:#fff;background:var(--ag-background-color,#fff);height:70px;padding:0}.ag-theme-bootstrap .ag-select-agg-func-virtual-list-item{cursor:default;line-height:20px;padding-left:8px}.ag-theme-bootstrap .ag-select-agg-func-virtual-list-item:hover{background-color:#bde2e5;background-color:var(--ag-selected-row-background-color,#bde2e5)}.ag-theme-bootstrap .ag-chart-menu{border-radius:0;background:#fff;background:var(--ag-background-color,#fff)}.ag-theme-bootstrap .ag-chart-menu-icon{opacity:.5;line-height:24px;font-size:24px;width:24px;height:24px;margin:2px 0;cursor:pointer;border-radius:0;color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap .ag-chart-menu-icon:hover{opacity:1}.ag-theme-bootstrap .ag-chart-mini-thumbnail{border:1px solid #a9a9a9;border-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9));border-radius:5px;margin:5px}.ag-theme-bootstrap .ag-chart-mini-thumbnail:nth-last-child(3),.ag-theme-bootstrap .ag-chart-mini-thumbnail:nth-last-child(3)~.ag-chart-mini-thumbnail{margin-left:auto;margin-right:auto}.ag-theme-bootstrap .ag-ltr .ag-chart-mini-thumbnail:first-child{margin-left:0}.ag-theme-bootstrap .ag-ltr .ag-chart-mini-thumbnail:last-child,.ag-theme-bootstrap .ag-rtl .ag-chart-mini-thumbnail:first-child{margin-right:0}.ag-theme-bootstrap .ag-rtl .ag-chart-mini-thumbnail:last-child{margin-left:0}.ag-theme-bootstrap .ag-chart-mini-thumbnail.ag-selected{border-color:#000;border-color:var(--ag-minichart-selected-chart-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000)))}.ag-theme-bootstrap .ag-chart-settings-card-item{background:#000;background:var(--ag-foreground-color,#000);width:8px;height:8px;border-radius:4px}.ag-theme-bootstrap .ag-chart-settings-card-item.ag-selected{background-color:#000;background-color:var(--ag-minichart-selected-page-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000)))}.ag-theme-bootstrap .ag-chart-data-column-drag-handle{margin-left:4px}.ag-theme-bootstrap .ag-charts-settings-group-container{padding:4px}.ag-theme-bootstrap .ag-charts-data-group-container{padding:6px 6px 2px}.ag-theme-bootstrap .ag-charts-data-group-container>*{margin-bottom:4px}.ag-theme-bootstrap .ag-charts-format-top-level-group-container{margin-left:8px;padding:4px}.ag-theme-bootstrap .ag-charts-format-top-level-group-item{margin:4px 0}.ag-theme-bootstrap .ag-charts-format-sub-level-group-container{padding:6px 6px 2px}.ag-theme-bootstrap .ag-charts-format-sub-level-group-container>*{margin-bottom:4px}.ag-theme-bootstrap .ag-charts-group-container.ag-group-container-horizontal{padding:4px}.ag-theme-bootstrap .ag-chart-data-section,.ag-theme-bootstrap .ag-chart-format-section{display:flex;margin:0}.ag-theme-bootstrap .ag-chart-menu-panel{background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6)}.ag-theme-bootstrap .ag-ltr .ag-chart-menu-panel{border-left:1px solid #a9a9a9;border-left-color:var(--ag-border-color,#a9a9a9)}.ag-theme-bootstrap .ag-rtl .ag-chart-menu-panel{border-right:1px solid #a9a9a9;border-right-color:var(--ag-border-color,#a9a9a9)}.ag-theme-bootstrap .ag-date-time-list-page-title{flex-grow:1;text-align:center}.ag-theme-bootstrap .ag-date-time-list-page-column-label,.ag-theme-bootstrap .ag-date-time-list-page-entry{text-align:center}.ag-theme-bootstrap .ag-checkbox-input-wrapper{font-family:agGridClassic;font-size:12px;line-height:12px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:12px;height:12px;background-color:var(--ag-checkbox-background-color);border-radius:0;display:inline-block;vertical-align:middle;flex:none}.ag-theme-bootstrap .ag-checkbox-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-bootstrap .ag-checkbox-input-wrapper:active,.ag-theme-bootstrap .ag-checkbox-input-wrapper:focus-within{outline:none}.ag-theme-bootstrap .ag-checkbox-input-wrapper.ag-disabled{opacity:.5}.ag-theme-bootstrap .ag-checkbox-input-wrapper:after{content:"\\f108";color:#000;color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-bootstrap .ag-checkbox-input-wrapper.ag-checked:after{content:"\\f106";color:#000;color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-bootstrap .ag-checkbox-input-wrapper.ag-indeterminate:after{content:"\\f107";color:#000;color:var(--ag-checkbox-indeterminate-color,var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000)));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-bootstrap .ag-toggle-button-input-wrapper{box-sizing:border-box;width:24px;height:12px;background-color:#000;background-color:var(--ag-toggle-button-off-background-color,var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000)));border-radius:6px;position:relative;flex:none;border:1px solid #000;border-color:var(--ag-toggle-button-off-border-color,var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000)))}.ag-theme-bootstrap .ag-toggle-button-input-wrapper input{opacity:0;height:100%;width:100%}.ag-theme-bootstrap .ag-toggle-button-input-wrapper:focus-within{outline:none}.ag-theme-bootstrap .ag-toggle-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-bootstrap .ag-toggle-button-input-wrapper.ag-checked{background-color:#000;background-color:var(--ag-toggle-button-on-background-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000)));border-color:#000;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000)))}.ag-theme-bootstrap .ag-toggle-button-input-wrapper:before{content:" ";position:absolute;top:-1px;left:-1px;display:block;box-sizing:border-box;height:12px;width:12px;background-color:#fff;background-color:var(--ag-toggle-button-switch-background-color,var(--ag-background-color,#fff));border-radius:6px;transition:left .1s;border:1px solid #000;border-color:var(--ag-toggle-button-switch-border-color,var(--ag-toggle-button-off-border-color,var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000))))}.ag-theme-bootstrap .ag-toggle-button-input-wrapper.ag-checked:before{left:calc(100% - 12px);border-color:#000;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000)))}.ag-theme-bootstrap .ag-radio-button-input-wrapper{font-family:agGridClassic;font-size:12px;line-height:12px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:12px;height:12px;background-color:var(--ag-checkbox-background-color);border-radius:0;display:inline-block;vertical-align:middle;flex:none;border-radius:12px}.ag-theme-bootstrap .ag-radio-button-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-bootstrap .ag-radio-button-input-wrapper:active,.ag-theme-bootstrap .ag-radio-button-input-wrapper:focus-within{outline:none}.ag-theme-bootstrap .ag-radio-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-bootstrap .ag-radio-button-input-wrapper:after{content:"\\f124";color:#000;color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-bootstrap .ag-radio-button-input-wrapper.ag-checked:after{content:"\\f125";color:#000;color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-bootstrap input[class^=ag-][type=range]{-webkit-appearance:none;width:100%;height:100%;background:none;overflow:visible}.ag-theme-bootstrap input[class^=ag-][type=range]::-webkit-slider-runnable-track{margin:0;padding:0;width:100%;height:3px;background-color:#a9a9a9;background-color:var(--ag-border-color,#a9a9a9);border-radius:0}.ag-theme-bootstrap input[class^=ag-][type=range]::-moz-range-track{margin:0;padding:0;width:100%;height:3px;background-color:#a9a9a9;background-color:var(--ag-border-color,#a9a9a9);border-radius:0}.ag-theme-bootstrap input[class^=ag-][type=range]::-ms-track{margin:0;padding:0;width:100%;height:3px;background-color:#a9a9a9;background-color:var(--ag-border-color,#a9a9a9);border-radius:0;color:transparent;width:calc(100% - 2px)}.ag-theme-bootstrap input[class^=ag-][type=range]::-webkit-slider-thumb{margin:0;padding:0;-webkit-appearance:none;width:12px;height:12px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #000;border-color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000));border-radius:12px;-webkit-transform:translateY(-4.5px);transform:translateY(-4.5px)}.ag-theme-bootstrap input[class^=ag-][type=range]::-ms-thumb{margin:0;padding:0;-webkit-appearance:none;width:12px;height:12px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #000;border-color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000));border-radius:12px}.ag-theme-bootstrap input[class^=ag-][type=range]::-moz-ag-range-thumb{margin:0;padding:0;-webkit-appearance:none;width:12px;height:12px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #000;border-color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000));border-radius:12px}.ag-theme-bootstrap input[class^=ag-][type=range]:focus{outline:none}.ag-theme-bootstrap input[class^=ag-][type=range]:focus::-webkit-slider-thumb{border-color:#000;border-color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap input[class^=ag-][type=range]:focus::-ms-thumb{border-color:#000;border-color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap input[class^=ag-][type=range]:focus::-moz-ag-range-thumb{border-color:#000;border-color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000))}.ag-theme-bootstrap input[class^=ag-][type=range]:active::-webkit-slider-runnable-track{background-color:var(--ag-input-focus-border-color)}.ag-theme-bootstrap input[class^=ag-][type=range]:active::-moz-ag-range-track{background-color:var(--ag-input-focus-border-color)}.ag-theme-bootstrap input[class^=ag-][type=range]:active::-ms-track{background-color:var(--ag-input-focus-border-color)}.ag-theme-bootstrap input[class^=ag-][type=range]:disabled{opacity:.5}.ag-theme-bootstrap .ag-icon{color:#333}.ag-theme-bootstrap .ag-icon-tree-closed:before{content:"\\f10b"}.ag-theme-bootstrap .ag-icon-tree-open:before{content:"\\f10f"}.ag-theme-bootstrap .ag-column-drop-cell,.ag-theme-bootstrap .ag-header{background-image:none}.ag-theme-bootstrap .ag-tab{border:1px solid transparent;padding:4px 8px;margin:4px 4px -1px}.ag-theme-bootstrap .ag-tabs-body{margin:2px 0}.ag-theme-bootstrap .ag-icon{margin:1px 1px 2px}.ag-theme-bootstrap .ag-tab-selected{background-color:#fff;background-color:var(--ag-background-color,#fff);border-color:#a9a9a9;border-color:var(--ag-border-color,#a9a9a9);border-bottom-color:transparent}.ag-theme-bootstrap .ag-tabs-header{background-color:var(--ag-header-background-color);border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-border-color,#a9a9a9)}.ag-theme-bootstrap .ag-filter .ag-filter-apply-panel{justify-content:flex-start}.ag-theme-bootstrap .ag-menu-option-active{background-color:#bde2e5;background-color:var(--ag-selected-row-background-color,#bde2e5)}.ag-theme-bootstrap .ag-column-drop-cell{border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);border-radius:0}.ag-theme-bootstrap .ag-column-drop-cell-button .ag-icon{border:1px solid transparent}.ag-theme-bootstrap .ag-column-drop-cell-button:hover .ag-icon{border-color:#a9a9a9;border-color:var(--ag-border-color,#a9a9a9)}.ag-theme-bootstrap .ag-panel-title-bar-button-icon{font-size:20px;line-height:20px}.ag-theme-bootstrap .ag-menu-option-part{padding-top:4px;padding-bottom:4px}.ag-theme-bootstrap .ag-column-drop-vertical-title-bar{margin-top:4px;margin-left:4px}.ag-theme-bootstrap .ag-column-drop-vertical-title{margin-left:4px}.ag-theme-bootstrap .ag-column-drop-vertical-empty-message{margin-left:24px}',""]),e.exports=t},function(e,t,o){var r=o(27),a=o(168);"string"==typeof(a=a.__esModule?a.default:a)&&(a=[[e.i,a,""]]);var n={insert:"head",singleton:!1};r(a,n);e.exports=a.locals||{}},function(e,t,o){(t=o(28)(!1)).push([e.i,'.ag-theme-dark{-webkit-font-smoothing:antialiased;color:#ccc;color:var(--ag-foreground-color,#ccc);font-family:Helvetica Neue,sans-serif;font-size:14px;line-height:normal}@font-face{font-family:agGridClassic;src:url("data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABOsAAsAAAAAJiwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlIAAAReYchjok9TLzIAAANcAAAAQQAAAFZWVlJ+Y21hcAAAA6AAAAHtAAAFgHClDfdnbHlmAAAFkAAACi0AABQQq+8lqmhlYWQAAA/AAAAANAAAADZ2z8SBaGhlYQAAD/QAAAAeAAAAJAfTBChobXR4AAAQFAAAABoAAAEou4L/4mxvY2EAABAwAAAAbwAAAJb7HvWgbWF4cAAAEKAAAAAfAAAAIAFgAHhuYW1lAAAQwAAAATMAAAJS8kTiWnBvc3QAABH0AAABtgAAApcplp2DeJx9k0lyE0EQRX+rZSMPyGDMZMRkRpsh3O5BjSTLltzyQHjBggULNmYBAeFg5ROw5gAEB+AUnIBgyYoDcACCA/Ay1UbGC6tC1VWZP3/+yspSIGlSy+qqUmzuPld9f+/gveZV1fBn/qPrYP/tmz3VDnf4qv6tKQj/qK4FvdCBvgUKXgefK+NhJeyGu+GH8FP4QyGoG3oMekorjFgJc6RUmZrKVdE4tpj1E7VAh8xtt87qgsbcU2ig8+SMiRk445Ke6o7OwNN3np7WQKUM4+wxbzHuauYERK578GeoWcVqrA10ntWENtHYQ0eH6BbeGXzrZI6I6eProy10VNXruK2XRM762SwyK3Ep/1gbvo9894AqHKLa8DfhN75Fsh7am2RKiHgEewaqW9Zwif8U3hRMRGzHa2bR10AmKEx1nZWdLOFk07oN+zO98qwbZUzPqzg88yLqR/a+8+XkOWrtwLUF9iEaRla7kfvkirSDf5KbKvROH/VFX/VdP/VLv3UK6ypeO8Ea3OsnVqZG/Y6jC7ztf1Y76Th3fhz1P2KCcze9NjG+QVlByzaFTqtNyjrCmjp+Ep2GL1CTU68qOSLPm2AdY6yyj0GfLruxxZj2Og/oAeuAeWqxwmxMw37L2V+GyVZDXRe9Wi14LvltWU3tJdV9Zz1vtzxPna/wjThZ5vXZxnsVizGNLA2PylFtHMv4c9SOspmqBqoSeqDmnbXjr6Ag003OMVSS6Ja/gB3vqgUUZOWLnNM5V98pb2rOcbFHBWiOypeces2sk/tos67Y+gsvGGrHAAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMnxi4gDQjSA4A1QYKdAAAAHictdQHTltBFIXh3wXTTEnvvRc6hGp6XQbpiBREOsoqs5O7gZBzPScLIFJG+nw9o+c3b/R8LtAB1OSp1KFap0KO31qttNdr9LTX6/zSvEkXVX0fYo8DjmL0+FirQ+yyz2FU2rO/o6Krm1zlPs80W2GMJeZZZZItxmlpdZEF1phhmg0mmGOKdXaYZZlNtvX7qnav6xkbdGrfbj1Jr+7YRz8DDHKaM5zlHOe5wEUucZkr2u0a17nBTW5xmzvc5Z72f8BDHvGYJzrPkD6HNRvRAzY42Vg54fU5xpbmVye3xls67cLazLQOOje1vjO7vLn9Dzf7D6OZH7Wfnu2Qb7PI0+7amDy3JXlh8/LSVuWVTcpr25I3Ni5vrSV7lv+QfVuUd7Yg721NPtiMfLRpObANObQJ+WRz8tmm5Iuty1fLs3+zWfluy/LDNuXI9AKjUmRWolqQtVZktqJeZL6io8jcRaMga2dB1q6CrN0FWXuKzGP0FmRtFvkmo68ga39B1oGCrIMFWU8VyhJhShVhyhdhShphyhxhSh9hyiFhSiRhyiZhSilhyithSi5hyjBhSjNhyjVhSjhhyjphSj1hyj9h6gSEqScQpu5AmPoEYeoRhKl3EKb+QVj2zbDMTFj7muGCrCNF+56jBSN/AHzNoH4AAAB4nO1Ye2xT1xm/37nEN87D8bUdXwezwLWJDZQCtmNfO4FATIgdQhLWGwhrt0DSGJHHpgaawFRatBIVVrXbHxXTWCiPabMHo9MgSH1IGxJMa6b+sbBJFZVK2/HHVNjI6JZ2k8W97DvHjzyggPrntBufe17fPec73/md3/edcMDhw4f4fs7IcSBLglwuW3mZD+mj+/ZBQtv//vtkhPxuYiIFe2EvijD5T/lPuUVYCQpeRRK8oswyRRZZJokyywQZLrXFxscbNwPf1oh5m65txjzWpuu0PdYGhF9k/LIuWm/czOXm3Mq/whViRfAaMYlu+NkbCeiG7sTZU2TPGz3QrR/vOavdzMmTSTLJFTN51AW1QX3IZOOFsdiFC7GxC41jUJ8rjTVe4Ao47q6O67rBWTk35+Ue41ZyXIHsWgFBsboOArK/EspFmwl42WXAgh1bQtjlgYDorgqUu3nM+T7N5qpx4Y/83VUjyzWyZjY7HGZyW5Qk7ReqCi2qmmpvJ66Ii3yGL/xpZfjifySJmig6HCL5hyjpY/q1ZBJO6jtw2Vm9bjK9luJ6coq4p5UrmKOTALheK9/HdHDldbo1Q5teffLf1aev8zdyKuRU2jJTk3f0ot/XH4YTc/XwPpoevByUH6jFX/Tz0PoQHfTSJN3OWfM/2uwPmvkhk9L14qL38T2IjELOwXEIOskIvLIQDAL+ldvsOEu11+Mlf9O31zyta1A3Pv7ur4uLK8rsvg0+e1kFXIJTtdihX4Y14+N1paWVTk+Fy+dzVVQtqKTDG9gcR/gjOJuAWC3DtUkcV1WOZsPEz8nhlH6ej+rnk7OydAofaEniA620zGV1v5HF8spHsxYghsvdQXcwEAzw/RmLadaMBcmkZmaWoZbT30uxJ2NBS9aCk1kLWlFCJLdw2y5QlVJMFfaK8lG2ShH1CYhy0I0sIYsyH5TFQJCMJvWSJEyp+hi0pPQxlYyyehrrp7AxzeV54Hn+eXqujYDbIRgB2UCBKbAM65PspU8OgwVfpG9WFSxYncElhxmXiAFkLDrAz0+eTejH9eMJ+C4xaVNYOQFdCe6r4p7u2oPQ9wO95GGoH0smp233Lq9wFZyPW43zK1IoYJfskgkBicwGobUQdLsQk17rCuI1CJUg2RXJgMikfyEUUFgJ5UGu9qyNHnpucNvSb9cF6xeZ9D+taPYW1T0WfvzAX0PfXF3UUO17pVX9uv9bT3ZtrYus9D85BFc3N5os9kq5uHY5b1qyyjLvieaDa3Z5GgJLiuFAEQG1wGBy6tcM4W1Bf7zhabujeN2CImN1VZ1/40ub9KO+TqskLZwfaHf+b65FQjwv4UK4FroORg1ZXUNYpm12Jac0QcB4qzxrwE3lJBRR4A5dQdvw/hd/uJ8q+Y0933umoXpdZ/euZ3Zs3ciULWnctbc3VgQboagtFAtVLQl5VvPlvNr84nBLW0nJRs8af/NI85Yz/vg2JWwwKP4eq2RfVBF+qjrUWcOXLlgGhcXzm22FAuEyPMo4px95DT2+VQbRG/SVB4Iq45Qk34/eZ3sq3d6elSV30I/yLDoQ3SI6Fq8gwVqVmC9fDqfTZFIvgSm94dIlrFDxkuxZvziL05zcwmmvqiDT5BI8pCwjH6WSyTT7ISN8WQlOJpMTSUaCJ+/NUKWC7Lovcl/jZK4KPenjlIcYsSLvZSk2n0R3UAZ3Ofr0TKrCBKeQYdFGyLY0p0zF8h3t0JqdjqnD96tovqSaxiytklhas6hwqh15TFXn2rTKLQaARicCuaOq2m1m1PQMi2b46iS/lfGVhIRHQzTYebpHPw7dPWdIDZw8nYmDzlCyJXe/uPsF/y/+n1w1159BpaGMuiwvYs+j4AEL+RkqsdUElQQb6sCDnUGfhxaxC6segXVTOSlgpx95q70+KsbkK0muuxL82KmEvB7yQsRmWxIeibQ2b2rZbcMnEi+qsAARyTxDhdNmCTY1OQ8usFidRgepWFpoL7JbwBpp2dTcGhkJL0FxSzkU2QuXOUhpsdFptToPOpuaghabs8IwjzcTsFQUxSN0XJyptfkozkQru9kAcaPZFPQXWgzznfGmkM3qHHHG406jaHY5lhYSg5nOxFQaCR9FcUuZQAqXOlxmo1BEBUecVluoKe6cb7AU+oMmszHOVjHzvBxBFC9kjCUgLJGs0FciYyE8cfPQYwaUoNctlJPY0eGjV6/iK5kv/Pjl7u6Xu8lvZjXSgvZWN+3i5s2KPZchNz5a5CmwoBYU5E5JeXDseevjmG80fAyuxT7xvR5+/SEBqFYX+2jVMRR//pOYD/O8H5qOVViUAtnEH7nzWz6aSelMNEJjEfrJV12bwsJ2XCIlnAev7bmPYquOKaNQHfuYKv2wtaWza3sNTXJMOZa/L7yKZ7KA7jA9jfAUO4ngzxFb5hw6+T9zpdN3EBY7SDDamwAveBO9vQn9A/2DRC8514ctWOrTX+rDNuzry8YSd1ksYeMWcwEaS9ATZqZOYxF1EWb0CKECemYDflqk8eVKehyZTzSU0+MIU4efHYxu2BAdfFb/bGgw2tAQHRyCCe3NUH00Nti1XYlI0rJ4qH49VjrDEcAafxOlh/TbQ7up9O4hMON3Gz7X3lwmSRGls3swFl0XaspUugbj0fpQDvdR9BMCcjiL2DBMC0iUKTFyo6y2M51Mqfp5FaZ4h5Ygo2qK8l/eVjTewxq4RckteN0KpVQy2Xkurarpc50wha5jvDed7oWwmuHnPE5k9Khhbu39kUIDBAaVWvRHwQKMIBExfOYeyg4mPaFWSuL0BjAHN9p3DlDcHEjx67R3SKUo/adk9eBgbcnFklqaDUxo10mjdA+CyO1kBkIkhiT9tkOE1ZkPMt+VkljyBbwzzMYR85Tk1Tk4IjMwQG9zbGPNFAaL6I6bKQwEBgsb7XHRejXtgalD+d0uyyHgMNvwiLK96zpuNj6dXfff7C10a693d1Lhzm4UViKz8biUxTD3w6PEVGQ+g4GS3nk8VtwJ3BvcGdyX+0LyUAZ+VKXrOSW/v37P4T3r2euR1dR3NGQ/Wb8nj60TWX/oVfACoMhBcvCXCejSTyROa38gsTOZUP50Ks/fA4jjUs5OYxh07XmeKcj+uyKAAH5L9blI3OXTxwZqJiZqBtrRCX8Ii/UP6Y0NFi8YqJ2YqB2A16bxTUbp6BhBpchP9DG8sJzPc8koYp/QO4pIYwS8nrRoO+f2kUz4wNdjwDU2Z0wj0CCjJSOR7UvyMYorI0HG4ZPaFf294YvwNrmiXYHgEJam9YrTnaVHABXTdiI4aXM+LnBzMa4D+dtumxsXLATalo0KQn6Jt/vz3t5gw96sr6dfCKxNAooH8LgyFbufPCEIHTNCgA7BKrQaDNvQn1MH2yHYBBemDuqm0cVvMxhaUaJjhivvEATiWG4y3fmpyWPCnO80ef54r0zL7FHgV7MnablXjTufL8cRcTgc1VuKw//fJvfa5L+BscYKAAAAeJxjYGRgYABi/jvPp8Xz23xl4GZ+ARSI4ny8rwFG///2/xvzZ+ZPQJUcDExAkgEAoUMP6XicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AIAnloHAgAAeJxjYGBgYH5Ba/z/G+3M/f+NgQ4AAPv8MfAAAHicY2AAAgmGIIYshhaGC4wijCGMPYz7GF8xGTGFMVUwTWC6wGzGPIf5BwsfiwZLCcsOlgssL1gnsB5iE2EzYGtim8K2jZ2HXYvdhX0Z+w72fxwRHAUcszhWcGzjOMJxieMZxxfOOi4O0iEAtgsblgB4nGNgZGBg8GLIYeBhAAEmIOYCQgaG/2A+AwAbuAHZAHicfZC9TsMwFIVP+odoBaoEYmAyCwtS+rPRtVKzd+ieJnaaKo2D41bqznPwBDxHn4OnYObEeCkStSXnu9899w4BMMQJAZoT4Ma9zWnhitUvt0n3njvkJ89dDBB67tG/eu7jBQvPA9zhjRuCzjXNI949t3CLD89t+k/PHfLJcxcP+PLco//23McqGHoe4DlQcRaZPJ0XcV3nyVJm+yI2Z+6sWElT57oUk3B85iNZShNbmYr1UdSHbGqtEsronVjo0sqi0KIyeisTG26srWajkfI+TPQOMTJEMMiRYo6Cdc2bI8ESkr29c+ZC7v/OihuMY40SAhP+9/GFfMR86WZiWH5Tzqxx5FvjwKkprYVirZjR2JEWbneTLng1TeV6W5qEPsTGTVWYYcSr/uRDprjpB8WrbRMAeJxtkmdv2zAURX1iyVbstEnTNt17D7VN994z/RUMRctEJFIgKY/8+rJxGiBA36dzHx7uu3xgZ6mzqEHn/7XFEl0SUnr0yVhmwJAVjnCUVdY4xjrHOcFJNjjFac5wlnOc5wIXucRlrnCVa1znBje5xW3ucJd73CfnAQ95xCaPecJTnvGcF7zkFa95w1ve8Z4PfOQTn/nCV77xnR/85Bdb/O4MRVk6VYqgrekJ5+zUd4WXPSmMVFUqx8KFNTlWcmfbzvI9UMXGQUObQgXlam1EUOsH7dbsT65IW1mXNzoK14+irY0fSGuCEzKoIpG2mafSWe+TQnmZqVkjomexrOYq95Xw4+EB5ZvdyL2RruLKdKSdD0npdJOWzrZNEkdCUqlR6FXaxN39yopCmzKrxUzXelcltTJtFrMulFGzkBhr1NDYkIuqslNVpE10Ud1Gm7TRExuyxqmJtq1fc9HM5tttCNbkdjRaPdwwqdPlOCReTNTA19EuL+zU7OPfWMMF7o1lC46pQzzNenBKHb5l1prFKwb/IN9EUOJQBDQWwxSPpGLMDtvM4lcoqGlpmDNil0mn8wcxorJdAAA=") format("woff");font-weight:400;font-style:normal}.ag-theme-dark .ag-icon{font-family:agGridClassic;font-size:12px;line-height:12px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ag-theme-dark .ag-icon-aggregation:before{content:"\\f101"}.ag-theme-dark .ag-icon-arrows:before{content:"\\f102"}.ag-theme-dark .ag-icon-asc:before{content:"\\f103"}.ag-theme-dark .ag-icon-cancel:before{content:"\\f104"}.ag-theme-dark .ag-icon-chart:before{content:"\\f105"}.ag-theme-dark .ag-icon-color-picker:before{content:"\\f109"}.ag-theme-dark .ag-icon-columns:before{content:"\\f10a"}.ag-theme-dark .ag-icon-contracted:before{content:"\\f10b"}.ag-theme-dark .ag-icon-copy:before{content:"\\f10c"}.ag-theme-dark .ag-icon-cross:before{content:"\\f10d"}.ag-theme-dark .ag-icon-desc:before{content:"\\f10e"}.ag-theme-dark .ag-icon-expanded:before{content:"\\f10f"}.ag-theme-dark .ag-icon-eye-slash:before{content:"\\f110"}.ag-theme-dark .ag-icon-eye:before{content:"\\f111"}.ag-theme-dark .ag-icon-filter:before{content:"\\f112"}.ag-theme-dark .ag-icon-first:before{content:"\\f113"}.ag-theme-dark .ag-icon-grip:before{content:"\\f114"}.ag-theme-dark .ag-icon-group:before{content:"\\f115"}.ag-theme-dark .ag-icon-last:before{content:"\\f116"}.ag-theme-dark .ag-icon-left:before{content:"\\f117"}.ag-theme-dark .ag-icon-linked:before{content:"\\f118"}.ag-theme-dark .ag-icon-loading:before{content:"\\f119"}.ag-theme-dark .ag-icon-maximize:before{content:"\\f11a"}.ag-theme-dark .ag-icon-menu:before{content:"\\f11b"}.ag-theme-dark .ag-icon-minimize:before{content:"\\f11c"}.ag-theme-dark .ag-icon-next:before{content:"\\f11d"}.ag-theme-dark .ag-icon-none:before{content:"\\f11e"}.ag-theme-dark .ag-icon-not-allowed:before{content:"\\f11f"}.ag-theme-dark .ag-icon-paste:before{content:"\\f120"}.ag-theme-dark .ag-icon-pin:before{content:"\\f121"}.ag-theme-dark .ag-icon-pivot:before{content:"\\f122"}.ag-theme-dark .ag-icon-previous:before{content:"\\f123"}.ag-theme-dark .ag-icon-right:before{content:"\\f126"}.ag-theme-dark .ag-icon-save:before{content:"\\f127"}.ag-theme-dark .ag-icon-small-down:before{content:"\\f128"}.ag-theme-dark .ag-icon-small-left:before{content:"\\f129"}.ag-theme-dark .ag-icon-small-right:before{content:"\\f12a"}.ag-theme-dark .ag-icon-small-up:before{content:"\\f12b"}.ag-theme-dark .ag-icon-tick:before{content:"\\f12c"}.ag-theme-dark .ag-icon-tree-closed:before{content:"\\f12d"}.ag-theme-dark .ag-icon-tree-indeterminate:before{content:"\\f12e"}.ag-theme-dark .ag-icon-tree-open:before{content:"\\f12f"}.ag-theme-dark .ag-icon-unlinked:before{content:"\\f130"}.ag-theme-dark .ag-icon-row-drag:before{content:"\\f114"}.ag-theme-dark .ag-right-arrow:before{content:"\\f117";content:"\\f126"}.ag-theme-dark .ag-root-wrapper{background-color:#302e2e;background-color:var(--ag-background-color,#302e2e)}.ag-theme-dark [class^=ag-],.ag-theme-dark [class^=ag-]:after,.ag-theme-dark [class^=ag-]:before,.ag-theme-dark [class^=ag-]:focus{box-sizing:border-box;outline:none}.ag-theme-dark [class^=ag-]::-ms-clear{display:none}.ag-theme-dark .ag-checkbox .ag-input-wrapper,.ag-theme-dark .ag-radio-button .ag-input-wrapper{overflow:visible}.ag-theme-dark .ag-range-field .ag-input-wrapper{height:100%}.ag-theme-dark .ag-toggle-button{flex:none;width:unset;min-width:unset}.ag-theme-dark .ag-ltr .ag-label-align-right .ag-label{margin-left:4px}.ag-theme-dark .ag-rtl .ag-label-align-right .ag-label{margin-right:4px}.ag-theme-dark input[class^=ag-]{margin:0}.ag-theme-dark input[class^=ag-],.ag-theme-dark select[class^=ag-],.ag-theme-dark textarea[class^=ag-]{background-color:#302e2e;background-color:var(--ag-background-color,#302e2e)}.ag-theme-dark input[class^=ag-]:not([type]),.ag-theme-dark input[class^=ag-][type=date],.ag-theme-dark input[class^=ag-][type=datetime-local],.ag-theme-dark input[class^=ag-][type=number],.ag-theme-dark input[class^=ag-][type=tel],.ag-theme-dark input[class^=ag-][type=text],.ag-theme-dark textarea[class^=ag-]{font-size:inherit;line-height:inherit;color:inherit;border:1px solid #000;border-color:var(--ag-input-border-color,#000)}.ag-theme-dark input[class^=ag-]:not([type]):disabled,.ag-theme-dark input[class^=ag-][type=date]:disabled,.ag-theme-dark input[class^=ag-][type=datetime-local]:disabled,.ag-theme-dark input[class^=ag-][type=number]:disabled,.ag-theme-dark input[class^=ag-][type=tel]:disabled,.ag-theme-dark input[class^=ag-][type=text]:disabled,.ag-theme-dark textarea[class^=ag-]:disabled{color:hsla(0,0%,80%,.5);color:var(--ag-disabled-foreground-color,hsla(0,0%,80%,.5));background-color:rgba(48,46,46,.3);background-color:var(--ag-input-disabled-background-color,rgba(48,46,46,.3));border-color:rgba(0,0,0,.3);border-color:var(--ag-input-disabled-border-color,rgba(0,0,0,.3))}.ag-theme-dark input[class^=ag-]:not([type]):focus,.ag-theme-dark input[class^=ag-][type=date]:focus,.ag-theme-dark input[class^=ag-][type=datetime-local]:focus,.ag-theme-dark input[class^=ag-][type=number]:focus,.ag-theme-dark input[class^=ag-][type=tel]:focus,.ag-theme-dark input[class^=ag-][type=text]:focus,.ag-theme-dark textarea[class^=ag-]:focus{outline:none;border-color:var(--ag-input-focus-border-color)}.ag-theme-dark input[class^=ag-][type=number]{-moz-appearance:textfield}.ag-theme-dark input[class^=ag-][type=number]::-webkit-inner-spin-button,.ag-theme-dark input[class^=ag-][type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.ag-theme-dark input[class^=ag-][type=range]{padding:0}.ag-theme-dark .ag-drag-handle{color:#ccc;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-list-item,.ag-theme-dark .ag-virtual-list-item{height:20px}.ag-theme-dark .ag-keyboard-focus .ag-virtual-list-item:focus{outline:none}.ag-theme-dark .ag-keyboard-focus .ag-virtual-list-item:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-dark .ag-select-list{background-color:#302e2e;background-color:var(--ag-background-color,#302e2e);overflow-y:auto;overflow-x:hidden}.ag-theme-dark .ag-list-item{display:flex;align-items:center}.ag-theme-dark .ag-list-item.ag-active-item{background-color:var(--ag-row-hover-color)}.ag-theme-dark .ag-select-list-item{padding-left:4px;padding-right:4px;cursor:default;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.ag-theme-dark .ag-select-list-item span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.ag-theme-dark .ag-select .ag-picker-field-wrapper{background-color:#302e2e;background-color:var(--ag-background-color,#302e2e);min-height:20px;cursor:default}.ag-theme-dark .ag-select:not(.ag-cell-editor){height:20px}.ag-theme-dark .ag-select .ag-picker-field-display{margin:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ag-theme-dark .ag-select .ag-picker-field-icon{display:flex;align-items:center}.ag-theme-dark .ag-select.ag-disabled{opacity:.5}.ag-theme-dark .ag-rich-select{background-color:#302e2e;background-color:var(--ag-control-panel-background-color,#302e2e)}.ag-theme-dark .ag-rich-select-list{width:100%;min-width:200px;height:162.5px}.ag-theme-dark .ag-rich-select-value{padding:0 4px 0 12px;height:25px;border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9))}.ag-theme-dark .ag-rich-select-virtual-list-item{cursor:default;height:20px}.ag-theme-dark .ag-rich-select-virtual-list-item:hover{background-color:var(--ag-row-hover-color)}.ag-theme-dark .ag-rich-select-row{padding-left:12px}.ag-theme-dark .ag-rich-select-row-selected{background-color:#4a708b;background-color:var(--ag-selected-row-background-color,#4a708b)}.ag-theme-dark .ag-group-contracted,.ag-theme-dark .ag-group-expanded,.ag-theme-dark .ag-row-drag,.ag-theme-dark .ag-selection-checkbox{color:#ccc;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-ltr .ag-group-contracted,.ag-theme-dark .ag-ltr .ag-group-expanded,.ag-theme-dark .ag-ltr .ag-row-drag,.ag-theme-dark .ag-ltr .ag-selection-checkbox{margin-right:12px}.ag-theme-dark .ag-rtl .ag-group-contracted,.ag-theme-dark .ag-rtl .ag-group-expanded,.ag-theme-dark .ag-rtl .ag-row-drag,.ag-theme-dark .ag-rtl .ag-selection-checkbox{margin-left:12px}.ag-theme-dark .ag-cell-wrapper>:not(.ag-cell-value):not(.ag-group-value){height:23px;display:flex;align-items:center;flex:none}.ag-theme-dark .ag-group-contracted,.ag-theme-dark .ag-group-expanded{cursor:pointer}.ag-theme-dark .ag-group-title-bar-icon{cursor:pointer;flex:none;color:#ccc;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-ltr .ag-group-child-count{margin-left:2px}.ag-theme-dark .ag-rtl .ag-group-child-count{margin-right:2px}.ag-theme-dark .ag-group-title-bar{background-color:#201f1f;background-color:var(--ag-subheader-background-color,#201f1f);padding:4px}.ag-theme-dark .ag-group-toolbar{padding:4px}.ag-theme-dark .ag-disabled-group-container,.ag-theme-dark .ag-disabled-group-title-bar{opacity:.5}.ag-theme-dark .group-item{margin:2px 0}.ag-theme-dark .ag-label{white-space:nowrap}.ag-theme-dark .ag-ltr .ag-label{margin-right:4px}.ag-theme-dark .ag-rtl .ag-label{margin-left:4px}.ag-theme-dark .ag-label-align-top .ag-label{margin-bottom:2px}.ag-theme-dark .ag-ltr .ag-angle-select-field,.ag-theme-dark .ag-ltr .ag-slider-field{margin-right:8px}.ag-theme-dark .ag-rtl .ag-angle-select-field,.ag-theme-dark .ag-rtl .ag-slider-field{margin-left:8px}.ag-theme-dark .ag-angle-select-parent-circle{width:24px;height:24px;border-radius:12px;border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);background-color:#302e2e;background-color:var(--ag-background-color,#302e2e)}.ag-theme-dark .ag-angle-select-child-circle{top:4px;left:12px;width:6px;height:6px;margin-left:-3px;margin-top:-4px;border-radius:3px;background-color:#ccc;background-color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-picker-field-wrapper{border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);border-radius:5px}.ag-theme-dark .ag-picker-field-button{background-color:#302e2e;background-color:var(--ag-background-color,#302e2e);color:#ccc;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-dialog.ag-color-dialog{border-radius:5px}.ag-theme-dark .ag-color-picker .ag-picker-field-display{height:12px}.ag-theme-dark .ag-color-panel{padding:4px}.ag-theme-dark .ag-spectrum-color{background-color:red;border-radius:2px}.ag-theme-dark .ag-spectrum-tools{padding:10px}.ag-theme-dark .ag-spectrum-sat{background-image:linear-gradient(90deg,#fff,rgba(204,154,129,0))}.ag-theme-dark .ag-spectrum-val{background-image:linear-gradient(0deg,#000,rgba(204,154,129,0))}.ag-theme-dark .ag-spectrum-dragger{border-radius:12px;height:12px;width:12px;border:1px solid #fff;background:#000;box-shadow:0 0 2px 0 rgba(0,0,0,.24)}.ag-theme-dark .ag-spectrum-alpha-background,.ag-theme-dark .ag-spectrum-hue-background{border-radius:2px}.ag-theme-dark .ag-spectrum-tool{margin-bottom:10px;height:11px;border-radius:2px}.ag-theme-dark .ag-spectrum-slider{margin-top:-12px;width:13px;height:13px;border-radius:13px;background-color:#f8f8f8;box-shadow:0 1px 4px 0 rgba(0,0,0,.37)}.ag-theme-dark .ag-recent-color{margin:0 3px}.ag-theme-dark .ag-recent-color:first-child{margin-left:0}.ag-theme-dark .ag-recent-color:last-child{margin-right:0}.ag-theme-dark.ag-dnd-ghost{background:#302e2e;background:var(--ag-background-color,#302e2e);border-radius:0;box-shadow:none;overflow:hidden;text-overflow:ellipsis;z-index:10;border:1px solid #a9a9a9;border:1px solid var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9));color:#ccc;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#ccc));height:25px!important;line-height:25px;margin:0;padding:0 8px;-webkit-transform:translateY(8px);transform:translateY(8px)}.ag-theme-dark .ag-dnd-ghost-icon{margin-right:4px;color:#ccc;color:var(--ag-foreground-color,#ccc)}.ag-theme-dark .ag-popup-child:not(.ag-tooltip-custom){box-shadow:5px 5px 10px rgba(0,0,0,.3)}.ag-dragging-fill-handle .ag-theme-dark .ag-dialog,.ag-dragging-range-handle .ag-theme-dark .ag-dialog{opacity:.7;pointer-events:none}.ag-theme-dark .ag-dialog{border-radius:0;border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-panel{background-color:#302e2e;background-color:var(--ag-background-color,#302e2e)}.ag-theme-dark .ag-panel-title-bar{background-color:#626262;background-color:var(--ag-header-background-color,#626262);color:#ccc;color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,var(--ag-foreground-color,#ccc)));height:25px;padding:4px 12px;border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-ltr .ag-panel-title-bar-button{margin-left:4px}.ag-theme-dark .ag-rtl .ag-panel-title-bar-button{margin-right:4px}.ag-theme-dark .ag-tooltip{background-color:#626262;background-color:var(--ag-header-background-color,#626262);color:#ccc;color:var(--ag-foreground-color,#ccc);padding:4px;border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);border-radius:0;transition:opacity 1s}.ag-theme-dark .ag-tooltip.ag-tooltip-hiding{opacity:0}.ag-theme-dark .ag-ltr .ag-column-select-indent-1{padding-left:16px}.ag-theme-dark .ag-rtl .ag-column-select-indent-1{padding-right:16px}.ag-theme-dark .ag-ltr .ag-column-select-indent-2{padding-left:32px}.ag-theme-dark .ag-rtl .ag-column-select-indent-2{padding-right:32px}.ag-theme-dark .ag-ltr .ag-column-select-indent-3{padding-left:48px}.ag-theme-dark .ag-rtl .ag-column-select-indent-3{padding-right:48px}.ag-theme-dark .ag-ltr .ag-column-select-indent-4{padding-left:64px}.ag-theme-dark .ag-rtl .ag-column-select-indent-4{padding-right:64px}.ag-theme-dark .ag-ltr .ag-column-select-indent-5{padding-left:80px}.ag-theme-dark .ag-rtl .ag-column-select-indent-5{padding-right:80px}.ag-theme-dark .ag-ltr .ag-column-select-indent-6{padding-left:96px}.ag-theme-dark .ag-rtl .ag-column-select-indent-6{padding-right:96px}.ag-theme-dark .ag-ltr .ag-column-select-indent-7{padding-left:112px}.ag-theme-dark .ag-rtl .ag-column-select-indent-7{padding-right:112px}.ag-theme-dark .ag-ltr .ag-column-select-indent-8{padding-left:128px}.ag-theme-dark .ag-rtl .ag-column-select-indent-8{padding-right:128px}.ag-theme-dark .ag-ltr .ag-column-select-indent-9{padding-left:144px}.ag-theme-dark .ag-rtl .ag-column-select-indent-9{padding-right:144px}.ag-theme-dark .ag-column-select-header-icon{cursor:pointer}.ag-theme-dark .ag-keyboard-focus .ag-column-select-header-icon:focus{outline:none}.ag-theme-dark .ag-keyboard-focus .ag-column-select-header-icon:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:0;left:0;display:block;width:100%;height:100%;border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-dark .ag-ltr .ag-column-group-icons:not(:last-child),.ag-theme-dark .ag-ltr .ag-column-select-checkbox:not(:last-child),.ag-theme-dark .ag-ltr .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-dark .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-dark .ag-ltr .ag-column-select-column-label:not(:last-child),.ag-theme-dark .ag-ltr .ag-column-select-header-checkbox:not(:last-child),.ag-theme-dark .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-dark .ag-ltr .ag-column-select-header-icon:not(:last-child){margin-right:6px}.ag-theme-dark .ag-rtl .ag-column-group-icons:not(:last-child),.ag-theme-dark .ag-rtl .ag-column-select-checkbox:not(:last-child),.ag-theme-dark .ag-rtl .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-dark .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-dark .ag-rtl .ag-column-select-column-label:not(:last-child),.ag-theme-dark .ag-rtl .ag-column-select-header-checkbox:not(:last-child),.ag-theme-dark .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-dark .ag-rtl .ag-column-select-header-icon:not(:last-child){margin-left:6px}.ag-theme-dark .ag-keyboard-focus .ag-column-select-column-group:focus{outline:none}.ag-theme-dark .ag-keyboard-focus .ag-column-select-column-group:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-2px;left:-2px;display:block;width:calc(100% - -4px);height:calc(100% - -4px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-dark .ag-keyboard-focus .ag-column-select-column:focus{outline:none}.ag-theme-dark .ag-keyboard-focus .ag-column-select-column:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-2px;left:-2px;display:block;width:calc(100% - -4px);height:calc(100% - -4px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-dark .ag-column-select-column-group:not(:last-child),.ag-theme-dark .ag-column-select-column:not(:last-child){margin-bottom:4px}.ag-theme-dark .ag-column-select-column-group-readonly,.ag-theme-dark .ag-column-select-column-readonly{color:hsla(0,0%,80%,.5);color:var(--ag-disabled-foreground-color,hsla(0,0%,80%,.5));pointer-events:none}.ag-theme-dark .ag-ltr .ag-column-select-add-group-indent{margin-left:20px}.ag-theme-dark .ag-rtl .ag-column-select-add-group-indent{margin-right:20px}.ag-theme-dark .ag-column-select-list{padding:6px}.ag-theme-dark .ag-rtl{text-align:right}.ag-theme-dark .ag-root-wrapper{border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);border-radius:0}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-left:36px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-right:36px}.ag-theme-dark .ag-ltr .ag-row-group-indent-1{padding-left:24px}.ag-theme-dark .ag-rtl .ag-row-group-indent-1{padding-right:24px}.ag-theme-dark .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-left:60px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-right:60px}.ag-theme-dark .ag-ltr .ag-row-group-indent-2{padding-left:48px}.ag-theme-dark .ag-rtl .ag-row-group-indent-2{padding-right:48px}.ag-theme-dark .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-left:84px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-right:84px}.ag-theme-dark .ag-ltr .ag-row-group-indent-3{padding-left:72px}.ag-theme-dark .ag-rtl .ag-row-group-indent-3{padding-right:72px}.ag-theme-dark .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-left:108px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-right:108px}.ag-theme-dark .ag-ltr .ag-row-group-indent-4{padding-left:96px}.ag-theme-dark .ag-rtl .ag-row-group-indent-4{padding-right:96px}.ag-theme-dark .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-left:132px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-right:132px}.ag-theme-dark .ag-ltr .ag-row-group-indent-5{padding-left:120px}.ag-theme-dark .ag-rtl .ag-row-group-indent-5{padding-right:120px}.ag-theme-dark .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-left:156px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-right:156px}.ag-theme-dark .ag-ltr .ag-row-group-indent-6{padding-left:144px}.ag-theme-dark .ag-rtl .ag-row-group-indent-6{padding-right:144px}.ag-theme-dark .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-left:180px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-right:180px}.ag-theme-dark .ag-ltr .ag-row-group-indent-7{padding-left:168px}.ag-theme-dark .ag-rtl .ag-row-group-indent-7{padding-right:168px}.ag-theme-dark .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-left:204px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-right:204px}.ag-theme-dark .ag-ltr .ag-row-group-indent-8{padding-left:192px}.ag-theme-dark .ag-rtl .ag-row-group-indent-8{padding-right:192px}.ag-theme-dark .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-left:228px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-right:228px}.ag-theme-dark .ag-ltr .ag-row-group-indent-9{padding-left:216px}.ag-theme-dark .ag-rtl .ag-row-group-indent-9{padding-right:216px}.ag-theme-dark .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-left:252px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-right:252px}.ag-theme-dark .ag-ltr .ag-row-group-indent-10{padding-left:240px}.ag-theme-dark .ag-rtl .ag-row-group-indent-10{padding-right:240px}.ag-theme-dark .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-left:276px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-right:276px}.ag-theme-dark .ag-ltr .ag-row-group-indent-11{padding-left:264px}.ag-theme-dark .ag-rtl .ag-row-group-indent-11{padding-right:264px}.ag-theme-dark .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-left:300px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-right:300px}.ag-theme-dark .ag-ltr .ag-row-group-indent-12{padding-left:288px}.ag-theme-dark .ag-rtl .ag-row-group-indent-12{padding-right:288px}.ag-theme-dark .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-left:324px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-right:324px}.ag-theme-dark .ag-ltr .ag-row-group-indent-13{padding-left:312px}.ag-theme-dark .ag-rtl .ag-row-group-indent-13{padding-right:312px}.ag-theme-dark .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-left:348px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-right:348px}.ag-theme-dark .ag-ltr .ag-row-group-indent-14{padding-left:336px}.ag-theme-dark .ag-rtl .ag-row-group-indent-14{padding-right:336px}.ag-theme-dark .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-left:372px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-right:372px}.ag-theme-dark .ag-ltr .ag-row-group-indent-15{padding-left:360px}.ag-theme-dark .ag-rtl .ag-row-group-indent-15{padding-right:360px}.ag-theme-dark .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-left:396px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-right:396px}.ag-theme-dark .ag-ltr .ag-row-group-indent-16{padding-left:384px}.ag-theme-dark .ag-rtl .ag-row-group-indent-16{padding-right:384px}.ag-theme-dark .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-left:420px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-right:420px}.ag-theme-dark .ag-ltr .ag-row-group-indent-17{padding-left:408px}.ag-theme-dark .ag-rtl .ag-row-group-indent-17{padding-right:408px}.ag-theme-dark .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-left:444px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-right:444px}.ag-theme-dark .ag-ltr .ag-row-group-indent-18{padding-left:432px}.ag-theme-dark .ag-rtl .ag-row-group-indent-18{padding-right:432px}.ag-theme-dark .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-left:468px}.ag-theme-dark .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-right:468px}.ag-theme-dark .ag-ltr .ag-row-group-indent-19{padding-left:456px}.ag-theme-dark .ag-rtl .ag-row-group-indent-19{padding-right:456px}.ag-theme-dark .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-dark .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-dark .ag-cell{-webkit-font-smoothing:subpixel-antialiased}.ag-theme-dark .ag-value-change-delta{padding-right:2px}.ag-theme-dark .ag-value-change-delta-up{color:#adff2f;color:var(--ag-value-change-delta-up-color,#adff2f)}.ag-theme-dark .ag-value-change-delta-down{color:red;color:var(--ag-value-change-delta-down-color,red)}.ag-theme-dark .ag-value-change-value{background-color:transparent;border-radius:1px;padding-left:1px;padding-right:1px;transition:background-color 1s}.ag-theme-dark .ag-value-change-value-highlight{background-color:#d2691e;background-color:var(--ag-value-change-value-highlight-background-color,#d2691e);transition:background-color .1s}.ag-theme-dark .ag-cell-data-changed{background-color:#d2691e!important;background-color:var(--ag-value-change-value-highlight-background-color,#d2691e)!important}.ag-theme-dark .ag-cell-data-changed-animation{background-color:transparent}.ag-theme-dark .ag-cell-highlight{background-color:hsla(0,0%,100%,.4)!important;background-color:var(--ag-range-selection-highlight-color,hsla(0,0%,100%,.4))!important}.ag-theme-dark .ag-row{height:25px;background-color:#302e2e;background-color:var(--ag-background-color,#302e2e);color:#ccc;color:var(--ag-data-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-row-highlight-above:after,.ag-theme-dark .ag-row-highlight-below:after{content:"";position:absolute;width:calc(100% - 1px);height:1px;background-color:#ccc;background-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#ccc));left:1px}.ag-theme-dark .ag-row-highlight-above:after{top:-1px}.ag-theme-dark .ag-row-highlight-above.ag-row-first:after{top:0}.ag-theme-dark .ag-row-highlight-below:after{bottom:0}.ag-theme-dark .ag-row-odd{background-color:#403e3e;background-color:var(--ag-odd-row-background-color,#403e3e)}.ag-theme-dark .ag-horizontal-left-spacer:not(.ag-scroller-corner){border-right:1px solid #a9a9a9;border-right-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-horizontal-right-spacer:not(.ag-scroller-corner){border-left:1px solid #a9a9a9;border-left-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-ltr .ag-right-aligned-cell{text-align:right}.ag-theme-dark .ag-rtl .ag-right-aligned-cell{text-align:left}.ag-theme-dark .ag-ltr .ag-right-aligned-cell .ag-cell-value{margin-left:auto}.ag-theme-dark .ag-rtl .ag-right-aligned-cell .ag-cell-value{margin-right:auto}.ag-theme-dark .ag-cell{border:1px solid transparent;line-height:23px}.ag-theme-dark .ag-cell,.ag-theme-dark .ag-row>.ag-cell-wrapper{padding-left:11px;padding-right:11px}.ag-theme-dark .ag-row-dragging{cursor:move;opacity:.5}.ag-theme-dark .ag-cell-inline-editing{height:25px}.ag-theme-dark .ag-cell-inline-editing,.ag-theme-dark .ag-popup-editor{border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);background:#302e2e;background:var(--ag-background-color,#302e2e);border-radius:0;box-shadow:none;padding:0;background-color:#302e2e;background-color:var(--ag-control-panel-background-color,#302e2e)}.ag-theme-dark .ag-large-text-input{height:auto;padding:12px}.ag-theme-dark .ag-details-row{padding:20px;background-color:#302e2e;background-color:var(--ag-background-color,#302e2e)}.ag-theme-dark .ag-overlay-loading-wrapper{background-color:rgba(48,46,46,.66);background-color:var(--ag-modal-overlay-background-color,rgba(48,46,46,.66))}.ag-theme-dark .ag-overlay-loading-center{border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);background:#302e2e;background:var(--ag-background-color,#302e2e);border-radius:0;box-shadow:none;padding:4px}.ag-theme-dark .ag-overlay-no-rows-wrapper.ag-layout-auto-height{padding-top:30px}.ag-theme-dark .ag-loading{padding-left:12px;display:flex;height:100%;align-items:center}.ag-theme-dark .ag-loading-icon{padding-right:12px}.ag-theme-dark .ag-icon-loading{-webkit-animation-name:spin;animation-name:spin;-webkit-animation-duration:1s;animation-duration:1s;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite;-webkit-animation-timing-function:linear;animation-timing-function:linear}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}.ag-theme-dark .ag-floating-top{border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-floating-bottom{border-top:1px solid #a9a9a9;border-top-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-ltr .ag-cell{border-right:dotted grey}.ag-theme-dark .ag-rtl .ag-cell{border-left:dotted grey}.ag-theme-dark .ag-ltr .ag-cell{border-right-width:1px}.ag-theme-dark .ag-rtl .ag-cell{border-left-width:1px}.ag-theme-dark .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell){border-left:1px solid #a9a9a9;border-left-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell){border-right:1px solid #a9a9a9;border-right-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-row-selected{background-color:#4a708b;background-color:var(--ag-selected-row-background-color,#4a708b)}.ag-theme-dark .ag-cell-range-selected:not(.ag-cell-focus){background-color:rgba(100,160,160,.4);background-color:var(--ag-range-selection-background-color,rgba(100,160,160,.4))}.ag-theme-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart{background-color:rgba(0,88,255,.1);background-color:var(--ag-range-selection-chart-background-color,rgba(0,88,255,.1))}.ag-theme-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category{background-color:rgba(0,255,132,.1);background-color:var(--ag-range-selection-chart-category-background-color,rgba(0,255,132,.1))}.ag-theme-dark .ag-cell-range-selected-1:not(.ag-cell-focus){background-color:rgba(100,160,160,.4);background-color:var(--ag-range-selection-background-color-1,var(--ag-range-selection-background-color,rgba(100,160,160,.4)))}.ag-theme-dark .ag-cell-range-selected-2:not(.ag-cell-focus){background-color:rgba(100,160,160,.64);background-color:var(--ag-range-selection-background-color-2,rgba(100,160,160,.64))}.ag-theme-dark .ag-cell-range-selected-3:not(.ag-cell-focus){background-color:rgba(100,160,160,.784);background-color:var(--ag-range-selection-background-color-3,rgba(100,160,160,.784))}.ag-theme-dark .ag-cell-range-selected-4:not(.ag-cell-focus){background-color:rgba(100,160,160,.8704);background-color:var(--ag-range-selection-background-color-4,rgba(100,160,160,.8704))}.ag-theme-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top{border-top-color:#ccc;border-top-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right{border-right-color:#ccc;border-right-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom{border-bottom-color:#ccc;border-bottom-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left{border-left-color:#ccc;border-left-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-dark .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-dark .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),.ag-theme-dark .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-dark .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-dark .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected){border:1px solid #ccc;border-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#ccc));outline:initial}.ag-theme-dark .ag-cell.ag-selection-fill-top,.ag-theme-dark .ag-cell.ag-selection-fill-top.ag-cell-range-selected{border-top:1px dashed #ccc;border-top-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-ltr .ag-cell.ag-selection-fill-right,.ag-theme-dark .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-right:1px dashed #ccc;border-right-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-rtl .ag-cell.ag-selection-fill-right,.ag-theme-dark .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-left:1px dashed #ccc;border-left-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-cell.ag-selection-fill-bottom,.ag-theme-dark .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected{border-bottom:1px dashed #ccc;border-bottom-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-ltr .ag-cell.ag-selection-fill-left,.ag-theme-dark .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-left:1px dashed #ccc;border-left-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-rtl .ag-cell.ag-selection-fill-left,.ag-theme-dark .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-right:1px dashed #ccc;border-right-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-fill-handle,.ag-theme-dark .ag-range-handle{position:absolute;width:6px;height:6px;bottom:-1px;background-color:#ccc;background-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-ltr .ag-fill-handle,.ag-theme-dark .ag-ltr .ag-range-handle{right:-1px}.ag-theme-dark .ag-rtl .ag-fill-handle,.ag-theme-dark .ag-rtl .ag-range-handle{left:-1px}.ag-theme-dark .ag-fill-handle{cursor:cell}.ag-theme-dark .ag-range-handle{cursor:nwse-resize}.ag-theme-dark .ag-cell-inline-editing{border-color:var(--ag-input-focus-border-color)!important}.ag-theme-dark .ag-menu{border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);background:#302e2e;background:var(--ag-background-color,#302e2e);border-radius:0;box-shadow:none;padding:0}.ag-theme-dark .ag-menu-list{cursor:default;width:100%;padding-top:4px;padding-bottom:4px}.ag-theme-dark .ag-menu-option-part{padding-top:6px;padding-bottom:6px;line-height:12px}.ag-theme-dark .ag-menu-option-active{background-color:var(--ag-row-hover-color)}.ag-theme-dark .ag-menu-option-disabled{opacity:.5}.ag-theme-dark .ag-menu-option-text{margin-left:4px}.ag-theme-dark .ag-menu-option-icon{padding-left:8px;padding-right:4px;min-width:20px}.ag-theme-dark .ag-menu-option-shortcut{padding-left:8px}.ag-theme-dark .ag-menu-separator{height:8px}.ag-theme-dark .ag-menu-separator-cell:after{content:"";display:block;border-top:1px solid #a9a9a9;border-top-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-menu-option-popup-pointer{width:20px;text-align:center}.ag-theme-dark .ag-tabs-header{min-width:220px;width:100%;display:flex}.ag-theme-dark .ag-tab{border-bottom:0 solid transparent;display:flex;flex:none;align-items:center;justify-content:center;cursor:pointer}.ag-theme-dark .ag-keyboard-focus .ag-tab:focus{outline:none}.ag-theme-dark .ag-keyboard-focus .ag-tab:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-dark .ag-tab-selected{border-bottom-color:#ccc;border-bottom-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-foreground-color,#ccc)))}.ag-theme-dark .ag-menu-header{color:#ccc;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-filter-condition-operator{height:17px}.ag-theme-dark .ag-ltr .ag-filter-condition-operator-or{margin-left:8px}.ag-theme-dark .ag-rtl .ag-filter-condition-operator-or{margin-right:8px}.ag-theme-dark .ag-set-filter-select-all{padding-top:6px}.ag-theme-dark .ag-set-filter-list{height:120px}.ag-theme-dark .ag-set-filter-filter{margin-top:6px;margin-left:6px;margin-right:6px}.ag-theme-dark .ag-filter-to{margin-top:4px}.ag-theme-dark .ag-mini-filter{margin:6px 6px 0}.ag-theme-dark .ag-set-filter-item{margin:0 6px}.ag-theme-dark .ag-ltr .ag-set-filter-item-value{margin-left:6px}.ag-theme-dark .ag-rtl .ag-set-filter-item-value{margin-right:6px}.ag-theme-dark .ag-filter-header-container{padding-bottom:6px;border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9))}.ag-theme-dark .ag-filter-apply-panel{padding:6px;border-top:1px solid #a9a9a9;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9))}.ag-theme-dark .ag-filter-apply-panel-button{line-height:1.5}.ag-theme-dark .ag-ltr .ag-filter-apply-panel-button{margin-left:8px}.ag-theme-dark .ag-rtl .ag-filter-apply-panel-button{margin-right:8px}.ag-theme-dark .ag-simple-filter-body-wrapper{padding:6px 6px 2px}.ag-theme-dark .ag-simple-filter-body-wrapper>*{margin-bottom:4px}.ag-theme-dark .ag-filter-no-matches{margin:6px}.ag-theme-dark .ag-side-bar{position:relative}.ag-theme-dark .ag-tool-panel-wrapper{background-color:#302e2e;background-color:var(--ag-control-panel-background-color,#302e2e)}.ag-theme-dark .ag-side-buttons{padding-top:16px;width:16px;position:relative;color:#ccc;color:var(--ag-foreground-color,#ccc);overflow:hidden}.ag-theme-dark button.ag-side-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;background:transparent;padding:8px 0;width:calc(100% + 1px);margin:0;min-height:72px;background-position-y:center;background-position-x:center;background-repeat:no-repeat;border-left:none;border-right:none;border-top:#a9a9a9;border-top:1px solid var(--ag-border-color,#a9a9a9);border-bottom:#a9a9a9;border-bottom:1px solid var(--ag-border-color,#a9a9a9)}.ag-theme-dark button.ag-side-button-button:focus{box-shadow:none}.ag-theme-dark .ag-keyboard-focus .ag-side-button-button:focus{outline:none}.ag-theme-dark .ag-keyboard-focus .ag-side-button-button:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-dark .ag-selected .ag-side-button-button{background-color:#302e2e;background-color:var(--ag-control-panel-background-color,#302e2e);border-top-color:#a9a9a9;border-top-color:var(--ag-border-color,#a9a9a9);border-bottom-color:#a9a9a9;border-bottom-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-side-button-icon-wrapper{margin-bottom:3px}.ag-theme-dark .ag-ltr .ag-side-bar-left,.ag-theme-dark .ag-rtl .ag-side-bar-right{border-right:1px solid #a9a9a9;border-right-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,.ag-theme-dark .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper{border-left:1px solid #a9a9a9;border-left-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-ltr .ag-side-bar-left .ag-side-button-button,.ag-theme-dark .ag-rtl .ag-side-bar-right .ag-side-button-button{border-right:0 solid transparent;margin-right:-1px;padding-right:1px}.ag-theme-dark .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,.ag-theme-dark .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button{border-right-color:#ccc;border-right-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-foreground-color,#ccc)))}.ag-theme-dark .ag-ltr .ag-side-bar-right,.ag-theme-dark .ag-rtl .ag-side-bar-left{border-left:1px solid #a9a9a9;border-left-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper,.ag-theme-dark .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper{border-right:1px solid #a9a9a9;border-right-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-ltr .ag-side-bar-right .ag-side-button-button,.ag-theme-dark .ag-rtl .ag-side-bar-left .ag-side-button-button{border-left:0 solid transparent;margin-left:-1px;padding-left:1px}.ag-theme-dark .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button,.ag-theme-dark .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button{border-left-color:#ccc;border-left-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-foreground-color,#ccc)))}.ag-theme-dark .ag-filter-toolpanel-header{height:24px}.ag-theme-dark .ag-ltr .ag-filter-toolpanel-header,.ag-theme-dark .ag-ltr .ag-filter-toolpanel-search{padding-left:4px}.ag-theme-dark .ag-rtl .ag-filter-toolpanel-header,.ag-theme-dark .ag-rtl .ag-filter-toolpanel-search{padding-right:4px}.ag-theme-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus{outline:none}.ag-theme-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-dark .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{font-family:agGridClassic;font-size:12px;line-height:12px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;content:"\\f112";position:absolute}.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-left:4px}.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-right:4px}.ag-theme-dark .ag-filter-toolpanel-group-level-0-header{height:32px}.ag-theme-dark .ag-filter-toolpanel-group-item{margin-top:2px;margin-bottom:2px}.ag-theme-dark .ag-filter-toolpanel-search{height:25px}.ag-theme-dark .ag-filter-toolpanel-search-input{flex-grow:1;height:16px}.ag-theme-dark .ag-ltr .ag-filter-toolpanel-search-input{margin-right:4px}.ag-theme-dark .ag-rtl .ag-filter-toolpanel-search-input{margin-left:4px}.ag-theme-dark .ag-filter-toolpanel-group-level-0{border-top:1px solid #a9a9a9;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9))}.ag-theme-dark .ag-ltr .ag-filter-toolpanel-expand,.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-title-bar-icon{margin-right:4px}.ag-theme-dark .ag-rtl .ag-filter-toolpanel-expand,.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-title-bar-icon{margin-left:4px}.ag-theme-dark .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-left:20px}.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-right:20px}.ag-theme-dark .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-left:36px}.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-right:36px}.ag-theme-dark .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-left:52px}.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-right:52px}.ag-theme-dark .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-left:68px}.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-right:68px}.ag-theme-dark .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-left:84px}.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-right:84px}.ag-theme-dark .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-left:100px}.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-right:100px}.ag-theme-dark .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-left:116px}.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-right:116px}.ag-theme-dark .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-left:132px}.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-right:132px}.ag-theme-dark .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-left:148px}.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-right:148px}.ag-theme-dark .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-left:164px}.ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-right:164px}.ag-theme-dark .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header{padding-left:4px}.ag-theme-dark .ag-filter-toolpanel-instance-filter{border-top:1px solid #a9a9a9;border-top-color:var(--ag-border-color,#a9a9a9);border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-border-color,#a9a9a9);padding-top:4px}.ag-theme-dark .ag-ltr .ag-filter-toolpanel-instance-header-icon{margin-left:4px}.ag-theme-dark .ag-rtl .ag-filter-toolpanel-instance-header-icon{margin-right:4px}.ag-theme-dark .ag-pivot-mode-panel{height:25px;display:flex}.ag-theme-dark .ag-pivot-mode-select{display:flex;align-items:center}.ag-theme-dark .ag-ltr .ag-pivot-mode-select{margin-left:6px}.ag-theme-dark .ag-rtl .ag-pivot-mode-select{margin-right:6px}.ag-theme-dark .ag-keyboard-focus .ag-column-select-header:focus{outline:none}.ag-theme-dark .ag-keyboard-focus .ag-column-select-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-dark .ag-column-select-header{height:25px;align-items:center;padding:0 6px}.ag-theme-dark .ag-column-panel-column-select,.ag-theme-dark .ag-column-select-header{border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9))}.ag-theme-dark .ag-column-panel-column-select{border-top:1px solid #a9a9a9;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9))}.ag-theme-dark .ag-column-group-icons,.ag-theme-dark .ag-column-select-header-icon{color:#ccc;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-header{background-color:#626262;background-color:var(--ag-header-background-color,#626262);border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-header-row{color:#ccc;color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,var(--ag-foreground-color,#ccc)))}.ag-theme-dark .ag-pinned-right-header{border-left:1px solid #a9a9a9;border-left-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-pinned-left-header{border-right:1px solid #a9a9a9;border-right-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-header-row{height:25px}.ag-theme-dark .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-left:4px}.ag-theme-dark .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon,.ag-theme-dark .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-right:4px}.ag-theme-dark .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon{margin-left:4px}.ag-theme-dark .ag-header-cell,.ag-theme-dark .ag-header-group-cell{padding-left:12px;padding-right:12px}.ag-theme-dark .ag-header-cell.ag-header-cell-moving,.ag-theme-dark .ag-header-group-cell.ag-header-cell-moving{background-color:#bebebe;background-color:var(--ag-header-cell-moving-background-color,#bebebe)}.ag-theme-dark .ag-keyboard-focus .ag-header-cell:focus{outline:none}.ag-theme-dark .ag-keyboard-focus .ag-header-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-dark .ag-keyboard-focus .ag-header-group-cell:focus{outline:none}.ag-theme-dark .ag-keyboard-focus .ag-header-group-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-dark .ag-header-icon{color:#ccc;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-header-expand-icon{cursor:pointer}.ag-theme-dark .ag-ltr .ag-header-expand-icon{padding-left:4px}.ag-theme-dark .ag-rtl .ag-header-expand-icon{padding-right:4px}.ag-theme-dark .ag-header-row:not(:first-child) .ag-header-cell,.ag-theme-dark .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group{border-top:1px solid #a9a9a9;border-top-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-header-cell:after,.ag-theme-dark .ag-header-group-cell:after{content:"";position:absolute;z-index:1;display:block;width:1px;height:100%;top:0;background-color:hsla(0,0%,66.3%,.5);background-color:var(--ag-header-column-separator-color,hsla(0,0%,66.3%,.5))}.ag-theme-dark .ag-ltr .ag-header-cell:after,.ag-theme-dark .ag-ltr .ag-header-group-cell:after{right:0}.ag-theme-dark .ag-rtl .ag-header-cell:after,.ag-theme-dark .ag-rtl .ag-header-group-cell:after{left:0}.ag-theme-dark .ag-ltr .ag-header-select-all{margin-right:12px}.ag-theme-dark .ag-ltr .ag-floating-filter-button,.ag-theme-dark .ag-rtl .ag-header-select-all{margin-left:12px}.ag-theme-dark .ag-rtl .ag-floating-filter-button{margin-right:12px}.ag-theme-dark .ag-floating-filter-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;height:12px;padding:0;width:12px}.ag-theme-dark .ag-filter-loading{background-color:#302e2e;background-color:var(--ag-control-panel-background-color,#302e2e);height:100%;padding:6px;position:absolute;width:100%;z-index:1}.ag-theme-dark .ag-paging-panel{border-top:1px solid #a9a9a9;border-top-color:var(--ag-border-color,#a9a9a9);color:#ccc;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#ccc));height:25px}.ag-theme-dark .ag-paging-panel>*{margin:0 12px}.ag-theme-dark .ag-paging-button{cursor:pointer;opacity:0;top:0;right:0;bottom:0;left:0;padding:0;width:12px}.ag-theme-dark .ag-disabled .ag-paging-button{cursor:default}.ag-theme-dark .ag-paging-button-wrapper.ag-disabled{color:hsla(0,0%,80%,.5);color:var(--ag-disabled-foreground-color,hsla(0,0%,80%,.5));cursor:default}.ag-theme-dark .ag-paging-button-wrapper,.ag-theme-dark .ag-paging-description{margin:0 4px}.ag-theme-dark .ag-status-bar{border-top:1px solid #a9a9a9;border-top-color:var(--ag-border-color,#a9a9a9);color:hsla(0,0%,80%,.5);color:var(--ag-disabled-foreground-color,hsla(0,0%,80%,.5));padding-right:16px;padding-left:16px;line-height:1.5}.ag-theme-dark .ag-status-name-value-value{color:#ccc;color:var(--ag-foreground-color,#ccc)}.ag-theme-dark .ag-status-bar-center{text-align:center}.ag-theme-dark .ag-status-name-value{margin-left:4px;margin-right:4px;padding-top:8px;padding-bottom:8px}.ag-theme-dark .ag-column-drop-cell{background:#403e3e;background:var(--ag-chip-background-color,#403e3e);border-radius:16px;height:16px;padding:0 2px}.ag-theme-dark .ag-column-drop-cell-text{margin:0 4px}.ag-theme-dark .ag-column-drop-cell-button{min-width:16px;margin:0 2px;color:#ccc;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-column-drop-cell-drag-handle{margin-left:8px}.ag-theme-dark .ag-column-drop-cell-ghost{opacity:.5}.ag-theme-dark .ag-column-drop-horizontal{background-color:#302e2e;background-color:var(--ag-control-panel-background-color,#302e2e);color:#ccc;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#ccc));height:25px;border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-ltr .ag-column-drop-horizontal{padding-left:12px}.ag-theme-dark .ag-rtl .ag-column-drop-horizontal{padding-right:12px}.ag-theme-dark .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child){border-right:1px solid #a9a9a9;border-right-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child){border-left:1px solid #a9a9a9;border-left-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-column-drop-horizontal-cell-separator{margin:0 4px;color:#ccc;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-column-drop-horizontal-empty-message{color:hsla(0,0%,80%,.5);color:var(--ag-disabled-foreground-color,hsla(0,0%,80%,.5))}.ag-theme-dark .ag-ltr .ag-column-drop-horizontal-icon{margin-right:12px}.ag-theme-dark .ag-rtl .ag-column-drop-horizontal-icon{margin-left:12px}.ag-theme-dark .ag-column-drop-vertical-list{padding-bottom:4px;padding-right:4px;padding-left:4px}.ag-theme-dark .ag-column-drop-vertical-cell{margin-top:4px}.ag-theme-dark .ag-column-drop-vertical{min-height:50px;max-height:150px;border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9))}.ag-theme-dark .ag-column-drop-vertical.ag-last-column-drop{border-bottom:none}.ag-theme-dark .ag-column-drop-vertical-icon{margin-left:4px;margin-right:4px}.ag-theme-dark .ag-column-drop-vertical-list{position:relative}.ag-theme-dark .ag-column-drop-vertical-empty-message{position:absolute;top:0;bottom:0;left:0;right:0;overflow:hidden;color:hsla(0,0%,80%,.5);color:var(--ag-disabled-foreground-color,hsla(0,0%,80%,.5));margin-top:4px}.ag-theme-dark .ag-select-agg-func-popup{border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);border-radius:0;box-shadow:none;background:#302e2e;background:var(--ag-background-color,#302e2e);height:70px;padding:0}.ag-theme-dark .ag-select-agg-func-virtual-list-item{cursor:default;line-height:20px;padding-left:8px}.ag-theme-dark .ag-select-agg-func-virtual-list-item:hover{background-color:#4a708b;background-color:var(--ag-selected-row-background-color,#4a708b)}.ag-theme-dark .ag-chart-menu{border-radius:0;background:#302e2e;background:var(--ag-background-color,#302e2e)}.ag-theme-dark .ag-chart-menu-icon{opacity:.5;line-height:24px;font-size:24px;width:24px;height:24px;margin:2px 0;cursor:pointer;border-radius:0;color:#ccc;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark .ag-chart-menu-icon:hover{opacity:1}.ag-theme-dark .ag-chart-mini-thumbnail{border:1px solid #a9a9a9;border-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9));border-radius:5px;margin:5px}.ag-theme-dark .ag-chart-mini-thumbnail:nth-last-child(3),.ag-theme-dark .ag-chart-mini-thumbnail:nth-last-child(3)~.ag-chart-mini-thumbnail{margin-left:auto;margin-right:auto}.ag-theme-dark .ag-ltr .ag-chart-mini-thumbnail:first-child{margin-left:0}.ag-theme-dark .ag-ltr .ag-chart-mini-thumbnail:last-child,.ag-theme-dark .ag-rtl .ag-chart-mini-thumbnail:first-child{margin-right:0}.ag-theme-dark .ag-rtl .ag-chart-mini-thumbnail:last-child{margin-left:0}.ag-theme-dark .ag-chart-mini-thumbnail.ag-selected{border-color:#ccc;border-color:var(--ag-minichart-selected-chart-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#ccc)))}.ag-theme-dark .ag-chart-settings-card-item{background:#ccc;background:var(--ag-foreground-color,#ccc);width:8px;height:8px;border-radius:4px}.ag-theme-dark .ag-chart-settings-card-item.ag-selected{background-color:#ccc;background-color:var(--ag-minichart-selected-page-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#ccc)))}.ag-theme-dark .ag-chart-data-column-drag-handle{margin-left:4px}.ag-theme-dark .ag-charts-data-group-title-bar,.ag-theme-dark .ag-charts-format-top-level-group-title-bar,.ag-theme-dark .ag-charts-settings-group-title-bar{border-top:1px solid #a9a9a9;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9))}.ag-theme-dark .ag-charts-settings-group-container{padding:4px}.ag-theme-dark .ag-charts-data-group-container{padding:6px 6px 2px}.ag-theme-dark .ag-charts-data-group-container>*{margin-bottom:4px}.ag-theme-dark .ag-charts-format-top-level-group-container{margin-left:8px;padding:4px}.ag-theme-dark .ag-charts-format-top-level-group-item{margin:4px 0}.ag-theme-dark .ag-charts-format-sub-level-group-container{padding:6px 6px 2px}.ag-theme-dark .ag-charts-format-sub-level-group-container>*{margin-bottom:4px}.ag-theme-dark .ag-charts-group-container.ag-group-container-horizontal{padding:4px}.ag-theme-dark .ag-chart-data-section,.ag-theme-dark .ag-chart-format-section{display:flex;margin:0}.ag-theme-dark .ag-chart-menu-panel{background-color:#302e2e;background-color:var(--ag-control-panel-background-color,#302e2e)}.ag-theme-dark .ag-ltr .ag-chart-menu-panel{border-left:1px solid #a9a9a9;border-left-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-rtl .ag-chart-menu-panel{border-right:1px solid #a9a9a9;border-right-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-date-time-list-page-title{flex-grow:1;text-align:center}.ag-theme-dark .ag-date-time-list-page-column-label,.ag-theme-dark .ag-date-time-list-page-entry{text-align:center}.ag-theme-dark .ag-checkbox-input-wrapper{font-family:agGridClassic;font-size:12px;line-height:12px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:12px;height:12px;background-color:var(--ag-checkbox-background-color);border-radius:0;display:inline-block;vertical-align:middle;flex:none}.ag-theme-dark .ag-checkbox-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-dark .ag-checkbox-input-wrapper:active,.ag-theme-dark .ag-checkbox-input-wrapper:focus-within{outline:none}.ag-theme-dark .ag-checkbox-input-wrapper.ag-disabled{opacity:.5}.ag-theme-dark .ag-checkbox-input-wrapper:after{content:"\\f108";color:#ccc;color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#ccc));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-dark .ag-checkbox-input-wrapper.ag-checked:after{content:"\\f106";color:#ccc;color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#ccc));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-dark .ag-checkbox-input-wrapper.ag-indeterminate:after{content:"\\f107";color:#ccc;color:var(--ag-checkbox-indeterminate-color,var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#ccc)));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-dark .ag-toggle-button-input-wrapper{box-sizing:border-box;width:24px;height:12px;background-color:#ccc;background-color:var(--ag-toggle-button-off-background-color,var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#ccc)));border-radius:6px;position:relative;flex:none;border:1px solid #ccc;border-color:var(--ag-toggle-button-off-border-color,var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#ccc)))}.ag-theme-dark .ag-toggle-button-input-wrapper input{opacity:0;height:100%;width:100%}.ag-theme-dark .ag-toggle-button-input-wrapper:focus-within{outline:none}.ag-theme-dark .ag-toggle-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-dark .ag-toggle-button-input-wrapper.ag-checked{background-color:#ccc;background-color:var(--ag-toggle-button-on-background-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#ccc)));border-color:#ccc;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#ccc)))}.ag-theme-dark .ag-toggle-button-input-wrapper:before{content:" ";position:absolute;top:-1px;left:-1px;display:block;box-sizing:border-box;height:12px;width:12px;background-color:#302e2e;background-color:var(--ag-toggle-button-switch-background-color,var(--ag-background-color,#302e2e));border-radius:6px;transition:left .1s;border:1px solid #ccc;border-color:var(--ag-toggle-button-switch-border-color,var(--ag-toggle-button-off-border-color,var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#ccc))))}.ag-theme-dark .ag-toggle-button-input-wrapper.ag-checked:before{left:calc(100% - 12px);border-color:#ccc;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#ccc)))}.ag-theme-dark .ag-radio-button-input-wrapper{font-family:agGridClassic;font-size:12px;line-height:12px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:12px;height:12px;background-color:var(--ag-checkbox-background-color);border-radius:0;display:inline-block;vertical-align:middle;flex:none;border-radius:12px}.ag-theme-dark .ag-radio-button-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-dark .ag-radio-button-input-wrapper:active,.ag-theme-dark .ag-radio-button-input-wrapper:focus-within{outline:none}.ag-theme-dark .ag-radio-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-dark .ag-radio-button-input-wrapper:after{content:"\\f124";color:#ccc;color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#ccc));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-dark .ag-radio-button-input-wrapper.ag-checked:after{content:"\\f125";color:#ccc;color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#ccc));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-dark input[class^=ag-][type=range]{-webkit-appearance:none;width:100%;height:100%;background:none;overflow:visible}.ag-theme-dark input[class^=ag-][type=range]::-webkit-slider-runnable-track{margin:0;padding:0;width:100%;height:3px;background-color:#a9a9a9;background-color:var(--ag-border-color,#a9a9a9);border-radius:0}.ag-theme-dark input[class^=ag-][type=range]::-moz-range-track{margin:0;padding:0;width:100%;height:3px;background-color:#a9a9a9;background-color:var(--ag-border-color,#a9a9a9);border-radius:0}.ag-theme-dark input[class^=ag-][type=range]::-ms-track{margin:0;padding:0;width:100%;height:3px;background-color:#a9a9a9;background-color:var(--ag-border-color,#a9a9a9);border-radius:0;color:transparent;width:calc(100% - 2px)}.ag-theme-dark input[class^=ag-][type=range]::-webkit-slider-thumb{margin:0;padding:0;-webkit-appearance:none;width:12px;height:12px;background-color:#302e2e;background-color:var(--ag-background-color,#302e2e);border:1px solid #ccc;border-color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#ccc));border-radius:12px;-webkit-transform:translateY(-4.5px);transform:translateY(-4.5px)}.ag-theme-dark input[class^=ag-][type=range]::-ms-thumb{margin:0;padding:0;-webkit-appearance:none;width:12px;height:12px;background-color:#302e2e;background-color:var(--ag-background-color,#302e2e);border:1px solid #ccc;border-color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#ccc));border-radius:12px}.ag-theme-dark input[class^=ag-][type=range]::-moz-ag-range-thumb{margin:0;padding:0;-webkit-appearance:none;width:12px;height:12px;background-color:#302e2e;background-color:var(--ag-background-color,#302e2e);border:1px solid #ccc;border-color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#ccc));border-radius:12px}.ag-theme-dark input[class^=ag-][type=range]:focus{outline:none}.ag-theme-dark input[class^=ag-][type=range]:focus::-webkit-slider-thumb{border-color:#ccc;border-color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark input[class^=ag-][type=range]:focus::-ms-thumb{border-color:#ccc;border-color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark input[class^=ag-][type=range]:focus::-moz-ag-range-thumb{border-color:#ccc;border-color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#ccc))}.ag-theme-dark input[class^=ag-][type=range]:active::-webkit-slider-runnable-track{background-color:var(--ag-input-focus-border-color)}.ag-theme-dark input[class^=ag-][type=range]:active::-moz-ag-range-track{background-color:var(--ag-input-focus-border-color)}.ag-theme-dark input[class^=ag-][type=range]:active::-ms-track{background-color:var(--ag-input-focus-border-color)}.ag-theme-dark input[class^=ag-][type=range]:disabled{opacity:.5}.ag-theme-dark .ag-icon{color:#d6d5d5}.ag-theme-dark .ag-icon-tree-closed:before{content:"\\f10b"}.ag-theme-dark .ag-icon-tree-open:before{content:"\\f10f"}.ag-theme-dark .ag-column-drop-cell,.ag-theme-dark .ag-header{background-image:none}.ag-theme-dark .ag-tab{border:1px solid transparent;padding:4px 8px;margin:4px 4px -1px}.ag-theme-dark .ag-tabs-body{margin:2px 0}.ag-theme-dark .ag-icon{margin:1px 1px 2px}.ag-theme-dark .ag-tab-selected{background-color:#302e2e;background-color:var(--ag-background-color,#302e2e);border-color:#a9a9a9;border-color:var(--ag-border-color,#a9a9a9);border-bottom-color:transparent}.ag-theme-dark .ag-tabs-header{background-color:#626262;background-color:var(--ag-header-background-color,#626262);border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-filter .ag-filter-apply-panel{justify-content:flex-start}.ag-theme-dark .ag-menu-option-active{background-color:#4a708b;background-color:var(--ag-selected-row-background-color,#4a708b)}.ag-theme-dark .ag-column-drop-cell{border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);border-radius:0}.ag-theme-dark .ag-column-drop-cell-button .ag-icon{border:1px solid transparent}.ag-theme-dark .ag-column-drop-cell-button:hover .ag-icon{border-color:#a9a9a9;border-color:var(--ag-border-color,#a9a9a9)}.ag-theme-dark .ag-panel-title-bar-button-icon{font-size:20px;line-height:20px}.ag-theme-dark .ag-menu-option-part{padding-top:4px;padding-bottom:4px}.ag-theme-dark .ag-column-drop-vertical-title-bar{margin-top:4px;margin-left:4px}.ag-theme-dark .ag-column-drop-vertical-title{margin-left:4px}.ag-theme-dark .ag-column-drop-vertical-empty-message{margin-left:24px}',""]),e.exports=t},function(e,t,o){var r=o(27),a=o(170);"string"==typeof(a=a.__esModule?a.default:a)&&(a=[[e.i,a,""]]);var n={insert:"head",singleton:!1};r(a,n);e.exports=a.locals||{}},function(e,t,o){(t=o(28)(!1)).push([e.i,'.ag-theme-fresh{-webkit-font-smoothing:antialiased;color:#000;color:var(--ag-foreground-color,#000);font-family:Helvetica Neue,sans-serif;font-size:14px;line-height:normal}@font-face{font-family:agGridClassic;src:url("data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABOsAAsAAAAAJiwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlIAAAReYchjok9TLzIAAANcAAAAQQAAAFZWVlJ+Y21hcAAAA6AAAAHtAAAFgHClDfdnbHlmAAAFkAAACi0AABQQq+8lqmhlYWQAAA/AAAAANAAAADZ2z8SBaGhlYQAAD/QAAAAeAAAAJAfTBChobXR4AAAQFAAAABoAAAEou4L/4mxvY2EAABAwAAAAbwAAAJb7HvWgbWF4cAAAEKAAAAAfAAAAIAFgAHhuYW1lAAAQwAAAATMAAAJS8kTiWnBvc3QAABH0AAABtgAAApcplp2DeJx9k0lyE0EQRX+rZSMPyGDMZMRkRpsh3O5BjSTLltzyQHjBggULNmYBAeFg5ROw5gAEB+AUnIBgyYoDcACCA/Ay1UbGC6tC1VWZP3/+yspSIGlSy+qqUmzuPld9f+/gveZV1fBn/qPrYP/tmz3VDnf4qv6tKQj/qK4FvdCBvgUKXgefK+NhJeyGu+GH8FP4QyGoG3oMekorjFgJc6RUmZrKVdE4tpj1E7VAh8xtt87qgsbcU2ig8+SMiRk445Ke6o7OwNN3np7WQKUM4+wxbzHuauYERK578GeoWcVqrA10ntWENtHYQ0eH6BbeGXzrZI6I6eProy10VNXruK2XRM762SwyK3Ep/1gbvo9894AqHKLa8DfhN75Fsh7am2RKiHgEewaqW9Zwif8U3hRMRGzHa2bR10AmKEx1nZWdLOFk07oN+zO98qwbZUzPqzg88yLqR/a+8+XkOWrtwLUF9iEaRla7kfvkirSDf5KbKvROH/VFX/VdP/VLv3UK6ypeO8Ea3OsnVqZG/Y6jC7ztf1Y76Th3fhz1P2KCcze9NjG+QVlByzaFTqtNyjrCmjp+Ep2GL1CTU68qOSLPm2AdY6yyj0GfLruxxZj2Og/oAeuAeWqxwmxMw37L2V+GyVZDXRe9Wi14LvltWU3tJdV9Zz1vtzxPna/wjThZ5vXZxnsVizGNLA2PylFtHMv4c9SOspmqBqoSeqDmnbXjr6Ag003OMVSS6Ja/gB3vqgUUZOWLnNM5V98pb2rOcbFHBWiOypeces2sk/tos67Y+gsvGGrHAAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMnxi4gDQjSA4A1QYKdAAAAHictdQHTltBFIXh3wXTTEnvvRc6hGp6XQbpiBREOsoqs5O7gZBzPScLIFJG+nw9o+c3b/R8LtAB1OSp1KFap0KO31qttNdr9LTX6/zSvEkXVX0fYo8DjmL0+FirQ+yyz2FU2rO/o6Krm1zlPs80W2GMJeZZZZItxmlpdZEF1phhmg0mmGOKdXaYZZlNtvX7qnav6xkbdGrfbj1Jr+7YRz8DDHKaM5zlHOe5wEUucZkr2u0a17nBTW5xmzvc5Z72f8BDHvGYJzrPkD6HNRvRAzY42Vg54fU5xpbmVye3xls67cLazLQOOje1vjO7vLn9Dzf7D6OZH7Wfnu2Qb7PI0+7amDy3JXlh8/LSVuWVTcpr25I3Ni5vrSV7lv+QfVuUd7Yg721NPtiMfLRpObANObQJ+WRz8tmm5Iuty1fLs3+zWfluy/LDNuXI9AKjUmRWolqQtVZktqJeZL6io8jcRaMga2dB1q6CrN0FWXuKzGP0FmRtFvkmo68ga39B1oGCrIMFWU8VyhJhShVhyhdhShphyhxhSh9hyiFhSiRhyiZhSilhyithSi5hyjBhSjNhyjVhSjhhyjphSj1hyj9h6gSEqScQpu5AmPoEYeoRhKl3EKb+QVj2zbDMTFj7muGCrCNF+56jBSN/AHzNoH4AAAB4nO1Ye2xT1xm/37nEN87D8bUdXwezwLWJDZQCtmNfO4FATIgdQhLWGwhrt0DSGJHHpgaawFRatBIVVrXbHxXTWCiPabMHo9MgSH1IGxJMa6b+sbBJFZVK2/HHVNjI6JZ2k8W97DvHjzyggPrntBufe17fPec73/md3/edcMDhw4f4fs7IcSBLglwuW3mZD+mj+/ZBQtv//vtkhPxuYiIFe2EvijD5T/lPuUVYCQpeRRK8oswyRRZZJokyywQZLrXFxscbNwPf1oh5m65txjzWpuu0PdYGhF9k/LIuWm/czOXm3Mq/whViRfAaMYlu+NkbCeiG7sTZU2TPGz3QrR/vOavdzMmTSTLJFTN51AW1QX3IZOOFsdiFC7GxC41jUJ8rjTVe4Ao47q6O67rBWTk35+Ue41ZyXIHsWgFBsboOArK/EspFmwl42WXAgh1bQtjlgYDorgqUu3nM+T7N5qpx4Y/83VUjyzWyZjY7HGZyW5Qk7ReqCi2qmmpvJ66Ii3yGL/xpZfjifySJmig6HCL5hyjpY/q1ZBJO6jtw2Vm9bjK9luJ6coq4p5UrmKOTALheK9/HdHDldbo1Q5teffLf1aev8zdyKuRU2jJTk3f0ot/XH4YTc/XwPpoevByUH6jFX/Tz0PoQHfTSJN3OWfM/2uwPmvkhk9L14qL38T2IjELOwXEIOskIvLIQDAL+ldvsOEu11+Mlf9O31zyta1A3Pv7ur4uLK8rsvg0+e1kFXIJTtdihX4Y14+N1paWVTk+Fy+dzVVQtqKTDG9gcR/gjOJuAWC3DtUkcV1WOZsPEz8nhlH6ej+rnk7OydAofaEniA620zGV1v5HF8spHsxYghsvdQXcwEAzw/RmLadaMBcmkZmaWoZbT30uxJ2NBS9aCk1kLWlFCJLdw2y5QlVJMFfaK8lG2ShH1CYhy0I0sIYsyH5TFQJCMJvWSJEyp+hi0pPQxlYyyehrrp7AxzeV54Hn+eXqujYDbIRgB2UCBKbAM65PspU8OgwVfpG9WFSxYncElhxmXiAFkLDrAz0+eTejH9eMJ+C4xaVNYOQFdCe6r4p7u2oPQ9wO95GGoH0smp233Lq9wFZyPW43zK1IoYJfskgkBicwGobUQdLsQk17rCuI1CJUg2RXJgMikfyEUUFgJ5UGu9qyNHnpucNvSb9cF6xeZ9D+taPYW1T0WfvzAX0PfXF3UUO17pVX9uv9bT3ZtrYus9D85BFc3N5os9kq5uHY5b1qyyjLvieaDa3Z5GgJLiuFAEQG1wGBy6tcM4W1Bf7zhabujeN2CImN1VZ1/40ub9KO+TqskLZwfaHf+b65FQjwv4UK4FroORg1ZXUNYpm12Jac0QcB4qzxrwE3lJBRR4A5dQdvw/hd/uJ8q+Y0933umoXpdZ/euZ3Zs3ciULWnctbc3VgQboagtFAtVLQl5VvPlvNr84nBLW0nJRs8af/NI85Yz/vg2JWwwKP4eq2RfVBF+qjrUWcOXLlgGhcXzm22FAuEyPMo4px95DT2+VQbRG/SVB4Iq45Qk34/eZ3sq3d6elSV30I/yLDoQ3SI6Fq8gwVqVmC9fDqfTZFIvgSm94dIlrFDxkuxZvziL05zcwmmvqiDT5BI8pCwjH6WSyTT7ISN8WQlOJpMTSUaCJ+/NUKWC7Lovcl/jZK4KPenjlIcYsSLvZSk2n0R3UAZ3Ofr0TKrCBKeQYdFGyLY0p0zF8h3t0JqdjqnD96tovqSaxiytklhas6hwqh15TFXn2rTKLQaARicCuaOq2m1m1PQMi2b46iS/lfGVhIRHQzTYebpHPw7dPWdIDZw8nYmDzlCyJXe/uPsF/y/+n1w1159BpaGMuiwvYs+j4AEL+RkqsdUElQQb6sCDnUGfhxaxC6segXVTOSlgpx95q70+KsbkK0muuxL82KmEvB7yQsRmWxIeibQ2b2rZbcMnEi+qsAARyTxDhdNmCTY1OQ8usFidRgepWFpoL7JbwBpp2dTcGhkJL0FxSzkU2QuXOUhpsdFptToPOpuaghabs8IwjzcTsFQUxSN0XJyptfkozkQru9kAcaPZFPQXWgzznfGmkM3qHHHG406jaHY5lhYSg5nOxFQaCR9FcUuZQAqXOlxmo1BEBUecVluoKe6cb7AU+oMmszHOVjHzvBxBFC9kjCUgLJGs0FciYyE8cfPQYwaUoNctlJPY0eGjV6/iK5kv/Pjl7u6Xu8lvZjXSgvZWN+3i5s2KPZchNz5a5CmwoBYU5E5JeXDseevjmG80fAyuxT7xvR5+/SEBqFYX+2jVMRR//pOYD/O8H5qOVViUAtnEH7nzWz6aSelMNEJjEfrJV12bwsJ2XCIlnAev7bmPYquOKaNQHfuYKv2wtaWza3sNTXJMOZa/L7yKZ7KA7jA9jfAUO4ngzxFb5hw6+T9zpdN3EBY7SDDamwAveBO9vQn9A/2DRC8514ctWOrTX+rDNuzry8YSd1ksYeMWcwEaS9ATZqZOYxF1EWb0CKECemYDflqk8eVKehyZTzSU0+MIU4efHYxu2BAdfFb/bGgw2tAQHRyCCe3NUH00Nti1XYlI0rJ4qH49VjrDEcAafxOlh/TbQ7up9O4hMON3Gz7X3lwmSRGls3swFl0XaspUugbj0fpQDvdR9BMCcjiL2DBMC0iUKTFyo6y2M51Mqfp5FaZ4h5Ygo2qK8l/eVjTewxq4RckteN0KpVQy2Xkurarpc50wha5jvDed7oWwmuHnPE5k9Khhbu39kUIDBAaVWvRHwQKMIBExfOYeyg4mPaFWSuL0BjAHN9p3DlDcHEjx67R3SKUo/adk9eBgbcnFklqaDUxo10mjdA+CyO1kBkIkhiT9tkOE1ZkPMt+VkljyBbwzzMYR85Tk1Tk4IjMwQG9zbGPNFAaL6I6bKQwEBgsb7XHRejXtgalD+d0uyyHgMNvwiLK96zpuNj6dXfff7C10a693d1Lhzm4UViKz8biUxTD3w6PEVGQ+g4GS3nk8VtwJ3BvcGdyX+0LyUAZ+VKXrOSW/v37P4T3r2euR1dR3NGQ/Wb8nj60TWX/oVfACoMhBcvCXCejSTyROa38gsTOZUP50Ks/fA4jjUs5OYxh07XmeKcj+uyKAAH5L9blI3OXTxwZqJiZqBtrRCX8Ii/UP6Y0NFi8YqJ2YqB2A16bxTUbp6BhBpchP9DG8sJzPc8koYp/QO4pIYwS8nrRoO+f2kUz4wNdjwDU2Z0wj0CCjJSOR7UvyMYorI0HG4ZPaFf294YvwNrmiXYHgEJam9YrTnaVHABXTdiI4aXM+LnBzMa4D+dtumxsXLATalo0KQn6Jt/vz3t5gw96sr6dfCKxNAooH8LgyFbufPCEIHTNCgA7BKrQaDNvQn1MH2yHYBBemDuqm0cVvMxhaUaJjhivvEATiWG4y3fmpyWPCnO80ef54r0zL7FHgV7MnablXjTufL8cRcTgc1VuKw//fJvfa5L+BscYKAAAAeJxjYGRgYABi/jvPp8Xz23xl4GZ+ARSI4ny8rwFG///2/xvzZ+ZPQJUcDExAkgEAoUMP6XicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AIAnloHAgAAeJxjYGBgYH5Ba/z/G+3M/f+NgQ4AAPv8MfAAAHicY2AAAgmGIIYshhaGC4wijCGMPYz7GF8xGTGFMVUwTWC6wGzGPIf5BwsfiwZLCcsOlgssL1gnsB5iE2EzYGtim8K2jZ2HXYvdhX0Z+w72fxwRHAUcszhWcGzjOMJxieMZxxfOOi4O0iEAtgsblgB4nGNgZGBg8GLIYeBhAAEmIOYCQgaG/2A+AwAbuAHZAHicfZC9TsMwFIVP+odoBaoEYmAyCwtS+rPRtVKzd+ieJnaaKo2D41bqznPwBDxHn4OnYObEeCkStSXnu9899w4BMMQJAZoT4Ma9zWnhitUvt0n3njvkJ89dDBB67tG/eu7jBQvPA9zhjRuCzjXNI949t3CLD89t+k/PHfLJcxcP+PLco//23McqGHoe4DlQcRaZPJ0XcV3nyVJm+yI2Z+6sWElT57oUk3B85iNZShNbmYr1UdSHbGqtEsronVjo0sqi0KIyeisTG26srWajkfI+TPQOMTJEMMiRYo6Cdc2bI8ESkr29c+ZC7v/OihuMY40SAhP+9/GFfMR86WZiWH5Tzqxx5FvjwKkprYVirZjR2JEWbneTLng1TeV6W5qEPsTGTVWYYcSr/uRDprjpB8WrbRMAeJxtkmdv2zAURX1iyVbstEnTNt17D7VN994z/RUMRctEJFIgKY/8+rJxGiBA36dzHx7uu3xgZ6mzqEHn/7XFEl0SUnr0yVhmwJAVjnCUVdY4xjrHOcFJNjjFac5wlnOc5wIXucRlrnCVa1znBje5xW3ucJd73CfnAQ95xCaPecJTnvGcF7zkFa95w1ve8Z4PfOQTn/nCV77xnR/85Bdb/O4MRVk6VYqgrekJ5+zUd4WXPSmMVFUqx8KFNTlWcmfbzvI9UMXGQUObQgXlam1EUOsH7dbsT65IW1mXNzoK14+irY0fSGuCEzKoIpG2mafSWe+TQnmZqVkjomexrOYq95Xw4+EB5ZvdyL2RruLKdKSdD0npdJOWzrZNEkdCUqlR6FXaxN39yopCmzKrxUzXelcltTJtFrMulFGzkBhr1NDYkIuqslNVpE10Ud1Gm7TRExuyxqmJtq1fc9HM5tttCNbkdjRaPdwwqdPlOCReTNTA19EuL+zU7OPfWMMF7o1lC46pQzzNenBKHb5l1prFKwb/IN9EUOJQBDQWwxSPpGLMDtvM4lcoqGlpmDNil0mn8wcxorJdAAA=") format("woff");font-weight:400;font-style:normal}.ag-theme-fresh .ag-icon{font-family:agGridClassic;font-size:12px;line-height:12px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ag-theme-fresh .ag-icon-aggregation:before{content:"\\f101"}.ag-theme-fresh .ag-icon-arrows:before{content:"\\f102"}.ag-theme-fresh .ag-icon-asc:before{content:"\\f103"}.ag-theme-fresh .ag-icon-cancel:before{content:"\\f104"}.ag-theme-fresh .ag-icon-chart:before{content:"\\f105"}.ag-theme-fresh .ag-icon-color-picker:before{content:"\\f109"}.ag-theme-fresh .ag-icon-columns:before{content:"\\f10a"}.ag-theme-fresh .ag-icon-contracted:before{content:"\\f10b"}.ag-theme-fresh .ag-icon-copy:before{content:"\\f10c"}.ag-theme-fresh .ag-icon-cross:before{content:"\\f10d"}.ag-theme-fresh .ag-icon-desc:before{content:"\\f10e"}.ag-theme-fresh .ag-icon-expanded:before{content:"\\f10f"}.ag-theme-fresh .ag-icon-eye-slash:before{content:"\\f110"}.ag-theme-fresh .ag-icon-eye:before{content:"\\f111"}.ag-theme-fresh .ag-icon-filter:before{content:"\\f112"}.ag-theme-fresh .ag-icon-first:before{content:"\\f113"}.ag-theme-fresh .ag-icon-grip:before{content:"\\f114"}.ag-theme-fresh .ag-icon-group:before{content:"\\f115"}.ag-theme-fresh .ag-icon-last:before{content:"\\f116"}.ag-theme-fresh .ag-icon-left:before{content:"\\f117"}.ag-theme-fresh .ag-icon-linked:before{content:"\\f118"}.ag-theme-fresh .ag-icon-loading:before{content:"\\f119"}.ag-theme-fresh .ag-icon-maximize:before{content:"\\f11a"}.ag-theme-fresh .ag-icon-menu:before{content:"\\f11b"}.ag-theme-fresh .ag-icon-minimize:before{content:"\\f11c"}.ag-theme-fresh .ag-icon-next:before{content:"\\f11d"}.ag-theme-fresh .ag-icon-none:before{content:"\\f11e"}.ag-theme-fresh .ag-icon-not-allowed:before{content:"\\f11f"}.ag-theme-fresh .ag-icon-paste:before{content:"\\f120"}.ag-theme-fresh .ag-icon-pin:before{content:"\\f121"}.ag-theme-fresh .ag-icon-pivot:before{content:"\\f122"}.ag-theme-fresh .ag-icon-previous:before{content:"\\f123"}.ag-theme-fresh .ag-icon-right:before{content:"\\f126"}.ag-theme-fresh .ag-icon-save:before{content:"\\f127"}.ag-theme-fresh .ag-icon-small-down:before{content:"\\f128"}.ag-theme-fresh .ag-icon-small-left:before{content:"\\f129"}.ag-theme-fresh .ag-icon-small-right:before{content:"\\f12a"}.ag-theme-fresh .ag-icon-small-up:before{content:"\\f12b"}.ag-theme-fresh .ag-icon-tick:before{content:"\\f12c"}.ag-theme-fresh .ag-icon-tree-closed:before{content:"\\f12d"}.ag-theme-fresh .ag-icon-tree-indeterminate:before{content:"\\f12e"}.ag-theme-fresh .ag-icon-tree-open:before{content:"\\f12f"}.ag-theme-fresh .ag-icon-unlinked:before{content:"\\f130"}.ag-theme-fresh .ag-icon-row-drag:before{content:"\\f114"}.ag-theme-fresh .ag-right-arrow:before{content:"\\f117";content:"\\f126"}.ag-theme-fresh .ag-root-wrapper{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-fresh [class^=ag-],.ag-theme-fresh [class^=ag-]:after,.ag-theme-fresh [class^=ag-]:before,.ag-theme-fresh [class^=ag-]:focus{box-sizing:border-box;outline:none}.ag-theme-fresh [class^=ag-]::-ms-clear{display:none}.ag-theme-fresh .ag-checkbox .ag-input-wrapper,.ag-theme-fresh .ag-radio-button .ag-input-wrapper{overflow:visible}.ag-theme-fresh .ag-range-field .ag-input-wrapper{height:100%}.ag-theme-fresh .ag-toggle-button{flex:none;width:unset;min-width:unset}.ag-theme-fresh .ag-ltr .ag-label-align-right .ag-label{margin-left:4px}.ag-theme-fresh .ag-rtl .ag-label-align-right .ag-label{margin-right:4px}.ag-theme-fresh input[class^=ag-]{margin:0}.ag-theme-fresh input[class^=ag-],.ag-theme-fresh select[class^=ag-],.ag-theme-fresh textarea[class^=ag-]{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-fresh input[class^=ag-]:not([type]),.ag-theme-fresh input[class^=ag-][type=date],.ag-theme-fresh input[class^=ag-][type=datetime-local],.ag-theme-fresh input[class^=ag-][type=number],.ag-theme-fresh input[class^=ag-][type=tel],.ag-theme-fresh input[class^=ag-][type=text],.ag-theme-fresh textarea[class^=ag-]{font-size:inherit;line-height:inherit;color:inherit;border:1px solid #000;border-color:var(--ag-input-border-color,#000)}.ag-theme-fresh input[class^=ag-]:not([type]):disabled,.ag-theme-fresh input[class^=ag-][type=date]:disabled,.ag-theme-fresh input[class^=ag-][type=datetime-local]:disabled,.ag-theme-fresh input[class^=ag-][type=number]:disabled,.ag-theme-fresh input[class^=ag-][type=tel]:disabled,.ag-theme-fresh input[class^=ag-][type=text]:disabled,.ag-theme-fresh textarea[class^=ag-]:disabled{color:rgba(0,0,0,.5);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.5));background-color:#ebebeb;background-color:var(--ag-input-disabled-background-color,#ebebeb);border-color:rgba(0,0,0,.3);border-color:var(--ag-input-disabled-border-color,rgba(0,0,0,.3))}.ag-theme-fresh input[class^=ag-]:not([type]):focus,.ag-theme-fresh input[class^=ag-][type=date]:focus,.ag-theme-fresh input[class^=ag-][type=datetime-local]:focus,.ag-theme-fresh input[class^=ag-][type=number]:focus,.ag-theme-fresh input[class^=ag-][type=tel]:focus,.ag-theme-fresh input[class^=ag-][type=text]:focus,.ag-theme-fresh textarea[class^=ag-]:focus{outline:none;border-color:var(--ag-input-focus-border-color)}.ag-theme-fresh input[class^=ag-][type=number]{-moz-appearance:textfield}.ag-theme-fresh input[class^=ag-][type=number]::-webkit-inner-spin-button,.ag-theme-fresh input[class^=ag-][type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.ag-theme-fresh input[class^=ag-][type=range]{padding:0}.ag-theme-fresh .ag-drag-handle{color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-list-item,.ag-theme-fresh .ag-virtual-list-item{height:20px}.ag-theme-fresh .ag-keyboard-focus .ag-virtual-list-item:focus{outline:none}.ag-theme-fresh .ag-keyboard-focus .ag-virtual-list-item:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-fresh .ag-select-list{background-color:#fff;background-color:var(--ag-background-color,#fff);overflow-y:auto;overflow-x:hidden}.ag-theme-fresh .ag-list-item{display:flex;align-items:center}.ag-theme-fresh .ag-list-item.ag-active-item{background-color:var(--ag-row-hover-color)}.ag-theme-fresh .ag-select-list-item{padding-left:4px;padding-right:4px;cursor:default;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.ag-theme-fresh .ag-select-list-item span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.ag-theme-fresh .ag-select .ag-picker-field-wrapper{background-color:#fff;background-color:var(--ag-background-color,#fff);min-height:20px;cursor:default}.ag-theme-fresh .ag-select:not(.ag-cell-editor){height:20px}.ag-theme-fresh .ag-select .ag-picker-field-display{margin:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ag-theme-fresh .ag-select .ag-picker-field-icon{display:flex;align-items:center}.ag-theme-fresh .ag-select.ag-disabled{opacity:.5}.ag-theme-fresh .ag-rich-select{background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6)}.ag-theme-fresh .ag-rich-select-list{width:100%;min-width:200px;height:162.5px}.ag-theme-fresh .ag-rich-select-value{padding:0 4px 0 12px;height:25px;border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9))}.ag-theme-fresh .ag-rich-select-virtual-list-item{cursor:default;height:20px}.ag-theme-fresh .ag-rich-select-virtual-list-item:hover{background-color:var(--ag-row-hover-color)}.ag-theme-fresh .ag-rich-select-row{padding-left:12px}.ag-theme-fresh .ag-rich-select-row-selected{background-color:#bde2e5;background-color:var(--ag-selected-row-background-color,#bde2e5)}.ag-theme-fresh .ag-group-contracted,.ag-theme-fresh .ag-group-expanded,.ag-theme-fresh .ag-row-drag,.ag-theme-fresh .ag-selection-checkbox{color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-ltr .ag-group-contracted,.ag-theme-fresh .ag-ltr .ag-group-expanded,.ag-theme-fresh .ag-ltr .ag-row-drag,.ag-theme-fresh .ag-ltr .ag-selection-checkbox{margin-right:12px}.ag-theme-fresh .ag-rtl .ag-group-contracted,.ag-theme-fresh .ag-rtl .ag-group-expanded,.ag-theme-fresh .ag-rtl .ag-row-drag,.ag-theme-fresh .ag-rtl .ag-selection-checkbox{margin-left:12px}.ag-theme-fresh .ag-cell-wrapper>:not(.ag-cell-value):not(.ag-group-value){height:23px;display:flex;align-items:center;flex:none}.ag-theme-fresh .ag-group-contracted,.ag-theme-fresh .ag-group-expanded{cursor:pointer}.ag-theme-fresh .ag-group-title-bar-icon{cursor:pointer;flex:none;color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-ltr .ag-group-child-count{margin-left:2px}.ag-theme-fresh .ag-rtl .ag-group-child-count{margin-right:2px}.ag-theme-fresh .ag-group-title-bar{background-color:#ececec;background-color:var(--ag-subheader-background-color,#ececec);padding:4px}.ag-theme-fresh .ag-group-toolbar{padding:4px}.ag-theme-fresh .ag-disabled-group-container,.ag-theme-fresh .ag-disabled-group-title-bar{opacity:.5}.ag-theme-fresh .group-item{margin:2px 0}.ag-theme-fresh .ag-label{white-space:nowrap}.ag-theme-fresh .ag-ltr .ag-label{margin-right:4px}.ag-theme-fresh .ag-rtl .ag-label{margin-left:4px}.ag-theme-fresh .ag-label-align-top .ag-label{margin-bottom:2px}.ag-theme-fresh .ag-ltr .ag-angle-select-field,.ag-theme-fresh .ag-ltr .ag-slider-field{margin-right:8px}.ag-theme-fresh .ag-rtl .ag-angle-select-field,.ag-theme-fresh .ag-rtl .ag-slider-field{margin-left:8px}.ag-theme-fresh .ag-angle-select-parent-circle{width:24px;height:24px;border-radius:12px;border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-fresh .ag-angle-select-child-circle{top:4px;left:12px;width:6px;height:6px;margin-left:-3px;margin-top:-4px;border-radius:3px;background-color:#000;background-color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-picker-field-wrapper{border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);border-radius:5px}.ag-theme-fresh .ag-picker-field-button{background-color:#fff;background-color:var(--ag-background-color,#fff);color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-dialog.ag-color-dialog{border-radius:5px}.ag-theme-fresh .ag-color-picker .ag-picker-field-display{height:12px}.ag-theme-fresh .ag-color-panel{padding:4px}.ag-theme-fresh .ag-spectrum-color{background-color:red;border-radius:2px}.ag-theme-fresh .ag-spectrum-tools{padding:10px}.ag-theme-fresh .ag-spectrum-sat{background-image:linear-gradient(90deg,#fff,rgba(204,154,129,0))}.ag-theme-fresh .ag-spectrum-val{background-image:linear-gradient(0deg,#000,rgba(204,154,129,0))}.ag-theme-fresh .ag-spectrum-dragger{border-radius:12px;height:12px;width:12px;border:1px solid #fff;background:#000;box-shadow:0 0 2px 0 rgba(0,0,0,.24)}.ag-theme-fresh .ag-spectrum-alpha-background,.ag-theme-fresh .ag-spectrum-hue-background{border-radius:2px}.ag-theme-fresh .ag-spectrum-tool{margin-bottom:10px;height:11px;border-radius:2px}.ag-theme-fresh .ag-spectrum-slider{margin-top:-12px;width:13px;height:13px;border-radius:13px;background-color:#f8f8f8;box-shadow:0 1px 4px 0 rgba(0,0,0,.37)}.ag-theme-fresh .ag-recent-color{margin:0 3px}.ag-theme-fresh .ag-recent-color:first-child{margin-left:0}.ag-theme-fresh .ag-recent-color:last-child{margin-right:0}.ag-theme-fresh.ag-dnd-ghost{background:#fff;background:var(--ag-background-color,#fff);border-radius:0;box-shadow:none;overflow:hidden;text-overflow:ellipsis;z-index:10;border:1px solid #a9a9a9;border:1px solid var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9));color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000));height:25px!important;line-height:25px;margin:0;padding:0 8px;-webkit-transform:translateY(8px);transform:translateY(8px)}.ag-theme-fresh .ag-dnd-ghost-icon{margin-right:4px;color:#000;color:var(--ag-foreground-color,#000)}.ag-theme-fresh .ag-popup-child:not(.ag-tooltip-custom){box-shadow:5px 5px 10px rgba(0,0,0,.3)}.ag-dragging-fill-handle .ag-theme-fresh .ag-dialog,.ag-dragging-range-handle .ag-theme-fresh .ag-dialog{opacity:.7;pointer-events:none}.ag-theme-fresh .ag-dialog{border-radius:0;border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-panel{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-fresh .ag-panel-title-bar{background-color:var(--ag-header-background-color);color:#000;color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000)));height:25px;padding:4px 12px;border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-ltr .ag-panel-title-bar-button{margin-left:4px}.ag-theme-fresh .ag-rtl .ag-panel-title-bar-button{margin-right:4px}.ag-theme-fresh .ag-tooltip{background-color:var(--ag-header-background-color);color:#000;color:var(--ag-foreground-color,#000);padding:4px;border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);border-radius:0;transition:opacity 1s}.ag-theme-fresh .ag-tooltip.ag-tooltip-hiding{opacity:0}.ag-theme-fresh .ag-ltr .ag-column-select-indent-1{padding-left:16px}.ag-theme-fresh .ag-rtl .ag-column-select-indent-1{padding-right:16px}.ag-theme-fresh .ag-ltr .ag-column-select-indent-2{padding-left:32px}.ag-theme-fresh .ag-rtl .ag-column-select-indent-2{padding-right:32px}.ag-theme-fresh .ag-ltr .ag-column-select-indent-3{padding-left:48px}.ag-theme-fresh .ag-rtl .ag-column-select-indent-3{padding-right:48px}.ag-theme-fresh .ag-ltr .ag-column-select-indent-4{padding-left:64px}.ag-theme-fresh .ag-rtl .ag-column-select-indent-4{padding-right:64px}.ag-theme-fresh .ag-ltr .ag-column-select-indent-5{padding-left:80px}.ag-theme-fresh .ag-rtl .ag-column-select-indent-5{padding-right:80px}.ag-theme-fresh .ag-ltr .ag-column-select-indent-6{padding-left:96px}.ag-theme-fresh .ag-rtl .ag-column-select-indent-6{padding-right:96px}.ag-theme-fresh .ag-ltr .ag-column-select-indent-7{padding-left:112px}.ag-theme-fresh .ag-rtl .ag-column-select-indent-7{padding-right:112px}.ag-theme-fresh .ag-ltr .ag-column-select-indent-8{padding-left:128px}.ag-theme-fresh .ag-rtl .ag-column-select-indent-8{padding-right:128px}.ag-theme-fresh .ag-ltr .ag-column-select-indent-9{padding-left:144px}.ag-theme-fresh .ag-rtl .ag-column-select-indent-9{padding-right:144px}.ag-theme-fresh .ag-column-select-header-icon{cursor:pointer}.ag-theme-fresh .ag-keyboard-focus .ag-column-select-header-icon:focus{outline:none}.ag-theme-fresh .ag-keyboard-focus .ag-column-select-header-icon:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:0;left:0;display:block;width:100%;height:100%;border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-fresh .ag-ltr .ag-column-group-icons:not(:last-child),.ag-theme-fresh .ag-ltr .ag-column-select-checkbox:not(:last-child),.ag-theme-fresh .ag-ltr .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-fresh .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-fresh .ag-ltr .ag-column-select-column-label:not(:last-child),.ag-theme-fresh .ag-ltr .ag-column-select-header-checkbox:not(:last-child),.ag-theme-fresh .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-fresh .ag-ltr .ag-column-select-header-icon:not(:last-child){margin-right:6px}.ag-theme-fresh .ag-rtl .ag-column-group-icons:not(:last-child),.ag-theme-fresh .ag-rtl .ag-column-select-checkbox:not(:last-child),.ag-theme-fresh .ag-rtl .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-fresh .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-fresh .ag-rtl .ag-column-select-column-label:not(:last-child),.ag-theme-fresh .ag-rtl .ag-column-select-header-checkbox:not(:last-child),.ag-theme-fresh .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-fresh .ag-rtl .ag-column-select-header-icon:not(:last-child){margin-left:6px}.ag-theme-fresh .ag-keyboard-focus .ag-column-select-column-group:focus{outline:none}.ag-theme-fresh .ag-keyboard-focus .ag-column-select-column-group:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-2px;left:-2px;display:block;width:calc(100% - -4px);height:calc(100% - -4px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-fresh .ag-keyboard-focus .ag-column-select-column:focus{outline:none}.ag-theme-fresh .ag-keyboard-focus .ag-column-select-column:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-2px;left:-2px;display:block;width:calc(100% - -4px);height:calc(100% - -4px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-fresh .ag-column-select-column-group:not(:last-child),.ag-theme-fresh .ag-column-select-column:not(:last-child){margin-bottom:4px}.ag-theme-fresh .ag-column-select-column-group-readonly,.ag-theme-fresh .ag-column-select-column-readonly{color:rgba(0,0,0,.5);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.5));pointer-events:none}.ag-theme-fresh .ag-ltr .ag-column-select-add-group-indent{margin-left:20px}.ag-theme-fresh .ag-rtl .ag-column-select-add-group-indent{margin-right:20px}.ag-theme-fresh .ag-column-select-list{padding:6px}.ag-theme-fresh .ag-rtl{text-align:right}.ag-theme-fresh .ag-root-wrapper{border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);border-radius:0}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-left:36px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-right:36px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-1{padding-left:24px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-1{padding-right:24px}.ag-theme-fresh .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-left:60px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-right:60px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-2{padding-left:48px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-2{padding-right:48px}.ag-theme-fresh .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-left:84px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-right:84px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-3{padding-left:72px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-3{padding-right:72px}.ag-theme-fresh .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-left:108px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-right:108px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-4{padding-left:96px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-4{padding-right:96px}.ag-theme-fresh .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-left:132px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-right:132px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-5{padding-left:120px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-5{padding-right:120px}.ag-theme-fresh .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-left:156px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-right:156px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-6{padding-left:144px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-6{padding-right:144px}.ag-theme-fresh .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-left:180px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-right:180px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-7{padding-left:168px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-7{padding-right:168px}.ag-theme-fresh .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-left:204px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-right:204px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-8{padding-left:192px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-8{padding-right:192px}.ag-theme-fresh .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-left:228px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-right:228px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-9{padding-left:216px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-9{padding-right:216px}.ag-theme-fresh .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-left:252px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-right:252px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-10{padding-left:240px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-10{padding-right:240px}.ag-theme-fresh .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-left:276px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-right:276px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-11{padding-left:264px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-11{padding-right:264px}.ag-theme-fresh .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-left:300px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-right:300px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-12{padding-left:288px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-12{padding-right:288px}.ag-theme-fresh .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-left:324px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-right:324px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-13{padding-left:312px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-13{padding-right:312px}.ag-theme-fresh .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-left:348px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-right:348px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-14{padding-left:336px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-14{padding-right:336px}.ag-theme-fresh .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-left:372px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-right:372px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-15{padding-left:360px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-15{padding-right:360px}.ag-theme-fresh .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-left:396px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-right:396px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-16{padding-left:384px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-16{padding-right:384px}.ag-theme-fresh .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-left:420px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-right:420px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-17{padding-left:408px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-17{padding-right:408px}.ag-theme-fresh .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-left:444px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-right:444px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-18{padding-left:432px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-18{padding-right:432px}.ag-theme-fresh .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-left:468px}.ag-theme-fresh .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-right:468px}.ag-theme-fresh .ag-ltr .ag-row-group-indent-19{padding-left:456px}.ag-theme-fresh .ag-rtl .ag-row-group-indent-19{padding-right:456px}.ag-theme-fresh .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent{margin-left:24px}.ag-theme-fresh .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent{margin-right:24px}.ag-theme-fresh .ag-cell{-webkit-font-smoothing:subpixel-antialiased}.ag-theme-fresh .ag-value-change-delta{padding-right:2px}.ag-theme-fresh .ag-value-change-delta-up{color:#006400;color:var(--ag-value-change-delta-up-color,#006400)}.ag-theme-fresh .ag-value-change-delta-down{color:#8b0000;color:var(--ag-value-change-delta-down-color,#8b0000)}.ag-theme-fresh .ag-value-change-value{background-color:transparent;border-radius:1px;padding-left:1px;padding-right:1px;transition:background-color 1s}.ag-theme-fresh .ag-value-change-value-highlight{background-color:#cec;background-color:var(--ag-value-change-value-highlight-background-color,#cec);transition:background-color .1s}.ag-theme-fresh .ag-cell-data-changed{background-color:#cec!important;background-color:var(--ag-value-change-value-highlight-background-color,#cec)!important}.ag-theme-fresh .ag-cell-data-changed-animation{background-color:transparent}.ag-theme-fresh .ag-cell-highlight{background-color:rgba(136,255,136,.4)!important;background-color:var(--ag-range-selection-highlight-color,rgba(136,255,136,.4))!important}.ag-theme-fresh .ag-row{height:25px;background-color:#fff;background-color:var(--ag-background-color,#fff);color:#000;color:var(--ag-data-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-row-highlight-above:after,.ag-theme-fresh .ag-row-highlight-below:after{content:"";position:absolute;width:calc(100% - 1px);height:1px;background-color:#000;background-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000));left:1px}.ag-theme-fresh .ag-row-highlight-above:after{top:-1px}.ag-theme-fresh .ag-row-highlight-above.ag-row-first:after{top:0}.ag-theme-fresh .ag-row-highlight-below:after{bottom:0}.ag-theme-fresh .ag-row-odd{background-color:#f6f6f6;background-color:var(--ag-odd-row-background-color,#f6f6f6)}.ag-theme-fresh .ag-horizontal-left-spacer:not(.ag-scroller-corner){border-right:1px solid #a9a9a9;border-right-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-horizontal-right-spacer:not(.ag-scroller-corner){border-left:1px solid #a9a9a9;border-left-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-ltr .ag-right-aligned-cell{text-align:right}.ag-theme-fresh .ag-rtl .ag-right-aligned-cell{text-align:left}.ag-theme-fresh .ag-ltr .ag-right-aligned-cell .ag-cell-value{margin-left:auto}.ag-theme-fresh .ag-rtl .ag-right-aligned-cell .ag-cell-value{margin-right:auto}.ag-theme-fresh .ag-cell{border:1px solid transparent;line-height:23px}.ag-theme-fresh .ag-cell,.ag-theme-fresh .ag-row>.ag-cell-wrapper{padding-left:11px;padding-right:11px}.ag-theme-fresh .ag-row-dragging{cursor:move;opacity:.5}.ag-theme-fresh .ag-cell-inline-editing{height:25px}.ag-theme-fresh .ag-cell-inline-editing,.ag-theme-fresh .ag-popup-editor{border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);background:#fff;background:var(--ag-background-color,#fff);border-radius:0;box-shadow:none;padding:0;background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6)}.ag-theme-fresh .ag-large-text-input{height:auto;padding:12px}.ag-theme-fresh .ag-details-row{padding:20px;background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-fresh .ag-overlay-loading-wrapper{background-color:hsla(0,0%,100%,.66);background-color:var(--ag-modal-overlay-background-color,hsla(0,0%,100%,.66))}.ag-theme-fresh .ag-overlay-loading-center{border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);background:#fff;background:var(--ag-background-color,#fff);border-radius:0;box-shadow:none;padding:4px}.ag-theme-fresh .ag-overlay-no-rows-wrapper.ag-layout-auto-height{padding-top:30px}.ag-theme-fresh .ag-loading{padding-left:12px;display:flex;height:100%;align-items:center}.ag-theme-fresh .ag-loading-icon{padding-right:12px}.ag-theme-fresh .ag-icon-loading{-webkit-animation-name:spin;animation-name:spin;-webkit-animation-duration:1s;animation-duration:1s;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite;-webkit-animation-timing-function:linear;animation-timing-function:linear}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}.ag-theme-fresh .ag-floating-top{border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-floating-bottom{border-top:1px solid #a9a9a9;border-top-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-ltr .ag-cell{border-right:dotted #a9a9a9}.ag-theme-fresh .ag-rtl .ag-cell{border-left:dotted #a9a9a9}.ag-theme-fresh .ag-ltr .ag-cell{border-right-width:1px}.ag-theme-fresh .ag-rtl .ag-cell{border-left-width:1px}.ag-theme-fresh .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell){border-left:1px solid #a9a9a9;border-left-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell){border-right:1px solid #a9a9a9;border-right-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-row-selected{background-color:#bde2e5;background-color:var(--ag-selected-row-background-color,#bde2e5)}.ag-theme-fresh .ag-cell-range-selected:not(.ag-cell-focus){background-color:rgba(0,0,0,.2);background-color:var(--ag-range-selection-background-color,rgba(0,0,0,.2))}.ag-theme-fresh .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart{background-color:rgba(0,88,255,.1);background-color:var(--ag-range-selection-chart-background-color,rgba(0,88,255,.1))}.ag-theme-fresh .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category{background-color:rgba(0,255,132,.1);background-color:var(--ag-range-selection-chart-category-background-color,rgba(0,255,132,.1))}.ag-theme-fresh .ag-cell-range-selected-1:not(.ag-cell-focus){background-color:rgba(0,0,0,.2);background-color:var(--ag-range-selection-background-color-1,var(--ag-range-selection-background-color,rgba(0,0,0,.2)))}.ag-theme-fresh .ag-cell-range-selected-2:not(.ag-cell-focus){background-color:rgba(0,0,0,.36);background-color:var(--ag-range-selection-background-color-2,rgba(0,0,0,.36))}.ag-theme-fresh .ag-cell-range-selected-3:not(.ag-cell-focus){background-color:rgba(0,0,0,.488);background-color:var(--ag-range-selection-background-color-3,rgba(0,0,0,.488))}.ag-theme-fresh .ag-cell-range-selected-4:not(.ag-cell-focus){background-color:rgba(0,0,0,.5904);background-color:var(--ag-range-selection-background-color-4,rgba(0,0,0,.5904))}.ag-theme-fresh .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top{border-top-color:#000;border-top-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right{border-right-color:#000;border-right-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom{border-bottom-color:#000;border-bottom-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left{border-left-color:#000;border-left-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-fresh .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-fresh .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),.ag-theme-fresh .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-fresh .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-fresh .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected){border:1px solid #000;border-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000));outline:initial}.ag-theme-fresh .ag-cell.ag-selection-fill-top,.ag-theme-fresh .ag-cell.ag-selection-fill-top.ag-cell-range-selected{border-top:1px dashed #000;border-top-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-ltr .ag-cell.ag-selection-fill-right,.ag-theme-fresh .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-right:1px dashed #000;border-right-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-rtl .ag-cell.ag-selection-fill-right,.ag-theme-fresh .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-left:1px dashed #000;border-left-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-cell.ag-selection-fill-bottom,.ag-theme-fresh .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected{border-bottom:1px dashed #000;border-bottom-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-ltr .ag-cell.ag-selection-fill-left,.ag-theme-fresh .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-left:1px dashed #000;border-left-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-rtl .ag-cell.ag-selection-fill-left,.ag-theme-fresh .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-right:1px dashed #000;border-right-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-fill-handle,.ag-theme-fresh .ag-range-handle{position:absolute;width:6px;height:6px;bottom:-1px;background-color:#000;background-color:var(--ag-range-selection-border-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-ltr .ag-fill-handle,.ag-theme-fresh .ag-ltr .ag-range-handle{right:-1px}.ag-theme-fresh .ag-rtl .ag-fill-handle,.ag-theme-fresh .ag-rtl .ag-range-handle{left:-1px}.ag-theme-fresh .ag-fill-handle{cursor:cell}.ag-theme-fresh .ag-range-handle{cursor:nwse-resize}.ag-theme-fresh .ag-cell-inline-editing{border-color:var(--ag-input-focus-border-color)!important}.ag-theme-fresh .ag-menu{border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);background:#fff;background:var(--ag-background-color,#fff);border-radius:0;box-shadow:none;padding:0}.ag-theme-fresh .ag-menu-list{cursor:default;width:100%;padding-top:4px;padding-bottom:4px}.ag-theme-fresh .ag-menu-option-part{padding-top:6px;padding-bottom:6px;line-height:12px}.ag-theme-fresh .ag-menu-option-active{background-color:var(--ag-row-hover-color)}.ag-theme-fresh .ag-menu-option-disabled{opacity:.5}.ag-theme-fresh .ag-menu-option-text{margin-left:4px}.ag-theme-fresh .ag-menu-option-icon{padding-left:8px;padding-right:4px;min-width:20px}.ag-theme-fresh .ag-menu-option-shortcut{padding-left:8px}.ag-theme-fresh .ag-menu-separator{height:8px}.ag-theme-fresh .ag-menu-separator-cell:after{content:"";display:block;border-top:1px solid #a9a9a9;border-top-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-menu-option-popup-pointer{width:20px;text-align:center}.ag-theme-fresh .ag-tabs-header{min-width:220px;width:100%;display:flex}.ag-theme-fresh .ag-tab{border-bottom:0 solid transparent;display:flex;flex:none;align-items:center;justify-content:center;cursor:pointer}.ag-theme-fresh .ag-keyboard-focus .ag-tab:focus{outline:none}.ag-theme-fresh .ag-keyboard-focus .ag-tab:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-fresh .ag-tab-selected{border-bottom-color:#000;border-bottom-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-foreground-color,#000)))}.ag-theme-fresh .ag-menu-header{color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-filter-condition-operator{height:17px}.ag-theme-fresh .ag-ltr .ag-filter-condition-operator-or{margin-left:8px}.ag-theme-fresh .ag-rtl .ag-filter-condition-operator-or{margin-right:8px}.ag-theme-fresh .ag-set-filter-select-all{padding-top:6px}.ag-theme-fresh .ag-set-filter-list{height:120px}.ag-theme-fresh .ag-set-filter-filter{margin-top:6px;margin-left:6px;margin-right:6px}.ag-theme-fresh .ag-filter-to{margin-top:4px}.ag-theme-fresh .ag-mini-filter{margin:6px 6px 0}.ag-theme-fresh .ag-set-filter-item{margin:0 6px}.ag-theme-fresh .ag-ltr .ag-set-filter-item-value{margin-left:6px}.ag-theme-fresh .ag-rtl .ag-set-filter-item-value{margin-right:6px}.ag-theme-fresh .ag-filter-header-container{padding-bottom:6px;border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9))}.ag-theme-fresh .ag-filter-apply-panel{padding:6px;border-top:1px solid #a9a9a9;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9))}.ag-theme-fresh .ag-filter-apply-panel-button{line-height:1.5}.ag-theme-fresh .ag-ltr .ag-filter-apply-panel-button{margin-left:8px}.ag-theme-fresh .ag-rtl .ag-filter-apply-panel-button{margin-right:8px}.ag-theme-fresh .ag-simple-filter-body-wrapper{padding:6px 6px 2px}.ag-theme-fresh .ag-simple-filter-body-wrapper>*{margin-bottom:4px}.ag-theme-fresh .ag-filter-no-matches{margin:6px}.ag-theme-fresh .ag-side-bar{position:relative}.ag-theme-fresh .ag-tool-panel-wrapper{background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6)}.ag-theme-fresh .ag-side-buttons{padding-top:16px;width:16px;position:relative;color:#000;color:var(--ag-foreground-color,#000);overflow:hidden}.ag-theme-fresh button.ag-side-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;background:transparent;padding:8px 0;width:calc(100% + 1px);margin:0;min-height:72px;background-position-y:center;background-position-x:center;background-repeat:no-repeat;border-left:none;border-right:none;border-top:#a9a9a9;border-top:1px solid var(--ag-border-color,#a9a9a9);border-bottom:#a9a9a9;border-bottom:1px solid var(--ag-border-color,#a9a9a9)}.ag-theme-fresh button.ag-side-button-button:focus{box-shadow:none}.ag-theme-fresh .ag-keyboard-focus .ag-side-button-button:focus{outline:none}.ag-theme-fresh .ag-keyboard-focus .ag-side-button-button:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-fresh .ag-selected .ag-side-button-button{background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6);border-top-color:#a9a9a9;border-top-color:var(--ag-border-color,#a9a9a9);border-bottom-color:#a9a9a9;border-bottom-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-side-button-icon-wrapper{margin-bottom:3px}.ag-theme-fresh .ag-ltr .ag-side-bar-left,.ag-theme-fresh .ag-rtl .ag-side-bar-right{border-right:1px solid #a9a9a9;border-right-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,.ag-theme-fresh .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper{border-left:1px solid #a9a9a9;border-left-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-ltr .ag-side-bar-left .ag-side-button-button,.ag-theme-fresh .ag-rtl .ag-side-bar-right .ag-side-button-button{border-right:0 solid transparent;margin-right:-1px;padding-right:1px}.ag-theme-fresh .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,.ag-theme-fresh .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button{border-right-color:#000;border-right-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-foreground-color,#000)))}.ag-theme-fresh .ag-ltr .ag-side-bar-right,.ag-theme-fresh .ag-rtl .ag-side-bar-left{border-left:1px solid #a9a9a9;border-left-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper,.ag-theme-fresh .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper{border-right:1px solid #a9a9a9;border-right-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-ltr .ag-side-bar-right .ag-side-button-button,.ag-theme-fresh .ag-rtl .ag-side-bar-left .ag-side-button-button{border-left:0 solid transparent;margin-left:-1px;padding-left:1px}.ag-theme-fresh .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button,.ag-theme-fresh .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button{border-left-color:#000;border-left-color:var(--ag-selected-tab-underline-color,var(--ag-range-selection-border-color,var(--ag-foreground-color,#000)))}.ag-theme-fresh .ag-filter-toolpanel-header{height:24px}.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-header,.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-search{padding-left:4px}.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-header,.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-search{padding-right:4px}.ag-theme-fresh .ag-keyboard-focus .ag-filter-toolpanel-header:focus{outline:none}.ag-theme-fresh .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-fresh .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{font-family:agGridClassic;font-size:12px;line-height:12px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;content:"\\f112";position:absolute}.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-left:4px}.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-right:4px}.ag-theme-fresh .ag-filter-toolpanel-group-level-0-header{height:32px}.ag-theme-fresh .ag-filter-toolpanel-group-item{margin-top:2px;margin-bottom:2px}.ag-theme-fresh .ag-filter-toolpanel-search{height:25px}.ag-theme-fresh .ag-filter-toolpanel-search-input{flex-grow:1;height:16px}.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-search-input{margin-right:4px}.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-search-input{margin-left:4px}.ag-theme-fresh .ag-filter-toolpanel-group-level-0{border-top:1px solid #a9a9a9;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9))}.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-expand,.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-title-bar-icon{margin-right:4px}.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-expand,.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-title-bar-icon{margin-left:4px}.ag-theme-fresh .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-left:20px}.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-right:20px}.ag-theme-fresh .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-left:36px}.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-right:36px}.ag-theme-fresh .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-left:52px}.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-right:52px}.ag-theme-fresh .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-left:68px}.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-right:68px}.ag-theme-fresh .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-left:84px}.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-right:84px}.ag-theme-fresh .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-left:100px}.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-right:100px}.ag-theme-fresh .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-left:116px}.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-right:116px}.ag-theme-fresh .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-left:132px}.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-right:132px}.ag-theme-fresh .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-left:148px}.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-right:148px}.ag-theme-fresh .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-left:164px}.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-right:164px}.ag-theme-fresh .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header{padding-left:4px}.ag-theme-fresh .ag-filter-toolpanel-instance-filter{border-top:1px solid #a9a9a9;border-top-color:var(--ag-border-color,#a9a9a9);border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-border-color,#a9a9a9);padding-top:4px}.ag-theme-fresh .ag-ltr .ag-filter-toolpanel-instance-header-icon{margin-left:4px}.ag-theme-fresh .ag-rtl .ag-filter-toolpanel-instance-header-icon{margin-right:4px}.ag-theme-fresh .ag-pivot-mode-panel{height:25px;display:flex}.ag-theme-fresh .ag-pivot-mode-select{display:flex;align-items:center}.ag-theme-fresh .ag-ltr .ag-pivot-mode-select{margin-left:6px}.ag-theme-fresh .ag-rtl .ag-pivot-mode-select{margin-right:6px}.ag-theme-fresh .ag-keyboard-focus .ag-column-select-header:focus{outline:none}.ag-theme-fresh .ag-keyboard-focus .ag-column-select-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-fresh .ag-column-select-header{height:25px;align-items:center;padding:0 6px}.ag-theme-fresh .ag-column-panel-column-select,.ag-theme-fresh .ag-column-select-header{border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9))}.ag-theme-fresh .ag-column-panel-column-select{border-top:1px solid #a9a9a9;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9))}.ag-theme-fresh .ag-column-group-icons,.ag-theme-fresh .ag-column-select-header-icon{color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-header{background-color:var(--ag-header-background-color);border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-header-row{color:#000;color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000)))}.ag-theme-fresh .ag-pinned-right-header{border-left:1px solid #a9a9a9;border-left-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-pinned-left-header{border-right:1px solid #a9a9a9;border-right-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-header-row{height:25px}.ag-theme-fresh .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-left:4px}.ag-theme-fresh .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon,.ag-theme-fresh .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-right:4px}.ag-theme-fresh .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon{margin-left:4px}.ag-theme-fresh .ag-header-cell,.ag-theme-fresh .ag-header-group-cell{padding-left:12px;padding-right:12px}.ag-theme-fresh .ag-header-cell.ag-header-cell-moving,.ag-theme-fresh .ag-header-group-cell.ag-header-cell-moving{background-color:#bebebe;background-color:var(--ag-header-cell-moving-background-color,#bebebe)}.ag-theme-fresh .ag-keyboard-focus .ag-header-cell:focus{outline:none}.ag-theme-fresh .ag-keyboard-focus .ag-header-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-fresh .ag-keyboard-focus .ag-header-group-cell:focus{outline:none}.ag-theme-fresh .ag-keyboard-focus .ag-header-group-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid;border-color:var(--ag-input-focus-border-color)}.ag-theme-fresh .ag-header-icon{color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-header-expand-icon{cursor:pointer}.ag-theme-fresh .ag-ltr .ag-header-expand-icon{padding-left:4px}.ag-theme-fresh .ag-rtl .ag-header-expand-icon{padding-right:4px}.ag-theme-fresh .ag-header-row:not(:first-child) .ag-header-cell,.ag-theme-fresh .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group{border-top:1px solid #a9a9a9;border-top-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-header-cell:after,.ag-theme-fresh .ag-header-group-cell:after{content:"";position:absolute;z-index:1;display:block;width:1px;height:100%;top:0;background-color:hsla(0,0%,66.3%,.5);background-color:var(--ag-header-column-separator-color,hsla(0,0%,66.3%,.5))}.ag-theme-fresh .ag-ltr .ag-header-cell:after,.ag-theme-fresh .ag-ltr .ag-header-group-cell:after{right:0}.ag-theme-fresh .ag-rtl .ag-header-cell:after,.ag-theme-fresh .ag-rtl .ag-header-group-cell:after{left:0}.ag-theme-fresh .ag-ltr .ag-header-select-all{margin-right:12px}.ag-theme-fresh .ag-ltr .ag-floating-filter-button,.ag-theme-fresh .ag-rtl .ag-header-select-all{margin-left:12px}.ag-theme-fresh .ag-rtl .ag-floating-filter-button{margin-right:12px}.ag-theme-fresh .ag-floating-filter-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;height:12px;padding:0;width:12px}.ag-theme-fresh .ag-filter-loading{background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6);height:100%;padding:6px;position:absolute;width:100%;z-index:1}.ag-theme-fresh .ag-paging-panel{border-top:1px solid #a9a9a9;border-top-color:var(--ag-border-color,#a9a9a9);color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000));height:25px}.ag-theme-fresh .ag-paging-panel>*{margin:0 12px}.ag-theme-fresh .ag-paging-button{cursor:pointer;opacity:0;top:0;right:0;bottom:0;left:0;padding:0;width:12px}.ag-theme-fresh .ag-disabled .ag-paging-button{cursor:default}.ag-theme-fresh .ag-paging-button-wrapper.ag-disabled{color:rgba(0,0,0,.5);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.5));cursor:default}.ag-theme-fresh .ag-paging-button-wrapper,.ag-theme-fresh .ag-paging-description{margin:0 4px}.ag-theme-fresh .ag-status-bar{border-top:1px solid #a9a9a9;border-top-color:var(--ag-border-color,#a9a9a9);color:rgba(0,0,0,.5);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.5));padding-right:16px;padding-left:16px;line-height:1.5}.ag-theme-fresh .ag-status-name-value-value{color:#000;color:var(--ag-foreground-color,#000)}.ag-theme-fresh .ag-status-bar-center{text-align:center}.ag-theme-fresh .ag-status-name-value{margin-left:4px;margin-right:4px;padding-top:8px;padding-bottom:8px}.ag-theme-fresh .ag-column-drop-cell{background:var(--ag-chip-background-color);border-radius:16px;height:16px;padding:0 2px}.ag-theme-fresh .ag-column-drop-cell-text{margin:0 4px}.ag-theme-fresh .ag-column-drop-cell-button{min-width:16px;margin:0 2px;color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-column-drop-cell-drag-handle{margin-left:8px}.ag-theme-fresh .ag-column-drop-cell-ghost{opacity:.5}.ag-theme-fresh .ag-column-drop-horizontal{background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6);color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000));height:25px;border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-ltr .ag-column-drop-horizontal{padding-left:12px}.ag-theme-fresh .ag-rtl .ag-column-drop-horizontal{padding-right:12px}.ag-theme-fresh .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child){border-right:1px solid #a9a9a9;border-right-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child){border-left:1px solid #a9a9a9;border-left-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-column-drop-horizontal-cell-separator{margin:0 4px;color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-column-drop-horizontal-empty-message{color:rgba(0,0,0,.5);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.5))}.ag-theme-fresh .ag-ltr .ag-column-drop-horizontal-icon{margin-right:12px}.ag-theme-fresh .ag-rtl .ag-column-drop-horizontal-icon{margin-left:12px}.ag-theme-fresh .ag-column-drop-vertical-list{padding-bottom:4px;padding-right:4px;padding-left:4px}.ag-theme-fresh .ag-column-drop-vertical-cell{margin-top:4px}.ag-theme-fresh .ag-column-drop-vertical{min-height:50px;max-height:150px;border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9))}.ag-theme-fresh .ag-column-drop-vertical.ag-last-column-drop{border-bottom:none}.ag-theme-fresh .ag-column-drop-vertical-icon{margin-left:4px;margin-right:4px}.ag-theme-fresh .ag-column-drop-vertical-list{position:relative}.ag-theme-fresh .ag-column-drop-vertical-empty-message{position:absolute;top:0;bottom:0;left:0;right:0;overflow:hidden;color:rgba(0,0,0,.5);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.5));margin-top:4px}.ag-theme-fresh .ag-select-agg-func-popup{border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);border-radius:0;box-shadow:none;background:#fff;background:var(--ag-background-color,#fff);height:70px;padding:0}.ag-theme-fresh .ag-select-agg-func-virtual-list-item{cursor:default;line-height:20px;padding-left:8px}.ag-theme-fresh .ag-select-agg-func-virtual-list-item:hover{background-color:#bde2e5;background-color:var(--ag-selected-row-background-color,#bde2e5)}.ag-theme-fresh .ag-chart-menu{border-radius:0;background:#fff;background:var(--ag-background-color,#fff)}.ag-theme-fresh .ag-chart-menu-icon{opacity:.5;line-height:24px;font-size:24px;width:24px;height:24px;margin:2px 0;cursor:pointer;border-radius:0;color:#000;color:var(--ag-secondary-foreground-color,var(--ag-foreground-color,#000))}.ag-theme-fresh .ag-chart-menu-icon:hover{opacity:1}.ag-theme-fresh .ag-chart-mini-thumbnail{border:1px solid #a9a9a9;border-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9));border-radius:5px;margin:5px}.ag-theme-fresh .ag-chart-mini-thumbnail:nth-last-child(3),.ag-theme-fresh .ag-chart-mini-thumbnail:nth-last-child(3)~.ag-chart-mini-thumbnail{margin-left:auto;margin-right:auto}.ag-theme-fresh .ag-ltr .ag-chart-mini-thumbnail:first-child{margin-left:0}.ag-theme-fresh .ag-ltr .ag-chart-mini-thumbnail:last-child,.ag-theme-fresh .ag-rtl .ag-chart-mini-thumbnail:first-child{margin-right:0}.ag-theme-fresh .ag-rtl .ag-chart-mini-thumbnail:last-child{margin-left:0}.ag-theme-fresh .ag-chart-mini-thumbnail.ag-selected{border-color:#000;border-color:var(--ag-minichart-selected-chart-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000)))}.ag-theme-fresh .ag-chart-settings-card-item{background:#000;background:var(--ag-foreground-color,#000);width:8px;height:8px;border-radius:4px}.ag-theme-fresh .ag-chart-settings-card-item.ag-selected{background-color:#000;background-color:var(--ag-minichart-selected-page-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000)))}.ag-theme-fresh .ag-chart-data-column-drag-handle{margin-left:4px}.ag-theme-fresh .ag-charts-data-group-title-bar,.ag-theme-fresh .ag-charts-format-top-level-group-title-bar,.ag-theme-fresh .ag-charts-settings-group-title-bar{border-top:1px solid #a9a9a9;border-top-color:var(--ag-secondary-border-color,var(--ag-border-color,#a9a9a9))}.ag-theme-fresh .ag-charts-settings-group-container{padding:4px}.ag-theme-fresh .ag-charts-data-group-container{padding:6px 6px 2px}.ag-theme-fresh .ag-charts-data-group-container>*{margin-bottom:4px}.ag-theme-fresh .ag-charts-format-top-level-group-container{margin-left:8px;padding:4px}.ag-theme-fresh .ag-charts-format-top-level-group-item{margin:4px 0}.ag-theme-fresh .ag-charts-format-sub-level-group-container{padding:6px 6px 2px}.ag-theme-fresh .ag-charts-format-sub-level-group-container>*{margin-bottom:4px}.ag-theme-fresh .ag-charts-group-container.ag-group-container-horizontal{padding:4px}.ag-theme-fresh .ag-chart-data-section,.ag-theme-fresh .ag-chart-format-section{display:flex;margin:0}.ag-theme-fresh .ag-chart-menu-panel{background-color:#f6f6f6;background-color:var(--ag-control-panel-background-color,#f6f6f6)}.ag-theme-fresh .ag-ltr .ag-chart-menu-panel{border-left:1px solid #a9a9a9;border-left-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-rtl .ag-chart-menu-panel{border-right:1px solid #a9a9a9;border-right-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-date-time-list-page-title{flex-grow:1;text-align:center}.ag-theme-fresh .ag-date-time-list-page-column-label,.ag-theme-fresh .ag-date-time-list-page-entry{text-align:center}.ag-theme-fresh .ag-checkbox-input-wrapper{font-family:agGridClassic;font-size:12px;line-height:12px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:12px;height:12px;background-color:var(--ag-checkbox-background-color);border-radius:0;display:inline-block;vertical-align:middle;flex:none}.ag-theme-fresh .ag-checkbox-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-fresh .ag-checkbox-input-wrapper:active,.ag-theme-fresh .ag-checkbox-input-wrapper:focus-within{outline:none}.ag-theme-fresh .ag-checkbox-input-wrapper.ag-disabled{opacity:.5}.ag-theme-fresh .ag-checkbox-input-wrapper:after{content:"\\f108";color:#000;color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-fresh .ag-checkbox-input-wrapper.ag-checked:after{content:"\\f106";color:#000;color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-fresh .ag-checkbox-input-wrapper.ag-indeterminate:after{content:"\\f107";color:#000;color:var(--ag-checkbox-indeterminate-color,var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000)));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-fresh .ag-toggle-button-input-wrapper{box-sizing:border-box;width:24px;height:12px;background-color:#000;background-color:var(--ag-toggle-button-off-background-color,var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000)));border-radius:6px;position:relative;flex:none;border:1px solid #000;border-color:var(--ag-toggle-button-off-border-color,var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000)))}.ag-theme-fresh .ag-toggle-button-input-wrapper input{opacity:0;height:100%;width:100%}.ag-theme-fresh .ag-toggle-button-input-wrapper:focus-within{outline:none}.ag-theme-fresh .ag-toggle-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-fresh .ag-toggle-button-input-wrapper.ag-checked{background-color:#000;background-color:var(--ag-toggle-button-on-background-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000)));border-color:#000;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000)))}.ag-theme-fresh .ag-toggle-button-input-wrapper:before{content:" ";position:absolute;top:-1px;left:-1px;display:block;box-sizing:border-box;height:12px;width:12px;background-color:#fff;background-color:var(--ag-toggle-button-switch-background-color,var(--ag-background-color,#fff));border-radius:6px;transition:left .1s;border:1px solid #000;border-color:var(--ag-toggle-button-switch-border-color,var(--ag-toggle-button-off-border-color,var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000))))}.ag-theme-fresh .ag-toggle-button-input-wrapper.ag-checked:before{left:calc(100% - 12px);border-color:#000;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000)))}.ag-theme-fresh .ag-radio-button-input-wrapper{font-family:agGridClassic;font-size:12px;line-height:12px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:12px;height:12px;background-color:var(--ag-checkbox-background-color);border-radius:0;display:inline-block;vertical-align:middle;flex:none;border-radius:12px}.ag-theme-fresh .ag-radio-button-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-fresh .ag-radio-button-input-wrapper:active,.ag-theme-fresh .ag-radio-button-input-wrapper:focus-within{outline:none}.ag-theme-fresh .ag-radio-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-fresh .ag-radio-button-input-wrapper:after{content:"\\f124";color:#000;color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-fresh .ag-radio-button-input-wrapper.ag-checked:after{content:"\\f125";color:#000;color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-fresh input[class^=ag-][type=range]{-webkit-appearance:none;width:100%;height:100%;background:none;overflow:visible}.ag-theme-fresh input[class^=ag-][type=range]::-webkit-slider-runnable-track{margin:0;padding:0;width:100%;height:3px;background-color:#a9a9a9;background-color:var(--ag-border-color,#a9a9a9);border-radius:0}.ag-theme-fresh input[class^=ag-][type=range]::-moz-range-track{margin:0;padding:0;width:100%;height:3px;background-color:#a9a9a9;background-color:var(--ag-border-color,#a9a9a9);border-radius:0}.ag-theme-fresh input[class^=ag-][type=range]::-ms-track{margin:0;padding:0;width:100%;height:3px;background-color:#a9a9a9;background-color:var(--ag-border-color,#a9a9a9);border-radius:0;color:transparent;width:calc(100% - 2px)}.ag-theme-fresh input[class^=ag-][type=range]::-webkit-slider-thumb{margin:0;padding:0;-webkit-appearance:none;width:12px;height:12px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #000;border-color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000));border-radius:12px;-webkit-transform:translateY(-4.5px);transform:translateY(-4.5px)}.ag-theme-fresh input[class^=ag-][type=range]::-ms-thumb{margin:0;padding:0;-webkit-appearance:none;width:12px;height:12px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #000;border-color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000));border-radius:12px}.ag-theme-fresh input[class^=ag-][type=range]::-moz-ag-range-thumb{margin:0;padding:0;-webkit-appearance:none;width:12px;height:12px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #000;border-color:var(--ag-checkbox-unchecked-color,var(--ag-foreground-color,#000));border-radius:12px}.ag-theme-fresh input[class^=ag-][type=range]:focus{outline:none}.ag-theme-fresh input[class^=ag-][type=range]:focus::-webkit-slider-thumb{border-color:#000;border-color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000))}.ag-theme-fresh input[class^=ag-][type=range]:focus::-ms-thumb{border-color:#000;border-color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000))}.ag-theme-fresh input[class^=ag-][type=range]:focus::-moz-ag-range-thumb{border-color:#000;border-color:var(--ag-checkbox-checked-color,var(--ag-foreground-color,#000))}.ag-theme-fresh input[class^=ag-][type=range]:active::-webkit-slider-runnable-track{background-color:var(--ag-input-focus-border-color)}.ag-theme-fresh input[class^=ag-][type=range]:active::-moz-ag-range-track{background-color:var(--ag-input-focus-border-color)}.ag-theme-fresh input[class^=ag-][type=range]:active::-ms-track{background-color:var(--ag-input-focus-border-color)}.ag-theme-fresh input[class^=ag-][type=range]:disabled{opacity:.5}.ag-theme-fresh .ag-icon{color:#333}.ag-theme-fresh .ag-icon-tree-closed:before{content:"\\f10b"}.ag-theme-fresh .ag-icon-tree-open:before{content:"\\f10f"}.ag-theme-fresh .ag-column-drop-cell,.ag-theme-fresh .ag-header{background-image:linear-gradient(#fff,#d3d3d3)}.ag-theme-fresh .ag-tab{border:1px solid transparent;padding:4px 8px;margin:4px 4px -1px}.ag-theme-fresh .ag-tabs-body{margin:2px 0}.ag-theme-fresh .ag-icon{margin:1px 1px 2px}.ag-theme-fresh .ag-tab-selected{background-color:#fff;background-color:var(--ag-background-color,#fff);border-color:#a9a9a9;border-color:var(--ag-border-color,#a9a9a9);border-bottom-color:transparent}.ag-theme-fresh .ag-tabs-header{background-color:var(--ag-header-background-color);border-bottom:1px solid #a9a9a9;border-bottom-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-filter .ag-filter-apply-panel{justify-content:flex-start}.ag-theme-fresh .ag-menu-option-active{background-color:#bde2e5;background-color:var(--ag-selected-row-background-color,#bde2e5)}.ag-theme-fresh .ag-column-drop-cell{border:1px solid #a9a9a9;border-color:var(--ag-border-color,#a9a9a9);border-radius:0}.ag-theme-fresh .ag-column-drop-cell-button .ag-icon{border:1px solid transparent}.ag-theme-fresh .ag-column-drop-cell-button:hover .ag-icon{border-color:#a9a9a9;border-color:var(--ag-border-color,#a9a9a9)}.ag-theme-fresh .ag-panel-title-bar-button-icon{font-size:20px;line-height:20px}.ag-theme-fresh .ag-menu-option-part{padding-top:4px;padding-bottom:4px}.ag-theme-fresh .ag-column-drop-vertical-title-bar{margin-top:4px;margin-left:4px}.ag-theme-fresh .ag-column-drop-vertical-title{margin-left:4px}.ag-theme-fresh .ag-column-drop-vertical-empty-message{margin-left:24px}',""]),e.exports=t},function(e,t,o){var r=o(27),a=o(172);"string"==typeof(a=a.__esModule?a.default:a)&&(a=[[e.i,a,""]]);var n={insert:"head",singleton:!1};r(a,n);e.exports=a.locals||{}},function(e,t,o){(t=o(28)(!1)).push([e.i,'.ag-theme-material{-webkit-font-smoothing:antialiased;color:rgba(0,0,0,.87);color:var(--ag-foreground-color,rgba(0,0,0,.87));font-family:Roboto,sans-serif;font-size:13px;line-height:normal}@font-face{font-family:agGridMaterial;src:url("data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABGsAAsAAAAAIJAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlEAAAReYPJi3U9TLzIAAANcAAAAPgAAAFZWTFJvY21hcAAAA5wAAAHsAAAFgGqPB0pnbHlmAAAFiAAACFEAAA58peGl1GhlYWQAAA3cAAAALwAAADZ2zcSBaGhlYQAADgwAAAAWAAAAJAfRBDJobXR4AAAOJAAAABIAAAEkt5gAAGxvY2EAAA44AAAAbQAAAJSyFLU8bWF4cAAADqgAAAAfAAAAIAFcAEluYW1lAAAOyAAAATIAAAJebBQ2inBvc3QAAA/8AAABrgAAAom3/2OGeJx9k09yElEQxr9hCCYBk6gRFVFT8X/UOM4MTIBIQBApKwsXLly4iQstrZSrnMC1B7A8gKfwBJZLVx7AA1gewF83g5gswhQz73V//fXX/fopkLSoSF0VhqPd51ra3zt4r5qKmvzM//862H/7Zk/z0x2+on/nFYR/tKR1vdCBvgUKXgefC6WwEHbD3fBD+Cn8oRDUmjZBl/WAJ1bCO1KqhprKVFAJW8x6Sy3QIe+2W0+rqjn3DDTUWXLGxAydcUNPdU0r8PSdp0ctAzhT5+zxHvFc1/IxiEw34G+gZhursdbReUoLeozGHjo6RLfwruDbIXNETB9fH22ho4rex7Fe6h42q80iGzku5R/rke8j31XowhTVhr8Jv/FtknVqb5IpIeIu7A1QD/MebugK0U14erB1PHrLoysgExSmuszKKkuorEKH2nqmV0SWUTGJ6XkXJzXfQv3M3ne+TLcPWTtwjcDeQcPMaidyk1xWewK+yv6dPuqLvuq7fuqXfoOvkiXxCrpw7xzbmQX6dxQ9wNv+Z7VKT3AWR1GHEYvU3fTexPiGeQctWwWf9SZlHWFNHV+G0/AD1GScxhyTF3neBGuJ/Tb7GPRSPo0tnpPe5yEzYBNQo5Mxb2OazFtGhy8QbauJrnPerRY85/20rKd2k5Z9ZzNvp1zj1C/yjais4f15gvcSFmOaWeoelaHaOO7jz1A7y2aq6qhKfXZtssZ+CwZkWqOOiZJEV/0GjH2q1lHQyG/kqs64+k5+UquOiz0qoBNRfpNT75lNch9tNhWjv/VfaSwAAAB4nGNgZGphnMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVFgEqgRRAAA0p8KWwAAeJy11AduVDEUheF/SkILvbcUSK+T3ntlGaFHoUShR6ySndwNEM4dHxYQJCx9c8d+nvdsPZ8BWoCaDEsdqnUqZPut0UpzvMbF5nidX+q3cZ6qvo9wwBEn0Tg91egI+xxyHJVm72+raHYbj+hlRr01GqywwDqT7DDOEtMss8gGs7q+xQTzTLHJHnOsss2ufl/V0+u0ck5PvaB1XNL9LnOFq1zjOje4yS1uc4e73OM+D3iopz3WnHY66KSLp5rXTY9W0Ec/AwwypB21ab2jjGmBrZytrZ1xfrbGysL65M74kna7uDE7o43OT23uza1u7/7Dzf5Da8uP2k/3npFvs1iTfWvIc1uRF7YgL21dXtmkvLYdeWPj8taW5MCm5dCW5Z0tynvbkA82Kx8tT9eRbcmxTcgnm5fPNiVfbFO+2p58szn5bqvyw7blxPQCo1JkVqJakLVWZLaiXmS+oqXQmSZMp5swnXPCdOIJywyGKQWE5dsLUzIIU0YIU1oIUx4IU4IIU5YIU6oIU74IU9IIU+YIU/oIUw4JUyIJUzYJU0oJU14JU3IJa+6rvSBrR0HWzoKsXQVZnxRKPWHN/XYXZO0pyNpbkLWvIGt/QdaBgqyDBVmHCrIOF/kfGiNFc/2jRWYpxgpyrFEw9gcVSJ+veJzFV21MW+cVvue9xTcmEOKAffECduyLfWkwrsy1udgGwlcCisrHZCdaG1LTdIG0sBjaVF2WoX1okyK1ayqt9Efzp9GkizSpTVv+pNOUVCxVmfrHUfNrYmzqn+GsQ1RCreTGVzvnxTbhY1Kn/Rjc933PfT/OPee8z/mwAAL+sTWxR9gvCOCxV4LdE/HoqoetmRVQZX4FG+byvXvQIHYncrnEbCYjCI/RGfED8QPBIlQKNcJhPKlFNFXSJCUiyRHNp9oVu2ZXFbsi6wrcMNKLi+k26lj/Yjo9z9/Zz7CfJyqxmDbSOlLIlssj9qA8+wShWtZtmk3WYT6WTa7GzQXYiGfNMvg2G4dBFJvvnRPnUIYjeNQrWSRLjeyQHS16q94aVv2qv1pSJVVXdVmXJdiYeTalR6N66tkvikQq9tZbsbk53otz25Y4kf9zcRV74f/zTZF/s1asRUqie6rWbAo1XbMrmdnZB5cuZV9+mT1vTrCB/K1cTijJuSquCtWCk27WewDsthoXaJ6WTojYwkGwgi6DLF5++LVLc+EjlvMxv2Y+GFoCY0hcxfdtiw+/BsfQp2AMb+cv781fRCDt4v6b/H0W2M05f3/6UZ4i52nz2Hx78UWeYvkOvpuT6Z18C7b7sfhDoQwRVSsIVpBkK4i6Gyx0dfYaR0trhK6N/dNMxZ4z89C5tPTp+/v3O6scoeMhR5UTFuFGHBfMP0HH0lJnZaXrsN/pDYW8Tl+di9hbS5jdvJ8qbpPDgltQ6K4iCjUJWwSbjE23a5GywrwN27xh5PhTGM2xwhu7buTHcUwahQlcwafoJ+waW0O9BFRJQi95M3b7dizH1uJ37sRzJdz8XLyDmjuFen5LFjt6lEfmRI0DjdqKNvUr1R6bh71vViihJGzMmhFSDz7DXgEzAp+Jt0Pe/EesPxFS8h/RGutXQvnzrL/gr4RNih+Iey6KrKtibTybLT7sr4+8bPdxPGNTbKoEYjd3chgkJ4dvzbIsOvwOPZG7rrLXY7lc7DZbiOdy8TulmPEUWxXa8SXIFK9FUlu1FtkF8gFAUldwQpEtitevKi6mtehEq0HAJdkiabTZIWvsTSnYp3ri8uBTEyMDJ16ok0+1DfmsvZLt6FDfPqsnvK9Xaj6uNhzp7x3A9ck6//fPWB/71eP1jUfC1h5m83UoTseg5nZf7O845xn0abWHjh4H1e3vVKpOfI+mx7pGq2sa6/xFXJLMhxAnjTySoKwoMQaSTtBRNr/oDUK4E1pcUHMARK+FoBr2wwaXre6FEwPvIFFfj8RI4GQgcPIH1AUao9GRaJT9g77Xf9HtLo7mZGEHdiDSnpFoESOTaN9CbPEhHikHAHovRm7DXGZr+WuYBSpyCbiRSJjLyVJ8Yd/we7HSzeh4N4AxiX3z8cd4MWYkmYQIATFHZwu+3cNm+Hco03jKKD5058fZ24U2k5hP0DYL3/uMWI5UuWAT7IheN51BMzQBCaejTXCo5h6FmUdBM2msHxzo8vPgMB/MI2FWpOlvhYICDFI3ND29gmM6fz+dnqbpXXpUE3pVD+rxFVcDXkkm2QJXA5XYmZ8AEyVGURXV2IQrDBJ0mSsbMxfMhVi2aN859gnmi1ohgF9AUeMQUTCuYVTjVBBkNIUPU2aLi5GKSHQCRrrfedsVw4iOtbWNRQ1Daff+HobMD+EVToNSWoQNJa4Mt6VeTLUNK3EpaWB/gmbGZlJtxbhajvaUuR0xLWHikCXM0hFMVGRAHbO2qOkRVZHsLHB+ePyNN8aHz0+XiPHR7u7RbvaTbZNEmFe6aalgl0lxkjSuxtudRdgcEicTwh4Y01Fd/o93yPdtNiwvkplEouDza8I9OqkjLw6hDMfGnrxsBbzO0r4ivy24io/kbI8Q/A9ZG8JEUiCAIABGCkCM1dDGvXK42dMceHLwTPRCk9nsbYBBJOBzbwNN7pXSzdSZwScDzQ1es7npgvllgxc+b7oQ5XNFnaYwTjvwflSUTwkCxjBlR5D2tDhqLF5/uBU8Ng1V1sTam5VdI12VN3lIHqDeXLY5nV6nEyL5W0l4JylO+oJBH0bv83zPdW+oVqnFB210fXa2iI0usROlqKJMourVwKM41S8qnHlVffVvEHC51ttPr59qv+yCVpyBv5v3Xa7L7afWT7evu7bqjf+dj7VUW27mUI/gE5qEJwRN0DE2edBX0BSdVA24qC44AIBug/bw+PinsOTUfLz8onlyKR0bRRm3Vl+vudnbfMz/yzAQK33wR/OLY8fUiYmb+P6l2nWsccK8gqRjZWXFMNq2Drg5A7Ab8GvzynvHuujI/BNqFxLgp8RsbKu5aoTHiyg7SCg7QtA6SCgTvdRzqLXQSgFgVy/N9Pb19c5cgoNF6uqPzj4d0fXI02f/UiTEVVow17dvfvjTbZs4UcAUyVKBNmwlaXjA2Qws6n8hWt9Lvb0vXaWu77tJydYK+7HLfWeBd8VWSUbPx5zyaM3Pa4RsDIt/VvCZSfwF4tisFZWSr5TpHHY2dJD8rcSma5gLU7FMJjaVpB800GAu8xKnoW4qnsnEp+C3pZrqE3aWuAMWVA2ZDBulXzzFtbMYxxmXjebZ3b3WEOyvZTJ0VtjFEwtunKf1LX2fEyuKtQ2ocPHd+CpsxCDxbiyLY7G+Yq5iXM1Qjc9cyRLvNXZtswak4qiQq9jrVAlu1YBzaCfKoy0UWyjNgN1hkWQsqBEMEtakVCjZt/JRJIyFEW6U8dGB3d1MOPrRjvCxtrFzo8l9+Vu/jA0Us1JP6LT7xdTAfDjfz+5i6lECx/d3HD7XHk21GUmY+kXt811RnpmU0Mmy08lncCf7gyD8G975gHwAAAB4nGNgZGBgAOLNefk58fw2Xxm4mV8ABaI4H+9rQNAMDMwvQOIMHAxMIB4AThwLfgB4nGNgZGBgfsHAgEQyMqACTwBFgwMNAAB4nGNgYGBgfjF0MT0AAODAKyYAAHicY2AAAikGD4Y4hhkMlxjeMMowujEWMC5ivMP4jkmByYopgCmJaQ8zA7MMswmzF3MD8wzmDcyfWFRYjFi8WCJYilgOsTKwqrB6sC5jfcPmxhbD1sY2hW0R2wa2fWwX2O6xfWC3Ix0CAAMJHZwAAAB4nGNgZGBg8GSwZeBkAAEmIOYCQgaG/2A+AwAWwQGmAHicfZA9asNAEIWf/BdiQwiEuFKxEEgTkH9Kk9qCgBsX7mVrJcustWK1NvgGOUhOkEOkzEFyijytt7ELz8LwvTdvplgAj/hBgKYCPLjeVAt3VGduk549d8gvnrsYYOK5R//dcx9v+PA8wBMOvBB07umE+PTcYv7Lc5v+t+cO+ddzF0P8ee4hDOC5j1UQeh7gNTBJHpsiXSRWmiJRS5kfVHJlXqqVNHWhSzGJxpeDWJbSkFOxPon6mE+tzURm9F7MdWmlUlpURu/kxkZba6vZaJR5P9roPRLkiGFQIMWCykI6lUBhSc75F4rK3Ezemq0c11QaJQT/P8L45kZMLp0++ym31jix1zhyb0rXIqPOmNHYk+buepNWfJpO5WY7Ohv6EbZuq8IMI77sKh8xxUv/NPJv3gAAeJxtkQdv2zAQhf3Fki3baeO6bbr3Hmqb7r1X+i9oipaJSKRAUR759WXtIECAHnDgew+Hd4OtjdY6+q3/xy4btImI6dAloUefAZsc4zhbDDnBiJOc4jTbnOEs5zjPBS5yictc4SrXuM4NbnKL29zhLve4zwMekvKIxzxhh6c84zkveMkrXvOGt7zjPR/4yCc+84WvfOM7P/jJL36zy5/WQOS5U7nw2pqOcM7O67aoZUcKI1WRrJ90J5ZT4fxQTpXcG9tFugIq2z4UtMmUV67URng1OpQbc1C5KW1hXVrpQFw3kKY0dV9a452QXmWRtNUyls7WdZSpWiZqUYngmfXUUqV1IeppO6DORBehTTzRrvZR7nQV5842VRQKfFSoie8U2oR+3cKKTJs8KcVCl3pfRaUyTRLmWzNjjRoY61NRFHausrgKBqpdaROHDAtXemb90AUTm44b761J7WSydVQwsdP51Ee1mKl+XQavNLNzcwD/jTNYw1VZssZhWh/OMPJOqaN3660kWymTNGa9B4Ich8KjsRjm1EgKpuwxZhE+P6OkoWLJhH1mrdZfDrCtIAAA") format("woff");font-weight:400;font-style:normal}.ag-theme-material .ag-icon{font-family:agGridMaterial;font-size:18px;line-height:18px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ag-theme-material .ag-icon-aggregation:before{content:"\\f101"}.ag-theme-material .ag-icon-arrows:before{content:"\\f102"}.ag-theme-material .ag-icon-asc:before{content:"\\f103"}.ag-theme-material .ag-icon-cancel:before{content:"\\f104"}.ag-theme-material .ag-icon-chart:before{content:"\\f105"}.ag-theme-material .ag-icon-color-picker:before{content:"\\f109"}.ag-theme-material .ag-icon-columns:before{content:"\\f10a"}.ag-theme-material .ag-icon-contracted:before{content:"\\f10b"}.ag-theme-material .ag-icon-copy:before{content:"\\f10c"}.ag-theme-material .ag-icon-cross:before{content:"\\f10d"}.ag-theme-material .ag-icon-desc:before{content:"\\f10e"}.ag-theme-material .ag-icon-expanded:before{content:"\\f10f"}.ag-theme-material .ag-icon-eye-slash:before{content:"\\f110"}.ag-theme-material .ag-icon-eye:before{content:"\\f111"}.ag-theme-material .ag-icon-filter:before{content:"\\f112"}.ag-theme-material .ag-icon-first:before{content:"\\f113"}.ag-theme-material .ag-icon-grip:before{content:"\\f114"}.ag-theme-material .ag-icon-group:before{content:"\\f115"}.ag-theme-material .ag-icon-last:before{content:"\\f116"}.ag-theme-material .ag-icon-left:before{content:"\\f117"}.ag-theme-material .ag-icon-linked:before{content:"\\f118"}.ag-theme-material .ag-icon-loading:before{content:"\\f119"}.ag-theme-material .ag-icon-maximize:before{content:"\\f11a"}.ag-theme-material .ag-icon-menu:before{content:"\\f11b"}.ag-theme-material .ag-icon-minimize:before{content:"\\f11c"}.ag-theme-material .ag-icon-next:before{content:"\\f11d"}.ag-theme-material .ag-icon-none:before{content:"\\f11e"}.ag-theme-material .ag-icon-not-allowed:before{content:"\\f11f"}.ag-theme-material .ag-icon-paste:before{content:"\\f120"}.ag-theme-material .ag-icon-pin:before{content:"\\f121"}.ag-theme-material .ag-icon-pivot:before{content:"\\f122"}.ag-theme-material .ag-icon-previous:before{content:"\\f123"}.ag-theme-material .ag-icon-right:before{content:"\\f126"}.ag-theme-material .ag-icon-save:before{content:"\\f127"}.ag-theme-material .ag-icon-small-down:before{content:"\\f128"}.ag-theme-material .ag-icon-small-left:before{content:"\\f129"}.ag-theme-material .ag-icon-small-right:before{content:"\\f12a"}.ag-theme-material .ag-icon-small-up:before{content:"\\f12b"}.ag-theme-material .ag-icon-tick:before{content:"\\f12c"}.ag-theme-material .ag-icon-tree-closed:before{content:"\\f12d"}.ag-theme-material .ag-icon-tree-indeterminate:before{content:"\\f12e"}.ag-theme-material .ag-icon-tree-open:before{content:"\\f12f"}.ag-theme-material .ag-icon-unlinked:before{content:"\\f130"}.ag-theme-material .ag-icon-row-drag:before{content:"\\f114"}.ag-theme-material .ag-right-arrow:before{content:"\\f117";content:"\\f126"}.ag-theme-material .ag-root-wrapper{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-material [class^=ag-],.ag-theme-material [class^=ag-]:after,.ag-theme-material [class^=ag-]:before,.ag-theme-material [class^=ag-]:focus{box-sizing:border-box;outline:none}.ag-theme-material [class^=ag-]::-ms-clear{display:none}.ag-theme-material .ag-checkbox .ag-input-wrapper,.ag-theme-material .ag-radio-button .ag-input-wrapper{overflow:visible}.ag-theme-material .ag-range-field .ag-input-wrapper{height:100%}.ag-theme-material .ag-toggle-button{flex:none;width:unset;min-width:unset}.ag-theme-material .ag-ltr .ag-label-align-right .ag-label{margin-left:8px}.ag-theme-material .ag-rtl .ag-label-align-right .ag-label{margin-right:8px}.ag-theme-material input[class^=ag-]{margin:0}.ag-theme-material input[class^=ag-],.ag-theme-material select[class^=ag-],.ag-theme-material textarea[class^=ag-]{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-material input[class^=ag-]:not([type]),.ag-theme-material input[class^=ag-][type=date],.ag-theme-material input[class^=ag-][type=datetime-local],.ag-theme-material input[class^=ag-][type=number],.ag-theme-material input[class^=ag-][type=tel],.ag-theme-material input[class^=ag-][type=text],.ag-theme-material textarea[class^=ag-]{line-height:inherit;color:inherit}.ag-theme-material input[class^=ag-]:not([type]):disabled,.ag-theme-material input[class^=ag-][type=date]:disabled,.ag-theme-material input[class^=ag-][type=datetime-local]:disabled,.ag-theme-material input[class^=ag-][type=number]:disabled,.ag-theme-material input[class^=ag-][type=tel]:disabled,.ag-theme-material input[class^=ag-][type=text]:disabled,.ag-theme-material textarea[class^=ag-]:disabled{color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38));background-color:var(--ag-input-disabled-background-color);border-color:var(--ag-input-disabled-border-color)}.ag-theme-material input[class^=ag-]:not([type]):focus,.ag-theme-material input[class^=ag-][type=date]:focus,.ag-theme-material input[class^=ag-][type=datetime-local]:focus,.ag-theme-material input[class^=ag-][type=number]:focus,.ag-theme-material input[class^=ag-][type=tel]:focus,.ag-theme-material input[class^=ag-][type=text]:focus,.ag-theme-material textarea[class^=ag-]:focus{outline:none;box-shadow:0 0 0 5px rgba(32,33,36,.122);border-color:#ff4081;border-color:var(--ag-input-focus-border-color,var(--ag-material-accent-color,#ff4081))}.ag-theme-material input[class^=ag-][type=number]{-moz-appearance:textfield}.ag-theme-material input[class^=ag-][type=number]::-webkit-inner-spin-button,.ag-theme-material input[class^=ag-][type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.ag-theme-material input[class^=ag-][type=range]{padding:0}.ag-theme-material button[class^=ag-]:focus,.ag-theme-material input[class^=ag-][type=button]:focus{box-shadow:0 0 0 5px rgba(32,33,36,.122)}.ag-theme-material .ag-drag-handle{color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-material .ag-list-item,.ag-theme-material .ag-virtual-list-item{height:40px}.ag-theme-material .ag-keyboard-focus .ag-virtual-list-item:focus{outline:none}.ag-theme-material .ag-keyboard-focus .ag-virtual-list-item:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #ff4081;border-color:var(--ag-input-focus-border-color,var(--ag-material-accent-color,#ff4081))}.ag-theme-material .ag-select-list{background-color:#fff;background-color:var(--ag-background-color,#fff);overflow-y:auto;overflow-x:hidden}.ag-theme-material .ag-list-item{display:flex;align-items:center}.ag-theme-material .ag-list-item.ag-active-item{background-color:#fafafa;background-color:var(--ag-row-hover-color,#fafafa)}.ag-theme-material .ag-select-list-item{padding-left:4px;padding-right:4px;cursor:default;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.ag-theme-material .ag-select-list-item span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.ag-theme-material .ag-select .ag-picker-field-wrapper{background-color:#fff;background-color:var(--ag-background-color,#fff);min-height:40px;cursor:default}.ag-theme-material .ag-select:not(.ag-cell-editor){height:40px}.ag-theme-material .ag-select .ag-picker-field-display{margin:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ag-theme-material .ag-select .ag-picker-field-icon{display:flex;align-items:center}.ag-theme-material .ag-select.ag-disabled{opacity:.5}.ag-theme-material .ag-rich-select{background-color:#fafafa;background-color:var(--ag-control-panel-background-color,#fafafa)}.ag-theme-material .ag-rich-select-list{width:100%;min-width:200px;height:312px}.ag-theme-material .ag-rich-select-value{padding:0 8px 0 24px;height:48px}.ag-theme-material .ag-rich-select-virtual-list-item{cursor:default;height:40px}.ag-theme-material .ag-rich-select-virtual-list-item:hover{background-color:#fafafa;background-color:var(--ag-row-hover-color,#fafafa)}.ag-theme-material .ag-rich-select-row{padding-left:24px}.ag-theme-material .ag-rich-select-row-selected{background-color:#eee;background-color:var(--ag-selected-row-background-color,#eee)}.ag-theme-material .ag-group-contracted,.ag-theme-material .ag-group-expanded,.ag-theme-material .ag-row-drag,.ag-theme-material .ag-selection-checkbox{color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-material .ag-ltr .ag-group-contracted,.ag-theme-material .ag-ltr .ag-group-expanded,.ag-theme-material .ag-ltr .ag-row-drag,.ag-theme-material .ag-ltr .ag-selection-checkbox{margin-right:24px}.ag-theme-material .ag-rtl .ag-group-contracted,.ag-theme-material .ag-rtl .ag-group-expanded,.ag-theme-material .ag-rtl .ag-row-drag,.ag-theme-material .ag-rtl .ag-selection-checkbox{margin-left:24px}.ag-theme-material .ag-cell-wrapper>:not(.ag-cell-value):not(.ag-group-value){height:46px;display:flex;align-items:center;flex:none}.ag-theme-material .ag-group-contracted,.ag-theme-material .ag-group-expanded{cursor:pointer}.ag-theme-material .ag-group-title-bar-icon{cursor:pointer;flex:none;color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-material .ag-ltr .ag-group-child-count{margin-left:2px}.ag-theme-material .ag-rtl .ag-group-child-count{margin-right:2px}.ag-theme-material .ag-group-title-bar{background-color:#eee;background-color:var(--ag-subheader-background-color,#eee);padding:8px}.ag-theme-material .ag-group-toolbar{padding:8px}.ag-theme-material .ag-disabled-group-container,.ag-theme-material .ag-disabled-group-title-bar{opacity:.5}.ag-theme-material .group-item{margin:4px 0}.ag-theme-material .ag-label{white-space:nowrap}.ag-theme-material .ag-ltr .ag-label{margin-right:8px}.ag-theme-material .ag-rtl .ag-label{margin-left:8px}.ag-theme-material .ag-label-align-top .ag-label{margin-bottom:4px}.ag-theme-material .ag-ltr .ag-angle-select-field,.ag-theme-material .ag-ltr .ag-slider-field{margin-right:16px}.ag-theme-material .ag-rtl .ag-angle-select-field,.ag-theme-material .ag-rtl .ag-slider-field{margin-left:16px}.ag-theme-material .ag-angle-select-parent-circle{width:24px;height:24px;border-radius:12px;border:1px solid #e2e2e2;border-color:var(--ag-border-color,#e2e2e2);background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-material .ag-angle-select-child-circle{top:4px;left:12px;width:6px;height:6px;margin-left:-3px;margin-top:-4px;border-radius:3px;background-color:rgba(0,0,0,.54);background-color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-material .ag-picker-field-wrapper{border:1px solid #e2e2e2;border-color:var(--ag-border-color,#e2e2e2);border-radius:5px}.ag-theme-material .ag-picker-field-wrapper:focus{box-shadow:0 0 0 5px rgba(32,33,36,.122)}.ag-theme-material .ag-picker-field-button{background-color:#fff;background-color:var(--ag-background-color,#fff);color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-material .ag-dialog.ag-color-dialog{border-radius:5px}.ag-theme-material .ag-color-picker .ag-picker-field-display{height:18px}.ag-theme-material .ag-color-panel{padding:8px}.ag-theme-material .ag-spectrum-color{background-color:red;border-radius:2px}.ag-theme-material .ag-spectrum-tools{padding:10px}.ag-theme-material .ag-spectrum-sat{background-image:linear-gradient(90deg,#fff,rgba(204,154,129,0))}.ag-theme-material .ag-spectrum-val{background-image:linear-gradient(0deg,#000,rgba(204,154,129,0))}.ag-theme-material .ag-spectrum-dragger{border-radius:12px;height:12px;width:12px;border:1px solid #fff;background:#000;box-shadow:0 0 2px 0 rgba(0,0,0,.24)}.ag-theme-material .ag-spectrum-alpha-background,.ag-theme-material .ag-spectrum-hue-background{border-radius:2px}.ag-theme-material .ag-spectrum-tool{margin-bottom:10px;height:11px;border-radius:2px}.ag-theme-material .ag-spectrum-slider{margin-top:-12px;width:13px;height:13px;border-radius:13px;background-color:#f8f8f8;box-shadow:0 1px 4px 0 rgba(0,0,0,.37)}.ag-theme-material .ag-recent-color{margin:0 3px}.ag-theme-material .ag-recent-color:first-child{margin-left:0}.ag-theme-material .ag-recent-color:last-child{margin-right:0}.ag-theme-material.ag-dnd-ghost{background:#fff;background:var(--ag-background-color,#fff);border-radius:2px;box-shadow:0 3px 1px -2px rgba(0,0,0,.2),0 2px 2px 0 rgba(0,0,0,.14),0 1px 5px 0 rgba(0,0,0,.12);overflow:hidden;text-overflow:ellipsis;z-index:10;color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54));height:56px!important;line-height:56px;margin:0;padding:0 16px;-webkit-transform:translateY(16px);transform:translateY(16px)}.ag-theme-material .ag-dnd-ghost-icon{margin-right:8px;color:rgba(0,0,0,.87);color:var(--ag-foreground-color,rgba(0,0,0,.87))}.ag-theme-material .ag-popup-child:not(.ag-tooltip-custom){box-shadow:5px 5px 10px rgba(0,0,0,.3)}.ag-dragging-fill-handle .ag-theme-material .ag-dialog,.ag-dragging-range-handle .ag-theme-material .ag-dialog{opacity:.7;pointer-events:none}.ag-theme-material .ag-dialog{border-radius:0}.ag-theme-material .ag-panel{background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-material .ag-panel-title-bar{background-color:#fff;background-color:var(--ag-header-background-color,#fff);color:rgba(0,0,0,.54);color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,rgba(0,0,0,.54)));height:56px;padding:8px 24px}.ag-theme-material .ag-ltr .ag-panel-title-bar-button{margin-left:8px}.ag-theme-material .ag-rtl .ag-panel-title-bar-button{margin-right:8px}.ag-theme-material .ag-tooltip{background-color:#fff;background-color:var(--ag-header-background-color,#fff);color:rgba(0,0,0,.87);color:var(--ag-foreground-color,rgba(0,0,0,.87));padding:8px;border-radius:2px;transition:opacity 1s}.ag-theme-material .ag-tooltip.ag-tooltip-hiding{opacity:0}.ag-theme-material .ag-ltr .ag-column-select-indent-1{padding-left:26px}.ag-theme-material .ag-rtl .ag-column-select-indent-1{padding-right:26px}.ag-theme-material .ag-ltr .ag-column-select-indent-2{padding-left:52px}.ag-theme-material .ag-rtl .ag-column-select-indent-2{padding-right:52px}.ag-theme-material .ag-ltr .ag-column-select-indent-3{padding-left:78px}.ag-theme-material .ag-rtl .ag-column-select-indent-3{padding-right:78px}.ag-theme-material .ag-ltr .ag-column-select-indent-4{padding-left:104px}.ag-theme-material .ag-rtl .ag-column-select-indent-4{padding-right:104px}.ag-theme-material .ag-ltr .ag-column-select-indent-5{padding-left:130px}.ag-theme-material .ag-rtl .ag-column-select-indent-5{padding-right:130px}.ag-theme-material .ag-ltr .ag-column-select-indent-6{padding-left:156px}.ag-theme-material .ag-rtl .ag-column-select-indent-6{padding-right:156px}.ag-theme-material .ag-ltr .ag-column-select-indent-7{padding-left:182px}.ag-theme-material .ag-rtl .ag-column-select-indent-7{padding-right:182px}.ag-theme-material .ag-ltr .ag-column-select-indent-8{padding-left:208px}.ag-theme-material .ag-rtl .ag-column-select-indent-8{padding-right:208px}.ag-theme-material .ag-ltr .ag-column-select-indent-9{padding-left:234px}.ag-theme-material .ag-rtl .ag-column-select-indent-9{padding-right:234px}.ag-theme-material .ag-column-select-header-icon{cursor:pointer}.ag-theme-material .ag-keyboard-focus .ag-column-select-header-icon:focus{outline:none}.ag-theme-material .ag-keyboard-focus .ag-column-select-header-icon:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:0;left:0;display:block;width:100%;height:100%;border:1px solid #ff4081;border-color:var(--ag-input-focus-border-color,var(--ag-material-accent-color,#ff4081))}.ag-theme-material .ag-ltr .ag-column-group-icons:not(:last-child),.ag-theme-material .ag-ltr .ag-column-select-checkbox:not(:last-child),.ag-theme-material .ag-ltr .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-material .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-material .ag-ltr .ag-column-select-column-label:not(:last-child),.ag-theme-material .ag-ltr .ag-column-select-header-checkbox:not(:last-child),.ag-theme-material .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-material .ag-ltr .ag-column-select-header-icon:not(:last-child){margin-right:12px}.ag-theme-material .ag-rtl .ag-column-group-icons:not(:last-child),.ag-theme-material .ag-rtl .ag-column-select-checkbox:not(:last-child),.ag-theme-material .ag-rtl .ag-column-select-column-drag-handle:not(:last-child),.ag-theme-material .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child),.ag-theme-material .ag-rtl .ag-column-select-column-label:not(:last-child),.ag-theme-material .ag-rtl .ag-column-select-header-checkbox:not(:last-child),.ag-theme-material .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child),.ag-theme-material .ag-rtl .ag-column-select-header-icon:not(:last-child){margin-left:12px}.ag-theme-material .ag-keyboard-focus .ag-column-select-column-group:focus{outline:none}.ag-theme-material .ag-keyboard-focus .ag-column-select-column-group:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-4px;left:-4px;display:block;width:calc(100% - -8px);height:calc(100% - -8px);border:1px solid #ff4081;border-color:var(--ag-input-focus-border-color,var(--ag-material-accent-color,#ff4081))}.ag-theme-material .ag-keyboard-focus .ag-column-select-column:focus{outline:none}.ag-theme-material .ag-keyboard-focus .ag-column-select-column:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:-4px;left:-4px;display:block;width:calc(100% - -8px);height:calc(100% - -8px);border:1px solid #ff4081;border-color:var(--ag-input-focus-border-color,var(--ag-material-accent-color,#ff4081))}.ag-theme-material .ag-column-select-column-group:not(:last-child),.ag-theme-material .ag-column-select-column:not(:last-child){margin-bottom:14px}.ag-theme-material .ag-column-select-column-group-readonly,.ag-theme-material .ag-column-select-column-readonly{color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38));pointer-events:none}.ag-theme-material .ag-ltr .ag-column-select-add-group-indent{margin-left:34px}.ag-theme-material .ag-rtl .ag-column-select-add-group-indent{margin-right:34px}.ag-theme-material .ag-column-select-list{padding:16px 12px}.ag-theme-material .ag-rtl{text-align:right}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-left:66px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-1{padding-right:66px}.ag-theme-material .ag-ltr .ag-row-group-indent-1{padding-left:42px}.ag-theme-material .ag-rtl .ag-row-group-indent-1{padding-right:42px}.ag-theme-material .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-left:108px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-2{padding-right:108px}.ag-theme-material .ag-ltr .ag-row-group-indent-2{padding-left:84px}.ag-theme-material .ag-rtl .ag-row-group-indent-2{padding-right:84px}.ag-theme-material .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-left:150px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-3{padding-right:150px}.ag-theme-material .ag-ltr .ag-row-group-indent-3{padding-left:126px}.ag-theme-material .ag-rtl .ag-row-group-indent-3{padding-right:126px}.ag-theme-material .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-left:192px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-4{padding-right:192px}.ag-theme-material .ag-ltr .ag-row-group-indent-4{padding-left:168px}.ag-theme-material .ag-rtl .ag-row-group-indent-4{padding-right:168px}.ag-theme-material .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-left:234px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-5{padding-right:234px}.ag-theme-material .ag-ltr .ag-row-group-indent-5{padding-left:210px}.ag-theme-material .ag-rtl .ag-row-group-indent-5{padding-right:210px}.ag-theme-material .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-left:276px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-6{padding-right:276px}.ag-theme-material .ag-ltr .ag-row-group-indent-6{padding-left:252px}.ag-theme-material .ag-rtl .ag-row-group-indent-6{padding-right:252px}.ag-theme-material .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-left:318px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-7{padding-right:318px}.ag-theme-material .ag-ltr .ag-row-group-indent-7{padding-left:294px}.ag-theme-material .ag-rtl .ag-row-group-indent-7{padding-right:294px}.ag-theme-material .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-left:360px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-8{padding-right:360px}.ag-theme-material .ag-ltr .ag-row-group-indent-8{padding-left:336px}.ag-theme-material .ag-rtl .ag-row-group-indent-8{padding-right:336px}.ag-theme-material .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-left:402px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-9{padding-right:402px}.ag-theme-material .ag-ltr .ag-row-group-indent-9{padding-left:378px}.ag-theme-material .ag-rtl .ag-row-group-indent-9{padding-right:378px}.ag-theme-material .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-left:444px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-10{padding-right:444px}.ag-theme-material .ag-ltr .ag-row-group-indent-10{padding-left:420px}.ag-theme-material .ag-rtl .ag-row-group-indent-10{padding-right:420px}.ag-theme-material .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-left:486px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-11{padding-right:486px}.ag-theme-material .ag-ltr .ag-row-group-indent-11{padding-left:462px}.ag-theme-material .ag-rtl .ag-row-group-indent-11{padding-right:462px}.ag-theme-material .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-left:528px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-12{padding-right:528px}.ag-theme-material .ag-ltr .ag-row-group-indent-12{padding-left:504px}.ag-theme-material .ag-rtl .ag-row-group-indent-12{padding-right:504px}.ag-theme-material .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-left:570px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-13{padding-right:570px}.ag-theme-material .ag-ltr .ag-row-group-indent-13{padding-left:546px}.ag-theme-material .ag-rtl .ag-row-group-indent-13{padding-right:546px}.ag-theme-material .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-left:612px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-14{padding-right:612px}.ag-theme-material .ag-ltr .ag-row-group-indent-14{padding-left:588px}.ag-theme-material .ag-rtl .ag-row-group-indent-14{padding-right:588px}.ag-theme-material .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-left:654px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-15{padding-right:654px}.ag-theme-material .ag-ltr .ag-row-group-indent-15{padding-left:630px}.ag-theme-material .ag-rtl .ag-row-group-indent-15{padding-right:630px}.ag-theme-material .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-left:696px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-16{padding-right:696px}.ag-theme-material .ag-ltr .ag-row-group-indent-16{padding-left:672px}.ag-theme-material .ag-rtl .ag-row-group-indent-16{padding-right:672px}.ag-theme-material .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-left:738px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-17{padding-right:738px}.ag-theme-material .ag-ltr .ag-row-group-indent-17{padding-left:714px}.ag-theme-material .ag-rtl .ag-row-group-indent-17{padding-right:714px}.ag-theme-material .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-left:780px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-18{padding-right:780px}.ag-theme-material .ag-ltr .ag-row-group-indent-18{padding-left:756px}.ag-theme-material .ag-rtl .ag-row-group-indent-18{padding-right:756px}.ag-theme-material .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-ltr .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-left:822px}.ag-theme-material .ag-rtl .ag-row>.ag-cell-wrapper.ag-row-group-indent-19{padding-right:822px}.ag-theme-material .ag-ltr .ag-row-group-indent-19{padding-left:798px}.ag-theme-material .ag-rtl .ag-row-group-indent-19{padding-right:798px}.ag-theme-material .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent{margin-left:42px}.ag-theme-material .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent{margin-right:42px}.ag-theme-material .ag-cell{-webkit-font-smoothing:subpixel-antialiased}.ag-theme-material .ag-value-change-delta{padding-right:2px}.ag-theme-material .ag-value-change-delta-up{color:#43a047;color:var(--ag-value-change-delta-up-color,#43a047)}.ag-theme-material .ag-value-change-delta-down{color:#e53935;color:var(--ag-value-change-delta-down-color,#e53935)}.ag-theme-material .ag-value-change-value{background-color:transparent;border-radius:1px;padding-left:1px;padding-right:1px;transition:background-color 1s}.ag-theme-material .ag-value-change-value-highlight{background-color:#00acc1;background-color:var(--ag-value-change-value-highlight-background-color,#00acc1);transition:background-color .1s}.ag-theme-material .ag-cell-data-changed{background-color:#00acc1!important;background-color:var(--ag-value-change-value-highlight-background-color,#00acc1)!important}.ag-theme-material .ag-cell-data-changed-animation{background-color:transparent}.ag-theme-material .ag-cell-highlight{background-color:#fce4ec!important;background-color:var(--ag-range-selection-highlight-color,#fce4ec)!important}.ag-theme-material .ag-row{height:48px;background-color:#fff;background-color:var(--ag-background-color,#fff);color:rgba(0,0,0,.87);color:var(--ag-data-color,var(--ag-foreground-color,rgba(0,0,0,.87)));border-width:1px;border-color:#e2e2e2;border-color:var(--ag-row-border-color,var(--ag-secondary-border-color,var(--ag-border-color,#e2e2e2)))}.ag-theme-material .ag-row:not(.ag-row-first){border-top-style:solid}.ag-theme-material .ag-row.ag-row-last{border-bottom-style:solid}.ag-theme-material .ag-row-highlight-above:after,.ag-theme-material .ag-row-highlight-below:after{content:"";position:absolute;width:calc(100% - 1px);height:1px;background-color:#3f51b5;background-color:var(--ag-range-selection-border-color,var(--ag-material-primary-color,#3f51b5));left:1px}.ag-theme-material .ag-row-highlight-above:after{top:-1px}.ag-theme-material .ag-row-highlight-above.ag-row-first:after{top:0}.ag-theme-material .ag-row-highlight-below:after{bottom:0}.ag-theme-material .ag-row-odd{background-color:var(--ag-odd-row-background-color)}.ag-theme-material .ag-horizontal-left-spacer:not(.ag-scroller-corner){border-right:1px solid #e2e2e2;border-right-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-horizontal-right-spacer:not(.ag-scroller-corner){border-left:1px solid #e2e2e2;border-left-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-row-hover{background-color:#fafafa;background-color:var(--ag-row-hover-color,#fafafa)}.ag-theme-material .ag-ltr .ag-right-aligned-cell{text-align:right}.ag-theme-material .ag-rtl .ag-right-aligned-cell{text-align:left}.ag-theme-material .ag-ltr .ag-right-aligned-cell .ag-cell-value{margin-left:auto}.ag-theme-material .ag-rtl .ag-right-aligned-cell .ag-cell-value{margin-right:auto}.ag-theme-material .ag-cell{border:1px solid transparent;line-height:46px}.ag-theme-material .ag-cell,.ag-theme-material .ag-row>.ag-cell-wrapper{padding-left:23px;padding-right:23px}.ag-theme-material .ag-row-dragging{cursor:move;opacity:.5}.ag-theme-material .ag-cell-inline-editing{height:48px}.ag-theme-material .ag-cell-inline-editing,.ag-theme-material .ag-popup-editor{background:#fff;background:var(--ag-background-color,#fff);border-radius:2px;box-shadow:0 3px 1px -2px rgba(0,0,0,.2),0 2px 2px 0 rgba(0,0,0,.14),0 1px 5px 0 rgba(0,0,0,.12);padding:0;background-color:#fafafa;background-color:var(--ag-control-panel-background-color,#fafafa)}.ag-theme-material .ag-large-text-input{height:auto;padding:24px}.ag-theme-material .ag-details-row{padding:40px;background-color:#fff;background-color:var(--ag-background-color,#fff)}.ag-theme-material .ag-overlay-loading-wrapper{background-color:hsla(0,0%,100%,.66);background-color:var(--ag-modal-overlay-background-color,hsla(0,0%,100%,.66))}.ag-theme-material .ag-overlay-loading-center{background:#fff;background:var(--ag-background-color,#fff);border-radius:2px;box-shadow:0 3px 1px -2px rgba(0,0,0,.2),0 2px 2px 0 rgba(0,0,0,.14),0 1px 5px 0 rgba(0,0,0,.12);padding:8px}.ag-theme-material .ag-overlay-no-rows-wrapper.ag-layout-auto-height{padding-top:30px}.ag-theme-material .ag-loading{padding-left:24px;display:flex;height:100%;align-items:center}.ag-theme-material .ag-loading-icon{padding-right:24px}.ag-theme-material .ag-icon-loading{-webkit-animation-name:spin;animation-name:spin;-webkit-animation-duration:1s;animation-duration:1s;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite;-webkit-animation-timing-function:linear;animation-timing-function:linear}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}.ag-theme-material .ag-floating-top{border-bottom:1px solid #e2e2e2;border-bottom-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-floating-bottom{border-top:1px solid #e2e2e2;border-top-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-ltr .ag-cell{border-right:solid transparent}.ag-theme-material .ag-rtl .ag-cell{border-left:solid transparent}.ag-theme-material .ag-ltr .ag-cell{border-right-width:1px}.ag-theme-material .ag-rtl .ag-cell{border-left-width:1px}.ag-theme-material .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell){border-left:1px solid #e2e2e2;border-left-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell){border-right:1px solid #e2e2e2;border-right-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-row-selected{background-color:#eee;background-color:var(--ag-selected-row-background-color,#eee)}.ag-theme-material .ag-cell-range-selected:not(.ag-cell-focus){background-color:rgba(122,134,203,.1);background-color:var(--ag-range-selection-background-color,rgba(122,134,203,.1))}.ag-theme-material .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart{background-color:rgba(0,88,255,.1);background-color:var(--ag-range-selection-chart-background-color,rgba(0,88,255,.1))}.ag-theme-material .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category{background-color:rgba(0,255,132,.1);background-color:var(--ag-range-selection-chart-category-background-color,rgba(0,255,132,.1))}.ag-theme-material .ag-cell-range-selected-1:not(.ag-cell-focus){background-color:rgba(122,134,203,.1);background-color:var(--ag-range-selection-background-color-1,var(--ag-range-selection-background-color,rgba(122,134,203,.1)))}.ag-theme-material .ag-cell-range-selected-2:not(.ag-cell-focus){background-color:rgba(122,134,203,.19);background-color:var(--ag-range-selection-background-color-2,rgba(122,134,203,.19))}.ag-theme-material .ag-cell-range-selected-3:not(.ag-cell-focus){background-color:rgba(122,134,203,.271);background-color:var(--ag-range-selection-background-color-3,rgba(122,134,203,.271))}.ag-theme-material .ag-cell-range-selected-4:not(.ag-cell-focus){background-color:rgba(122,134,203,.3439);background-color:var(--ag-range-selection-background-color-4,rgba(122,134,203,.3439))}.ag-theme-material .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top{border-top-color:#3f51b5;border-top-color:var(--ag-range-selection-border-color,var(--ag-material-primary-color,#3f51b5))}.ag-theme-material .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right{border-right-color:#3f51b5;border-right-color:var(--ag-range-selection-border-color,var(--ag-material-primary-color,#3f51b5))}.ag-theme-material .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom{border-bottom-color:#3f51b5;border-bottom-color:var(--ag-range-selection-border-color,var(--ag-material-primary-color,#3f51b5))}.ag-theme-material .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left{border-left-color:#3f51b5;border-left-color:var(--ag-range-selection-border-color,var(--ag-material-primary-color,#3f51b5))}.ag-theme-material .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-material .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-material .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),.ag-theme-material .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle,.ag-theme-material .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,.ag-theme-material .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected){border:1px solid #3f51b5;border-color:var(--ag-range-selection-border-color,var(--ag-material-primary-color,#3f51b5));outline:initial}.ag-theme-material .ag-cell.ag-selection-fill-top,.ag-theme-material .ag-cell.ag-selection-fill-top.ag-cell-range-selected{border-top:1px dashed #3f51b5;border-top-color:var(--ag-range-selection-border-color,var(--ag-material-primary-color,#3f51b5))}.ag-theme-material .ag-ltr .ag-cell.ag-selection-fill-right,.ag-theme-material .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-right:1px dashed #3f51b5;border-right-color:var(--ag-range-selection-border-color,var(--ag-material-primary-color,#3f51b5))}.ag-theme-material .ag-rtl .ag-cell.ag-selection-fill-right,.ag-theme-material .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected{border-left:1px dashed #3f51b5;border-left-color:var(--ag-range-selection-border-color,var(--ag-material-primary-color,#3f51b5))}.ag-theme-material .ag-cell.ag-selection-fill-bottom,.ag-theme-material .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected{border-bottom:1px dashed #3f51b5;border-bottom-color:var(--ag-range-selection-border-color,var(--ag-material-primary-color,#3f51b5))}.ag-theme-material .ag-ltr .ag-cell.ag-selection-fill-left,.ag-theme-material .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-left:1px dashed #3f51b5;border-left-color:var(--ag-range-selection-border-color,var(--ag-material-primary-color,#3f51b5))}.ag-theme-material .ag-rtl .ag-cell.ag-selection-fill-left,.ag-theme-material .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected{border-right:1px dashed #3f51b5;border-right-color:var(--ag-range-selection-border-color,var(--ag-material-primary-color,#3f51b5))}.ag-theme-material .ag-fill-handle,.ag-theme-material .ag-range-handle{position:absolute;width:6px;height:6px;bottom:-1px;background-color:#3f51b5;background-color:var(--ag-range-selection-border-color,var(--ag-material-primary-color,#3f51b5))}.ag-theme-material .ag-ltr .ag-fill-handle,.ag-theme-material .ag-ltr .ag-range-handle{right:-1px}.ag-theme-material .ag-rtl .ag-fill-handle,.ag-theme-material .ag-rtl .ag-range-handle{left:-1px}.ag-theme-material .ag-fill-handle{cursor:cell}.ag-theme-material .ag-range-handle{cursor:nwse-resize}.ag-theme-material .ag-cell-inline-editing{border-color:#ff4081!important;border-color:var(--ag-input-focus-border-color,var(--ag-material-accent-color,#ff4081))!important}.ag-theme-material .ag-menu{background:#fff;background:var(--ag-background-color,#fff);border-radius:2px;box-shadow:0 3px 1px -2px rgba(0,0,0,.2),0 2px 2px 0 rgba(0,0,0,.14),0 1px 5px 0 rgba(0,0,0,.12);padding:0}.ag-theme-material .ag-menu-list{cursor:default;width:100%;padding-top:8px;padding-bottom:8px}.ag-theme-material .ag-menu-option-part{padding-top:10px;padding-bottom:10px;line-height:18px}.ag-theme-material .ag-menu-option-active{background-color:#fafafa;background-color:var(--ag-row-hover-color,#fafafa)}.ag-theme-material .ag-menu-option-disabled{opacity:.5}.ag-theme-material .ag-menu-option-text{margin-left:8px}.ag-theme-material .ag-menu-option-icon{padding-left:16px;padding-right:8px;min-width:34px}.ag-theme-material .ag-menu-option-shortcut{padding-left:16px}.ag-theme-material .ag-menu-separator{height:16px}.ag-theme-material .ag-menu-separator-cell:after{content:"";display:block;border-top:1px solid #e2e2e2;border-top-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-menu-option-popup-pointer{width:34px;text-align:center}.ag-theme-material .ag-tabs-header{min-width:220px;width:100%;display:flex}.ag-theme-material .ag-tab{border-bottom:2px solid transparent;display:flex;flex:none;align-items:center;justify-content:center;cursor:pointer;flex:1 1 auto}.ag-theme-material .ag-keyboard-focus .ag-tab:focus{outline:none}.ag-theme-material .ag-keyboard-focus .ag-tab:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #ff4081;border-color:var(--ag-input-focus-border-color,var(--ag-material-accent-color,#ff4081))}.ag-theme-material .ag-tab-selected{border-bottom-color:#3f51b5;border-bottom-color:var(--ag-selected-tab-underline-color,var(--ag-material-primary-color,#3f51b5))}.ag-theme-material .ag-menu-header{color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-material .ag-filter-condition-operator{height:17px}.ag-theme-material .ag-ltr .ag-filter-condition-operator-or{margin-left:16px}.ag-theme-material .ag-rtl .ag-filter-condition-operator-or{margin-right:16px}.ag-theme-material .ag-set-filter-select-all{padding-top:16px}.ag-theme-material .ag-set-filter-list{height:240px}.ag-theme-material .ag-set-filter-filter{margin-top:16px;margin-left:12px;margin-right:12px}.ag-theme-material .ag-filter-to{margin-top:14px}.ag-theme-material .ag-mini-filter{margin:16px 12px 0}.ag-theme-material .ag-set-filter-item{margin:0 12px}.ag-theme-material .ag-ltr .ag-set-filter-item-value{margin-left:12px}.ag-theme-material .ag-rtl .ag-set-filter-item-value{margin-right:12px}.ag-theme-material .ag-filter-header-container{padding-bottom:16px}.ag-theme-material .ag-filter-apply-panel{padding:16px 12px}.ag-theme-material .ag-filter-apply-panel-button{line-height:1.5}.ag-theme-material .ag-ltr .ag-filter-apply-panel-button{margin-left:16px}.ag-theme-material .ag-rtl .ag-filter-apply-panel-button{margin-right:16px}.ag-theme-material .ag-simple-filter-body-wrapper{padding:16px 12px 2px}.ag-theme-material .ag-simple-filter-body-wrapper>*{margin-bottom:14px}.ag-theme-material .ag-filter-no-matches{margin:16px 12px}.ag-theme-material .ag-side-bar{position:relative}.ag-theme-material .ag-tool-panel-wrapper{background-color:#fafafa;background-color:var(--ag-control-panel-background-color,#fafafa)}.ag-theme-material .ag-side-buttons{padding-top:32px;width:22px;position:relative;color:rgba(0,0,0,.87);color:var(--ag-foreground-color,rgba(0,0,0,.87));overflow:hidden}.ag-theme-material button.ag-side-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;background:transparent;padding:16px 0;width:100%;margin:0;min-height:144px;background-position-y:center;background-position-x:center;background-repeat:no-repeat;border:none}.ag-theme-material button.ag-side-button-button:focus{box-shadow:none}.ag-theme-material .ag-keyboard-focus .ag-side-button-button:focus{outline:none}.ag-theme-material .ag-keyboard-focus .ag-side-button-button:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #ff4081;border-color:var(--ag-input-focus-border-color,var(--ag-material-accent-color,#ff4081))}.ag-theme-material .ag-side-button-icon-wrapper{margin-bottom:3px}.ag-theme-material .ag-ltr .ag-side-bar-left .ag-side-button-button,.ag-theme-material .ag-rtl .ag-side-bar-right .ag-side-button-button{border-right:2px solid transparent}.ag-theme-material .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,.ag-theme-material .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button{border-right-color:#3f51b5;border-right-color:var(--ag-selected-tab-underline-color,var(--ag-material-primary-color,#3f51b5))}.ag-theme-material .ag-ltr .ag-side-bar-right .ag-side-button-button,.ag-theme-material .ag-rtl .ag-side-bar-left .ag-side-button-button{border-left:2px solid transparent}.ag-theme-material .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button,.ag-theme-material .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button{border-left-color:#3f51b5;border-left-color:var(--ag-selected-tab-underline-color,var(--ag-material-primary-color,#3f51b5))}.ag-theme-material .ag-filter-toolpanel-header{height:48px}.ag-theme-material .ag-ltr .ag-filter-toolpanel-header,.ag-theme-material .ag-ltr .ag-filter-toolpanel-search{padding-left:8px}.ag-theme-material .ag-rtl .ag-filter-toolpanel-header,.ag-theme-material .ag-rtl .ag-filter-toolpanel-search{padding-right:8px}.ag-theme-material .ag-keyboard-focus .ag-filter-toolpanel-header:focus{outline:none}.ag-theme-material .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #ff4081;border-color:var(--ag-input-focus-border-color,var(--ag-material-accent-color,#ff4081))}.ag-theme-material .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{font-family:agGridMaterial;font-size:18px;line-height:18px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;content:"\\f112";position:absolute}.ag-theme-material .ag-ltr .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-left:8px}.ag-theme-material .ag-rtl .ag-filter-toolpanel-group.ag-has-filter>.ag-group-title-bar .ag-group-title:after{padding-right:8px}.ag-theme-material .ag-filter-toolpanel-group-level-0-header{height:64px}.ag-theme-material .ag-filter-toolpanel-group-item{margin-top:4px;margin-bottom:4px}.ag-theme-material .ag-filter-toolpanel-search{height:56px}.ag-theme-material .ag-filter-toolpanel-search-input{flex-grow:1;height:32px}.ag-theme-material .ag-ltr .ag-filter-toolpanel-search-input{margin-right:8px}.ag-theme-material .ag-rtl .ag-filter-toolpanel-search-input{margin-left:8px}.ag-theme-material .ag-ltr .ag-filter-toolpanel-expand,.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-title-bar-icon{margin-right:8px}.ag-theme-material .ag-rtl .ag-filter-toolpanel-expand,.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-title-bar-icon{margin-left:8px}.ag-theme-material .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-left:24px}.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header{padding-right:24px}.ag-theme-material .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-left:40px}.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header{padding-right:40px}.ag-theme-material .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-left:56px}.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header{padding-right:56px}.ag-theme-material .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-left:72px}.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header{padding-right:72px}.ag-theme-material .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-left:88px}.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header{padding-right:88px}.ag-theme-material .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-left:104px}.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header{padding-right:104px}.ag-theme-material .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-left:120px}.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header{padding-right:120px}.ag-theme-material .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-left:136px}.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header{padding-right:136px}.ag-theme-material .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-left:152px}.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header{padding-right:152px}.ag-theme-material .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar{background-color:transparent}.ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-left:168px}.ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header{padding-right:168px}.ag-theme-material .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header{padding-left:8px}.ag-theme-material .ag-filter-toolpanel-instance-filter{padding-top:8px}.ag-theme-material .ag-ltr .ag-filter-toolpanel-instance-header-icon{margin-left:8px}.ag-theme-material .ag-rtl .ag-filter-toolpanel-instance-header-icon{margin-right:8px}.ag-theme-material .ag-pivot-mode-panel{height:56px;display:flex}.ag-theme-material .ag-pivot-mode-select{display:flex;align-items:center}.ag-theme-material .ag-ltr .ag-pivot-mode-select{margin-left:12px}.ag-theme-material .ag-rtl .ag-pivot-mode-select{margin-right:12px}.ag-theme-material .ag-keyboard-focus .ag-column-select-header:focus{outline:none}.ag-theme-material .ag-keyboard-focus .ag-column-select-header:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #ff4081;border-color:var(--ag-input-focus-border-color,var(--ag-material-accent-color,#ff4081))}.ag-theme-material .ag-column-select-header{align-items:center;padding:0 12px}.ag-theme-material .ag-column-group-icons,.ag-theme-material .ag-column-select-header-icon{color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-material .ag-header{background-color:#fff;background-color:var(--ag-header-background-color,#fff);border-bottom:1px solid #e2e2e2;border-bottom-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-header-row{color:rgba(0,0,0,.54);color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,rgba(0,0,0,.54)))}.ag-theme-material .ag-pinned-right-header{border-left:1px solid #e2e2e2;border-left-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-pinned-left-header{border-right:1px solid #e2e2e2;border-right-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-header-row{height:56px}.ag-theme-material .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-left:8px}.ag-theme-material .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon,.ag-theme-material .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon{margin-right:8px}.ag-theme-material .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon{margin-left:8px}.ag-theme-material .ag-header-cell,.ag-theme-material .ag-header-group-cell{padding-left:24px;padding-right:24px}.ag-theme-material .ag-header-cell.ag-header-cell-moving,.ag-theme-material .ag-header-group-cell.ag-header-cell-moving{background-color:#f2f2f2;background-color:var(--ag-header-cell-moving-background-color,var(--ag-header-cell-hover-background-color,#f2f2f2))}.ag-theme-material .ag-keyboard-focus .ag-header-cell:focus{outline:none}.ag-theme-material .ag-keyboard-focus .ag-header-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #ff4081;border-color:var(--ag-input-focus-border-color,var(--ag-material-accent-color,#ff4081))}.ag-theme-material .ag-keyboard-focus .ag-header-group-cell:focus{outline:none}.ag-theme-material .ag-keyboard-focus .ag-header-group-cell:focus:after{content:"";position:absolute;background-color:transparent;pointer-events:none;top:4px;left:4px;display:block;width:calc(100% - 8px);height:calc(100% - 8px);border:1px solid #ff4081;border-color:var(--ag-input-focus-border-color,var(--ag-material-accent-color,#ff4081))}.ag-theme-material .ag-header-icon{color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-material .ag-header-expand-icon{cursor:pointer}.ag-theme-material .ag-ltr .ag-header-expand-icon{padding-left:4px}.ag-theme-material .ag-rtl .ag-header-expand-icon{padding-right:4px}.ag-theme-material .ag-header-row:not(:first-child) .ag-header-cell,.ag-theme-material .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group{border-top:1px solid #e2e2e2;border-top-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-header-cell:first-of-type.ag-column-resizing,.ag-theme-material .ag-header-cell:first-of-type:not(.ag-header-cell-moving):hover,.ag-theme-material .ag-header-cell:not(.ag-column-resizing)+.ag-header-cell.ag-column-resizing,.ag-theme-material .ag-header-cell:not(.ag-column-resizing)+.ag-header-cell:not(.ag-header-cell-moving):hover,.ag-theme-material .ag-header-group-cell:first-of-type.ag-column-resizing,.ag-theme-material .ag-header-group-cell:first-of-type:not(.ag-header-cell-moving):hover,.ag-theme-material .ag-header-group-cell:not(.ag-column-resizing)+.ag-header-group-cell.ag-column-resizing,.ag-theme-material .ag-header-group-cell:not(.ag-column-resizing)+.ag-header-group-cell:not(.ag-header-cell-moving):hover{background-color:#f2f2f2;background-color:var(--ag-header-cell-hover-background-color,#f2f2f2)}.ag-theme-material .ag-ltr .ag-header-select-all{margin-right:24px}.ag-theme-material .ag-ltr .ag-floating-filter-button,.ag-theme-material .ag-rtl .ag-header-select-all{margin-left:24px}.ag-theme-material .ag-rtl .ag-floating-filter-button{margin-right:24px}.ag-theme-material .ag-floating-filter-button-button{color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;height:18px;padding:0;width:18px}.ag-theme-material .ag-filter-loading{background-color:#fafafa;background-color:var(--ag-control-panel-background-color,#fafafa);height:100%;padding:16px 12px;position:absolute;width:100%;z-index:1}.ag-theme-material .ag-paging-panel{border-top:1px solid #e2e2e2;border-top-color:var(--ag-border-color,#e2e2e2);color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54));height:56px}.ag-theme-material .ag-paging-panel>*{margin:0 24px}.ag-theme-material .ag-paging-button{cursor:pointer;opacity:0;top:0;right:0;bottom:0;left:0;padding:0;width:18px}.ag-theme-material .ag-disabled .ag-paging-button{cursor:default}.ag-theme-material .ag-paging-button-wrapper.ag-disabled{color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38));cursor:default}.ag-theme-material .ag-paging-button-wrapper,.ag-theme-material .ag-paging-description{margin:0 8px}.ag-theme-material .ag-status-bar{color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38));padding-right:32px;padding-left:32px;line-height:1.5}.ag-theme-material .ag-status-name-value-value{color:rgba(0,0,0,.87);color:var(--ag-foreground-color,rgba(0,0,0,.87))}.ag-theme-material .ag-status-bar-center{text-align:center}.ag-theme-material .ag-status-name-value{margin-left:8px;margin-right:8px;padding-top:16px;padding-bottom:16px}.ag-theme-material .ag-column-drop-cell{background:#e2e2e2;background:var(--ag-chip-background-color,#e2e2e2);border-radius:32px;height:32px;padding:0 4px}.ag-theme-material .ag-column-drop-cell-text{margin:0 8px}.ag-theme-material .ag-column-drop-cell-button{min-width:32px;margin:0 4px;color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-material .ag-column-drop-cell-drag-handle{margin-left:16px}.ag-theme-material .ag-column-drop-cell-ghost{opacity:.5}.ag-theme-material .ag-column-drop-horizontal{background-color:#fafafa;background-color:var(--ag-control-panel-background-color,#fafafa);color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54));height:48px}.ag-theme-material .ag-ltr .ag-column-drop-horizontal{padding-left:24px}.ag-theme-material .ag-rtl .ag-column-drop-horizontal{padding-right:24px}.ag-theme-material .ag-column-drop-horizontal-cell-separator{margin:0 8px;color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-material .ag-column-drop-horizontal-empty-message{color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38))}.ag-theme-material .ag-ltr .ag-column-drop-horizontal-icon{margin-right:24px}.ag-theme-material .ag-rtl .ag-column-drop-horizontal-icon{margin-left:24px}.ag-theme-material .ag-column-drop-vertical-list{padding-bottom:8px;padding-right:8px;padding-left:8px}.ag-theme-material .ag-column-drop-vertical-cell{margin-top:8px}.ag-theme-material .ag-column-drop-vertical{min-height:50px;max-height:150px}.ag-theme-material .ag-column-drop-vertical-icon{margin-left:8px;margin-right:8px}.ag-theme-material .ag-column-drop-vertical-list{position:relative}.ag-theme-material .ag-column-drop-vertical-empty-message{position:absolute;top:0;bottom:0;left:0;right:0;overflow:hidden;margin-top:8px}.ag-theme-material .ag-select-agg-func-popup{border-radius:2px;box-shadow:0 3px 1px -2px rgba(0,0,0,.2),0 2px 2px 0 rgba(0,0,0,.14),0 1px 5px 0 rgba(0,0,0,.12);background:#fff;background:var(--ag-background-color,#fff);height:140px;padding:0}.ag-theme-material .ag-select-agg-func-virtual-list-item{cursor:default;line-height:40px;padding-left:16px}.ag-theme-material .ag-select-agg-func-virtual-list-item:hover{background-color:#eee;background-color:var(--ag-selected-row-background-color,#eee)}.ag-theme-material .ag-chart-menu{border-radius:2px;background:#fff;background:var(--ag-background-color,#fff)}.ag-theme-material .ag-chart-menu-icon{opacity:.5;line-height:24px;font-size:24px;width:24px;height:24px;margin:2px 0;cursor:pointer;border-radius:2px;color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-material .ag-chart-menu-icon:hover{opacity:1}.ag-theme-material .ag-chart-mini-thumbnail{border:1px solid #e2e2e2;border-color:var(--ag-secondary-border-color,var(--ag-border-color,#e2e2e2));border-radius:5px;margin:5px}.ag-theme-material .ag-chart-mini-thumbnail:nth-last-child(3),.ag-theme-material .ag-chart-mini-thumbnail:nth-last-child(3)~.ag-chart-mini-thumbnail{margin-left:auto;margin-right:auto}.ag-theme-material .ag-ltr .ag-chart-mini-thumbnail:first-child{margin-left:0}.ag-theme-material .ag-ltr .ag-chart-mini-thumbnail:last-child,.ag-theme-material .ag-rtl .ag-chart-mini-thumbnail:first-child{margin-right:0}.ag-theme-material .ag-rtl .ag-chart-mini-thumbnail:last-child{margin-left:0}.ag-theme-material .ag-chart-mini-thumbnail.ag-selected{border-color:#ff4081;border-color:var(--ag-minichart-selected-chart-color,var(--ag-checkbox-checked-color,var(--ag-material-accent-color,#ff4081)))}.ag-theme-material .ag-chart-settings-card-item{background:rgba(0,0,0,.87);background:var(--ag-foreground-color,rgba(0,0,0,.87));width:8px;height:8px;border-radius:4px}.ag-theme-material .ag-chart-settings-card-item.ag-selected{background-color:#ff4081;background-color:var(--ag-minichart-selected-page-color,var(--ag-checkbox-checked-color,var(--ag-material-accent-color,#ff4081)))}.ag-theme-material .ag-chart-data-column-drag-handle{margin-left:8px}.ag-theme-material .ag-charts-settings-group-container{padding:8px}.ag-theme-material .ag-charts-data-group-container{padding:16px 12px 2px}.ag-theme-material .ag-charts-data-group-container>*{margin-bottom:14px}.ag-theme-material .ag-charts-format-top-level-group-container{margin-left:16px;padding:8px}.ag-theme-material .ag-charts-format-top-level-group-item{margin:8px 0}.ag-theme-material .ag-charts-format-sub-level-group-container{padding:16px 12px 2px}.ag-theme-material .ag-charts-format-sub-level-group-container>*{margin-bottom:14px}.ag-theme-material .ag-charts-group-container.ag-group-container-horizontal{padding:8px}.ag-theme-material .ag-chart-data-section,.ag-theme-material .ag-chart-format-section{display:flex;margin:0}.ag-theme-material .ag-chart-menu-panel{background-color:#fafafa;background-color:var(--ag-control-panel-background-color,#fafafa)}.ag-theme-material .ag-ltr .ag-chart-menu-panel{border-left:1px solid #e2e2e2;border-left-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-rtl .ag-chart-menu-panel{border-right:1px solid #e2e2e2;border-right-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-date-time-list-page-title{flex-grow:1;text-align:center}.ag-theme-material .ag-date-time-list-page-column-label,.ag-theme-material .ag-date-time-list-page-entry{text-align:center}.ag-theme-material .ag-checkbox-input-wrapper{font-family:agGridMaterial;font-size:18px;line-height:18px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:18px;height:18px;background-color:var(--ag-checkbox-background-color);border-radius:2px;display:inline-block;vertical-align:middle;flex:none}.ag-theme-material .ag-checkbox-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-material .ag-checkbox-input-wrapper:active,.ag-theme-material .ag-checkbox-input-wrapper:focus-within{outline:none;box-shadow:0 0 0 5px rgba(32,33,36,.122)}.ag-theme-material .ag-checkbox-input-wrapper.ag-disabled{opacity:.5}.ag-theme-material .ag-checkbox-input-wrapper:after{content:"\\f108";color:#333;color:var(--ag-checkbox-unchecked-color,#333);position:absolute;top:0;left:0;pointer-events:none}.ag-theme-material .ag-checkbox-input-wrapper.ag-checked:after{content:"\\f106";color:#ff4081;color:var(--ag-checkbox-checked-color,var(--ag-material-accent-color,#ff4081));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-material .ag-checkbox-input-wrapper.ag-indeterminate:after{content:"\\f107";color:#333;color:var(--ag-checkbox-indeterminate-color,var(--ag-checkbox-unchecked-color,#333));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-material .ag-toggle-button-input-wrapper{box-sizing:border-box;width:36px;height:18px;background-color:#333;background-color:var(--ag-toggle-button-off-background-color,var(--ag-checkbox-unchecked-color,#333));border-radius:9px;position:relative;flex:none;border:1px solid #333;border-color:var(--ag-toggle-button-off-border-color,var(--ag-checkbox-unchecked-color,#333))}.ag-theme-material .ag-toggle-button-input-wrapper input{opacity:0;height:100%;width:100%}.ag-theme-material .ag-toggle-button-input-wrapper:focus-within{outline:none;box-shadow:0 0 0 5px rgba(32,33,36,.122)}.ag-theme-material .ag-toggle-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-material .ag-toggle-button-input-wrapper.ag-checked{background-color:#ff4081;background-color:var(--ag-toggle-button-on-background-color,var(--ag-checkbox-checked-color,var(--ag-material-accent-color,#ff4081)));border-color:#ff4081;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-material-accent-color,#ff4081)))}.ag-theme-material .ag-toggle-button-input-wrapper:before{content:" ";position:absolute;top:-1px;left:-1px;display:block;box-sizing:border-box;height:18px;width:18px;background-color:#fff;background-color:var(--ag-toggle-button-switch-background-color,var(--ag-background-color,#fff));border-radius:9px;transition:left .1s;border:1px solid #333;border-color:var(--ag-toggle-button-switch-border-color,var(--ag-toggle-button-off-border-color,var(--ag-checkbox-unchecked-color,#333)))}.ag-theme-material .ag-toggle-button-input-wrapper.ag-checked:before{left:calc(100% - 18px);border-color:#ff4081;border-color:var(--ag-toggle-button-on-border-color,var(--ag-checkbox-checked-color,var(--ag-material-accent-color,#ff4081)))}.ag-theme-material .ag-radio-button-input-wrapper{font-family:agGridMaterial;font-size:18px;line-height:18px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:18px;height:18px;background-color:var(--ag-checkbox-background-color);border-radius:2px;display:inline-block;vertical-align:middle;flex:none;border-radius:18px}.ag-theme-material .ag-radio-button-input-wrapper input{-webkit-appearance:none;opacity:0;width:100%;height:100%}.ag-theme-material .ag-radio-button-input-wrapper:active,.ag-theme-material .ag-radio-button-input-wrapper:focus-within{outline:none;box-shadow:0 0 0 5px rgba(32,33,36,.122)}.ag-theme-material .ag-radio-button-input-wrapper.ag-disabled{opacity:.5}.ag-theme-material .ag-radio-button-input-wrapper:after{content:"\\f124";color:#333;color:var(--ag-checkbox-unchecked-color,#333);position:absolute;top:0;left:0;pointer-events:none}.ag-theme-material .ag-radio-button-input-wrapper.ag-checked:after{content:"\\f125";color:#ff4081;color:var(--ag-checkbox-checked-color,var(--ag-material-accent-color,#ff4081));position:absolute;top:0;left:0;pointer-events:none}.ag-theme-material input[class^=ag-][type=range]{-webkit-appearance:none;width:100%;height:100%;background:none;overflow:visible}.ag-theme-material input[class^=ag-][type=range]::-webkit-slider-runnable-track{margin:0;padding:0;width:100%;height:3px;background-color:#e2e2e2;background-color:var(--ag-border-color,#e2e2e2);border-radius:0;border-radius:2px}.ag-theme-material input[class^=ag-][type=range]::-moz-range-track{margin:0;padding:0;width:100%;height:3px;background-color:#e2e2e2;background-color:var(--ag-border-color,#e2e2e2);border-radius:0;border-radius:2px}.ag-theme-material input[class^=ag-][type=range]::-ms-track{margin:0;padding:0;width:100%;height:3px;background-color:#e2e2e2;background-color:var(--ag-border-color,#e2e2e2);border-radius:0;border-radius:2px;color:transparent;width:calc(100% - 2px)}.ag-theme-material input[class^=ag-][type=range]::-webkit-slider-thumb{margin:0;padding:0;-webkit-appearance:none;width:18px;height:18px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #333;border-color:var(--ag-checkbox-unchecked-color,#333);border-radius:18px;-webkit-transform:translateY(-7.5px);transform:translateY(-7.5px)}.ag-theme-material input[class^=ag-][type=range]::-ms-thumb{margin:0;padding:0;-webkit-appearance:none;width:18px;height:18px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #333;border-color:var(--ag-checkbox-unchecked-color,#333);border-radius:18px}.ag-theme-material input[class^=ag-][type=range]::-moz-ag-range-thumb{margin:0;padding:0;-webkit-appearance:none;width:18px;height:18px;background-color:#fff;background-color:var(--ag-background-color,#fff);border:1px solid #333;border-color:var(--ag-checkbox-unchecked-color,#333);border-radius:18px}.ag-theme-material input[class^=ag-][type=range]:focus{outline:none}.ag-theme-material input[class^=ag-][type=range]:focus::-webkit-slider-thumb{box-shadow:0 0 0 5px rgba(32,33,36,.122);border-color:#ff4081;border-color:var(--ag-checkbox-checked-color,var(--ag-material-accent-color,#ff4081))}.ag-theme-material input[class^=ag-][type=range]:focus::-ms-thumb{box-shadow:0 0 0 5px rgba(32,33,36,.122);border-color:#ff4081;border-color:var(--ag-checkbox-checked-color,var(--ag-material-accent-color,#ff4081))}.ag-theme-material input[class^=ag-][type=range]:focus::-moz-ag-range-thumb{box-shadow:0 0 0 5px rgba(32,33,36,.122);border-color:#ff4081;border-color:var(--ag-checkbox-checked-color,var(--ag-material-accent-color,#ff4081))}.ag-theme-material input[class^=ag-][type=range]:active::-webkit-slider-runnable-track{background-color:#ff4081;background-color:var(--ag-input-focus-border-color,var(--ag-material-accent-color,#ff4081))}.ag-theme-material input[class^=ag-][type=range]:active::-moz-ag-range-track{background-color:#ff4081;background-color:var(--ag-input-focus-border-color,var(--ag-material-accent-color,#ff4081))}.ag-theme-material input[class^=ag-][type=range]:active::-ms-track{background-color:#ff4081;background-color:var(--ag-input-focus-border-color,var(--ag-material-accent-color,#ff4081))}.ag-theme-material input[class^=ag-][type=range]:disabled{opacity:.5}.ag-theme-material .ag-filter-toolpanel-header,.ag-theme-material .ag-filter-toolpanel-search,.ag-theme-material .ag-header-row,.ag-theme-material .ag-panel-title-bar-title,.ag-theme-material .ag-side-button-button,.ag-theme-material .ag-status-bar{font-size:12px;font-weight:600;color:rgba(0,0,0,.54);color:var(--ag-header-foreground-color,var(--ag-secondary-foreground-color,rgba(0,0,0,.54)))}.ag-theme-material .ag-tab{height:36px}.ag-theme-material .ag-column-drop-horizontal,.ag-theme-material .ag-tabs-header{background-color:#eee;background-color:var(--ag-subheader-background-color,#eee)}.ag-theme-material .ag-tabs-body{padding:4px 0}.ag-theme-material .ag-tabs-body .ag-menu-list{padding-top:0;padding-bottom:0}.ag-theme-material .ag-header-cell,.ag-theme-material .ag-header-group-cell{transition:background-color .5s}.ag-theme-material .ag-row-last .ag-cell-inline-editing{bottom:0}.ag-theme-material .ag-cell-inline-editing{padding:8px;height:72px}.ag-theme-material .ag-side-button-button{color:rgba(0,0,0,.54);color:var(--ag-secondary-foreground-color,rgba(0,0,0,.54))}.ag-theme-material .ag-column-drop-vertical{border-bottom:1px solid #e2e2e2;border-bottom-color:var(--ag-border-color,#e2e2e2);padding-top:8px}.ag-theme-material .ag-column-drop-vertical.ag-last-column-drop{border-bottom:none}.ag-theme-material .ag-column-drop-vertical-cell{margin-left:0}.ag-theme-material .ag-set-filter-select-all{border-bottom:1px solid #e2e2e2;border-bottom-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-column-drop-vertical-empty-message{font-size:12px;font-weight:600;color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38))}.ag-theme-material .ag-ltr .ag-column-drop-vertical-empty-message{padding-left:34px;padding-right:8px}.ag-theme-material .ag-rtl .ag-column-drop-vertical-empty-message{padding-right:34px;padding-left:8px}.ag-theme-material .ag-status-bar{border:1px solid #e2e2e2;border-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-column-panel-column-select{border-top:1px solid #e2e2e2;border-top-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-column-select,.ag-theme-material .ag-column-select-header{border-bottom:1px solid #e2e2e2;border-bottom-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-column-select-header{height:56px}.ag-theme-material .ag-group-title-bar{padding:6px 8px}.ag-theme-material .ag-charts-format-sub-level-group-title-bar{padding:4px 8px}.ag-theme-material .ag-chart-data-section,.ag-theme-material .ag-chart-format-section{padding-bottom:4px}.ag-theme-material .ag-group-toolbar{background-color:hsla(0,0%,93.3%,.5)}.ag-theme-material input[class^=ag-]:not([type]),.ag-theme-material input[class^=ag-][type=date],.ag-theme-material input[class^=ag-][type=datetime-local],.ag-theme-material input[class^=ag-][type=number],.ag-theme-material input[class^=ag-][type=tel],.ag-theme-material input[class^=ag-][type=text],.ag-theme-material textarea[class^=ag-]{background:transparent;color:rgba(0,0,0,.87);color:var(--ag-foreground-color,rgba(0,0,0,.87));font-family:inherit;font-size:inherit;height:40px;padding-bottom:8px;border-width:0;border-bottom:2px solid #e2e2e2;border-bottom-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material input:focus[class^=ag-]:not([type]),.ag-theme-material input:focus[class^=ag-][type=date],.ag-theme-material input:focus[class^=ag-][type=datetime-local],.ag-theme-material input:focus[class^=ag-][type=number],.ag-theme-material input:focus[class^=ag-][type=tel],.ag-theme-material input:focus[class^=ag-][type=text],.ag-theme-material textarea:focus[class^=ag-]{border-bottom:2px solid #3f51b5;border-bottom-color:var(--ag-material-primary-color,#3f51b5);outline:none;box-shadow:none}.ag-theme-material input:not([type])[class^=ag-]::-webkit-input-placeholder,.ag-theme-material input[type=date][class^=ag-]::-webkit-input-placeholder,.ag-theme-material input[type=datetime-local][class^=ag-]::-webkit-input-placeholder,.ag-theme-material input[type=number][class^=ag-]::-webkit-input-placeholder,.ag-theme-material input[type=tel][class^=ag-]::-webkit-input-placeholder,.ag-theme-material input[type=text][class^=ag-]::-webkit-input-placeholder,.ag-theme-material textarea[class^=ag-]::-webkit-input-placeholder{color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38))}.ag-theme-material input:not([type])[class^=ag-]::-moz-placeholder,.ag-theme-material input[type=date][class^=ag-]::-moz-placeholder,.ag-theme-material input[type=datetime-local][class^=ag-]::-moz-placeholder,.ag-theme-material input[type=number][class^=ag-]::-moz-placeholder,.ag-theme-material input[type=tel][class^=ag-]::-moz-placeholder,.ag-theme-material input[type=text][class^=ag-]::-moz-placeholder,.ag-theme-material textarea[class^=ag-]::-moz-placeholder{color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38))}.ag-theme-material input:not([type])[class^=ag-]:-ms-input-placeholder,.ag-theme-material input[type=date][class^=ag-]:-ms-input-placeholder,.ag-theme-material input[type=datetime-local][class^=ag-]:-ms-input-placeholder,.ag-theme-material input[type=number][class^=ag-]:-ms-input-placeholder,.ag-theme-material input[type=tel][class^=ag-]:-ms-input-placeholder,.ag-theme-material input[type=text][class^=ag-]:-ms-input-placeholder,.ag-theme-material textarea[class^=ag-]:-ms-input-placeholder{color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38))}.ag-theme-material input:not([type])[class^=ag-]::-ms-input-placeholder,.ag-theme-material input[type=date][class^=ag-]::-ms-input-placeholder,.ag-theme-material input[type=datetime-local][class^=ag-]::-ms-input-placeholder,.ag-theme-material input[type=number][class^=ag-]::-ms-input-placeholder,.ag-theme-material input[type=tel][class^=ag-]::-ms-input-placeholder,.ag-theme-material input[type=text][class^=ag-]::-ms-input-placeholder,.ag-theme-material textarea[class^=ag-]::-ms-input-placeholder{color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38))}.ag-theme-material input:not([type])[class^=ag-]::placeholder,.ag-theme-material input[type=date][class^=ag-]::placeholder,.ag-theme-material input[type=datetime-local][class^=ag-]::placeholder,.ag-theme-material input[type=number][class^=ag-]::placeholder,.ag-theme-material input[type=tel][class^=ag-]::placeholder,.ag-theme-material input[type=text][class^=ag-]::placeholder,.ag-theme-material textarea[class^=ag-]::placeholder{color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38))}.ag-theme-material input:disabled[class^=ag-]:not([type]),.ag-theme-material input:disabled[class^=ag-][type=date],.ag-theme-material input:disabled[class^=ag-][type=datetime-local],.ag-theme-material input:disabled[class^=ag-][type=number],.ag-theme-material input:disabled[class^=ag-][type=tel],.ag-theme-material input:disabled[class^=ag-][type=text],.ag-theme-material textarea:disabled[class^=ag-]{border-bottom:1px solid #e2e2e2;border-bottom-color:var(--ag-border-color,#e2e2e2)}.ag-theme-material .ag-standard-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:transparent;border:0;color:#3f51b5;color:var(--ag-material-primary-color,#3f51b5);font-family:inherit;font-size:inherit;margin:0;padding:0;text-transform:uppercase}.ag-theme-material .ag-standard-button:disabled{color:rgba(0,0,0,.38);color:var(--ag-disabled-foreground-color,rgba(0,0,0,.38));background-color:var(--ag-input-disabled-background-color);border-color:var(--ag-input-disabled-border-color)}.ag-theme-material .ag-dnd-ghost{font-size:12px;font-weight:600}.ag-theme-material .ag-filter-toolpanel-header{height:32px}.ag-theme-material .ag-filter-toolpanel-group-level-0-header{height:56px}.ag-theme-material .ag-overlay-no-rows-wrapper.ag-layout-auto-height{padding-top:60px}',""]),e.exports=t},function(e,t,o){var r=o(27),a=o(174);"string"==typeof(a=a.__esModule?a.default:a)&&(a=[[e.i,a,""]]);var n={insert:"head",singleton:!1};r(a,n);e.exports=a.locals||{}},function(e,t,o){(t=o(28)(!1)).push([e.i,'@font-face{font-family:agGridAlpine;src:url("data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABNkAAsAAAAAIqAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlMAAAReYc5joU9TLzIAAANcAAAAQAAAAFZWUVJ5Y21hcAAAA5wAAAHqAAAFgHCsDfxnbHlmAAAFiAAACesAABCUC9Ir6mhlYWQAAA90AAAANAAAADZ2zsSBaGhlYQAAD6gAAAAeAAAAJAfSBC5obXR4AAAPyAAAABcAAAEou4D/+2xvY2EAAA/gAAAAbwAAAJbPsst2bWF4cAAAEFAAAAAfAAAAIAFgAHNuYW1lAAAQcAAAATUAAAJG5xgJvXBvc3QAABGoAAABuQAAApPSPvKNeJx9k81SE1EQhc9kQgwJBkREjREU//GPYX4yJiGQMAFisXDhwoUbXGhpUa54Atc+gOUD+BQ+geXSlQ/gA1g+gN/tTAyyIFOZubf79Onuc/vKk1TRmroqZDv7z1U7PDh6r7qKGv2c//jaO3z75kDl8Q5f0b5lef4f1bSiFzrSN0/ea+9zoeQX/K6/73/wP/k/5IO6pkegq1rnCRXxDhQrUVOpCiphC1k/UQu0z7tt1nktaso8mQa6QM6QmIExruqpbmkOnr7x9LQJKuZxnD3euzy3NXsKItUd+BOq2cDqWBvUeU7T2qHGHnV0iG7hncO3ReaAmD6+PrX5hiqajnt6SeS89eYikxwX8w+1bfvAdkuoMEa14W/C7/gek3Vsb5IpIuIh7Amobq7hKv8q3hhMQGzHNHPRSyAjKoy1zMp1FtHZjG7C/kyvdJ+47TymZyqOer5H9RN73/hS8hy3duDaBfuAGiZWdyJ3yRVoiL/CSWV6p4/6oq/6rp/6pd/gF8kSWQebcG+dqsw0+p1EZ3jb/6yu0zOcxUnU/4gKfTdNmxDfIFfQZZvB57SJWQdYY8NX4XT4jGpS9Jpi8gLLG2Etsd9gH4Ku5dPY4jlrOg+YATcBdbRY5+2YRvOWsr9MtFuN6rpoarXguWSn5TR1N2nWdm7m3SnX0fkK34DOEtNnD+9VLI5pYmlYVErVjmMNf0q1k2yuqgZVRcxA2SZraLcgI9N1+hhVEumG3YChTdUKFST5jVzQeau+k5/UguFCi/JQIshvcmyauUnuU5ubit2/LKNqzAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMb0GmMDCC5ADUogpqeJy11IdSWkEYxfE/RdNM79X0jgJiQIogIMhjmO6Y4pju5CnzJt8LxJzlnjyAmcnO/Fh2udy9O3fPB8wABXkqRcgXyZHab83mpvMFjk7ni/zSeI7D5PW9xBY77EV5f1+zJTbZZjdy09HfltPVc1zjPs80WqNClxZ9aoyp0tHsKm0GNKizzhJNlhkyYYUeIzb0/7xWLzLLIa16RM9xTPc7zglOcorTnOEs5zjPBS5yictc4apWu84N5rnJLW5zh7vc0/oPeMgjHvNE+ynp9wUWKesBZzlYWzvg9alVuq1+bVztaLftQaOujTaXh5OV3mjjH272H9pc+ij89GhCepuZtNtNq8hz68oLa8lL68srq8lrG8sbq8pb68iWpROybavyztry3gbywRry0eqyY+uya0vyyZry2Zbliw3lq6W9f7MV+W49+WEj2TO9wMhlUlYinyH1hUzKVhQzKV8xk9GZJkynmzCdc8J04glLGQxTCghLby9MySBMGSFMaSFMuSFMCSJMWSJMqSJM+SJMSSNMmSNM6SNMOSRMiSRM2SRMKSVMeSVMySVMGSVMaSZMuSZMCSdMWSdMqSdM+SdMlYAw1QTCVB0IU50gTBWDMNUOwlRFCEt1MyxlJmz6/AsZUr+YIfXlDOU/rrOgigAAeJzFF21sU9f1nntjvzgJSRx/vJgQg/3ivNSxwxL7+dkx2JAEEmhIqWpYCqMhMCbWdFppM7EBbsd+dEVV1apS6A/yY9O2oFVaQEOb+sFKtZaRqh/qVLQf/fixdkxkXbNRodIZ3mXnXttpApnW/Zr93rnn3nt8zrnnni8TIPihcyxKqgmBgEdVPAEjYOoBOsdrCgW4yu9HeJxFs4VCJlMoCHLbzes3r7NP2afEhr+qIx7SRIhLURXdtJkChhAwVaAuXcBPnn028uqrNIMg8iwfHR4eXidXInKBPrFgMnzv8DD/YiE9qiWEsh7WQypRjmo6Y07VhJPds7nLaX4GrqZnuQ2uz6ZhCx5F0k6wCeImq/CnQcWu2N2qV/V2mQkzEddb9VaXoqOSqBnqBlcPjI6YqZQ5MvpRGRnpPn68e2JCQjaxaEsi1uvlXYTk/yOTle6tFjFF3l3MqekxjyZG+G0+fzafh4P5PFtmvY0XeJAfK+t5mV0mLuITtx2sBY/T7YdYoCsDhjPeAQ4wVVDZD2587o/58WFVcrTm+N+GZmBqiF3G+aLNG5+Dd+gCTN21mL+6NH+GznUb9yetizRyO2fr4oMLeTLJ0xlwhpbiizxZ1S18i4vfvZVv0Xbs++yb6L+VpJEQByiqA5i5Euzi6jxub1fCENdGP+Ej3Xu5BZmZmQunq6t9dd7ODZ3eOh/8Hn6axg3+KqydmcksW+ZvavUFOzuDvtAKv2BfIWVEMa6K91NHSCjgDNg0Z8ylOdPg1Jwsaj1FD/DN8q5eyhdoLM+PiZsq3lbJ7+lp5GFDHSm6DxyEFL+AYcii/AKfKcVj8Tw/ZOfwND7SLC1v92CUBFSJuL1oqATaqVVzoQ70NK/ROnNwNc8NoTK8gVADbsAb7OXOoPUC7b+nU7NeEHu0X+u09tH+Ugw+zZ4WvuYANJfiAB3dBa7Cvb18Cnb08pN8qhd2IKCJRVPYgSTkljgGXUEb6Aqw9TKQYYsIZLjObbMY1IvPHkKBioq2moEk5qGzkIRUduHZn8A4aCIdZK3ga6qJWJcfVoJSCyIp2ZUOuhrMDKg499NYl6nbtWAHGHFTVxNI6VbUhNlBg9C4NjKwfWT75HgzY+6+aDRi7hr7+uT4iooKz9BotM+9fPTowN2b0mGjfVM4UJlsuWdT2D0w1OLbc/RJ+nP87R19h7dWVZu7tI5IIgbQd2hrddWafY7me7rW7zVbuleG+9uN9t1Jd3gg1zKQ3omLC/SvxdwRRf3RpYUyUtdQhpZOQlHh1WDDTfR23ETvpxX9R/f4UPhTR0eXo2r8/IrxyV9J5ZslsqICfhzeFA5v2iYA+My961FkEV7aerhPaFtVGidRp4GwBKWYG0PbK2QZaqR4FKduBGyqxzRMNlZ4qUBPWdPvZ9+jc4XJszBcyGbffy8z+T4p50J6jc7hvTnkbeiKKnISvfbKK+lCgRu5HBjnzqVlbakhNcU4QfpynIjc0URWEo3opJ2sJsTUjJi64A39lznWqbPZ7EsSWm/9p0khX/xkS2OmNKI6lfPnv1UnAlgdQ/i6UI6Br46vWFNwDODIxoSPWm9LViiCnuIziMFv+Aw9IOXyzVmUleXHUIVMJrOEzVzo61iA0WZXpMngYC5Hz0iT8RpyWxxhscYw1ANsfTF0YIsII+qf7eZn+Jnu2XKMTNDzWJ8aSQQlxDOQBkMr+pHEOkDF1BzSPBg6tBbaARHpaz8LrtGmplK7k8ndqakpbU3wORjiv4aDEgdtfhOuamntruTIQyPJu7S0kptCuFGs7D4wkpQ2vXmTzco8fotNA5gTRXG0ic4BlbCJBqQ0F/mSLh8cPHbNvEbbzWsmJpQ3IW4NCrgL5/QT3OFvDg5CvBUxfMy1g4OD4zjic+2PEC/XkOfYc6iFU+bhmAfQKTEZagbogPWSHxsG2sP5h1g07+W8B+gHWTj4oVxjLn7sA7k2n2++9Fe0vzH/LWb08gspvOd8piz/HfZOUf682HlFsvNC0X/KmgilimL/VNZkviZMF/OiSG8qwPfSnKchxaI4dkOy5E+XWL3sz0SmVbG0KaL5oJeuXImcPx+RkPrl8JiE82cr9jEBzKZLdzIQF2isy6tCB0CwVQc/eNyCcKm+hvdEI4Nbdqb2t/NosAW2IALvBlvE4lJtDh/ZuWUwEm0J8mj7fv73liC8274/JdfK+j2Adc6LfqOjfhrmQrui3VLkAl1etz3YGk+AMHDAiLHGU8vWbV237JQsaQMC8g+cPl/Q5wPDej4HP8mxsVBHRwir3z5JcyLY2ag14mM10BMiKRTv8Ag7TIKlKpMoflWzVQxZAMWOhkZTKfY6NLkuegm0eitaBgQFliDVG/MiqsPdz2D2tjmau1ebeyvranwNqhv8nnUb9gNQ5vZE1eN/icAll6Omsn4y0dblhOWVKoVKOlFZVV1X21B/ER55xlFdXVfTVu2oHl3ub2xyNdTyj1Zsq9lnt/mM9q+p1ciBPlVf76r1TtYy1sT/anfrjfGG4xUVoFQ2XBTHqZJnmmbTGImrSBtZTzaSO0mO7CSj5Ft4Rj9VG1gtVSpCHVSnrgw1W2wBpxcrqZmwuVVRmAzpVorucWO90lQ58UrDhNxqzMDaGzPMMKBFYpioPTG9A/SQXVM8MbMVcw1ztm0IA6oU3tDGP+YffzmDZjhkXfjHnBanDqsSaFxbBS9WRbblIo7wxrZxR2TbtkjVupau5X6wXocjhwHy2fidSYBDWfjdIUGP5kiFHz2X7H+U/XJJ/s1ydsN63e5A8rm3nPUoDA5DnWTueLCtv506IjmUAzbF5Q37NyYfeXmz8ei/EqGR7JEjQaRmAEfy8MhtcSkzMp1O8wuQSnP6WVp0a92cLOxn3eSOcoTVC7dZJcxWLyKMBQWUYdYldkrB9fj4gd6+vt4D41Bfxh7/zq4dhmkaO3a9V0bYZbHB/7mY+MaRRUQSKcWT0KUG4z0htJEFoZj49f9Btb6He3sfflyAvq+mJZ0r0SMofGWFb6t9iopFV6TABf8BZT85241/BovnG2Rjsq7KTkbkQPyXG5AdSTEXWh/T09ZWTNYZmJUL/GSWzllvl2UxekLcmssBl6AO6ugJrH5Dpfs+wZjYc9DiKmP8Cr+yeA97V2xtsWTKXy/Ns0hQ2vsFc8l+X/TYJtwPX/Ra5/mfe6BJYH+AlT0luijtFSd04WnOyoLTc9+8faJ0ulgfdOzS6WeyLECKTmOdEC65INePYUXykC6RS0XpB4/Xrqj4pwodAOM5Jnpmz5c9ghFPmCoSqviYQF8rNgFmeG08m9y95xu5Suv5H3UPlDuFns7tKx8aGTgZt/rpa9gOaJEN1Wub9qxJjSSncvDA0cZvr0vJbkHr3GzbnrsPKemLhPwbDwYCEQB4nGNgZGBgAOLsD0FR8fw2Xxm4mV8ABaI4H+9rgNH/f///zfyW+S1QJQcDE5BkAACRug+HeJxjYGRgYH7BwAAi///+/5v5LQMjAyrwAgCe2QcHAAB4nGNgYGBgfgHC/39D6KGH6QEAIHUuCwB4nGNgAAIphiCGDIZFDHcYvjGqMQYwVjGuYTzH+IhJhMmMyYcpgekAMxezBrMDcxfzIeZbzJ9YTFiKWGawbGK5wfKKlY01jHUK6z+2JWw72P6xR7Dnsfexz2Ffxb6D/Rj7LfYX7H84vEiHANyaI6IAeJxjYGRgYPBiSGfgYQABJiDmAkIGhv9gPgMAGzsB1AB4nHWRPU7DQBCFnxMniBghJCREx1Y0SM5PQZEuFHGfIgWdE68dR7bXWm8ipeMYnIBjUHIETsEheDFTREjZ1a6/+fbNNAZwgy94OC4PV+19XB1csPrjLulW2Cc/CPcQ4Em4T/8sPKB9EQ7YWXKC51/S3ONNuINrvAt36T+EffKncA93+Bbu0/8ID7D0fOEAj95rnEU2T2ZFnVd6obNdEdtTdcpLbZvcVGocjk51pCttY6cTtTqoZp9NnEtVak2p5qZyuiiMqq3Z6rULN87V0+EwFR+uTYkYGSJY5EgwQ4GaVEFjwZNhRxPz9VzqnF/yWDSsDGuFMUKMzqYjnqrtiOH4TdixwoF3gz17JrQOKeuUGcO/ojBvJx/TBbehqdu3Lc2aPsSm7aoxxZA7/ZcPmeKkXwK+aWkAAAB4nG2S6W7bMBCE/cWSI9tpk7ptet/3obbpfaf3kT4FQ9EyEYkUSMp28vRl4yBAgO4fzgwWs7MLdpY6ixp0/l9bLNElIaXHMhl9BgxZ4RjHWWWNE4w4ySlOs84ZznKO81zgIpe4zBWuco3r3OAmt7jNHe5yj/s84CE5j3jMEzZ4yjOe84KXvOI1b3jLO97zgY9s8onPfOEr3/jOD37yi99s8aczFGXpVCmCtqYnnLMz3xVe9qQwUlXZ4sk3UjkRLqzJiZI723ae7wNVrB8K2hQqKFdrI4IaHcqtOehckbayLm90JG45krY2fiCtCU7IoIpE2mY3lc56nxTKy0zNGxE9i77aVbmvhJ90I+qNdRXHpGPtfEhKp5u0dLZtktgQkkqNQ6/SJs5brqwotCmzWsx1rfdUUivTZjHfghk1D4mxRg2NDbmoKjtTRdpEF9VttEkbPbUha5yaatv6NRfNbL7dhmBNbsfj1aOCSZ0uJyHxYqoGvo52eWFn5gD+izVcwP22bIFj6hDPMQpOqaP36+9LtlEma81iHwQlDkVAYzHM8EgqJuywzTx+g4KaloZdxuwx7XT+AvL3sQsAAAA=") format("woff");font-weight:400;font-style:normal}.ag-icon{font-family:agGridAlpine;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ag-icon-aggregation:before{content:"\\f101"}.ag-icon-arrows:before{content:"\\f102"}.ag-icon-asc:before{content:"\\f103"}.ag-icon-cancel:before{content:"\\f104"}.ag-icon-chart:before{content:"\\f105"}.ag-icon-color-picker:before{content:"\\f109"}.ag-icon-columns:before{content:"\\f10a"}.ag-icon-contracted:before{content:"\\f10b"}.ag-icon-copy:before{content:"\\f10c"}.ag-icon-cross:before{content:"\\f10d"}.ag-icon-desc:before{content:"\\f10e"}.ag-icon-expanded:before{content:"\\f10f"}.ag-icon-eye-slash:before{content:"\\f110"}.ag-icon-eye:before{content:"\\f111"}.ag-icon-filter:before{content:"\\f112"}.ag-icon-first:before{content:"\\f113"}.ag-icon-grip:before{content:"\\f114"}.ag-icon-group:before{content:"\\f115"}.ag-icon-last:before{content:"\\f116"}.ag-icon-left:before{content:"\\f117"}.ag-icon-linked:before{content:"\\f118"}.ag-icon-loading:before{content:"\\f119"}.ag-icon-maximize:before{content:"\\f11a"}.ag-icon-menu:before{content:"\\f11b"}.ag-icon-minimize:before{content:"\\f11c"}.ag-icon-next:before{content:"\\f11d"}.ag-icon-none:before{content:"\\f11e"}.ag-icon-not-allowed:before{content:"\\f11f"}.ag-icon-paste:before{content:"\\f120"}.ag-icon-pin:before{content:"\\f121"}.ag-icon-pivot:before{content:"\\f122"}.ag-icon-previous:before{content:"\\f123"}.ag-icon-right:before{content:"\\f126"}.ag-icon-save:before{content:"\\f127"}.ag-icon-small-down:before{content:"\\f128"}.ag-icon-small-left:before{content:"\\f129"}.ag-icon-small-right:before{content:"\\f12a"}.ag-icon-small-up:before{content:"\\f12b"}.ag-icon-tick:before{content:"\\f12c"}.ag-icon-tree-closed:before{content:"\\f12d"}.ag-icon-tree-indeterminate:before{content:"\\f12e"}.ag-icon-tree-open:before{content:"\\f12f"}.ag-icon-unlinked:before{content:"\\f130"}.ag-icon-row-drag:before{content:"\\f114"}.ag-right-arrow:before{content:"\\f117";content:"\\f126"}',""]),e.exports=t},function(e,t,o){var r=o(27),a=o(176);"string"==typeof(a=a.__esModule?a.default:a)&&(a=[[e.i,a,""]]);var n={insert:"head",singleton:!1};r(a,n);e.exports=a.locals||{}},function(e,t,o){(t=o(28)(!1)).push([e.i,'@font-face{font-family:agGridBalham;src:url("data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABX4AAsAAAAAJ8wAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlEAAAReXgFf/09TLzIAAANcAAAAPgAAAFZWTFJaY21hcAAAA5wAAAHtAAAFgFIH7gFnbHlmAAAFjAAADLgAABYYNphscGhlYWQAABJEAAAALwAAADZ2zsSBaGhlYQAAEnQAAAAbAAAAJAfTBC1obXR4AAASkAAAABIAAAEUp/gAAGxvY2EAABKkAAAAZAAAAIwBFQakbWF4cAAAEwgAAAAfAAAAIAFbAHNuYW1lAAATKAAAATUAAAJG0OP3eXBvc3QAABRgAAABlwAAAlqez14KeJx9k09yElEQxr9hCBKISYwxloga/0bjOAwM/yQQCFKWZWXhwoULN3GhpZVylRO49gCWB/AUnsBy6coDeADLA/jrZpCYRXjFzJvur7/+ul8/BZJKSrSr3OTx/nMtHx4cvVdFeU1/5j++Dw7fvjlQcfaFL+/vooLwj5Z1Qy90pG+BgtfB51whzIW74X74IfwU/lAIalMx6LIesGLVeEZkr6uhVDkVsMXsm2qBDnm23bqmC1pwz1AjrZMzJmbkjNt6qptahWfgPH31QCUs4+zzHLNuaeUURKrb8NdR08VqrFUyrGpRe2jso6NDdAvvCr4dMkfEDPANdA68ofLexyd6iaI1r80i6xku4R/TZfuO/KvMmqHa8DfgN74tss7sDTLViLgHex3Uw6yH27pGdAOePmwdj256dBlkDYWJrrKzympUtkT9PT3TK8+6m8X0vYvTmrdQP7cPnC+l2uPWDlxjsHfRMLfaidwhV6QJ/pI2eL/TR33RV33XT/3Sb53B2sVrFfTg3jm1M0X6dxI9xNv+Z7VKC5zPSdT/iEXqbnhvYnyjrIOWrYxO603CPsKaOL6ETsMPUZNyGnlyRJ63hnWB1eU7Bn02m8YWa8n7PGIGbAIqdKfB05im85bS4Usw2W6qa8O71YLnop+W9dRu0rJ/2czbKVfAXOYdUVnd+/MI7xUsxjS3VD0qRbVx3MefonaezVRVUdX02bXJmvgtGJJpkzqmSmrcXLsBE5+q6yioZzdyndMw9Z3spM47LvaoAM1RdpMT75lN8gBtNhXjv2nbY10AAAB4nGNgZMpnnMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVFgEqgRRAAAy9AKRgAAeJy102dSWzEUhuHXhW56TaN3Y2wwvRkb/rAM0hlSGNKZrDI70QZCvnPPyQLITDTz+Ls6o6srjSygDSjImhQhXySHtd+q5rJ6ge6sXuSX+iU6yeu5whU33KXa/b2qFS655jblst7fltPoEk9ZZEe9I811oKdjqrT0xh4b7LPLCXU2OWWdbWo0OGeLQ5qc6f28vl7UGtvp0He7tJIezdhLH/0MMMgQw4wwyhjjTPCYJ/raM42ZZIppZpjVuDnmWdAalvTcwzIr+l1Vr6wFtvOwdvTA8dbWDnaOq63Knna7e1Lf1Ea3a43zrcPm2T9M9h9ayX4KP6N3gZ2ms91eBvt/PA8H8iLYyb4Mx/IqVOV1aMmbYPO+DXtyFTbkOuzLu7Ar78OJfAh1+Rg25Sacym1Yl09hWz6HmnwJDfkazuVb2JLv4VB+hKbcBR1gyjm7KynvsCw4u1up6Ox+pTZn9y61Oyw7HJadDssuh2W3s/uYehyWJWcnmXodln0Oy36H5YDDctBhOeSwHHZYjjgsRx2WYw7LcYflhMPykdPdJAXdUlLQfSUF3VxSyPY16bCcclhOOyxnHJazDss5l+133mG1BYfVFh1WW3JYbdlhtRWXzbPqsrWVHTZ2zWFjKy4bs+6w96oum7PmKP8BU32drwAAAHic7RhpcBvVeb+3lmRZsm5pJdk6V4ety9YdS/Zu7MTGdu7DCRlC0jQHDTFH0tAwIYJCaCAhDDSZcEwzFDoDGZgpw7TTDNMmpUMZMFNi0hQ6JTD9AbQNaRtCyXQGFy393molxybl+l1pd9/33vve9773ve96j2EZ/LHPss8yHJNm1jMMeAlnYQ1E0xROkSixCqQYUgXVRlDbbZwXuKawAEULm4JohA+qVXyetzs45a/WyH97Np+1B6K5YqGIuIViIRKl/3yANXcMxqCpCWKDHdJ70nvTNfBIfwvPAWCbSI4HL3j5HNHpEF65de5/4CFxCqw6v9fg0JlanEZ/xMBNidJ+aNLYDf0Gu1rt9XVbPAC72KevRBo8cm2gEF77+JIfXF8nrUzDslMia7ToHQ691dI+4Gh1egycSazouuwhm75bbzWa250hm5+fR0UFsrweYR9hfAxj5TTRIqcJmOUiag7IRTFglgvOPDGcOHw4MQytM0vpY6X+5pXbG/2tynzkZdbGNGNFmYeHN/clz5xJ7hPI0X2JM2cS+6Q5lC2Zt23sNsbGdDJ5xA/S7bDRrcnQfcjRfdBkaN1Ge+R9KdAeK9JFykg/WoRLW1aPZbLZzNjq1+rAlrGRoVg8HhsaeYYCEENo7MnkU08ln5S/7LYZ6DIgzESXIenj+gj8Mg2enawTIQ2jQ5lmzTx9i1k7f7pSOb9z5we33EK2SteR4erzU1PTYz5gzzFWJsogmU4IpiBvzgmQDWS8YDfbDMAGggYKeWmbQHtToAGUH7C56vfTK7q7V6RJreyqVjwZDz5kr1x2SOteyz4KN01jpOUR7E88aU91D37wIXfj5yPEzDwKN8/mKf7VeWIDaBdfxlF/9SXS++XsSKlhWV1m8MJAfXo+0GBJdSVOcpcRp5PdNYsL9tzlvbQcms2BIodb2U2MCjXWyTBa0HBaYIs+qPkGmyNTyFNFJH+X1pc2SlUQJiZeeU6ncxkd6cG0w+iCF+GJMnZIv4W+iQmhtdXbFnEF0+mgK9zupeSb5DmSrEHRGSPDhHlz1qq8QN/jovgrQTghitVTgvA2yVQnp9+GHZPDrAr5RB6p3pND0sXE++8n4FKtVNayCO3JyvBMN52lLsByQ6gsekEEHNhSwK4Izi7vuT2A7eSnl+Ij8dhIghbxkcinkUJB/khNc2MjcTgiXRfOV7APsjJCXDqFH5IpRKSXKCr0RgqSnljiw3ExH57m+2XyMrUVmGG1l5kj8V9uZjN9iOKbssSq+BBYWPMhMDFbLrh1Gi2QQygM6SKYyJ+odExgQhSVLJtjbAkl08MsZMaYdYhfKGYxfNSiAOXMANGa7y/KXgbZ5AxgBDlY0KpaFmiuCAKIkCI4ppClgrVpwqgpqJwZEVBbUsAHNcCv32pZ+/SdoVazpc3tj/QlRhY8s2zl/GVpk1Wr05lMCbE3IXQv5CCybMmGzWsdtvbSSO+mcgLu6V7AgXfnkR8v4Esj5c2luDTpjl8V74om3LHhWFeUfJRm2cX3Xt0e9MbaAy4kHLbY7N3lVW0pm9PutffF+xIP+67OkzVCn83uVbe0x8ubyiMl6ff+NXkyfGMfGwxiS+9I6WxHF1J0J6JdcSymdfUYyzNtTIopo6TkCKuISH25eDBWcgZSl05NIhqUBioZSgmViqOSQLv1AIqGWi1UG/JYcMP1N+1YszSjyEL8zTgsvP9GnyKLZXfyVADDpQ2l0oadG3p6NvwxNrxyOCZ/WL6x+MUh3mCcW1qtLHxsU5NI+sYHawv3uG9ZQlfr60ESNTp/gBglEiO1ouF7kmwS8wn0gqCs0wOaYkFZbKQPAiqbkjPYi/maahTybBI6nQNFZ/MJAAIaZ2HA1Um2V081yxCqSK2XnIt2e8rdbq3+uwfHdpR0za50n7c7NCiate50n6c7tLdrRUe3p5R2a80KP2RK1mdtXaNVZt5MPlG0WvqW0FBsh6SHS4y+tgZyoeFfrLiaNoz4vOzbuximyOez3GVv+EvqU7IvmvZIV65MVWo/USkFpUR2mmfkaXm0uT6mnxlkRr5uxmZFblQYc8Kzym+Ymx2tVGCX9Ar0SPsbkB6hS9IoHP9m6Vj1n4IgiMrbiGfTe1jz1tTLk7jisf8sCHWvXf037mBdD3ewbSg5M913dMh061muGMXVFqMkKsJ+aZd4QDoLkcnJdAXelbyVNHlQOCEcgAhEpLOTGdyBTJ3WdowDMWa1rNMoVg0KGN0blWpBhHwkmkY9NwCqtBdzXhHVFVXdGpSxsJF6u5TSQUfbsAOb07Ldy1R44sRYGWhraWkf96zoCOU0aofLomctYVO70WDi43t6Yr7xpNPDxTbFFnm2dXHtXNzbDJqwy66z0CHxInA2C+hYC29ot7Xo5qUinWRQq1e1Le+MeLZ5rK2tfRF+yG1h+bAlZI9u7E6H4m2c0b8tdU855QOtH6neXe72e7U6lW9TkkOqVoNxScqTt8ljAtbQtcn0Eqvp/zK5kkxqNnofe9/n/AZDrYzGaRW+ssXhW1TqGoTRaoWbJxIT8GJiIgGuqanq5NTUAoTJOmxF77FuyocAPokMWsU6LPGZeHpq2j6qpMqoGTwyWH3UQDThLsDsoPgP9q2hHct2wO+UcuIsS8vHaoWS4yTJ6/X8G9A66n82WX0APbDygktEexDrex/EmCbPp0ykTAuvN8kT/bA237/easJiO7zwFju0ffkOZewzmLvV7LKejaA51w43UDqYevts6mA//KIfobe7DsLSvfFTp+J74WR1Ek7WYJyZ0rmL3cU4mAQzh5kr5yAMUFXjHLLaoa5R7SoKhKNVjVrRQwxEsm4hGm2NRrpACw45BnWBwwcgjyoUOTlyccUITF27atkNLfpYZNHI81dfO69vLiFh/4339S8dnn+NVhuOLF98cvFYjG9uXjM0uvqCX61e0jcwmktHYbf0YXa8M2Y0W08O9HRI+0I6p7tQWq4Vchm7w/KZj/0eyaWPrdt8zdI5+bDdIfQ8tnL1aP/GgkgSsfuXji1akoqrYslVI2PLHownX+0bGaoEQxqV2wG3SQ+b2sKRXKn8GvE6pH3iof55nUmVwHZ29Arlz1qUfR1nb0Pt62B6UTLy4U8+ENr5zyf/vCbjsKmDkVwBAsEINhXKYA/ksxkHIqrJdr3B5Vvlcxn0lWBPEB+4VCunzC5X0OUCnaR3h0JuEXYJ7nCY9VhsToPFYnDaLIgkjSqDjuPH7PQ78ak+HnbBcXeoUgm5pVFXuOGz9yDPQYxuDNSzxgLuAS1EoNuloXkD9TRoTzS98IEmgquC2v4VOUdWTi1h2SEgTSqtp9RV3Nhs1LssnA289rmD38HsgrXZk9xDGDj+YtXqm01HCx0ZM7ibOQLN5Ehzi85osJjegNsPYS5l1HfotLoNbq+zzWoxSO+2j+k3q1WufLyb0yEF8oDJZDU4jhpYtk36q9oWdeYsD2Gk0zRb3qDLabksbvtxJ/qZIWYBs5K5htnAbPkfsTtgdsgXJyoavn2Y5tUsw46JoIavXTk4ZMGEbVw2H1VrsvliDFAiWUw87Fmq3WE1r7FnixHenv2iwA67q698eAGjrrbaDBiD/fDLlsTYyoQ2NtSxU5sYG0u0zA1l3F6ovgp7bgOoiLkFmAnsFuHkboqP4uiJ3fHCnKvu+MJQ/2n1VbUW0S+cMptwMrgNjDJx7c0dV8WJNrES5wGVxuqIeYfm3P7r0fwdnxTC68U9e4I0IQDYU4HbG/pxDs+19H5Dud0wUXXwU3GYZt1uBGmdXkIV4NK9O7fPmz9/3vadYKpD9+7asrHU21vauOUCAuUyAuw52iFdnIkszMChQG/9vF/nRfha3My6e5FxviqL8NwVblW+Mt/S6NjMkZTY7FyJ5lfo/DEwcZg0oWePstulswdEaRfsFw+kK5IX3q2kJycx4zp7gGZLB2iaNDmp0BnHnKAVvTID5gDm2TYHOhk8Gavqnp51Vp9fkQ6S4WBa+vl46fTp0vhKJPUOhKR36CkfQu3j5dOny+NwuHHfpiKH5XM6KXJFtkm6KKd6ZAtN3xFgZuMBPRNjvpqopfV31coGzov1Mz+HONKhn+HRd4AcQSB5Dww0aCWJje6yFWVwQg6AVqFx93QDO477Hsf8m7EGMdHG0wxGHXpYRS+LscWK+Y2XoMOKaqbzoSjQzIeTTZteltZgGqT4Y4SECPkRzDlPVDIkTZwnphTncSz/9saQkBT4rTFnQNNsdwtJeKJzsQebzElX1yqL2exD2OdXO9o2zmG34WAVOSpNfIAEQU2OQvE8kW7FVAbxfTIhfZsp1R4abUNCo36ZjoNVZRIda5CO6Fu1tiNdxhX+FyXYf3Z4nGNgZGBgAOJNb47Mjue3+crAzfwCKBDF+XhfA4JmYGB+CRJn4GBgAvEAeqIMgAB4nGNgZGBgfsHAACH//2d+ycDIgApcAXBnBQgAeJxjYGBgYH4xdDA9AADYnCd6AAB4nGNgAIIZDBcYnjE6MEYxLmF8xaTBFMVUw9THdIPpEzMHswzzBhYNlgKWLpYrrEGsOayT2GTYlrE9Ymdgl2K3YI9hf8PhxrGBM4xzDhcTlxpXAFcKVxlXF9cMbh7SIQDoHxaseJxjYGRgYHBlSGfgYQABJiDmAkIGhv9gPgMAGrQBzwB4nHWPP07DMBjFX2haRIsQEhJiwxMLUvpnYOjYodk7dGBzGydtlcSR41bqxjE4Acdg5AicgkPwEr6hQqotOT///N4nBcAtvhCgWQGu27NZF7jk7Y87pDvhkPwo3MUAz8I9+hfhPu1MeMBmwQlBeEXzgDfhC9zgXbhD/yEckj+Fu7jHt3CP/ke4j2UQCg/wFLzqLHbbZKbzjS4WJtvn2p2qU14aV29tqcbR6FTHpjROe5Oo1VHVh2zifapSZws1t6U3eW5V5ezOrH208b6aDoep+GhtC2hkiOGwRcI/18ix4VlgAcOXPe+ar+dS5/ySbYea3qKEwhgRRmfTMdNl29Dw/CZsrHDkWePAzoTWI+U9ZcayoTBvJzfpnNvSVO3bjmZNH3F206owxZA7/ZePmOKkX1qXaMkAAAB4nG2R6W7bMBCE/cWSrThp47ptet/3obbpfadX+h40RclEJFIgKR95+hJ1ESBA9w9nBsvZWbK30VvXqPf/OmCDPgkpA4ZkbDJii21OcZodxpxhwlnOcZ5dLnCRS1zmCle5xnVucJNb3OYOd7nHfR7wkEc85glPyXnGc16wx0te8Zo3vOUd7/nARz7xmS98ZZ9vfOcHP/nFAb97W6KqnKpE0NYMhHN24fvCy4EURqo6lTPhwljOlDyc2mX+F6hi91jQplBBuUYbEdTkWO7Mv85taWvr8lZH4oaRdI3xI2lNcEIGVSTStqtUOut9UigvM7VsRfQsNtVK5b4WftaPaFDqOo5JS+18SCqn27RytmuT2BCSWpVhUGsT52XrI98b1lYU2lRZI5a60UcqaZTpshh0zYw1asvYkIu6tgtVpG10Uv1Wm7TVcxvGLl63+bQLwZrcluXOScGkTlezkHgxVyPfRJe8sAuTrWFMFuLKk+CUOvlGWWfWERFUOBQBjcWwwCOpmXHIlGX8zYKGjpYVJUfMe70/6zKeWwA=") format("woff");font-weight:400;font-style:normal}.ag-icon{font-family:agGridBalham;font-size:16px;line-height:16px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ag-icon-aggregation:before{content:"\\f101"}.ag-icon-arrows:before{content:"\\f102"}.ag-icon-asc:before{content:"\\f103"}.ag-icon-cancel:before{content:"\\f104"}.ag-icon-chart:before{content:"\\f105"}.ag-icon-color-picker:before{content:"\\f109"}.ag-icon-columns:before{content:"\\f10a"}.ag-icon-contracted:before{content:"\\f10b"}.ag-icon-copy:before{content:"\\f10c"}.ag-icon-cross:before{content:"\\f10d"}.ag-icon-desc:before{content:"\\f10e"}.ag-icon-expanded:before{content:"\\f10f"}.ag-icon-eye-slash:before{content:"\\f110"}.ag-icon-eye:before{content:"\\f111"}.ag-icon-filter:before{content:"\\f112"}.ag-icon-first:before{content:"\\f113"}.ag-icon-grip:before{content:"\\f114"}.ag-icon-group:before{content:"\\f115"}.ag-icon-last:before{content:"\\f116"}.ag-icon-left:before{content:"\\f117"}.ag-icon-linked:before{content:"\\f118"}.ag-icon-loading:before{content:"\\f119"}.ag-icon-maximize:before{content:"\\f11a"}.ag-icon-menu:before{content:"\\f11b"}.ag-icon-minimize:before{content:"\\f11c"}.ag-icon-next:before{content:"\\f11d"}.ag-icon-none:before{content:"\\f11e"}.ag-icon-not-allowed:before{content:"\\f11f"}.ag-icon-paste:before{content:"\\f120"}.ag-icon-pin:before{content:"\\f121"}.ag-icon-pivot:before{content:"\\f122"}.ag-icon-previous:before{content:"\\f123"}.ag-icon-right:before{content:"\\f126"}.ag-icon-save:before{content:"\\f127"}.ag-icon-small-down:before{content:"\\f128"}.ag-icon-small-left:before{content:"\\f129"}.ag-icon-small-right:before{content:"\\f12a"}.ag-icon-small-up:before{content:"\\f12b"}.ag-icon-tick:before{content:"\\f12c"}.ag-icon-tree-closed:before{content:"\\f12d"}.ag-icon-tree-indeterminate:before{content:"\\f12e"}.ag-icon-tree-open:before{content:"\\f12f"}.ag-icon-unlinked:before{content:"\\f130"}.ag-icon-row-drag:before{content:"\\f114"}.ag-right-arrow:before{content:"\\f117";content:"\\f126"}',""]),e.exports=t},function(e,t,o){var r=o(27),a=o(178);"string"==typeof(a=a.__esModule?a.default:a)&&(a=[[e.i,a,""]]);var n={insert:"head",singleton:!1};r(a,n);e.exports=a.locals||{}},function(e,t,o){(t=o(28)(!1)).push([e.i,'@font-face{font-family:agGridClassic;src:url("data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABOsAAsAAAAAJiwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlIAAAReYchjok9TLzIAAANcAAAAQQAAAFZWVlJ+Y21hcAAAA6AAAAHtAAAFgHClDfdnbHlmAAAFkAAACi0AABQQq+8lqmhlYWQAAA/AAAAANAAAADZ2z8SBaGhlYQAAD/QAAAAeAAAAJAfTBChobXR4AAAQFAAAABoAAAEou4L/4mxvY2EAABAwAAAAbwAAAJb7HvWgbWF4cAAAEKAAAAAfAAAAIAFgAHhuYW1lAAAQwAAAATMAAAJS8kTiWnBvc3QAABH0AAABtgAAApcplp2DeJx9k0lyE0EQRX+rZSMPyGDMZMRkRpsh3O5BjSTLltzyQHjBggULNmYBAeFg5ROw5gAEB+AUnIBgyYoDcACCA/Ay1UbGC6tC1VWZP3/+yspSIGlSy+qqUmzuPld9f+/gveZV1fBn/qPrYP/tmz3VDnf4qv6tKQj/qK4FvdCBvgUKXgefK+NhJeyGu+GH8FP4QyGoG3oMekorjFgJc6RUmZrKVdE4tpj1E7VAh8xtt87qgsbcU2ig8+SMiRk445Ke6o7OwNN3np7WQKUM4+wxbzHuauYERK578GeoWcVqrA10ntWENtHYQ0eH6BbeGXzrZI6I6eProy10VNXruK2XRM762SwyK3Ep/1gbvo9894AqHKLa8DfhN75Fsh7am2RKiHgEewaqW9Zwif8U3hRMRGzHa2bR10AmKEx1nZWdLOFk07oN+zO98qwbZUzPqzg88yLqR/a+8+XkOWrtwLUF9iEaRla7kfvkirSDf5KbKvROH/VFX/VdP/VLv3UK6ypeO8Ea3OsnVqZG/Y6jC7ztf1Y76Th3fhz1P2KCcze9NjG+QVlByzaFTqtNyjrCmjp+Ep2GL1CTU68qOSLPm2AdY6yyj0GfLruxxZj2Og/oAeuAeWqxwmxMw37L2V+GyVZDXRe9Wi14LvltWU3tJdV9Zz1vtzxPna/wjThZ5vXZxnsVizGNLA2PylFtHMv4c9SOspmqBqoSeqDmnbXjr6Ag003OMVSS6Ja/gB3vqgUUZOWLnNM5V98pb2rOcbFHBWiOypeces2sk/tos67Y+gsvGGrHAAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMnxi4gDQjSA4A1QYKdAAAAHictdQHTltBFIXh3wXTTEnvvRc6hGp6XQbpiBREOsoqs5O7gZBzPScLIFJG+nw9o+c3b/R8LtAB1OSp1KFap0KO31qttNdr9LTX6/zSvEkXVX0fYo8DjmL0+FirQ+yyz2FU2rO/o6Krm1zlPs80W2GMJeZZZZItxmlpdZEF1phhmg0mmGOKdXaYZZlNtvX7qnav6xkbdGrfbj1Jr+7YRz8DDHKaM5zlHOe5wEUucZkr2u0a17nBTW5xmzvc5Z72f8BDHvGYJzrPkD6HNRvRAzY42Vg54fU5xpbmVye3xls67cLazLQOOje1vjO7vLn9Dzf7D6OZH7Wfnu2Qb7PI0+7amDy3JXlh8/LSVuWVTcpr25I3Ni5vrSV7lv+QfVuUd7Yg721NPtiMfLRpObANObQJ+WRz8tmm5Iuty1fLs3+zWfluy/LDNuXI9AKjUmRWolqQtVZktqJeZL6io8jcRaMga2dB1q6CrN0FWXuKzGP0FmRtFvkmo68ga39B1oGCrIMFWU8VyhJhShVhyhdhShphyhxhSh9hyiFhSiRhyiZhSilhyithSi5hyjBhSjNhyjVhSjhhyjphSj1hyj9h6gSEqScQpu5AmPoEYeoRhKl3EKb+QVj2zbDMTFj7muGCrCNF+56jBSN/AHzNoH4AAAB4nO1Ye2xT1xm/37nEN87D8bUdXwezwLWJDZQCtmNfO4FATIgdQhLWGwhrt0DSGJHHpgaawFRatBIVVrXbHxXTWCiPabMHo9MgSH1IGxJMa6b+sbBJFZVK2/HHVNjI6JZ2k8W97DvHjzyggPrntBufe17fPec73/md3/edcMDhw4f4fs7IcSBLglwuW3mZD+mj+/ZBQtv//vtkhPxuYiIFe2EvijD5T/lPuUVYCQpeRRK8oswyRRZZJokyywQZLrXFxscbNwPf1oh5m65txjzWpuu0PdYGhF9k/LIuWm/czOXm3Mq/whViRfAaMYlu+NkbCeiG7sTZU2TPGz3QrR/vOavdzMmTSTLJFTN51AW1QX3IZOOFsdiFC7GxC41jUJ8rjTVe4Ao47q6O67rBWTk35+Ue41ZyXIHsWgFBsboOArK/EspFmwl42WXAgh1bQtjlgYDorgqUu3nM+T7N5qpx4Y/83VUjyzWyZjY7HGZyW5Qk7ReqCi2qmmpvJ66Ii3yGL/xpZfjifySJmig6HCL5hyjpY/q1ZBJO6jtw2Vm9bjK9luJ6coq4p5UrmKOTALheK9/HdHDldbo1Q5teffLf1aev8zdyKuRU2jJTk3f0ot/XH4YTc/XwPpoevByUH6jFX/Tz0PoQHfTSJN3OWfM/2uwPmvkhk9L14qL38T2IjELOwXEIOskIvLIQDAL+ldvsOEu11+Mlf9O31zyta1A3Pv7ur4uLK8rsvg0+e1kFXIJTtdihX4Y14+N1paWVTk+Fy+dzVVQtqKTDG9gcR/gjOJuAWC3DtUkcV1WOZsPEz8nhlH6ej+rnk7OydAofaEniA620zGV1v5HF8spHsxYghsvdQXcwEAzw/RmLadaMBcmkZmaWoZbT30uxJ2NBS9aCk1kLWlFCJLdw2y5QlVJMFfaK8lG2ShH1CYhy0I0sIYsyH5TFQJCMJvWSJEyp+hi0pPQxlYyyehrrp7AxzeV54Hn+eXqujYDbIRgB2UCBKbAM65PspU8OgwVfpG9WFSxYncElhxmXiAFkLDrAz0+eTejH9eMJ+C4xaVNYOQFdCe6r4p7u2oPQ9wO95GGoH0smp233Lq9wFZyPW43zK1IoYJfskgkBicwGobUQdLsQk17rCuI1CJUg2RXJgMikfyEUUFgJ5UGu9qyNHnpucNvSb9cF6xeZ9D+taPYW1T0WfvzAX0PfXF3UUO17pVX9uv9bT3ZtrYus9D85BFc3N5os9kq5uHY5b1qyyjLvieaDa3Z5GgJLiuFAEQG1wGBy6tcM4W1Bf7zhabujeN2CImN1VZ1/40ub9KO+TqskLZwfaHf+b65FQjwv4UK4FroORg1ZXUNYpm12Jac0QcB4qzxrwE3lJBRR4A5dQdvw/hd/uJ8q+Y0933umoXpdZ/euZ3Zs3ciULWnctbc3VgQboagtFAtVLQl5VvPlvNr84nBLW0nJRs8af/NI85Yz/vg2JWwwKP4eq2RfVBF+qjrUWcOXLlgGhcXzm22FAuEyPMo4px95DT2+VQbRG/SVB4Iq45Qk34/eZ3sq3d6elSV30I/yLDoQ3SI6Fq8gwVqVmC9fDqfTZFIvgSm94dIlrFDxkuxZvziL05zcwmmvqiDT5BI8pCwjH6WSyTT7ISN8WQlOJpMTSUaCJ+/NUKWC7Lovcl/jZK4KPenjlIcYsSLvZSk2n0R3UAZ3Ofr0TKrCBKeQYdFGyLY0p0zF8h3t0JqdjqnD96tovqSaxiytklhas6hwqh15TFXn2rTKLQaARicCuaOq2m1m1PQMi2b46iS/lfGVhIRHQzTYebpHPw7dPWdIDZw8nYmDzlCyJXe/uPsF/y/+n1w1159BpaGMuiwvYs+j4AEL+RkqsdUElQQb6sCDnUGfhxaxC6segXVTOSlgpx95q70+KsbkK0muuxL82KmEvB7yQsRmWxIeibQ2b2rZbcMnEi+qsAARyTxDhdNmCTY1OQ8usFidRgepWFpoL7JbwBpp2dTcGhkJL0FxSzkU2QuXOUhpsdFptToPOpuaghabs8IwjzcTsFQUxSN0XJyptfkozkQru9kAcaPZFPQXWgzznfGmkM3qHHHG406jaHY5lhYSg5nOxFQaCR9FcUuZQAqXOlxmo1BEBUecVluoKe6cb7AU+oMmszHOVjHzvBxBFC9kjCUgLJGs0FciYyE8cfPQYwaUoNctlJPY0eGjV6/iK5kv/Pjl7u6Xu8lvZjXSgvZWN+3i5s2KPZchNz5a5CmwoBYU5E5JeXDseevjmG80fAyuxT7xvR5+/SEBqFYX+2jVMRR//pOYD/O8H5qOVViUAtnEH7nzWz6aSelMNEJjEfrJV12bwsJ2XCIlnAev7bmPYquOKaNQHfuYKv2wtaWza3sNTXJMOZa/L7yKZ7KA7jA9jfAUO4ngzxFb5hw6+T9zpdN3EBY7SDDamwAveBO9vQn9A/2DRC8514ctWOrTX+rDNuzry8YSd1ksYeMWcwEaS9ATZqZOYxF1EWb0CKECemYDflqk8eVKehyZTzSU0+MIU4efHYxu2BAdfFb/bGgw2tAQHRyCCe3NUH00Nti1XYlI0rJ4qH49VjrDEcAafxOlh/TbQ7up9O4hMON3Gz7X3lwmSRGls3swFl0XaspUugbj0fpQDvdR9BMCcjiL2DBMC0iUKTFyo6y2M51Mqfp5FaZ4h5Ygo2qK8l/eVjTewxq4RckteN0KpVQy2Xkurarpc50wha5jvDed7oWwmuHnPE5k9Khhbu39kUIDBAaVWvRHwQKMIBExfOYeyg4mPaFWSuL0BjAHN9p3DlDcHEjx67R3SKUo/adk9eBgbcnFklqaDUxo10mjdA+CyO1kBkIkhiT9tkOE1ZkPMt+VkljyBbwzzMYR85Tk1Tk4IjMwQG9zbGPNFAaL6I6bKQwEBgsb7XHRejXtgalD+d0uyyHgMNvwiLK96zpuNj6dXfff7C10a693d1Lhzm4UViKz8biUxTD3w6PEVGQ+g4GS3nk8VtwJ3BvcGdyX+0LyUAZ+VKXrOSW/v37P4T3r2euR1dR3NGQ/Wb8nj60TWX/oVfACoMhBcvCXCejSTyROa38gsTOZUP50Ks/fA4jjUs5OYxh07XmeKcj+uyKAAH5L9blI3OXTxwZqJiZqBtrRCX8Ii/UP6Y0NFi8YqJ2YqB2A16bxTUbp6BhBpchP9DG8sJzPc8koYp/QO4pIYwS8nrRoO+f2kUz4wNdjwDU2Z0wj0CCjJSOR7UvyMYorI0HG4ZPaFf294YvwNrmiXYHgEJam9YrTnaVHABXTdiI4aXM+LnBzMa4D+dtumxsXLATalo0KQn6Jt/vz3t5gw96sr6dfCKxNAooH8LgyFbufPCEIHTNCgA7BKrQaDNvQn1MH2yHYBBemDuqm0cVvMxhaUaJjhivvEATiWG4y3fmpyWPCnO80ef54r0zL7FHgV7MnablXjTufL8cRcTgc1VuKw//fJvfa5L+BscYKAAAAeJxjYGRgYABi/jvPp8Xz23xl4GZ+ARSI4ny8rwFG///2/xvzZ+ZPQJUcDExAkgEAoUMP6XicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AIAnloHAgAAeJxjYGBgYH5Ba/z/G+3M/f+NgQ4AAPv8MfAAAHicY2AAAgmGIIYshhaGC4wijCGMPYz7GF8xGTGFMVUwTWC6wGzGPIf5BwsfiwZLCcsOlgssL1gnsB5iE2EzYGtim8K2jZ2HXYvdhX0Z+w72fxwRHAUcszhWcGzjOMJxieMZxxfOOi4O0iEAtgsblgB4nGNgZGBg8GLIYeBhAAEmIOYCQgaG/2A+AwAbuAHZAHicfZC9TsMwFIVP+odoBaoEYmAyCwtS+rPRtVKzd+ieJnaaKo2D41bqznPwBDxHn4OnYObEeCkStSXnu9899w4BMMQJAZoT4Ma9zWnhitUvt0n3njvkJ89dDBB67tG/eu7jBQvPA9zhjRuCzjXNI949t3CLD89t+k/PHfLJcxcP+PLco//23McqGHoe4DlQcRaZPJ0XcV3nyVJm+yI2Z+6sWElT57oUk3B85iNZShNbmYr1UdSHbGqtEsronVjo0sqi0KIyeisTG26srWajkfI+TPQOMTJEMMiRYo6Cdc2bI8ESkr29c+ZC7v/OihuMY40SAhP+9/GFfMR86WZiWH5Tzqxx5FvjwKkprYVirZjR2JEWbneTLng1TeV6W5qEPsTGTVWYYcSr/uRDprjpB8WrbRMAeJxtkmdv2zAURX1iyVbstEnTNt17D7VN994z/RUMRctEJFIgKY/8+rJxGiBA36dzHx7uu3xgZ6mzqEHn/7XFEl0SUnr0yVhmwJAVjnCUVdY4xjrHOcFJNjjFac5wlnOc5wIXucRlrnCVa1znBje5xW3ucJd73CfnAQ95xCaPecJTnvGcF7zkFa95w1ve8Z4PfOQTn/nCV77xnR/85Bdb/O4MRVk6VYqgrekJ5+zUd4WXPSmMVFUqx8KFNTlWcmfbzvI9UMXGQUObQgXlam1EUOsH7dbsT65IW1mXNzoK14+irY0fSGuCEzKoIpG2mafSWe+TQnmZqVkjomexrOYq95Xw4+EB5ZvdyL2RruLKdKSdD0npdJOWzrZNEkdCUqlR6FXaxN39yopCmzKrxUzXelcltTJtFrMulFGzkBhr1NDYkIuqslNVpE10Ud1Gm7TRExuyxqmJtq1fc9HM5tttCNbkdjRaPdwwqdPlOCReTNTA19EuL+zU7OPfWMMF7o1lC46pQzzNenBKHb5l1prFKwb/IN9EUOJQBDQWwxSPpGLMDtvM4lcoqGlpmDNil0mn8wcxorJdAAA=") format("woff");font-weight:400;font-style:normal}.ag-icon{font-family:agGridClassic;font-size:12px;line-height:12px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ag-icon-aggregation:before{content:"\\f101"}.ag-icon-arrows:before{content:"\\f102"}.ag-icon-asc:before{content:"\\f103"}.ag-icon-cancel:before{content:"\\f104"}.ag-icon-chart:before{content:"\\f105"}.ag-icon-color-picker:before{content:"\\f109"}.ag-icon-columns:before{content:"\\f10a"}.ag-icon-contracted:before{content:"\\f10b"}.ag-icon-copy:before{content:"\\f10c"}.ag-icon-cross:before{content:"\\f10d"}.ag-icon-desc:before{content:"\\f10e"}.ag-icon-expanded:before{content:"\\f10f"}.ag-icon-eye-slash:before{content:"\\f110"}.ag-icon-eye:before{content:"\\f111"}.ag-icon-filter:before{content:"\\f112"}.ag-icon-first:before{content:"\\f113"}.ag-icon-grip:before{content:"\\f114"}.ag-icon-group:before{content:"\\f115"}.ag-icon-last:before{content:"\\f116"}.ag-icon-left:before{content:"\\f117"}.ag-icon-linked:before{content:"\\f118"}.ag-icon-loading:before{content:"\\f119"}.ag-icon-maximize:before{content:"\\f11a"}.ag-icon-menu:before{content:"\\f11b"}.ag-icon-minimize:before{content:"\\f11c"}.ag-icon-next:before{content:"\\f11d"}.ag-icon-none:before{content:"\\f11e"}.ag-icon-not-allowed:before{content:"\\f11f"}.ag-icon-paste:before{content:"\\f120"}.ag-icon-pin:before{content:"\\f121"}.ag-icon-pivot:before{content:"\\f122"}.ag-icon-previous:before{content:"\\f123"}.ag-icon-right:before{content:"\\f126"}.ag-icon-save:before{content:"\\f127"}.ag-icon-small-down:before{content:"\\f128"}.ag-icon-small-left:before{content:"\\f129"}.ag-icon-small-right:before{content:"\\f12a"}.ag-icon-small-up:before{content:"\\f12b"}.ag-icon-tick:before{content:"\\f12c"}.ag-icon-tree-closed:before{content:"\\f12d"}.ag-icon-tree-indeterminate:before{content:"\\f12e"}.ag-icon-tree-open:before{content:"\\f12f"}.ag-icon-unlinked:before{content:"\\f130"}.ag-icon-row-drag:before{content:"\\f114"}.ag-right-arrow:before{content:"\\f117";content:"\\f126"}',""]),e.exports=t},function(e,t,o){var r=o(27),a=o(180);"string"==typeof(a=a.__esModule?a.default:a)&&(a=[[e.i,a,""]]);var n={insert:"head",singleton:!1};r(a,n);e.exports=a.locals||{}},function(e,t,o){(t=o(28)(!1)).push([e.i,'@font-face{font-family:agGridMaterial;src:url("data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABGsAAsAAAAAIJAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlEAAAReYPJi3U9TLzIAAANcAAAAPgAAAFZWTFJvY21hcAAAA5wAAAHsAAAFgGqPB0pnbHlmAAAFiAAACFEAAA58peGl1GhlYWQAAA3cAAAALwAAADZ2zcSBaGhlYQAADgwAAAAWAAAAJAfRBDJobXR4AAAOJAAAABIAAAEkt5gAAGxvY2EAAA44AAAAbQAAAJSyFLU8bWF4cAAADqgAAAAfAAAAIAFcAEluYW1lAAAOyAAAATIAAAJebBQ2inBvc3QAAA/8AAABrgAAAom3/2OGeJx9k09yElEQxr9hCCYBk6gRFVFT8X/UOM4MTIBIQBApKwsXLly4iQstrZSrnMC1B7A8gKfwBJZLVx7AA1gewF83g5gswhQz73V//fXX/fopkLSoSF0VhqPd51ra3zt4r5qKmvzM//862H/7Zk/z0x2+on/nFYR/tKR1vdCBvgUKXgefC6WwEHbD3fBD+Cn8oRDUmjZBl/WAJ1bCO1KqhprKVFAJW8x6Sy3QIe+2W0+rqjn3DDTUWXLGxAydcUNPdU0r8PSdp0ctAzhT5+zxHvFc1/IxiEw34G+gZhursdbReUoLeozGHjo6RLfwruDbIXNETB9fH22ho4rex7Fe6h42q80iGzku5R/rke8j31XowhTVhr8Jv/FtknVqb5IpIeIu7A1QD/MebugK0U14erB1PHrLoysgExSmuszKKkuorEKH2nqmV0SWUTGJ6XkXJzXfQv3M3ne+TLcPWTtwjcDeQcPMaidyk1xWewK+yv6dPuqLvuq7fuqXfoOvkiXxCrpw7xzbmQX6dxQ9wNv+Z7VKT3AWR1GHEYvU3fTexPiGeQctWwWf9SZlHWFNHV+G0/AD1GScxhyTF3neBGuJ/Tb7GPRSPo0tnpPe5yEzYBNQo5Mxb2OazFtGhy8QbauJrnPerRY85/20rKd2k5Z9ZzNvp1zj1C/yjais4f15gvcSFmOaWeoelaHaOO7jz1A7y2aq6qhKfXZtssZ+CwZkWqOOiZJEV/0GjH2q1lHQyG/kqs64+k5+UquOiz0qoBNRfpNT75lNch9tNhWjv/VfaSwAAAB4nGNgZGphnMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVFgEqgRRAAA0p8KWwAAeJy11AduVDEUheF/SkILvbcUSK+T3ntlGaFHoUShR6ySndwNEM4dHxYQJCx9c8d+nvdsPZ8BWoCaDEsdqnUqZPut0UpzvMbF5nidX+q3cZ6qvo9wwBEn0Tg91egI+xxyHJVm72+raHYbj+hlRr01GqywwDqT7DDOEtMss8gGs7q+xQTzTLHJHnOsss2ufl/V0+u0ck5PvaB1XNL9LnOFq1zjOje4yS1uc4e73OM+D3iopz3WnHY66KSLp5rXTY9W0Ec/AwwypB21ab2jjGmBrZytrZ1xfrbGysL65M74kna7uDE7o43OT23uza1u7/7Dzf5Da8uP2k/3npFvs1iTfWvIc1uRF7YgL21dXtmkvLYdeWPj8taW5MCm5dCW5Z0tynvbkA82Kx8tT9eRbcmxTcgnm5fPNiVfbFO+2p58szn5bqvyw7blxPQCo1JkVqJakLVWZLaiXmS+oqXQmSZMp5swnXPCdOIJywyGKQWE5dsLUzIIU0YIU1oIUx4IU4IIU5YIU6oIU74IU9IIU+YIU/oIUw4JUyIJUzYJU0oJU14JU3IJa+6rvSBrR0HWzoKsXQVZnxRKPWHN/XYXZO0pyNpbkLWvIGt/QdaBgqyDBVmHCrIOF/kfGiNFc/2jRWYpxgpyrFEw9gcVSJ+veJzFV21MW+cVvue9xTcmEOKAffECduyLfWkwrsy1udgGwlcCisrHZCdaG1LTdIG0sBjaVF2WoX1okyK1ayqt9Efzp9GkizSpTVv+pNOUVCxVmfrHUfNrYmzqn+GsQ1RCreTGVzvnxTbhY1Kn/Rjc933PfT/OPee8z/mwAAL+sTWxR9gvCOCxV4LdE/HoqoetmRVQZX4FG+byvXvQIHYncrnEbCYjCI/RGfED8QPBIlQKNcJhPKlFNFXSJCUiyRHNp9oVu2ZXFbsi6wrcMNKLi+k26lj/Yjo9z9/Zz7CfJyqxmDbSOlLIlssj9qA8+wShWtZtmk3WYT6WTa7GzQXYiGfNMvg2G4dBFJvvnRPnUIYjeNQrWSRLjeyQHS16q94aVv2qv1pSJVVXdVmXJdiYeTalR6N66tkvikQq9tZbsbk53otz25Y4kf9zcRV74f/zTZF/s1asRUqie6rWbAo1XbMrmdnZB5cuZV9+mT1vTrCB/K1cTijJuSquCtWCk27WewDsthoXaJ6WTojYwkGwgi6DLF5++LVLc+EjlvMxv2Y+GFoCY0hcxfdtiw+/BsfQp2AMb+cv781fRCDt4v6b/H0W2M05f3/6UZ4i52nz2Hx78UWeYvkOvpuT6Z18C7b7sfhDoQwRVSsIVpBkK4i6Gyx0dfYaR0trhK6N/dNMxZ4z89C5tPTp+/v3O6scoeMhR5UTFuFGHBfMP0HH0lJnZaXrsN/pDYW8Tl+di9hbS5jdvJ8qbpPDgltQ6K4iCjUJWwSbjE23a5GywrwN27xh5PhTGM2xwhu7buTHcUwahQlcwafoJ+waW0O9BFRJQi95M3b7dizH1uJ37sRzJdz8XLyDmjuFen5LFjt6lEfmRI0DjdqKNvUr1R6bh71vViihJGzMmhFSDz7DXgEzAp+Jt0Pe/EesPxFS8h/RGutXQvnzrL/gr4RNih+Iey6KrKtibTybLT7sr4+8bPdxPGNTbKoEYjd3chgkJ4dvzbIsOvwOPZG7rrLXY7lc7DZbiOdy8TulmPEUWxXa8SXIFK9FUlu1FtkF8gFAUldwQpEtitevKi6mtehEq0HAJdkiabTZIWvsTSnYp3ri8uBTEyMDJ16ok0+1DfmsvZLt6FDfPqsnvK9Xaj6uNhzp7x3A9ck6//fPWB/71eP1jUfC1h5m83UoTseg5nZf7O845xn0abWHjh4H1e3vVKpOfI+mx7pGq2sa6/xFXJLMhxAnjTySoKwoMQaSTtBRNr/oDUK4E1pcUHMARK+FoBr2wwaXre6FEwPvIFFfj8RI4GQgcPIH1AUao9GRaJT9g77Xf9HtLo7mZGEHdiDSnpFoESOTaN9CbPEhHikHAHovRm7DXGZr+WuYBSpyCbiRSJjLyVJ8Yd/we7HSzeh4N4AxiX3z8cd4MWYkmYQIATFHZwu+3cNm+Hco03jKKD5058fZ24U2k5hP0DYL3/uMWI5UuWAT7IheN51BMzQBCaejTXCo5h6FmUdBM2msHxzo8vPgMB/MI2FWpOlvhYICDFI3ND29gmM6fz+dnqbpXXpUE3pVD+rxFVcDXkkm2QJXA5XYmZ8AEyVGURXV2IQrDBJ0mSsbMxfMhVi2aN859gnmi1ohgF9AUeMQUTCuYVTjVBBkNIUPU2aLi5GKSHQCRrrfedsVw4iOtbWNRQ1Daff+HobMD+EVToNSWoQNJa4Mt6VeTLUNK3EpaWB/gmbGZlJtxbhajvaUuR0xLWHikCXM0hFMVGRAHbO2qOkRVZHsLHB+ePyNN8aHz0+XiPHR7u7RbvaTbZNEmFe6aalgl0lxkjSuxtudRdgcEicTwh4Y01Fd/o93yPdtNiwvkplEouDza8I9OqkjLw6hDMfGnrxsBbzO0r4ivy24io/kbI8Q/A9ZG8JEUiCAIABGCkCM1dDGvXK42dMceHLwTPRCk9nsbYBBJOBzbwNN7pXSzdSZwScDzQ1es7npgvllgxc+b7oQ5XNFnaYwTjvwflSUTwkCxjBlR5D2tDhqLF5/uBU8Ng1V1sTam5VdI12VN3lIHqDeXLY5nV6nEyL5W0l4JylO+oJBH0bv83zPdW+oVqnFB210fXa2iI0usROlqKJMourVwKM41S8qnHlVffVvEHC51ttPr59qv+yCVpyBv5v3Xa7L7afWT7evu7bqjf+dj7VUW27mUI/gE5qEJwRN0DE2edBX0BSdVA24qC44AIBug/bw+PinsOTUfLz8onlyKR0bRRm3Vl+vudnbfMz/yzAQK33wR/OLY8fUiYmb+P6l2nWsccK8gqRjZWXFMNq2Drg5A7Ab8GvzynvHuujI/BNqFxLgp8RsbKu5aoTHiyg7SCg7QtA6SCgTvdRzqLXQSgFgVy/N9Pb19c5cgoNF6uqPzj4d0fXI02f/UiTEVVow17dvfvjTbZs4UcAUyVKBNmwlaXjA2Qws6n8hWt9Lvb0vXaWu77tJydYK+7HLfWeBd8VWSUbPx5zyaM3Pa4RsDIt/VvCZSfwF4tisFZWSr5TpHHY2dJD8rcSma5gLU7FMJjaVpB800GAu8xKnoW4qnsnEp+C3pZrqE3aWuAMWVA2ZDBulXzzFtbMYxxmXjebZ3b3WEOyvZTJ0VtjFEwtunKf1LX2fEyuKtQ2ocPHd+CpsxCDxbiyLY7G+Yq5iXM1Qjc9cyRLvNXZtswak4qiQq9jrVAlu1YBzaCfKoy0UWyjNgN1hkWQsqBEMEtakVCjZt/JRJIyFEW6U8dGB3d1MOPrRjvCxtrFzo8l9+Vu/jA0Us1JP6LT7xdTAfDjfz+5i6lECx/d3HD7XHk21GUmY+kXt811RnpmU0Mmy08lncCf7gyD8G975gHwAAAB4nGNgZGBgAOLNefk58fw2Xxm4mV8ABaI4H+9rQNAMDMwvQOIMHAxMIB4AThwLfgB4nGNgZGBgfsHAgEQyMqACTwBFgwMNAAB4nGNgYGBgfjF0MT0AAODAKyYAAHicY2AAAikGD4Y4hhkMlxjeMMowujEWMC5ivMP4jkmByYopgCmJaQ8zA7MMswmzF3MD8wzmDcyfWFRYjFi8WCJYilgOsTKwqrB6sC5jfcPmxhbD1sY2hW0R2wa2fWwX2O6xfWC3Ix0CAAMJHZwAAAB4nGNgZGBg8GSwZeBkAAEmIOYCQgaG/2A+AwAWwQGmAHicfZA9asNAEIWf/BdiQwiEuFKxEEgTkH9Kk9qCgBsX7mVrJcustWK1NvgGOUhOkEOkzEFyijytt7ELz8LwvTdvplgAj/hBgKYCPLjeVAt3VGduk549d8gvnrsYYOK5R//dcx9v+PA8wBMOvBB07umE+PTcYv7Lc5v+t+cO+ddzF0P8ee4hDOC5j1UQeh7gNTBJHpsiXSRWmiJRS5kfVHJlXqqVNHWhSzGJxpeDWJbSkFOxPon6mE+tzURm9F7MdWmlUlpURu/kxkZba6vZaJR5P9roPRLkiGFQIMWCykI6lUBhSc75F4rK3Ezemq0c11QaJQT/P8L45kZMLp0++ym31jix1zhyb0rXIqPOmNHYk+buepNWfJpO5WY7Ohv6EbZuq8IMI77sKh8xxUv/NPJv3gAAeJxtkQdv2zAQhf3Fki3baeO6bbr3Hmqb7r1X+i9oipaJSKRAUR759WXtIECAHnDgew+Hd4OtjdY6+q3/xy4btImI6dAloUefAZsc4zhbDDnBiJOc4jTbnOEs5zjPBS5yictc4SrXuM4NbnKL29zhLve4zwMekvKIxzxhh6c84zkveMkrXvOGt7zjPR/4yCc+84WvfOM7P/jJL36zy5/WQOS5U7nw2pqOcM7O67aoZUcKI1WRrJ90J5ZT4fxQTpXcG9tFugIq2z4UtMmUV67URng1OpQbc1C5KW1hXVrpQFw3kKY0dV9a452QXmWRtNUyls7WdZSpWiZqUYngmfXUUqV1IeppO6DORBehTTzRrvZR7nQV5842VRQKfFSoie8U2oR+3cKKTJs8KcVCl3pfRaUyTRLmWzNjjRoY61NRFHausrgKBqpdaROHDAtXemb90AUTm44b761J7WSydVQwsdP51Ee1mKl+XQavNLNzcwD/jTNYw1VZssZhWh/OMPJOqaN3660kWymTNGa9B4Ich8KjsRjm1EgKpuwxZhE+P6OkoWLJhH1mrdZfDrCtIAAA") format("woff");font-weight:400;font-style:normal}.ag-icon{font-family:agGridMaterial;font-size:18px;line-height:18px;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ag-icon-aggregation:before{content:"\\f101"}.ag-icon-arrows:before{content:"\\f102"}.ag-icon-asc:before{content:"\\f103"}.ag-icon-cancel:before{content:"\\f104"}.ag-icon-chart:before{content:"\\f105"}.ag-icon-color-picker:before{content:"\\f109"}.ag-icon-columns:before{content:"\\f10a"}.ag-icon-contracted:before{content:"\\f10b"}.ag-icon-copy:before{content:"\\f10c"}.ag-icon-cross:before{content:"\\f10d"}.ag-icon-desc:before{content:"\\f10e"}.ag-icon-expanded:before{content:"\\f10f"}.ag-icon-eye-slash:before{content:"\\f110"}.ag-icon-eye:before{content:"\\f111"}.ag-icon-filter:before{content:"\\f112"}.ag-icon-first:before{content:"\\f113"}.ag-icon-grip:before{content:"\\f114"}.ag-icon-group:before{content:"\\f115"}.ag-icon-last:before{content:"\\f116"}.ag-icon-left:before{content:"\\f117"}.ag-icon-linked:before{content:"\\f118"}.ag-icon-loading:before{content:"\\f119"}.ag-icon-maximize:before{content:"\\f11a"}.ag-icon-menu:before{content:"\\f11b"}.ag-icon-minimize:before{content:"\\f11c"}.ag-icon-next:before{content:"\\f11d"}.ag-icon-none:before{content:"\\f11e"}.ag-icon-not-allowed:before{content:"\\f11f"}.ag-icon-paste:before{content:"\\f120"}.ag-icon-pin:before{content:"\\f121"}.ag-icon-pivot:before{content:"\\f122"}.ag-icon-previous:before{content:"\\f123"}.ag-icon-right:before{content:"\\f126"}.ag-icon-save:before{content:"\\f127"}.ag-icon-small-down:before{content:"\\f128"}.ag-icon-small-left:before{content:"\\f129"}.ag-icon-small-right:before{content:"\\f12a"}.ag-icon-small-up:before{content:"\\f12b"}.ag-icon-tick:before{content:"\\f12c"}.ag-icon-tree-closed:before{content:"\\f12d"}.ag-icon-tree-indeterminate:before{content:"\\f12e"}.ag-icon-tree-open:before{content:"\\f12f"}.ag-icon-unlinked:before{content:"\\f130"}.ag-icon-row-drag:before{content:"\\f114"}.ag-right-arrow:before{content:"\\f117";content:"\\f126"}',""]),e.exports=t}])})); \ No newline at end of file +// @ag-grid-community/all-modules v27.1.0 +!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.agGrid=t():e.agGrid=t()}(window,(function(){return function(e){var t={};function a(r){if(t[r])return t[r].exports;var o=t[r]={i:r,l:!1,exports:{}};return e[r].call(o.exports,o,o.exports,a),o.l=!0,o.exports}return a.m=e,a.c=t,a.d=function(e,t,r){a.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:r})},a.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},a.t=function(e,t){if(1&t&&(e=a(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var r=Object.create(null);if(a.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var o in e)a.d(r,o,function(t){return e[t]}.bind(null,o));return r},a.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return a.d(t,"a",t),t},a.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},a.p="",a(a.s=191)}([function(e,t,a){"use strict";a.d(t,"c",(function(){return i})),a.d(t,"f",(function(){return l})),a.d(t,"e",(function(){return g})),a.d(t,"g",(function(){return p})),a.d(t,"b",(function(){return d})),a.d(t,"a",(function(){return s})),a.d(t,"d",(function(){return c})),a.d(t,"h",(function(){return h}));var r=a(1),o=a(12),n=a(15),i=function(){function e(e,t){if(this.beanWrappers={},this.destroyed=!1,e&&e.beanClasses){this.contextParams=e,this.logger=t,this.logger.log(">> creating ag-Application Context"),this.createBeans();var a=this.getBeanInstances();this.wireBeans(a),this.logger.log(">> ag-Application Context ready - component is alive")}}return e.prototype.getBeanInstances=function(){return Object(r.values)(this.beanWrappers).map((function(e){return e.beanInstance}))},e.prototype.createBean=function(e,t){if(!e)throw Error("Can't wire to bean since it is null");return this.wireBeans([e],t),e},e.prototype.wireBeans=function(e,t){this.autoWireBeans(e),this.methodWireBeans(e),this.callLifeCycleMethods(e,"preConstructMethods"),Object(r.exists)(t)&&e.forEach(t),this.callLifeCycleMethods(e,"postConstructMethods")},e.prototype.createBeans=function(){var e=this;this.contextParams.beanClasses.forEach(this.createBeanWrapper.bind(this)),Object(o.iterateObject)(this.beanWrappers,(function(t,a){var r;a.bean.__agBeanMetaData&&a.bean.__agBeanMetaData.autowireMethods&&a.bean.__agBeanMetaData.autowireMethods.agConstructor&&(r=a.bean.__agBeanMetaData.autowireMethods.agConstructor);var o,n,i=e.getBeansForParameters(r,a.bean.name),l=(o=a.bean,n=[null].concat(i),new(o.bind.apply(o,n)));a.beanInstance=l}));var t=Object.keys(this.beanWrappers).join(", ");this.logger.log("created beans: "+t)},e.prototype.createBeanWrapper=function(e){var t=e.__agBeanMetaData;if(!t){var a=void 0;return a=e.prototype.constructor?Object(n.getFunctionName)(e.prototype.constructor):""+e,void console.error("Context item "+a+" is not a bean")}var r={bean:e,beanInstance:null,beanName:t.beanName};this.beanWrappers[t.beanName]=r},e.prototype.autoWireBeans=function(e){var t=this;e.forEach((function(e){t.forEachMetaDataInHierarchy(e,(function(a,r){var o=a.agClassAttributes;o&&o.forEach((function(a){var o=t.lookupBeanInstance(r,a.beanName,a.optional);e[a.attributeName]=o}))}))}))},e.prototype.methodWireBeans=function(e){var t=this;e.forEach((function(e){t.forEachMetaDataInHierarchy(e,(function(a,r){Object(o.iterateObject)(a.autowireMethods,(function(a,o){if("agConstructor"!==a){var n=t.getBeansForParameters(o,r);e[a].apply(e,n)}}))}))}))},e.prototype.forEachMetaDataInHierarchy=function(e,t){for(var a=Object.getPrototypeOf(e);null!=a;){var r=a.constructor;if(r.hasOwnProperty("__agBeanMetaData"))t(r.__agBeanMetaData,this.getBeanName(r));a=Object.getPrototypeOf(a)}},e.prototype.getBeanName=function(e){if(e.__agBeanMetaData&&e.__agBeanMetaData.beanName)return e.__agBeanMetaData.beanName;var t=e.toString();return t.substring(9,t.indexOf("("))},e.prototype.getBeansForParameters=function(e,t){var a=this,r=[];return e&&Object(o.iterateObject)(e,(function(e,o){var n=a.lookupBeanInstance(t,o);r[Number(e)]=n})),r},e.prototype.lookupBeanInstance=function(e,t,a){if(void 0===a&&(a=!1),"context"===t)return this;if(this.contextParams.providedBeanInstances&&this.contextParams.providedBeanInstances.hasOwnProperty(t))return this.contextParams.providedBeanInstances[t];var r=this.beanWrappers[t];return r?r.beanInstance:(a||console.error("AG Grid: unable to find bean reference "+t+" while initialising "+e),null)},e.prototype.callLifeCycleMethods=function(e,t){var a=this;e.forEach((function(e){return a.callLifeCycleMethodsOnBean(e,t)}))},e.prototype.callLifeCycleMethodsOnBean=function(e,t,a){var r={};this.forEachMetaDataInHierarchy(e,(function(e){var o=e[t];o&&o.forEach((function(e){e!=a&&(r[e]=!0)}))})),Object.keys(r).forEach((function(t){return e[t]()}))},e.prototype.getBean=function(e){return this.lookupBeanInstance("getBean",e,!0)},e.prototype.destroy=function(){if(!this.destroyed){this.logger.log(">> Shutting down ag-Application Context");var e=this.getBeanInstances();this.destroyBeans(e),this.contextParams.providedBeanInstances=null,this.destroyed=!0,this.logger.log(">> ag-Application Context shut down - component is dead")}},e.prototype.destroyBean=function(e){e&&this.destroyBeans([e])},e.prototype.destroyBeans=function(e){var t=this;return e?(e.forEach((function(e){t.callLifeCycleMethodsOnBean(e,"preDestroyMethods","destroy");var a=e;"function"==typeof a.destroy&&a.destroy()})),[]):[]},e}();function l(e,t,a){var r=f(e.constructor);r.preConstructMethods||(r.preConstructMethods=[]),r.preConstructMethods.push(t)}function g(e,t,a){var r=f(e.constructor);r.postConstructMethods||(r.postConstructMethods=[]),r.postConstructMethods.push(t)}function p(e,t,a){var r=f(e.constructor);r.preDestroyMethods||(r.preDestroyMethods=[]),r.preDestroyMethods.push(t)}function d(e){return function(t){f(t).beanName=e}}function s(e){return function(t,a,r){u(t,e,!1,t,a,null)}}function c(e){return function(t,a,r){u(t,e,!0,t,a,null)}}function u(e,t,a,r,o,n){if(null!==t)if("number"!=typeof n){var i=f(e.constructor);i.agClassAttributes||(i.agClassAttributes=[]),i.agClassAttributes.push({attributeName:o,beanName:t,optional:a})}else console.error("AG Grid: Autowired should be on an attribute");else console.error("AG Grid: Autowired name should not be null")}function h(e){return function(t,a,r){var o,n="function"==typeof t?t:t.constructor;if("number"==typeof r){var i=void 0;a?(o=f(n),i=a):(o=f(n),i="agConstructor"),o.autowireMethods||(o.autowireMethods={}),o.autowireMethods[i]||(o.autowireMethods[i]={}),o.autowireMethods[i][r]=e}}}function f(e){return e.hasOwnProperty("__agBeanMetaData")||(e.__agBeanMetaData={}),e.__agBeanMetaData}},function(e,t,a){"use strict";function r(e){return null==e||""===e?null:e}function o(e,t){return void 0===t&&(t=!1),null!=e&&(""!==e||t)}function n(e){return!o(e)}function i(e){return null==e||0===e.length}function l(e){return null!=e&&"function"==typeof e.toString?e.toString():null}function g(e){if(void 0!==e){if(null===e||""===e)return null;if("number"==typeof e)return isNaN(e)?void 0:e;var t=parseInt(e,10);return isNaN(t)?void 0:t}}function p(e){if(void 0!==e)return null!==e&&""!==e&&("boolean"==typeof e?e:/true/i.test(e))}function d(e){if(null!=e&&""!==e)return e}function s(e,t){return null==e&&null==t||(null!=e||null==t)&&((null==e||null!=t)&&e===t)}function c(e,t){return(e?JSON.stringify(e):null)===(t?JSON.stringify(t):null)}function u(e,t,a){void 0===a&&(a=!1);var r=null==e,o=null==t;if(e&&e.toNumber&&(e=e.toNumber()),t&&t.toNumber&&(t=t.toNumber()),r&&o)return 0;if(r)return-1;if(o)return 1;function n(e,t){return e>t?1:ea)break}return!1}function f(e){var t=window.getComputedStyle(e),a=t.height,r=t.width,o=t.paddingTop,n=t.paddingRight,i=t.paddingBottom,l=t.paddingLeft,g=t.marginTop,p=t.marginRight,d=t.marginBottom,s=t.marginLeft,c=t.boxSizing;return{height:parseFloat(a),width:parseFloat(r),paddingTop:parseFloat(o),paddingRight:parseFloat(n),paddingBottom:parseFloat(i),paddingLeft:parseFloat(l),marginTop:parseFloat(g),marginRight:parseFloat(p),marginBottom:parseFloat(d),marginLeft:parseFloat(s),boxSizing:c}}function m(e){var t=f(e);return"border-box"===t.boxSizing?t.height-t.paddingTop-t.paddingBottom:t.height}function b(e){var t=f(e);return"border-box"===t.boxSizing?t.width-t.paddingLeft-t.paddingRight:t.width}function w(e){var t=f(e),a=t.marginBottom+t.marginTop;return Math.ceil(e.offsetHeight+a)}function v(e){var t=f(e),a=t.marginLeft+t.marginRight;return Math.ceil(e.offsetWidth+a)}function x(){if("boolean"==typeof r)return r;var e=document.createElement("div");return e.style.direction="rtl",e.style.width="1px",e.style.height="1px",e.style.position="fixed",e.style.top="0px",e.style.overflow="hidden",e.dir="rtl",e.innerHTML='
\n \n \n
',document.body.appendChild(e),e.scrollLeft=1,r=0===Math.floor(e.scrollLeft),document.body.removeChild(e),r}function y(e,t){var a=e.scrollLeft;return t&&(a=Math.abs(a),Object(o.isBrowserChrome)()&&!x()&&(a=e.scrollWidth-e.clientWidth-a)),a}function k(e,t,a){a&&(x()?t*=-1:(Object(o.isBrowserSafari)()||Object(o.isBrowserChrome)())&&(t=e.scrollWidth-e.clientWidth-t)),e.scrollLeft=t}function C(e){for(;e&&e.firstChild;)e.removeChild(e.firstChild)}function O(e,t){A(e.querySelector(t))}function A(e){e&&e.parentNode&&e.parentNode.removeChild(e)}function E(e){return null!==e.offsetParent}function R(e){if(null!==DOMParser)return(new DOMParser).parseFromString(e,"text/html").body.firstChild;var t=document.createElement("div");return t.innerHTML=(e||"").trim(),t.firstChild}function S(e,t){e.lastChild?e.insertAdjacentHTML("afterbegin",t):e.innerHTML=t}function T(e,t){return e.attributes&&e.attributes[t]?e.attributes[t].value:null}function D(e){return e&&e.clientHeight?e.clientHeight:0}function P(e){return e&&e.clientWidth?e.clientWidth:0}function N(e,t,a){a&&a.nextSibling===t||(a?a.nextSibling?e.insertBefore(t,a.nextSibling):e.appendChild(t):e.firstChild&&e.firstChild!==t&&e.insertAdjacentElement("afterbegin",t))}function M(e,t){for(var a=0;a=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},l=function(){function e(){var e=this;this.destroyFunctions=[],this.destroyed=!1,this.__v_skip=!0,this.isAlive=function(){return!e.destroyed}}return e.prototype.getFrameworkOverrides=function(){return this.frameworkOverrides},e.prototype.getContext=function(){return this.context},e.prototype.destroy=function(){this.destroyFunctions.forEach((function(e){return e()})),this.destroyFunctions.length=0,this.destroyed=!0,this.dispatchEvent({type:e.EVENT_DESTROYED})},e.prototype.addEventListener=function(e,t){this.localEventService||(this.localEventService=new r.a),this.localEventService.addEventListener(e,t)},e.prototype.removeEventListener=function(e,t){this.localEventService&&this.localEventService.removeEventListener(e,t)},e.prototype.dispatchEventAsync=function(e){var t=this;window.setTimeout((function(){return t.dispatchEvent(e)}),0)},e.prototype.dispatchEvent=function(e){this.localEventService&&this.localEventService.dispatchEvent(e)},e.prototype.addManagedListener=function(e,t,a){var r=this;if(!this.destroyed){e instanceof HTMLElement?Object(n.addSafePassiveEventListener)(this.getFrameworkOverrides(),e,t,a):e.addEventListener(t,a);var o=function(){return e.removeEventListener(t,a),r.destroyFunctions=r.destroyFunctions.filter((function(e){return e!==o})),null};return this.destroyFunctions.push(o),o}},e.prototype.addDestroyFunc=function(e){this.isAlive()?this.destroyFunctions.push(e):e()},e.prototype.createManagedBean=function(e,t){var a=this.createBean(e,t);return this.addDestroyFunc(this.destroyBean.bind(this,e,t)),a},e.prototype.createBean=function(e,t,a){return(t||this.getContext()).createBean(e,a)},e.prototype.destroyBean=function(e,t){return(t||this.getContext()).destroyBean(e)},e.prototype.destroyBeans=function(e,t){var a=this;return e&&e.forEach((function(e){return a.destroyBean(e,t)})),[]},e.EVENT_DESTROYED="destroyed",i([Object(o.a)("frameworkOverrides")],e.prototype,"frameworkOverrides",void 0),i([Object(o.a)("context")],e.prototype,"context",void 0),i([Object(o.a)("eventService")],e.prototype,"eventService",void 0),i([Object(o.a)("gridOptionsWrapper")],e.prototype,"gridOptionsWrapper",void 0),i([o.g],e.prototype,"destroy",null),e}()},function(e,t,a){"use strict";a.d(t,"a",(function(){return o})),a.d(t,"b",(function(){return n}));var r=a(15);function o(e){return i.bind(this,e,void 0)}function n(e){return i.bind(this,"[ref="+e+"]",e)}function i(e,t,a,o,n){null!==e?"number"!=typeof n?function(e,t,a){var o=function(e,t){e.__agComponentMetaData||(e.__agComponentMetaData={});e.__agComponentMetaData[t]||(e.__agComponentMetaData[t]={});return e.__agComponentMetaData[t]}(e,Object(r.getFunctionName)(e.constructor));o[t]||(o[t]=[]);o[t].push(a)}(a,"querySelectors",{attributeName:o,querySelector:e,refSelector:t}):console.error("AG Grid: QuerySelector should be on an attribute"):console.error("AG Grid: QuerySelector selector should not be null")}},function(e,t,a){"use strict";a.d(t,"a",(function(){return r}));var r=function(){function e(){}return e.BACKSPACE="Backspace",e.TAB="Tab",e.ENTER="Enter",e.ESCAPE="Escape",e.SPACE=" ",e.LEFT="ArrowLeft",e.UP="ArrowUp",e.RIGHT="ArrowRight",e.DOWN="ArrowDown",e.DELETE="Delete",e.A="A",e.C="C",e.V="V",e.D="D",e.Z="Z",e.Y="Y",e.F2="F2",e.PAGE_UP="PageUp",e.PAGE_DOWN="PageDown",e.PAGE_HOME="Home",e.PAGE_END="End",e}()},function(e,t,a){"use strict";a.d(t,"a",(function(){return r}));var r=function(){function e(){}return e.EVENT_COLUMN_EVERYTHING_CHANGED="columnEverythingChanged",e.EVENT_NEW_COLUMNS_LOADED="newColumnsLoaded",e.EVENT_COLUMN_PIVOT_MODE_CHANGED="columnPivotModeChanged",e.EVENT_COLUMN_ROW_GROUP_CHANGED="columnRowGroupChanged",e.EVENT_EXPAND_COLLAPSE_ALL="expandOrCollapseAll",e.EVENT_COLUMN_PIVOT_CHANGED="columnPivotChanged",e.EVENT_GRID_COLUMNS_CHANGED="gridColumnsChanged",e.EVENT_COLUMN_VALUE_CHANGED="columnValueChanged",e.EVENT_COLUMN_MOVED="columnMoved",e.EVENT_COLUMN_VISIBLE="columnVisible",e.EVENT_COLUMN_PINNED="columnPinned",e.EVENT_COLUMN_GROUP_OPENED="columnGroupOpened",e.EVENT_COLUMN_RESIZED="columnResized",e.EVENT_DISPLAYED_COLUMNS_CHANGED="displayedColumnsChanged",e.EVENT_VIRTUAL_COLUMNS_CHANGED="virtualColumnsChanged",e.EVENT_ASYNC_TRANSACTIONS_FLUSHED="asyncTransactionsFlushed",e.EVENT_ROW_GROUP_OPENED="rowGroupOpened",e.EVENT_ROW_DATA_CHANGED="rowDataChanged",e.EVENT_ROW_DATA_UPDATED="rowDataUpdated",e.EVENT_PINNED_ROW_DATA_CHANGED="pinnedRowDataChanged",e.EVENT_RANGE_SELECTION_CHANGED="rangeSelectionChanged",e.EVENT_CHART_CREATED="chartCreated",e.EVENT_CHART_RANGE_SELECTION_CHANGED="chartRangeSelectionChanged",e.EVENT_CHART_OPTIONS_CHANGED="chartOptionsChanged",e.EVENT_CHART_DESTROYED="chartDestroyed",e.EVENT_TOOL_PANEL_VISIBLE_CHANGED="toolPanelVisibleChanged",e.EVENT_COLUMN_PANEL_ITEM_DRAG_START="columnPanelItemDragStart",e.EVENT_COLUMN_PANEL_ITEM_DRAG_END="columnPanelItemDragEnd",e.EVENT_MODEL_UPDATED="modelUpdated",e.EVENT_PASTE_START="pasteStart",e.EVENT_PASTE_END="pasteEnd",e.EVENT_FILL_START="fillStart",e.EVENT_FILL_END="fillEnd",e.EVENT_CELL_CLICKED="cellClicked",e.EVENT_CELL_DOUBLE_CLICKED="cellDoubleClicked",e.EVENT_CELL_MOUSE_DOWN="cellMouseDown",e.EVENT_CELL_CONTEXT_MENU="cellContextMenu",e.EVENT_CELL_VALUE_CHANGED="cellValueChanged",e.EVENT_CELL_EDIT_REQUEST="cellEditRequest",e.EVENT_ROW_VALUE_CHANGED="rowValueChanged",e.EVENT_CELL_FOCUSED="cellFocused",e.EVENT_ROW_SELECTED="rowSelected",e.EVENT_SELECTION_CHANGED="selectionChanged",e.EVENT_CELL_KEY_DOWN="cellKeyDown",e.EVENT_CELL_KEY_PRESS="cellKeyPress",e.EVENT_CELL_MOUSE_OVER="cellMouseOver",e.EVENT_CELL_MOUSE_OUT="cellMouseOut",e.EVENT_FILTER_CHANGED="filterChanged",e.EVENT_FILTER_MODIFIED="filterModified",e.EVENT_FILTER_OPENED="filterOpened",e.EVENT_SORT_CHANGED="sortChanged",e.EVENT_VIRTUAL_ROW_REMOVED="virtualRowRemoved",e.EVENT_ROW_CLICKED="rowClicked",e.EVENT_ROW_DOUBLE_CLICKED="rowDoubleClicked",e.EVENT_GRID_READY="gridReady",e.EVENT_GRID_SIZE_CHANGED="gridSizeChanged",e.EVENT_VIEWPORT_CHANGED="viewportChanged",e.EVENT_SCROLLBAR_WIDTH_CHANGED="scrollbarWidthChanged",e.EVENT_FIRST_DATA_RENDERED="firstDataRendered",e.EVENT_DRAG_STARTED="dragStarted",e.EVENT_DRAG_STOPPED="dragStopped",e.EVENT_CHECKBOX_CHANGED="checkboxChanged",e.EVENT_ROW_EDITING_STARTED="rowEditingStarted",e.EVENT_ROW_EDITING_STOPPED="rowEditingStopped",e.EVENT_CELL_EDITING_STARTED="cellEditingStarted",e.EVENT_CELL_EDITING_STOPPED="cellEditingStopped",e.EVENT_BODY_SCROLL="bodyScroll",e.EVENT_BODY_SCROLL_END="bodyScrollEnd",e.EVENT_HEIGHT_SCALE_CHANGED="heightScaleChanged",e.EVENT_PAGINATION_CHANGED="paginationChanged",e.EVENT_COMPONENT_STATE_CHANGED="componentStateChanged",e.EVENT_BODY_HEIGHT_CHANGED="bodyHeightChanged",e.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED="displayedColumnsWidthChanged",e.EVENT_SCROLL_VISIBILITY_CHANGED="scrollVisibilityChanged",e.EVENT_COLUMN_HOVER_CHANGED="columnHoverChanged",e.EVENT_FLASH_CELLS="flashCells",e.EVENT_PAGINATION_PIXEL_OFFSET_CHANGED="paginationPixelOffsetChanged",e.EVENT_DISPLAYED_ROWS_CHANGED="displayedRowsChanged",e.EVENT_LEFT_PINNED_WIDTH_CHANGED="leftPinnedWidthChanged",e.EVENT_RIGHT_PINNED_WIDTH_CHANGED="rightPinnedWidthChanged",e.EVENT_ROW_CONTAINER_HEIGHT_CHANGED="rowContainerHeightChanged",e.EVENT_ROW_DRAG_ENTER="rowDragEnter",e.EVENT_ROW_DRAG_MOVE="rowDragMove",e.EVENT_ROW_DRAG_LEAVE="rowDragLeave",e.EVENT_ROW_DRAG_END="rowDragEnd",e.EVENT_POPUP_TO_FRONT="popupToFront",e.EVENT_COLUMN_ROW_GROUP_CHANGE_REQUEST="columnRowGroupChangeRequest",e.EVENT_COLUMN_PIVOT_CHANGE_REQUEST="columnPivotChangeRequest",e.EVENT_COLUMN_VALUE_CHANGE_REQUEST="columnValueChangeRequest",e.EVENT_COLUMN_AGG_FUNC_CHANGE_REQUEST="columnAggFuncChangeRequest",e.EVENT_KEYBOARD_FOCUS="keyboardFocus",e.EVENT_MOUSE_FOCUS="mouseFocus",e.EVENT_STORE_UPDATED="storeUpdated",e}()},function(e,t,a){"use strict";a.r(t),a.d(t,"firstExistingValue",(function(){return o})),a.d(t,"existsAndNotEmpty",(function(){return n})),a.d(t,"last",(function(){return i})),a.d(t,"areEqual",(function(){return l})),a.d(t,"compareArrays",(function(){return g})),a.d(t,"shallowCompare",(function(){return p})),a.d(t,"sortNumerically",(function(){return d})),a.d(t,"removeRepeatsFromArray",(function(){return s})),a.d(t,"removeFromArray",(function(){return c})),a.d(t,"removeAllFromArray",(function(){return u})),a.d(t,"insertIntoArray",(function(){return h})),a.d(t,"insertArrayIntoArray",(function(){return f})),a.d(t,"moveInArray",(function(){return m})),a.d(t,"includes",(function(){return b})),a.d(t,"flatten",(function(){return w})),a.d(t,"pushAll",(function(){return v})),a.d(t,"toStrings",(function(){return x})),a.d(t,"forEachReverse",(function(){return y}));var r=a(1);function o(){for(var e=[],t=0;t0}function i(e){if(e&&e.length)return e[e.length-1]}function l(e,t,a){return null==e&&null==t||null!=e&&null!=t&&e.length===t.length&&e.every((function(e,r){return a?a(e,t[r]):t[r]===e}))}function g(e,t){return l(e,t)}function p(e,t){return l(e,t)}function d(e){return e.sort((function(e,t){return e-t}))}function s(e,t){if(e)for(var a=e.length-2;a>=0;a--){var r=e[a]===t,o=e[a+1]===t;r&&o&&e.splice(a+1,1)}}function c(e,t){var a=e.indexOf(t);a>=0&&e.splice(a,1)}function u(e,t){t.forEach((function(t){return c(e,t)}))}function h(e,t,a){e.splice(a,0,t)}function f(e,t,a){if(null!=e&&null!=t)for(var r=t.length-1;r>=0;r--){h(e,t[r],a)}}function m(e,t,a){u(e,t),t.slice().reverse().forEach((function(t){return h(e,t,a)}))}function b(e,t){return e.indexOf(t)>-1}function w(e){return[].concat.apply([],e)}function v(e,t){null!=t&&null!=e&&t.forEach((function(t){return e.push(t)}))}function x(e){return e.map(r.toStringOrNull)}function y(e,t){if(null!=e)for(var a=e.length-1;a>=0;a--)t(e[a],a)}},function(e,t,a){"use strict";function r(e,t,a){e.setAttribute(n(t),a.toString())}function o(e,t){e.removeAttribute(n(t))}function n(e){return"aria-"+e}function i(e,t){t?e.setAttribute("role",t):e.removeAttribute("role")}function l(e){return e.isSortAscending()?"ascending":e.isSortDescending()?"descending":"none"}function g(e){return parseInt(e.getAttribute("aria-level"),10)}function p(e){return parseInt(e.getAttribute("aria-posinset"),10)}function d(e){return e.getAttribute("aria-describedby")||""}function s(e,t){t?r(e,"label",t):o(e,"label")}function c(e,t){var a="labelledby";t?r(e,a,t):o(e,a)}function u(e,t){var a="describedby";t?r(e,a,t):o(e,a)}function h(e,t){r(e,"level",t)}function f(e,t){r(e,"disabled",t)}function m(e,t){r(e,"expanded",t)}function b(e){o(e,"expanded")}function w(e,t){r(e,"setsize",t)}function v(e,t){r(e,"posinset",t)}function x(e,t){r(e,"multiselectable",t)}function y(e,t){r(e,"rowcount",t)}function k(e,t){r(e,"rowindex",t)}function C(e,t){r(e,"colcount",t)}function O(e,t){r(e,"colindex",t)}function A(e,t){r(e,"colspan",t)}function E(e,t){r(e,"sort",t)}function R(e){o(e,"sort")}function S(e,t){t?r(e,"selected",t):o(e,"selected")}function T(e,t){r(e,"checked",void 0===t?"mixed":t)}a.r(t),a.d(t,"setAriaRole",(function(){return i})),a.d(t,"getAriaSortState",(function(){return l})),a.d(t,"getAriaLevel",(function(){return g})),a.d(t,"getAriaPosInSet",(function(){return p})),a.d(t,"getAriaDescribedBy",(function(){return d})),a.d(t,"setAriaLabel",(function(){return s})),a.d(t,"setAriaLabelledBy",(function(){return c})),a.d(t,"setAriaDescribedBy",(function(){return u})),a.d(t,"setAriaLevel",(function(){return h})),a.d(t,"setAriaDisabled",(function(){return f})),a.d(t,"setAriaExpanded",(function(){return m})),a.d(t,"removeAriaExpanded",(function(){return b})),a.d(t,"setAriaSetSize",(function(){return w})),a.d(t,"setAriaPosInSet",(function(){return v})),a.d(t,"setAriaMultiSelectable",(function(){return x})),a.d(t,"setAriaRowCount",(function(){return y})),a.d(t,"setAriaRowIndex",(function(){return k})),a.d(t,"setAriaColCount",(function(){return C})),a.d(t,"setAriaColIndex",(function(){return O})),a.d(t,"setAriaColSpan",(function(){return A})),a.d(t,"setAriaSort",(function(){return E})),a.d(t,"removeAriaSort",(function(){return R})),a.d(t,"setAriaSelected",(function(){return S})),a.d(t,"setAriaChecked",(function(){return T}))},function(e,t,a){"use strict";a.r(t),a.d(t,"iterateObject",(function(){return o})),a.d(t,"cloneObject",(function(){return n})),a.d(t,"deepCloneObject",(function(){return i})),a.d(t,"deepCloneDefinition",(function(){return l})),a.d(t,"getProperty",(function(){return g})),a.d(t,"setProperty",(function(){return p})),a.d(t,"copyPropertiesIfPresent",(function(){return d})),a.d(t,"copyPropertyIfPresent",(function(){return s})),a.d(t,"getAllKeysInObjects",(function(){return c})),a.d(t,"getAllValuesInObject",(function(){return u})),a.d(t,"mergeDeep",(function(){return h})),a.d(t,"missingOrEmptyObject",(function(){return f})),a.d(t,"get",(function(){return m})),a.d(t,"set",(function(){return b})),a.d(t,"deepFreeze",(function(){return w})),a.d(t,"getValueUsingField",(function(){return v})),a.d(t,"removeAllReferences",(function(){return x})),a.d(t,"isNonNullObject",(function(){return y}));var r=a(1);function o(e,t){null!=e&&(Array.isArray(e)?e.forEach((function(e,a){return t(""+a,e)})):Object.keys(e).forEach((function(a){return t(a,e[a])})))}function n(e){for(var t={},a=Object.keys(e),r=0;r=0)){var o=a[e],n=y(o)&&o.constructor===Object;r[e]=n?l(o):o}})),r}}function g(e,t){return e[t]}function p(e,t,a){e[t]=a}function d(e,t){for(var a=[],r=2;r1;)if(null==(o=o[r.shift()]))return a;var n=o[r[0]];return null!=n?n:a}function b(e,t,a){if(null!=e){for(var r=t.split("."),o=e;r.length>1;)if(null==(o=o[r.shift()]))return;o[r[0]]=a}}function w(e){return Object.freeze(e),Object(r.values)(e).forEach((function(e){(y(e)||"function"==typeof e)&&w(e)})),e}function v(e,t,a){if(t&&e){if(!a)return e[t];for(var r=t.split("."),o=e,n=0;n=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},c=new i.d,u=function(){function e(e){this.cssClassStates={},this.getGui=e}return e.prototype.addCssClass=function(e){!0!==this.cssClassStates[e]&&e.length&&(this.getGui().classList.add(e),this.cssClassStates[e]=!0)},e.prototype.removeCssClass=function(e){!1!==this.cssClassStates[e]&&e.length&&(this.getGui().classList.remove(e),this.cssClassStates[e]=!1)},e.prototype.containsCssClass=function(e){return this.getGui().classList.contains(e)},e.prototype.addOrRemoveCssClass=function(e,t){this.cssClassStates[e]!==t&&e.length&&(this.getGui().classList.toggle(e,t),this.cssClassStates[e]=t)},e}(),h=function(e){function t(t){var a=e.call(this)||this;return a.displayed=!0,a.visible=!0,a.compId=c.next(),a.cssClassManager=new u((function(){return a.eGui})),t&&a.setTemplate(t),a}return d(t,e),t.prototype.preConstructOnComponent=function(){this.usingBrowserTooltips=this.gridOptionsWrapper.isEnableBrowserTooltips()},t.prototype.getCompId=function(){return this.compId},t.prototype.getTooltipParams=function(){return{value:this.tooltipText,location:"UNKNOWN"}},t.prototype.setTooltip=function(e){var t=this;this.tooltipText!=e&&(this.tooltipText&&(t.usingBrowserTooltips?t.getGui().removeAttribute("title"):t.tooltipFeature=t.destroyBean(t.tooltipFeature)),null!=e&&(this.tooltipText=e,this.tooltipText&&(t.usingBrowserTooltips?t.getGui().setAttribute("title",t.tooltipText):t.tooltipFeature=t.createBean(new p.a(t)))))},t.prototype.createChildComponentsFromTags=function(e,t){var a=this;Object(l.copyNodeList)(e.childNodes).forEach((function(r){if(r instanceof HTMLElement){var o=a.createComponentFromElement(r,(function(e){e.getGui()&&a.copyAttributesFromNode(r,e.getGui())}),t);if(o){if(o.addItems&&r.children.length){a.createChildComponentsFromTags(r,t);var n=Array.prototype.slice.call(r.children);o.addItems(n)}a.swapComponentForNode(o,e,r)}else r.childNodes&&a.createChildComponentsFromTags(r,t)}}))},t.prototype.createComponentFromElement=function(e,a,r){var o=e.nodeName,n=r?r[e.getAttribute("ref")]:void 0,i=this.agStackComponentsRegistry.getComponentClass(o);if(i){t.elementGettingCreated=e;var l=new i(n);return l.setParentComponent(this),this.createBean(l,null,a),l}return null},t.prototype.copyAttributesFromNode=function(e,t){Object(l.iterateNamedNodeMap)(e.attributes,(function(e,a){return t.setAttribute(e,a)}))},t.prototype.swapComponentForNode=function(e,t,a){var r=e.getGui();t.replaceChild(r,a),t.insertBefore(document.createComment(a.nodeName),r),this.addDestroyFunc(this.destroyBean.bind(this,e)),this.swapInComponentForQuerySelectors(e,a)},t.prototype.swapInComponentForQuerySelectors=function(e,t){var a=this;this.iterateOverQuerySelectors((function(r){a[r.attributeName]===t&&(a[r.attributeName]=e)}))},t.prototype.iterateOverQuerySelectors=function(e){for(var t=Object.getPrototypeOf(this);null!=t;){var a=t.__agComponentMetaData,r=Object(g.getFunctionName)(t.constructor);a&&a[r]&&a[r].querySelectors&&a[r].querySelectors.forEach((function(t){return e(t)})),t=Object.getPrototypeOf(t)}},t.prototype.setTemplate=function(e,t){var a=Object(l.loadTemplate)(e);this.setTemplateFromElement(a,t)},t.prototype.setTemplateFromElement=function(e,t){this.eGui=e,this.eGui.__agComponent=this,this.wireQuerySelectors(),this.getContext()&&this.createChildComponentsFromTags(this.getGui(),t)},t.prototype.createChildComponentsPreConstruct=function(){this.getGui()&&this.createChildComponentsFromTags(this.getGui())},t.prototype.wireQuerySelectors=function(){var e=this;if(this.eGui){var t=this;this.iterateOverQuerySelectors((function(a){var r=function(e){return t[a.attributeName]=e};if(a.refSelector&&e.eGui.getAttribute("ref")===a.refSelector)r(e.eGui);else{var o=e.eGui.querySelector(a.querySelector);o&&r(o.__agComponent||o)}}))}},t.prototype.getGui=function(){return this.eGui},t.prototype.getFocusableElement=function(){return this.eGui},t.prototype.setParentComponent=function(e){this.parentComponent=e},t.prototype.getParentComponent=function(){return this.parentComponent},t.prototype.setGui=function(e){this.eGui=e},t.prototype.queryForHtmlElement=function(e){return this.eGui.querySelector(e)},t.prototype.queryForHtmlInputElement=function(e){return this.eGui.querySelector(e)},t.prototype.appendChild=function(e,t){if(t||(t=this.eGui),null!=e)if(Object(l.isNodeOrElement)(e))t.appendChild(e);else{var a=e;t.appendChild(a.getGui()),this.addDestroyFunc(this.destroyBean.bind(this,a))}},t.prototype.isDisplayed=function(){return this.displayed},t.prototype.setVisible=function(e){e!==this.visible&&(this.visible=e,Object(l.setVisible)(this.eGui,e))},t.prototype.setDisplayed=function(e){if(e!==this.displayed){this.displayed=e,Object(l.setDisplayed)(this.eGui,e);var a={type:t.EVENT_DISPLAYED_CHANGED,visible:this.displayed};this.dispatchEvent(a)}},t.prototype.destroy=function(){this.tooltipFeature&&(this.tooltipFeature=this.destroyBean(this.tooltipFeature)),e.prototype.destroy.call(this)},t.prototype.addGuiEventListener=function(e,t){var a=this;this.eGui.addEventListener(e,t),this.addDestroyFunc((function(){return a.eGui.removeEventListener(e,t)}))},t.prototype.addCssClass=function(e){this.cssClassManager.addCssClass(e)},t.prototype.removeCssClass=function(e){this.cssClassManager.removeCssClass(e)},t.prototype.containsCssClass=function(e){return this.cssClassManager.containsCssClass(e)},t.prototype.addOrRemoveCssClass=function(e,t){this.cssClassManager.addOrRemoveCssClass(e,t)},t.prototype.getAttribute=function(e){var t=this.eGui;return t?t.getAttribute(e):null},t.prototype.getRefElement=function(e){return this.queryForHtmlElement('[ref="'+e+'"]')},t.EVENT_DISPLAYED_CHANGED="displayedChanged",s([Object(o.a)("agStackComponentsRegistry")],t.prototype,"agStackComponentsRegistry",void 0),s([o.f],t.prototype,"preConstructOnComponent",null),s([o.f],t.prototype,"createChildComponentsPreConstruct",null),t}(n.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return R}));var r=a(34),o=a(2),n=a(91),i=a(0),l=a(45),g=a(92),p=a(9),d=a(182),s=a(16),c=a(12),u=a(17),h=a(42),f=a(1),m=a(176),b=a(15),w=a(22),v=a(27),x=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},y=function(e,t){return function(a,r){t(a,r,e)}},k=function(e,t){var a="function"==typeof Symbol&&e[Symbol.iterator];if(!a)return e;var r,o,n=a.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(r=n.next()).done;)i.push(r.value)}catch(e){o={error:e}}finally{try{r&&!r.done&&(a=n.return)&&a.call(n)}finally{if(o)throw o.error}}return i},C=function(){for(var e=[],t=0;t0?a:t}var R=function(){function e(){this.propertyEventService=new r.a,this.domDataKey="__AG_"+Math.random().toString(),this.destroyed=!1}var t;return t=e,e.prototype.agWire=function(e,t){this.gridOptions.api=e,this.gridOptions.columnApi=t,this.checkForDeprecated(),this.checkForViolations()},e.prototype.destroy=function(){this.gridOptions.api=null,this.gridOptions.columnApi=null,this.destroyed=!0},e.prototype.init=function(){var e=this;!0!==this.gridOptions.suppressPropertyNamesCheck&&(this.checkGridOptionsProperties(),this.checkColumnDefProperties()),null!=this.gridOptions.sideBar&&(this.gridOptions.sideBar=d.a.parse(this.gridOptions.sideBar));var t=this.useAsyncEvents();if(this.eventService.addGlobalListener(this.globalEventHandler.bind(this),t),this.isGroupSelectsChildren()&&this.isSuppressParentsInRowNodes()&&console.warn("AG Grid: 'groupSelectsChildren' does not work with 'suppressParentsInRowNodes', this selection method needs the part in rowNode to work"),this.isGroupSelectsChildren()&&(this.isRowSelectionMulti()||console.warn("AG Grid: rowSelection must be 'multiple' for groupSelectsChildren to make sense"),this.isRowModelServerSide()&&console.warn("AG Grid: group selects children is NOT support for Server Side Row Model. This is because the rows are lazy loaded, so selecting a group is not possible asthe grid has no way of knowing what the children are.")),this.isGroupRemoveSingleChildren()&&this.isGroupHideOpenParents()&&console.warn("AG Grid: groupRemoveSingleChildren and groupHideOpenParents do not work with each other, you need to pick one. And don't ask us how to us these together on our support forum either you will get the same answer!"),this.isRowModelServerSide()){var a=function(e){return"AG Grid: '"+e+"' is not supported on the Server-Side Row Model"};Object(f.exists)(this.gridOptions.groupDefaultExpanded)&&console.warn(a("groupDefaultExpanded")),Object(f.exists)(this.gridOptions.groupDefaultExpanded)&&console.warn(a("groupIncludeFooter")),Object(f.exists)(this.gridOptions.groupDefaultExpanded)&&console.warn(a("groupIncludeTotalFooter"))}this.isEnableRangeSelection()&&u.a.assertRegistered(s.a.RangeSelectionModule,"enableRangeSelection"),this.isEnableRangeSelection()||!this.isEnableRangeHandle()&&!this.isEnableFillHandle()||console.warn("AG Grid: 'enableRangeHandle' and 'enableFillHandle' will not work unless 'enableRangeSelection' is set to true");var r=function(t){e.gridOptions.icons&&e.gridOptions.icons[t]&&console.warn("gridOptions.icons."+t+" is no longer supported. For information on how to style checkboxes and radio buttons, see https://www.ag-grid.com/javascript-grid-icons/")};r("radioButtonOff"),r("radioButtonOn"),r("checkboxChecked"),r("checkboxUnchecked"),r("checkboxIndeterminate"),this.getScrollbarWidth()},e.prototype.checkColumnDefProperties=function(){var e=this;null!=this.gridOptions.columnDefs&&this.gridOptions.columnDefs.forEach((function(t){var a=Object.getOwnPropertyNames(t),r=C(g.a.ALL_PROPERTIES,g.a.FRAMEWORK_PROPERTIES);e.checkProperties(a,r,r,"colDef","https://www.ag-grid.com/javascript-grid-column-properties/")}))},e.prototype.checkGridOptionsProperties=function(){var e=Object.getOwnPropertyNames(this.gridOptions),t=C(l.a.ALL_PROPERTIES,l.a.FRAMEWORK_PROPERTIES,Object(f.values)(p.a).map((function(e){return n.a.getCallbackForEvent(e)}))),a=C(t,["api","columnApi"]);this.checkProperties(e,a,t,"gridOptions","https://www.ag-grid.com/javascript-grid-properties/")},e.prototype.checkProperties=function(e,t,a,r,o){var n=Object(m.fuzzyCheckStrings)(e,t,a);Object(c.iterateObject)(n,(function(e,t){console.warn("ag-grid: invalid "+r+" property '"+e+"' did you mean any of these: "+t.slice(0,8).join(", "))})),Object.keys(n).length>0&&console.warn("ag-grid: to see all the valid "+r+" properties please check: "+o)},e.prototype.getDomDataKey=function(){return this.domDataKey},e.prototype.getDomData=function(e,t){var a=e[this.getDomDataKey()];return a?a[t]:void 0},e.prototype.setDomData=function(e,t,a){var r=this.getDomDataKey(),o=e[r];Object(f.missing)(o)&&(o={},e[r]=o),o[t]=a},e.prototype.isRowSelection=function(){return"single"===this.gridOptions.rowSelection||"multiple"===this.gridOptions.rowSelection},e.prototype.isSuppressRowDeselection=function(){return O(this.gridOptions.suppressRowDeselection)},e.prototype.isRowSelectionMulti=function(){return"multiple"===this.gridOptions.rowSelection},e.prototype.isRowMultiSelectWithClick=function(){return O(this.gridOptions.rowMultiSelectWithClick)},e.prototype.getContext=function(){return this.gridOptions.context},e.prototype.isPivotMode=function(){return O(this.gridOptions.pivotMode)},e.prototype.isSuppressExpandablePivotGroups=function(){return O(this.gridOptions.suppressExpandablePivotGroups)},e.prototype.getPivotColumnGroupTotals=function(){return this.gridOptions.pivotColumnGroupTotals},e.prototype.getPivotRowTotals=function(){return this.gridOptions.pivotRowTotals},e.prototype.isRowModelInfinite=function(){return this.gridOptions.rowModelType===o.a.ROW_MODEL_TYPE_INFINITE},e.prototype.isRowModelViewport=function(){return this.gridOptions.rowModelType===o.a.ROW_MODEL_TYPE_VIEWPORT},e.prototype.isRowModelServerSide=function(){return this.gridOptions.rowModelType===o.a.ROW_MODEL_TYPE_SERVER_SIDE},e.prototype.isRowModelDefault=function(){return Object(f.missing)(this.gridOptions.rowModelType)||this.gridOptions.rowModelType===o.a.ROW_MODEL_TYPE_CLIENT_SIDE},e.prototype.isFullRowEdit=function(){return"fullRow"===this.gridOptions.editType},e.prototype.isSuppressFocusAfterRefresh=function(){return O(this.gridOptions.suppressFocusAfterRefresh)},e.prototype.isSuppressBrowserResizeObserver=function(){return O(this.gridOptions.suppressBrowserResizeObserver)},e.prototype.isSuppressMaintainUnsortedOrder=function(){return O(this.gridOptions.suppressMaintainUnsortedOrder)},e.prototype.isSuppressClearOnFillReduction=function(){return O(this.gridOptions.suppressClearOnFillReduction)},e.prototype.isShowToolPanel=function(){return O(this.gridOptions.sideBar&&Array.isArray(this.getSideBar().toolPanels))},e.prototype.getSideBar=function(){return this.gridOptions.sideBar},e.prototype.isSuppressTouch=function(){return O(this.gridOptions.suppressTouch)},e.prototype.isMaintainColumnOrder=function(){return O(this.gridOptions.maintainColumnOrder)},e.prototype.isSuppressRowTransform=function(){return O(this.gridOptions.suppressRowTransform)},e.prototype.isSuppressColumnStateEvents=function(){return O(this.gridOptions.suppressColumnStateEvents)},e.prototype.isAllowDragFromColumnsToolPanel=function(){return O(this.gridOptions.allowDragFromColumnsToolPanel)},e.prototype.useAsyncEvents=function(){return!O(this.gridOptions.suppressAsyncEvents)},e.prototype.isEnableCellChangeFlash=function(){return O(this.gridOptions.enableCellChangeFlash)},e.prototype.getCellFlashDelay=function(){return this.gridOptions.cellFlashDelay||500},e.prototype.getCellFadeDelay=function(){return this.gridOptions.cellFadeDelay||1e3},e.prototype.isGroupSelectsChildren=function(){var e=O(this.gridOptions.groupSelectsChildren);return e&&this.isTreeData()?(console.warn("AG Grid: groupSelectsChildren does not work with tree data"),!1):e},e.prototype.isSuppressRowHoverHighlight=function(){return O(this.gridOptions.suppressRowHoverHighlight)},e.prototype.isColumnHoverHighlight=function(){return O(this.gridOptions.columnHoverHighlight)},e.prototype.isGroupSelectsFiltered=function(){return O(this.gridOptions.groupSelectsFiltered)},e.prototype.isGroupHideOpenParents=function(){return O(this.gridOptions.groupHideOpenParents)},e.prototype.isGroupMaintainOrder=function(){return O(this.gridOptions.groupMaintainOrder)},e.prototype.getAutoGroupColumnDef=function(){return this.gridOptions.autoGroupColumnDef},e.prototype.isGroupMultiAutoColumn=function(){return this.gridOptions.groupDisplayType?this.matchesGroupDisplayType("multipleColumns",this.gridOptions.groupDisplayType):O(this.gridOptions.groupHideOpenParents)},e.prototype.isGroupUseEntireRow=function(e){return!e&&(!!this.gridOptions.groupDisplayType&&this.matchesGroupDisplayType("groupRows",this.gridOptions.groupDisplayType))},e.prototype.isGroupSuppressAutoColumn=function(){return!(!this.gridOptions.groupDisplayType||!this.matchesGroupDisplayType("custom",this.gridOptions.groupDisplayType))||!!this.gridOptions.treeDataDisplayType&&this.matchesTreeDataDisplayType("custom",this.gridOptions.treeDataDisplayType)},e.prototype.isGroupRemoveSingleChildren=function(){return O(this.gridOptions.groupRemoveSingleChildren)},e.prototype.isGroupRemoveLowestSingleChildren=function(){return O(this.gridOptions.groupRemoveLowestSingleChildren)},e.prototype.isGroupIncludeFooter=function(){return O(this.gridOptions.groupIncludeFooter)},e.prototype.isGroupIncludeTotalFooter=function(){return O(this.gridOptions.groupIncludeTotalFooter)},e.prototype.isGroupSuppressBlankHeader=function(){return O(this.gridOptions.groupSuppressBlankHeader)},e.prototype.isSuppressRowClickSelection=function(){return O(this.gridOptions.suppressRowClickSelection)},e.prototype.isSuppressCellFocus=function(){return O(this.gridOptions.suppressCellFocus)},e.prototype.isSuppressMultiSort=function(){return O(this.gridOptions.suppressMultiSort)},e.prototype.isMultiSortKeyCtrl=function(){return"ctrl"===this.gridOptions.multiSortKey},e.prototype.isPivotSuppressAutoColumn=function(){return O(this.gridOptions.pivotSuppressAutoColumn)},e.prototype.isSuppressDragLeaveHidesColumns=function(){return O(this.gridOptions.suppressDragLeaveHidesColumns)},e.prototype.isSuppressScrollOnNewData=function(){return O(this.gridOptions.suppressScrollOnNewData)},e.prototype.isSuppressScrollWhenPopupsAreOpen=function(){return O(this.gridOptions.suppressScrollWhenPopupsAreOpen)},e.prototype.isRowDragEntireRow=function(){return O(this.gridOptions.rowDragEntireRow)},e.prototype.isSuppressRowDrag=function(){return O(this.gridOptions.suppressRowDrag)},e.prototype.isRowDragManaged=function(){return O(this.gridOptions.rowDragManaged)},e.prototype.isSuppressMoveWhenRowDragging=function(){return O(this.gridOptions.suppressMoveWhenRowDragging)},e.prototype.isRowDragMultiRow=function(){return O(this.gridOptions.rowDragMultiRow)},e.prototype.getDomLayout=function(){var e=this.gridOptions.domLayout||o.a.DOM_LAYOUT_NORMAL;return-1===[o.a.DOM_LAYOUT_PRINT,o.a.DOM_LAYOUT_AUTO_HEIGHT,o.a.DOM_LAYOUT_NORMAL].indexOf(e)?(Object(b.doOnce)((function(){return console.warn("AG Grid: "+e+" is not valid for DOM Layout, valid values are "+o.a.DOM_LAYOUT_NORMAL+", "+o.a.DOM_LAYOUT_AUTO_HEIGHT+" and "+o.a.DOM_LAYOUT_PRINT)}),"warn about dom layout values"),o.a.DOM_LAYOUT_NORMAL):e},e.prototype.isSuppressHorizontalScroll=function(){return O(this.gridOptions.suppressHorizontalScroll)},e.prototype.isSuppressMaxRenderedRowRestriction=function(){return O(this.gridOptions.suppressMaxRenderedRowRestriction)},e.prototype.isExcludeChildrenWhenTreeDataFiltering=function(){return O(this.gridOptions.excludeChildrenWhenTreeDataFiltering)},e.prototype.isAlwaysShowHorizontalScroll=function(){return O(this.gridOptions.alwaysShowHorizontalScroll)},e.prototype.isAlwaysShowVerticalScroll=function(){return O(this.gridOptions.alwaysShowVerticalScroll)},e.prototype.isDebounceVerticalScrollbar=function(){return O(this.gridOptions.debounceVerticalScrollbar)},e.prototype.isSuppressLoadingOverlay=function(){return O(this.gridOptions.suppressLoadingOverlay)},e.prototype.isSuppressNoRowsOverlay=function(){return O(this.gridOptions.suppressNoRowsOverlay)},e.prototype.isSuppressFieldDotNotation=function(){return O(this.gridOptions.suppressFieldDotNotation)},e.prototype.getPinnedTopRowData=function(){return this.gridOptions.pinnedTopRowData},e.prototype.getPinnedBottomRowData=function(){return this.gridOptions.pinnedBottomRowData},e.prototype.isFunctionsPassive=function(){return O(this.gridOptions.functionsPassive)},e.prototype.isSuppressChangeDetection=function(){return O(this.gridOptions.suppressChangeDetection)},e.prototype.isSuppressAnimationFrame=function(){return O(this.gridOptions.suppressAnimationFrame)},e.prototype.getQuickFilterText=function(){return this.gridOptions.quickFilterText},e.prototype.isCacheQuickFilter=function(){return O(this.gridOptions.cacheQuickFilter)},e.prototype.isUnSortIcon=function(){return O(this.gridOptions.unSortIcon)},e.prototype.isSuppressMenuHide=function(){return O(this.gridOptions.suppressMenuHide)},e.prototype.isEnterMovesDownAfterEdit=function(){return O(this.gridOptions.enterMovesDownAfterEdit)},e.prototype.isEnterMovesDown=function(){return O(this.gridOptions.enterMovesDown)},e.prototype.isUndoRedoCellEditing=function(){return O(this.gridOptions.undoRedoCellEditing)},e.prototype.getUndoRedoCellEditingLimit=function(){return A(this.gridOptions.undoRedoCellEditingLimit)},e.prototype.getRowStyle=function(){return this.gridOptions.rowStyle},e.prototype.getRowClass=function(){return this.gridOptions.rowClass},e.prototype.getRowStyleFunc=function(){return this.gridOptions.getRowStyle},e.prototype.getRowClassFunc=function(){return this.gridOptions.getRowClass},e.prototype.rowClassRules=function(){return this.gridOptions.rowClassRules},e.prototype.getServerSideStoreType=function(){return this.gridOptions.serverSideStoreType},e.prototype.getServerSideStoreParamsFunc=function(){return this.gridOptions.getServerSideStoreParams},e.prototype.getCreateChartContainerFunc=function(){return this.gridOptions.createChartContainer},e.prototype.getPopupParent=function(){return this.gridOptions.popupParent},e.prototype.getBlockLoadDebounceMillis=function(){return this.gridOptions.blockLoadDebounceMillis},e.prototype.getPostProcessPopupFunc=function(){return this.gridOptions.postProcessPopup},e.prototype.getPaginationNumberFormatterFunc=function(){return this.gridOptions.paginationNumberFormatter},e.prototype.getChildCountFunc=function(){return this.gridOptions.getChildCount},e.prototype.getIsApplyServerSideTransactionFunc=function(){return this.gridOptions.isApplyServerSideTransaction},e.prototype.getDefaultGroupOrderComparator=function(){return this.gridOptions.defaultGroupOrderComparator},e.prototype.getIsFullWidthCellFunc=function(){return this.gridOptions.isFullWidthCell},e.prototype.getFullWidthCellRendererParams=function(){return this.gridOptions.fullWidthCellRendererParams},e.prototype.isEmbedFullWidthRows=function(){return O(this.gridOptions.embedFullWidthRows)||O(this.gridOptions.deprecatedEmbedFullWidthRows)},e.prototype.isDetailRowAutoHeight=function(){return O(this.gridOptions.detailRowAutoHeight)},e.prototype.getSuppressKeyboardEventFunc=function(){return this.gridOptions.suppressKeyboardEvent},e.prototype.getBusinessKeyForNodeFunc=function(){return this.gridOptions.getBusinessKeyForNode},e.prototype.getApi=function(){return this.gridOptions.api},e.prototype.getColumnApi=function(){return this.gridOptions.columnApi},e.prototype.isReadOnlyEdit=function(){return O(this.gridOptions.readOnlyEdit)},e.prototype.isImmutableData=function(){return null!=this.gridOptions.getRowId||O(this.gridOptions.immutableData)},e.prototype.isEnsureDomOrder=function(){return O(this.gridOptions.ensureDomOrder)},e.prototype.isEnableCharts=function(){return!!O(this.gridOptions.enableCharts)&&u.a.assertRegistered(s.a.GridChartsModule,"enableCharts")},e.prototype.getColResizeDefault=function(){return this.gridOptions.colResizeDefault},e.prototype.isSingleClickEdit=function(){return O(this.gridOptions.singleClickEdit)},e.prototype.isSuppressClickEdit=function(){return O(this.gridOptions.suppressClickEdit)},e.prototype.isStopEditingWhenCellsLoseFocus=function(){return O(this.gridOptions.stopEditingWhenCellsLoseFocus)},e.prototype.getGroupDefaultExpanded=function(){return this.gridOptions.groupDefaultExpanded},e.prototype.getMaxConcurrentDatasourceRequests=function(){var e=A(this.gridOptions.maxConcurrentDatasourceRequests);return null==e?2:e<=0?void 0:e},e.prototype.getMaxBlocksInCache=function(){return this.gridOptions.maxBlocksInCache},e.prototype.getCacheOverflowSize=function(){return this.gridOptions.cacheOverflowSize},e.prototype.getPaginationPageSize=function(){return A(this.gridOptions.paginationPageSize)},e.prototype.isPaginateChildRows=function(){return!(!this.isGroupRemoveSingleChildren()&&!this.isGroupRemoveLowestSingleChildren())||O(this.gridOptions.paginateChildRows)},e.prototype.getCacheBlockSize=function(){return E(this.gridOptions.cacheBlockSize)},e.prototype.getInfiniteInitialRowCount=function(){return this.gridOptions.infiniteInitialRowCount},e.prototype.isPurgeClosedRowNodes=function(){return O(this.gridOptions.purgeClosedRowNodes)},e.prototype.isSuppressPaginationPanel=function(){return O(this.gridOptions.suppressPaginationPanel)},e.prototype.getRowData=function(){return this.gridOptions.rowData},e.prototype.isEnableRtl=function(){return O(this.gridOptions.enableRtl)},e.prototype.getRowGroupPanelShow=function(){return this.gridOptions.rowGroupPanelShow},e.prototype.getPivotPanelShow=function(){return this.gridOptions.pivotPanelShow},e.prototype.isAngularCompileRows=function(){return O(this.gridOptions.angularCompileRows)},e.prototype.isAngularCompileFilters=function(){return O(this.gridOptions.angularCompileFilters)},e.prototype.isDebug=function(){return O(this.gridOptions.debug)},e.prototype.getColumnDefs=function(){return this.gridOptions.columnDefs},e.prototype.getColumnTypes=function(){return this.gridOptions.columnTypes},e.prototype.getDatasource=function(){return this.gridOptions.datasource},e.prototype.getViewportDatasource=function(){return this.gridOptions.viewportDatasource},e.prototype.getServerSideDatasource=function(){return this.gridOptions.serverSideDatasource},e.prototype.isAccentedSort=function(){return O(this.gridOptions.accentedSort)},e.prototype.isEnableBrowserTooltips=function(){return O(this.gridOptions.enableBrowserTooltips)},e.prototype.isEnableCellExpressions=function(){return O(this.gridOptions.enableCellExpressions)},e.prototype.isEnableGroupEdit=function(){return O(this.gridOptions.enableGroupEdit)},e.prototype.isSuppressMiddleClickScrolls=function(){return O(this.gridOptions.suppressMiddleClickScrolls)},e.prototype.isPreventDefaultOnContextMenu=function(){return O(this.gridOptions.preventDefaultOnContextMenu)},e.prototype.isSuppressPreventDefaultOnMouseWheel=function(){return O(this.gridOptions.suppressPreventDefaultOnMouseWheel)},e.prototype.isSuppressColumnVirtualisation=function(){return O(this.gridOptions.suppressColumnVirtualisation)},e.prototype.isSuppressRowVirtualisation=function(){return O(this.gridOptions.suppressRowVirtualisation)},e.prototype.isSuppressContextMenu=function(){return O(this.gridOptions.suppressContextMenu)},e.prototype.isAllowContextMenuWithControlKey=function(){return O(this.gridOptions.allowContextMenuWithControlKey)},e.prototype.isSuppressCopyRowsToClipboard=function(){return O(this.gridOptions.suppressCopyRowsToClipboard)},e.prototype.isCopyHeadersToClipboard=function(){return O(this.gridOptions.copyHeadersToClipboard)},e.prototype.isCopyGroupHeadersToClipboard=function(){return O(this.gridOptions.copyGroupHeadersToClipboard)},e.prototype.isSuppressClipboardPaste=function(){return O(this.gridOptions.suppressClipboardPaste)},e.prototype.isSuppressLastEmptyLineOnPaste=function(){return O(this.gridOptions.suppressLastEmptyLineOnPaste)},e.prototype.isPagination=function(){return O(this.gridOptions.pagination)},e.prototype.isSuppressEnterpriseResetOnNewColumns=function(){return O(this.gridOptions.suppressEnterpriseResetOnNewColumns)},e.prototype.getProcessDataFromClipboardFunc=function(){return this.gridOptions.processDataFromClipboard},e.prototype.getAsyncTransactionWaitMillis=function(){return Object(f.exists)(this.gridOptions.asyncTransactionWaitMillis)?this.gridOptions.asyncTransactionWaitMillis:o.a.BATCH_WAIT_MILLIS},e.prototype.isSuppressMovableColumns=function(){return O(this.gridOptions.suppressMovableColumns)},e.prototype.isAnimateRows=function(){return!this.isEnsureDomOrder()&&O(this.gridOptions.animateRows)},e.prototype.isSuppressColumnMoveAnimation=function(){return O(this.gridOptions.suppressColumnMoveAnimation)},e.prototype.isSuppressAggFuncInHeader=function(){return O(this.gridOptions.suppressAggFuncInHeader)},e.prototype.isSuppressAggAtRootLevel=function(){return O(this.gridOptions.suppressAggAtRootLevel)},e.prototype.isSuppressAggFilteredOnly=function(){return O(this.gridOptions.suppressAggFilteredOnly)},e.prototype.isShowOpenedGroup=function(){return O(this.gridOptions.showOpenedGroup)},e.prototype.isReactUi=function(){return O(this.gridOptions.reactUi)},e.prototype.isSuppressReactUi=function(){return O(this.gridOptions.suppressReactUi)},e.prototype.isEnableRangeSelection=function(){return u.a.isRegistered(s.a.RangeSelectionModule)&&O(this.gridOptions.enableRangeSelection)},e.prototype.isEnableRangeHandle=function(){return O(this.gridOptions.enableRangeHandle)},e.prototype.isEnableFillHandle=function(){return O(this.gridOptions.enableFillHandle)},e.prototype.getFillHandleDirection=function(){var e=this.gridOptions.fillHandleDirection;return e?"x"!==e&&"y"!==e&&"xy"!==e?(Object(b.doOnce)((function(){return console.warn("AG Grid: valid values for fillHandleDirection are 'x', 'y' and 'xy'. Default to 'xy'.")}),"warn invalid fill direction"),"xy"):e:"xy"},e.prototype.getFillOperation=function(){return this.gridOptions.fillOperation},e.prototype.isSuppressMultiRangeSelection=function(){return O(this.gridOptions.suppressMultiRangeSelection)},e.prototype.isPaginationAutoPageSize=function(){return O(this.gridOptions.paginationAutoPageSize)},e.prototype.isRememberGroupStateWhenNewData=function(){return O(this.gridOptions.rememberGroupStateWhenNewData)},e.prototype.getIcons=function(){return this.gridOptions.icons},e.prototype.getAggFuncs=function(){return this.gridOptions.aggFuncs},e.prototype.getSortingOrder=function(){return this.gridOptions.sortingOrder},e.prototype.getAlignedGrids=function(){return this.gridOptions.alignedGrids},e.prototype.isMasterDetail=function(){return!!O(this.gridOptions.masterDetail)&&u.a.assertRegistered(s.a.MasterDetailModule,"masterDetail")},e.prototype.isKeepDetailRows=function(){return O(this.gridOptions.keepDetailRows)},e.prototype.getKeepDetailRowsCount=function(){var e=this.gridOptions.keepDetailRowsCount;return Object(f.exists)(e)&&e>0?this.gridOptions.keepDetailRowsCount:10},e.prototype.getIsRowMasterFunc=function(){return this.gridOptions.isRowMaster},e.prototype.getIsRowSelectableFunc=function(){return this.gridOptions.isRowSelectable},e.prototype.getGroupRowRendererParams=function(){return this.gridOptions.groupRowRendererParams},e.prototype.getOverlayLoadingTemplate=function(){return this.gridOptions.overlayLoadingTemplate},e.prototype.getOverlayNoRowsTemplate=function(){return this.gridOptions.overlayNoRowsTemplate},e.prototype.isSuppressAutoSize=function(){return O(this.gridOptions.suppressAutoSize)},e.prototype.isEnableCellTextSelection=function(){return O(this.gridOptions.enableCellTextSelection)},e.prototype.isSuppressParentsInRowNodes=function(){return O(this.gridOptions.suppressParentsInRowNodes)},e.prototype.isSuppressClipboardApi=function(){return O(this.gridOptions.suppressClipboardApi)},e.prototype.isFunctionsReadOnly=function(){return O(this.gridOptions.functionsReadOnly)},e.prototype.isEnableCellTextSelect=function(){return O(this.gridOptions.enableCellTextSelection)},e.prototype.getDefaultColDef=function(){return this.gridOptions.defaultColDef},e.prototype.getDefaultColGroupDef=function(){return this.gridOptions.defaultColGroupDef},e.prototype.getDefaultExportParams=function(e){return this.gridOptions.defaultExportParams?(console.warn("AG Grid: Since v25.2 `defaultExportParams` has been replaced by `default"+Object(v.capitalise)(e)+"ExportParams`'"),this.gridOptions.defaultExportParams):"csv"===e&&this.gridOptions.defaultCsvExportParams?this.gridOptions.defaultCsvExportParams:"excel"===e&&this.gridOptions.defaultExcelExportParams?this.gridOptions.defaultExcelExportParams:void 0},e.prototype.isSuppressCsvExport=function(){return O(this.gridOptions.suppressCsvExport)},e.prototype.isAllowShowChangeAfterFilter=function(){return O(this.gridOptions.allowShowChangeAfterFilter)},e.prototype.isSuppressExcelExport=function(){return O(this.gridOptions.suppressExcelExport)},e.prototype.isSuppressMakeColumnVisibleAfterUnGroup=function(){return O(this.gridOptions.suppressMakeColumnVisibleAfterUnGroup)},e.prototype.getDataPathFunc=function(){return this.gridOptions.getDataPath},e.prototype.getIsServerSideGroupFunc=function(){return this.gridOptions.isServerSideGroup},e.prototype.getIsServerSideGroupOpenByDefaultFunc=function(){return this.gridOptions.isServerSideGroupOpenByDefault},e.prototype.getIsGroupOpenByDefaultFunc=function(){return this.gridOptions.isGroupOpenByDefault},e.prototype.getServerSideGroupKeyFunc=function(){return this.gridOptions.getServerSideGroupKey},e.prototype.getGroupRowAggNodesFunc=function(){return this.gridOptions.groupRowAggNodes},e.prototype.getContextMenuItemsFunc=function(){return this.gridOptions.getContextMenuItems},e.prototype.getMainMenuItemsFunc=function(){return this.gridOptions.getMainMenuItems},e.prototype.getRowIdFunc=function(){var e=this.gridOptions,t=e.getRowId,a=e.getRowNodeId;return t||(a?function(e){return a(e.data)}:void 0)},e.prototype.getNavigateToNextHeaderFunc=function(){return this.gridOptions.navigateToNextHeader},e.prototype.getTabToNextHeaderFunc=function(){return this.gridOptions.tabToNextHeader},e.prototype.getNavigateToNextCellFunc=function(){return this.gridOptions.navigateToNextCell},e.prototype.getTabToNextCellFunc=function(){return this.gridOptions.tabToNextCell},e.prototype.getGridTabIndex=function(){return(this.gridOptions.tabIndex||0).toString()},e.prototype.isTreeData=function(){return!!O(this.gridOptions.treeData)&&u.a.assertRegistered(s.a.RowGroupingModule,"Tree Data")},e.prototype.isValueCache=function(){return O(this.gridOptions.valueCache)},e.prototype.isValueCacheNeverExpires=function(){return O(this.gridOptions.valueCacheNeverExpires)},e.prototype.isDeltaSort=function(){return O(this.gridOptions.deltaSort)},e.prototype.isAggregateOnlyChangedColumns=function(){return O(this.gridOptions.aggregateOnlyChangedColumns)},e.prototype.getProcessSecondaryColDefFunc=function(){return this.gridOptions.processSecondaryColDef},e.prototype.getProcessSecondaryColGroupDefFunc=function(){return this.gridOptions.processSecondaryColGroupDef},e.prototype.getSendToClipboardFunc=function(){return this.gridOptions.sendToClipboard},e.prototype.getProcessRowPostCreateFunc=function(){return this.gridOptions.processRowPostCreate},e.prototype.getProcessCellForClipboardFunc=function(){return this.gridOptions.processCellForClipboard},e.prototype.getProcessHeaderForClipboardFunc=function(){return this.gridOptions.processHeaderForClipboard},e.prototype.getProcessGroupHeaderForClipboardFunc=function(){return this.gridOptions.processGroupHeaderForClipboard},e.prototype.getProcessCellFromClipboardFunc=function(){return this.gridOptions.processCellFromClipboard},e.prototype.getViewportRowModelPageSize=function(){return E(this.gridOptions.viewportRowModelPageSize,5)},e.prototype.getViewportRowModelBufferSize=function(){return e=this.gridOptions.viewportRowModelBufferSize,t=5,e>=0?e:t;var e,t},e.prototype.isServerSideSortingAlwaysResets=function(){return O(this.gridOptions.serverSideSortingAlwaysResets)},e.prototype.isServerSideFilteringAlwaysResets=function(){return O(this.gridOptions.serverSideFilteringAlwaysResets)},e.prototype.getPostSortFunc=function(){return this.gridOptions.postSort},e.prototype.getChartToolbarItemsFunc=function(){return this.gridOptions.getChartToolbarItems},e.prototype.getChartThemeOverrides=function(){return this.gridOptions.chartThemeOverrides},e.prototype.getCustomChartThemes=function(){return this.gridOptions.customChartThemes},e.prototype.getChartThemes=function(){return this.gridOptions.chartThemes||["ag-default","ag-material","ag-pastel","ag-vivid","ag-solar"]},e.prototype.getClipboardDelimiter=function(){return Object(f.exists)(this.gridOptions.clipboardDelimiter)?this.gridOptions.clipboardDelimiter:"\t"},e.prototype.setProperty=function(e,t,a){void 0===a&&(a=!1);var r=this.gridOptions,o=r[e];if(a||o!==t){r[e]=t;var n={type:e,currentValue:t,previousValue:o};this.propertyEventService.dispatchEvent(n)}},e.prototype.addEventListener=function(e,t){this.propertyEventService.addEventListener(e,t)},e.prototype.removeEventListener=function(e,t){this.propertyEventService.removeEventListener(e,t)},e.prototype.isSkipHeaderOnAutoSize=function(){return!!this.gridOptions.skipHeaderOnAutoSize},e.prototype.getAutoSizePadding=function(){var e=this.gridOptions.autoSizePadding;return null!=e&&e>=0?e:20},e.prototype.getHeaderHeight=function(){return"number"==typeof this.gridOptions.headerHeight?this.gridOptions.headerHeight:this.getFromTheme(25,"headerHeight")},e.prototype.getFloatingFiltersHeight=function(){return"number"==typeof this.gridOptions.floatingFiltersHeight?this.gridOptions.floatingFiltersHeight:this.getFromTheme(25,"headerHeight")},e.prototype.getGroupHeaderHeight=function(){return"number"==typeof this.gridOptions.groupHeaderHeight?this.gridOptions.groupHeaderHeight:this.getHeaderHeight()},e.prototype.getPivotHeaderHeight=function(){return"number"==typeof this.gridOptions.pivotHeaderHeight?this.gridOptions.pivotHeaderHeight:this.getHeaderHeight()},e.prototype.getPivotGroupHeaderHeight=function(){return"number"==typeof this.gridOptions.pivotGroupHeaderHeight?this.gridOptions.pivotGroupHeaderHeight:this.getGroupHeaderHeight()},e.prototype.isExternalFilterPresent=function(){return"function"==typeof this.gridOptions.isExternalFilterPresent&&this.gridOptions.isExternalFilterPresent()},e.prototype.doesExternalFilterPass=function(e){return"function"==typeof this.gridOptions.doesExternalFilterPass&&this.gridOptions.doesExternalFilterPass(e)},e.prototype.getTooltipDelay=function(e){var t=this.gridOptions,a=t.tooltipShowDelay,r=t.tooltipHideDelay,o="show"===e?a:r,n=Object(v.capitalise)(e);return Object(f.exists)(o)?(o<0&&Object(b.doOnce)((function(){return console.warn("ag-grid: tooltip"+n+"Delay should not be lower than 0")}),"tooltip"+n+"DelayWarn"),Math.max(200,o)):null},e.prototype.isTooltipMouseTrack=function(){return O(this.gridOptions.tooltipMouseTrack)},e.prototype.isSuppressModelUpdateAfterUpdateTransaction=function(){return O(this.gridOptions.suppressModelUpdateAfterUpdateTransaction)},e.prototype.getDocument=function(){var e=null;return this.gridOptions.getDocument&&Object(f.exists)(this.gridOptions.getDocument)?e=this.gridOptions.getDocument():this.eGridDiv&&(e=this.eGridDiv.ownerDocument),e&&Object(f.exists)(e)?e:document},e.prototype.getMinColWidth=function(){var e=this.gridOptions.minColWidth;if(Object(f.exists)(e)&&e>t.MIN_COL_WIDTH)return this.gridOptions.minColWidth;var a=this.getFromTheme(null,"headerCellMinWidth");return Object(f.exists)(a)?Math.max(a,t.MIN_COL_WIDTH):t.MIN_COL_WIDTH},e.prototype.getMaxColWidth=function(){return this.gridOptions.maxColWidth&&this.gridOptions.maxColWidth>t.MIN_COL_WIDTH?this.gridOptions.maxColWidth:null},e.prototype.getColWidth=function(){return"number"!=typeof this.gridOptions.colWidth||this.gridOptions.colWidth=0?this.gridOptions.scrollbarWidth:Object(w.getScrollbarWidth)();null!=e&&(this.scrollbarWidth=e,this.eventService.dispatchEvent({type:p.a.EVENT_SCROLLBAR_WIDTH_CHANGED}))}return this.scrollbarWidth},e.prototype.checkForDeprecated=function(){var e=this.gridOptions;e.deprecatedEmbedFullWidthRows&&console.warn("AG Grid: since v21.2, deprecatedEmbedFullWidthRows has been replaced with embedFullWidthRows."),e.rowDeselection&&console.warn("AG Grid: since v24.x, rowDeselection is deprecated and the behaviour is true by default. Please use `suppressRowDeselection` to prevent rows from being deselected."),e.enableMultiRowDragging&&(e.rowDragMultiRow=!0,delete e.enableMultiRowDragging,console.warn("AG Grid: since v26.1, `enableMultiRowDragging` is deprecated. Please use `rowDragMultiRow`."));var t=function(t,a,r){null!=e[t]&&(console.warn("ag-grid: since version "+r+", '"+t+"' is deprecated / renamed, please use the new property name '"+a+"' instead."),null==e[a]&&(e[a]=e[t]))};if(t("batchUpdateWaitMillis","asyncTransactionWaitMillis","23.1.x"),t("deltaRowDataMode","immutableData","23.1.x"),(e.immutableColumns||e.deltaColumnMode)&&console.warn("AG Grid: since v24.0, immutableColumns and deltaColumnMode properties are gone. The grid now works like this as default. To keep column order maintained, set grid property applyColumnDefOrder=true"),t("suppressSetColumnStateEvents","suppressColumnStateEvents","24.0.x"),e.groupRowInnerRenderer||e.groupRowInnerRendererParams||e.groupRowInnerRendererFramework){console.warn("AG Grid: since v24.0, grid properties groupRowInnerRenderer, groupRowInnerRendererFramework and groupRowInnerRendererParams are no longer used."),console.warn(" Instead use the grid properties groupRowRendererParams.innerRenderer, groupRowRendererParams.innerRendererFramework and groupRowRendererParams.innerRendererParams."),console.warn(" For example instead of this:"),console.warn(' groupRowInnerRenderer: "myRenderer"'),console.warn(" groupRowInnerRendererParams: {x: a}"),console.warn(" Replace with this:"),console.warn(" groupRowRendererParams: {"),console.warn(' innerRenderer: "myRenderer",'),console.warn(" innerRendererParams: {x: a}"),console.warn(" }"),console.warn(" We have copied the properties over for you. However to stop this error message, please change your application code."),e.groupRowRendererParams||(e.groupRowRendererParams={});var a=e.groupRowRendererParams;e.groupRowInnerRenderer&&(a.innerRenderer=e.groupRowInnerRenderer),e.groupRowInnerRendererParams&&(a.innerRendererParams=e.groupRowInnerRendererParams),e.groupRowInnerRendererFramework&&(a.innerRendererFramework=e.groupRowInnerRendererFramework)}if(e.rememberGroupStateWhenNewData&&console.warn("AG Grid: since v24.0, grid property rememberGroupStateWhenNewData is deprecated. This feature was provided before Transaction Updates worked (which keep group state). Now that transaction updates are possible and they keep group state, this feature is no longer needed."),e.detailCellRendererParams&&e.detailCellRendererParams.autoHeight&&(console.warn("AG Grid: since v24.1, grid property detailCellRendererParams.autoHeight is replaced with grid property detailRowAutoHeight. This allows this feature to work when you provide a custom DetailCellRenderer"),e.detailRowAutoHeight=!0),e.suppressKeyboardEvent&&console.warn("AG Grid: since v24.1 suppressKeyboardEvent in the gridOptions has been deprecated and will be removed in\n future versions of AG Grid. If you need this to be set for every column use the defaultColDef property."),e.suppressEnterpriseResetOnNewColumns&&console.warn("AG Grid: since v25, grid property suppressEnterpriseResetOnNewColumns is deprecated. This was a temporary property to allow changing columns in Server Side Row Model without triggering a reload. Now that it is possible to dynamically change columns in the grid, this is no longer needed."),e.suppressColumnStateEvents&&console.warn('AG Grid: since v25, grid property suppressColumnStateEvents no longer works due to a refactor that we did. It should be possible to achieve similar using event.source, which would be "api" if the event was due to setting column state via the API'),e.defaultExportParams&&console.warn("AG Grid: since v25.2, the grid property `defaultExportParams` has been replaced by `defaultCsvExportParams` and `defaultExcelExportParams`."),e.stopEditingWhenGridLosesFocus&&(console.warn("AG Grid: since v25.2.2, the grid property `stopEditingWhenGridLosesFocus` has been replaced by `stopEditingWhenCellsLoseFocus`."),e.stopEditingWhenCellsLoseFocus=!0),e.applyColumnDefOrder&&console.warn("AG Grid: since v26.0, the grid property `applyColumnDefOrder` is no longer needed, as this is the default behaviour. To turn this behaviour off, set maintainColumnOrder=true"),e.groupMultiAutoColumn&&(console.warn("AG Grid: since v26.0, the grid property `groupMultiAutoColumn` has been replaced by `groupDisplayType = 'multipleColumns'`"),e.groupDisplayType="multipleColumns"),e.groupUseEntireRow&&(console.warn("AG Grid: since v26.0, the grid property `groupUseEntireRow` has been replaced by `groupDisplayType = 'groupRows'`"),e.groupDisplayType="groupRows"),e.groupSuppressAutoColumn){var r=e.treeData?"treeDataDisplayType":"groupDisplayType";console.warn("AG Grid: since v26.0, the grid property `groupSuppressAutoColumn` has been replaced by `"+r+" = 'custom'`"),e.groupDisplayType="custom"}e.defaultGroupSortComparator&&(console.warn("AG Grid: since v26.0, the grid property `defaultGroupSortComparator` has been replaced by `defaultGroupOrderComparator`"),e.defaultGroupOrderComparator=e.defaultGroupSortComparator),e.colWidth&&console.warn("AG Grid: since v26.1, the grid property `colWidth` is deprecated and should be set via `defaultColDef.width`."),e.minColWidth&&console.warn("AG Grid: since v26.1, the grid property `minColWidth` is deprecated and should be set via `defaultColDef.minWidth`."),e.maxColWidth&&console.warn("AG Grid: since v26.1, the grid property `maxColWidth` is deprecated and should be set via `defaultColDef.maxWidth`."),e.reactUi&&console.warn("AG Grid: since v27.0, React UI is on by default, so no need for reactUi=true. To turn it off, set suppressReactUi=true."),e.suppressReactUi&&console.warn("AG Grid: The legacy React rendering engine is deprecated and will be removed in the next major version of the grid."),e.suppressCellSelection&&(console.warn("AG Grid: since v27.0, `suppressCellSelection` has been replaced by `suppressCellFocus`."),e.suppressCellFocus=e.suppressCellSelection),e.getRowNodeId&&console.warn("AG Grid: since v27.1, `getRowNodeId` is deprecate and has been replaced by `getRowId`. The difference is if getRowId() is implemented, immutable data is on by default."),e.immutableData&&console.warn("AG Grid: since v27.1, `immutableData` is deprecated. To turn on, implement `getRowId` has been replaced by `getRowId`. The difference is if getRowId() is implemented, immutable data is on by default."),e.clipboardDeliminator&&(console.warn("AG Grid: since v27.1, `clipboardDeliminator` has been replaced by `clipboardDelimiter`."),e.clipboardDelimiter=e.clipboardDeliminator)},e.prototype.checkForViolations=function(){this.isTreeData()&&this.treeDataViolations()},e.prototype.treeDataViolations=function(){this.isRowModelDefault()&&Object(f.missing)(this.getDataPathFunc())&&console.warn("AG Grid: property usingTreeData=true with rowModel=clientSide, but you did not provide getDataPath function, please provide getDataPath function if using tree data."),this.isRowModelServerSide()&&(Object(f.missing)(this.getIsServerSideGroupFunc())&&console.warn("AG Grid: property usingTreeData=true with rowModel=serverSide, but you did not provide isServerSideGroup function, please provide isServerSideGroup function if using tree data."),Object(f.missing)(this.getServerSideGroupKeyFunc())&&console.warn("AG Grid: property usingTreeData=true with rowModel=serverSide, but you did not provide getServerSideGroupKey function, please provide getServerSideGroupKey function if using tree data."))},e.prototype.getLocaleTextFunc=function(){if(this.gridOptions.localeTextFunc)return this.gridOptions.localeTextFunc;var e=this.gridOptions.localeText;return function(t,a){var r=e&&e[t];return null!=r?r:a}},e.prototype.globalEventHandler=function(e,t){if(!this.destroyed){var a=n.a.getCallbackForEvent(e);"function"==typeof this.gridOptions[a]&&this.gridOptions[a](t)}},e.prototype.setRowHeightVariable=function(e){var t=e+"px";this.eGridDiv.style.getPropertyValue("--ag-row-height").trim()!=t&&this.eGridDiv.style.setProperty("--ag-row-height",t)},e.prototype.getRowHeightAsNumber=function(){if(!this.gridOptions.rowHeight||Object(f.missing)(this.gridOptions.rowHeight))return this.getDefaultRowHeight();var e=this.gridOptions.rowHeight;return e&&this.isNumeric(e)?(this.setRowHeightVariable(e),e):(console.warn("AG Grid row height must be a number if not using standard row model"),this.getDefaultRowHeight())},e.prototype.isGetRowHeightFunction=function(){return"function"==typeof this.gridOptions.getRowHeight},e.prototype.getRowHeightForNode=function(e,t,a){if(void 0===t&&(t=!1),null==a&&(a=this.getDefaultRowHeight()),this.isGetRowHeightFunction()){if(t)return{height:a,estimated:!0};var r={node:e,data:e.data,api:this.gridOptions.api,context:this.gridOptions.context},o=this.gridOptions.getRowHeight(r);if(this.isNumeric(o))return 0===o&&Object(b.doOnce)((function(){return console.warn("AG Grid: The return of `getRowHeight` cannot be zero. If the intention is to hide rows, use a filter instead.")}),"invalidRowHeight"),{height:Math.max(1,o),estimated:!1}}return e.detail&&this.isMasterDetail()?this.isDetailRowAutoHeight()?{height:1,estimated:!1}:this.isNumeric(this.gridOptions.detailRowHeight)?{height:this.gridOptions.detailRowHeight,estimated:!1}:{height:300,estimated:!1}:{height:this.gridOptions.rowHeight&&this.isNumeric(this.gridOptions.rowHeight)?this.gridOptions.rowHeight:a,estimated:!1}},e.prototype.isDynamicRowHeight=function(){return"function"==typeof this.gridOptions.getRowHeight},e.prototype.getListItemHeight=function(){return this.getFromTheme(20,"listItemHeight")},e.prototype.chartMenuPanelWidth=function(){return this.environment.chartMenuPanelWidth()},e.prototype.isNumeric=function(e){return!isNaN(e)&&"number"==typeof e&&isFinite(e)},e.prototype.getFromTheme=function(e,t){var a=this.environment.getTheme().theme;return a&&0===a.indexOf("ag-theme")?this.environment.getSassVariable(a,t):e},e.prototype.getDefaultRowHeight=function(){return this.getFromTheme(25,"rowHeight")},e.prototype.matchesGroupDisplayType=function(e,t){var a=["groupRows","multipleColumns","custom","singleColumn"];return a.indexOf(t)<0?(console.warn("AG Grid: '"+t+"' is not a valid groupDisplayType value - possible values are: '"+a.join("', '")+"'"),!1):t===e},e.prototype.matchesTreeDataDisplayType=function(e,t){var a=["auto","custom"];return a.indexOf(t)<0?(console.warn("AG Grid: '"+t+"' is not a valid treeDataDisplayType value - possible values are: '"+a.join("', '")+"'"),!1):t===e},e.MIN_COL_WIDTH=10,e.PROP_HEADER_HEIGHT="headerHeight",e.PROP_GROUP_REMOVE_SINGLE_CHILDREN="groupRemoveSingleChildren",e.PROP_GROUP_REMOVE_LOWEST_SINGLE_CHILDREN="groupRemoveLowestSingleChildren",e.PROP_PIVOT_HEADER_HEIGHT="pivotHeaderHeight",e.PROP_SUPPRESS_CLIPBOARD_PASTE="suppressClipboardPaste",e.PROP_GROUP_HEADER_HEIGHT="groupHeaderHeight",e.PROP_PIVOT_GROUP_HEADER_HEIGHT="pivotGroupHeaderHeight",e.PROP_NAVIGATE_TO_NEXT_CELL="navigateToNextCell",e.PROP_TAB_TO_NEXT_CELL="tabToNextCell",e.PROP_NAVIGATE_TO_NEXT_HEADER="navigateToNextHeader",e.PROP_TAB_TO_NEXT_HEADER="tabToNextHeader",e.PROP_IS_EXTERNAL_FILTER_PRESENT="isExternalFilterPresent",e.PROP_DOES_EXTERNAL_FILTER_PASS="doesExternalFilterPass",e.PROP_FLOATING_FILTERS_HEIGHT="floatingFiltersHeight",e.PROP_SUPPRESS_ROW_CLICK_SELECTION="suppressRowClickSelection",e.PROP_SUPPRESS_ROW_DRAG="suppressRowDrag",e.PROP_SUPPRESS_MOVE_WHEN_ROW_DRAG="suppressMoveWhenRowDragging",e.PROP_GET_ROW_CLASS="getRowClass",e.PROP_GET_ROW_STYLE="getRowStyle",e.PROP_GET_ROW_HEIGHT="getRowHeight",e.PROP_POPUP_PARENT="popupParent",e.PROP_DOM_LAYOUT="domLayout",e.PROP_FILL_HANDLE_DIRECTION="fillHandleDirection",e.PROP_GROUP_ROW_AGG_NODES="groupRowAggNodes",e.PROP_GET_BUSINESS_KEY_FOR_NODE="getBusinessKeyForNode",e.PROP_GET_CHILD_COUNT="getChildCount",e.PROP_PROCESS_ROW_POST_CREATE="processRowPostCreate",e.PROP_GET_ROW_NODE_ID="getRowNodeId",e.PROP_IS_FULL_WIDTH_CELL="isFullWidthCell",e.PROP_IS_ROW_SELECTABLE="isRowSelectable",e.PROP_IS_ROW_MASTER="isRowMaster",e.PROP_POST_SORT="postSort",e.PROP_GET_DOCUMENT="getDocument",e.PROP_POST_PROCESS_POPUP="postProcessPopup",e.PROP_DEFAULT_GROUP_ORDER_COMPARATOR="defaultGroupOrderComparator",e.PROP_PAGINATION_NUMBER_FORMATTER="paginationNumberFormatter",e.PROP_GET_CONTEXT_MENU_ITEMS="getContextMenuItems",e.PROP_GET_MAIN_MENU_ITEMS="getMainMenuItems",e.PROP_PROCESS_CELL_FOR_CLIPBOARD="processCellForClipboard",e.PROP_PROCESS_CELL_FROM_CLIPBOARD="processCellFromClipboard",e.PROP_SEND_TO_CLIPBOARD="sendToClipboard",e.PROP_PROCESS_TO_SECONDARY_COLDEF="processSecondaryColDef",e.PROP_PROCESS_SECONDARY_COL_GROUP_DEF="processSecondaryColGroupDef",e.PROP_GET_CHART_TOOLBAR_ITEMS="getChartToolbarItems",e.PROP_GET_SERVER_SIDE_STORE_PARAMS="getServerSideStoreParams",e.PROP_IS_SERVER_SIDE_GROUPS_OPEN_BY_DEFAULT="isServerSideGroupOpenByDefault",e.PROP_IS_APPLY_SERVER_SIDE_TRANSACTION="isApplyServerSideTransaction",e.PROP_IS_SERVER_SIDE_GROUP="isServerSideGroup",e.PROP_GET_SERVER_SIDE_GROUP_KEY="getServerSideGroupKey",x([Object(i.a)("gridOptions")],e.prototype,"gridOptions",void 0),x([Object(i.a)("eventService")],e.prototype,"eventService",void 0),x([Object(i.a)("environment")],e.prototype,"environment",void 0),x([Object(i.a)("eGridDiv")],e.prototype,"eGridDiv",void 0),x([y(0,Object(i.h)("gridApi")),y(1,Object(i.h)("columnApi"))],e.prototype,"agWire",null),x([i.g],e.prototype,"destroy",null),x([i.e],e.prototype,"init",null),e=t=x([Object(i.b)("gridOptionsWrapper")],e)}()},function(e,t,a){"use strict";a.r(t),a.d(t,"doOnce",(function(){return i})),a.d(t,"getFunctionName",(function(){return l})),a.d(t,"getFunctionParameters",(function(){return g})),a.d(t,"isFunction",(function(){return p})),a.d(t,"executeInAWhile",(function(){return d})),a.d(t,"executeNextVMTurn",(function(){return u})),a.d(t,"executeAfter",(function(){return h})),a.d(t,"debounce",(function(){return f})),a.d(t,"waitUntil",(function(){return m})),a.d(t,"compose",(function(){return b})),a.d(t,"callIfPresent",(function(){return w}));var r=/((\/\/.*$)|(\/\*[\s\S]*?\*\/))/gm,o=/([^\s,]+)/g,n={};function i(e,t){n[t]||(e(),n[t]=!0)}function l(e){if(e.name)return e.name;var t=/function\s+([^\(]+)/.exec(e.toString());return t&&2===t.length?t[1].trim():null}function g(e){var t=e.toString().replace(r,"");return t.slice(t.indexOf("(")+1,t.indexOf(")")).match(o)||[]}function p(e){return!!(e&&e.constructor&&e.call&&e.apply)}function d(e){h(e,400)}var s=[],c=!1;function u(e){s.push(e),c||(c=!0,window.setTimeout((function(){var e=s.slice();s.length=0,c=!1,e.forEach((function(e){return e()}))}),0))}function h(e,t){void 0===t&&(t=0),e.length>0&&window.setTimeout((function(){return e.forEach((function(e){return e()}))}),t)}function f(e,t,a){var r;return void 0===a&&(a=!1),function(){for(var o=[],n=0;na;(e()||l)&&(t(),i=!0,null!=n&&(window.clearInterval(n),n=null),l&&r&&console.warn(r))};l(),i||(n=window.setInterval(l,10))}function b(){for(var e=[],t=0;t=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},c=0,u=function(){function e(e,t,a,o){this.instanceId=c++,this.moving=!1,this.menuVisible=!1,this.filterActive=!1,this.eventService=new r.a,this.rowGroupActive=!1,this.pivotActive=!1,this.aggregationActive=!1,this.colDef=e,this.userProvidedColDef=t,this.colId=a,this.primary=o,this.setState(e)}return e.prototype.getInstanceId=function(){return this.instanceId},e.prototype.setState=function(e){void 0!==e.sort?e.sort!==n.a.SORT_ASC&&e.sort!==n.a.SORT_DESC||(this.sort=e.sort):e.initialSort!==n.a.SORT_ASC&&e.initialSort!==n.a.SORT_DESC||(this.sort=e.initialSort);var t=Object(g.attrToNumber)(e.sortIndex),a=Object(g.attrToNumber)(e.initialSortIndex);void 0!==t?null!==t&&(this.sortIndex=t):null!==a&&(this.sortIndex=a);var r=Object(g.attrToBoolean)(e.hide),o=Object(g.attrToBoolean)(e.initialHide);this.visible=void 0!==r?!r:!o,void 0!==e.pinned?this.setPinned(e.pinned):this.setPinned(e.initialPinned);var i=Object(g.attrToNumber)(e.flex),l=Object(g.attrToNumber)(e.initialFlex);void 0!==i?this.flex=i:void 0!==l&&(this.flex=l)},e.prototype.setColDef=function(e,t){this.colDef=e,this.userProvidedColDef=t,this.initMinAndMaxWidths(),this.initDotNotation()},e.prototype.getUserProvidedColDef=function(){return this.userProvidedColDef},e.prototype.setParent=function(e){this.parent=e},e.prototype.getParent=function(){return this.parent},e.prototype.setOriginalParent=function(e){this.originalParent=e},e.prototype.getOriginalParent=function(){return this.originalParent},e.prototype.initialise=function(){this.initMinAndMaxWidths(),this.resetActualWidth("gridInitializing"),this.initDotNotation(),this.validate()},e.prototype.initDotNotation=function(){var e=this.gridOptionsWrapper.isSuppressFieldDotNotation();this.fieldContainsDots=Object(g.exists)(this.colDef.field)&&this.colDef.field.indexOf(".")>=0&&!e,this.tooltipFieldContainsDots=Object(g.exists)(this.colDef.tooltipField)&&this.colDef.tooltipField.indexOf(".")>=0&&!e},e.prototype.initMinAndMaxWidths=function(){var e=this.colDef;this.minWidth=this.columnUtils.calculateColMinWidth(e),this.maxWidth=this.columnUtils.calculateColMaxWidth(e)},e.prototype.resetActualWidth=function(e){void 0===e&&(e="api");var t=this.columnUtils.calculateColInitialWidth(this.colDef);this.setActualWidth(t,e,!0)},e.prototype.isEmptyGroup=function(){return!1},e.prototype.isRowGroupDisplayed=function(e){if(Object(g.missing)(this.colDef)||Object(g.missing)(this.colDef.showRowGroup))return!1;var t=!0===this.colDef.showRowGroup,a=this.colDef.showRowGroup===e;return t||a},e.prototype.isPrimary=function(){return this.primary},e.prototype.isFilterAllowed=function(){var e=!!this.colDef.filter||!!this.colDef.filterFramework;return this.primary&&e},e.prototype.isFieldContainsDots=function(){return this.fieldContainsDots},e.prototype.isTooltipFieldContainsDots=function(){return this.tooltipFieldContainsDots},e.prototype.validate=function(){var e=this.colDef;function t(e,t,a){Object(p.doOnce)((function(){a?console.warn(e,a):Object(p.doOnce)((function(){return console.warn(e)}),t)}),t)}if(this.gridOptionsWrapper.isRowModelDefault()&&!l.a.isRegistered(i.a.RowGroupingModule)){["enableRowGroup","rowGroup","rowGroupIndex","enablePivot","enableValue","pivot","pivotIndex","aggFunc"].forEach((function(a){Object(g.exists)(e[a])&&(l.a.isPackageBased()?t("AG Grid: "+a+" is only valid in ag-grid-enterprise, your column definition should not have "+a,"ColumnRowGroupingMissing"+a):t("AG Grid: "+a+" is only valid with AG Grid Enterprise Module "+i.a.RowGroupingModule+" - your column definition should not have "+a,"ColumnRowGroupingMissing"+a))}))}if(l.a.isRegistered(i.a.RichSelectModule)||"agRichSelect"===this.colDef.cellEditor&&(l.a.isPackageBased()?t("AG Grid: "+this.colDef.cellEditor+" can only be used with ag-grid-enterprise","ColumnRichSelectMissing"):t("AG Grid: "+this.colDef.cellEditor+" can only be used with AG Grid Enterprise Module "+i.a.RichSelectModule,"ColumnRichSelectMissing")),this.gridOptionsWrapper.isTreeData()){["rowGroup","rowGroupIndex","pivot","pivotIndex"].forEach((function(a){Object(g.exists)(e[a])&&t("AG Grid: "+a+" is not possible when doing tree data, your column definition should not have "+a,"TreeDataCannotRowGroup")}))}Object(g.exists)(this.colDef.width)&&"number"!=typeof this.colDef.width&&t("AG Grid: colDef.width should be a number, not "+typeof this.colDef.width,"ColumnCheck_asdfawef"),e.pinnedRowCellRenderer&&t("AG Grid: pinnedRowCellRenderer no longer exists, use cellRendererSelector if you want a different Cell Renderer for pinned rows. Check params.node.rowPinned. This was an unfortunate (but necessary) change we had to do to allow future plans we have of re-skinng the data grid in frameworks such as React, Angular and Vue. See https://www.ag-grid.com/javascript-grid/cell-rendering/#many-renderers-one-column","colDef.pinnedRowCellRenderer-deprecated"),e.pinnedRowCellRendererParams&&t("AG Grid: pinnedRowCellRenderer no longer exists, use cellRendererSelector if you want a different Cell Renderer for pinned rows. Check params.node.rowPinned. This was an unfortunate (but necessary) change we had to do to allow future plans we have of re-skinng the data grid in frameworks such as React, Angular and Vue. See https://www.ag-grid.com/javascript-grid/cell-rendering/#many-renderers-one-column","colDef.pinnedRowCellRenderer-deprecated"),e.pinnedRowCellRendererFramework&&t("AG Grid: pinnedRowCellRenderer no longer exists, use cellRendererSelector if you want a different Cell Renderer for pinned rows. Check params.node.rowPinned. This was an unfortunate (but necessary) change we had to do to allow future plans we have of re-skinng the data grid in frameworks such as React, Angular and Vue. See https://www.ag-grid.com/javascript-grid/cell-rendering/#many-renderers-one-column","colDef.pinnedRowCellRenderer-deprecated"),e.pinnedRowValueGetter&&t("AG Grid: pinnedRowCellRenderer is deprecated, use cellRendererSelector if you want a different Cell Renderer for pinned rows. Check params.node.rowPinned. This was an unfortunate (but necessary) change we had to do to allow future plans we have of re-skinng the data grid in frameworks such as React, Angular and Vue.","colDef.pinnedRowCellRenderer-deprecated")},e.prototype.addEventListener=function(e,t){this.eventService.addEventListener(e,t)},e.prototype.removeEventListener=function(e,t){this.eventService.removeEventListener(e,t)},e.prototype.createColumnFunctionCallbackParams=function(e){return{node:e,data:e.data,column:this,colDef:this.colDef,context:this.gridOptionsWrapper.getContext(),api:this.gridOptionsWrapper.getApi(),columnApi:this.gridOptionsWrapper.getColumnApi()}},e.prototype.isSuppressNavigable=function(e){if("boolean"==typeof this.colDef.suppressNavigable)return this.colDef.suppressNavigable;if("function"==typeof this.colDef.suppressNavigable){var t=this.createColumnFunctionCallbackParams(e);return(0,this.colDef.suppressNavigable)(t)}return!1},e.prototype.isCellEditable=function(e){return!(e.group&&!this.gridOptionsWrapper.isEnableGroupEdit())&&this.isColumnFunc(e,this.colDef.editable)},e.prototype.isSuppressFillHandle=function(){return!!Object(g.attrToBoolean)(this.colDef.suppressFillHandle)},e.prototype.isAutoHeight=function(){return!!Object(g.attrToBoolean)(this.colDef.autoHeight)},e.prototype.isRowDrag=function(e){return this.isColumnFunc(e,this.colDef.rowDrag)},e.prototype.isDndSource=function(e){return this.isColumnFunc(e,this.colDef.dndSource)},e.prototype.isCellCheckboxSelection=function(e){return this.isColumnFunc(e,this.colDef.checkboxSelection)},e.prototype.isSuppressPaste=function(e){return this.isColumnFunc(e,this.colDef?this.colDef.suppressPaste:null)},e.prototype.isResizable=function(){return!!Object(g.attrToBoolean)(this.colDef.resizable)},e.prototype.isColumnFunc=function(e,t){return"boolean"==typeof t?t:"function"==typeof t&&t(this.createColumnFunctionCallbackParams(e))},e.prototype.setMoving=function(t,a){void 0===a&&(a="api"),this.moving=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_MOVING_CHANGED,a))},e.prototype.createColumnEvent=function(e,t){return{api:this.gridApi,columnApi:this.columnApi,type:e,column:this,columns:[this],source:t}},e.prototype.isMoving=function(){return this.moving},e.prototype.getSort=function(){return this.sort},e.prototype.setSort=function(t,a){void 0===a&&(a="api"),this.sort!==t&&(this.sort=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_SORT_CHANGED,a)))},e.prototype.setMenuVisible=function(t,a){void 0===a&&(a="api"),this.menuVisible!==t&&(this.menuVisible=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_MENU_VISIBLE_CHANGED,a)))},e.prototype.isMenuVisible=function(){return this.menuVisible},e.prototype.isSortAscending=function(){return this.sort===n.a.SORT_ASC},e.prototype.isSortDescending=function(){return this.sort===n.a.SORT_DESC},e.prototype.isSortNone=function(){return Object(g.missing)(this.sort)},e.prototype.isSorting=function(){return Object(g.exists)(this.sort)},e.prototype.getSortIndex=function(){return this.sortIndex},e.prototype.setSortIndex=function(e){this.sortIndex=e},e.prototype.setAggFunc=function(e){this.aggFunc=e},e.prototype.getAggFunc=function(){return this.aggFunc},e.prototype.getLeft=function(){return this.left},e.prototype.getOldLeft=function(){return this.oldLeft},e.prototype.getRight=function(){return this.left+this.actualWidth},e.prototype.setLeft=function(t,a){void 0===a&&(a="api"),this.oldLeft=this.left,this.left!==t&&(this.left=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_LEFT_CHANGED,a)))},e.prototype.isFilterActive=function(){return this.filterActive},e.prototype.setFilterActive=function(t,a,r){void 0===a&&(a="api"),this.filterActive!==t&&(this.filterActive=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_FILTER_ACTIVE_CHANGED,a)));var o=this.createColumnEvent(e.EVENT_FILTER_CHANGED,a);r&&Object(d.mergeDeep)(o,r),this.eventService.dispatchEvent(o)},e.prototype.setPinned=function(e){!0===e||e===n.a.PINNED_LEFT?this.pinned=n.a.PINNED_LEFT:e===n.a.PINNED_RIGHT?this.pinned=n.a.PINNED_RIGHT:this.pinned=null},e.prototype.setFirstRightPinned=function(t,a){void 0===a&&(a="api"),this.firstRightPinned!==t&&(this.firstRightPinned=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_FIRST_RIGHT_PINNED_CHANGED,a)))},e.prototype.setLastLeftPinned=function(t,a){void 0===a&&(a="api"),this.lastLeftPinned!==t&&(this.lastLeftPinned=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_LAST_LEFT_PINNED_CHANGED,a)))},e.prototype.isFirstRightPinned=function(){return this.firstRightPinned},e.prototype.isLastLeftPinned=function(){return this.lastLeftPinned},e.prototype.isPinned=function(){return this.pinned===n.a.PINNED_LEFT||this.pinned===n.a.PINNED_RIGHT},e.prototype.isPinnedLeft=function(){return this.pinned===n.a.PINNED_LEFT},e.prototype.isPinnedRight=function(){return this.pinned===n.a.PINNED_RIGHT},e.prototype.getPinned=function(){return this.pinned},e.prototype.setVisible=function(t,a){void 0===a&&(a="api");var r=!0===t;this.visible!==r&&(this.visible=r,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_VISIBLE_CHANGED,a)))},e.prototype.isVisible=function(){return this.visible},e.prototype.getColDef=function(){return this.colDef},e.prototype.getColumnGroupShow=function(){return this.colDef.columnGroupShow},e.prototype.getColId=function(){return this.colId},e.prototype.getId=function(){return this.getColId()},e.prototype.getUniqueId=function(){return this.getId()},e.prototype.getDefinition=function(){return this.colDef},e.prototype.getActualWidth=function(){return this.actualWidth},e.prototype.createBaseColDefParams=function(e){return{node:e,data:e.data,colDef:this.colDef,column:this,api:this.gridOptionsWrapper.getApi(),columnApi:this.gridOptionsWrapper.getColumnApi(),context:this.gridOptionsWrapper.getContext()}},e.prototype.getColSpan=function(e){if(Object(g.missing)(this.colDef.colSpan))return 1;var t=this.createBaseColDefParams(e),a=this.colDef.colSpan(t);return Math.max(a,1)},e.prototype.getRowSpan=function(e){if(Object(g.missing)(this.colDef.rowSpan))return 1;var t=this.createBaseColDefParams(e),a=this.colDef.rowSpan(t);return Math.max(a,1)},e.prototype.setActualWidth=function(e,t,a){void 0===t&&(t="api"),void 0===a&&(a=!1),null!=this.minWidth&&(e=Math.max(e,this.minWidth)),null!=this.maxWidth&&(e=Math.min(e,this.maxWidth)),this.actualWidth!==e&&(this.actualWidth=e,this.flex&&"flex"!==t&&"gridInitializing"!==t&&(this.flex=null),a||this.fireColumnWidthChangedEvent(t))},e.prototype.fireColumnWidthChangedEvent=function(t){this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_WIDTH_CHANGED,t))},e.prototype.isGreaterThanMax=function(e){return null!=this.maxWidth&&e>this.maxWidth},e.prototype.getMinWidth=function(){return this.minWidth},e.prototype.getMaxWidth=function(){return this.maxWidth},e.prototype.getFlex=function(){return this.flex||0},e.prototype.setFlex=function(e){this.flex!==e&&(this.flex=e)},e.prototype.setMinimum=function(e){void 0===e&&(e="api"),Object(g.exists)(this.minWidth)&&this.setActualWidth(this.minWidth,e)},e.prototype.setRowGroupActive=function(t,a){void 0===a&&(a="api"),this.rowGroupActive!==t&&(this.rowGroupActive=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_ROW_GROUP_CHANGED,a)))},e.prototype.isRowGroupActive=function(){return this.rowGroupActive},e.prototype.setPivotActive=function(t,a){void 0===a&&(a="api"),this.pivotActive!==t&&(this.pivotActive=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_PIVOT_CHANGED,a)))},e.prototype.isPivotActive=function(){return this.pivotActive},e.prototype.isAnyFunctionActive=function(){return this.isPivotActive()||this.isRowGroupActive()||this.isValueActive()},e.prototype.isAnyFunctionAllowed=function(){return this.isAllowPivot()||this.isAllowRowGroup()||this.isAllowValue()},e.prototype.setValueActive=function(t,a){void 0===a&&(a="api"),this.aggregationActive!==t&&(this.aggregationActive=t,this.eventService.dispatchEvent(this.createColumnEvent(e.EVENT_VALUE_CHANGED,a)))},e.prototype.isValueActive=function(){return this.aggregationActive},e.prototype.isAllowPivot=function(){return!0===this.colDef.enablePivot},e.prototype.isAllowValue=function(){return!0===this.colDef.enableValue},e.prototype.isAllowRowGroup=function(){return!0===this.colDef.enableRowGroup},e.prototype.getMenuTabs=function(e){var t=this.getColDef().menuTabs;return null==t&&(t=e),t},e.prototype.isLockPosition=function(){return console.warn("AG Grid: since v21, col.isLockPosition() should not be used, please use col.getColDef().lockPosition instead."),!!this.colDef&&!!this.colDef.lockPosition},e.prototype.isLockVisible=function(){return console.warn("AG Grid: since v21, col.isLockVisible() should not be used, please use col.getColDef().lockVisible instead."),!!this.colDef&&!!this.colDef.lockVisible},e.prototype.isLockPinned=function(){return console.warn("AG Grid: since v21, col.isLockPinned() should not be used, please use col.getColDef().lockPinned instead."),!!this.colDef&&!!this.colDef.lockPinned},e.EVENT_MOVING_CHANGED="movingChanged",e.EVENT_LEFT_CHANGED="leftChanged",e.EVENT_WIDTH_CHANGED="widthChanged",e.EVENT_LAST_LEFT_PINNED_CHANGED="lastLeftPinnedChanged",e.EVENT_FIRST_RIGHT_PINNED_CHANGED="firstRightPinnedChanged",e.EVENT_VISIBLE_CHANGED="visibleChanged",e.EVENT_FILTER_CHANGED="filterChanged",e.EVENT_FILTER_ACTIVE_CHANGED="filterActiveChanged",e.EVENT_SORT_CHANGED="sortChanged",e.EVENT_MENU_VISIBLE_CHANGED="menuVisibleChanged",e.EVENT_ROW_GROUP_CHANGED="columnRowGroupChanged",e.EVENT_PIVOT_CHANGED="columnPivotChanged",e.EVENT_VALUE_CHANGED="columnValueChanged",s([Object(o.a)("gridOptionsWrapper")],e.prototype,"gridOptionsWrapper",void 0),s([Object(o.a)("columnUtils")],e.prototype,"columnUtils",void 0),s([Object(o.a)("columnApi")],e.prototype,"columnApi",void 0),s([Object(o.a)("gridApi")],e.prototype,"gridApi",void 0),s([Object(o.a)("context")],e.prototype,"context",void 0),s([o.e],e.prototype,"initialise",null),e}()},function(e,t,a){"use strict";a.d(t,"a",(function(){return r})),a.d(t,"b",(function(){return d}));var r,o=a(34),n=a(4),i=a(2),l=a(1),g=a(12),p=a(15);!function(e){e[e.Above=0]="Above",e[e.Below=1]="Below"}(r||(r={}));var d=function(){function e(t){this.rowIndex=null,this.key=null,this.childrenMapped={},this.displayed=!1,this.rowTop=null,this.oldRowTop=null,this.selectable=!0,this.__objectId=e.OBJECT_ID_SEQUENCE++,this.__autoHeights={},this.alreadyRendered=!1,this.highlighted=null,this.selected=!1,this.beans=t}return e.prototype.setData=function(e){this.setDataCommon(e,!1)},e.prototype.updateData=function(e){this.setDataCommon(e,!0)},e.prototype.setDataCommon=function(e,t){var a=this.data;this.data=e,this.beans.valueCache.onDataChanged(),this.updateDataOnDetailNode(),this.checkRowSelectable();var r=this.createDataChangedEvent(e,a,t);this.dispatchLocalEvent(r)},e.prototype.updateDataOnDetailNode=function(){this.detailNode&&(this.detailNode.data=this.data)},e.prototype.createDataChangedEvent=function(t,a,r){return{type:e.EVENT_DATA_CHANGED,node:this,oldData:a,newData:t,update:r}},e.prototype.createLocalRowEvent=function(e){return{type:e,node:this}},e.prototype.getRowIndexString=function(){return this.rowPinned===i.a.PINNED_TOP?"t-"+this.rowIndex:this.rowPinned===i.a.PINNED_BOTTOM?"b-"+this.rowIndex:this.rowIndex.toString()},e.prototype.createDaemonNode=function(){var t=new e(this.beans);return t.id=this.id,t.data=this.data,t.daemon=!0,t.selected=this.selected,t.level=this.level,t},e.prototype.setDataAndId=function(e,t){var a=Object(l.exists)(this.id)?this.createDaemonNode():null,r=this.data;this.data=e,this.updateDataOnDetailNode(),this.setId(t),this.beans.selectionService.syncInRowNode(this,a),this.checkRowSelectable();var o=this.createDataChangedEvent(e,r,!1);this.dispatchLocalEvent(o)},e.prototype.checkRowSelectable=function(){var e=this.beans.gridOptionsWrapper.getIsRowSelectableFunc();this.setRowSelectable(!e||e(this))},e.prototype.setRowSelectable=function(t){this.selectable!==t&&(this.selectable=t,this.eventService&&this.eventService.dispatchEvent(this.createLocalRowEvent(e.EVENT_SELECTABLE_CHANGED)))},e.prototype.setId=function(t){var a=this.beans.gridOptionsWrapper.getRowIdFunc();if(a)if(this.data){var r=this.getGroupKeys(!0);this.id=a({api:this.beans.gridApi,columnApi:this.beans.columnApi,data:this.data,parentKeys:r.length>0?r:void 0,level:this.level}),null!==this.id&&"string"==typeof this.id&&this.id.startsWith(e.ID_PREFIX_ROW_GROUP)&&console.error("AG Grid: Row IDs cannot start with "+e.ID_PREFIX_ROW_GROUP+", this is a reserved prefix for AG Grid's row grouping feature."),null!==this.id&&"string"!=typeof this.id&&(this.id=""+this.id)}else this.id=void 0;else this.id=t},e.prototype.getGroupKeys=function(e){void 0===e&&(e=!1);var t=[],a=this;for(e&&(a=a.parent);a&&a.level>=0;)t.push(a.key),a=a.parent;return t.reverse(),t},e.prototype.isPixelInRange=function(e){return!(!Object(l.exists)(this.rowTop)||!Object(l.exists)(this.rowHeight))&&(e>=this.rowTop&&ea&&(a=n)):e=!0})),!e&&((t||a<10)&&(a=this.beans.gridOptionsWrapper.getRowHeightForNode(this).height),a!=this.rowHeight))){this.setRowHeight(a);var o=this.beans.rowModel;o.onRowHeightChanged&&o.onRowHeightChanged()}},e.prototype.setRowIndex=function(t){this.rowIndex!==t&&(this.rowIndex=t,this.eventService&&this.eventService.dispatchEvent(this.createLocalRowEvent(e.EVENT_ROW_INDEX_CHANGED)))},e.prototype.setUiLevel=function(t){this.uiLevel!==t&&(this.uiLevel=t,this.eventService&&this.eventService.dispatchEvent(this.createLocalRowEvent(e.EVENT_UI_LEVEL_CHANGED)))},e.prototype.setExpanded=function(t){if(this.expanded!==t){this.expanded=t,this.eventService&&this.eventService.dispatchEvent(this.createLocalRowEvent(e.EVENT_EXPANDED_CHANGED));var a=Object.assign({},this.createGlobalRowEvent(n.a.EVENT_ROW_GROUP_OPENED),{expanded:t});this.beans.rowNodeEventThrottle.dispatchExpanded(a),this.beans.gridOptionsWrapper.isGroupIncludeFooter()&&this.beans.rowRenderer.refreshCells({rowNodes:[this]})}},e.prototype.createGlobalRowEvent=function(e){return{type:e,node:this,data:this.data,rowIndex:this.rowIndex,rowPinned:this.rowPinned,context:this.beans.gridOptionsWrapper.getContext(),api:this.beans.gridOptionsWrapper.getApi(),columnApi:this.beans.gridOptionsWrapper.getColumnApi()}},e.prototype.dispatchLocalEvent=function(e){this.eventService&&this.eventService.dispatchEvent(e)},e.prototype.setDataValue=function(e,t,a){var r=this.beans.columnModel.getPrimaryColumn(e),o=this.beans.valueService.getValue(r,this);this.beans.valueService.setValue(this,r,t,a),this.dispatchCellChangedEvent(r,t,o)},e.prototype.setGroupValue=function(e,t){var a=this.beans.columnModel.getGridColumn(e);Object(l.missing)(this.groupData)&&(this.groupData={});var r=a.getColId(),o=this.groupData[r];o!==t&&(this.groupData[r]=t,this.dispatchCellChangedEvent(a,t,o))},e.prototype.setAggData=function(e){var t=this,a=Object(g.getAllKeysInObjects)([this.aggData,e]),r=this.aggData;this.aggData=e,this.eventService&&a.forEach((function(e){var a=t.beans.columnModel.getGridColumn(e),o=t.aggData?t.aggData[e]:void 0,n=r?r[e]:void 0;t.dispatchCellChangedEvent(a,o,n)}))},e.prototype.updateHasChildren=function(){var t=this.group&&!this.footer||this.childrenAfterGroup&&this.childrenAfterGroup.length>0;t!==this.__hasChildren&&(this.__hasChildren=!!t,this.eventService&&this.eventService.dispatchEvent(this.createLocalRowEvent(e.EVENT_HAS_CHILDREN_CHANGED)))},e.prototype.hasChildren=function(){return null==this.__hasChildren&&this.updateHasChildren(),this.__hasChildren},e.prototype.isEmptyRowGroupNode=function(){return this.group&&Object(l.missingOrEmpty)(this.childrenAfterGroup)},e.prototype.dispatchCellChangedEvent=function(t,a,r){var o={type:e.EVENT_CELL_CHANGED,node:this,column:t,newValue:a,oldValue:r};this.dispatchLocalEvent(o)},e.prototype.resetQuickFilterAggregateText=function(){this.quickFilterAggregateText=null},e.prototype.isExpandable=function(){return!!(this.hasChildren()&&!this.footer||this.master)},e.prototype.isSelected=function(){return this.footer?this.sibling.isSelected():this.selected},e.prototype.depthFirstSearch=function(e){this.childrenAfterGroup&&this.childrenAfterGroup.forEach((function(t){return t.depthFirstSearch(e)})),e(this)},e.prototype.calculateSelectedFromChildren=function(){var e,t=!1,a=!1,r=!1;if(this.childrenAfterGroup)for(var o=0;o0){this.beans.selectionService.updateGroupsFromChildrenSelections();var c={type:n.a.EVENT_SELECTION_CHANGED,api:this.beans.gridApi,columnApi:this.beans.columnApi};this.beans.eventService.dispatchEvent(c)}a&&this.beans.selectionService.setLastSelectedNode(this)}return s},e.prototype.doRowRangeSelection=function(e){var t=this;void 0===e&&(e=!0);var a=this.beans.gridOptionsWrapper.isGroupSelectsChildren(),r=this.beans.selectionService.getLastSelectedNode(),o=this.beans.rowModel.getNodesInRangeForSelection(this,r),i=0;o.forEach((function(r){r.group&&a||!1===e&&t===r||r.selectThisNode(e)&&i++})),this.beans.selectionService.updateGroupsFromChildrenSelections();var l={type:n.a.EVENT_SELECTION_CHANGED,api:this.beans.gridApi,columnApi:this.beans.columnApi};return this.beans.eventService.dispatchEvent(l),i},e.prototype.isParentOfNode=function(e){for(var t=this.parent;t;){if(t===e)return!0;t=t.parent}return!1},e.prototype.selectThisNode=function(t){var a=!this.selectable&&t,r=this.selected===t;if(a||r)return!1;this.selected=t,this.eventService&&this.dispatchLocalEvent(this.createLocalRowEvent(e.EVENT_ROW_SELECTED));var o=this.createGlobalRowEvent(n.a.EVENT_ROW_SELECTED);return this.beans.eventService.dispatchEvent(o),!0},e.prototype.selectChildNodes=function(e,t){var a=t?this.childrenAfterFilter:this.childrenAfterGroup;if(Object(l.missing)(a))return 0;for(var r=0,o=0;o-1)return r;var o=document.createElement("span");return o.appendChild(r),o}function l(e,t,a,i){var l=null,g=a&&a.getColDef().icons;if(g&&(l=g[e]),t&&!l){var p=t.getIcons();p&&(l=p[e])}if(!l){var d=document.createElement("span"),s=n[e];return s||(i?s=e:(console.warn("AG Grid: Did not find icon "+e),s="")),d.setAttribute("class","ag-icon ag-icon-"+s),d.setAttribute("unselectable","on"),Object(o.setAriaRole)(d,"presentation"),d}var c=void 0;if("function"==typeof l)c=l();else{if("string"!=typeof l)throw new Error("icon from grid options needs to be a string or a function");c=l}return"string"==typeof c?Object(r.loadTemplate)(c):Object(r.isNodeOrElement)(c)?c:void console.warn("AG Grid: iconRenderer should return back a string or a dom object")}},function(e,t,a){"use strict";a.d(t,"b",(function(){return o})),a.d(t,"d",(function(){return n})),a.d(t,"c",(function(){return i})),a.d(t,"a",(function(){return w}));var r,o,n,i,l=a(6),g=a(0),p=a(27),d=a(20),s=a(10),c=a(22),u=a(5),h=a(15),f=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),m=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},b=function(e){var t="function"==typeof Symbol&&Symbol.iterator,a=t&&e[t],r=0;if(a)return a.call(e);if(e&&"number"==typeof e.length)return{next:function(){return e&&r>=e.length&&(e=void 0),{value:e&&e[r++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")};!function(e){e[e.ToolPanel=0]="ToolPanel",e[e.HeaderCell=1]="HeaderCell",e[e.RowDrag=2]="RowDrag",e[e.ChartPanel=3]="ChartPanel"}(o||(o={})),function(e){e[e.Up=0]="Up",e[e.Down=1]="Down"}(n||(n={})),function(e){e[e.Left=0]="Left",e[e.Right=1]="Right"}(i||(i={}));var w=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.dragSourceAndParamsList=[],t.dropTargets=[],t}var a;return f(t,e),a=t,t.prototype.init=function(){this.ePinnedIcon=Object(d.createIcon)("columnMovePin",this.gridOptionsWrapper,null),this.eHideIcon=Object(d.createIcon)("columnMoveHide",this.gridOptionsWrapper,null),this.eMoveIcon=Object(d.createIcon)("columnMoveMove",this.gridOptionsWrapper,null),this.eLeftIcon=Object(d.createIcon)("columnMoveLeft",this.gridOptionsWrapper,null),this.eRightIcon=Object(d.createIcon)("columnMoveRight",this.gridOptionsWrapper,null),this.eGroupIcon=Object(d.createIcon)("columnMoveGroup",this.gridOptionsWrapper,null),this.eAggregateIcon=Object(d.createIcon)("columnMoveValue",this.gridOptionsWrapper,null),this.ePivotIcon=Object(d.createIcon)("columnMovePivot",this.gridOptionsWrapper,null),this.eDropNotAllowedIcon=Object(d.createIcon)("dropNotAllowed",this.gridOptionsWrapper,null)},t.prototype.addDragSource=function(e,t){void 0===t&&(t=!1);var a={eElement:e.eElement,dragStartPixels:e.dragStartPixels,onDragStart:this.onDragStart.bind(this,e),onDragStop:this.onDragStop.bind(this),onDragging:this.onDragging.bind(this)};this.dragSourceAndParamsList.push({params:a,dragSource:e}),this.dragService.addDragSource(a,t)},t.prototype.removeDragSource=function(e){var t=this.dragSourceAndParamsList.find((function(t){return t.dragSource===e}));t&&(this.dragService.removeDragSource(t.params),Object(s.removeFromArray)(this.dragSourceAndParamsList,t))},t.prototype.clearDragSourceParamsList=function(){var e=this;this.dragSourceAndParamsList.forEach((function(t){return e.dragService.removeDragSource(t.params)})),this.dragSourceAndParamsList.length=0},t.prototype.nudge=function(){this.dragging&&this.onDragging(this.eventLastTime,!0)},t.prototype.onDragStart=function(e,t){this.dragging=!0,this.dragSource=e,this.eventLastTime=t,this.dragItem=this.dragSource.getDragItem(),this.lastDropTarget=this.dragSource.dragSourceDropTarget,this.dragSource.onDragStarted&&this.dragSource.onDragStarted(),this.createGhost()},t.prototype.onDragStop=function(e){if(this.eventLastTime=null,this.dragging=!1,this.dragSource.onDragStopped&&this.dragSource.onDragStopped(),this.lastDropTarget&&this.lastDropTarget.onDragStop){var t=this.createDropTargetEvent(this.lastDropTarget,e,null,null,!1);this.lastDropTarget.onDragStop(t)}this.lastDropTarget=null,this.dragItem=null,this.removeGhost()},t.prototype.onDragging=function(e,t){var a=this,r=this.getHorizontalDirection(e),o=this.getVerticalDirection(e);this.eventLastTime=e,this.positionGhost(e);var n=this.dropTargets.filter((function(t){return a.isMouseOnDropTarget(e,t)})),i=n.length,l=null;if(i>0&&(l=1===i?n[0]:n.reduce((function(e,t){if(!e)return t;var a=e.getContainer(),r=t.getContainer();return a.contains(r)?t:e}))),l!==this.lastDropTarget)this.leaveLastTargetIfExists(e,r,o,t),this.enterDragTargetIfExists(l,e,r,o,t),this.lastDropTarget=l;else if(l&&l.onDragging){var g=this.createDropTargetEvent(l,e,r,o,t);l.onDragging(g)}},t.prototype.enterDragTargetIfExists=function(e,t,a,r,o){if(e){if(e.onDragEnter){var n=this.createDropTargetEvent(e,t,a,r,o);e.onDragEnter(n)}this.setGhostIcon(e.getIconName?e.getIconName():null)}},t.prototype.leaveLastTargetIfExists=function(e,t,a,r){if(this.lastDropTarget){if(this.lastDropTarget.onDragLeave){var o=this.createDropTargetEvent(this.lastDropTarget,e,t,a,r);this.lastDropTarget.onDragLeave(o)}this.setGhostIcon(null)}},t.prototype.getAllContainersFromDropTarget=function(e){var t=e.getSecondaryContainers?e.getSecondaryContainers():null,a=[[e.getContainer()]];return t?a.concat(t):a},t.prototype.allContainersIntersect=function(e,t){var a,r;try{for(var o=b(t),n=o.next();!n.done;n=o.next()){var i=n.value.getBoundingClientRect();if(0===i.width||0===i.height)return!1;var l=e.clientX>=i.left&&e.clientX=i.top&&e.clientYa?i.Left:i.Right},t.prototype.getVerticalDirection=function(e){var t=this.eventLastTime&&this.eventLastTime.clientY,a=e.clientY;return t===a?null:t>a?n.Up:n.Down},t.prototype.createDropTargetEvent=function(e,t,a,r,o){var n=e.getContainer(),i=n.getBoundingClientRect(),l=this.gridApi,g=this.columnApi,p=this.dragItem,d=this.dragSource;return{event:t,x:t.clientX-i.left,y:t.clientY-i.top,vDirection:r,hDirection:a,dragSource:d,fromNudge:o,dragItem:p,api:l,columnApi:g,dropZoneTarget:n}},t.prototype.positionGhost=function(e){var t=this.eGhost;if(t){var a=t.getBoundingClientRect().height,r=Object(c.getBodyWidth)()-2,o=Object(c.getBodyHeight)()-2,n=e.pageY-a/2,i=e.pageX-10,l=this.gridOptionsWrapper.getDocument(),g=l.defaultView||window,p=g.pageYOffset||l.documentElement.scrollTop,d=g.pageXOffset||l.documentElement.scrollLeft;r>0&&i+t.clientWidth>r+d&&(i=r+d-t.clientWidth),i<0&&(i=0),o>0&&n+t.clientHeight>o+p&&(n=o+p-t.clientHeight),n<0&&(n=0),t.style.left=i+"px",t.style.top=n+"px"}},t.prototype.removeGhost=function(){this.eGhost&&this.eGhostParent&&this.eGhostParent.removeChild(this.eGhost),this.eGhost=null},t.prototype.createGhost=function(){this.eGhost=Object(u.loadTemplate)(a.GHOST_TEMPLATE);var e=this.environment.getTheme().theme;e&&this.eGhost.classList.add(e),this.eGhostIcon=this.eGhost.querySelector(".ag-dnd-ghost-icon"),this.setGhostIcon(null);var t=this.eGhost.querySelector(".ag-dnd-ghost-label"),r=this.dragSource.dragItemName;Object(h.isFunction)(r)&&(r=r()),t.innerHTML=Object(p.escapeString)(r)||"",this.eGhost.style.height="25px",this.eGhost.style.top="20px",this.eGhost.style.left="20px";var o=this.gridOptionsWrapper.getDocument(),n=null;try{n=o.fullscreenElement}catch(e){}finally{n||(n=o.querySelector("body"))}this.eGhostParent=n,this.eGhostParent?this.eGhostParent.appendChild(this.eGhost):console.warn("AG Grid: could not find document body, it is needed for dragging columns")},t.prototype.setGhostIcon=function(e,t){void 0===t&&(t=!1),Object(u.clearElement)(this.eGhostIcon);var r=null;switch(e||(e=this.dragSource.defaultIconName||a.ICON_NOT_ALLOWED),e){case a.ICON_PINNED:r=this.ePinnedIcon;break;case a.ICON_MOVE:r=this.eMoveIcon;break;case a.ICON_LEFT:r=this.eLeftIcon;break;case a.ICON_RIGHT:r=this.eRightIcon;break;case a.ICON_GROUP:r=this.eGroupIcon;break;case a.ICON_AGGREGATE:r=this.eAggregateIcon;break;case a.ICON_PIVOT:r=this.ePivotIcon;break;case a.ICON_NOT_ALLOWED:r=this.eDropNotAllowedIcon;break;case a.ICON_HIDE:r=this.eHideIcon}this.eGhostIcon.classList.toggle("ag-shake-left-to-right",t),r===this.eHideIcon&&this.gridOptionsWrapper.isSuppressDragLeaveHidesColumns()||r&&this.eGhostIcon.appendChild(r)},t.ICON_PINNED="pinned",t.ICON_MOVE="move",t.ICON_LEFT="left",t.ICON_RIGHT="right",t.ICON_GROUP="group",t.ICON_AGGREGATE="aggregate",t.ICON_PIVOT="pivot",t.ICON_NOT_ALLOWED="notAllowed",t.ICON_HIDE="hide",t.GHOST_TEMPLATE='
\n \n
\n
',m([Object(g.a)("dragService")],t.prototype,"dragService",void 0),m([Object(g.a)("environment")],t.prototype,"environment",void 0),m([Object(g.a)("columnApi")],t.prototype,"columnApi",void 0),m([Object(g.a)("gridApi")],t.prototype,"gridApi",void 0),m([g.e],t.prototype,"init",null),m([g.g],t.prototype,"clearDragSourceParamsList",null),t=a=m([Object(g.b)("dragAndDropService")],t)}(l.a)},function(e,t,a){"use strict";a.r(t),a.d(t,"isBrowserEdge",(function(){return c})),a.d(t,"isBrowserSafari",(function(){return u})),a.d(t,"isBrowserChrome",(function(){return h})),a.d(t,"isBrowserFirefox",(function(){return f})),a.d(t,"isIOSUserAgent",(function(){return m})),a.d(t,"getTabIndex",(function(){return b})),a.d(t,"getMaxDivHeight",(function(){return w})),a.d(t,"getScrollbarWidth",(function(){return v})),a.d(t,"isInvisibleScrollbar",(function(){return y})),a.d(t,"hasOverflowScrolling",(function(){return k})),a.d(t,"getBodyWidth",(function(){return C})),a.d(t,"getBodyHeight",(function(){return O}));var r,o,n,i,l,g,p,d,s=function(e){var t="function"==typeof Symbol&&Symbol.iterator,a=t&&e[t],r=0;if(a)return a.call(e);if(e&&"number"==typeof e.length)return{next:function(){return e&&r>=e.length&&(e=void 0),{value:e&&e[r++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")};function c(){return void 0===n&&(n=!(void 0===o&&(o=!!document.documentMode),o||!window.StyleMedia)),n}function u(){return void 0===r&&(r=/^((?!chrome|android).)*safari/i.test(navigator.userAgent)),r}function h(){if(void 0===i){var e=window;i=!!e.chrome&&(!!e.chrome.webstore||!!e.chrome.runtime)||/Chrome/.test(navigator.userAgent)&&/Google Inc/.test(navigator.vendor)}return i}function f(){if(void 0===l){var e=window;l=void 0!==e.InstallTrigger}return l}function m(){return void 0===g&&(g=(/iPad|iPhone|iPod/.test(navigator.platform)||"MacIntel"===navigator.platform&&navigator.maxTouchPoints>1)&&!window.MSStream),g}function b(e){if(!e)return null;var t=e.tabIndex,a=e.getAttribute("tabIndex");return-1!==t||null!==a&&(""!==a||f())?t.toString():null}function w(){if(!document.body)return-1;var e=1e6,t=navigator.userAgent.toLowerCase().match(/firefox/)?6e6:1e9,a=document.createElement("div");for(document.body.appendChild(a);;){var r=2*e;if(a.style.height=r+"px",r>t||a.clientHeight!==r)break;e=r}return document.body.removeChild(a),e}function v(){return null==d&&x(),d}function x(){var e=document.body,t=document.createElement("div");t.style.width=t.style.height="100px",t.style.opacity="0",t.style.overflow="scroll",t.style.msOverflowStyle="scrollbar",t.style.position="absolute",e.appendChild(t);var a=t.offsetWidth-t.clientWidth;0===a&&0===t.clientWidth&&(a=null),t.parentNode&&t.parentNode.removeChild(t),null!=a&&(d=a,p=0===a)}function y(){return null==p&&x(),p}function k(){var e,t,a=["webkit","moz","o","ms"],r=document.createElement("div"),o=!1;document.getElementsByTagName("body")[0].appendChild(r),r.setAttribute("style",a.map((function(e){return"-"+e+"-overflow-scrolling: touch"})).concat("overflow-scrolling: touch").join(";"));var n=window.getComputedStyle(r);if("touch"===n.overflowScrolling&&(o=!0),!o)try{for(var i=s(a),l=i.next();!l.done;l=i.next())if("touch"===n[l.value+"OverflowScrolling"]){o=!0;break}}catch(t){e={error:t}}finally{try{l&&!l.done&&(t=i.return)&&t.call(i)}finally{if(e)throw e.error}}return r.parentNode&&r.parentNode.removeChild(r),o}function C(){return document.body?document.body.clientWidth:window.innerHeight?window.innerWidth:document.documentElement&&document.documentElement.clientWidth?document.documentElement.clientWidth:-1}function O(){return document.body?document.body.clientHeight:window.innerHeight?window.innerHeight:document.documentElement&&document.documentElement.clientHeight?document.documentElement.clientHeight:-1}},function(e,t,a){"use strict";a.d(t,"c",(function(){return l})),a.d(t,"g",(function(){return g})),a.d(t,"f",(function(){return L})),a.d(t,"d",(function(){return I})),a.d(t,"b",(function(){return N})),a.d(t,"a",(function(){return G})),a.d(t,"e",(function(){return _}));var r={};a.r(r),a.d(r,"stringToArray",(function(){return g}));var o={};a.r(o),a.d(o,"getNameOfClass",(function(){return c})),a.d(o,"findLineByLeastSquares",(function(){return u})),a.d(o,"cssStyleObjectToMarkup",(function(){return h})),a.d(o,"message",(function(){return f})),a.d(o,"bindCellRendererToHtmlElement",(function(){return m}));var n={};a.r(n),a.d(n,"sortRowNodesByOrder",(function(){return D})),a.d(n,"traverseNodesWithKey",(function(){return P}));var i=function(e,t){var a="function"==typeof Symbol&&e[Symbol.iterator];if(!a)return e;var r,o,n=a.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(r=n.next()).done;)i.push(r.value)}catch(e){o={error:e}}finally{try{r&&!r.done&&(a=n.return)&&a.call(n)}finally{if(o)throw o.error}}return i},l=function(){function e(e,t,a,r){void 0===r&&(r=1),this.r=Math.min(1,Math.max(0,e||0)),this.g=Math.min(1,Math.max(0,t||0)),this.b=Math.min(1,Math.max(0,a||0)),this.a=Math.min(1,Math.max(0,r||0))}return e.fromString=function(t){if(t.indexOf("#")>=0)return e.fromHexString(t);var a=e.nameToHex[t];if(a)return e.fromHexString(a);if(t.indexOf("rgb")>=0)return e.fromRgbaString(t);throw new Error("Invalid color string: '"+t+"'")},e.parseHex=function(e){var t;switch((e=e.replace(/ /g,"").slice(1)).length){case 6:case 8:t=[];for(var a=0;a=3&&t.every((function(e){return e>=0})))return 3===t.length&&t.push(255),t},e.fromHexString=function(t){var a=e.parseHex(t);if(a){var r=i(a,4);return new e(r[0]/255,r[1]/255,r[2]/255,r[3]/255)}throw new Error("Malformed hexadecimal color string: '"+t+"'")},e.stringToRgba=function(e){for(var t=i([NaN,NaN],2),a=t[0],r=t[1],o=0;o=0?(s=Math.max(0,Math.min(100,s)),s/=100):3===o?s=Math.max(0,Math.min(1,s)):(s=Math.max(0,Math.min(255,s)),s/=255),p.push(s)}return p}},e.fromRgbaString=function(t){var a=e.stringToRgba(t);if(a){if(3===a.length)return new e(a[0],a[1],a[2]);if(4===a.length)return new e(a[0],a[1],a[2],a[3])}throw new Error("Malformed rgb/rgba color string: '"+t+"'")},e.fromArray=function(t){if(4===t.length)return new e(t[0],t[1],t[2],t[3]);if(3===t.length)return new e(t[0],t[1],t[2]);throw new Error("The given array should contain 3 or 4 color components (numbers).")},e.fromHSB=function(t,a,r,o){void 0===o&&(o=1);var n=e.HSBtoRGB(t,a,r);return new e(n[0],n[1],n[2],o)},e.padHex=function(e){return 1===e.length?"0"+e:e},e.prototype.toHexString=function(){var t="#"+e.padHex(Math.round(255*this.r).toString(16))+e.padHex(Math.round(255*this.g).toString(16))+e.padHex(Math.round(255*this.b).toString(16));return this.a<1&&(t+=e.padHex(Math.round(255*this.a).toString(16))),t},e.prototype.toRgbaString=function(e){void 0===e&&(e=3);var t=[Math.round(255*this.r),Math.round(255*this.g),Math.round(255*this.b)],a=Math.pow(10,e);return 1!==this.a?(t.push(Math.round(this.a*a)/a),"rgba("+t.join(", ")+")"):"rgb("+t.join(", ")+")"},e.prototype.toString=function(){return 1===this.a?this.toHexString():this.toRgbaString()},e.prototype.toHSB=function(){return e.RGBtoHSB(this.r,this.g,this.b)},e.RGBtoHSB=function(e,t,a){var r=Math.min(e,t,a),o=Math.max(e,t,a),n=NaN;if(r!==o){var i=o-r,l=(o-e)/i,g=(o-t)/i,p=(o-a)/i;n=e===o?p-g:t===o?2+l-p:4+g-l,(n/=6)<0&&(n+=1)}return[360*n,0!==o?(o-r)/o:0,o]},e.HSBtoRGB=function(e,t,a){isNaN(e)&&(e=0),e=(e%360+360)%360/360;var r=0,o=0,n=0;if(0===t)r=o=n=a;else{var i=6*(e-Math.floor(e)),l=i-Math.floor(i),g=a*(1-t),p=a*(1-t*l),d=a*(1-t*(1-l));switch(i>>0){case 0:r=a,o=d,n=g;break;case 1:r=p,o=a,n=g;break;case 2:r=g,o=a,n=d;break;case 3:r=g,o=p,n=a;break;case 4:r=d,o=g,n=a;break;case 5:r=a,o=g,n=p}}return[r,o,n]},e.prototype.derive=function(t,a,r,o){var n=e.RGBtoHSB(this.r,this.g,this.b),i=n[2];0==i&&r>1&&(i=.05);var l=((n[0]+t)%360+360)%360,g=Math.max(Math.min(n[1]*a,1),0);i=Math.max(Math.min(i*r,1),0);var p=Math.max(Math.min(this.a*o,1),0),d=e.HSBtoRGB(l,g,i);return d.push(p),e.fromArray(d)},e.prototype.brighter=function(){return this.derive(0,1,1/.7,1)},e.prototype.darker=function(){return this.derive(0,1,.7,1)},e.nameToHex=Object.freeze({aliceblue:"#F0F8FF",antiquewhite:"#FAEBD7",aqua:"#00FFFF",aquamarine:"#7FFFD4",azure:"#F0FFFF",beige:"#F5F5DC",bisque:"#FFE4C4",black:"#000000",blanchedalmond:"#FFEBCD",blue:"#0000FF",blueviolet:"#8A2BE2",brown:"#A52A2A",burlywood:"#DEB887",cadetblue:"#5F9EA0",chartreuse:"#7FFF00",chocolate:"#D2691E",coral:"#FF7F50",cornflowerblue:"#6495ED",cornsilk:"#FFF8DC",crimson:"#DC143C",cyan:"#00FFFF",darkblue:"#00008B",darkcyan:"#008B8B",darkgoldenrod:"#B8860B",darkgray:"#A9A9A9",darkgreen:"#006400",darkgrey:"#A9A9A9",darkkhaki:"#BDB76B",darkmagenta:"#8B008B",darkolivegreen:"#556B2F",darkorange:"#FF8C00",darkorchid:"#9932CC",darkred:"#8B0000",darksalmon:"#E9967A",darkseagreen:"#8FBC8F",darkslateblue:"#483D8B",darkslategray:"#2F4F4F",darkslategrey:"#2F4F4F",darkturquoise:"#00CED1",darkviolet:"#9400D3",deeppink:"#FF1493",deepskyblue:"#00BFFF",dimgray:"#696969",dimgrey:"#696969",dodgerblue:"#1E90FF",firebrick:"#B22222",floralwhite:"#FFFAF0",forestgreen:"#228B22",fuchsia:"#FF00FF",gainsboro:"#DCDCDC",ghostwhite:"#F8F8FF",gold:"#FFD700",goldenrod:"#DAA520",gray:"#808080",green:"#008000",greenyellow:"#ADFF2F",grey:"#808080",honeydew:"#F0FFF0",hotpink:"#FF69B4",indianred:"#CD5C5C",indigo:"#4B0082",ivory:"#FFFFF0",khaki:"#F0E68C",lavender:"#E6E6FA",lavenderblush:"#FFF0F5",lawngreen:"#7CFC00",lemonchiffon:"#FFFACD",lightblue:"#ADD8E6",lightcoral:"#F08080",lightcyan:"#E0FFFF",lightgoldenrodyellow:"#FAFAD2",lightgray:"#D3D3D3",lightgreen:"#90EE90",lightgrey:"#D3D3D3",lightpink:"#FFB6C1",lightsalmon:"#FFA07A",lightseagreen:"#20B2AA",lightskyblue:"#87CEFA",lightslategray:"#778899",lightslategrey:"#778899",lightsteelblue:"#B0C4DE",lightyellow:"#FFFFE0",lime:"#00FF00",limegreen:"#32CD32",linen:"#FAF0E6",magenta:"#FF00FF",maroon:"#800000",mediumaquamarine:"#66CDAA",mediumblue:"#0000CD",mediumorchid:"#BA55D3",mediumpurple:"#9370DB",mediumseagreen:"#3CB371",mediumslateblue:"#7B68EE",mediumspringgreen:"#00FA9A",mediumturquoise:"#48D1CC",mediumvioletred:"#C71585",midnightblue:"#191970",mintcream:"#F5FFFA",mistyrose:"#FFE4E1",moccasin:"#FFE4B5",navajowhite:"#FFDEAD",navy:"#000080",oldlace:"#FDF5E6",olive:"#808000",olivedrab:"#6B8E23",orange:"#FFA500",orangered:"#FF4500",orchid:"#DA70D6",palegoldenrod:"#EEE8AA",palegreen:"#98FB98",paleturquoise:"#AFEEEE",palevioletred:"#DB7093",papayawhip:"#FFEFD5",peachpuff:"#FFDAB9",peru:"#CD853F",pink:"#FFC0CB",plum:"#DDA0DD",powderblue:"#B0E0E6",purple:"#800080",rebeccapurple:"#663399",red:"#FF0000",rosybrown:"#BC8F8F",royalblue:"#4169E1",saddlebrown:"#8B4513",salmon:"#FA8072",sandybrown:"#F4A460",seagreen:"#2E8B57",seashell:"#FFF5EE",sienna:"#A0522D",silver:"#C0C0C0",skyblue:"#87CEEB",slateblue:"#6A5ACD",slategray:"#708090",slategrey:"#708090",snow:"#FFFAFA",springgreen:"#00FF7F",steelblue:"#4682B4",tan:"#D2B48C",teal:"#008080",thistle:"#D8BFD8",tomato:"#FF6347",turquoise:"#40E0D0",violet:"#EE82EE",wheat:"#F5DEB3",white:"#FFFFFF",whitesmoke:"#F5F5F5",yellow:"#FFFF00",yellowgreen:"#9ACD32"}),e}();function g(e,t){void 0===t&&(t=",");var a=[],r=function(e){return"\r"===e||"\n"===e},o=!1;if(""===e)return[[""]];for(var n,i,l,g=function(g,p,d){var s=e[d-1],c=e[d],u=e[d+1],h=function(){a[g]||(a[g]=[]),a[g][p]||(a[g][p]="")};if(h(),'"'===c){if(o)return'"'===u?(a[g][p]+='"',d++):o=!1,n=g,i=p,l=d,"continue";if(void 0===s||s===t||r(s))return o=!0,n=g,i=p,l=d,"continue"}if(!o){if(c===t)return p++,h(),n=g,i=p,l=d,"continue";if(r(c))return p=0,g++,h(),"\r"===c&&"\n"===u&&d++,n=g,i=p,l=d,"continue"}a[g][p]+=c,n=g,i=p,l=d},p=0,d=0,s=0;s1?a[1]:""}function u(e){var t=e.length,a=0;if(t<=1)return e;for(var r=0;r1?a=Math.max(a,parseInt(n[1],10)):Math.floor(o)!==o&&(a=Math.max(a,o.toString().split(".")[1].length))}for(var i=0,l=0,g=0,p=0,d=0,s=0;s
'),document.body&&document.body.appendChild(a)}a.insertBefore(t,a.children[0])}function m(e,t){e.then((function(e){var a=e.getGui();null!=a&&("object"==typeof a?t.appendChild(a):t.innerHTML=a)}))}var b=a(11),w=a(10),v=a(22),x=a(33),y=a(24),k=a(15),C=a(176),O=a(1),A=a(20),E=a(50),R=a(51),S=a(77),T=a(42);function D(e,t){if(e){for(var a=function(e,a){var r=t[e.id],o=t[a.id],n=void 0!==r,i=void 0!==o;return n&&i?r-o:!n&&!i?e.__objectId-a.__objectId:n?1:-1},r=!1,o=0;o0){r=!0;break}r&&e.sort(a)}}function P(e,t){var a=[];!function e(r){if(!r)return;r.forEach((function(r){if(r.group||r.hasChildren()){a.push(r.key);var o=a.join("|");t(r,o),e(r.childrenAfterGroup),a.pop()}}))}(e)}var N,M=a(78),F=function(){return(F=Object.assign||function(e){for(var t,a=1,r=arguments.length;a=0}function u(e){for(var t=[],a=e.target;a;)t.push(a),a=a.parentElement;return t}function h(e){e.__agGridEventPath=f(e)}function f(e){var t=e;return t.path?t.path:t.composedPath?t.composedPath():t.__agGridEventPath?t.__agGridEventPath:u(e)}function m(e,t,a,n){var i=Object(r.includes)(o,a)?{passive:!0}:void 0;e&&e.addEventListener&&e.addEventListener(t,a,n,i)}},function(e,t,a){"use strict";a.d(t,"b",(function(){return o})),a.d(t,"c",(function(){return n})),a.d(t,"d",(function(){return Q})),a.d(t,"a",(function(){return $}));var r,o,n,i=a(6),l=a(0),g=a(9),p=a(24),d=a(44),s=a(22),c=a(38),u=a(50),h=a(4),f=a(8),m=a(2),b=a(1),w=a(10),v=a(17),x=a(16),y=a(41),k=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),C=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},O=function(e,t){var a="function"==typeof Symbol&&e[Symbol.iterator];if(!a)return e;var r,o,n=a.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(r=n.next()).done;)i.push(r.value)}catch(e){o={error:e}}finally{try{r&&!r.done&&(a=n.return)&&a.call(n)}finally{if(o)throw o.error}}return i},A=function(e){function t(t){var a=e.call(this)||this;return a.element=t,a}return k(t,e),t.prototype.postConstruct=function(){this.addMouseListeners(),this.mockContextMenuForIPad(),this.addKeyboardEvents()},t.prototype.addKeyboardEvents=function(){var e=this;["keydown","keypress"].forEach((function(t){var a=e.processKeyboardEvent.bind(e,t);e.addManagedListener(e.element,t,a)}))},t.prototype.addMouseListeners=function(){var e=this;["dblclick","contextmenu","mouseover","mouseout","click",Object(p.isEventSupported)("touchstart")?"touchstart":"mousedown"].forEach((function(t){var a=e.processMouseEvent.bind(e,t);e.addManagedListener(e.element,t,a)}))},t.prototype.processMouseEvent=function(e,t){if(this.mouseEventService.isEventFromThisGrid(t)&&!Object(p.isStopPropagationForAgGrid)(t)){var a=this.getRowForEvent(t),r=this.mouseEventService.getRenderedCellForEvent(t);"contextmenu"===e?this.handleContextMenuMouseEvent(t,null,a,r):(r&&r.onMouseEvent(e,t),a&&a.onMouseEvent(e,t))}},t.prototype.mockContextMenuForIPad=function(){var e=this;if(Object(s.isIOSUserAgent)()){var t=new c.a(this.element);this.addManagedListener(t,c.a.EVENT_LONG_TAP,(function(t){var a=e.getRowForEvent(t.touchEvent),r=e.mouseEventService.getRenderedCellForEvent(t.touchEvent);e.handleContextMenuMouseEvent(null,t.touchEvent,a,r)})),this.addDestroyFunc((function(){return t.destroy()}))}},t.prototype.getRowForEvent=function(e){for(var t=e.target;t;){var a=this.gridOptionsWrapper.getDomData(t,d.a.DOM_DATA_KEY_ROW_CTRL);if(a)return a;t=t.parentElement}return null},t.prototype.handleContextMenuMouseEvent=function(e,t,a,r){var o=a?a.getRowNode():null,n=r?r.getColumn():null,i=null;if(n){var l=e||t;r.dispatchCellContextMenuEvent(l),i=this.valueService.getValue(n,o)}var g=this.ctrlsService.getGridBodyCtrl(),p=r?r.getGui():g.getGridBodyElement();this.contextMenuFactory&&this.contextMenuFactory.onContextMenu(e,t,o,n,i,p)},t.prototype.processKeyboardEvent=function(e,t){var a=Object(p.getCtrlForEvent)(this.gridOptionsWrapper,t,y.a.DOM_DATA_KEY_CELL_CTRL),r=Object(p.getCtrlForEvent)(this.gridOptionsWrapper,t,d.a.DOM_DATA_KEY_ROW_CTRL);t.defaultPrevented||(a?this.processCellKeyboardEvent(a,e,t):r&&r.isFullWidth()&&this.processFullWidthRowKeyboardEvent(r,e,t))},t.prototype.processCellKeyboardEvent=function(e,t,a){var r=e.getRowNode(),o=e.getColumn(),n=e.isEditing();if(!Object(u.isUserSuppressingKeyboardEvent)(this.gridOptionsWrapper,a,r,o,n))switch(t){case"keydown":!n&&this.navigationService.handlePageScrollingKey(a)||e.onKeyDown(a),this.doGridOperations(a,e.isEditing());break;case"keypress":e.onKeyPress(a)}if("keydown"===t){var i=e.createEvent(a,h.a.EVENT_CELL_KEY_DOWN);this.eventService.dispatchEvent(i)}if("keypress"===t){var l=e.createEvent(a,h.a.EVENT_CELL_KEY_PRESS);this.eventService.dispatchEvent(l)}},t.prototype.processFullWidthRowKeyboardEvent=function(e,t,a){var r=e.getRowNode(),o=this.focusService.getFocusedCell(),n=o&&o.column;if(!Object(u.isUserSuppressingKeyboardEvent)(this.gridOptionsWrapper,a,r,n,!1)){var i=a.key;if("keydown"===t)switch(i){case f.a.UP:case f.a.DOWN:e.onKeyboardNavigate(a);break;case f.a.TAB:e.onTabKeyDown(a)}}if("keydown"===t){var l=e.createRowEvent(h.a.EVENT_CELL_KEY_DOWN,a);this.eventService.dispatchEvent(l)}if("keypress"===t){var g=e.createRowEvent(h.a.EVENT_CELL_KEY_PRESS,a);this.eventService.dispatchEvent(g)}},t.prototype.doGridOperations=function(e,t){if((e.ctrlKey||e.metaKey)&&!t&&this.mouseEventService.isEventFromThisGrid(e))switch(e.key.toUpperCase()){case f.a.A:return this.onCtrlAndA(e);case f.a.C:return this.onCtrlAndC(e);case f.a.V:return this.onCtrlAndV();case f.a.D:return this.onCtrlAndD(e);case f.a.Z:return e.shiftKey?this.undoRedoService.redo():this.undoRedoService.undo();case f.a.Y:return this.undoRedoService.redo()}},t.prototype.onCtrlAndA=function(e){var t=this.pinnedRowModel,a=this.paginationProxy,r=this.rangeService,o=m.a.PINNED_BOTTOM,n=m.a.PINNED_TOP;if(r&&a.isRowsToRender()){var i=O([t.isEmpty(n),t.isEmpty(o)],2),l=i[0]?null:n,g=void 0,p=void 0;i[1]?(g=null,p=this.paginationProxy.getRowCount()-1):(g=o,p=t.getPinnedBottomRowData().length-1);var d=this.columnModel.getAllDisplayedColumns();if(Object(b.missingOrEmpty)(d))return;r.setCellRange({rowStartIndex:0,rowStartPinned:l,rowEndIndex:p,rowEndPinned:g,columnStart:d[0],columnEnd:Object(w.last)(d)})}e.preventDefault()},t.prototype.onCtrlAndC=function(e){this.clipboardService&&!this.gridOptionsWrapper.isEnableCellTextSelection()&&(this.clipboardService.copyToClipboard(),e.preventDefault())},t.prototype.onCtrlAndV=function(){v.a.isRegistered(x.a.ClipboardModule)&&!this.gridOptionsWrapper.isSuppressClipboardPaste()&&this.clipboardService.pasteFromClipboard()},t.prototype.onCtrlAndD=function(e){v.a.isRegistered(x.a.ClipboardModule)&&!this.gridOptionsWrapper.isSuppressClipboardPaste()&&this.clipboardService.copyRangeDown(),e.preventDefault()},C([Object(l.a)("mouseEventService")],t.prototype,"mouseEventService",void 0),C([Object(l.a)("valueService")],t.prototype,"valueService",void 0),C([Object(l.d)("contextMenuFactory")],t.prototype,"contextMenuFactory",void 0),C([Object(l.a)("ctrlsService")],t.prototype,"ctrlsService",void 0),C([Object(l.a)("navigationService")],t.prototype,"navigationService",void 0),C([Object(l.a)("focusService")],t.prototype,"focusService",void 0),C([Object(l.a)("undoRedoService")],t.prototype,"undoRedoService",void 0),C([Object(l.a)("columnModel")],t.prototype,"columnModel",void 0),C([Object(l.a)("paginationProxy")],t.prototype,"paginationProxy",void 0),C([Object(l.a)("pinnedRowModel")],t.prototype,"pinnedRowModel",void 0),C([Object(l.d)("rangeService")],t.prototype,"rangeService",void 0),C([Object(l.d)("clipboardService")],t.prototype,"clipboardService",void 0),C([l.e],t.prototype,"postConstruct",null),t}(i.a),E=a(5),R=function(){var e=function(t,a){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(t,a)};return function(t,a){function r(){this.constructor=t}e(t,a),t.prototype=null===a?Object.create(a):(r.prototype=a.prototype,new r)}}(),S=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},T=function(e){function t(t){var a=e.call(this)||this;return a.centerContainerCon=t,a}return R(t,e),t.prototype.postConstruct=function(){var e=this;this.ctrlsService.whenReady((function(){e.gridBodyCon=e.ctrlsService.getGridBodyCtrl(),e.listenForResize()})),this.addManagedListener(this.eventService,h.a.EVENT_SCROLLBAR_WIDTH_CHANGED,this.onScrollbarWidthChanged.bind(this))},t.prototype.listenForResize=function(){var e=this.onCenterViewportResized.bind(this);this.centerContainerCon.registerViewportResizeListener(e),this.gridBodyCon.registerBodyViewportResizeListener(e)},t.prototype.onScrollbarWidthChanged=function(){this.checkViewportAndScrolls()},t.prototype.onCenterViewportResized=function(){if(this.centerContainerCon.isViewportVisible()){this.checkViewportAndScrolls();var e=this.centerContainerCon.getCenterWidth();e!==this.centerWidth&&(this.centerWidth=e,this.columnModel.refreshFlexedColumns({viewportWidth:this.centerWidth,updateBodyWidths:!0,fireResizedEvent:!0}))}else this.bodyHeight=0},t.prototype.checkViewportAndScrolls=function(){this.updateScrollVisibleService(),this.checkBodyHeight(),this.onHorizontalViewportChanged(),this.gridBodyCon.getScrollFeature().checkScrollLeft()},t.prototype.getBodyHeight=function(){return this.bodyHeight},t.prototype.checkBodyHeight=function(){var e=this.gridBodyCon.getBodyViewportElement(),t=Object(E.getInnerHeight)(e);if(this.bodyHeight!==t){this.bodyHeight=t;var a={type:h.a.EVENT_BODY_HEIGHT_CHANGED,api:this.gridApi,columnApi:this.columnApi};this.eventService.dispatchEvent(a)}},t.prototype.updateScrollVisibleService=function(){this.updateScrollVisibleServiceImpl(),setTimeout(this.updateScrollVisibleServiceImpl.bind(this),500)},t.prototype.updateScrollVisibleServiceImpl=function(){var e={horizontalScrollShowing:this.isHorizontalScrollShowing(),verticalScrollShowing:this.gridBodyCon.isVerticalScrollShowing()};this.scrollVisibleService.setScrollsVisible(e),this.gridBodyCon.setVerticalScrollPaddingVisible(e.verticalScrollShowing)},t.prototype.isHorizontalScrollShowing=function(){return this.gridOptionsWrapper.isAlwaysShowHorizontalScroll()||this.centerContainerCon.isViewportHScrollShowing()},t.prototype.onHorizontalViewportChanged=function(){var e=this.centerContainerCon.getCenterWidth(),t=this.centerContainerCon.getViewportScrollLeft();this.columnModel.setViewportPosition(e,t)},S([Object(l.a)("ctrlsService")],t.prototype,"ctrlsService",void 0),S([Object(l.a)("columnModel")],t.prototype,"columnModel",void 0),S([Object(l.a)("scrollVisibleService")],t.prototype,"scrollVisibleService",void 0),S([Object(l.a)("columnApi")],t.prototype,"columnApi",void 0),S([Object(l.a)("gridApi")],t.prototype,"gridApi",void 0),S([l.e],t.prototype,"postConstruct",null),t}(i.a),D=a(51),P=function(){var e=function(t,a){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(t,a)};return function(t,a){function r(){this.constructor=t}e(t,a),t.prototype=null===a?Object.create(a):(r.prototype=a.prototype,new r)}}(),N=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},M=function(e){function t(t){var a=e.call(this)||this;return a.element=t,a}return P(t,e),t.prototype.postConstruct=function(){this.addManagedListener(this.eventService,g.a.EVENT_LEFT_PINNED_WIDTH_CHANGED,this.onPinnedLeftWidthChanged.bind(this))},t.prototype.onPinnedLeftWidthChanged=function(){var e=this.pinnedWidthService.getPinnedLeftWidth(),t=e>0;Object(E.setDisplayed)(this.element,t),t&&Object(E.setFixedWidth)(this.element,e)},N([Object(l.a)("pinnedWidthService")],t.prototype,"pinnedWidthService",void 0),N([l.e],t.prototype,"postConstruct",null),t}(i.a),F=function(){var e=function(t,a){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(t,a)};return function(t,a){function r(){this.constructor=t}e(t,a),t.prototype=null===a?Object.create(a):(r.prototype=a.prototype,new r)}}(),L=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},I=function(e){function t(t){var a=e.call(this)||this;return a.element=t,a}return F(t,e),t.prototype.postConstruct=function(){this.addManagedListener(this.eventService,g.a.EVENT_RIGHT_PINNED_WIDTH_CHANGED,this.onPinnedRightWidthChanged.bind(this))},t.prototype.onPinnedRightWidthChanged=function(){var e=this.pinnedWidthService.getPinnedRightWidth(),t=e>0;Object(E.setDisplayed)(this.element,t),t&&Object(E.setFixedWidth)(this.element,e)},L([Object(l.a)("pinnedWidthService")],t.prototype,"pinnedWidthService",void 0),L([l.e],t.prototype,"postConstruct",null),t}(i.a),G=function(){var e=function(t,a){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(t,a)};return function(t,a){function r(){this.constructor=t}e(t,a),t.prototype=null===a?Object.create(a):(r.prototype=a.prototype,new r)}}(),_=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},j=function(e){function t(t,a){var r=e.call(this)||this;return r.eContainer=t,r.eWrapper=a,r}return G(t,e),t.prototype.postConstruct=function(){this.addManagedListener(this.eventService,g.a.EVENT_ROW_CONTAINER_HEIGHT_CHANGED,this.onHeightChanged.bind(this))},t.prototype.onHeightChanged=function(){var e=this.maxDivHeightScaler.getUiContainerHeight(),t=null!=e?e+"px":"";this.eContainer.style.height=t,this.eWrapper&&(this.eWrapper.style.height=t)},_([Object(l.a)("rowContainerHeightService")],t.prototype,"maxDivHeightScaler",void 0),_([l.e],t.prototype,"postConstruct",null),t}(i.a),H=function(){var e=function(t,a){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(t,a)};return function(t,a){function r(){this.constructor=t}e(t,a),t.prototype=null===a?Object.create(a):(r.prototype=a.prototype,new r)}}(),W=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},V=function(e){function t(t){var a=e.call(this)||this;return a.eContainer=t,a}return H(t,e),t.prototype.postConstruct=function(){var e=this;if(this.gridOptionsWrapper.isEnableRangeSelection()&&!Object(b.missing)(this.rangeService)){var t={dragStartPixels:0,eElement:this.eContainer,onDragStart:this.rangeService.onDragStart.bind(this.rangeService),onDragStop:this.rangeService.onDragStop.bind(this.rangeService),onDragging:this.rangeService.onDragging.bind(this.rangeService)};this.dragService.addDragSource(t),this.addDestroyFunc((function(){return e.dragService.removeDragSource(t)}))}},W([Object(l.d)("rangeService")],t.prototype,"rangeService",void 0),W([Object(l.a)("dragService")],t.prototype,"dragService",void 0),W([l.e],t.prototype,"postConstruct",null),t}(i.a),B=a(81),z=a(14),U=function(){var e=function(t,a){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(t,a)};return function(t,a){function r(){this.constructor=t}e(t,a),t.prototype=null===a?Object.create(a):(r.prototype=a.prototype,new r)}}(),Y=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},K=function(e,t){var a="function"==typeof Symbol&&e[Symbol.iterator];if(!a)return e;var r,o,n=a.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(r=n.next()).done;)i.push(r.value)}catch(e){o={error:e}}finally{try{r&&!r.done&&(a=n.return)&&a.call(n)}finally{if(o)throw o.error}}return i},q=function(){for(var e=[],t=0;t=0&&t()},t.prototype.getContainerElement=function(){return this.eContainer},t.prototype.getViewportSizeFeature=function(){return this.viewportSizeFeature},t.prototype.setComp=function(e,t,a,r){var n=this;this.comp=e,this.eContainer=t,this.eViewport=a,this.eWrapper=r,this.createManagedBean(new A(this.eContainer)),this.addPreventScrollWhileDragging(),this.listenOnDomOrder(),this.stopHScrollOnPinnedRows();var i=[o.TOP_CENTER,o.TOP_LEFT,o.TOP_RIGHT],l=[o.BOTTOM_CENTER,o.BOTTOM_LEFT,o.BOTTOM_RIGHT],g=[o.CENTER,o.LEFT,o.RIGHT],p=q(i,l,g),d=[o.CENTER,o.LEFT,o.RIGHT,o.FULL_WIDTH],s=[o.CENTER,o.TOP_CENTER,o.BOTTOM_CENTER],c=[o.LEFT,o.BOTTOM_LEFT,o.TOP_LEFT],u=[o.RIGHT,o.BOTTOM_RIGHT,o.TOP_RIGHT];this.forContainers(c,(function(){return n.createManagedBean(new M(n.eContainer))})),this.forContainers(u,(function(){return n.createManagedBean(new I(n.eContainer))})),this.forContainers(d,(function(){return n.createManagedBean(new j(n.eContainer,n.eWrapper))})),this.forContainers(p,(function(){return n.createManagedBean(new V(n.eContainer))})),this.forContainers(s,(function(){return n.createManagedBean(new B.a((function(e){return n.comp.setContainerWidth(e+"px")})))}))},t.prototype.listenOnDomOrder=function(){var e=this,t=function(){return e.comp.setDomOrder(e.gridOptionsWrapper.isEnsureDomOrder())};this.addManagedListener(this.gridOptionsWrapper,z.a.PROP_DOM_LAYOUT,t),t()},t.prototype.stopHScrollOnPinnedRows=function(){var e=this;this.forContainers([o.TOP_CENTER,o.BOTTOM_CENTER],(function(){e.addManagedListener(e.eViewport,"scroll",(function(){return e.eViewport.scrollLeft=0}))}))},t.prototype.onDisplayedColumnsChanged=function(){var e=this;this.forContainers([o.CENTER],(function(){return e.onHorizontalViewportChanged()}))},t.prototype.onDisplayedColumnsWidthChanged=function(){var e=this;this.forContainers([o.CENTER],(function(){return e.onHorizontalViewportChanged()}))},t.prototype.onScrollVisibilityChanged=function(){if(this.name===o.CENTER){var e=this.scrollVisibleService.isHorizontalScrollShowing()&&this.gridOptionsWrapper.getScrollbarWidth()||0,t=0==e?"100%":"calc(100% + "+e+"px)";this.comp.setViewportHeight(t)}},t.prototype.addPreventScrollWhileDragging=function(){var e=this,t=function(t){e.dragService.isDragging()&&t.cancelable&&t.preventDefault()};this.eContainer.addEventListener("touchmove",t,{passive:!1}),this.addDestroyFunc((function(){return e.eContainer.removeEventListener("touchmove",t)}))},t.prototype.onHorizontalViewportChanged=function(){var e=this.getCenterWidth(),t=this.getCenterViewportScrollLeft();this.columnModel.setViewportPosition(e,t)},t.prototype.getCenterWidth=function(){return Object(E.getInnerWidth)(this.eViewport)},t.prototype.getCenterViewportScrollLeft=function(){return Object(E.getScrollLeft)(this.eViewport,this.enableRtl)},t.prototype.registerViewportResizeListener=function(e){var t=this.resizeObserverService.observeResize(this.eViewport,e);this.addDestroyFunc((function(){return t()}))},t.prototype.isViewportVisible=function(){return Object(E.isVisible)(this.eViewport)},t.prototype.isViewportHScrollShowing=function(){return Object(E.isHorizontalScrollShowing)(this.eViewport)},t.prototype.getViewportScrollLeft=function(){return Object(E.getScrollLeft)(this.eViewport,this.enableRtl)},t.prototype.isHorizontalScrollShowing=function(){return this.gridOptionsWrapper.isAlwaysShowHorizontalScroll()||Object(E.isHorizontalScrollShowing)(this.eViewport)},t.prototype.getViewportElement=function(){return this.eViewport},t.prototype.setContainerTranslateX=function(e){this.eContainer.style.transform="translateX("+e+"px)"},t.prototype.getHScrollPosition=function(){return{left:this.eViewport.scrollLeft,right:this.eViewport.scrollLeft+this.eViewport.offsetWidth}},t.prototype.setCenterViewportScrollLeft=function(e){Object(E.setScrollLeft)(this.eViewport,e,this.enableRtl)},t.prototype.onDisplayedRowsChanged=function(){var e=this,t=this.name===o.TOP_FULL_WIDTH||this.name===o.BOTTOM_FULL_WIDTH||this.name===o.FULL_WIDTH,a=this.getRowCtrls().filter((function(a){var r=a.isFullWidth(),o=e.gridOptionsWrapper.getDomLayout()===m.a.DOM_LAYOUT_PRINT,n=e.embedFullWidthRows||o;return t?!n&&r:n||!r}));this.comp.setRowCtrls(a)},t.prototype.getRowCtrls=function(){switch(this.name){case o.TOP_CENTER:case o.TOP_LEFT:case o.TOP_RIGHT:case o.TOP_FULL_WIDTH:return this.rowRenderer.getTopRowCtrls();case o.BOTTOM_CENTER:case o.BOTTOM_LEFT:case o.BOTTOM_RIGHT:case o.BOTTOM_FULL_WIDTH:return this.rowRenderer.getBottomRowCtrls();default:return this.rowRenderer.getRowCtrls()}},Y([Object(l.a)("scrollVisibleService")],t.prototype,"scrollVisibleService",void 0),Y([Object(l.a)("dragService")],t.prototype,"dragService",void 0),Y([Object(l.a)("ctrlsService")],t.prototype,"ctrlsService",void 0),Y([Object(l.a)("columnModel")],t.prototype,"columnModel",void 0),Y([Object(l.a)("resizeObserverService")],t.prototype,"resizeObserverService",void 0),Y([Object(l.a)("rowRenderer")],t.prototype,"rowRenderer",void 0),Y([l.e],t.prototype,"postConstruct",null),t}(i.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return o})),a.d(t,"b",(function(){return m}));var r,o,n=a(7),i=a(178),l=a(57),g=a(23),p=a(76),d=a(10),s=a(5),c=a(13),u=a(43),h=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),f=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i};!function(e){e[e.One=0]="One",e[e.Two=1]="Two"}(o||(o={}));var m=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return h(t,e),t.prototype.getNumberOfInputs=function(e){var a=this.optionsFactory.getCustomOption(e);if(a){var r=a.numberOfInputs;return null!=r?r:1}var o=[t.EMPTY,t.NOT_BLANK,t.BLANK];return e&&o.indexOf(e)>=0?0:e===t.IN_RANGE?2:1},t.prototype.onFloatingFilterChanged=function(e,t){this.setTypeFromFloatingFilter(e),this.setValueFromFloatingFilter(t),this.onUiChanged(!0)},t.prototype.setTypeFromFloatingFilter=function(e){this.eType1.setValue(e),this.eType2.setValue(this.optionsFactory.getDefaultOption()),(this.isDefaultOperator("AND")?this.eJoinOperatorAnd:this.eJoinOperatorOr).setValue(!0)},t.prototype.getModelFromUi=function(){return this.isConditionUiComplete(o.One)?this.isAllowTwoConditions()&&this.isConditionUiComplete(o.Two)?{filterType:this.getFilterType(),operator:this.getJoinOperator(),condition1:this.createCondition(o.One),condition2:this.createCondition(o.Two)}:this.createCondition(o.One):null},t.prototype.getConditionTypes=function(){return[this.eType1.getValue(),this.eType2.getValue()]},t.prototype.getJoinOperator=function(){return!0===this.eJoinOperatorOr.getValue()?"OR":"AND"},t.prototype.areModelsEqual=function(e,t){if(!e&&!t)return!0;if(!e&&t||e&&!t)return!1;var a,r=!e.operator,o=!t.operator;if(!r&&o||r&&!o)return!1;if(r){var n=e,i=t;a=this.areSimpleModelsEqual(n,i)}else{var l=e,g=t;a=l.operator===g.operator&&this.areSimpleModelsEqual(l.condition1,g.condition1)&&this.areSimpleModelsEqual(l.condition2,g.condition2)}return a},t.prototype.setModelIntoUi=function(e){if(e.operator){var t=e,a="OR"===t.operator;this.eJoinOperatorAnd.setValue(!a),this.eJoinOperatorOr.setValue(a),this.eType1.setValue(t.condition1.type),this.eType2.setValue(t.condition2.type),this.setConditionIntoUi(t.condition1,o.One),this.setConditionIntoUi(t.condition2,o.Two)}else{var r=e;this.eJoinOperatorAnd.setValue(this.isDefaultOperator("AND")),this.eJoinOperatorOr.setValue(this.isDefaultOperator("OR")),this.eType1.setValue(r.type),this.eType2.setValue(this.optionsFactory.getDefaultOption()),this.setConditionIntoUi(r,o.One),this.setConditionIntoUi(null,o.Two)}return g.a.resolve()},t.prototype.doesFilterPass=function(e){var t=this,a=this.getModel();if(null==a)return!0;var r=a.operator,o=[];if(r){var n=a;o.push(n.condition1,n.condition2)}else o.push(a);return o[r&&"OR"===r?"some":"every"]((function(a){return t.individualConditionPasses(e,a)}))},t.prototype.setParams=function(t){e.prototype.setParams.call(this,t),this.optionsFactory=new i.a,this.optionsFactory.init(t,this.getDefaultFilterOptions()),this.allowTwoConditions=!t.suppressAndOrCondition,this.alwaysShowBothConditions=!!t.alwaysShowBothConditions,this.defaultJoinOperator=this.getDefaultJoinOperator(t.defaultJoinOperator),this.putOptionsIntoDropdown(),this.addChangedListeners()},t.prototype.getDefaultJoinOperator=function(e){return Object(d.includes)(["AND","OR"],e)?e:"AND"},t.prototype.putOptionsIntoDropdown=function(){var e=this,t=this.optionsFactory.getFilterOptions(),a=[this.eType1,this.eType2];t.forEach((function(t){var r="string"==typeof t?e.createBoilerplateListOption(t):e.createCustomListOption(t);a.forEach((function(e){return e.addOption(r)}))})),a.forEach((function(e){return e.setDisabled(t.length<=1)}))},t.prototype.createBoilerplateListOption=function(e){return{value:e,text:this.translate(e)}},t.prototype.createCustomListOption=function(e){var t=e.displayKey,a=this.optionsFactory.getCustomOption(e.displayKey);return{value:t,text:a?this.gridOptionsWrapper.getLocaleTextFunc()(a.displayKey,a.displayName):this.translate(t)}},t.prototype.isAllowTwoConditions=function(){return this.allowTwoConditions},t.prototype.createBodyTemplate=function(){return'\n \n '+this.createValueTemplate(o.One)+'\n
\n \n \n
\n \n '+this.createValueTemplate(o.Two)},t.prototype.getCssIdentifier=function(){return"simple-filter"},t.prototype.updateUiVisibility=function(){var e=this,t=[[this.eType1],[this.eType2,this.eJoinOperatorPanel,this.eJoinOperatorAnd,this.eJoinOperatorOr]],a=[this.eCondition1Body,this.eCondition2Body];t.forEach((function(t,a){var r=e.isConditionVisible(a),o=e.isConditionDisabled(a);t.forEach((function(e){e instanceof u.a||e instanceof p.a?(e.setDisabled(o),e.setDisplayed(r)):(Object(s.setDisabled)(e,o),Object(s.setDisplayed)(e,r))}))})),a.forEach((function(t,a){Object(s.setDisplayed)(t,e.isConditionBodyVisible(a))})),this.forEachInput((function(t,a,r,o){e.setElementDisplayed(t,a1?"inRangeStart":0===r?"filterOoo":"inRangeEnd",l=0===r&&n>1?t("ariaFilterFromValue","Filter from value"):0===r?t("ariaFilterValue","Filter Value"):t("ariaFilterToValue","Filter to Value");a.setInputPlaceholder(e.translate(i)),a.setInputAriaLabel(l)}}))},t.prototype.setElementValue=function(e,t,a){e instanceof u.a&&e.setValue(null!=t?String(t):null,a)},t.prototype.setElementDisplayed=function(e,t){e instanceof c.a&&Object(s.setDisplayed)(e.getGui(),t)},t.prototype.setElementDisabled=function(e,t){e instanceof c.a&&Object(s.setDisabled)(e.getGui(),t)},t.prototype.attachElementOnChange=function(e,t){e instanceof u.a&&e.onValueChange(t)},t.prototype.forEachInput=function(e){var t=this,a=this.getInputs();this.getConditionTypes().forEach((function(r,o){for(var n=t.getNumberOfInputs(r),i=0;i0},t.prototype.isConditionUiComplete=function(e){return this.getConditionTypes()[e]!==t.EMPTY&&!this.getValues(e).some((function(e){return null==e}))},t.prototype.resetUiToDefaults=function(e){var t=this,a=this.gridOptionsWrapper.getLocaleTextFunc()("ariaFilteringOperator","Filtering operator"),r="ag-simple-filter-and-or-"+this.getCompId(),o=this.optionsFactory.getDefaultOption();return this.eType1.setValue(o,e).setAriaLabel(a).setDisabled(this.isReadOnly()),this.eType2.setValue(this.optionsFactory.getDefaultOption(),e).setAriaLabel(a).setDisabled(this.isReadOnly()),this.eJoinOperatorAnd.setValue(this.isDefaultOperator("AND"),e).setName(r).setLabel(this.translate("andCondition")).setDisabled(this.isReadOnly()),this.eJoinOperatorOr.setValue(this.isDefaultOperator("OR"),e).setName(r).setLabel(this.translate("orCondition")).setDisabled(this.isReadOnly()),this.forEachInput((function(a){t.setElementValue(a,null,e),t.setElementDisabled(a,t.isReadOnly())})),this.resetPlaceholder(),g.a.resolve()},t.prototype.setConditionIntoUi=function(e,t){var a=this,r=this.mapValuesFromModel(e);this.forEachInput((function(e,o,n,i){n===t&&a.setElementValue(e,null!=r[o]?r[o]:null)}))},t.prototype.setValueFromFloatingFilter=function(e){var t=this;this.forEachInput((function(a,r,o,n){t.setElementValue(a,0===r&&0===o?e:null)}))},t.prototype.isDefaultOperator=function(e){return e===this.defaultJoinOperator},t.prototype.addChangedListeners=function(){var e=this;if(!this.isReadOnly()){var t=function(){return e.onUiChanged()};this.eType1.onValueChange(t),this.eType2.onValueChange(t),this.eJoinOperatorOr.onValueChange(t),this.eJoinOperatorAnd.onValueChange(t),this.forEachInput((function(a){e.attachElementOnChange(a,t)}))}},t.prototype.individualConditionPasses=function(e,t){var a=this.getCellValue(e.node),r=this.mapValuesFromModel(t),o=this.optionsFactory.getCustomOption(t.type),n=this.evaluateCustomFilter(o,r,a);return null!=n?n:null==a?this.evaluateNullValue(t.type):this.evaluateNonNullValue(r,a,t,e)},t.prototype.evaluateCustomFilter=function(e,t,a){if(null!=e){var r=e.predicate;return null==r||t.some((function(e){return null==e}))?void 0:r(t,a)}},t.prototype.isBlank=function(e){return null==e||"string"==typeof e&&0===e.trim().length},t.EMPTY="empty",t.BLANK="blank",t.NOT_BLANK="notBlank",t.EQUALS="equals",t.NOT_EQUAL="notEqual",t.LESS_THAN="lessThan",t.LESS_THAN_OR_EQUAL="lessThanOrEqual",t.GREATER_THAN="greaterThan",t.GREATER_THAN_OR_EQUAL="greaterThanOrEqual",t.IN_RANGE="inRange",t.CONTAINS="contains",t.NOT_CONTAINS="notContains",t.STARTS_WITH="startsWith",t.ENDS_WITH="endsWith",f([Object(n.b)("eOptions1")],t.prototype,"eType1",void 0),f([Object(n.b)("eOptions2")],t.prototype,"eType2",void 0),f([Object(n.b)("eJoinOperatorPanel")],t.prototype,"eJoinOperatorPanel",void 0),f([Object(n.b)("eJoinOperatorAnd")],t.prototype,"eJoinOperatorAnd",void 0),f([Object(n.b)("eJoinOperatorOr")],t.prototype,"eJoinOperatorOr",void 0),f([Object(n.b)("eCondition1Body")],t.prototype,"eCondition1Body",void 0),f([Object(n.b)("eCondition2Body")],t.prototype,"eCondition2Body",void 0),t}(l.a)},function(e,t,a){"use strict";a.r(t),a.d(t,"utf8_encode",(function(){return n})),a.d(t,"camelCaseToHyphen",(function(){return i})),a.d(t,"hyphenToCamelCase",(function(){return l})),a.d(t,"capitalise",(function(){return g})),a.d(t,"escapeString",(function(){return p})),a.d(t,"camelCaseToHumanText",(function(){return d}));var r=/[&<>"']/g,o={"&":"&","<":"<",">":">",'"':""","'":"'"};function n(e){var t=String.fromCharCode;function a(e,a){return t(e>>a&63|128)}function r(e){if(e>=0&&e<=31&&10!==e)return"_x"+e.toString(16).toUpperCase().padStart(4,"0")+"_";if(0==(4294967168&e))return t(e);var r="";return 0==(4294965248&e)?r=t(e>>6&31|192):0==(4294901760&e)?(!function(e){if(e>=55296&&e<=57343)throw Error("Lone surrogate U+"+e.toString(16).toUpperCase()+" is not a scalar value")}(e),r=t(e>>12&15|224),r+=a(e,6)):0==(4292870144&e)&&(r=t(e>>18&7|240),r+=a(e,12),r+=a(e,6)),r+=t(63&e|128)}for(var o=function(e){var t=[];if(!e)return[];for(var a,r,o=e.length,n=0;n=55296&&a<=56319&&n1?e.substring(1,e.length):"")})).join(" ")}},function(e,t,a){"use strict";a.d(t,"a",(function(){return i}));var r=a(30),o=a(18),n=a(34),i=function(){function e(e,t,a,r){this.localEventService=new n.a,this.expandable=!1,this.colGroupDef=e,this.groupId=t,this.expanded=!!e&&!!e.openByDefault,this.padding=a,this.level=r}return e.prototype.setOriginalParent=function(e){this.originalParent=e},e.prototype.getOriginalParent=function(){return this.originalParent},e.prototype.getLevel=function(){return this.level},e.prototype.isVisible=function(){return!!this.children&&this.children.some((function(e){return e.isVisible()}))},e.prototype.isPadding=function(){return this.padding},e.prototype.setExpanded=function(t){this.expanded=void 0!==t&&t;var a={type:e.EVENT_EXPANDED_CHANGED};this.localEventService.dispatchEvent(a)},e.prototype.isExpandable=function(){return this.expandable},e.prototype.isExpanded=function(){return this.expanded},e.prototype.getGroupId=function(){return this.groupId},e.prototype.getId=function(){return this.getGroupId()},e.prototype.setChildren=function(e){this.children=e},e.prototype.getChildren=function(){return this.children},e.prototype.getColGroupDef=function(){return this.colGroupDef},e.prototype.getLeafColumns=function(){var e=[];return this.addLeafColumns(e),e},e.prototype.addLeafColumns=function(t){this.children&&this.children.forEach((function(a){a instanceof o.a?t.push(a):a instanceof e&&a.addLeafColumns(t)}))},e.prototype.getColumnGroupShow=function(){var e=this.colGroupDef;if(e)return e.columnGroupShow},e.prototype.setupExpandable=function(){var e=this;this.setExpandable(),this.getLeafColumns().forEach((function(t){return t.addEventListener(o.a.EVENT_VISIBLE_CHANGED,e.onColumnVisibilityChanged.bind(e))}))},e.prototype.setExpandable=function(){if(!this.isPadding()){for(var t=!1,a=!1,o=!1,n=this.findChildrenRemovingPadding(),i=0,l=n.length;i=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i};!function(e){e.AUTO_HEIGHT="ag-layout-auto-height",e.NORMAL="ag-layout-normal",e.PRINT="ag-layout-print"}(o||(o={}));var s=function(e){function t(t){var a=e.call(this)||this;return a.view=t,a}return p(t,e),t.prototype.postConstruct=function(){this.addManagedListener(this.gridOptionsWrapper,l.a.PROP_DOM_LAYOUT,this.updateLayoutClasses.bind(this)),this.updateLayoutClasses()},t.prototype.updateLayoutClasses=function(){var e=this.gridOptionsWrapper.getDomLayout(),t={autoHeight:e===n.a.DOM_LAYOUT_AUTO_HEIGHT,normal:e===n.a.DOM_LAYOUT_NORMAL,print:e===n.a.DOM_LAYOUT_PRINT},a=t.autoHeight?o.AUTO_HEIGHT:t.print?o.PRINT:o.NORMAL;this.view.updateLayoutClasses(a,t)},d([Object(i.a)("gridOptionsWrapper")],t.prototype,"gridOptionsWrapper",void 0),d([i.e],t.prototype,"postConstruct",null),t}(g.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return g}));var r=a(18),o=a(34),n=a(0),i=a(10),l=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},g=function(){function e(e,t,a,r){this.displayedChildren=[],this.localEventService=new o.a,this.groupId=t,this.instanceId=a,this.providedColumnGroup=e,this.pinned=r}return e.createUniqueId=function(e,t){return e+"_"+t},e.prototype.reset=function(){this.parent=null,this.children=null,this.displayedChildren=null},e.prototype.getParent=function(){return this.parent},e.prototype.setParent=function(e){this.parent=e},e.prototype.getUniqueId=function(){return e.createUniqueId(this.groupId,this.instanceId)},e.prototype.isEmptyGroup=function(){return 0===this.displayedChildren.length},e.prototype.isMoving=function(){var e=this.getProvidedColumnGroup().getLeafColumns();return!(!e||0===e.length)&&e.every((function(e){return e.isMoving()}))},e.prototype.checkLeft=function(){if(this.displayedChildren.forEach((function(t){t instanceof e&&t.checkLeft()})),this.displayedChildren.length>0)if(this.gridOptionsWrapper.isEnableRtl()){var t=Object(i.last)(this.displayedChildren).getLeft();this.setLeft(t)}else{var a=this.displayedChildren[0].getLeft();this.setLeft(a)}else this.setLeft(null)},e.prototype.getLeft=function(){return this.left},e.prototype.getOldLeft=function(){return this.oldLeft},e.prototype.setLeft=function(t){this.oldLeft=t,this.left!==t&&(this.left=t,this.localEventService.dispatchEvent(this.createAgEvent(e.EVENT_LEFT_CHANGED)))},e.prototype.getPinned=function(){return this.pinned},e.prototype.createAgEvent=function(e){return{type:e}},e.prototype.addEventListener=function(e,t){this.localEventService.addEventListener(e,t)},e.prototype.removeEventListener=function(e,t){this.localEventService.removeEventListener(e,t)},e.prototype.getGroupId=function(){return this.groupId},e.prototype.getInstanceId=function(){return this.instanceId},e.prototype.isChildInThisGroupDeepSearch=function(t){var a=!1;return this.children.forEach((function(r){t===r&&(a=!0),r instanceof e&&r.isChildInThisGroupDeepSearch(t)&&(a=!0)})),a},e.prototype.getActualWidth=function(){var e=0;return this.displayedChildren&&this.displayedChildren.forEach((function(t){e+=t.getActualWidth()})),e},e.prototype.isResizable=function(){if(!this.displayedChildren)return!1;var e=!1;return this.displayedChildren.forEach((function(t){t.isResizable()&&(e=!0)})),e},e.prototype.getMinWidth=function(){var e=0;return this.displayedChildren.forEach((function(t){e+=t.getMinWidth()||0})),e},e.prototype.addChild=function(e){this.children||(this.children=[]),this.children.push(e)},e.prototype.getDisplayedChildren=function(){return this.displayedChildren},e.prototype.getLeafColumns=function(){var e=[];return this.addLeafColumns(e),e},e.prototype.getDisplayedLeafColumns=function(){var e=[];return this.addDisplayedLeafColumns(e),e},e.prototype.getDefinition=function(){return this.providedColumnGroup.getColGroupDef()},e.prototype.getColGroupDef=function(){return this.providedColumnGroup.getColGroupDef()},e.prototype.isPadding=function(){return this.providedColumnGroup.isPadding()},e.prototype.isExpandable=function(){return this.providedColumnGroup.isExpandable()},e.prototype.isExpanded=function(){return this.providedColumnGroup.isExpanded()},e.prototype.setExpanded=function(e){this.providedColumnGroup.setExpanded(e)},e.prototype.addDisplayedLeafColumns=function(t){this.displayedChildren.forEach((function(a){a instanceof r.a?t.push(a):a instanceof e&&a.addDisplayedLeafColumns(t)}))},e.prototype.addLeafColumns=function(t){this.children.forEach((function(a){a instanceof r.a?t.push(a):a instanceof e&&a.addLeafColumns(t)}))},e.prototype.getChildren=function(){return this.children},e.prototype.getColumnGroupShow=function(){return this.providedColumnGroup.getColumnGroupShow()},e.prototype.getProvidedColumnGroup=function(){return this.providedColumnGroup},e.prototype.getOriginalColumnGroup=function(){return console.warn("AG Grid: columnGroup.getOriginalColumnGroup() is deprecated due to a method rename, use columnGroup.getProvidedColumnGroup() instead"),this.getProvidedColumnGroup()},e.prototype.getPaddingLevel=function(){var e=this.getParent();return this.isPadding()&&e&&e.isPadding()?1+e.getPaddingLevel():0},e.prototype.calculateDisplayedColumns=function(){var t=this;this.displayedChildren=[];for(var a=this;null!=a&&a.isPadding();)a=a.getParent();if(!(!!a&&a.providedColumnGroup.isExpandable()))return this.displayedChildren=this.children,void this.localEventService.dispatchEvent(this.createAgEvent(e.EVENT_DISPLAYED_CHILDREN_CHANGED));this.children.forEach((function(r){if(!(r instanceof e&&(!r.displayedChildren||!r.displayedChildren.length)))switch(r.getColumnGroupShow()){case e.HEADER_GROUP_SHOW_OPEN:a.providedColumnGroup.isExpanded()&&t.displayedChildren.push(r);break;case e.HEADER_GROUP_SHOW_CLOSED:a.providedColumnGroup.isExpanded()||t.displayedChildren.push(r);break;default:t.displayedChildren.push(r)}})),this.localEventService.dispatchEvent(this.createAgEvent(e.EVENT_DISPLAYED_CHILDREN_CHANGED))},e.HEADER_GROUP_SHOW_OPEN="open",e.HEADER_GROUP_SHOW_CLOSED="closed",e.EVENT_LEFT_CHANGED="leftChanged",e.EVENT_DISPLAYED_CHILDREN_CHANGED="displayedChildrenChanged",l([Object(n.a)("gridOptionsWrapper")],e.prototype,"gridOptionsWrapper",void 0),e}()},function(e,t,a){"use strict";a.d(t,"c",(function(){return r})),a.d(t,"j",(function(){return o})),a.d(t,"k",(function(){return n})),a.d(t,"b",(function(){return i})),a.d(t,"a",(function(){return l})),a.d(t,"l",(function(){return g})),a.d(t,"m",(function(){return p})),a.d(t,"n",(function(){return d})),a.d(t,"q",(function(){return s})),a.d(t,"d",(function(){return c})),a.d(t,"e",(function(){return u})),a.d(t,"p",(function(){return h})),a.d(t,"o",(function(){return f})),a.d(t,"f",(function(){return m})),a.d(t,"i",(function(){return b})),a.d(t,"h",(function(){return w})),a.d(t,"g",(function(){return v}));var r={propertyName:"dateComponent",cellRenderer:!1},o={propertyName:"headerComponent",cellRenderer:!1},n={propertyName:"headerGroupComponent",cellRenderer:!1},i={propertyName:"cellRenderer",cellRenderer:!0},l={propertyName:"cellEditor",cellRenderer:!1},g={propertyName:"innerRenderer",cellRenderer:!0},p={propertyName:"loadingOverlayComponent",cellRenderer:!1},d={propertyName:"noRowsOverlayComponent",cellRenderer:!1},s={propertyName:"tooltipComponent",cellRenderer:!1},c={propertyName:"filter",cellRenderer:!1},u={propertyName:"floatingFilterComponent",cellRenderer:!1},h={propertyName:"toolPanel",cellRenderer:!1},f={propertyName:"statusPanel",cellRenderer:!1},m={propertyName:"fullWidthCellRenderer",cellRenderer:!0},b={propertyName:"loadingCellRenderer",cellRenderer:!0},w={propertyName:"groupRowRenderer",cellRenderer:!0},v={propertyName:"detailCellRenderer",cellRenderer:!0}},function(e,t,a){"use strict";a.d(t,"a",(function(){return i}));var r,o=a(26),n=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),i=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return n(t,e),t.prototype.setParams=function(t){e.prototype.setParams.call(this,t),this.scalarFilterParams=t},t.prototype.evaluateNullValue=function(e){switch(e){case t.EQUALS:case t.NOT_EQUAL:if(this.scalarFilterParams.includeBlanksInEquals)return!0;break;case t.GREATER_THAN:case t.GREATER_THAN_OR_EQUAL:if(this.scalarFilterParams.includeBlanksInGreaterThan)return!0;break;case t.LESS_THAN:case t.LESS_THAN_OR_EQUAL:if(this.scalarFilterParams.includeBlanksInLessThan)return!0;break;case t.IN_RANGE:if(this.scalarFilterParams.includeBlanksInRange)return!0;break;case t.BLANK:return!0;case t.NOT_BLANK:return!1}return!1},t.prototype.evaluateNonNullValue=function(e,a,r){var o=this.comparator(),n=null!=e[0]?o(e[0],a):0;switch(r.type){case t.EQUALS:return 0===n;case t.NOT_EQUAL:return 0!==n;case t.GREATER_THAN:return n>0;case t.GREATER_THAN_OR_EQUAL:return n>=0;case t.LESS_THAN:return n<0;case t.LESS_THAN_OR_EQUAL:return n<=0;case t.IN_RANGE:var i=o(e[1],a);return this.scalarFilterParams.inRangeInclusive?n>=0&&i<=0:n>0&&i<0;case t.BLANK:return this.isBlank(a);case t.NOT_BLANK:return!this.isBlank(a);default:return console.warn('AG Grid: Unexpected type of filter "'+r.type+'", it looks like the filter was configured with incorrect Filter Options'),!0}},t}(o.b)},function(e,t,a){"use strict";a.r(t),a.d(t,"serialiseDate",(function(){return n})),a.d(t,"parseDateTimeFromString",(function(){return i}));var r=a(42),o=function(e,t){var a="function"==typeof Symbol&&e[Symbol.iterator];if(!a)return e;var r,o,n=a.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(r=n.next()).done;)i.push(r.value)}catch(e){o={error:e}}finally{try{r&&!r.done&&(a=n.return)&&a.call(n)}finally{if(o)throw o.error}}return i};function n(e,t,a){if(void 0===t&&(t=!0),void 0===a&&(a="-"),!e)return null;var o=[e.getFullYear(),e.getMonth()+1,e.getDate()].map((function(e){return Object(r.padStartWidthZeros)(e,2)})).join(a);return t&&(o+=" "+[e.getHours(),e.getMinutes(),e.getSeconds()].map((function(e){return Object(r.padStartWidthZeros)(e,2)})).join(":")),o}function i(e){if(!e)return null;var t=o(e.split(" "),2),a=t[0],r=t[1];if(!a)return null;var n=a.split("-").map((function(e){return parseInt(e,10)}));if(3!==n.filter((function(e){return!isNaN(e)})).length)return null;var i=o(n,3),l=i[0],g=i[1],p=i[2],d=new Date(l,g-1,p);if(d.getFullYear()!==l||d.getMonth()!==g-1||d.getDate()!==p)return null;if(!r||"00:00:00"===r)return d;var s=o(r.split(":").map((function(e){return parseInt(e,10)})),3),c=s[0],u=s[1],h=s[2];return c>=0&&c<24&&d.setHours(c),u>=0&&u<60&&d.setMinutes(u),h>=0&&h<60&&d.setSeconds(h),d}},function(e,t,a){"use strict";a.d(t,"a",(function(){return i}));var r=a(0),o=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},n=function(e,t){return function(a,r){t(a,r,e)}},i=function(){function e(){this.allSyncListeners=new Map,this.allAsyncListeners=new Map,this.globalSyncListeners=new Set,this.globalAsyncListeners=new Set,this.asyncFunctionsQueue=[],this.scheduled=!1,this.firedEvents={}}return e.prototype.setBeans=function(e,t,a,r){if(void 0===r&&(r=null),this.frameworkOverrides=a,r){var o=t.useAsyncEvents();this.addGlobalListener(r,o)}},e.prototype.getListeners=function(e,t,a){var r=t?this.allAsyncListeners:this.allSyncListeners,o=r.get(e);return!o&&a&&(o=new Set,r.set(e,o)),o},e.prototype.noRegisteredListenersExist=function(){return 0===this.allSyncListeners.size&&0===this.allAsyncListeners.size&&0===this.globalSyncListeners.size&&0===this.globalAsyncListeners.size},e.prototype.addEventListener=function(e,t,a){void 0===a&&(a=!1),this.getListeners(e,a,!0).add(t)},e.prototype.removeEventListener=function(e,t,a){void 0===a&&(a=!1);var r=this.getListeners(e,a,!1);r&&(r.delete(t),0===r.size&&(a?this.allAsyncListeners:this.allSyncListeners).delete(e))},e.prototype.addGlobalListener=function(e,t){void 0===t&&(t=!1),(t?this.globalAsyncListeners:this.globalSyncListeners).add(e)},e.prototype.removeGlobalListener=function(e,t){void 0===t&&(t=!1),(t?this.globalAsyncListeners:this.globalSyncListeners).delete(e)},e.prototype.dispatchEvent=function(e){this.dispatchToListeners(e,!0),this.dispatchToListeners(e,!1),this.firedEvents[e.type]=!0},e.prototype.dispatchEventOnce=function(e){this.firedEvents[e.type]||this.dispatchEvent(e)},e.prototype.dispatchToListeners=function(e,t){var a=this,r=e.type,o=this.getListeners(r,t,!1);o&&function(r){r.forEach((function(r){t?a.dispatchAsync((function(){return r(e)})):r(e)}))}(o),(t?this.globalAsyncListeners:this.globalSyncListeners).forEach((function(o){t?a.dispatchAsync((function(){return a.frameworkOverrides.dispatchEvent(r,(function(){return o(r,e)}),!0)})):a.frameworkOverrides.dispatchEvent(r,(function(){return o(r,e)}),!0)}))},e.prototype.dispatchAsync=function(e){this.asyncFunctionsQueue.push(e),this.scheduled||(window.setTimeout(this.flushAsyncQueue.bind(this),0),this.scheduled=!0)},e.prototype.flushAsyncQueue=function(){this.scheduled=!1;var e=this.asyncFunctionsQueue.slice();this.asyncFunctionsQueue=[],e.forEach((function(e){return e()}))},o([n(0,Object(r.h)("loggerFactory")),n(1,Object(r.h)("gridOptionsWrapper")),n(2,Object(r.h)("frameworkOverrides")),n(3,Object(r.h)("globalEventListener"))],e.prototype,"setBeans",null),e=o([Object(r.b)("eventService")],e)}()},function(e,t,a){"use strict";a.d(t,"a",(function(){return s}));var r,o=a(0),n=a(8),i=a(24),l=a(6),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),p=function(){return(p=Object.assign||function(e){for(var t,a=1,r=arguments.length;a=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},s=function(e){function t(t,a){void 0===a&&(a={});var r=e.call(this)||this;return r.eFocusableElement=t,r.callbacks=a,r.callbacks=p({shouldStopEventPropagation:function(){return!1},onTabKeyDown:function(e){if(!e.defaultPrevented){var t=r.focusService.findNextFocusableElement(r.eFocusableElement,!1,e.shiftKey);t&&(t.focus(),e.preventDefault())}}},a),r}return g(t,e),t.prototype.postConstruct=function(){this.eFocusableElement.classList.add(t.FOCUS_MANAGED_CLASS),this.addKeyDownListeners(this.eFocusableElement),this.callbacks.onFocusIn&&this.addManagedListener(this.eFocusableElement,"focusin",this.callbacks.onFocusIn),this.callbacks.onFocusOut&&this.addManagedListener(this.eFocusableElement,"focusout",this.callbacks.onFocusOut)},t.prototype.addKeyDownListeners=function(e){var t=this;this.addManagedListener(e,"keydown",(function(e){e.defaultPrevented||Object(i.isStopPropagationForAgGrid)(e)||(t.callbacks.shouldStopEventPropagation(e)?Object(i.stopPropagationForAgGrid)(e):e.key===n.a.TAB?t.callbacks.onTabKeyDown(e):t.callbacks.handleKeyDown&&t.callbacks.handleKeyDown(e))}))},t.FOCUS_MANAGED_CLASS="ag-focus-managed",d([Object(o.a)("focusService")],t.prototype,"focusService",void 0),d([o.e],t.prototype,"postConstruct",null),t}(l.a)},function(e,t,a){"use strict";a.d(t,"b",(function(){return o})),a.d(t,"a",(function(){return y}));var r,o,n=a(0),i=a(11),l=a(5),g=a(12),p=a(13),d=a(7),s=a(82),c=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),u=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},h=function(e){function t(a){var r=e.call(this,t.TEMPLATE,a)||this;return r.headerCompVersion=0,r.column=a.getColumnGroupChild(),r.pinned=a.getPinned(),r}return c(t,e),t.prototype.postConstruct=function(){var e=this,t=this.getGui(),a=function(e,a,r){var o=r||t;null!=a&&""!=a?o.setAttribute(e,a):o.removeAttribute(e)},r={setWidth:function(e){return t.style.width=e},addOrRemoveCssClass:function(t,a){return e.addOrRemoveCssClass(t,a)},setAriaSort:function(e){return e?Object(i.setAriaSort)(t,e):Object(i.removeAriaSort)(t)},setColId:function(e){return a("col-id",e)},setTitle:function(e){return a("title",e)},setAriaDescribedBy:function(e){return Object(i.setAriaDescribedBy)(t,e)},setUserCompDetails:function(t){return e.setUserCompDetails(t)},getUserCompInstance:function(){return e.headerComp}};this.ctrl.setComp(r,this.getGui(),this.eResize);var o=this.ctrl.getSelectAllGui();this.eResize.insertAdjacentElement("afterend",o)},t.prototype.destroyHeaderComp=function(){this.headerComp&&(this.getGui().removeChild(this.headerCompGui),this.headerComp=this.destroyBean(this.headerComp),this.headerCompGui=void 0)},t.prototype.setUserCompDetails=function(e){var t=this;this.headerCompVersion++;var a=this.headerCompVersion;e.newAgStackInstance().then((function(e){return t.afterCompCreated(a,e)}))},t.prototype.afterCompCreated=function(e,t){e==this.headerCompVersion&&this.isAlive()?(this.destroyHeaderComp(),this.headerComp=t,this.headerCompGui=t.getGui(),this.getGui().appendChild(this.headerCompGui),this.ctrl.setDragSource(this.headerCompGui)):this.destroyBean(t)},t.TEMPLATE='
\n \n
',u([Object(d.b)("eResize")],t.prototype,"eResize",void 0),u([n.e],t.prototype,"postConstruct",null),u([n.g],t.prototype,"destroyHeaderComp",null),t}(s.a),f=function(){var e=function(t,a){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(t,a)};return function(t,a){function r(){this.constructor=t}e(t,a),t.prototype=null===a?Object.create(a):(r.prototype=a.prototype,new r)}}(),m=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},b=function(e){function t(a){return e.call(this,t.TEMPLATE,a)||this}return f(t,e),t.prototype.postConstruct=function(){var e=this,t=this.getGui(),a=function(e,a){return null!=a?t.setAttribute(e,a):t.removeAttribute(e)},r={addOrRemoveCssClass:function(t,a){return e.addOrRemoveCssClass(t,a)},addOrRemoveResizableCssClass:function(t,a){return e.eResize.classList.toggle(t,a)},setWidth:function(e){return t.style.width=e},setColId:function(e){return t.setAttribute("col-id",e)},setAriaExpanded:function(e){return a("aria-expanded",e)},setTitle:function(e){return a("title",e)},setUserCompDetails:function(t){return e.setUserCompDetails(t)}};this.ctrl.setComp(r,t,this.eResize)},t.prototype.setUserCompDetails=function(e){var t=this;e.newAgStackInstance().then((function(e){return t.afterHeaderCompCreated(e)}))},t.prototype.afterHeaderCompCreated=function(e){var t=this,a=function(){return t.destroyBean(e)};this.isAlive()?(this.getGui().appendChild(e.getGui()),this.addDestroyFunc(a),this.ctrl.setDragSource(e.getGui())):a()},t.TEMPLATE='
\n \n
',m([Object(n.a)("userComponentFactory")],t.prototype,"userComponentFactory",void 0),m([Object(d.b)("eResize")],t.prototype,"eResize",void 0),m([n.e],t.prototype,"postConstruct",null),t}(s.a),w=a(115),v=function(){var e=function(t,a){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(t,a)};return function(t,a){function r(){this.constructor=t}e(t,a),t.prototype=null===a?Object.create(a):(r.prototype=a.prototype,new r)}}(),x=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i};!function(e){e.COLUMN_GROUP="group",e.COLUMN="column",e.FLOATING_FILTER="filter"}(o||(o={}));var y=function(e){function t(t){var a=e.call(this)||this;a.headerComps={};var r=t.getType()==o.COLUMN_GROUP?"ag-header-row-column-group":t.getType()==o.FLOATING_FILTER?"ag-header-row-column-filter":"ag-header-row-column";return a.setTemplate('
'),a.ctrl=t,a}return v(t,e),t.prototype.init=function(){var e=this,t={setTransform:function(t){return e.getGui().style.transform=t},setHeight:function(t){return e.getGui().style.height=t},setTop:function(t){return e.getGui().style.top=t},setHeaderCtrls:function(t){return e.setHeaderCtrls(t)},setWidth:function(t){return e.getGui().style.width=t},setAriaRowIndex:function(t){return Object(i.setAriaRowIndex)(e.getGui(),t)}};this.ctrl.setComp(t)},t.prototype.destroyHeaderCtrls=function(){this.setHeaderCtrls([])},t.prototype.setHeaderCtrls=function(e){var t=this;if(this.isAlive()){var a=this.headerComps;if(this.headerComps={},e.forEach((function(e){var r=e.getInstanceId(),o=a[r];delete a[r],null==o&&(o=t.createHeaderComp(e),t.getGui().appendChild(o.getGui())),t.headerComps[r]=o})),Object(g.iterateObject)(a,(function(e,a){t.getGui().removeChild(a.getGui()),t.destroyBean(a)})),this.gridOptionsWrapper.isEnsureDomOrder()){var r=Object(g.getAllValuesInObject)(this.headerComps);r.sort((function(e,t){return e.getCtrl().getColumnGroupChild().getLeft()-t.getCtrl().getColumnGroupChild().getLeft()}));var o=r.map((function(e){return e.getGui()}));Object(l.setDomChildOrder)(this.getGui(),o)}}},t.prototype.createHeaderComp=function(e){var t;switch(this.ctrl.getType()){case o.COLUMN_GROUP:t=new b(e);break;case o.FLOATING_FILTER:t=new w.a(e);break;default:t=new h(e)}return this.createBean(t),t.setParentComponent(this),t},x([n.e],t.prototype,"init",null),x([n.g],t.prototype,"destroyHeaderCtrls",null),t}(p.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return l}));var r,o=a(79),n=a(5),i=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),l=function(e){function t(t,a,r){var o=e.call(this,t,a)||this;return o.className=r,o.disabled=!1,o}return i(t,e),t.prototype.postConstruct=function(){e.prototype.postConstruct.call(this),this.className&&this.addCssClass(this.className)},t.prototype.onValueChange=function(e){var a=this;return this.addManagedListener(this,t.EVENT_CHANGED,(function(){return e(a.getValue())})),this},t.prototype.getWidth=function(){return this.getGui().clientWidth},t.prototype.setWidth=function(e){return Object(n.setFixedWidth)(this.getGui(),e),this},t.prototype.getPreviousValue=function(){return this.previousValue},t.prototype.getValue=function(){return this.value},t.prototype.setValue=function(e,a){return this.value===e||(this.previousValue=this.value,this.value=e,a||this.dispatchEvent({type:t.EVENT_CHANGED})),this},t.prototype.setDisabled=function(e){e=!!e;var t=this.getGui();return Object(n.setDisabled)(t,e),t.classList.toggle("ag-disabled",e),this.disabled=e,this},t.prototype.isDisabled=function(){return!!this.disabled},t.EVENT_CHANGED="valueChange",t}(o.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return n}));var r=a(34),o=a(77),n=function(){function e(e,t){var a=this;void 0===t&&(t=!1),this.destroyFuncs=[],this.touching=!1,this.eventService=new r.a,this.eElement=e,this.preventMouseClick=t;var o=this.onTouchStart.bind(this),n=this.onTouchMove.bind(this),i=this.onTouchEnd.bind(this);this.eElement.addEventListener("touchstart",o,{passive:!0}),this.eElement.addEventListener("touchmove",n,{passive:!0}),this.eElement.addEventListener("touchend",i,{passive:!1}),this.destroyFuncs.push((function(){a.eElement.removeEventListener("touchstart",o,{passive:!0}),a.eElement.removeEventListener("touchmove",n,{passive:!0}),a.eElement.removeEventListener("touchend",i,{passive:!1})}))}return e.prototype.getActiveTouch=function(e){for(var t=0;t0)if(t-this.lastTapTime>e.DOUBLE_TAP_MILLIS){var a={type:e.EVENT_DOUBLE_TAP,touchStart:this.touchStart};this.eventService.dispatchEvent(a),this.lastTapTime=null}else this.lastTapTime=t;else this.lastTapTime=t},e.prototype.destroy=function(){this.destroyFuncs.forEach((function(e){return e()}))},e.EVENT_TAP="tap",e.EVENT_DOUBLE_TAP="doubleTap",e.EVENT_LONG_TAP="longTap",e.DOUBLE_TAP_MILLIS=500,e}()},function(e,t,a){"use strict";var r,o=function(){return void 0===r&&(r=Boolean(window&&document&&document.all&&!window.atob)),r},n=function(){var e={};return function(t){if(void 0===e[t]){var a=document.querySelector(t);if(window.HTMLIFrameElement&&a instanceof window.HTMLIFrameElement)try{a=a.contentDocument.head}catch(e){a=null}e[t]=a}return e[t]}}(),i=[];function l(e){for(var t=-1,a=0;a=4),this.cellComp.addOrRemoveCssClass("ag-cell-range-chart",this.hasChartRange),Object(p.setAriaSelected)(this.eGui,this.rangeCount>0||void 0),this.cellComp.addOrRemoveCssClass("ag-cell-range-single-cell",this.isSingleCell()),this.updateRangeBorders(),this.refreshHandle())},e.prototype.updateRangeBorders=function(){var e=this.getRangeBorders(),t=this.isSingleCell(),a=!t&&e.top,r=!t&&e.right,o=!t&&e.bottom,n=!t&&e.left;this.cellComp.addOrRemoveCssClass("ag-cell-range-top",a),this.cellComp.addOrRemoveCssClass("ag-cell-range-right",r),this.cellComp.addOrRemoveCssClass("ag-cell-range-bottom",o),this.cellComp.addOrRemoveCssClass("ag-cell-range-left",n)},e.prototype.isSingleCell=function(){var e=this.beans.rangeService;return 1===this.rangeCount&&e&&!e.isMoreThanOneCell()},e.prototype.getHasChartRange=function(){var e=this.beans.rangeService;if(!this.rangeCount||!e)return!1;var t=e.getCellRanges();return t.length>0&&t.every((function(e){return Object(i.includes)([l.a.DIMENSION,l.a.VALUE],e.type)}))},e.prototype.updateRangeBordersIfRangeCount=function(){this.rangeCount>0&&(this.updateRangeBorders(),this.refreshHandle())},e.prototype.getRangeBorders=function(){var e,t,a=this,r=this.beans.gridOptionsWrapper.isEnableRtl(),o=!1,n=!1,i=!1,l=!1,g=this.cellCtrl.getCellPosition().column,p=this.beans,d=p.rangeService,s=p.columnModel;r?(e=s.getDisplayedColAfter(g),t=s.getDisplayedColBefore(g)):(e=s.getDisplayedColBefore(g),t=s.getDisplayedColAfter(g));var c=d.getCellRanges().filter((function(e){return d.isCellInSpecificRange(a.cellCtrl.getCellPosition(),e)}));e||(l=!0),t||(n=!0);for(var u=0;u=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},I=function(e){function t(t,a,r,o){var n=e.call(this,'
')||this;return n.rowNode=t,n.column=a,n.beans=r,n.eCell=o,n}return F(t,e),t.prototype.postConstruct=function(){this.getGui().appendChild(Object(M.createIconNoSpan)("rowDrag",this.beans.gridOptionsWrapper,null)),this.addGuiEventListener("mousedown",(function(e){e.stopPropagation()})),this.addDragSource(),this.checkVisibility()},t.prototype.addDragSource=function(){this.addGuiEventListener("dragstart",this.onDragStart.bind(this))},t.prototype.onDragStart=function(e){var t=this,a=this.column.getColDef().dndSourceOnRowDrag;e.dataTransfer.setDragImage(this.eCell,0,0);a?a({rowNode:this.rowNode,dragEvent:e}):function(){try{var a=JSON.stringify(t.rowNode.data);e.dataTransfer.setData("application/json",a),e.dataTransfer.setData("text/plain",a)}catch(e){}}()},t.prototype.checkVisibility=function(){var e=this.column.isDndSource(this.rowNode);this.setDisplayed(e)},L([N.e],t.prototype,"postConstruct",null),t}(P.a),G=a(15),_=a(64),j=a(12),H=function(){var e=function(t,a){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(t,a)};return function(t,a){function r(){this.constructor=t}e(t,a),t.prototype=null===a?Object.create(a):(r.prototype=a.prototype,new r)}}(),W=function(){return(W=Object.assign||function(e){for(var t,a=1,r=arguments.length;a>>=8;return a}function g(e,t,a){return"number"!=typeof e?"":p(Math.round(100*e)/100,t,a)}function p(e,t,a){return"number"!=typeof e?"":e.toString().replace(".",a).replace(/(\d)(?=(\d{3})+(?!\d))/g,"$1"+t)}function d(e){return null==e?null:e.reduce((function(e,t){return e+t}),0)}a.r(t),a.d(t,"padStartWidthZeros",(function(){return r})),a.d(t,"createArrayOfNumbers",(function(){return o})),a.d(t,"isNumeric",(function(){return n})),a.d(t,"cleanNumber",(function(){return i})),a.d(t,"decToHex",(function(){return l})),a.d(t,"formatNumberTwoDecimalPlacesAndCommas",(function(){return g})),a.d(t,"formatNumberCommas",(function(){return p})),a.d(t,"sum",(function(){return d}))},function(e,t,a){"use strict";a.d(t,"a",(function(){return s}));var r,o=a(7),n=a(37),i=a(5),l=a(11),g=a(1),p=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),d=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},s=function(e){function t(t,a,r,o){void 0===r&&(r="text"),void 0===o&&(o="input");var n=e.call(this,t,'\n
\n
\n \n
",a)||this;return n.inputType=r,n.displayFieldTag=o,n}return p(t,e),t.prototype.postConstruct=function(){e.prototype.postConstruct.call(this),this.setInputType(),this.eLabel.classList.add(this.className+"-label"),this.eWrapper.classList.add(this.className+"-input-wrapper"),this.eInput.classList.add(this.className+"-input"),this.addCssClass("ag-input-field"),this.eInput.id=this.eInput.id||"ag-"+this.getCompId()+"-input";var t=this.config,a=t.width,r=t.value;null!=a&&this.setWidth(a),null!=r&&this.setValue(r),this.addInputListeners()},t.prototype.refreshLabel=function(){Object(g.exists)(this.getLabel())?Object(l.setAriaLabelledBy)(this.eInput,this.getLabelId()):this.eInput.removeAttribute("aria-labelledby"),e.prototype.refreshLabel.call(this)},t.prototype.addInputListeners=function(){var e=this;this.addManagedListener(this.eInput,"input",(function(t){return e.setValue(t.target.value)}))},t.prototype.setInputType=function(){"input"===this.displayFieldTag&&this.eInput.setAttribute("type",this.inputType)},t.prototype.getInputElement=function(){return this.eInput},t.prototype.setInputWidth=function(e){return Object(i.setElementWidth)(this.eWrapper,e),this},t.prototype.setInputName=function(e){return this.getInputElement().setAttribute("name",e),this},t.prototype.getFocusableElement=function(){return this.eInput},t.prototype.setMaxLength=function(e){return this.eInput.maxLength=e,this},t.prototype.setInputPlaceholder=function(e){return Object(i.addOrRemoveAttribute)(this.eInput,"placeholder",e),this},t.prototype.setInputAriaLabel=function(e){return Object(l.setAriaLabel)(this.eInput,e),this},t.prototype.setDisabled=function(t){return Object(i.setDisabled)(this.eInput,t),e.prototype.setDisabled.call(this,t)},d([Object(o.b)("eLabel")],t.prototype,"eLabel",void 0),d([Object(o.b)("eWrapper")],t.prototype,"eWrapper",void 0),d([Object(o.b)("eInput")],t.prototype,"eInput",void 0),t}(n.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return E}));var r,o,n=a(2),i=a(6),l=a(19),g=a(4),p=a(16),d=a(17),s=a(5),c=a(24),u=a(15),h=a(1),f=a(27),m=a(41),b=function(){return(b=Object.assign||function(e){for(var t,a=1,r=arguments.length;a0)&&!(r=n.next()).done;)i.push(r.value)}catch(e){o={error:e}}finally{try{r&&!r.done&&(a=n.return)&&a.call(n)}finally{if(o)throw o.error}}return i},O=function(){for(var e=[],t=0;t=0)}return!0},t.prototype.setAnimateFlags=function(e){if(e){var t=Object(h.exists)(this.rowNode.oldRowTop);this.slideRowIn=t,this.fadeRowIn=!t}else this.slideRowIn=!1,this.fadeRowIn=!1},t.prototype.isEditing=function(){return this.editingRow},t.prototype.stopRowEditing=function(e){this.stopEditing(e)},t.prototype.isFullWidth=function(){return this.rowType!==o.Normal},t.prototype.getRowType=function(){return this.rowType},t.prototype.refreshFullWidth=function(){var e=this,t=function(t,a){if(!t)return!0;var r=t.rowComp.getFullWidthCellRenderer();if(!r)return!1;if(!r.refresh)return!1;var o=e.createFullWidthParams(t.element,a);return r.refresh(o)},a=t(this.fullWidthGui,null),r=t(this.centerGui,null),o=t(this.leftGui,n.a.PINNED_LEFT),i=t(this.rightGui,n.a.PINNED_RIGHT);return a&&r&&o&&i},t.prototype.addListeners=function(){this.addManagedListener(this.rowNode,l.b.EVENT_HEIGHT_CHANGED,this.onRowHeightChanged.bind(this)),this.addManagedListener(this.rowNode,l.b.EVENT_ROW_SELECTED,this.onRowSelected.bind(this)),this.addManagedListener(this.rowNode,l.b.EVENT_ROW_INDEX_CHANGED,this.onRowIndexChanged.bind(this)),this.addManagedListener(this.rowNode,l.b.EVENT_TOP_CHANGED,this.onTopChanged.bind(this)),this.addManagedListener(this.rowNode,l.b.EVENT_EXPANDED_CHANGED,this.updateExpandedCss.bind(this)),this.addManagedListener(this.rowNode,l.b.EVENT_HAS_CHILDREN_CHANGED,this.updateExpandedCss.bind(this)),this.addManagedListener(this.rowNode,l.b.EVENT_DATA_CHANGED,this.onRowNodeDataChanged.bind(this)),this.addManagedListener(this.rowNode,l.b.EVENT_CELL_CHANGED,this.onRowNodeCellChanged.bind(this)),this.addManagedListener(this.rowNode,l.b.EVENT_HIGHLIGHT_CHANGED,this.onRowNodeHighlightChanged.bind(this)),this.addManagedListener(this.rowNode,l.b.EVENT_DRAGGING_CHANGED,this.onRowNodeDraggingChanged.bind(this)),this.addManagedListener(this.rowNode,l.b.EVENT_UI_LEVEL_CHANGED,this.onUiLevelChanged.bind(this));var e=this.beans.eventService;this.addManagedListener(e,g.a.EVENT_PAGINATION_PIXEL_OFFSET_CHANGED,this.onPaginationPixelOffsetChanged.bind(this)),this.addManagedListener(e,g.a.EVENT_HEIGHT_SCALE_CHANGED,this.onTopChanged.bind(this)),this.addManagedListener(e,g.a.EVENT_DISPLAYED_COLUMNS_CHANGED,this.onDisplayedColumnsChanged.bind(this)),this.addManagedListener(e,g.a.EVENT_VIRTUAL_COLUMNS_CHANGED,this.onVirtualColumnsChanged.bind(this)),this.addManagedListener(e,g.a.EVENT_CELL_FOCUSED,this.onCellFocusChanged.bind(this)),this.addManagedListener(e,g.a.EVENT_PAGINATION_CHANGED,this.onPaginationChanged.bind(this)),this.addManagedListener(e,g.a.EVENT_MODEL_UPDATED,this.onModelUpdated.bind(this)),this.addManagedListener(e,g.a.EVENT_COLUMN_MOVED,this.onColumnMoved.bind(this)),this.addListenersForCellComps()},t.prototype.onColumnMoved=function(){this.updateColumnLists()},t.prototype.addListenersForCellComps=function(){var e=this;this.addManagedListener(this.rowNode,l.b.EVENT_ROW_INDEX_CHANGED,(function(){e.getAllCellCtrls().forEach((function(e){return e.onRowIndexChanged()}))})),this.addManagedListener(this.rowNode,l.b.EVENT_CELL_CHANGED,(function(t){e.getAllCellCtrls().forEach((function(e){return e.onCellChanged(t)}))}))},t.prototype.onRowNodeDataChanged=function(e){this.getAllCellCtrls().forEach((function(t){return t.refreshCell({suppressFlash:!e.update,newData:!e.update})})),this.onRowSelected(),this.postProcessCss()},t.prototype.onRowNodeCellChanged=function(){this.postProcessCss()},t.prototype.postProcessCss=function(){this.setStylesFromGridOptions(),this.postProcessClassesFromGridOptions(),this.postProcessRowClassRules(),this.postProcessRowDragging()},t.prototype.onRowNodeHighlightChanged=function(){var e=this.rowNode.highlighted;this.allRowGuis.forEach((function(t){var a=e===l.a.Above,r=e===l.a.Below;t.rowComp.addOrRemoveCssClass("ag-row-highlight-above",a),t.rowComp.addOrRemoveCssClass("ag-row-highlight-below",r)}))},t.prototype.onRowNodeDraggingChanged=function(){this.postProcessRowDragging()},t.prototype.postProcessRowDragging=function(){var e=this.rowNode.dragging;this.allRowGuis.forEach((function(t){return t.rowComp.addOrRemoveCssClass("ag-row-dragging",e)}))},t.prototype.updateExpandedCss=function(){var e=this.rowNode.isExpandable(),t=1==this.rowNode.expanded;this.allRowGuis.forEach((function(a){a.rowComp.addOrRemoveCssClass("ag-row-group",e),a.rowComp.addOrRemoveCssClass("ag-row-group-expanded",e&&t),a.rowComp.addOrRemoveCssClass("ag-row-group-contracted",e&&!t),Object(y.setAriaExpanded)(a.element,e&&t)}))},t.prototype.onDisplayedColumnsChanged=function(){this.updateColumnLists(!0),this.beans.columnModel.wasAutoRowHeightEverActive()&&this.rowNode.checkAutoHeights()},t.prototype.onVirtualColumnsChanged=function(){this.updateColumnLists()},t.prototype.getRowPosition=function(){return{rowPinned:this.rowNode.rowPinned,rowIndex:this.rowNode.rowIndex}},t.prototype.onKeyboardNavigate=function(e){var t=this.allRowGuis.find((function(t){return t.element.contains(e.target)}));if((t?t.element:null)===e.target){var a=this.rowNode,r=this.beans.focusService.getFocusedCell(),o={rowIndex:a.rowIndex,rowPinned:a.rowPinned,column:r&&r.column};this.beans.navigationService.navigateToNextCell(e,e.key,o,!0),e.preventDefault()}},t.prototype.onTabKeyDown=function(e){if(!e.defaultPrevented&&!Object(c.isStopPropagationForAgGrid)(e)){var t=this.allRowGuis.find((function(t){return t.element.contains(e.target)})),a=t?t.element:null,r=a===e.target,o=null;r||(o=this.beans.focusService.findNextFocusableElement(a,!1,e.shiftKey)),(this.isFullWidth()&&r||!o)&&this.beans.navigationService.onTabKeyDown(this,e)}},t.prototype.onFullWidthRowFocused=function(e){var t,a=this.rowNode,r=this.isFullWidth()&&e.rowIndex===a.rowIndex&&e.rowPinned==a.rowPinned,o=this.fullWidthGui?this.fullWidthGui.element:null===(t=this.centerGui)||void 0===t?void 0:t.element;o&&(o.classList.toggle("ag-full-width-focus",r),r&&o.focus({preventScroll:!0}))},t.prototype.refreshCell=function(e){this.centerCellCtrls=this.removeCellCtrl(this.centerCellCtrls,e),this.leftCellCtrls=this.removeCellCtrl(this.leftCellCtrls,e),this.rightCellCtrls=this.removeCellCtrl(this.rightCellCtrls,e),this.updateColumnLists()},t.prototype.removeCellCtrl=function(e,t){var a={list:[],map:{}};return e.list.forEach((function(e){e!==t&&(a.list.push(e),a.map[e.getInstanceId()]=e)})),a},t.prototype.onMouseEvent=function(e,t){switch(e){case"dblclick":this.onRowDblClick(t);break;case"click":this.onRowClick(t);break;case"touchstart":case"mousedown":this.onRowMouseDown(t)}},t.prototype.createRowEvent=function(e,t){return{type:e,node:this.rowNode,data:this.rowNode.data,rowIndex:this.rowNode.rowIndex,rowPinned:this.rowNode.rowPinned,context:this.beans.gridOptionsWrapper.getContext(),api:this.beans.gridOptionsWrapper.getApi(),columnApi:this.beans.gridOptionsWrapper.getColumnApi(),event:t}},t.prototype.createRowEventWithSource=function(e,t){var a=this.createRowEvent(e,t);return a.source=this,a},t.prototype.onRowDblClick=function(e){if(!Object(c.isStopPropagationForAgGrid)(e)){var t=this.createRowEventWithSource(g.a.EVENT_ROW_DOUBLE_CLICKED,e);this.beans.eventService.dispatchEvent(t)}},t.prototype.onRowMouseDown=function(e){if(this.lastMouseDownOnDragger=Object(s.isElementChildOfClass)(e.target,"ag-row-drag",3),this.isFullWidth()){var t=this.rowNode,a=this.beans.columnModel;this.beans.focusService.setFocusedCell(t.rowIndex,a.getAllDisplayedColumns()[0],t.rowPinned,!0)}},t.prototype.onRowClick=function(e){if(!(Object(c.isStopPropagationForAgGrid)(e)||this.lastMouseDownOnDragger)){var t=this.createRowEventWithSource(g.a.EVENT_ROW_CLICKED,e);this.beans.eventService.dispatchEvent(t);var a=e.ctrlKey||e.metaKey,r=e.shiftKey;if(!(this.beans.gridOptionsWrapper.isGroupSelectsChildren()&&this.rowNode.group||!this.rowNode.selectable||this.rowNode.rowPinned||!this.beans.gridOptionsWrapper.isRowSelection()||this.beans.gridOptionsWrapper.isSuppressRowClickSelection())){var o=this.beans.gridOptionsWrapper.isRowMultiSelectWithClick(),n=!this.beans.gridOptionsWrapper.isSuppressRowDeselection();if(this.rowNode.isSelected())o?this.rowNode.setSelectedParams({newValue:!1}):a?n&&this.rowNode.setSelectedParams({newValue:!1}):this.rowNode.setSelectedParams({newValue:!r,clearSelection:!r,rangeSelect:r});else{var i=!o&&!a;this.rowNode.setSelectedParams({newValue:!0,clearSelection:i,rangeSelect:r})}}}},t.prototype.setupDetailRowAutoHeight=function(e){var t=this;if(this.rowType===o.FullWidthDetail&&this.beans.gridOptionsWrapper.isDetailRowAutoHeight()){var a=function(){var a=e.clientHeight;if(null!=a&&a>0){t.beans.frameworkOverrides.setTimeout((function(){t.rowNode.setRowHeight(a),t.beans.clientSideRowModel?t.beans.clientSideRowModel.onRowHeightChanged():t.beans.serverSideRowModel&&t.beans.serverSideRowModel.onRowHeightChanged()}),0)}},r=this.beans.resizeObserverService.observeResize(e,a);this.addDestroyFunc(r),a()}},t.prototype.createFullWidthParams=function(e,t){var a=this;return{fullWidth:!0,data:this.rowNode.data,node:this.rowNode,value:this.rowNode.key,valueFormatted:this.rowNode.key,$scope:this.scope?this.scope:this.parentScope,$compile:this.beans.$compile,rowIndex:this.rowNode.rowIndex,api:this.beans.gridOptionsWrapper.getApi(),columnApi:this.beans.gridOptionsWrapper.getColumnApi(),context:this.beans.gridOptionsWrapper.getContext(),eGridCell:e,eParentOfValue:e,pinned:t,addRenderedRowListener:this.addEventListener.bind(this),registerRowDragger:function(e,t,r,o){return a.addFullWidthRowDragging(e,t,r,o)}}},t.prototype.addFullWidthRowDragging=function(e,t,a,r){if(void 0===a&&(a=""),this.isFullWidth()){var o=new v.a((function(){return a}),this.rowNode,void 0,e,t,r);this.createManagedBean(o,this.beans.context)}},t.prototype.onUiLevelChanged=function(){var e=this.beans.rowCssClassCalculator.calculateRowLevel(this.rowNode);if(this.rowLevel!=e){var t="ag-row-level-"+e,a="ag-row-level-"+this.rowLevel;this.allRowGuis.forEach((function(e){e.rowComp.addOrRemoveCssClass(t,!0),e.rowComp.addOrRemoveCssClass(a,!1)}))}this.rowLevel=e},t.prototype.isFirstRowOnPage=function(){return this.rowNode.rowIndex===this.beans.paginationProxy.getPageFirstRow()},t.prototype.isLastRowOnPage=function(){return this.rowNode.rowIndex===this.beans.paginationProxy.getPageLastRow()},t.prototype.onModelUpdated=function(){this.refreshFirstAndLastRowStyles()},t.prototype.refreshFirstAndLastRowStyles=function(){var e=this.isFirstRowOnPage(),t=this.isLastRowOnPage();this.firstRowOnPage!==e&&(this.firstRowOnPage=e,this.allRowGuis.forEach((function(t){return t.rowComp.addOrRemoveCssClass("ag-row-first",e)}))),this.lastRowOnPage!==t&&(this.lastRowOnPage=t,this.allRowGuis.forEach((function(e){return e.rowComp.addOrRemoveCssClass("ag-row-last",t)})))},t.prototype.stopEditing=function(e){if(void 0===e&&(e=!1),this.getAllCellCtrls().forEach((function(t){return t.stopEditing(e)})),this.editingRow){if(!e){var t=this.createRowEvent(g.a.EVENT_ROW_VALUE_CHANGED);this.beans.eventService.dispatchEvent(t)}this.setEditingRow(!1)}},t.prototype.setInlineEditingCss=function(e){this.allRowGuis.forEach((function(t){t.rowComp.addOrRemoveCssClass("ag-row-inline-editing",e),t.rowComp.addOrRemoveCssClass("ag-row-not-inline-editing",!e)}))},t.prototype.setEditingRow=function(e){this.editingRow=e,this.allRowGuis.forEach((function(t){return t.rowComp.addOrRemoveCssClass("ag-row-editing",e)}));var t=e?this.createRowEvent(g.a.EVENT_ROW_EDITING_STARTED):this.createRowEvent(g.a.EVENT_ROW_EDITING_STOPPED);this.beans.eventService.dispatchEvent(t)},t.prototype.startRowEditing=function(e,t,a,r){void 0===e&&(e=null),void 0===t&&(t=null),void 0===a&&(a=null),void 0===r&&(r=null),this.editingRow||(this.getAllCellCtrls().forEach((function(o){var n=o===a;n?o.startEditing(e,t,n,r):o.startEditing(null,null,n,r)})),this.setEditingRow(!0))},t.prototype.getAllCellCtrls=function(){return O(this.centerCellCtrls.list,this.leftCellCtrls.list,this.rightCellCtrls.list)},t.prototype.postProcessClassesFromGridOptions=function(){var e=this,t=this.beans.rowCssClassCalculator.processClassesFromGridOptions(this.rowNode,this.scope);t&&t.length&&t.forEach((function(t){e.allRowGuis.forEach((function(e){return e.rowComp.addOrRemoveCssClass(t,!0)}))}))},t.prototype.postProcessRowClassRules=function(){var e=this;this.beans.rowCssClassCalculator.processRowClassRules(this.rowNode,this.scope,(function(t){e.allRowGuis.forEach((function(e){return e.rowComp.addOrRemoveCssClass(t,!0)}))}),(function(t){e.allRowGuis.forEach((function(e){return e.rowComp.addOrRemoveCssClass(t,!1)}))}))},t.prototype.setStylesFromGridOptions=function(){var e=this.processStylesFromGridOptions();this.allRowGuis.forEach((function(t){return t.rowComp.setUserStyles(e)}))},t.prototype.getRowBusinessKey=function(){var e=this.beans.gridOptionsWrapper.getBusinessKeyForNodeFunc();if("function"==typeof e)return e(this.rowNode)},t.prototype.getPinnedForContainer=function(e){return e===x.c.LEFT?n.a.PINNED_LEFT:e===x.c.RIGHT?n.a.PINNED_RIGHT:null},t.prototype.getInitialRowClasses=function(e){var t=this.getPinnedForContainer(e),a={rowNode:this.rowNode,rowFocused:this.rowFocused,fadeRowIn:this.fadeRowIn,rowIsEven:this.rowNode.rowIndex%2==0,rowLevel:this.rowLevel,fullWidthRow:this.isFullWidth(),firstRowOnPage:this.isFirstRowOnPage(),lastRowOnPage:this.isLastRowOnPage(),printLayout:this.printLayout,expandable:this.rowNode.isExpandable(),scope:this.scope,pinned:t};return this.beans.rowCssClassCalculator.getInitialRowClasses(a)},t.prototype.processStylesFromGridOptions=function(){var e=this.beans.gridOptionsWrapper.getRowStyle();if(!e||"function"!=typeof e){var t,a=this.beans.gridOptionsWrapper.getRowStyleFunc();if(a)t=a({data:this.rowNode.data,node:this.rowNode,rowIndex:this.rowNode.rowIndex,$scope:this.scope,api:this.beans.gridOptionsWrapper.getApi(),columnApi:this.beans.gridOptionsWrapper.getColumnApi(),context:this.beans.gridOptionsWrapper.getContext()});return Object.assign({},e,t)}console.warn("AG Grid: rowStyle should be an object of key/value styles, not be a function, use getRowStyle() instead")},t.prototype.onRowSelected=function(){var e=this,t=this.rowNode.isSelected();this.allRowGuis.forEach((function(a){a.rowComp.addOrRemoveCssClass("ag-row-selected",t),Object(y.setAriaSelected)(a.element,!!t||void 0);var r=e.createAriaLabel();Object(y.setAriaLabel)(a.element,null==r?"":r)}))},t.prototype.createAriaLabel=function(){var e=this.rowNode.isSelected();if(!e||!this.beans.gridOptionsWrapper.isSuppressRowDeselection())return this.beans.gridOptionsWrapper.getLocaleTextFunc()(e?"ariaRowDeselect":"ariaRowSelect","Press SPACE to "+(e?"deselect":"select")+" this row.")},t.prototype.isUseAnimationFrameForCreate=function(){return this.useAnimationFrameForCreate},t.prototype.addHoverFunctionality=function(e){var t=this;this.active&&(this.addManagedListener(e,"mouseenter",(function(){return t.rowNode.onMouseEnter()})),this.addManagedListener(e,"mouseleave",(function(){return t.rowNode.onMouseLeave()})),this.addManagedListener(this.rowNode,l.b.EVENT_MOUSE_ENTER,(function(){t.beans.gridOptionsWrapper.isSuppressRowHoverHighlight()||e.classList.add("ag-row-hover")})),this.addManagedListener(this.rowNode,l.b.EVENT_MOUSE_LEAVE,(function(){e.classList.remove("ag-row-hover")})))},t.prototype.roundRowTopToBounds=function(e){var t=this.beans.ctrlsService.getGridBodyCtrl().getScrollFeature().getVScrollPosition(),a=this.applyPaginationOffset(t.top,!0)-100,r=this.applyPaginationOffset(t.bottom,!0)+100;return Math.min(Math.max(a,e),r)},t.prototype.getFrameworkOverrides=function(){return this.beans.frameworkOverrides},t.prototype.onRowHeightChanged=function(){if(null!=this.rowNode.rowHeight){var e=this.beans.gridOptionsWrapper.isGetRowHeightFunction(),t=this.rowNode.rowHeight,a=this.beans.gridOptionsWrapper.getDefaultRowHeight();this.allRowGuis.forEach((function(r){r.element.style.height=t+"px",e&&r.element.style.setProperty("--ag-row-height",Math.min(a,t)-2+"px")}))}},t.prototype.addEventListener=function(t,a){"renderedRowRemoved"!==t&&"rowRemoved"!==t||(t=g.a.EVENT_VIRTUAL_ROW_REMOVED,console.warn("AG Grid: Since version 11, event renderedRowRemoved is now called "+g.a.EVENT_VIRTUAL_ROW_REMOVED)),e.prototype.addEventListener.call(this,t,a)},t.prototype.removeEventListener=function(t,a){"renderedRowRemoved"!==t&&"rowRemoved"!==t||(t=g.a.EVENT_VIRTUAL_ROW_REMOVED,console.warn("AG Grid: Since version 11, event renderedRowRemoved and rowRemoved is now called "+g.a.EVENT_VIRTUAL_ROW_REMOVED)),e.prototype.removeEventListener.call(this,t,a)},t.prototype.destroyFirstPass=function(){this.active=!1,this.setupRemoveAnimation();var t=this.createRowEvent(g.a.EVENT_VIRTUAL_ROW_REMOVED);this.dispatchEvent(t),this.beans.eventService.dispatchEvent(t),e.prototype.destroy.call(this)},t.prototype.setupRemoveAnimation=function(){if(null!=this.rowNode.rowTop){var e=this.roundRowTopToBounds(this.rowNode.rowTop);this.setRowTop(e)}else this.allRowGuis.forEach((function(e){return e.rowComp.addOrRemoveCssClass("ag-opacity-zero",!0)}))},t.prototype.destroySecondPass=function(){this.allRowGuis.length=0;var e=function(e){return e.list.forEach((function(e){return e.destroy()})),{list:[],map:{}}};this.centerCellCtrls=e(this.centerCellCtrls),this.leftCellCtrls=e(this.leftCellCtrls),this.rightCellCtrls=e(this.rightCellCtrls)},t.prototype.setFocusedClasses=function(){var e=this;this.allRowGuis.forEach((function(t){t.rowComp.addOrRemoveCssClass("ag-row-focus",e.rowFocused),t.rowComp.addOrRemoveCssClass("ag-row-no-focus",!e.rowFocused)}))},t.prototype.onCellFocusChanged=function(){var e=this.beans.focusService.isRowFocused(this.rowNode.rowIndex,this.rowNode.rowPinned);e!==this.rowFocused&&(this.rowFocused=e,this.setFocusedClasses()),!e&&this.editingRow&&this.stopEditing(!1)},t.prototype.onPaginationChanged=function(){var e=this.beans.paginationProxy.getCurrentPage();this.paginationPage!==e&&(this.paginationPage=e,this.onTopChanged()),this.refreshFirstAndLastRowStyles()},t.prototype.onTopChanged=function(){this.setRowTop(this.rowNode.rowTop)},t.prototype.onPaginationPixelOffsetChanged=function(){this.onTopChanged()},t.prototype.applyPaginationOffset=function(e,t){return void 0===t&&(t=!1),this.rowNode.isRowPinned()?e:e+this.beans.paginationProxy.getPixelOffset()*(t?1:-1)},t.prototype.setRowTop=function(e){if(!this.printLayout&&Object(h.exists)(e)){var t=this.applyPaginationOffset(e),a=(this.rowNode.isRowPinned()?t:this.beans.rowContainerHeightService.getRealPixelPosition(t))+"px";this.setRowTopStyle(a)}},t.prototype.getInitialRowTop=function(){return this.initialTop},t.prototype.getInitialTransform=function(){return this.initialTransform},t.prototype.setInitialRowTop=function(){if(this.printLayout)return"";var e=this.slideRowIn?this.roundRowTopToBounds(this.rowNode.oldRowTop):this.rowNode.rowTop,t=this.applyPaginationOffset(e),a=(this.rowNode.isRowPinned()?t:this.beans.rowContainerHeightService.getRealPixelPosition(t))+"px";this.beans.gridOptionsWrapper.isSuppressRowTransform()?this.initialTop=a:this.initialTransform="translateY("+a+")"},t.prototype.setRowTopStyle=function(e){var t=this.beans.gridOptionsWrapper.isSuppressRowTransform();this.allRowGuis.forEach((function(a){return t?a.rowComp.setTop(e):a.rowComp.setTransform("translateY("+e+")")}))},t.prototype.getRowNode=function(){return this.rowNode},t.prototype.getCellCtrl=function(e){var t=null;return this.getAllCellCtrls().forEach((function(a){a.getColumn()==e&&(t=a)})),null!=t||this.getAllCellCtrls().forEach((function(a){a.getColSpanningList().indexOf(e)>=0&&(t=a)})),t},t.prototype.onRowIndexChanged=function(){null!=this.rowNode.rowIndex&&(this.onCellFocusChanged(),this.updateRowIndexes(),this.postProcessCss())},t.prototype.updateRowIndexes=function(){var e=this.rowNode.getRowIndexString(),t=this.beans.headerNavigationService.getHeaderRowCount(),a=this.rowNode.rowIndex%2==0,r=t+this.rowNode.rowIndex+1;this.allRowGuis.forEach((function(t){t.rowComp.setRowIndex(e),t.rowComp.addOrRemoveCssClass("ag-row-even",a),t.rowComp.addOrRemoveCssClass("ag-row-odd",!a),Object(y.setAriaRowIndex)(t.element,r)}))},t.prototype.getPinnedLeftRowElement=function(){return this.leftGui?this.leftGui.element:void 0},t.prototype.getPinnedRightRowElement=function(){return this.rightGui?this.rightGui.element:void 0},t.prototype.getBodyRowElement=function(){return this.centerGui?this.centerGui.element:void 0},t.prototype.getFullWidthRowElement=function(){return this.fullWidthGui?this.fullWidthGui.element:void 0},t.DOM_DATA_KEY_ROW_CTRL="renderedRow",t}(i.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return n}));var r=function(e,t){var a="function"==typeof Symbol&&e[Symbol.iterator];if(!a)return e;var r,o,n=a.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(r=n.next()).done;)i.push(r.value)}catch(e){o={error:e}}finally{try{r&&!r.done&&(a=n.return)&&a.call(n)}finally{if(o)throw o.error}}return i},o=function(){for(var e=[],t=0;t=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i};!function(e){e[e.UP=0]="UP",e[e.DOWN=1]="DOWN",e[e.LEFT=2]="LEFT",e[e.RIGHT=3]="RIGHT"}(o||(o={}));var c=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return d(t,e),t.prototype.postConstruct=function(){var e=this;this.ctrlsService.whenReady((function(t){e.gridBodyCon=t.gridBodyCtrl}))},t.prototype.getHeaderRowCount=function(){var e=this.ctrlsService.getHeaderRowContainerCtrl();return e?e.getRowCount():0},t.prototype.getHeaderRowType=function(e){var t=this.ctrlsService.getHeaderRowContainerCtrl();if(t)return t.getRowType(e)},t.prototype.navigateVertically=function(e,t,a){if(t||(t=this.focusService.getFocusedHeader()),!t)return!1;var r=t.headerRowIndex,n=t.column,i=this.getHeaderRowCount(),l=e===o.UP,g=l?r-1:r+1,d=null,s=!1;g<0&&(g=0,d=n,s=!0),g>=i&&(g=-1);var c=this.getHeaderRowType(r);if(!s){if(c===p.b.COLUMN_GROUP){var u=n;d=l?n.getParent():u.getDisplayedChildren()[0]}else if(c===p.b.FLOATING_FILTER)d=n;else{u=n;d=l?u.getParent():u}if(!d)return!1}return this.focusService.focusHeaderPosition({headerPosition:{headerRowIndex:g,column:d},allowUserOverride:!0,event:a})},t.prototype.navigateHorizontally=function(e,t,a){void 0===t&&(t=!1);var r,n,i=this.focusService.getFocusedHeader();return e===o.LEFT!==this.gridOptionsWrapper.isEnableRtl()?(n="Before",r=this.headerPositionUtils.findHeader(i,n)):(n="After",r=this.headerPositionUtils.findHeader(i,n)),r?this.focusService.focusHeaderPosition({headerPosition:r,direction:n,fromTab:t,allowUserOverride:!0,event:a}):!t||this.focusNextHeaderRow(i,n,a)},t.prototype.focusNextHeaderRow=function(e,t,a){var r,o=e.headerRowIndex,n=null;return"Before"===t?o>0&&(r=o-1,n=this.headerPositionUtils.findColAtEdgeForHeaderRow(r,"end")):(r=o+1,n=this.headerPositionUtils.findColAtEdgeForHeaderRow(r,"start")),this.focusService.focusHeaderPosition({headerPosition:n,direction:t,fromTab:!0,allowUserOverride:!0,event:a})},t.prototype.scrollToColumn=function(e,t){if(void 0===t&&(t="After"),!e.getPinned()){var a;if(e instanceof l.a){var r=e.getDisplayedLeafColumns();a="Before"===t?Object(g.last)(r):r[0]}else a=e;this.gridBodyCon.getScrollFeature().ensureColumnVisible(a),this.gridBodyCon.getScrollFeature().horizontallyScrollHeaderCenterAndFloatingCenter(),this.animationFrameService.flushAllFrames()}},s([Object(i.a)("focusService")],t.prototype,"focusService",void 0),s([Object(i.a)("headerPositionUtils")],t.prototype,"headerPositionUtils",void 0),s([Object(i.a)("animationFrameService")],t.prototype,"animationFrameService",void 0),s([Object(i.a)("ctrlsService")],t.prototype,"ctrlsService",void 0),s([i.e],t.prototype,"postConstruct",null),t=s([Object(i.b)("headerNavigationService")],t)}(n.a)},function(e,t,a){"use strict";var r;a.d(t,"a",(function(){return r})),function(e){e.EVERYTHING="group",e.FILTER="filter",e.SORT="sort",e.MAP="map",e.AGGREGATE="aggregate",e.PIVOT="pivot",e.NOTHING="nothing"}(r||(r={}))},function(e,t,a){"use strict";a.d(t,"a",(function(){return l}));var r,o=a(4),n=a(43),i=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),l=function(e){function t(t,a,r){void 0===a&&(a="ag-checkbox"),void 0===r&&(r="checkbox");var o=e.call(this,t,a,r)||this;return o.labelAlignment="right",o.selected=!1,o.readOnly=!1,o.passive=!1,o}return i(t,e),t.prototype.addInputListeners=function(){this.addManagedListener(this.eInput,"click",this.onCheckboxClick.bind(this)),this.addManagedListener(this.eLabel,"click",this.toggle.bind(this))},t.prototype.getNextValue=function(){return void 0===this.selected||!this.selected},t.prototype.setPassive=function(e){this.passive=e},t.prototype.isReadOnly=function(){return this.readOnly},t.prototype.setReadOnly=function(e){this.eWrapper.classList.toggle("ag-disabled",e),this.eInput.disabled=e,this.readOnly=e},t.prototype.setDisabled=function(t){return this.eWrapper.classList.toggle("ag-disabled",t),e.prototype.setDisabled.call(this,t)},t.prototype.toggle=function(){if(!this.eInput.disabled){var e=this.isSelected(),t=this.getNextValue();this.passive?this.dispatchChange(t,e):this.setValue(t)}},t.prototype.getValue=function(){return this.isSelected()},t.prototype.setValue=function(e,t){return this.refreshSelectedClass(e),this.setSelected(e,t),this},t.prototype.setName=function(e){return this.getInputElement().name=e,this},t.prototype.isSelected=function(){return this.selected},t.prototype.setSelected=function(e,t){this.isSelected()!==e&&(this.previousValue=this.isSelected(),e=this.selected="boolean"==typeof e?e:void 0,this.eInput.checked=e,this.eInput.indeterminate=void 0===e,t||this.dispatchChange(this.selected,this.previousValue))},t.prototype.dispatchChange=function(e,a,r){this.dispatchEvent({type:t.EVENT_CHANGED,selected:e,previousValue:a,event:r});var n=this.getInputElement(),i={type:o.a.EVENT_CHECKBOX_CHANGED,id:n.id,name:n.name,selected:e,previousValue:a};this.eventService.dispatchEvent(i)},t.prototype.onCheckboxClick=function(e){if(!this.passive&&!this.eInput.disabled){var t=this.isSelected(),a=this.selected=e.target.checked;this.refreshSelectedClass(a),this.dispatchChange(a,t,e)}},t.prototype.refreshSelectedClass=function(e){this.eWrapper.classList.toggle("ag-checked",!0===e),this.eWrapper.classList.toggle("ag-indeterminate",null==e)},t}(n.a)},function(e,t,a){"use strict";a.r(t),a.d(t,"isEventFromPrintableCharacter",(function(){return n})),a.d(t,"isUserSuppressingKeyboardEvent",(function(){return i})),a.d(t,"isUserSuppressingHeaderKeyboardEvent",(function(){return l}));var r=a(22),o=a(1);function n(e){if(e.altKey||e.ctrlKey||e.metaKey)return!1;var t=1===e.key.length,a=function(e){return Object(r.isBrowserEdge)()&&"Del"===e.key&&46===e.charCode}(e);return t||a}function i(e,t,a,r,o){var n=e.getSuppressKeyboardEventFunc(),i=r?r.getColDef().suppressKeyboardEvent:void 0;if(!n&&!i)return!1;var l={event:t,editing:o,column:r,api:e.getApi(),node:a,data:a.data,colDef:r.getColDef(),context:e.getContext(),columnApi:e.getColumnApi()};if(i&&i(l))return!0;return!!n&&n(l)}function l(e,t,a,r){var n=r.getDefinition(),i=n&&n.suppressHeaderKeyboardEvent;return!!Object(o.exists)(i)&&!!i({api:e.getApi(),columnApi:e.getColumnApi(),context:e.getContext(),colDef:n,column:r,headerRowIndex:a,event:t})}},function(e,t,a){"use strict";function r(e){var t=new Map;return e.forEach((function(e){return t.set(e[0],e[1])})),t}function o(e,t){var a=new Map;return e.forEach((function(e){return a.set(t(e),e)})),a}function n(e){var t=[];return e.forEach((function(e,a){return t.push(a)})),t}a.r(t),a.d(t,"convertToMap",(function(){return r})),a.d(t,"mapById",(function(){return o})),a.d(t,"keys",(function(){return n}))},function(e,t,a){"use strict";a.d(t,"a",(function(){return d}));var r,o=a(6),n=a(0),i=a(50),l=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),g=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},p=0,d=function(e){function t(t,a){var r=e.call(this)||this;return r.lastFocusEvent=null,r.columnGroupChild=t,r.parentRowCtrl=a,r.instanceId=t.getUniqueId()+"-"+p++,r}return l(t,e),t.prototype.shouldStopEventPropagation=function(e){var t=this.focusService.getFocusedHeader(),a=t.headerRowIndex,r=t.column;return Object(i.isUserSuppressingHeaderKeyboardEvent)(this.gridOptionsWrapper,e,a,r)},t.prototype.setGui=function(e){this.eGui=e,this.addDomData()},t.prototype.addDomData=function(){var e=this,a=t.DOM_DATA_KEY_HEADER_CTRL;this.gridOptionsWrapper.setDomData(this.eGui,a,this),this.addDestroyFunc((function(){return e.gridOptionsWrapper.setDomData(e.eGui,a,null)}))},t.prototype.getGui=function(){return this.eGui},t.prototype.focus=function(e){return!!this.eGui&&(this.lastFocusEvent=e||null,this.eGui.focus(),!0)},t.prototype.getRowIndex=function(){return this.parentRowCtrl.getRowIndex()},t.prototype.getParentRowCtrl=function(){return this.parentRowCtrl},t.prototype.getPinned=function(){return this.parentRowCtrl.getPinned()},t.prototype.getInstanceId=function(){return this.instanceId},t.prototype.getColumnGroupChild=function(){return this.columnGroupChild},t.DOM_DATA_KEY_HEADER_CTRL="headerCtrl",g([Object(n.a)("focusService")],t.prototype,"focusService",void 0),t}(o.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return s}));var r,o=a(13),n=a(5),i=a(132),l=a(11),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),p=function(e,t){var a="function"==typeof Symbol&&e[Symbol.iterator];if(!a)return e;var r,o,n=a.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(r=n.next()).done;)i.push(r.value)}catch(e){o={error:e}}finally{try{r&&!r.done&&(a=n.return)&&a.call(n)}finally{if(o)throw o.error}}return i},d=function(){for(var e=[],t=0;t=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},m=function(e,t){var a="function"==typeof Symbol&&e[Symbol.iterator];if(!a)return e;var r,o,n=a.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(r=n.next()).done;)i.push(r.value)}catch(e){o={error:e}}finally{try{r&&!r.done&&(a=n.return)&&a.call(n)}finally{if(o)throw o.error}}return i},b=function(){for(var e=[],t=0;t0?-1===r.indexOf(t)&&r.push(t):(a.instancesMonitored.set(e,[t]),e.addEventListener("keydown",a.toggleKeyboardMode),e.addEventListener("mousedown",a.toggleKeyboardMode))},t.removeKeyboardModeEvents=function(e,t){var r=a.instancesMonitored.get(e),o=[];r&&r.length&&(o=b(r).filter((function(e){return e!==t})),a.instancesMonitored.set(e,o)),0===o.length&&(e.removeEventListener("keydown",a.toggleKeyboardMode),e.removeEventListener("mousedown",a.toggleKeyboardMode))},t.toggleKeyboardMode=function(e){var t=a.keyboardModeActive,r="keydown"===e.type;if(!(r&&(e.ctrlKey||e.metaKey||e.altKey)||t&&r||!t&&!r)){a.keyboardModeActive=r;var o=e.target.ownerDocument;if(o){var n=a.instancesMonitored.get(o);n&&n.forEach((function(e){e.dispatchEvent({type:r?i.a.EVENT_KEYBOARD_FOCUS:i.a.EVENT_MOUSE_FOCUS})}))}}},t.prototype.init=function(){var e=this,t=this.clearFocusedCell.bind(this);this.addManagedListener(this.eventService,i.a.EVENT_COLUMN_PIVOT_MODE_CHANGED,t),this.addManagedListener(this.eventService,i.a.EVENT_NEW_COLUMNS_LOADED,this.onColumnEverythingChanged.bind(this)),this.addManagedListener(this.eventService,i.a.EVENT_COLUMN_GROUP_OPENED,t),this.addManagedListener(this.eventService,i.a.EVENT_COLUMN_ROW_GROUP_CHANGED,t),this.ctrlsService.whenReady((function(t){e.gridCtrl=t.gridCtrl;var r=e.gridOptionsWrapper.getDocument();a.addKeyboardModeEvents(r,e.gridCtrl),e.addDestroyFunc((function(){return e.unregisterGridCompController(e.gridCtrl)}))}))},t.prototype.unregisterGridCompController=function(e){var t=this.gridOptionsWrapper.getDocument();a.removeKeyboardModeEvents(t,e)},t.prototype.onColumnEverythingChanged=function(){if(this.focusedCellPosition){var e=this.focusedCellPosition.column,t=this.columnModel.getGridColumn(e.getId());e!==t&&this.clearFocusedCell()}},t.prototype.isKeyboardMode=function(){return a.keyboardModeActive},t.prototype.getFocusCellToUseAfterRefresh=function(){var e=this.gridOptionsWrapper.getDocument();return this.gridOptionsWrapper.isSuppressFocusAfterRefresh()||!this.focusedCellPosition||this.isDomDataMissingInHierarchy(e.activeElement,s.a.DOM_DATA_KEY_ROW_CTRL)?null:this.focusedCellPosition},t.prototype.getFocusHeaderToUseAfterRefresh=function(){var e=this.gridOptionsWrapper.getDocument();return this.gridOptionsWrapper.isSuppressFocusAfterRefresh()||!this.focusedHeaderPosition||this.isDomDataMissingInHierarchy(e.activeElement,c.a.DOM_DATA_KEY_HEADER_CTRL)?null:this.focusedHeaderPosition},t.prototype.isDomDataMissingInHierarchy=function(e,t){for(var a=e;a;){if(this.gridOptionsWrapper.getDomData(a,t))return!1;a=a.parentNode}return!0},t.prototype.clearFocusedCell=function(){this.focusedCellPosition=null,this.onCellFocused(!1)},t.prototype.getFocusedCell=function(){return this.focusedCellPosition},t.prototype.setFocusedCell=function(e,t,a,r){void 0===r&&(r=!1);var o=this.columnModel.getGridColumn(t);o?(this.focusedCellPosition=o?{rowIndex:e,rowPinned:Object(p.makeNull)(a),column:o}:null,this.onCellFocused(r)):this.focusedCellPosition=null},t.prototype.isCellFocused=function(e){return null!=this.focusedCellPosition&&(this.focusedCellPosition.column===e.column&&this.isRowFocused(e.rowIndex,e.rowPinned))},t.prototype.isRowNodeFocused=function(e){return this.isRowFocused(e.rowIndex,e.rowPinned)},t.prototype.isHeaderWrapperFocused=function(e){if(null==this.focusedHeaderPosition)return!1;var t=e.getColumnGroupChild(),a=e.getRowIndex(),r=e.getPinned(),o=this.focusedHeaderPosition,n=o.column,i=o.headerRowIndex;return t===n&&a===i&&r==n.getPinned()},t.prototype.clearFocusedHeader=function(){this.focusedHeaderPosition=null},t.prototype.getFocusedHeader=function(){return this.focusedHeaderPosition},t.prototype.setFocusedHeader=function(e,t){this.focusedHeaderPosition={headerRowIndex:e,column:t}},t.prototype.focusHeaderPosition=function(e){var t=e.direction,a=e.fromTab,r=e.allowUserOverride,o=e.event,n=e.headerPosition;if(r){var i,l=this.gridOptionsWrapper,g=this.getFocusedHeader(),p=this.headerNavigationService.getHeaderRowCount();if(a){if(i=l.getTabToNextHeaderFunc())n=i({backwards:"Before"===t,previousHeaderPosition:g,nextHeaderPosition:n,headerRowCount:p,api:l.getApi(),columnApi:l.getColumnApi()})}else if((i=l.getNavigateToNextHeaderFunc())&&o)n=i({key:o.key,previousHeaderPosition:g,nextHeaderPosition:n,headerRowCount:p,event:o,api:l.getApi(),columnApi:l.getColumnApi()})}return!!n&&(-1===n.headerRowIndex?this.focusGridView(n.column):(this.headerNavigationService.scrollToColumn(n.column,t),this.ctrlsService.getHeaderRowContainerCtrl(n.column.getPinned()).focusHeader(n.headerRowIndex,n.column,o)))},t.prototype.focusFirstHeader=function(){var e=this.columnModel.getAllDisplayedColumns()[0];return!!e&&(e.getParent()&&(e=this.columnModel.getColumnGroupAtLevel(e,0)),this.focusHeaderPosition({headerPosition:{headerRowIndex:0,column:e}}))},t.prototype.focusLastHeader=function(e){var t=this.headerNavigationService.getHeaderRowCount()-1,a=Object(u.last)(this.columnModel.getAllDisplayedColumns());return this.focusHeaderPosition({headerPosition:{headerRowIndex:t,column:a},event:e})},t.prototype.isAnyCellFocused=function(){return!!this.focusedCellPosition},t.prototype.isRowFocused=function(e,t){return null!=this.focusedCellPosition&&(this.focusedCellPosition.rowIndex===e&&this.focusedCellPosition.rowPinned===Object(p.makeNull)(t))},t.prototype.findFocusableElements=function(e,t,a){void 0===a&&(a=!1);var r=d.a.FOCUSABLE_SELECTOR,o=d.a.FOCUSABLE_EXCLUDE;t&&(o+=", "+t),a&&(o+=', [tabindex="-1"]');var n=Array.prototype.slice.apply(e.querySelectorAll(r)),i=Array.prototype.slice.apply(e.querySelectorAll(o));if(!i.length)return n;var l;return l=i,n.filter((function(e){return-1===l.indexOf(e)}))},t.prototype.focusInto=function(e,t,a){void 0===t&&(t=!1),void 0===a&&(a=!1);var r=this.findFocusableElements(e,null,a),o=t?Object(u.last)(r):r[0];return!!o&&(o.focus(),!0)},t.prototype.findNextFocusableElement=function(e,t,a){void 0===e&&(e=this.eGridDiv);var r=this.findFocusableElements(e,t?':not([tabindex="-1"])':null),o=this.gridOptionsWrapper.getDocument().activeElement,n=(t?r.findIndex((function(e){return e.contains(o)})):r.indexOf(o))+(a?-1:1);return n<0||n>=r.length?null:r[n]},t.prototype.isFocusUnderManagedComponent=function(e){var t=this.gridOptionsWrapper.getDocument(),a=e.querySelectorAll("."+l.a.FOCUS_MANAGED_CLASS);if(!a.length)return!1;for(var r=0;r=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},f=function(e){function t(t){var a=e.call(this)||this;return a.scrollLeft=-1,a.nextScrollTop=-1,a.scrollTop=-1,a.eBodyViewport=t,a.resetLastHorizontalScrollElementDebounced=Object(s.debounce)(a.resetLastHorizontalScrollElement.bind(a),500),a}return u(t,e),t.prototype.postConstruct=function(){var e=this;this.enableRtl=this.gridOptionsWrapper.isEnableRtl(),this.addManagedListener(this.eventService,p.a.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED,this.onDisplayedColumnsWidthChanged.bind(this)),this.ctrlsService.whenReady((function(t){e.centerRowContainerCon=t.centerRowContainerCtrl,e.onDisplayedColumnsWidthChanged(),e.addScrollListener()}))},t.prototype.addScrollListener=function(){var e=this.ctrlsService.getFakeHScrollCtrl();this.addManagedListener(this.centerRowContainerCon.getViewportElement(),"scroll",this.onCenterViewportScroll.bind(this)),this.addManagedListener(e.getViewport(),"scroll",this.onFakeHorizontalScroll.bind(this));var t=this.gridOptionsWrapper.isDebounceVerticalScrollbar()?Object(s.debounce)(this.onVerticalScroll.bind(this),100):this.onVerticalScroll.bind(this);this.addManagedListener(this.eBodyViewport,"scroll",t)},t.prototype.onDisplayedColumnsWidthChanged=function(){this.enableRtl&&this.horizontallyScrollHeaderCenterAndFloatingCenter()},t.prototype.horizontallyScrollHeaderCenterAndFloatingCenter=function(e){if(!(null==this.centerRowContainerCon)){void 0===e&&(e=this.centerRowContainerCon.getCenterViewportScrollLeft());var t=this.enableRtl?e:-e,a=this.ctrlsService.getTopCenterRowContainerCtrl(),r=this.ctrlsService.getBottomCenterRowContainerCtrl(),o=this.ctrlsService.getFakeHScrollCtrl();this.ctrlsService.getHeaderRowContainerCtrl().setHorizontalScroll(t),r.setContainerTranslateX(t),a.setContainerTranslateX(t);var n=this.lastHorizontalScrollElement===this.centerRowContainerCon.getViewportElement()?o.getViewport():this.centerRowContainerCon.getViewportElement();Object(d.setScrollLeft)(n,Math.abs(e),this.enableRtl)}},t.prototype.isControllingScroll=function(e){return this.lastHorizontalScrollElement?e===this.lastHorizontalScrollElement:(this.lastHorizontalScrollElement=e,!0)},t.prototype.onFakeHorizontalScroll=function(){var e=this.ctrlsService.getFakeHScrollCtrl().getViewport();this.isControllingScroll(e)&&this.onBodyHorizontalScroll(e)},t.prototype.onCenterViewportScroll=function(){var e=this.centerRowContainerCon.getViewportElement();this.isControllingScroll(e)&&this.onBodyHorizontalScroll(e)},t.prototype.onBodyHorizontalScroll=function(e){var t=this.centerRowContainerCon.getViewportElement().scrollLeft;this.shouldBlockScrollUpdate("horizontal",t,!0)||(this.doHorizontalScroll(Math.round(Object(d.getScrollLeft)(e,this.enableRtl))),this.resetLastHorizontalScrollElementDebounced())},t.prototype.onVerticalScroll=function(){var e=this.eBodyViewport.scrollTop;this.shouldBlockScrollUpdate("vertical",e,!0)||(this.animationFrameService.setScrollTop(e),this.nextScrollTop=e,this.gridOptionsWrapper.isSuppressAnimationFrame()?(this.scrollTop=this.nextScrollTop,this.redrawRowsAfterScroll()):this.animationFrameService.schedule())},t.prototype.resetLastHorizontalScrollElement=function(){this.lastHorizontalScrollElement=null},t.prototype.doHorizontalScroll=function(e){var t=this.ctrlsService.getFakeHScrollCtrl().getViewport(),a=Object(d.getScrollLeft)(t,this.enableRtl);this.scrollLeft===e&&e===a||(this.scrollLeft=e,this.fireScrollEvent("horizontal"),this.horizontallyScrollHeaderCenterAndFloatingCenter(e),this.onHorizontalViewportChanged())},t.prototype.fireScrollEvent=function(e){var t=this,a={type:p.a.EVENT_BODY_SCROLL,api:this.gridApi,columnApi:this.columnApi,direction:e,left:this.scrollLeft,top:this.scrollTop};this.eventService.dispatchEvent(a),window.clearTimeout(this.scrollTimer),this.scrollTimer=void 0,this.scrollTimer=window.setTimeout((function(){var e=Object.assign({},a,{type:p.a.EVENT_BODY_SCROLL_END});t.eventService.dispatchEvent(e)}),100)},t.prototype.shouldBlockScrollUpdate=function(e,t,a){if(void 0===a&&(a=!1),a&&!Object(c.isIOSUserAgent)())return!1;if("vertical"===e){var r=Object(d.getInnerHeight)(this.eBodyViewport),o=this.eBodyViewport.scrollHeight;if(t<0||t+r>o)return!0}if("horizontal"===e){var n=this.centerRowContainerCon.getCenterWidth(),i=this.centerRowContainerCon.getViewportElement().scrollWidth;if(this.enableRtl&&Object(d.isRtlNegativeScroll)()){if(t>0)return!0}else if(t<0)return!0;if(Math.abs(t)+n>i)return!0}return!1},t.prototype.redrawRowsAfterScroll=function(){this.fireScrollEvent("vertical")},t.prototype.onHorizontalViewportChanged=function(){this.centerRowContainerCon.onHorizontalViewportChanged()},t.prototype.checkScrollLeft=function(){this.scrollLeft!==this.centerRowContainerCon.getCenterViewportScrollLeft()&&this.onBodyHorizontalScroll(this.centerRowContainerCon.getViewportElement())},t.prototype.executeAnimationFrameScroll=function(){var e=this.scrollTop!=this.nextScrollTop;return e&&(this.scrollTop=this.nextScrollTop,this.redrawRowsAfterScroll()),e},t.prototype.setHorizontalScrollPosition=function(e){var t=this.centerRowContainerCon.getViewportElement().scrollWidth-this.centerRowContainerCon.getCenterWidth();this.shouldBlockScrollUpdate("horizontal",e)&&(e=this.enableRtl&&Object(d.isRtlNegativeScroll)()?e>0?0:t:Math.min(Math.max(e,0),t)),Object(d.setScrollLeft)(this.centerRowContainerCon.getViewportElement(),Math.abs(e),this.enableRtl),this.doHorizontalScroll(e)},t.prototype.setVerticalScrollPosition=function(e){this.eBodyViewport.scrollTop=e},t.prototype.getVScrollPosition=function(){return{top:this.eBodyViewport.scrollTop,bottom:this.eBodyViewport.scrollTop+this.eBodyViewport.offsetHeight}},t.prototype.getHScrollPosition=function(){return this.centerRowContainerCon.getHScrollPosition()},t.prototype.isHorizontalScrollShowing=function(){return this.centerRowContainerCon.isHorizontalScrollShowing()},t.prototype.scrollHorizontally=function(e){var t=this.centerRowContainerCon.getViewportElement().scrollLeft;return this.setHorizontalScrollPosition(t+e),this.centerRowContainerCon.getViewportElement().scrollLeft-t},t.prototype.scrollToTop=function(){this.eBodyViewport.scrollTop=0},t.prototype.ensureNodeVisible=function(e,t){void 0===t&&(t=null);for(var a=this.rowModel.getRowCount(),r="function"==typeof e,o=-1,n=0;n=0&&this.ensureIndexVisible(o,t)},t.prototype.ensureIndexVisible=function(e,t){if(this.gridOptionsWrapper.getDomLayout()!==g.a.DOM_LAYOUT_PRINT){var a=this.paginationProxy.getRowCount();if("number"!=typeof e||e<0||e>=a)console.warn("invalid row index for ensureIndexVisible: "+e);else{this.gridOptionsWrapper.isPagination()&&!this.gridOptionsWrapper.isSuppressPaginationPanel()||this.paginationProxy.goToPageWithIndex(e);var r,o=this.paginationProxy.getRow(e);do{var n=o.rowTop,i=o.rowHeight,l=this.paginationProxy.getPixelOffset(),p=o.rowTop-l,d=p+o.rowHeight,s=this.getVScrollPosition(),c=this.heightScaler.getDivStretchOffset(),u=s.top+c,h=s.bottom+c,f=h-u,m=this.heightScaler.getScrollPositionForPixel(p),b=this.heightScaler.getScrollPositionForPixel(d-f),w=Math.min((m+b)/2,p),v=null;"top"===t?v=m:"bottom"===t?v=b:"middle"===t?v=w:u>p?v=m:hi:rn}},t.prototype.getColumnBounds=function(e){var t=this.enableRtl,a=this.columnModel.getBodyContainerWidth(),r=e.getActualWidth(),o=e.getLeft(),n=t?-1:1,i=t?a-o:o;return{colLeft:i,colMiddle:i+r/2*n,colRight:i+r*n}},t.prototype.getViewportBounds=function(){var e=this.centerRowContainerCon.getCenterWidth(),t=this.centerRowContainerCon.getCenterViewportScrollLeft();return{start:t,end:e+t,width:e}},h([Object(i.a)("ctrlsService")],t.prototype,"ctrlsService",void 0),h([Object(i.a)("animationFrameService")],t.prototype,"animationFrameService",void 0),h([Object(i.a)("columnApi")],t.prototype,"columnApi",void 0),h([Object(i.a)("gridApi")],t.prototype,"gridApi",void 0),h([Object(i.a)("paginationProxy")],t.prototype,"paginationProxy",void 0),h([Object(i.a)("rowModel")],t.prototype,"rowModel",void 0),h([Object(i.a)("rowContainerHeightService")],t.prototype,"heightScaler",void 0),h([Object(i.a)("rowRenderer")],t.prototype,"rowRenderer",void 0),h([Object(i.a)("columnModel")],t.prototype,"columnModel",void 0),h([i.e],t.prototype,"postConstruct",null),t}(n.a),m=a(21),b=a(19),w=a(10),v=a(1),x=a(124),y=function(){var e=function(t,a){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(t,a)};return function(t,a){function r(){this.constructor=t}e(t,a),t.prototype=null===a?Object.create(a):(r.prototype=a.prototype,new r)}}(),k=function(){return(k=Object.assign||function(e){for(var t,a=1,r=arguments.length;a=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},O=function(e,t){var a="function"==typeof Symbol&&e[Symbol.iterator];if(!a)return e;var r,o,n=a.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(r=n.next()).done;)i.push(r.value)}catch(e){o={error:e}}finally{try{r&&!r.done&&(a=n.return)&&a.call(n)}finally{if(o)throw o.error}}return i},A=function(){for(var e=[],t=0;tthis.paginationProxy.getCurrentPageHeight()||(n=this.rowModel.getRowIndexAtPixel(o),a=this.rowModel.getRow(n)),t.vDirection){case m.d.Down:r="down";break;case m.d.Up:r="up";break;default:r=null}return{type:e,api:this.gridOptionsWrapper.getApi(),columnApi:this.gridOptionsWrapper.getColumnApi(),event:t.event,node:t.dragItem.rowNode,nodes:t.dragItem.rowNodes,overIndex:n,overNode:a,y:o,vDirection:r}},t.prototype.dispatchGridEvent=function(e,t){var a=this.draggingToRowDragEvent(e,t);this.eventService.dispatchEvent(a)},t.prototype.onDragLeave=function(e){this.dispatchGridEvent(p.a.EVENT_ROW_DRAG_LEAVE,e),this.stopDragging(e),this.gridOptionsWrapper.isRowDragManaged()&&this.clearRowHighlight(),this.isFromThisGrid(e)&&(this.isMultiRowDrag=!1)},t.prototype.onDragStop=function(e){this.dispatchGridEvent(p.a.EVENT_ROW_DRAG_END,e),this.stopDragging(e),!this.gridOptionsWrapper.isRowDragManaged()||!this.gridOptionsWrapper.isSuppressMoveWhenRowDragging()&&this.isFromThisGrid(e)||this.isDropZoneWithinThisGrid(e)||this.moveRowAndClearHighlight(e)},t.prototype.stopDragging=function(e){this.autoScrollService.ensureCleared(),this.getRowNodes(e).forEach((function(e){e.setDragging(!1)}))},C([Object(i.a)("dragAndDropService")],t.prototype,"dragAndDropService",void 0),C([Object(i.a)("rowModel")],t.prototype,"rowModel",void 0),C([Object(i.a)("paginationProxy")],t.prototype,"paginationProxy",void 0),C([Object(i.a)("columnModel")],t.prototype,"columnModel",void 0),C([Object(i.a)("focusService")],t.prototype,"focusService",void 0),C([Object(i.a)("sortController")],t.prototype,"sortController",void 0),C([Object(i.a)("filterManager")],t.prototype,"filterManager",void 0),C([Object(i.a)("selectionService")],t.prototype,"selectionService",void 0),C([Object(i.a)("mouseEventService")],t.prototype,"mouseEventService",void 0),C([Object(i.a)("ctrlsService")],t.prototype,"ctrlsService",void 0),C([Object(i.d)("rangeService")],t.prototype,"rangeService",void 0),C([Object(i.a)("columnApi")],t.prototype,"columnApi",void 0),C([Object(i.a)("gridApi")],t.prototype,"gridApi",void 0),C([i.e],t.prototype,"postConstruct",null),t}(n.a),R=function(){var e=function(t,a){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(t,a)};return function(t,a){function r(){this.constructor=t}e(t,a),t.prototype=null===a?Object.create(a):(r.prototype=a.prototype,new r)}}(),S=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i};!function(e){e.ANIMATION_ON="ag-row-animation",e.ANIMATION_OFF="ag-row-no-animation"}(o||(o={}));var T="ag-selectable",D="ag-force-vertical-scroll",P="ag-column-moving",N=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.angularApplyTriggered=!1,t}return R(t,e),t.prototype.getScrollFeature=function(){return this.bodyScrollFeature},t.prototype.getBodyViewportElement=function(){return this.eBodyViewport},t.prototype.setComp=function(e,t,a,r,o){this.comp=e,this.eGridBody=t,this.eBodyViewport=a,this.eTop=r,this.eBottom=o,this.setCellTextSelection(this.gridOptionsWrapper.isEnableCellTextSelect()),this.createManagedBean(new l.b(this.comp)),this.bodyScrollFeature=this.createManagedBean(new f(this.eBodyViewport)),this.addRowDragListener(),this.setupRowAnimationCssClass(),this.ctrlsService.registerGridBodyCtrl(this),this.addEventListeners(),this.addFocusListeners([r,a,o]),this.onGridColumnsChanged(),this.addBodyViewportListener(),this.setFloatingHeights(),this.disableBrowserDragging(),this.addStopEditingWhenGridLosesFocus(),this.$scope&&this.addAngularApplyCheck()},t.prototype.getComp=function(){return this.comp},t.prototype.addEventListeners=function(){this.addManagedListener(this.eventService,p.a.EVENT_GRID_COLUMNS_CHANGED,this.onGridColumnsChanged.bind(this)),this.addManagedListener(this.eventService,p.a.EVENT_SCROLL_VISIBILITY_CHANGED,this.onScrollVisibilityChanged.bind(this)),this.addManagedListener(this.eventService,p.a.EVENT_PINNED_ROW_DATA_CHANGED,this.setFloatingHeights.bind(this))},t.prototype.addFocusListeners=function(e){var t=this;e.forEach((function(e){t.addManagedListener(e,"focusin",(function(){e.classList.add("ag-has-focus")})),t.addManagedListener(e,"focusout",(function(t){e.contains(t.relatedTarget)||e.classList.remove("ag-has-focus")}))}))},t.prototype.setColumnMovingCss=function(e){this.comp.setColumnMovingCss(e?P:null,e)},t.prototype.setCellTextSelection=function(e){void 0===e&&(e=!1);var t=e?T:null;this.comp.setCellSelectableCss(t,e)},t.prototype.onScrollVisibilityChanged=function(){var e=this.scrollVisibleService.isVerticalScrollShowing();this.setVerticalScrollPaddingVisible(e)},t.prototype.onGridColumnsChanged=function(){var e=this.columnModel.getAllGridColumns();this.comp.setColumnCount(e?e.length:0)},t.prototype.disableBrowserDragging=function(){this.addManagedListener(this.eGridBody,"dragstart",(function(e){if(e.target instanceof HTMLImageElement)return e.preventDefault(),!1}))},t.prototype.addStopEditingWhenGridLosesFocus=function(){var e=this;if(this.gridOptionsWrapper.isStopEditingWhenCellsLoseFocus()){var t=function(t){var r=t.relatedTarget;if(null!==Object(c.getTabIndex)(r)){var o=a.some((function(e){return e.contains(r)}))&&e.mouseEventService.isElementInThisGrid(r);if(!o){var n=e.popupService;o=n.getActivePopups().some((function(e){return e.contains(r)}))||n.isElementWithinCustomPopup(r)}o||e.rowRenderer.stopEditing()}else e.rowRenderer.stopEditing()},a=[this.eBodyViewport,this.eBottom,this.eTop];a.forEach((function(a){return e.addManagedListener(a,"focusout",t)}))}},t.prototype.updateRowCount=function(){var e=this.headerNavigationService.getHeaderRowCount(),t=this.paginationProxy.getType(),a=-1;t===g.a.ROW_MODEL_TYPE_CLIENT_SIDE&&(a=0,this.paginationProxy.forEachNode((function(e){e.group||a++})));var r=-1===a?-1:e+a;this.comp.setRowCount(r)},t.prototype.registerBodyViewportResizeListener=function(e){this.comp.registerBodyViewportResizeListener(e)},t.prototype.setVerticalScrollPaddingVisible=function(e){var t=e?"scroll":"hidden";this.comp.setPinnedTopBottomOverflowY(t)},t.prototype.isVerticalScrollShowing=function(){var e=this.gridOptionsWrapper.isAlwaysShowVerticalScroll(),t=e?D:null;return this.comp.setAlwaysVerticalScrollClass(t,e),e||Object(d.isVerticalScrollShowing)(this.eBodyViewport)},t.prototype.setupRowAnimationCssClass=function(){var e=this,t=function(){var t=e.gridOptionsWrapper.isAnimateRows()&&!e.rowContainerHeightService.isStretching(),a=t?o.ANIMATION_ON:o.ANIMATION_OFF;e.comp.setRowAnimationCssOnBodyViewport(a,t)};t(),this.addManagedListener(this.eventService,p.a.EVENT_HEIGHT_SCALE_CHANGED,t)},t.prototype.getGridBodyElement=function(){return this.eGridBody},t.prototype.addBodyViewportListener=function(){var e=this;this.addManagedListener(this.eBodyViewport,"contextmenu",(function(t){e.gridOptionsWrapper.isPreventDefaultOnContextMenu()&&t.preventDefault();var a=t.target;a!==e.eBodyViewport&&a!==e.ctrlsService.getCenterRowContainerCtrl().getViewportElement()||e.contextMenuFactory&&e.contextMenuFactory.onContextMenu(t,null,null,null,null,e.eGridBody)})),this.addManagedListener(this.eBodyViewport,"wheel",this.onWheel.bind(this))},t.prototype.onWheel=function(e){this.gridOptionsWrapper.isSuppressScrollWhenPopupsAreOpen()&&this.popupService.hasAnchoredPopup()&&e.preventDefault()},t.prototype.getGui=function(){return this.eGridBody},t.prototype.scrollVertically=function(e){var t=this.eBodyViewport.scrollTop;return this.bodyScrollFeature.setVerticalScrollPosition(t+e),this.eBodyViewport.scrollTop-t},t.prototype.addRowDragListener=function(){this.rowDragFeature=this.createManagedBean(new E(this.eBodyViewport)),this.dragAndDropService.addDropTarget(this.rowDragFeature)},t.prototype.getRowDragFeature=function(){return this.rowDragFeature},t.prototype.setFloatingHeights=function(){var e=this.pinnedRowModel,t=e.getPinnedTopTotalHeight();t&&(t+=1);var a=e.getPinnedBottomTotalHeight();a&&(a+=1),this.comp.setTopHeight(t),this.comp.setBottomHeight(a),this.comp.setTopDisplay(t?"inherit":"none"),this.comp.setBottomDisplay(a?"inherit":"none")},t.prototype.sizeColumnsToFit=function(e){var t=this,a=this.isVerticalScrollShowing()?this.gridOptionsWrapper.getScrollbarWidth():0,r=Object(d.getInnerWidth)(this.eBodyViewport)-a;r>0?this.columnModel.sizeColumnsToFit(r,"sizeColumnsToFit"):void 0===e?window.setTimeout((function(){t.sizeColumnsToFit(100)}),0):100===e?window.setTimeout((function(){t.sizeColumnsToFit(500)}),100):500===e?window.setTimeout((function(){t.sizeColumnsToFit(-1)}),500):console.warn("AG Grid: tried to call sizeColumnsToFit() but the grid is coming back with zero width, maybe the grid is not visible yet on the screen?")},t.prototype.addScrollEventListener=function(e){this.eBodyViewport.addEventListener("scroll",e)},t.prototype.removeScrollEventListener=function(e){this.eBodyViewport.removeEventListener("scroll",e)},t.prototype.requestAngularApply=function(){var e=this;this.angularApplyTriggered||(this.angularApplyTriggered=!0,window.setTimeout((function(){e.angularApplyTriggered=!1,e.$scope.$apply()}),0))},t.prototype.addAngularApplyCheck=function(){var e=this;this.addManagedListener(this.eventService,p.a.EVENT_DISPLAYED_COLUMNS_CHANGED,(function(){return e.requestAngularApply()})),this.addManagedListener(this.eventService,p.a.EVENT_VIRTUAL_COLUMNS_CHANGED,(function(){return e.requestAngularApply()}))},S([Object(i.a)("rowContainerHeightService")],t.prototype,"rowContainerHeightService",void 0),S([Object(i.a)("ctrlsService")],t.prototype,"ctrlsService",void 0),S([Object(i.a)("columnModel")],t.prototype,"columnModel",void 0),S([Object(i.a)("scrollVisibleService")],t.prototype,"scrollVisibleService",void 0),S([Object(i.d)("contextMenuFactory")],t.prototype,"contextMenuFactory",void 0),S([Object(i.a)("headerNavigationService")],t.prototype,"headerNavigationService",void 0),S([Object(i.a)("paginationProxy")],t.prototype,"paginationProxy",void 0),S([Object(i.a)("dragAndDropService")],t.prototype,"dragAndDropService",void 0),S([Object(i.a)("pinnedRowModel")],t.prototype,"pinnedRowModel",void 0),S([Object(i.a)("rowRenderer")],t.prototype,"rowRenderer",void 0),S([Object(i.a)("popupService")],t.prototype,"popupService",void 0),S([Object(i.a)("mouseEventService")],t.prototype,"mouseEventService",void 0),S([Object(i.a)("$scope")],t.prototype,"$scope",void 0),t}(n.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return u}));var r,o=a(0),n=a(5),i=a(15),l={applyFilter:"Apply",clearFilter:"Clear",resetFilter:"Reset",cancelFilter:"Cancel",textFilter:"Text Filter",numberFilter:"Number Filter",dateFilter:"Date Filter",setFilter:"Set Filter",filterOoo:"Filter...",empty:"Choose One",equals:"Equals",notEqual:"Not equal",lessThan:"Less than",greaterThan:"Greater than",inRange:"In range",inRangeStart:"From",inRangeEnd:"To",lessThanOrEqual:"Less than or equals",greaterThanOrEqual:"Greater than or equals",contains:"Contains",notContains:"Not contains",startsWith:"Starts with",endsWith:"Ends with",blank:"Blank",notBlank:"Not blank",andCondition:"AND",orCondition:"OR",dateFormatOoo:"yyyy-mm-dd"},g=a(35),p=a(78),d=a(13),s=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),c=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},u=function(e){function t(t){var a=e.call(this)||this;return a.filterNameKey=t,a.applyActive=!1,a.hidePopup=null,a.appliedModel=null,a}return s(t,e),t.prototype.postConstruct=function(){this.resetTemplate(),this.createManagedBean(new g.a(this.getFocusableElement(),{handleKeyDown:this.handleKeyDown.bind(this)}))},t.prototype.handleKeyDown=function(e){},t.prototype.getFilterTitle=function(){return this.translate(this.filterNameKey)},t.prototype.isFilterActive=function(){return!!this.appliedModel},t.prototype.resetTemplate=function(e){var t='\n
\n
\n '+this.createBodyTemplate()+"\n
\n
";this.setTemplate(t,e)},t.prototype.isReadOnly=function(){return!!this.providedFilterParams.readOnly},t.prototype.init=function(e){var t=this;this.setParams(e),this.resetUiToDefaults(!0).then((function(){t.updateUiVisibility(),t.setupOnBtApplyDebounce()}))},t.prototype.setParams=function(e){this.providedFilterParams=e,this.applyActive=t.isUseApplyButton(e),this.createButtonPanel()},t.prototype.createButtonPanel=function(){var e=this,t=this.providedFilterParams.buttons;if(!(!t||t.length<1||this.isReadOnly())){var a=document.createElement("div");a.classList.add("ag-filter-apply-panel");Object(p.convertToSet)(t).forEach((function(t){return function(t){var r,o;switch(t){case"apply":r=e.translate("applyFilter"),o=function(t){return e.onBtApply(!1,!1,t)};break;case"clear":r=e.translate("clearFilter"),o=function(){return e.onBtClear()};break;case"reset":r=e.translate("resetFilter"),o=function(){return e.onBtReset()};break;case"cancel":r=e.translate("cancelFilter"),o=function(t){e.onBtCancel(t)};break;default:return void console.warn("AG Grid: Unknown button type specified")}var i=Object(n.loadTemplate)(''+r+"\n ");a.appendChild(i),e.addManagedListener(i,"click",o)}(t)})),this.getGui().appendChild(a)}},t.prototype.getDefaultDebounceMs=function(){return 0},t.prototype.setupOnBtApplyDebounce=function(){var e=t.getDebounceMs(this.providedFilterParams,this.getDefaultDebounceMs());this.onBtApplyDebounce=Object(i.debounce)(this.onBtApply.bind(this),e)},t.prototype.getModel=function(){return this.appliedModel?this.appliedModel:null},t.prototype.setModel=function(e){var t=this;return(null!=e?this.setModelIntoUi(e):this.resetUiToDefaults()).then((function(){t.updateUiVisibility(),t.applyModel()}))},t.prototype.onBtCancel=function(e){var t=this,a=this.getModel(),r=function(){t.onUiChanged(!1,"prevent"),t.providedFilterParams.closeOnApply&&t.close(e)};null!=a?this.setModelIntoUi(a).then(r):this.resetUiToDefaults().then(r)},t.prototype.onBtClear=function(){var e=this;this.resetUiToDefaults().then((function(){return e.onUiChanged()}))},t.prototype.onBtReset=function(){this.onBtClear(),this.onBtApply()},t.prototype.applyModel=function(){var e=this.getModelFromUi();if(!this.isModelValid(e))return!1;var t=this.appliedModel;return this.appliedModel=e,!this.areModelsEqual(t,e)},t.prototype.isModelValid=function(e){return!0},t.prototype.onBtApply=function(e,t,a){void 0===e&&(e=!1),void 0===t&&(t=!1),this.applyModel()&&this.providedFilterParams.filterChangedCallback({afterFloatingFilter:e,afterDataChange:t}),this.providedFilterParams.closeOnApply&&this.applyActive&&!e&&!t&&this.close(a)},t.prototype.onNewRowsLoaded=function(){},t.prototype.close=function(e){if(this.hidePopup){var t,a=e,r=a&&a.key;"Enter"!==r&&"Space"!==r||(t={keyboardEvent:a}),this.hidePopup(t),this.hidePopup=null}},t.prototype.onUiChanged=function(e,t){if(void 0===e&&(e=!1),this.updateUiVisibility(),this.providedFilterParams.filterModifiedCallback(),this.applyActive&&!this.isReadOnly){var a=this.isModelValid(this.getModelFromUi());Object(n.setDisabled)(this.getRefElement("applyFilterButton"),!a)}e&&!t||"immediately"===t?this.onBtApply(e):(this.applyActive||t)&&"debounce"!==t||this.onBtApplyDebounce()},t.prototype.afterGuiAttached=function(e){null!=e&&(this.hidePopup=e.hidePopup)},t.getDebounceMs=function(e,a){return t.isUseApplyButton(e)?(null!=e.debounceMs&&console.warn("AG Grid: debounceMs is ignored when apply button is present"),0):null!=e.debounceMs?e.debounceMs:a},t.isUseApplyButton=function(e){return!!e.buttons&&e.buttons.indexOf("apply")>=0},t.prototype.destroy=function(){this.hidePopup=null,e.prototype.destroy.call(this)},t.prototype.translate=function(e){return this.gridOptionsWrapper.getLocaleTextFunc()(e,l[e])},t.prototype.getCellValue=function(e){var t=this.providedFilterParams,a=t.api,r=t.colDef,o=t.column,n=t.columnApi,i=t.context;return this.providedFilterParams.valueGetter({api:a,colDef:r,column:o,columnApi:n,context:i,data:e.data,getValue:function(t){return e.data[t]},node:e})},c([Object(o.a)("rowModel")],t.prototype,"rowModel",void 0),c([Object(o.a)("valueService")],t.prototype,"valueService",void 0),c([o.e],t.prototype,"postConstruct",null),t}(d.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return c}));var r,o,n=a(0),i=a(6),l=a(1),g=a(22),p=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),d=function(){return(d=Object.assign||function(e){for(var t,a=1,r=arguments.length;a=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i};!function(e){e[e.NOTHING=0]="NOTHING",e[e.WAITING_TO_SHOW=1]="WAITING_TO_SHOW",e[e.SHOWING=2]="SHOWING"}(o||(o={}));var c=function(e){function t(t){var a=e.call(this)||this;return a.DEFAULT_SHOW_TOOLTIP_DELAY=2e3,a.DEFAULT_HIDE_TOOLTIP_DELAY=1e4,a.SHOW_QUICK_TOOLTIP_DIFF=1e3,a.FADE_OUT_TOOLTIP_TIMEOUT=1e3,a.state=o.NOTHING,a.tooltipInstanceCount=0,a.tooltipMouseTrack=!1,a.parentComp=t,a}return p(t,e),t.prototype.postConstruct=function(){this.tooltipShowDelay=this.gridOptionsWrapper.getTooltipDelay("show")||this.DEFAULT_SHOW_TOOLTIP_DELAY,this.tooltipHideDelay=this.gridOptionsWrapper.getTooltipDelay("hide")||this.DEFAULT_HIDE_TOOLTIP_DELAY,this.tooltipMouseTrack=this.gridOptionsWrapper.isTooltipMouseTrack();var e=this.parentComp.getGui();this.addManagedListener(e,"mouseenter",this.onMouseEnter.bind(this)),this.addManagedListener(e,"mouseleave",this.onMouseLeave.bind(this)),this.addManagedListener(e,"mousemove",this.onMouseMove.bind(this)),this.addManagedListener(e,"mousedown",this.onMouseDown.bind(this)),this.addManagedListener(e,"keydown",this.onKeyDown.bind(this))},t.prototype.destroy=function(){this.setToDoNothing(),e.prototype.destroy.call(this)},t.prototype.onMouseEnter=function(e){if(!Object(g.isIOSUserAgent)()&&this.state==o.NOTHING){var t=this.isLastTooltipHiddenRecently()?200:this.tooltipShowDelay;this.showTooltipTimeoutId=window.setTimeout(this.showTooltip.bind(this),t),this.lastMouseEvent=e,this.state=o.WAITING_TO_SHOW}},t.prototype.onMouseLeave=function(){this.setToDoNothing()},t.prototype.onKeyDown=function(){this.setToDoNothing()},t.prototype.setToDoNothing=function(){this.state===o.SHOWING&&this.hideTooltip(),this.clearTimeouts(),this.state=o.NOTHING},t.prototype.onMouseMove=function(e){this.lastMouseEvent=e,this.tooltipMouseTrack&&this.state===o.SHOWING&&this.tooltipComp&&this.positionTooltipUnderLastMouseEvent()},t.prototype.onMouseDown=function(){this.setToDoNothing()},t.prototype.hideTooltip=function(){this.tooltipComp&&(this.destroyTooltipComp(),t.lastTooltipHideTime=(new Date).getTime()),this.state=o.NOTHING},t.prototype.destroyTooltipComp=function(){var e=this;this.tooltipComp.getGui().classList.add("ag-tooltip-hiding");var t=this.tooltipPopupDestroyFunc,a=this.tooltipComp;window.setTimeout((function(){t(),e.getContext().destroyBean(a)}),this.FADE_OUT_TOOLTIP_TIMEOUT),this.tooltipPopupDestroyFunc=void 0,this.tooltipComp=void 0},t.prototype.isLastTooltipHiddenRecently=function(){return(new Date).getTime()-t.lastTooltipHideTime=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},s=function(e){function t(){return e.call(this,"textFilter")||this}return g(t,e),t.trimInput=function(e){var t=e&&e.trim();return""===t?e:t},t.prototype.getDefaultDebounceMs=function(){return 500},t.prototype.setParams=function(a){e.prototype.setParams.call(this,a),this.textFilterParams=a,this.matcher=this.getTextMatcher(),this.formatter=this.textFilterParams.textFormatter||(this.textFilterParams.caseSensitive?t.DEFAULT_FORMATTER:t.DEFAULT_LOWERCASE_FORMATTER)},t.prototype.getTextMatcher=function(){var e=this.textFilterParams.textCustomComparator;return e?(l.f.doOnce((function(){return console.warn("AG Grid - textCustomComparator is deprecated, use textMatcher instead.")}),"textCustomComparator.deprecated"),function(t){var a=t.filterOption,r=t.value,o=t.filterText;return e(a,r,o)}):this.textFilterParams.textMatcher||t.DEFAULT_MATCHER},t.prototype.createCondition=function(e){var t=this.getConditionTypes()[e],a={filterType:this.getFilterType(),type:t},r=this.getValues(e);return r.length>0&&(a.filter=r[0]),r.length>1&&(a.filterTo=r[1]),a},t.prototype.getFilterType=function(){return"text"},t.prototype.areSimpleModelsEqual=function(e,t){return e.filter===t.filter&&e.filterTo===t.filterTo&&e.type===t.type},t.prototype.getInputs=function(){return[[this.eValueFrom1,this.eValueTo1],[this.eValueFrom2,this.eValueTo2]]},t.prototype.getValues=function(e){var a=this,r=[];return this.forEachInput((function(o,n,l,g){if(e===l&&n\n \n \n
'},t.prototype.mapValuesFromModel=function(e){var t=e||{},a=t.filter,r=t.filterTo,o=t.type;return[a||null,r||null].slice(0,this.getNumberOfInputs(o))},t.prototype.evaluateNullValue=function(e){var t=[n.b.NOT_EQUAL,n.b.NOT_CONTAINS,n.b.BLANK];return!!e&&t.indexOf(e)>=0},t.prototype.evaluateNonNullValue=function(e,t,a,r){var o=this,i=e.map((function(e){return o.formatter(e)}))||[],l=this.formatter(t),g=this.textFilterParams,d=g.api,s=g.colDef,c=g.column,u=g.columnApi,h=g.context,f=g.textFormatter;if(a.type===n.b.BLANK)return this.isBlank(t);if(a.type===n.b.NOT_BLANK)return!this.isBlank(t);var m={api:d,colDef:s,column:c,columnApi:u,context:h,node:r.node,data:r.data,filterOption:a.type,value:l,textFormatter:f};return i.some((function(e){return o.matcher(p(p({},m),{filterText:e}))}))},t.DEFAULT_FILTER_OPTIONS=[n.b.CONTAINS,n.b.NOT_CONTAINS,n.b.EQUALS,n.b.NOT_EQUAL,n.b.STARTS_WITH,n.b.ENDS_WITH,n.b.BLANK,n.b.NOT_BLANK],t.DEFAULT_FORMATTER=function(e){return e},t.DEFAULT_LOWERCASE_FORMATTER=function(e){return null==e?null:e.toString().toLowerCase()},t.DEFAULT_MATCHER=function(e){var a=e.filterOption,r=e.value,o=e.filterText;if(null==o)return!1;switch(a){case t.CONTAINS:return r.indexOf(o)>=0;case t.NOT_CONTAINS:return r.indexOf(o)<0;case t.EQUALS:return r===o;case t.NOT_EQUAL:return r!=o;case t.STARTS_WITH:return 0===r.indexOf(o);case t.ENDS_WITH:var n=r.lastIndexOf(o);return n>=0&&n===r.length-o.length;default:return!1}},d([Object(o.b)("eValue-index0-1")],t.prototype,"eValueFrom1",void 0),d([Object(o.b)("eValue-index1-1")],t.prototype,"eValueTo1",void 0),d([Object(o.b)("eValue-index0-2")],t.prototype,"eValueFrom2",void 0),d([Object(o.b)("eValue-index1-2")],t.prototype,"eValueTo2",void 0),t}(n.b)},function(e,t,a){"use strict";a.d(t,"a",(function(){return f}));var r,o=a(18),n=a(6),i=a(2),l=a(0),g=a(11),p=a(10),d=a(1),s=a(9),c=a(14),u=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),h=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},f=function(e){function t(t,a,r,o){var n=e.call(this)||this;return n.columnOrGroup=t,n.eCell=a,n.ariaEl=n.eCell.querySelector("[role=columnheader]")||n.eCell,n.colsSpanning=o,n.beans=r,n}return u(t,e),t.prototype.setColsSpanning=function(e){this.colsSpanning=e,this.onLeftChanged()},t.prototype.getColumnOrGroup=function(){return this.beans.gridOptionsWrapper.isEnableRtl()&&this.colsSpanning?Object(p.last)(this.colsSpanning):this.columnOrGroup},t.prototype.postConstruct=function(){this.addManagedListener(this.columnOrGroup,o.a.EVENT_LEFT_CHANGED,this.onLeftChanged.bind(this)),this.setLeftFirstTime(),this.addManagedListener(this.eventService,s.a.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED,this.onLeftChanged.bind(this)),this.addManagedListener(this.beans.gridOptionsWrapper,c.a.PROP_DOM_LAYOUT,this.onLeftChanged.bind(this))},t.prototype.setLeftFirstTime=function(){var e=this.beans.gridOptionsWrapper.isSuppressColumnMoveAnimation(),t=Object(d.exists)(this.columnOrGroup.getOldLeft());this.beans.columnAnimationService.isActive()&&t&&!e?this.animateInLeft():this.onLeftChanged()},t.prototype.animateInLeft=function(){var e=this,t=this.getColumnOrGroup(),a=t.getLeft(),r=t.getOldLeft(),o=this.modifyLeftForPrintLayout(t,r),n=this.modifyLeftForPrintLayout(t,a);this.setLeft(o),this.actualLeft=n,this.beans.columnAnimationService.executeNextVMTurn((function(){e.actualLeft===n&&e.setLeft(n)}))},t.prototype.onLeftChanged=function(){var e=this.getColumnOrGroup(),t=e.getLeft();this.actualLeft=this.modifyLeftForPrintLayout(e,t),this.setLeft(this.actualLeft)},t.prototype.modifyLeftForPrintLayout=function(e,t){if(!(this.beans.gridOptionsWrapper.getDomLayout()===i.a.DOM_LAYOUT_PRINT))return t;if(e.getPinned()===i.a.PINNED_LEFT)return t;var a=this.beans.columnModel.getDisplayedColumnsLeftWidth();return e.getPinned()===i.a.PINNED_RIGHT?a+this.beans.columnModel.getBodyContainerWidth()+t:a+t},t.prototype.setLeft=function(e){var t;if(Object(d.exists)(e)&&(this.eCell.style.left=e+"px"),this.columnOrGroup instanceof o.a)t=this.columnOrGroup;else{var a=this.columnOrGroup.getLeafColumns();if(!a.length)return;a.length>1&&Object(g.setAriaColSpan)(this.ariaEl,a.length),t=a[0]}var r=this.beans.columnModel.getAriaColumnIndex(t);Object(g.setAriaColIndex)(this.ariaEl,r)},h([l.e],t.prototype,"postConstruct",null),t}(n.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return f}));var r,o=a(0),n=a(168),i=a(169),l=a(13),g=a(8),p=a(20),d=a(5),s=a(58),c=a(11),u=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),h=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},f=function(e){function t(t){var a=e.call(this)||this;return a.params=t,a.isActive=!1,a.subMenuIsOpen=!1,a.setTemplate('
'),a}return u(t,e),t.prototype.init=function(){var e=this;this.addIcon(),this.addName(),this.addShortcut(),this.addSubMenu(),this.addTooltip();var t=this.getGui();this.params.disabled?(this.addCssClass(this.getClassName("disabled")),Object(c.setAriaDisabled)(t,!0)):(this.addGuiEventListener("click",(function(t){return e.onItemSelected(t)})),this.addGuiEventListener("keydown",(function(t){t.key!==g.a.ENTER&&t.key!==g.a.SPACE||(t.preventDefault(),e.onItemSelected(t))})),this.addGuiEventListener("mousedown",(function(e){e.stopPropagation(),e.preventDefault()})),this.addGuiEventListener("mouseenter",(function(){return e.onMouseEnter()})),this.addGuiEventListener("mouseleave",(function(){return e.onMouseLeave()}))),this.params.cssClasses&&this.params.cssClasses.forEach((function(t){return e.addCssClass(t)}))},t.prototype.isDisabled=function(){return!!this.params.disabled},t.prototype.openSubMenu=function(e){var a=this;if(void 0===e&&(e=!1),this.closeSubMenu(),this.params.subMenu){var r,o=Object(d.loadTemplate)('');if(this.params.subMenu instanceof Array){var l=Object(c.getAriaLevel)(this.getGui()),g=isNaN(l)?1:l+1,p=this.createBean(new n.a(g));p.setParentComponent(this),p.addMenuItems(this.params.subMenu),o.appendChild(p.getGui()),this.addManagedListener(p,t.EVENT_MENU_ITEM_SELECTED,(function(e){return a.dispatchEvent(e)})),p.addGuiEventListener("mouseenter",(function(){return a.cancelDeactivate()})),r=function(){return a.destroyBean(p)},e&&setTimeout((function(){return p.activateFirstItem()}),0)}else{var s=this.params.subMenu,u=this.createBean(new i.a(s));u.setParentComponent(this);var h=u.getGui(),f=function(){return a.cancelDeactivate()};h.addEventListener("mouseenter",f),r=function(){return h.removeEventListener("mouseenter",f)},o.appendChild(h),s.afterGuiAttached&&setTimeout((function(){return s.afterGuiAttached()}),0)}var m=this.getGui(),b=this.popupService.positionPopupForMenu.bind(this.popupService,{eventSource:m,ePopup:o}),w=this.gridOptionsWrapper.getLocaleTextFunc(),v=this.popupService.addPopup({modal:!0,eChild:o,positionCallback:b,anchorToElement:m,ariaLabel:w("ariaLabelSubMenu","SubMenu")});this.subMenuIsOpen=!0,Object(c.setAriaExpanded)(m,!0),this.hideSubMenu=function(){v&&v.hideFunc(),a.subMenuIsOpen=!1,Object(c.setAriaExpanded)(m,!1),r()}}},t.prototype.closeSubMenu=function(){this.hideSubMenu&&(this.hideSubMenu(),this.hideSubMenu=null,Object(c.setAriaExpanded)(this.getGui(),!1))},t.prototype.isSubMenuOpen=function(){return this.subMenuIsOpen},t.prototype.activate=function(e){var t=this;this.cancelActivate(),this.params.disabled||(this.isActive=!0,this.addCssClass(this.getClassName("active")),this.getGui().focus(),e&&this.params.subMenu&&window.setTimeout((function(){t.isAlive()&&t.isActive&&t.openSubMenu()}),300),this.onItemActivated())},t.prototype.deactivate=function(){this.cancelDeactivate(),this.removeCssClass(this.getClassName("active")),this.isActive=!1,this.subMenuIsOpen&&this.hideSubMenu()},t.prototype.addIcon=function(){if(this.params.checked||this.params.icon||!this.params.isCompact){var e=Object(d.loadTemplate)('');this.params.checked?e.appendChild(Object(p.createIconNoSpan)("check",this.gridOptionsWrapper)):this.params.icon&&(Object(d.isNodeOrElement)(this.params.icon)?e.appendChild(this.params.icon):"string"==typeof this.params.icon?e.innerHTML=this.params.icon:console.warn("AG Grid: menu item icon must be DOM node or string")),this.getGui().appendChild(e)}},t.prototype.addName=function(){if(this.params.name||!this.params.isCompact){var e=Object(d.loadTemplate)(''+(this.params.name||"")+"");this.getGui().appendChild(e)}},t.prototype.addTooltip=function(){this.params.tooltip&&(this.tooltip=this.params.tooltip,this.gridOptionsWrapper.isEnableBrowserTooltips()?this.getGui().setAttribute("title",this.tooltip):this.createManagedBean(new s.a(this)))},t.prototype.getTooltipParams=function(){return{location:"menu",value:this.tooltip}},t.prototype.addShortcut=function(){if(this.params.shortcut||!this.params.isCompact){var e=Object(d.loadTemplate)(''+(this.params.shortcut||"")+"");this.getGui().appendChild(e)}},t.prototype.addSubMenu=function(){if(this.params.subMenu||!this.params.isCompact){var e=Object(d.loadTemplate)(''),t=this.getGui();if(this.params.subMenu){var a=this.gridOptionsWrapper.isEnableRtl()?"smallLeft":"smallRight";Object(c.setAriaExpanded)(t,!1),e.appendChild(Object(p.createIconNoSpan)(a,this.gridOptionsWrapper))}t.appendChild(e)}},t.prototype.onItemSelected=function(e){if(this.params.action?this.params.action():this.openSubMenu(e&&"keydown"===e.type),!this.params.subMenu||this.params.action){var a={type:t.EVENT_MENU_ITEM_SELECTED,action:this.params.action,checked:this.params.checked,cssClasses:this.params.cssClasses,disabled:this.params.disabled,icon:this.params.icon,name:this.params.name,shortcut:this.params.shortcut,subMenu:this.params.subMenu,tooltip:this.params.tooltip,event:e};this.dispatchEvent(a)}},t.prototype.onItemActivated=function(){var e={type:t.EVENT_MENU_ITEM_ACTIVATED,menuItem:this};this.dispatchEvent(e)},t.prototype.cancelActivate=function(){this.activateTimeoutId&&(window.clearTimeout(this.activateTimeoutId),this.activateTimeoutId=0)},t.prototype.cancelDeactivate=function(){this.deactivateTimeoutId&&(window.clearTimeout(this.deactivateTimeoutId),this.deactivateTimeoutId=0)},t.prototype.onMouseEnter=function(){var e=this;this.cancelDeactivate(),this.params.isAnotherSubMenuOpen()?this.activateTimeoutId=window.setTimeout((function(){return e.activate(!0)}),t.ACTIVATION_DELAY):this.activate(!0)},t.prototype.onMouseLeave=function(){var e=this;this.cancelActivate(),this.isSubMenuOpen()?this.deactivateTimeoutId=window.setTimeout((function(){return e.deactivate()}),t.ACTIVATION_DELAY):this.deactivate()},t.prototype.getClassName=function(e){var t=this.params.isCompact?"ag-compact-menu-option":"ag-menu-option";return e?t+"-"+e:t},t.EVENT_MENU_ITEM_SELECTED="menuItemSelected",t.EVENT_MENU_ITEM_ACTIVATED="menuItemActivated",t.ACTIVATION_DELAY=80,h([Object(o.a)("popupService")],t.prototype,"popupService",void 0),h([o.e],t.prototype,"init",null),t}(l.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return s}));var r,o=a(46),n=a(7),i=a(1),l=a(22),g=a(8),p=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),d=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},s=function(e){function t(){return e.call(this,t.TEMPLATE)||this}return p(t,e),t.prototype.init=function(e){this.params=e;var t,a=this.eInput;e.cellStartedEdit?(this.focusAfterAttached=!0,e.eventKey===g.a.BACKSPACE||e.eventKey===g.a.DELETE?t="":e.charPress?t=e.charPress:(t=this.getStartValue(e),e.eventKey!==g.a.F2&&(this.highlightAllOnFocus=!0))):(this.focusAfterAttached=!1,t=this.getStartValue(e)),null!=t&&a.setValue(t,!0),this.addManagedListener(a.getGui(),"keydown",(function(e){var t=e.key;t!==g.a.PAGE_UP&&t!==g.a.PAGE_DOWN||e.preventDefault()}))},t.prototype.afterGuiAttached=function(){var e=this.gridOptionsWrapper.getLocaleTextFunc(),t=this.eInput;if(t.setInputAriaLabel(e("ariaInputEditor","Input Editor")),this.focusAfterAttached){Object(l.isBrowserSafari)()||t.getFocusableElement().focus();var a=t.getInputElement();if(this.highlightAllOnFocus)a.select();else{var r=t.getValue(),o=Object(i.exists)(r)&&r.length||0;o&&a.setSelectionRange(o,o)}}},t.prototype.focusIn=function(){var e=this.eInput,t=e.getFocusableElement(),a=e.getInputElement();t.focus(),a.select()},t.prototype.getValue=function(){var e=this.eInput;return this.params.parseValue(e.getValue())},t.prototype.getStartValue=function(e){return e.useFormatter||e.column.getColDef().refData?e.formatValue(e.value):e.value},t.prototype.isPopup=function(){return!1},t.TEMPLATE='
',d([Object(n.b)("eInput")],t.prototype,"eInput",void 0),t}(o.a)},function(e,t,a){"use strict";a.d(t,"b",(function(){return p})),a.d(t,"a",(function(){return d}));var r,o=a(0),n=a(6),i=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),l=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},g=function(e,t){return function(a,r){t(a,r,e)}},p=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return i(t,e),t.prototype.setBeans=function(e){this.logging=e.isDebug()},t.prototype.create=function(e){return new d(e,this.isLogging.bind(this))},t.prototype.isLogging=function(){return this.logging},l([g(0,Object(o.h)("gridOptionsWrapper"))],t.prototype,"setBeans",null),t=l([Object(o.b)("loggerFactory")],t)}(n.a),d=function(){function e(e,t){this.name=e,this.isLoggingFunc=t}return e.prototype.isLogging=function(){return this.isLoggingFunc()},e.prototype.log=function(e){this.isLoggingFunc()&&console.log("AG Grid."+this.name+": "+e)},e}()},function(e,t,a){"use strict";a.d(t,"a",(function(){return h}));var r,o=a(13),n=a(0),i=a(19),l=a(21),g=a(9),p=a(6),d=a(20),s=a(15),c=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),u=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},h=function(e){function t(t,a,r,o,n,i){var l=e.call(this)||this;return l.cellValueFn=t,l.rowNode=a,l.column=r,l.customGui=o,l.dragStartPixels=n,l.suppressVisibilityChange=i,l.dragSource=null,l}return c(t,e),t.prototype.isCustomGui=function(){return null!=this.customGui},t.prototype.postConstruct=function(){if(this.customGui?this.setDragElement(this.customGui,this.dragStartPixels):(this.setTemplate(''),this.getGui().appendChild(Object(d.createIconNoSpan)("rowDrag",this.beans.gridOptionsWrapper,null)),this.addDragSource()),this.checkCompatibility(),!this.suppressVisibilityChange){var e=this.beans.gridOptionsWrapper.isRowDragManaged()?new b(this,this.beans,this.rowNode,this.column):new m(this,this.beans,this.rowNode,this.column);this.createManagedBean(e,this.beans.context)}},t.prototype.setDragElement=function(e,t){this.setTemplateFromElement(e),this.addDragSource(t)},t.prototype.getSelectedCount=function(){if(!this.beans.gridOptionsWrapper.isRowDragMultiRow())return 1;var e=this.beans.selectionService.getSelectedNodes();return-1!==e.indexOf(this.rowNode)?e.length:1},t.prototype.checkCompatibility=function(){var e=this.beans.gridOptionsWrapper.isRowDragManaged();this.beans.gridOptionsWrapper.isTreeData()&&e&&Object(s.doOnce)((function(){return console.warn("AG Grid: If using row drag with tree data, you cannot have rowDragManaged=true")}),"RowDragComp.managedAndTreeData")},t.prototype.addDragSource=function(e){var t=this;void 0===e&&(e=4),this.dragSource&&this.removeDragSource();var a={rowNode:this.rowNode,columns:this.column?[this.column]:void 0,defaultTextValue:this.cellValueFn()},r=this.column&&this.column.getColDef().rowDragText,o=this.gridOptionsWrapper.getLocaleTextFunc();this.dragSource={type:l.b.RowDrag,eElement:this.getGui(),dragItemName:function(){var e=t.getSelectedCount();return r?r(a,e):1===e?t.cellValueFn():e+" "+o("rowDragRows","rows")},getDragItem:function(){return a},dragStartPixels:e,dragSourceDomDataKey:this.beans.gridOptionsWrapper.getDomDataKey()},this.beans.dragAndDropService.addDragSource(this.dragSource,!0)},t.prototype.removeDragSource=function(){this.dragSource&&this.beans.dragAndDropService.removeDragSource(this.dragSource),this.dragSource=null},u([Object(n.a)("beans")],t.prototype,"beans",void 0),u([n.e],t.prototype,"postConstruct",null),u([n.g],t.prototype,"removeDragSource",null),t}(o.a),f=function(e){function t(t,a,r){var o=e.call(this)||this;return o.parent=t,o.rowNode=a,o.column=r,o}return c(t,e),t.prototype.setDisplayedOrVisible=function(e){if(e)this.parent.setDisplayed(!1);else{var t=!0,a=!1;this.column&&(t=this.column.isRowDrag(this.rowNode)||this.parent.isCustomGui(),a=Object(s.isFunction)(this.column.getColDef().rowDrag)),a?(this.parent.setDisplayed(!0),this.parent.setVisible(t)):(this.parent.setDisplayed(t),this.parent.setVisible(!0))}},t}(p.a),m=function(e){function t(t,a,r,o){var n=e.call(this,t,r,o)||this;return n.beans=a,n}return c(t,e),t.prototype.postConstruct=function(){this.addManagedListener(this.beans.gridOptionsWrapper,"suppressRowDrag",this.onSuppressRowDrag.bind(this)),this.addManagedListener(this.rowNode,i.b.EVENT_DATA_CHANGED,this.workOutVisibility.bind(this)),this.addManagedListener(this.rowNode,i.b.EVENT_CELL_CHANGED,this.workOutVisibility.bind(this)),this.addManagedListener(this.rowNode,i.b.EVENT_CELL_CHANGED,this.workOutVisibility.bind(this)),this.addManagedListener(this.beans.eventService,g.a.EVENT_NEW_COLUMNS_LOADED,this.workOutVisibility.bind(this)),this.workOutVisibility()},t.prototype.onSuppressRowDrag=function(){this.workOutVisibility()},t.prototype.workOutVisibility=function(){var e=this.beans.gridOptionsWrapper.isSuppressRowDrag();this.setDisplayedOrVisible(e)},u([n.e],t.prototype,"postConstruct",null),t}(f),b=function(e){function t(t,a,r,o){var n=e.call(this,t,r,o)||this;return n.beans=a,n}return c(t,e),t.prototype.postConstruct=function(){this.addManagedListener(this.beans.eventService,g.a.EVENT_SORT_CHANGED,this.workOutVisibility.bind(this)),this.addManagedListener(this.beans.eventService,g.a.EVENT_FILTER_CHANGED,this.workOutVisibility.bind(this)),this.addManagedListener(this.beans.eventService,g.a.EVENT_COLUMN_ROW_GROUP_CHANGED,this.workOutVisibility.bind(this)),this.addManagedListener(this.beans.eventService,g.a.EVENT_NEW_COLUMNS_LOADED,this.workOutVisibility.bind(this)),this.addManagedListener(this.rowNode,i.b.EVENT_DATA_CHANGED,this.workOutVisibility.bind(this)),this.addManagedListener(this.rowNode,i.b.EVENT_CELL_CHANGED,this.workOutVisibility.bind(this)),this.addManagedListener(this.beans.gridOptionsWrapper,"suppressRowDrag",this.onSuppressRowDrag.bind(this)),this.workOutVisibility()},t.prototype.onSuppressRowDrag=function(){this.workOutVisibility()},t.prototype.workOutVisibility=function(){var e=this.beans.ctrlsService.getGridBodyCtrl().getRowDragFeature(),t=e&&e.shouldPreventRowMove(),a=this.beans.gridOptionsWrapper.isSuppressRowDrag(),r=this.beans.dragAndDropService.hasExternalDropZones(),o=t&&!r||a;this.setDisplayedOrVisible(o)},u([n.e],t.prototype,"postConstruct",null),t}(f)},function(e,t,a){"use strict";a.d(t,"a",(function(){return u}));var r,o=a(7),n=a(0),i=a(177),l=a(26),g=a(32),p=a(33),d=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),s=function(){return(s=Object.assign||function(e){for(var t,a=1,r=arguments.length;a=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},u=function(e){function t(){var t=e.call(this,"dateFilter")||this;return t.minValidYear=1e3,t.maxValidYear=1/0,t}return d(t,e),t.prototype.afterGuiAttached=function(t){e.prototype.afterGuiAttached.call(this,t),this.dateCondition1FromComp.afterGuiAttached(t)},t.prototype.mapValuesFromModel=function(e){var t=e||{},a=t.dateFrom,r=t.dateTo,o=t.type;return[a&&Object(p.parseDateTimeFromString)(a)||null,r&&Object(p.parseDateTimeFromString)(r)||null].slice(0,this.getNumberOfInputs(o))},t.prototype.comparator=function(){return this.dateFilterParams.comparator?this.dateFilterParams.comparator:this.defaultComparator.bind(this)},t.prototype.defaultComparator=function(e,t){return null==t||te?1:0},t.prototype.setParams=function(t){e.prototype.setParams.call(this,t),this.dateFilterParams=t;var a=function(e,a){if(null!=t[e]){if(!isNaN(t[e]))return null==t[e]?a:Number(t[e]);console.warn("AG Grid: DateFilter "+e+" is not a number")}return a};this.minValidYear=a("minValidYear",1e3),this.maxValidYear=a("maxValidYear",1/0),this.minValidYear>this.maxValidYear&&console.warn("AG Grid: DateFilter minValidYear should be <= maxValidYear"),this.createDateComponents()},t.prototype.createDateComponents=function(){var e=this,t=function(t){return new i.a(e.getContext(),e.userComponentFactory,{onDateChanged:function(){return e.onUiChanged()},filterParams:e.dateFilterParams},t)};this.dateCondition1FromComp=t(this.eCondition1PanelFrom),this.dateCondition1ToComp=t(this.eCondition1PanelTo),this.dateCondition2FromComp=t(this.eCondition2PanelFrom),this.dateCondition2ToComp=t(this.eCondition2PanelTo),this.addDestroyFunc((function(){e.forEachInput((function(e){return e.destroy()}))}))},t.prototype.setElementValue=function(e,t,a){e.setDate(t)},t.prototype.setElementDisplayed=function(e,t){e.setDisplayed(t)},t.prototype.setElementDisabled=function(e,t){e.setDisabled(t)},t.prototype.getDefaultFilterOptions=function(){return t.DEFAULT_FILTER_OPTIONS},t.prototype.createValueTemplate=function(e){var t=e===l.a.One?"1":"2";return'\n
\n
\n
\n
'},t.prototype.isConditionUiComplete=function(t){var a=this;if(!e.prototype.isConditionUiComplete.call(this,t))return!1;var r=!0;return this.forEachInput((function(e,o,n,i){var l;n!==t||!r||o>=i||(r=r&&(null!=(l=e.getDate())&&l.getUTCFullYear()>=a.minValidYear&&l.getUTCFullYear()<=a.maxValidYear))})),r},t.prototype.areSimpleModelsEqual=function(e,t){return e.dateFrom===t.dateFrom&&e.dateTo===t.dateTo&&e.type===t.type},t.prototype.getFilterType=function(){return"date"},t.prototype.createCondition=function(e){var t=this.getConditionTypes()[e],a={},r=this.getValues(e);return r.length>0&&(a.dateFrom=Object(p.serialiseDate)(r[0])),r.length>1&&(a.dateTo=Object(p.serialiseDate)(r[1])),s({dateFrom:null,dateTo:null,filterType:this.getFilterType(),type:t},a)},t.prototype.resetPlaceholder=function(){var e=this.gridOptionsWrapper.getLocaleTextFunc(),t=this.translate("dateFormatOoo"),a=e("ariaFilterValue","Filter Value");this.forEachInput((function(e){e.setInputPlaceholder(t),e.setInputAriaLabel(a)}))},t.prototype.getInputs=function(){return[[this.dateCondition1FromComp,this.dateCondition1ToComp],[this.dateCondition2FromComp,this.dateCondition2ToComp]]},t.prototype.getValues=function(e){var t=[];return this.forEachInput((function(a,r,o,n){e===o&&r=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},s=function(e){function t(){return e.call(this,"numberFilter")||this}return p(t,e),t.prototype.mapValuesFromModel=function(e){var t=e||{},a=t.filter,r=t.filterTo,o=t.type;return[null==a?null:a,null==r?null:r].slice(0,this.getNumberOfInputs(o))},t.prototype.getDefaultDebounceMs=function(){return 500},t.prototype.comparator=function(){return function(e,t){return e===t?0:e\n <'+a+' class="ag-filter-from ag-filter-filter" ref="eValue-index0-'+t+'">\n <"+a+' class="ag-filter-to ag-filter-filter" ref="eValue-index1-'+t+'">\n
"},t.prototype.getValues=function(e){var t=this,a=[];return this.forEachInput((function(r,o,n,i){e===n&&o0&&(a.filter=r[0]),r.length>1&&(a.filterTo=r[1]),a},t.prototype.getInputs=function(){return[[this.eValueFrom1,this.eValueTo1],[this.eValueFrom2,this.eValueTo2]]},t.prototype.getAllowedCharPattern=function(){var e=(this.numberFilterParams||{}).allowedCharPattern;return e||(Object(g.isBrowserChrome)()||Object(g.isBrowserEdge)()?null:"\\d\\-\\.")},t.DEFAULT_FILTER_OPTIONS=[i.a.EQUALS,i.a.NOT_EQUAL,i.a.LESS_THAN,i.a.LESS_THAN_OR_EQUAL,i.a.GREATER_THAN,i.a.GREATER_THAN_OR_EQUAL,i.a.IN_RANGE,i.a.BLANK,i.a.NOT_BLANK],d([Object(o.b)("eValue-index0-1")],t.prototype,"eValueFrom1",void 0),d([Object(o.b)("eValue-index1-1")],t.prototype,"eValueTo1",void 0),d([Object(o.b)("eValue-index0-2")],t.prototype,"eValueFrom2",void 0),d([Object(o.b)("eValue-index1-2")],t.prototype,"eValueTo2",void 0),t}(i.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return s}));var r,o=a(0),n=a(46),i=a(7),l=a(1),g=a(8),p=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),d=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},s=function(e){function t(){var t=e.call(this,'
')||this;return t.startedByEnter=!1,t}return p(t,e),t.prototype.init=function(e){var t=this;if(this.focusAfterAttached=e.cellStartedEdit,Object(l.missing)(e.values))console.warn("AG Grid: no values found for select cellEditor");else{this.startedByEnter=null!=e.eventKey&&e.eventKey===g.a.ENTER;var a=!1;e.values.forEach((function(r){var o={value:r},n=t.valueFormatterService.formatValue(e.column,null,null,r),i=null!=n;o.text=i?n:r,t.eSelect.addOption(o),a=a||e.value===r})),a?this.eSelect.setValue(e.value,!0):e.values.length&&this.eSelect.setValue(e.values[0],!0),this.gridOptionsWrapper.isFullRowEdit()||this.eSelect.onValueChange((function(){return e.stopEditing()}))}},t.prototype.afterGuiAttached=function(){this.focusAfterAttached&&this.eSelect.getFocusableElement().focus(),this.startedByEnter&&this.eSelect.showPicker()},t.prototype.focusIn=function(){this.eSelect.getFocusableElement().focus()},t.prototype.getValue=function(){return this.eSelect.getValue()},t.prototype.isPopup=function(){return!1},d([Object(o.a)("valueFormatterService")],t.prototype,"valueFormatterService",void 0),d([Object(i.b)("eSelect")],t.prototype,"eSelect",void 0),t}(n.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return c}));var r,o=a(0),n=a(13),i=a(4),l=a(7),g=a(19),p=a(24),d=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),s=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},c=function(e){function t(){return e.call(this,'\n ')||this}return d(t,e),t.prototype.postConstruct=function(){this.eCheckbox.setPassive(!0)},t.prototype.getCheckboxId=function(){return this.eCheckbox.getInputElement().id},t.prototype.onDataChanged=function(){this.onSelectionChanged()},t.prototype.onSelectableChanged=function(){this.showOrHideSelect()},t.prototype.onSelectionChanged=function(){var e=this.gridOptionsWrapper.getLocaleTextFunc(),t=this.rowNode.isSelected(),a=void 0===t?e("ariaIndeterminate","indeterminate"):!0===t?e("ariaChecked","checked"):e("ariaUnchecked","unchecked"),r=e("ariaRowToggleSelection","Press Space to toggle row selection");this.eCheckbox.setValue(t,!0),this.eCheckbox.setInputAriaLabel(r+" ("+a+")")},t.prototype.onCheckedClicked=function(e){var t=this.gridOptionsWrapper.isGroupSelectsFiltered();return this.rowNode.setSelectedParams({newValue:!1,rangeSelect:e.shiftKey,groupSelectsFiltered:t})},t.prototype.onUncheckedClicked=function(e){var t=this.gridOptionsWrapper.isGroupSelectsFiltered();return this.rowNode.setSelectedParams({newValue:!0,rangeSelect:e.shiftKey,groupSelectsFiltered:t})},t.prototype.init=function(e){var t=this;if(this.rowNode=e.rowNode,this.column=e.column,this.onSelectionChanged(),this.addGuiEventListener("click",(function(e){return Object(p.stopPropagationForAgGrid)(e)})),this.addGuiEventListener("dblclick",(function(e){return Object(p.stopPropagationForAgGrid)(e)})),this.addManagedListener(this.eCheckbox.getInputElement(),"click",(function(e){var a=t.eCheckbox.getValue();void 0===t.eCheckbox.getPreviousValue()||void 0===a?0===t.onUncheckedClicked(e||{})&&t.onCheckedClicked(e):a?t.onCheckedClicked(e):t.onUncheckedClicked(e||{})})),this.addManagedListener(this.rowNode,g.b.EVENT_ROW_SELECTED,this.onSelectionChanged.bind(this)),this.addManagedListener(this.rowNode,g.b.EVENT_DATA_CHANGED,this.onDataChanged.bind(this)),this.addManagedListener(this.rowNode,g.b.EVENT_SELECTABLE_CHANGED,this.onSelectableChanged.bind(this)),this.gridOptionsWrapper.getIsRowSelectableFunc()||this.checkboxCallbackExists()){var a=this.showOrHideSelect.bind(this);this.addManagedListener(this.eventService,i.a.EVENT_DISPLAYED_COLUMNS_CHANGED,a),this.addManagedListener(this.rowNode,g.b.EVENT_DATA_CHANGED,a),this.addManagedListener(this.rowNode,g.b.EVENT_CELL_CHANGED,a),this.showOrHideSelect()}this.eCheckbox.getInputElement().setAttribute("tabindex","-1")},t.prototype.showOrHideSelect=function(){var e=this.rowNode.selectable;e&&this.checkboxCallbackExists()&&(e=this.column.isCellCheckboxSelection(this.rowNode)),this.setVisible(e)},t.prototype.checkboxCallbackExists=function(){var e=this.column?this.column.getColDef():null;return!!e&&"function"==typeof e.checkboxSelection},s([Object(l.b)("eCheckbox")],t.prototype,"eCheckbox",void 0),s([o.e],t.prototype,"postConstruct",null),t}(n.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return r}));var r=function(){function e(e,t){this.active=!0,this.nodeIdsToColumns={},this.mapToItems={},this.keepingColumns=e,this.pathRoot={rowNode:t,children:null},this.mapToItems[t.id]=this.pathRoot}return e.prototype.setInactive=function(){this.active=!1},e.prototype.isActive=function(){return this.active},e.prototype.depthFirstSearchChangedPath=function(e,t){if(e.children)for(var a=0;a=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},n=function(){function e(){}return e.prototype.postConstruct=function(){this.doingMasterDetail=this.gridOptionsWrapper.isMasterDetail(),this.gridOptionsWrapper.isRowModelDefault()&&(this.clientSideRowModel=this.rowModel),this.gridOptionsWrapper.isRowModelServerSide()&&(this.serverSideRowModel=this.rowModel)},o([Object(r.a)("resizeObserverService")],e.prototype,"resizeObserverService",void 0),o([Object(r.a)("paginationProxy")],e.prototype,"paginationProxy",void 0),o([Object(r.a)("context")],e.prototype,"context",void 0),o([Object(r.a)("columnApi")],e.prototype,"columnApi",void 0),o([Object(r.a)("gridApi")],e.prototype,"gridApi",void 0),o([Object(r.a)("gridOptionsWrapper")],e.prototype,"gridOptionsWrapper",void 0),o([Object(r.a)("expressionService")],e.prototype,"expressionService",void 0),o([Object(r.a)("rowRenderer")],e.prototype,"rowRenderer",void 0),o([Object(r.a)("$compile")],e.prototype,"$compile",void 0),o([Object(r.a)("templateService")],e.prototype,"templateService",void 0),o([Object(r.a)("valueService")],e.prototype,"valueService",void 0),o([Object(r.a)("eventService")],e.prototype,"eventService",void 0),o([Object(r.a)("columnModel")],e.prototype,"columnModel",void 0),o([Object(r.a)("headerNavigationService")],e.prototype,"headerNavigationService",void 0),o([Object(r.a)("navigationService")],e.prototype,"navigationService",void 0),o([Object(r.a)("columnAnimationService")],e.prototype,"columnAnimationService",void 0),o([Object(r.d)("rangeService")],e.prototype,"rangeService",void 0),o([Object(r.a)("focusService")],e.prototype,"focusService",void 0),o([Object(r.d)("contextMenuFactory")],e.prototype,"contextMenuFactory",void 0),o([Object(r.a)("popupService")],e.prototype,"popupService",void 0),o([Object(r.a)("valueFormatterService")],e.prototype,"valueFormatterService",void 0),o([Object(r.a)("stylingService")],e.prototype,"stylingService",void 0),o([Object(r.a)("columnHoverService")],e.prototype,"columnHoverService",void 0),o([Object(r.a)("userComponentFactory")],e.prototype,"userComponentFactory",void 0),o([Object(r.a)("userComponentRegistry")],e.prototype,"userComponentRegistry",void 0),o([Object(r.a)("animationFrameService")],e.prototype,"animationFrameService",void 0),o([Object(r.a)("dragAndDropService")],e.prototype,"dragAndDropService",void 0),o([Object(r.a)("sortController")],e.prototype,"sortController",void 0),o([Object(r.a)("filterManager")],e.prototype,"filterManager",void 0),o([Object(r.a)("rowContainerHeightService")],e.prototype,"rowContainerHeightService",void 0),o([Object(r.a)("frameworkOverrides")],e.prototype,"frameworkOverrides",void 0),o([Object(r.a)("cellPositionUtils")],e.prototype,"cellPositionUtils",void 0),o([Object(r.a)("rowPositionUtils")],e.prototype,"rowPositionUtils",void 0),o([Object(r.a)("selectionService")],e.prototype,"selectionService",void 0),o([Object(r.d)("selectionHandleFactory")],e.prototype,"selectionHandleFactory",void 0),o([Object(r.a)("rowCssClassCalculator")],e.prototype,"rowCssClassCalculator",void 0),o([Object(r.a)("rowModel")],e.prototype,"rowModel",void 0),o([Object(r.a)("ctrlsService")],e.prototype,"ctrlsService",void 0),o([Object(r.a)("ctrlsFactory")],e.prototype,"ctrlsFactory",void 0),o([Object(r.a)("agStackComponentsRegistry")],e.prototype,"agStackComponentsRegistry",void 0),o([Object(r.a)("valueCache")],e.prototype,"valueCache",void 0),o([Object(r.a)("rowNodeEventThrottle")],e.prototype,"rowNodeEventThrottle",void 0),o([r.e],e.prototype,"postConstruct",null),e=o([Object(r.b)("beans")],e)}()},function(e,t,a){"use strict";a.d(t,"b",(function(){return m})),a.d(t,"a",(function(){return b}));var r=a(14),o=a(2),n=a(0),i=a(85),l=a(182),g=a(16),p=a(48),d=a(17),s=a(12),c=a(1),u=a(27),h=a(15),f=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i};function m(e){var t=e;return null!=t&&null!=t.getFrameworkComponentInstance?t.getFrameworkComponentInstance():e}var b=function(){function e(){this.detailGridInfoMap={},this.destroyCalled=!1}return e.prototype.registerOverlayWrapperComp=function(e){this.overlayWrapperComp=e},e.prototype.registerSideBarComp=function(e){this.sideBarComp=e},e.prototype.init=function(){var e=this;switch(this.rowModel.getType()){case o.a.ROW_MODEL_TYPE_CLIENT_SIDE:this.clientSideRowModel=this.rowModel;break;case o.a.ROW_MODEL_TYPE_INFINITE:this.infiniteRowModel=this.rowModel;break;case o.a.ROW_MODEL_TYPE_SERVER_SIDE:this.serverSideRowModel=this.rowModel}this.ctrlsService.whenReady((function(){e.gridBodyCon=e.ctrlsService.getGridBodyCtrl()}))},e.prototype.__getAlignedGridService=function(){return this.alignedGridsService},e.prototype.__getContext=function(){return this.context},e.prototype.addDetailGridInfo=function(e,t){this.detailGridInfoMap[e]=t},e.prototype.removeDetailGridInfo=function(e){this.detailGridInfoMap[e]=void 0},e.prototype.getDetailGridInfo=function(e){return this.detailGridInfoMap[e]},e.prototype.forEachDetailGridInfo=function(e){var t=0;Object(s.iterateObject)(this.detailGridInfoMap,(function(a,r){Object(c.exists)(r)&&(e(r,t),t++)}))},e.prototype.getDataAsCsv=function(e){if(d.a.assertRegistered(g.a.CsvExportModule,"api.getDataAsCsv"))return this.csvCreator.getDataAsCsv(e)},e.prototype.exportDataAsCsv=function(e){d.a.assertRegistered(g.a.CsvExportModule,"api.exportDataAsCSv")&&this.csvCreator.exportDataAsCsv(e)},e.prototype.getExcelExportMode=function(e){var t=this.gridOptionsWrapper.getDefaultExportParams("excel");return Object.assign({exportMode:"xlsx"},t,e).exportMode},e.prototype.getDataAsExcel=function(e){if(d.a.assertRegistered(g.a.ExcelExportModule,"api.getDataAsExcel")){var t=this.getExcelExportMode(e);if(this.excelCreator.getFactoryMode(t)!==i.a.MULTI_SHEET)return this.excelCreator.getDataAsExcel(e);console.warn("AG Grid: The Excel Exporter is currently on Multi Sheet mode. End that operation by calling `api.getMultipleSheetAsExcel()` or `api.exportMultipleSheetsAsExcel()`")}},e.prototype.exportDataAsExcel=function(e){if(d.a.assertRegistered(g.a.ExcelExportModule,"api.exportDataAsExcel")){var t=this.getExcelExportMode(e);this.excelCreator.getFactoryMode(t)!==i.a.MULTI_SHEET?this.excelCreator.exportDataAsExcel(e):console.warn("AG Grid: The Excel Exporter is currently on Multi Sheet mode. End that operation by calling `api.getMultipleSheetAsExcel()` or `api.exportMultipleSheetsAsExcel()`")}},e.prototype.getSheetDataForExcel=function(e){if(d.a.assertRegistered(g.a.ExcelExportModule,"api.getSheetDataForExcel")){var t=this.getExcelExportMode(e);return this.excelCreator.setFactoryMode(i.a.MULTI_SHEET,t),this.excelCreator.getSheetDataForExcel(e)}},e.prototype.getMultipleSheetsAsExcel=function(e){if(d.a.assertRegistered(g.a.ExcelExportModule,"api.getMultipleSheetsAsExcel"))return this.excelCreator.getMultipleSheetsAsExcel(e)},e.prototype.exportMultipleSheetsAsExcel=function(e){if(d.a.assertRegistered(g.a.ExcelExportModule,"api.exportMultipleSheetsAsExcel"))return this.excelCreator.exportMultipleSheetsAsExcel(e)},e.prototype.setEnterpriseDatasource=function(e){console.warn("AG Grid: since version 18.x, api.setEnterpriseDatasource() should be replaced with api.setServerSideDatasource()"),this.setServerSideDatasource(e)},e.prototype.setGridAriaProperty=function(e,t){if(e){var a=this.ctrlsService.getGridBodyCtrl().getGui(),r="aria-"+e;null===t?a.removeAttribute(r):a.setAttribute(r,t)}},e.prototype.setServerSideDatasource=function(e){this.serverSideRowModel?this.serverSideRowModel.setDatasource(e):console.warn("AG Grid: you can only use an enterprise datasource when gridOptions.rowModelType is '"+o.a.ROW_MODEL_TYPE_SERVER_SIDE+"'")},e.prototype.setDatasource=function(e){this.gridOptionsWrapper.isRowModelInfinite()?this.rowModel.setDatasource(e):console.warn("AG Grid: you can only use a datasource when gridOptions.rowModelType is '"+o.a.ROW_MODEL_TYPE_INFINITE+"'")},e.prototype.setViewportDatasource=function(e){this.gridOptionsWrapper.isRowModelViewport()?this.rowModel.setViewportDatasource(e):console.warn("AG Grid: you can only use a viewport datasource when gridOptions.rowModelType is '"+o.a.ROW_MODEL_TYPE_VIEWPORT+"'")},e.prototype.setRowData=function(e){null==this.immutableService?console.warn("AG Grid: you can only set rowData when using the Client Side Row Model"):this.immutableService.isActive()?this.immutableService.setRowData(e):(this.selectionService.reset(),this.clientSideRowModel.setRowData(e))},e.prototype.setFloatingTopRowData=function(e){console.warn("AG Grid: since v12, api.setFloatingTopRowData() is now api.setPinnedTopRowData()"),this.setPinnedTopRowData(e)},e.prototype.setFloatingBottomRowData=function(e){console.warn("AG Grid: since v12, api.setFloatingBottomRowData() is now api.setPinnedBottomRowData()"),this.setPinnedBottomRowData(e)},e.prototype.getFloatingTopRowCount=function(){return console.warn("AG Grid: since v12, api.getFloatingTopRowCount() is now api.getPinnedTopRowCount()"),this.getPinnedTopRowCount()},e.prototype.getFloatingBottomRowCount=function(){return console.warn("AG Grid: since v12, api.getFloatingBottomRowCount() is now api.getPinnedBottomRowCount()"),this.getPinnedBottomRowCount()},e.prototype.getFloatingTopRow=function(e){return console.warn("AG Grid: since v12, api.getFloatingTopRow() is now api.getPinnedTopRow()"),this.getPinnedTopRow(e)},e.prototype.getFloatingBottomRow=function(e){return console.warn("AG Grid: since v12, api.getFloatingBottomRow() is now api.getPinnedBottomRow()"),this.getPinnedBottomRow(e)},e.prototype.setPinnedTopRowData=function(e){this.pinnedRowModel.setPinnedTopRowData(e)},e.prototype.setPinnedBottomRowData=function(e){this.pinnedRowModel.setPinnedBottomRowData(e)},e.prototype.getPinnedTopRowCount=function(){return this.pinnedRowModel.getPinnedTopRowCount()},e.prototype.getPinnedBottomRowCount=function(){return this.pinnedRowModel.getPinnedBottomRowCount()},e.prototype.getPinnedTopRow=function(e){return this.pinnedRowModel.getPinnedTopRow(e)},e.prototype.getPinnedBottomRow=function(e){return this.pinnedRowModel.getPinnedBottomRow(e)},e.prototype.setColumnDefs=function(e,t){void 0===t&&(t="api"),this.columnModel.setColumnDefs(e,t)},e.prototype.setAutoGroupColumnDef=function(e,t){void 0===t&&(t="api"),this.gridOptionsWrapper.setProperty("autoGroupColumnDef",e,!0)},e.prototype.setDefaultColDef=function(e,t){void 0===t&&(t="api"),this.gridOptionsWrapper.setProperty("defaultColDef",e,!0)},e.prototype.expireValueCache=function(){this.valueCache.expire()},e.prototype.getVerticalPixelRange=function(){return this.gridBodyCon.getScrollFeature().getVScrollPosition()},e.prototype.getHorizontalPixelRange=function(){return this.gridBodyCon.getScrollFeature().getHScrollPosition()},e.prototype.setAlwaysShowHorizontalScroll=function(e){this.gridOptionsWrapper.setProperty("alwaysShowHorizontalScroll",e)},e.prototype.setAlwaysShowVerticalScroll=function(e){this.gridOptionsWrapper.setProperty("alwaysShowVerticalScroll",e)},e.prototype.refreshToolPanel=function(){this.sideBarComp&&this.sideBarComp.refresh()},e.prototype.refreshCells=function(e){void 0===e&&(e={}),Array.isArray(e)?console.warn("since AG Grid v11.1, refreshCells() now takes parameters, please see the documentation."):this.rowRenderer.refreshCells(e)},e.prototype.flashCells=function(e){void 0===e&&(e={}),this.rowRenderer.flashCells(e)},e.prototype.redrawRows=function(e){void 0===e&&(e={});var t=e?e.rowNodes:void 0;this.rowRenderer.redrawRows(t)},e.prototype.setFunctionsReadOnly=function(e){this.gridOptionsWrapper.setProperty("functionsReadOnly",e)},e.prototype.refreshHeader=function(){this.ctrlsService.getHeaderRowContainerCtrls().forEach((function(e){return e.refresh()}))},e.prototype.isAnyFilterPresent=function(){return this.filterManager.isAnyFilterPresent()},e.prototype.isColumnFilterPresent=function(){return this.filterManager.isAdvancedFilterPresent()},e.prototype.isQuickFilterPresent=function(){return this.filterManager.isQuickFilterPresent()},e.prototype.getModel=function(){return this.rowModel},e.prototype.setRowNodeExpanded=function(e,t){e&&e.setExpanded(t)},e.prototype.onGroupExpandedOrCollapsed=function(e){Object(c.missing)(this.clientSideRowModel)&&console.warn("AG Grid: cannot call onGroupExpandedOrCollapsed unless using normal row model"),Object(c.exists)(e)&&console.warn("AG Grid: api.onGroupExpandedOrCollapsed - refreshFromIndex parameter is no longer used, the grid will refresh all rows"),this.clientSideRowModel.refreshModel({step:p.a.MAP})},e.prototype.refreshInMemoryRowModel=function(e){console.warn("ag-grid: since version 18.x, api.refreshInMemoryRowModel() should be replaced with api.refreshClientSideRowModel()"),this.refreshClientSideRowModel(e)},e.prototype.refreshClientSideRowModel=function(e){Object(c.missing)(this.clientSideRowModel)&&console.warn("cannot call refreshClientSideRowModel unless using normal row model");var t=p.a.EVERYTHING,a={group:p.a.EVERYTHING,filter:p.a.FILTER,map:p.a.MAP,aggregate:p.a.AGGREGATE,sort:p.a.SORT,pivot:p.a.PIVOT};if(Object(c.exists)(e)&&(t=a[e]),Object(c.missing)(t))console.error("AG Grid: invalid step "+e+", available steps are "+Object.keys(a).join(", "));else{var r={step:t,keepRenderedRows:!0,keepEditingRows:!0,animate:!this.gridOptionsWrapper.isSuppressAnimationFrame()};this.clientSideRowModel.refreshModel(r)}},e.prototype.isAnimationFrameQueueEmpty=function(){return this.animationFrameService.isQueueEmpty()},e.prototype.flushAllAnimationFrames=function(){this.animationFrameService.flushAllFrames()},e.prototype.getRowNode=function(e){return this.rowModel.getRowNode(e)},e.prototype.getSizesForCurrentTheme=function(){return{rowHeight:this.gridOptionsWrapper.getRowHeightAsNumber(),headerHeight:this.gridOptionsWrapper.getHeaderHeight()}},e.prototype.expandAll=function(){this.clientSideRowModel?this.clientSideRowModel.expandOrCollapseAll(!0):this.serverSideRowModel?this.serverSideRowModel.expandAll(!0):console.warn("AG Grid: expandAll only works with Client Side Row Model and Server Side Row Model")},e.prototype.collapseAll=function(){this.clientSideRowModel?this.clientSideRowModel.expandOrCollapseAll(!1):this.serverSideRowModel?this.serverSideRowModel.expandAll(!1):console.warn("AG Grid: collapseAll only works with Client Side Row Model and Server Side Row Model")},e.prototype.getToolPanelInstance=function(e){if(this.sideBarComp)return m(this.sideBarComp.getToolPanelInstance(e));console.warn("AG Grid: toolPanel is only available in AG Grid Enterprise")},e.prototype.addVirtualRowListener=function(e,t,a){"string"!=typeof e&&console.warn("AG Grid: addVirtualRowListener is deprecated, please use addRenderedRowListener."),this.addRenderedRowListener(e,t,a)},e.prototype.addRenderedRowListener=function(e,t,a){"virtualRowSelected"===e&&console.warn("AG Grid: event virtualRowSelected is deprecated, to register for individual row\n selection events, add a listener directly to the row node."),this.rowRenderer.addRenderedRowListener(e,t,a)},e.prototype.setQuickFilter=function(e){this.filterManager.setQuickFilter(e)},e.prototype.selectIndex=function(e,t,a){console.warn("AG Grid: do not use api for selection, call node.setSelected(value) instead"),a&&console.warn("AG Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it"),this.selectionService.selectIndex(e,t)},e.prototype.deselectIndex=function(e,t){void 0===t&&(t=!1),console.warn("AG Grid: do not use api for selection, call node.setSelected(value) instead"),t&&console.warn("AG Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it"),this.selectionService.deselectIndex(e)},e.prototype.selectNode=function(e,t,a){void 0===t&&(t=!1),void 0===a&&(a=!1),console.warn("AG Grid: API for selection is deprecated, call node.setSelected(value) instead"),a&&console.warn("AG Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it"),e.setSelectedParams({newValue:!0,clearSelection:!t})},e.prototype.deselectNode=function(e,t){void 0===t&&(t=!1),console.warn("AG Grid: API for selection is deprecated, call node.setSelected(value) instead"),t&&console.warn("AG Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it"),e.setSelectedParams({newValue:!1})},e.prototype.selectAll=function(){this.selectionService.selectAllRowNodes()},e.prototype.deselectAll=function(){this.selectionService.deselectAllRowNodes()},e.prototype.selectAllFiltered=function(){this.selectionService.selectAllRowNodes(!0)},e.prototype.deselectAllFiltered=function(){this.selectionService.deselectAllRowNodes(!0)},e.prototype.recomputeAggregates=function(){Object(c.missing)(this.clientSideRowModel)&&console.warn("cannot call recomputeAggregates unless using normal row model"),console.warn("recomputeAggregates is deprecated, please call api.refreshClientSideRowModel('aggregate') instead"),this.clientSideRowModel.refreshModel({step:p.a.AGGREGATE})},e.prototype.sizeColumnsToFit=function(){this.gridBodyCon.sizeColumnsToFit()},e.prototype.showLoadingOverlay=function(){this.overlayWrapperComp.showLoadingOverlay()},e.prototype.showNoRowsOverlay=function(){this.overlayWrapperComp.showNoRowsOverlay()},e.prototype.hideOverlay=function(){this.overlayWrapperComp.hideOverlay()},e.prototype.isNodeSelected=function(e){return console.warn("AG Grid: no need to call api.isNodeSelected(), just call node.isSelected() instead"),e.isSelected()},e.prototype.getSelectedNodesById=function(){return console.error("AG Grid: since version 3.4, getSelectedNodesById no longer exists, use getSelectedNodes() instead"),null},e.prototype.getSelectedNodes=function(){return this.selectionService.getSelectedNodes()},e.prototype.getSelectedRows=function(){return this.selectionService.getSelectedRows()},e.prototype.getBestCostNodeSelection=function(){return this.selectionService.getBestCostNodeSelection()},e.prototype.getRenderedNodes=function(){return this.rowRenderer.getRenderedNodes()},e.prototype.ensureColIndexVisible=function(e){console.warn("AG Grid: ensureColIndexVisible(index) no longer supported, use ensureColumnVisible(colKey) instead.")},e.prototype.ensureColumnVisible=function(e,t){void 0===t&&(t="auto"),this.gridBodyCon.getScrollFeature().ensureColumnVisible(e,t)},e.prototype.ensureIndexVisible=function(e,t){this.gridBodyCon.getScrollFeature().ensureIndexVisible(e,t)},e.prototype.ensureNodeVisible=function(e,t){void 0===t&&(t=null),this.gridBodyCon.getScrollFeature().ensureNodeVisible(e,t)},e.prototype.forEachLeafNode=function(e){Object(c.missing)(this.clientSideRowModel)&&console.warn("cannot call forEachNode unless using normal row model"),this.clientSideRowModel.forEachLeafNode(e)},e.prototype.forEachNode=function(e){this.rowModel.forEachNode(e)},e.prototype.forEachNodeAfterFilter=function(e){Object(c.missing)(this.clientSideRowModel)&&console.warn("cannot call forEachNodeAfterFilter unless using normal row model"),this.clientSideRowModel.forEachNodeAfterFilter(e)},e.prototype.forEachNodeAfterFilterAndSort=function(e){Object(c.missing)(this.clientSideRowModel)&&console.warn("cannot call forEachNodeAfterFilterAndSort unless using normal row model"),this.clientSideRowModel.forEachNodeAfterFilterAndSort(e)},e.prototype.getFilterInstance=function(e,t){var a=this.getFilterInstanceImpl(e,(function(e){if(t){var a=m(e);t(a)}}));return m(a)},e.prototype.getFilterInstanceImpl=function(e,t){var a=this.columnModel.getPrimaryColumn(e);if(a){var r=this.filterManager.getFilterComponent(a,"NO_UI"),o=r&&r.resolveNow(null,(function(e){return e}));return o?setTimeout(t,0,o):r&&r.then((function(e){t(e)})),o}},e.prototype.destroyFilter=function(e){var t=this.columnModel.getPrimaryColumn(e);if(t)return this.filterManager.destroyFilter(t,"filterDestroyed")},e.prototype.getStatusPanel=function(e){if(this.statusBarService)return m(this.statusBarService.getStatusPanel(e))},e.prototype.getColumnDef=function(e){var t=this.columnModel.getPrimaryColumn(e);return t?t.getColDef():null},e.prototype.getColumnDefs=function(){return this.columnModel.getColumnDefs()},e.prototype.onFilterChanged=function(){this.filterManager.onFilterChanged()},e.prototype.onSortChanged=function(){this.sortController.onSortChanged()},e.prototype.setFilterModel=function(e){this.filterManager.setFilterModel(e)},e.prototype.getFilterModel=function(){return this.filterManager.getFilterModel()},e.prototype.getFocusedCell=function(){return this.focusService.getFocusedCell()},e.prototype.clearFocusedCell=function(){return this.focusService.clearFocusedCell()},e.prototype.setFocusedCell=function(e,t,a){this.focusService.setFocusedCell(e,t,a,!0)},e.prototype.setSuppressRowDrag=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_SUPPRESS_ROW_DRAG,e)},e.prototype.setSuppressMoveWhenRowDragging=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_SUPPRESS_MOVE_WHEN_ROW_DRAG,e)},e.prototype.setSuppressRowClickSelection=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_SUPPRESS_ROW_CLICK_SELECTION,e)},e.prototype.addRowDropZone=function(e){this.gridBodyCon.getRowDragFeature().addRowDropZone(e)},e.prototype.removeRowDropZone=function(e){var t=this.dragAndDropService.findExternalZone(e);t&&this.dragAndDropService.removeDropTarget(t)},e.prototype.getRowDropZoneParams=function(e){return this.gridBodyCon.getRowDragFeature().getRowDropZone(e)},e.prototype.setHeaderHeight=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_HEADER_HEIGHT,e)},e.prototype.setDomLayout=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_DOM_LAYOUT,e)},e.prototype.setEnableCellTextSelection=function(e){this.gridBodyCon.setCellTextSelection(e)},e.prototype.setFillHandleDirection=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_FILL_HANDLE_DIRECTION,e)},e.prototype.setGroupHeaderHeight=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_GROUP_HEADER_HEIGHT,e)},e.prototype.setFloatingFiltersHeight=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_FLOATING_FILTERS_HEIGHT,e)},e.prototype.setPivotHeaderHeight=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_PIVOT_HEADER_HEIGHT,e)},e.prototype.setPivotGroupHeaderHeight=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_PIVOT_GROUP_HEADER_HEIGHT,e)},e.prototype.setIsExternalFilterPresent=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_IS_EXTERNAL_FILTER_PRESENT,e)},e.prototype.setDoesExternalFilterPass=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_DOES_EXTERNAL_FILTER_PASS,e)},e.prototype.setNavigateToNextCell=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_NAVIGATE_TO_NEXT_CELL,e)},e.prototype.setTabToNextCell=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_TAB_TO_NEXT_CELL,e)},e.prototype.setTabToNextHeader=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_TAB_TO_NEXT_HEADER,e)},e.prototype.setNavigateToNextHeader=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_NAVIGATE_TO_NEXT_HEADER,e)},e.prototype.setGroupRowAggNodes=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_GROUP_ROW_AGG_NODES,e)},e.prototype.setGetBusinessKeyForNode=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_GET_BUSINESS_KEY_FOR_NODE,e)},e.prototype.setGetChildCount=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_GET_CHILD_COUNT,e)},e.prototype.setProcessRowPostCreate=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_PROCESS_ROW_POST_CREATE,e)},e.prototype.setGetRowNodeId=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_GET_ROW_NODE_ID,e)},e.prototype.setGetRowClass=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_GET_ROW_CLASS,e)},e.prototype.setIsFullWidthCell=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_IS_FULL_WIDTH_CELL,e)},e.prototype.setIsRowSelectable=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_IS_ROW_SELECTABLE,e)},e.prototype.setIsRowMaster=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_IS_ROW_MASTER,e)},e.prototype.setPostSort=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_POST_SORT,e)},e.prototype.setGetDocument=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_GET_DOCUMENT,e)},e.prototype.setGetContextMenuItems=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_GET_CONTEXT_MENU_ITEMS,e)},e.prototype.setGetMainMenuItems=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_GET_MAIN_MENU_ITEMS,e)},e.prototype.setProcessCellForClipboard=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_PROCESS_CELL_FOR_CLIPBOARD,e)},e.prototype.setSendToClipboard=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_SEND_TO_CLIPBOARD,e)},e.prototype.setProcessCellFromClipboard=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_PROCESS_CELL_FROM_CLIPBOARD,e)},e.prototype.setProcessSecondaryColDef=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_PROCESS_TO_SECONDARY_COLDEF,e)},e.prototype.setProcessSecondaryColGroupDef=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_PROCESS_SECONDARY_COL_GROUP_DEF,e)},e.prototype.setPostProcessPopup=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_POST_PROCESS_POPUP,e)},e.prototype.setDefaultGroupOrderComparator=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_DEFAULT_GROUP_ORDER_COMPARATOR,e)},e.prototype.setGetChartToolbarItems=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_GET_CHART_TOOLBAR_ITEMS,e)},e.prototype.setPaginationNumberFormatter=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_PAGINATION_NUMBER_FORMATTER,e)},e.prototype.setGetServerSideStoreParams=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_GET_SERVER_SIDE_STORE_PARAMS,e)},e.prototype.setIsServerSideGroupOpenByDefault=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_IS_SERVER_SIDE_GROUPS_OPEN_BY_DEFAULT,e)},e.prototype.setIsApplyServerSideTransaction=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_IS_APPLY_SERVER_SIDE_TRANSACTION,e)},e.prototype.setIsServerSideGroup=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_IS_SERVER_SIDE_GROUP,e)},e.prototype.setGetServerSideGroupKey=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_GET_SERVER_SIDE_GROUP_KEY,e)},e.prototype.setGetRowStyle=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_GET_ROW_STYLE,e)},e.prototype.setGetRowHeight=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_GET_ROW_HEIGHT,e)},e.prototype.isSideBarVisible=function(){return!!this.sideBarComp&&this.sideBarComp.isDisplayed()},e.prototype.setSideBarVisible=function(e){this.sideBarComp?this.sideBarComp.setDisplayed(e):e&&console.warn("AG Grid: sideBar is not loaded")},e.prototype.setSideBarPosition=function(e){this.sideBarComp?this.sideBarComp.setSideBarPosition(e):console.warn("AG Grid: sideBar is not loaded")},e.prototype.openToolPanel=function(e){this.sideBarComp?this.sideBarComp.openToolPanel(e):console.warn("AG Grid: toolPanel is only available in AG Grid Enterprise")},e.prototype.closeToolPanel=function(){this.sideBarComp?this.sideBarComp.close():console.warn("AG Grid: toolPanel is only available in AG Grid Enterprise")},e.prototype.getOpenedToolPanel=function(){return this.sideBarComp?this.sideBarComp.openedItem():null},e.prototype.getSideBar=function(){return this.gridOptionsWrapper.getSideBar()},e.prototype.setSideBar=function(e){this.gridOptionsWrapper.setProperty("sideBar",l.a.parse(e))},e.prototype.setSuppressClipboardPaste=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_SUPPRESS_CLIPBOARD_PASTE,e)},e.prototype.isToolPanelShowing=function(){return this.sideBarComp.isToolPanelShowing()},e.prototype.doLayout=function(){Object(h.doOnce)((function(){return console.warn("AG Grid - since version 25.1, doLayout was taken out, as it's not needed. The grid responds to grid size changes automatically")}),"doLayoutDeprecated")},e.prototype.resetRowHeights=function(){if(Object(c.exists)(this.clientSideRowModel)){if(this.columnModel.isAutoRowHeightActive())return void console.warn("AG Grid: calling gridApi.resetRowHeights() makes no sense when using Auto Row Height.");this.clientSideRowModel.resetRowHeights()}},e.prototype.setGroupRemoveSingleChildren=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_GROUP_REMOVE_SINGLE_CHILDREN,e)},e.prototype.setGroupRemoveLowestSingleChildren=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_GROUP_REMOVE_LOWEST_SINGLE_CHILDREN,e)},e.prototype.onRowHeightChanged=function(){this.clientSideRowModel?this.clientSideRowModel.onRowHeightChanged():this.serverSideRowModel&&this.serverSideRowModel.onRowHeightChanged()},e.prototype.getValue=function(e,t){var a=this.columnModel.getPrimaryColumn(e);return Object(c.missing)(a)&&(a=this.columnModel.getGridColumn(e)),Object(c.missing)(a)?null:this.valueService.getValue(a,t)},e.prototype.addEventListener=function(e,t){var a=this.gridOptionsWrapper.useAsyncEvents();this.eventService.addEventListener(e,t,a)},e.prototype.addGlobalListener=function(e){var t=this.gridOptionsWrapper.useAsyncEvents();this.eventService.addGlobalListener(e,t)},e.prototype.removeEventListener=function(e,t){var a=this.gridOptionsWrapper.useAsyncEvents();this.eventService.removeEventListener(e,t,a)},e.prototype.removeGlobalListener=function(e){var t=this.gridOptionsWrapper.useAsyncEvents();this.eventService.removeGlobalListener(e,t)},e.prototype.dispatchEvent=function(e){this.eventService.dispatchEvent(e)},e.prototype.destroy=function(){if(!this.destroyCalled){this.destroyCalled=!0;var e=this.ctrlsService.getGridCtrl();e&&e.destroyGridUi(),this.context.destroy()}},e.prototype.cleanDownReferencesToAvoidMemoryLeakInCaseApplicationIsKeepingReferenceToDestroyedGrid=function(){setTimeout(s.removeAllReferences.bind(window,this,"Grid API"),100)},e.prototype.warnIfDestroyed=function(e){return this.destroyCalled&&console.warn("AG Grid: Grid API method "+e+" was called on a grid that was destroyed."),this.destroyCalled},e.prototype.resetQuickFilter=function(){this.warnIfDestroyed("resetQuickFilter")||this.rowModel.forEachNode((function(e){return e.quickFilterAggregateText=null}))},e.prototype.getRangeSelections=function(){return console.warn("AG Grid: in v20.1.x, api.getRangeSelections() is gone, please use getCellRanges() instead.\n We had to change how cell selections works a small bit to allow charting to integrate. The return type of\n getCellRanges() is a bit different, please check the AG Grid documentation."),null},e.prototype.getCellRanges=function(){return this.rangeService?this.rangeService.getCellRanges():(console.warn("AG Grid: cell range selection is only available in AG Grid Enterprise"),null)},e.prototype.camelCaseToHumanReadable=function(e){return Object(u.camelCaseToHumanText)(e)},e.prototype.addRangeSelection=function(e){console.warn("AG Grid: As of version 21.x, range selection changed slightly to allow charting integration. Please call api.addCellRange() instead of api.addRangeSelection()")},e.prototype.addCellRange=function(e){this.rangeService||console.warn("AG Grid: cell range selection is only available in AG Grid Enterprise"),this.rangeService.addCellRange(e)},e.prototype.clearRangeSelection=function(){this.rangeService||console.warn("AG Grid: cell range selection is only available in AG Grid Enterprise"),this.rangeService.removeAllCellRanges()},e.prototype.undoCellEditing=function(){this.undoRedoService.undo()},e.prototype.redoCellEditing=function(){this.undoRedoService.redo()},e.prototype.getCurrentUndoSize=function(){return this.undoRedoService.getCurrentUndoStackSize()},e.prototype.getCurrentRedoSize=function(){return this.undoRedoService.getCurrentRedoStackSize()},e.prototype.getChartModels=function(){if(d.a.assertRegistered(g.a.RangeSelectionModule,"api.getChartModels")&&d.a.assertRegistered(g.a.GridChartsModule,"api.getChartModels"))return this.chartService.getChartModels()},e.prototype.getChartRef=function(e){if(d.a.assertRegistered(g.a.RangeSelectionModule,"api.getChartRef")&&d.a.assertRegistered(g.a.GridChartsModule,"api.getChartRef"))return this.chartService.getChartRef(e)},e.prototype.getChartImageDataURL=function(e){if(d.a.assertRegistered(g.a.RangeSelectionModule,"api.getChartImageDataURL")&&d.a.assertRegistered(g.a.GridChartsModule,"api.getChartImageDataURL"))return this.chartService.getChartImageDataURL(e)},e.prototype.createRangeChart=function(e){if(d.a.assertRegistered(g.a.RangeSelectionModule,"api.createRangeChart")&&d.a.assertRegistered(g.a.GridChartsModule,"api.createRangeChart"))return this.chartService.createRangeChart(e)},e.prototype.createCrossFilterChart=function(e){if(d.a.assertRegistered(g.a.RangeSelectionModule,"api.createCrossFilterChart")&&d.a.assertRegistered(g.a.GridChartsModule,"api.createCrossFilterChart"))return this.chartService.createCrossFilterChart(e)},e.prototype.restoreChart=function(e,t){if(d.a.assertRegistered(g.a.RangeSelectionModule,"api.restoreChart")&&d.a.assertRegistered(g.a.GridChartsModule,"api.restoreChart"))return this.chartService.restoreChart(e,t)},e.prototype.createPivotChart=function(e){if(d.a.assertRegistered(g.a.RangeSelectionModule,"api.createPivotChart")&&d.a.assertRegistered(g.a.GridChartsModule,"api.createPivotChart"))return this.chartService.createPivotChart(e)},e.prototype.copySelectedRowsToClipboard=function(e){this.clipboardService||console.warn("AG Grid: clipboard is only available in AG Grid Enterprise"),this.clipboardService.copySelectedRowsToClipboard(e)},e.prototype.copySelectedRangeToClipboard=function(e){this.clipboardService||console.warn("AG Grid: clipboard is only available in AG Grid Enterprise"),this.clipboardService.copySelectedRangeToClipboard(e)},e.prototype.copySelectedRangeDown=function(){this.clipboardService||console.warn("AG Grid: clipboard is only available in AG Grid Enterprise"),this.clipboardService.copyRangeDown()},e.prototype.showColumnMenuAfterButtonClick=function(e,t){var a=this.columnModel.getGridColumn(e);this.menuFactory.showMenuAfterButtonClick(a,t,"columnMenu")},e.prototype.showColumnMenuAfterMouseClick=function(e,t){var a=this.columnModel.getGridColumn(e);a||(a=this.columnModel.getPrimaryColumn(e)),a?this.menuFactory.showMenuAfterMouseEvent(a,t):console.error("AG Grid: column '"+e+"' not found")},e.prototype.hidePopupMenu=function(){this.contextMenuFactory&&this.contextMenuFactory.hideActiveMenu(),this.menuFactory.hideActiveMenu()},e.prototype.setPopupParent=function(e){this.gridOptionsWrapper.setProperty(r.a.PROP_POPUP_PARENT,e)},e.prototype.tabToNextCell=function(e){return this.navigationService.tabToNextCell(!1,e)},e.prototype.tabToPreviousCell=function(e){return this.navigationService.tabToNextCell(!0,e)},e.prototype.getCellRendererInstances=function(e){return void 0===e&&(e={}),this.rowRenderer.getCellRendererInstances(e).map(m)},e.prototype.getCellEditorInstances=function(e){return void 0===e&&(e={}),this.rowRenderer.getCellEditorInstances(e).map(m)},e.prototype.getEditingCells=function(){return this.rowRenderer.getEditingCells()},e.prototype.stopEditing=function(e){void 0===e&&(e=!1),this.rowRenderer.stopEditing(e)},e.prototype.startEditingCell=function(e){var t=this.columnModel.getGridColumn(e.colKey);if(t){var a={rowIndex:e.rowIndex,rowPinned:e.rowPinned||null,column:t};null==e.rowPinned&&this.gridBodyCon.getScrollFeature().ensureIndexVisible(e.rowIndex);var r=this.navigationService.getCellByPosition(a);r&&r.startRowOrCellEdit(e.key,e.charPress)}else console.warn("AG Grid: no column found for "+e.colKey)},e.prototype.addAggFunc=function(e,t){this.aggFuncService&&this.aggFuncService.addAggFunc(e,t)},e.prototype.addAggFuncs=function(e){this.aggFuncService&&this.aggFuncService.addAggFuncs(e)},e.prototype.clearAggFuncs=function(){this.aggFuncService&&this.aggFuncService.clear()},e.prototype.applyServerSideTransaction=function(e){if(this.serverSideTransactionManager)return this.serverSideTransactionManager.applyTransaction(e);console.warn("AG Grid: Cannot apply Server Side Transaction if not using the Server Side Row Model.")},e.prototype.applyServerSideTransactionAsync=function(e,t){if(this.serverSideTransactionManager)return this.serverSideTransactionManager.applyTransactionAsync(e,t);console.warn("AG Grid: Cannot apply Server Side Transaction if not using the Server Side Row Model.")},e.prototype.retryServerSideLoads=function(){this.serverSideRowModel?this.serverSideRowModel.retryLoads():console.warn("AG Grid: API retryServerSideLoads() can only be used when using Server-Side Row Model.")},e.prototype.flushServerSideAsyncTransactions=function(){if(this.serverSideTransactionManager)return this.serverSideTransactionManager.flushAsyncTransactions();console.warn("AG Grid: Cannot flush Server Side Transaction if not using the Server Side Row Model.")},e.prototype.applyTransaction=function(e){if(this.clientSideRowModel){var t=this.clientSideRowModel.updateRowData(e);return this.rowRenderer.refreshFullWidthRows(t.update),this.gridOptionsWrapper.isSuppressChangeDetection()||this.rowRenderer.refreshCells(),t}console.error("AG Grid: updateRowData() only works with ClientSideRowModel. Working with InfiniteRowModel was deprecated in v23.1 and removed in v24.1")},e.prototype.updateRowData=function(e){return Object(h.doOnce)((function(){return console.warn("AG Grid: as of v23.1, grid API updateRowData(transaction) is now called applyTransaction(transaction). updateRowData is deprecated and will be removed in a future major release.")}),"updateRowData deprecated"),this.applyTransaction(e)},e.prototype.applyTransactionAsync=function(e,t){this.clientSideRowModel?this.clientSideRowModel.batchUpdateRowData(e,t):console.error("AG Grid: api.applyTransactionAsync() only works with ClientSideRowModel.")},e.prototype.flushAsyncTransactions=function(){this.clientSideRowModel?this.clientSideRowModel.flushAsyncTransactions():console.error("AG Grid: api.applyTransactionAsync() only works with ClientSideRowModel.")},e.prototype.batchUpdateRowData=function(e,t){Object(h.doOnce)((function(){return console.warn("AG Grid: as of v23.1, grid API batchUpdateRowData(transaction, callback) is now called applyTransactionAsync(transaction, callback). batchUpdateRowData is deprecated and will be removed in a future major release.")}),"batchUpdateRowData deprecated"),this.applyTransactionAsync(e,t)},e.prototype.insertItemsAtIndex=function(e,t,a){void 0===a&&(a=!1),console.warn("AG Grid: insertItemsAtIndex() is deprecated, use updateRowData(transaction) instead."),this.updateRowData({add:t,addIndex:e,update:null,remove:null})},e.prototype.removeItems=function(e,t){void 0===t&&(t=!1),console.warn("AG Grid: removeItems() is deprecated, use updateRowData(transaction) instead.");var a=e.map((function(e){return e.data}));this.updateRowData({add:null,addIndex:null,update:null,remove:a})},e.prototype.addItems=function(e,t){void 0===t&&(t=!1),console.warn("AG Grid: addItems() is deprecated, use updateRowData(transaction) instead."),this.updateRowData({add:e,addIndex:null,update:null,remove:null})},e.prototype.refreshVirtualPageCache=function(){console.warn("AG Grid: refreshVirtualPageCache() is now called refreshInfiniteCache(), please call refreshInfiniteCache() instead"),this.refreshInfiniteCache()},e.prototype.refreshInfinitePageCache=function(){console.warn("AG Grid: refreshInfinitePageCache() is now called refreshInfiniteCache(), please call refreshInfiniteCache() instead"),this.refreshInfiniteCache()},e.prototype.refreshInfiniteCache=function(){this.infiniteRowModel?this.infiniteRowModel.refreshCache():console.warn("AG Grid: api.refreshInfiniteCache is only available when rowModelType='infinite'.")},e.prototype.purgeVirtualPageCache=function(){console.warn("AG Grid: purgeVirtualPageCache() is now called purgeInfiniteCache(), please call purgeInfiniteCache() instead"),this.purgeInfinitePageCache()},e.prototype.purgeInfinitePageCache=function(){console.warn("AG Grid: purgeInfinitePageCache() is now called purgeInfiniteCache(), please call purgeInfiniteCache() instead"),this.purgeInfiniteCache()},e.prototype.purgeInfiniteCache=function(){this.infiniteRowModel?this.infiniteRowModel.purgeCache():console.warn("AG Grid: api.purgeInfiniteCache is only available when rowModelType='infinite'.")},e.prototype.purgeEnterpriseCache=function(e){console.warn("ag-grid: since version 18.x, api.purgeEnterpriseCache() should be replaced with api.purgeServerSideCache()"),this.purgeServerSideCache(e)},e.prototype.purgeServerSideCache=function(e){void 0===e&&(e=[]),this.serverSideRowModel?(console.warn("AG Grid: since v25.0, api.purgeServerSideCache is deprecated. Please use api.refreshServerSideStore({purge: true}) instead."),this.refreshServerSideStore({route:e,purge:!0})):console.warn("AG Grid: api.purgeServerSideCache is only available when rowModelType='serverSide'.")},e.prototype.refreshServerSideStore=function(e){this.serverSideRowModel?this.serverSideRowModel.refreshStore(e):console.warn("AG Grid: api.refreshServerSideStore is only available when rowModelType='serverSide'.")},e.prototype.getServerSideStoreState=function(){return this.serverSideRowModel?this.serverSideRowModel.getStoreState():(console.warn("AG Grid: api.getServerSideStoreState is only available when rowModelType='serverSide'."),[])},e.prototype.getVirtualRowCount=function(){return console.warn("AG Grid: getVirtualRowCount() is now called getInfiniteRowCount(), please call getInfiniteRowCount() instead"),this.getInfiniteRowCount()},e.prototype.getInfiniteRowCount=function(){if(this.infiniteRowModel)return this.infiniteRowModel.getRowCount();console.warn("AG Grid: api.getVirtualRowCount is only available when rowModelType='virtual'.")},e.prototype.isMaxRowFound=function(){return console.warn("AG Grid: api.isLastRowIndexKnown is deprecated, please use api.isLastRowIndexKnown()"),this.isLastRowIndexKnown()},e.prototype.isLastRowIndexKnown=function(){if(this.infiniteRowModel)return this.infiniteRowModel.isLastRowIndexKnown();console.warn("AG Grid: api.isMaxRowFound is only available when rowModelType='virtual'.")},e.prototype.setVirtualRowCount=function(e,t){console.warn("AG Grid: setVirtualRowCount() is now called setInfiniteRowCount(), please call setInfiniteRowCount() instead"),this.setRowCount(e,t)},e.prototype.setInfiniteRowCount=function(e,t){console.warn("AG Grid: setInfiniteRowCount() is now called setRowCount(), please call setRowCount() instead"),this.setRowCount(e,t)},e.prototype.setRowCount=function(e,t){this.infiniteRowModel?this.infiniteRowModel.setRowCount(e,t):console.warn("AG Grid: api.setRowCount is only available for Infinite Row Model.")},e.prototype.getVirtualPageState=function(){return console.warn("AG Grid: getVirtualPageState() is now called getCacheBlockState(), please call getCacheBlockState() instead"),this.getCacheBlockState()},e.prototype.getInfinitePageState=function(){return console.warn("AG Grid: getInfinitePageState() is now called getCacheBlockState(), please call getCacheBlockState() instead"),this.getCacheBlockState()},e.prototype.getCacheBlockState=function(){return this.rowNodeBlockLoader.getBlockState()},e.prototype.checkGridSize=function(){console.warn("in AG Grid v25.2.0, checkGridSize() was removed, as it was legacy and didn't do anything uesful.")},e.prototype.getFirstRenderedRow=function(){return console.warn("in AG Grid v12, getFirstRenderedRow() was renamed to getFirstDisplayedRow()"),this.getFirstDisplayedRow()},e.prototype.getFirstDisplayedRow=function(){return this.rowRenderer.getFirstVirtualRenderedRow()},e.prototype.getLastRenderedRow=function(){return console.warn("in AG Grid v12, getLastRenderedRow() was renamed to getLastDisplayedRow()"),this.getLastDisplayedRow()},e.prototype.getLastDisplayedRow=function(){return this.rowRenderer.getLastVirtualRenderedRow()},e.prototype.getDisplayedRowAtIndex=function(e){return this.rowModel.getRow(e)},e.prototype.getDisplayedRowCount=function(){return this.rowModel.getRowCount()},e.prototype.paginationIsLastPageFound=function(){return this.paginationProxy.isLastPageFound()},e.prototype.paginationGetPageSize=function(){return this.paginationProxy.getPageSize()},e.prototype.paginationSetPageSize=function(e){this.gridOptionsWrapper.setProperty("paginationPageSize",e)},e.prototype.paginationGetCurrentPage=function(){return this.paginationProxy.getCurrentPage()},e.prototype.paginationGetTotalPages=function(){return this.paginationProxy.getTotalPages()},e.prototype.paginationGetRowCount=function(){return this.paginationProxy.getMasterRowCount()},e.prototype.paginationGoToNextPage=function(){this.paginationProxy.goToNextPage()},e.prototype.paginationGoToPreviousPage=function(){this.paginationProxy.goToPreviousPage()},e.prototype.paginationGoToFirstPage=function(){this.paginationProxy.goToFirstPage()},e.prototype.paginationGoToLastPage=function(){this.paginationProxy.goToLastPage()},e.prototype.paginationGoToPage=function(e){this.paginationProxy.goToPage(e)},f([Object(n.d)("immutableService")],e.prototype,"immutableService",void 0),f([Object(n.d)("csvCreator")],e.prototype,"csvCreator",void 0),f([Object(n.d)("excelCreator")],e.prototype,"excelCreator",void 0),f([Object(n.a)("rowRenderer")],e.prototype,"rowRenderer",void 0),f([Object(n.a)("navigationService")],e.prototype,"navigationService",void 0),f([Object(n.a)("filterManager")],e.prototype,"filterManager",void 0),f([Object(n.a)("columnModel")],e.prototype,"columnModel",void 0),f([Object(n.a)("selectionService")],e.prototype,"selectionService",void 0),f([Object(n.a)("gridOptionsWrapper")],e.prototype,"gridOptionsWrapper",void 0),f([Object(n.a)("valueService")],e.prototype,"valueService",void 0),f([Object(n.a)("alignedGridsService")],e.prototype,"alignedGridsService",void 0),f([Object(n.a)("eventService")],e.prototype,"eventService",void 0),f([Object(n.a)("pinnedRowModel")],e.prototype,"pinnedRowModel",void 0),f([Object(n.a)("context")],e.prototype,"context",void 0),f([Object(n.a)("rowModel")],e.prototype,"rowModel",void 0),f([Object(n.a)("sortController")],e.prototype,"sortController",void 0),f([Object(n.a)("paginationProxy")],e.prototype,"paginationProxy",void 0),f([Object(n.a)("focusService")],e.prototype,"focusService",void 0),f([Object(n.a)("dragAndDropService")],e.prototype,"dragAndDropService",void 0),f([Object(n.d)("rangeService")],e.prototype,"rangeService",void 0),f([Object(n.d)("clipboardService")],e.prototype,"clipboardService",void 0),f([Object(n.d)("aggFuncService")],e.prototype,"aggFuncService",void 0),f([Object(n.a)("menuFactory")],e.prototype,"menuFactory",void 0),f([Object(n.d)("contextMenuFactory")],e.prototype,"contextMenuFactory",void 0),f([Object(n.a)("valueCache")],e.prototype,"valueCache",void 0),f([Object(n.a)("animationFrameService")],e.prototype,"animationFrameService",void 0),f([Object(n.d)("statusBarService")],e.prototype,"statusBarService",void 0),f([Object(n.d)("chartService")],e.prototype,"chartService",void 0),f([Object(n.d)("undoRedoService")],e.prototype,"undoRedoService",void 0),f([Object(n.d)("rowNodeBlockLoader")],e.prototype,"rowNodeBlockLoader",void 0),f([Object(n.d)("ssrmTransactionManager")],e.prototype,"serverSideTransactionManager",void 0),f([Object(n.a)("ctrlsService")],e.prototype,"ctrlsService",void 0),f([Object(n.d)("frameworkComponentWrapper")],e.prototype,"frameworkComponentWrapper",void 0),f([n.e],e.prototype,"init",null),f([n.g],e.prototype,"cleanDownReferencesToAvoidMemoryLeakInCaseApplicationIsKeepingReferenceToDestroyedGrid",null),e=f([Object(n.b)("gridApi")],e)}()},function(e,t,a){"use strict";a.d(t,"a",(function(){return o}));var r=a(1),o=function(){function e(){}return e.getHeaderClassesFromColDef=function(e,t,a,o){return Object(r.missing)(e)?[]:this.getColumnClassesFromCollDef(e.headerClass,e,t,a,o)},e.getToolPanelClassesFromColDef=function(e,t,a,o){return Object(r.missing)(e)?[]:this.getColumnClassesFromCollDef(e.toolPanelClass,e,t,a,o)},e.getClassParams=function(e,t,a,r){return{colDef:e,column:a,columnGroup:r,context:t.getContext(),api:t.getApi()}},e.getColumnClassesFromCollDef=function(e,t,a,o,n){if(Object(r.missing)(e))return[];var i;"function"==typeof e?i=e(this.getClassParams(t,a,o,n)):i=e;return"string"==typeof i?[i]:Array.isArray(i)?i:[]},e}()},function(e,t,a){"use strict";a.d(t,"a",(function(){return c}));var r,o=a(0),n=a(74),i=a(13),l=a(5),g=a(20),p=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),d=function(){return(d=Object.assign||function(e){for(var t,a=1,r=arguments.length;a=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},c=function(e){function t(t){var a=e.call(this,d(d({},t),{popup:!0}))||this;return a.isMaximizable=!1,a.isMaximized=!1,a.maximizeListeners=[],a.resizeListenerDestroy=null,a.lastPosition={x:0,y:0,width:0,height:0},a}return p(t,e),t.prototype.postConstruct=function(){var t=this,a=this.getGui(),r=this.config,o=r.movable,n=r.resizable,i=r.maximizable;this.addCssClass("ag-dialog"),e.prototype.postConstruct.call(this),this.addManagedListener(a,"focusin",(function(e){a.contains(e.relatedTarget)||t.popupService.bringPopupToFront(a)})),o&&this.setMovable(o),i&&this.setMaximizable(i),n&&this.setResizable(n)},t.prototype.renderComponent=function(){var e=this.getGui(),t=this.config,a=t.alwaysOnTop,r=t.modal,o=t.title,n=this.gridOptionsWrapper.getLocaleTextFunc(),i=this.popupService.addPopup({modal:r,eChild:e,closeOnEsc:!0,closedCallback:this.destroy.bind(this),alwaysOnTop:a,ariaLabel:o||n("ariaLabelDialog","Dialog")});i&&(this.close=i.hideFunc)},t.prototype.toggleMaximize=function(){var e=this.positionableFeature.getPosition();if(this.isMaximized){var t=this.lastPosition,a=t.x,r=t.y,o=t.width,n=t.height;this.setWidth(o),this.setHeight(n),this.positionableFeature.offsetElement(a,r)}else this.lastPosition.width=this.getWidth(),this.lastPosition.height=this.getHeight(),this.lastPosition.x=e.x,this.lastPosition.y=e.y,this.positionableFeature.offsetElement(0,0),this.setHeight("100%"),this.setWidth("100%");this.isMaximized=!this.isMaximized,this.refreshMaximizeIcon()},t.prototype.refreshMaximizeIcon=function(){Object(l.setDisplayed)(this.maximizeIcon,!this.isMaximized),Object(l.setDisplayed)(this.minimizeIcon,this.isMaximized)},t.prototype.clearMaximizebleListeners=function(){this.maximizeListeners.length&&(this.maximizeListeners.forEach((function(e){return e()})),this.maximizeListeners.length=0),this.resizeListenerDestroy&&(this.resizeListenerDestroy(),this.resizeListenerDestroy=null)},t.prototype.destroy=function(){this.maximizeButtonComp=this.destroyBean(this.maximizeButtonComp),this.clearMaximizebleListeners(),e.prototype.destroy.call(this)},t.prototype.setResizable=function(e){this.positionableFeature.setResizable(e)},t.prototype.setMovable=function(e){this.positionableFeature.setMovable(e,this.eTitleBar)},t.prototype.setMaximizable=function(e){var t=this;if(!e)return this.clearMaximizebleListeners(),void(this.maximizeButtonComp&&(this.destroyBean(this.maximizeButtonComp),this.maximizeButtonComp=this.maximizeIcon=this.minimizeIcon=void 0));var a=this.eTitleBar;if(a&&e!==this.isMaximizable){var r=this.maximizeButtonComp=this.createBean(new i.a('
')),o=r.getGui();o.appendChild(this.maximizeIcon=Object(g.createIconNoSpan)("maximize",this.gridOptionsWrapper)),this.maximizeIcon.classList.add("ag-panel-title-bar-button-icon"),o.appendChild(this.minimizeIcon=Object(g.createIconNoSpan)("minimize",this.gridOptionsWrapper)),this.minimizeIcon.classList.add("ag-panel-title-bar-button-icon","ag-hidden"),r.addManagedListener(o,"click",this.toggleMaximize.bind(this)),this.addTitleBarButton(r,0),this.maximizeListeners.push(this.addManagedListener(a,"dblclick",this.toggleMaximize.bind(this))),this.resizeListenerDestroy=this.addManagedListener(this,"resize",(function(){t.isMaximized=!1,t.refreshMaximizeIcon()}))}},s([Object(o.a)("popupService")],t.prototype,"popupService",void 0),t}(n.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return c}));var r,o=a(7),n=a(0),i=a(13),l=a(5),g=a(20),p=a(151),d=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),s=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},c=function(e){function t(a){var r=e.call(this,t.getTemplate(a))||this;return r.closable=!0,r.config=a,r}return d(t,e),t.getTemplate=function(e){var t=e&&e.cssIdentifier||"default";return'
\n
\n \n
\n
\n
\n
'},t.prototype.postConstruct=function(){var e=this,t=this.config,a=t.component,r=t.closable,o=t.hideTitleBar,n=t.title,i=t.minWidth,l=void 0===i?250:i,g=t.width,d=t.minHeight,s=void 0===d?250:d,c=t.height,u=t.centered,h=t.popup,f=t.x,m=t.y;this.positionableFeature=new p.a(this.getGui(),{minWidth:l,width:g,minHeight:s,height:c,centered:u,x:f,y:m,popup:h,calculateTopBuffer:function(){return e.positionableFeature.getHeight()-e.getBodyHeight()}}),this.createManagedBean(this.positionableFeature);var b=this.getGui();a&&this.setBodyComponent(a),o?this.eTitleBar.classList.add("ag-hidden"):(n&&this.setTitle(n),this.setClosable(null!=r?r:this.closable)),this.addManagedListener(this.eTitleBar,"mousedown",(function(t){var a=e.gridOptionsWrapper.getDocument();if(b.contains(t.relatedTarget)||b.contains(a.activeElement)||e.eTitleBarButtons.contains(t.target))t.preventDefault();else{var r=e.eContentWrapper.querySelector("button, [href], input, select, textarea, [tabindex]");r&&r.focus()}})),h&&this.positionableFeature.isPositioned()||(this.renderComponent&&this.renderComponent(),this.positionableFeature.initialisePosition(),this.eContentWrapper.style.height="0")},t.prototype.renderComponent=function(){var e=this,t=this.getGui();t.focus(),this.close=function(){t.parentElement.removeChild(t),e.destroy()}},t.prototype.getHeight=function(){return this.positionableFeature.getHeight()},t.prototype.setHeight=function(e){this.positionableFeature.setHeight(e)},t.prototype.getWidth=function(){return this.positionableFeature.getWidth()},t.prototype.setWidth=function(e){this.positionableFeature.setWidth(e)},t.prototype.setClosable=function(e){if(e!==this.closable&&(this.closable=e),e){var a=this.closeButtonComp=new i.a(t.CLOSE_BTN_TEMPLATE);this.getContext().createBean(a);var r=a.getGui(),o=Object(g.createIconNoSpan)("close",this.gridOptionsWrapper);o.classList.add("ag-panel-title-bar-button-icon"),r.appendChild(o),this.addTitleBarButton(a),a.addManagedListener(r,"click",this.onBtClose.bind(this))}else if(this.closeButtonComp){(r=this.closeButtonComp.getGui()).parentElement.removeChild(r),this.closeButtonComp=this.destroyBean(this.closeButtonComp)}},t.prototype.setBodyComponent=function(e){e.setParentComponent(this),this.eContentWrapper.appendChild(e.getGui())},t.prototype.addTitleBarButton=function(e,t){var a=this.eTitleBarButtons,r=a.children,o=r.length;null==t&&(t=o),t=Math.max(0,Math.min(t,o)),e.addCssClass("ag-panel-title-bar-button");var n=e.getGui();0===t?a.insertAdjacentElement("afterbegin",n):t===o?a.insertAdjacentElement("beforeend",n):r[t-1].insertAdjacentElement("afterend",n),e.setParentComponent(this)},t.prototype.getBodyHeight=function(){return Object(l.getInnerHeight)(this.eContentWrapper)},t.prototype.getBodyWidth=function(){return Object(l.getInnerWidth)(this.eContentWrapper)},t.prototype.setTitle=function(e){this.eTitle.innerText=e},t.prototype.onBtClose=function(){this.close()},t.prototype.destroy=function(){this.closeButtonComp&&(this.closeButtonComp=this.destroyBean(this.closeButtonComp));var t=this.getGui();t&&t.offsetParent&&this.close(),e.prototype.destroy.call(this)},t.CLOSE_BTN_TEMPLATE='
',s([Object(o.b)("eContentWrapper")],t.prototype,"eContentWrapper",void 0),s([Object(o.b)("eTitleBar")],t.prototype,"eTitleBar",void 0),s([Object(o.b)("eTitleBarButtons")],t.prototype,"eTitleBarButtons",void 0),s([Object(o.b)("eTitle")],t.prototype,"eTitle",void 0),s([n.e],t.prototype,"postConstruct",null),t}(i.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return l}));var r,o=a(43),n=a(1),i=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),l=function(e){function t(t,a,r){return void 0===a&&(a="ag-text-field"),void 0===r&&(r="text"),e.call(this,t,a,r)||this}return i(t,e),t.prototype.postConstruct=function(){e.prototype.postConstruct.call(this),this.config.allowedCharPattern&&this.preventDisallowedCharacters()},t.prototype.setValue=function(t,a){var r=e.prototype.setValue.call(this,t,a);return this.eInput.value!==t&&(this.eInput.value=Object(n.exists)(t)?t:""),r},t.prototype.preventDisallowedCharacters=function(){var e=new RegExp("["+this.config.allowedCharPattern+"]");this.addManagedListener(this.eInput,"keypress",(function(t){t.key&&!e.test(t.key)&&t.preventDefault()})),this.addManagedListener(this.eInput,"paste",(function(t){var a,r=null===(a=t.clipboardData)||void 0===a?void 0:a.getData("text");r&&r.split("").some((function(t){return!e.test(t)}))&&t.preventDefault()}))},t}(o.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return b}));var r,o=a(37),n=a(179),i=a(13),l=a(0),g=a(27),p=a(8),d=a(11),s=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),c=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},u=function(e){function t(t){void 0===t&&(t="default");var a=e.call(this,'
')||this;return a.cssIdentifier=t,a.options=[],a.itemEls=[],a}return s(t,e),t.prototype.init=function(){this.addManagedListener(this.getGui(),"keydown",this.handleKeyDown.bind(this))},t.prototype.handleKeyDown=function(e){var t=e.key;switch(t){case p.a.ENTER:if(this.highlightedEl){var a=this.itemEls.indexOf(this.highlightedEl);this.setValueByIndex(a)}else this.setValue(this.getValue());break;case p.a.DOWN:case p.a.UP:var r=t===p.a.DOWN,o=void 0;if(e.preventDefault(),this.highlightedEl){var n=this.itemEls.indexOf(this.highlightedEl)+(r?1:-1);n=Math.min(Math.max(n,0),this.itemEls.length-1),o=this.itemEls[n]}else o=this.itemEls[r?0:this.itemEls.length-1];this.highlightItem(o)}},t.prototype.addOptions=function(e){var t=this;return e.forEach((function(e){return t.addOption(e)})),this},t.prototype.addOption=function(e){var t=e.value,a=e.text,r=Object(g.escapeString)(a||t);return this.options.push({value:t,text:r}),this.renderOption(t,r),this.updateIndices(),this},t.prototype.updateIndices=function(){var e=this.getGui().querySelectorAll(".ag-list-item");e.forEach((function(t,a){Object(d.setAriaPosInSet)(t,a+1),Object(d.setAriaSetSize)(t,e.length)}))},t.prototype.renderOption=function(e,t){var a=this,r=document.createElement("div");Object(d.setAriaRole)(r,"option"),r.classList.add("ag-list-item","ag-"+this.cssIdentifier+"-list-item"),r.innerHTML=""+t+"",r.tabIndex=-1,this.itemEls.push(r),this.addManagedListener(r,"mouseover",(function(){return a.highlightItem(r)})),this.addManagedListener(r,"mouseleave",(function(){return a.clearHighlighted()})),this.addManagedListener(r,"click",(function(){return a.setValue(e)})),this.getGui().appendChild(r)},t.prototype.setValue=function(e,t){if(this.value===e)return this.fireItemSelected(),this;if(null==e)return this.reset(),this;var a=this.options.findIndex((function(t){return t.value===e}));if(-1!==a){var r=this.options[a];this.value=r.value,this.displayValue=null!=r.text?r.text:r.value,this.highlightItem(this.itemEls[a]),t||this.fireChangeEvent()}return this},t.prototype.setValueByIndex=function(e){return this.setValue(this.options[e].value)},t.prototype.getValue=function(){return this.value},t.prototype.getDisplayValue=function(){return this.displayValue},t.prototype.refreshHighlighted=function(){var e=this;this.clearHighlighted();var t=this.options.findIndex((function(t){return t.value===e.value}));-1!==t&&this.highlightItem(this.itemEls[t])},t.prototype.reset=function(){this.value=null,this.displayValue=null,this.clearHighlighted(),this.fireChangeEvent()},t.prototype.highlightItem=function(e){e.offsetParent&&(this.clearHighlighted(),this.highlightedEl=e,this.highlightedEl.classList.add(t.ACTIVE_CLASS),Object(d.setAriaSelected)(this.highlightedEl,!0),this.highlightedEl.focus())},t.prototype.clearHighlighted=function(){this.highlightedEl&&this.highlightedEl.offsetParent&&(this.highlightedEl.classList.remove(t.ACTIVE_CLASS),Object(d.setAriaSelected)(this.highlightedEl,!1),this.highlightedEl=null)},t.prototype.fireChangeEvent=function(){this.dispatchEvent({type:o.a.EVENT_CHANGED}),this.fireItemSelected()},t.prototype.fireItemSelected=function(){this.dispatchEvent({type:t.EVENT_ITEM_SELECTED})},t.EVENT_ITEM_SELECTED="selectedItem",t.ACTIVE_CLASS="ag-active-item",c([l.e],t.prototype,"init",null),t}(i.a),h=a(5),f=function(){var e=function(t,a){return(e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(t,a)};return function(t,a){function r(){this.constructor=t}e(t,a),t.prototype=null===a?Object.create(a):(r.prototype=a.prototype,new r)}}(),m=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},b=function(e){function t(t){return e.call(this,t,"ag-select","smallDown","listbox")||this}return f(t,e),t.prototype.init=function(){var e=this;this.listComponent=this.createBean(new u("select")),this.listComponent.setParentComponent(this),this.eWrapper.tabIndex=0,this.listComponent.addManagedListener(this.listComponent,u.EVENT_ITEM_SELECTED,(function(){e.hideList&&e.hideList()})),this.listComponent.addManagedListener(this.listComponent,o.a.EVENT_CHANGED,(function(){e.setValue(e.listComponent.getValue(),!1,!0),e.hideList&&e.hideList()}))},t.prototype.showPicker=function(){var e=this,t=this.listComponent.getGui(),a=this.gridOptionsWrapper.getDocument(),r=this.addManagedListener(a.body,"wheel",(function(a){!t.contains(a.target)&&e.hideList&&e.hideList()})),o=this.addManagedListener(t,"focusout",(function(a){!t.contains(a.relatedTarget)&&e.hideList&&e.hideList()})),n=this.gridOptionsWrapper.getLocaleTextFunc(),i=this.popupService.addPopup({modal:!0,eChild:t,closeOnEsc:!0,closedCallback:function(){e.hideList=null,e.isPickerDisplayed=!1,o(),r(),e.isAlive()&&(Object(d.setAriaExpanded)(e.eWrapper,!1),e.getFocusableElement().focus())},ariaLabel:n("ariaLabelSelectField","Select Field")});return i&&(this.hideList=i.hideFunc),this.isPickerDisplayed=!0,Object(h.setElementWidth)(t,Object(h.getAbsoluteWidth)(this.eWrapper)),Object(d.setAriaExpanded)(this.eWrapper,!0),t.style.maxHeight=Object(h.getInnerHeight)(this.popupService.getPopupParent())+"px",t.style.position="absolute",this.popupService.positionPopupUnderComponent({type:"ag-list",eventSource:this.eWrapper,ePopup:t,keepWithinBounds:!0}),this.listComponent.refreshHighlighted(),this.listComponent},t.prototype.addOptions=function(e){var t=this;return e.forEach((function(e){return t.addOption(e)})),this},t.prototype.addOption=function(e){return this.listComponent.addOption(e),this},t.prototype.setValue=function(t,a,r){return this.value===t?this:(r||this.listComponent.setValue(t,!0),this.listComponent.getValue()===this.getValue()?this:(this.eDisplayField.innerHTML=this.listComponent.getDisplayValue(),e.prototype.setValue.call(this,t,a)))},t.prototype.destroy=function(){this.hideList&&this.hideList(),this.destroyBean(this.listComponent),e.prototype.destroy.call(this)},m([Object(l.a)("popupService")],t.prototype,"popupService",void 0),m([l.e],t.prototype,"init",null),t}(n.a)},function(e,t,a){"use strict";function r(e,t,a){if(0===a)return!1;var r=Math.abs(e.clientX-t.clientX),o=Math.abs(e.clientY-t.clientY);return Math.max(r,o)<=a}a.r(t),a.d(t,"areEventsNear",(function(){return r}))},function(e,t,a){"use strict";function r(e){var t=new Set;return e.forEach((function(e){return t.add(e)})),t}a.r(t),a.d(t,"convertToSet",(function(){return r}))},function(e,t,a){"use strict";a.d(t,"a",(function(){return d}));var r,o=a(13),n=a(0),i=a(5),l=a(11),g=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),p=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},d=function(e){function t(t,a){var r=e.call(this,a)||this;return r.labelSeparator="",r.labelAlignment="left",r.label="",r.config=t||{},r}return g(t,e),t.prototype.postConstruct=function(){this.addCssClass("ag-labeled"),this.eLabel.classList.add("ag-label");var e=this.config,t=e.labelSeparator,a=e.label,r=e.labelWidth,o=e.labelAlignment;null!=t&&this.setLabelSeparator(t),null!=a&&this.setLabel(a),null!=r&&this.setLabelWidth(r),this.setLabelAlignment(o||this.labelAlignment),this.refreshLabel()},t.prototype.refreshLabel=function(){Object(i.clearElement)(this.eLabel),"string"==typeof this.label?this.eLabel.innerText=this.label+this.labelSeparator:this.label&&this.eLabel.appendChild(this.label),""===this.label?(this.eLabel.classList.add("ag-hidden"),Object(l.setAriaRole)(this.eLabel,"presentation")):(this.eLabel.classList.remove("ag-hidden"),Object(l.setAriaRole)(this.eLabel,null))},t.prototype.setLabelSeparator=function(e){return this.labelSeparator===e||(this.labelSeparator=e,null!=this.label&&this.refreshLabel()),this},t.prototype.getLabelId=function(){return this.eLabel.id=this.eLabel.id||"ag-"+this.getCompId()+"-label",this.eLabel.id},t.prototype.getLabel=function(){return this.label},t.prototype.setLabel=function(e){return this.label===e||(this.label=e,this.refreshLabel()),this},t.prototype.setLabelAlignment=function(e){var t=this.getGui().classList;return t.toggle("ag-label-align-left","left"===e),t.toggle("ag-label-align-right","right"===e),t.toggle("ag-label-align-top","top"===e),this},t.prototype.setLabelWidth=function(e){return null==this.label||Object(i.setElementWidth)(this.eLabel,e),this},p([n.e],t.prototype,"postConstruct",null),t}(o.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return l}));var r,o=a(6),n=a(58),i=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),l=function(e){function t(t,a){var r=e.call(this)||this;return r.ctrl=t,r.beans=a,r}return i(t,e),t.prototype.setComp=function(e){this.comp=e,this.setupTooltip()},t.prototype.setupTooltip=function(){this.browserTooltips=this.beans.gridOptionsWrapper.isEnableBrowserTooltips(),this.updateTooltipText(),this.browserTooltips?this.comp.setTitle(null!=this.tooltip?this.tooltip:void 0):this.createTooltipFeatureIfNeeded()},t.prototype.updateTooltipText=function(){this.tooltip=this.ctrl.getTooltipValue()},t.prototype.createTooltipFeatureIfNeeded=function(){var e=this;if(null==this.genericTooltipFeature){var t={getTooltipParams:function(){return e.getTooltipParams()},getGui:function(){return e.ctrl.getGui()}};this.genericTooltipFeature=this.createManagedBean(new n.a(t),this.beans.context)}},t.prototype.refreshToolTip=function(){this.updateTooltipText(),this.browserTooltips&&this.comp.setTitle(null!=this.tooltip?this.tooltip:void 0)},t.prototype.getTooltipParams=function(){var e=this.ctrl,t=e.getColumn?e.getColumn():void 0,a=e.getColDef?e.getColDef():void 0,r=e.getRowNode?e.getRowNode():void 0;return{location:e.getLocation(),colDef:a,column:t,rowIndex:e.getRowIndex?e.getRowIndex():void 0,node:r,data:r?r.data:void 0,value:this.getTooltipText(),valueFormatted:e.getValueFormatted?e.getValueFormatted():void 0}},t.prototype.getTooltipText=function(){return this.tooltip},t.prototype.destroy=function(){e.prototype.destroy.call(this)},t}(o.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return s}));var r,o=a(6),n=a(0),i=a(14),l=a(2),g=a(9),p=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),d=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},s=function(e){function t(t){var a=e.call(this)||this;return a.callback=t,a}return p(t,e),t.prototype.postConstruct=function(){var e=this.setWidth.bind(this);this.addManagedListener(this.gridOptionsWrapper,i.a.PROP_DOM_LAYOUT,e),this.addManagedListener(this.eventService,g.a.EVENT_DISPLAYED_COLUMNS_CHANGED,e),this.addManagedListener(this.eventService,g.a.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED,e),this.setWidth()},t.prototype.setWidth=function(){var e=this.columnModel,t=this.gridOptionsWrapper.getDomLayout()===l.a.DOM_LAYOUT_PRINT,a=e.getBodyContainerWidth(),r=e.getDisplayedColumnsLeftWidth(),o=e.getDisplayedColumnsRightWidth(),n=t?a+r+o:a;this.callback(n)},d([Object(n.a)("columnModel")],t.prototype,"columnModel",void 0),d([n.e],t.prototype,"postConstruct",null),t}(o.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return i}));var r,o=a(13),n=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),i=function(e){function t(t,a){var r=e.call(this,t)||this;return r.ctrl=a,r}return n(t,e),t.prototype.getCtrl=function(){return this.ctrl},t}(o.a)},function(e,t,a){"use strict";a.d(t,"a",(function(){return h}));var r,o=a(2),n=a(0),i=a(5),l=a(12),g=a(13),p=a(7),d=a(36),s=a(116),c=(r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var a in t)t.hasOwnProperty(a)&&(e[a]=t[a])})(e,t)},function(e,t){function a(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(a.prototype=t.prototype,new a)}),u=function(e,t,a,r){var o,n=arguments.length,i=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,a):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,a,r);else for(var l=e.length-1;l>=0;l--)(o=e[l])&&(i=(n<3?o(i):n>3?o(t,a,i):o(t,a))||i);return n>3&&i&&Object.defineProperty(t,a,i),i},h=function(e){function t(t){var a=e.call(this)||this;return a.headerRowComps={},a.rowCompsList=[],a.pinned=t,a}return c(t,e),t.prototype.init=function(){var e=this;this.selectAndSetTemplate();var t={addOrRemoveCssClass:function(t,a){return e.addOrRemoveCssClass(t,a)},setCtrls:function(t){return e.setCtrls(t)},setCenterWidth:function(t){return e.eCenterContainer.style.width=t},setContainerTransform:function(t){return e.eCenterContainer.style.transform=t},setPinnedContainerWidth:function(t){var a=e.getGui();a.style.width=t,a.style.maxWidth=t,a.style.minWidth=t}};this.createManagedBean(new s.a(this.pinned)).setComp(t,this.getGui())},t.prototype.selectAndSetTemplate=function(){var e=this.pinned==o.a.PINNED_LEFT,a=this.pinned==o.a.PINNED_RIGHT,r=e?t.PINNED_LEFT_TEMPLATE:a?t.PINNED_RIGHT_TEMPLATE:t.CENTER_TEMPLATE;this.setTemplate(r),this.eRowContainer=this.eCenterContainer?this.eCenterContainer:this.getGui()},t.prototype.destroyRowComps=function(){this.setCtrls([])},t.prototype.destroyRowComp=function(e){this.destroyBean(e),this.eRowContainer.removeChild(e.getGui())},t.prototype.setCtrls=function(e){var t,a=this,r=this.headerRowComps;this.headerRowComps={},this.rowCompsList=[];e.forEach((function(e){var o=e.getInstanceId(),n=r[o];delete r[o];var l=n||a.createBean(new d.a(e));a.headerRowComps[o]=l,a.rowCompsList.push(l),function(e){var r=e.getGui();r.parentElement!=a.eRowContainer&&a.eRowContainer.appendChild(r),t&&Object(i.ensureDomOrder)(a.eRowContainer,r,t),t=r}(l)})),Object(l.getAllValuesInObject)(r).forEach((function(e){return a.destroyRowComp(e)}))},t.PINNED_LEFT_TEMPLATE='